/* ── DESIGN TOKENS ─────────────────────────────────────────── */
:root{
  --cyan:#00C8E8;--cyan-dark:#0099BB;--cyan-glow:rgba(0,200,232,0.15);
  --navy:#050D1A;--navy2:#0A1828;--navy3:#0F2235;
  --white:#F0F8FF;--muted:rgba(180,220,240,0.55);
  --border:rgba(0,200,232,0.2);--border-strong:rgba(0,200,232,0.45);
  --danger:#FF4D4D;--success:#22E8A0;--warn:#FFB800;--purple:#B07EFF;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:'Exo 2',sans-serif;background:var(--navy);color:var(--white)}

.hidden{display:none}

/* ── LOGIN ─────────────────────────────────────────────────── */
#loginScreen{
  min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:2rem;
  background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(0,200,232,.12) 0%,transparent 70%),var(--navy);
}
.login-logo{
  width:110px;height:110px;border-radius:50%;border:3px solid var(--cyan);
  overflow:hidden;margin-bottom:1.25rem;box-shadow:0 0 32px rgba(0,200,232,.3);
  display:flex;align-items:center;justify-content:center;background:var(--navy2);
}
.login-logo img{width:100%;height:100%;object-fit:cover}
.login-title{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:2px;color:var(--cyan);text-align:center;line-height:1.1;margin-bottom:.2rem}
.login-sub{font-size:.72rem;color:var(--muted);text-align:center;margin-bottom:1.5rem;letter-spacing:1px;text-transform:uppercase}
.login-card{background:var(--navy2);border:1px solid var(--border);border-radius:16px;padding:1.5rem;width:100%;max-width:320px}
.role-tabs{display:flex;gap:6px;margin-bottom:.85rem}
.role-tab{flex:1;padding:6px 4px;border:1px solid var(--border);border-radius:8px;background:none;color:var(--muted);font-family:'Exo 2',sans-serif;font-size:.62rem;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:all .2s;text-align:center}
.role-tab.active{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-glow)}
.role-desc{font-size:.68rem;color:var(--muted);text-align:center;margin-bottom:.85rem;min-height:1.5em}
.login-label{font-size:.68rem;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem;display:block}
.login-input{
  width:100%;background:var(--navy3);border:1px solid var(--border);border-radius:8px;
  padding:.7rem 1rem;color:var(--white);font-family:'Exo 2',sans-serif;
  font-size:1rem;letter-spacing:4px;outline:none;transition:border-color .2s;
  text-align:center;margin-bottom:.85rem;
}
.login-input:focus{border-color:var(--cyan)}
.login-btn{
  width:100%;background:var(--cyan);color:var(--navy);border:none;border-radius:8px;
  padding:.8rem;font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:2px;cursor:pointer;transition:opacity .2s;
}
.login-btn:hover{opacity:.85}
.login-btn:disabled{opacity:.5;cursor:not-allowed}
.login-error{color:var(--danger);font-size:.75rem;text-align:center;margin-top:.6rem;display:none}

/* ── APP SHELL ─────────────────────────────────────────────── */
#app{display:none;flex-direction:column;min-height:100vh}
.topbar{
  background:var(--navy2);border-bottom:1px solid var(--border);
  padding:0 1rem;height:54px;display:flex;align-items:center;gap:10px;
  position:sticky;top:0;z-index:100;
}
.topbar-logo{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--cyan);overflow:hidden;flex-shrink:0;background:var(--navy3);display:flex;align-items:center;justify-content:center}
.topbar-logo img{width:100%;height:100%;object-fit:cover}
.topbar-title{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:1.5px;color:var(--cyan);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.role-chip{font-size:.58rem;letter-spacing:.8px;text-transform:uppercase;padding:3px 8px;border-radius:20px;font-weight:600;white-space:nowrap;flex-shrink:0}
.chip-admin{background:rgba(255,184,0,.12);color:var(--warn);border:1px solid rgba(255,184,0,.3)}
.chip-registrasi{background:rgba(0,200,232,.12);color:var(--cyan);border:1px solid rgba(0,200,232,.3)}
.chip-viewonly{background:rgba(180,220,240,.08);color:var(--muted);border:1px solid rgba(180,220,240,.2)}
.chip-binpres{background:rgba(124,58,237,.12);color:#A78BFA;border:1px solid rgba(124,58,237,.3)}
.chip-klub{background:rgba(34,232,160,.12);color:var(--success);border:1px solid rgba(34,232,160,.3)}
.topbar-logout{background:none;border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:3px 8px;font-size:.62rem;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;font-family:'Exo 2',sans-serif;transition:all .2s;flex-shrink:0}
.topbar-logout:hover{border-color:var(--danger);color:var(--danger)}

.main{flex:1;padding:1rem;padding-bottom:80px;max-width:1200px;margin:0 auto;width:100%}
.section{display:none}
.section.active{display:block}

/* ── CARDS ─────────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin-bottom:1rem}
.stat-card{background:var(--navy2);border:1px solid var(--border);border-radius:12px;padding:.85rem;text-align:center}
.stat-card.hl{border-color:var(--cyan-dark);background:rgba(0,200,232,.07)}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:1.9rem;color:var(--cyan);line-height:1}
.stat-label{font-size:.6rem;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-top:3px}
.pay-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px;margin-bottom:.75rem}
.pay-card{background:var(--navy2);border:1px solid var(--border);border-radius:10px;padding:.7rem;text-align:center}
.pay-num{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;line-height:1}
.pay-lbl{font-size:.58rem;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-top:2px}

/* ── SECTION TITLE ─────────────────────────────────────────── */
.sec-title{font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:2px;color:var(--cyan);margin:.85rem 0 .6rem;display:flex;align-items:center;gap:8px}
.sec-title::after{content:'';flex:1;height:1px;background:var(--border)}
.sec-title:first-child{margin-top:0}

/* ── CONTROLS ──────────────────────────────────────────────── */
.controls{background:var(--navy2);border:1px solid var(--border);border-radius:12px;padding:.85rem;margin-bottom:.75rem;display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end}
.ctrl-group{display:flex;flex-direction:column;gap:3px;flex:1;min-width:130px}
.ctrl-label{font-size:.6rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.ctrl-input,.ctrl-select{background:var(--navy3);border:1px solid var(--border);border-radius:7px;padding:.5rem .7rem;color:var(--white);font-family:'Exo 2',sans-serif;font-size:.8rem;outline:none;transition:border-color .2s}
.ctrl-input:focus,.ctrl-select:focus{border-color:var(--cyan)}
.ctrl-select option{background:var(--navy2)}
.ctrl-btn{background:var(--navy3);border:1px solid var(--border-strong);color:var(--cyan);border-radius:7px;padding:.5rem .85rem;font-family:'Exo 2',sans-serif;font-size:.75rem;cursor:pointer;transition:all .2s;white-space:nowrap;align-self:flex-end}
.ctrl-btn:hover{background:var(--cyan-glow)}
.ctrl-btn.excel{border-color:var(--success);color:var(--success);background:rgba(34,232,160,.06)}
.ctrl-btn.export{display:none;border-color:#1D9E5C;color:#1D9E5C;background:rgba(29,158,92,.06)}
.ctrl-btn:disabled{opacity:.4;cursor:not-allowed}
.ctrl-actions{display:flex;gap:6px;align-self:flex-end;flex-shrink:0}

/* ── TABLE ─────────────────────────────────────────────────── */
.table-wrap{background:var(--navy2);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:.75rem}
.table-top{padding:.6rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}
.table-count{font-size:.7rem;color:var(--muted)}
.table-count span{color:var(--cyan);font-weight:600}
.tbl-outer{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:.78rem}
thead tr{background:var(--navy3);border-bottom:1px solid var(--border-strong)}
th{padding:.55rem .7rem;text-align:left;font-size:.58rem;letter-spacing:1px;text-transform:uppercase;color:var(--cyan);white-space:nowrap;user-select:none}
tbody tr{border-bottom:1px solid rgba(0,200,232,.06);transition:background .15s}
tbody tr:hover{background:rgba(0,200,232,.04)}
tbody tr.dup{border-left:3px solid var(--warn)}
td{padding:.55rem .7rem;vertical-align:middle}
.t-muted{color:var(--muted);font-size:.7rem}
.t-name{font-weight:600}
.t-mono{font-family:monospace;color:var(--muted);font-size:.7rem}
.empty{padding:2.5rem;text-align:center;color:var(--muted);font-size:.82rem}

/* ── BADGES ────────────────────────────────────────────────── */
.badge{display:inline-block;padding:2px 7px;border-radius:20px;font-size:.58rem;letter-spacing:.3px;font-weight:600;white-space:nowrap;margin:1px}
.b-kta{background:rgba(34,232,160,.1);color:var(--success);border:1px solid rgba(34,232,160,.25)}
.b-nokta{background:rgba(255,77,77,.08);color:#FF8080;border:1px solid rgba(255,77,77,.2)}
.b-cat{background:rgba(0,200,232,.1);color:var(--cyan);border:1px solid rgba(0,200,232,.2)}
.b-hunt{background:rgba(255,184,0,.1);color:var(--warn);border:1px solid rgba(255,184,0,.2)}
.b-dup{background:rgba(255,184,0,.1);color:var(--warn);border:1px solid rgba(255,184,0,.2);font-size:.52rem}
.b-menunggu{background:rgba(255,184,0,.1);color:var(--warn);border:1px solid rgba(255,184,0,.25)}
.b-terverifikasi{background:rgba(34,232,160,.1);color:var(--success);border:1px solid rgba(34,232,160,.25)}
.b-ditolak{background:rgba(255,77,77,.1);color:#FF8080;border:1px solid rgba(255,77,77,.2)}
.b-belum{background:rgba(180,220,240,.06);color:var(--muted);border:1px solid rgba(180,220,240,.15)}
.badge-elit{background:rgba(255,184,0,.12);color:var(--warn);border:1px solid rgba(255,184,0,.3)}
.badge-potensial{background:rgba(0,200,232,.1);color:var(--cyan);border:1px solid rgba(0,200,232,.25)}
.badge-pemula{background:rgba(180,220,240,.06);color:var(--muted);border:1px solid rgba(180,220,240,.2)}
.b-kategori{background:rgba(0,200,232,.08);color:var(--cyan);border:1px solid rgba(0,200,232,.2)}
.row-highlight td{background:rgba(0,200,232,.05)}

/* ── LINKS ─────────────────────────────────────────────────── */
.link-bukti{color:var(--cyan);font-size:.68rem;text-decoration:none;display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border:1px solid var(--border);border-radius:5px;transition:all .2s}
.link-bukti:hover{background:var(--cyan-glow);border-color:var(--cyan)}

/* ── ACTION BUTTONS ────────────────────────────────────────── */
.acts{display:flex;gap:4px;flex-wrap:nowrap}
.act-btn{border:none;border-radius:6px;padding:7px 13px;font-family:'Exo 2',sans-serif;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;display:inline-flex;align-items:center;gap:3px}
.act-btn:disabled{opacity:.4;cursor:not-allowed}
.act-verif{background:rgba(34,232,160,.12);color:var(--success);border:1px solid rgba(34,232,160,.28)}
.act-verif:hover:not(:disabled){background:rgba(34,232,160,.24)}
.act-tolak{background:rgba(255,77,77,.1);color:#FF8080;border:1px solid rgba(255,77,77,.2)}
.act-tolak:hover:not(:disabled){background:rgba(255,77,77,.2)}

/* TOGGLE */
.tog{background:rgba(180,220,240,.06);color:var(--muted);border:1px solid rgba(180,220,240,.18);border-radius:6px;padding:7px 12px;font-family:'Exo 2',sans-serif;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .22s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.tog:disabled{opacity:.4;cursor:not-allowed}
.tog.on{background:rgba(34,232,160,.13);color:var(--success);border-color:rgba(34,232,160,.35)}
.tog .ck{width:10px;height:10px;border-radius:50%;border:1.5px solid currentColor;display:inline-flex;align-items:center;justify-content:center;font-size:.48rem;flex-shrink:0;transition:all .2s}
.tog.on .ck{background:var(--success);border-color:var(--success);color:var(--navy)}

/* ── BOTTOM NAV ────────────────────────────────────────────── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--navy2);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;height:60px;z-index:200}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 8px;color:var(--muted);cursor:pointer;border:none;background:none;font-family:'Exo 2',sans-serif;transition:color .2s;flex:1}
.nav-item.active{color:var(--cyan)}
.nav-item.locked{opacity:.3;cursor:not-allowed}
.nav-item svg{width:19px;height:19px}
.nav-item span{font-size:.52rem;letter-spacing:.4px;text-transform:uppercase}

/* ── TOAST ─────────────────────────────────────────────────── */
.toast{position:fixed;bottom:85px;left:50%;transform:translateX(-50%) translateY(14px);background:var(--navy3);border:1px solid var(--border-strong);color:var(--white);padding:.45rem 1.1rem;border-radius:20px;font-size:.75rem;opacity:0;transition:all .28s;z-index:999;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{border-color:var(--danger);color:#FF8080}

/* ── LOADING OVERLAY ───────────────────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(5,13,26,.85);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:500;gap:12px}
.overlay.hidden{display:none}
.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin .8s linear infinite}
.overlay-text{font-size:.8rem;color:var(--muted);letter-spacing:.5px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── SUMMARY STRIP ─────────────────────────────────────────── */
.summary-strip{display:flex;background:var(--navy2);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:.75rem}
.summary-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .4rem;border-right:1px solid var(--border);text-align:center;min-width:0}
.summary-item:last-child{border-right:none}
.s-num{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;line-height:1}
.s-lbl{font-size:.5rem;letter-spacing:.7px;text-transform:uppercase;color:var(--muted);margin-top:2px;white-space:nowrap}

/* ── MOBILE CARDS ──────────────────────────────────────────── */
#mobileRows{display:none}
#mobileRegisRows{display:none}
.mc-section{display:none}
.mobile-card{background:var(--navy2);border:1px solid var(--border);border-radius:10px;margin-bottom:6px;overflow:hidden;transition:border-color .2s}
.mobile-card.dup{border-left:3px solid var(--warn)}
.mobile-card.expanded{border-color:var(--border-strong)}
.mc-main{padding:.65rem .75rem;cursor:pointer;user-select:none}
.mc-row1{display:flex;align-items:center;gap:6px;margin-bottom:.4rem}
.mc-num{font-size:.62rem;color:var(--muted);flex-shrink:0}
.mc-name{font-weight:600;font-size:.84rem;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mc-badges{display:flex;gap:3px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end;max-width:45%}
.mc-row2{display:flex;align-items:center;gap:6px}
.mc-status{flex:1}
.mc-acts{display:flex;gap:4px;flex-shrink:0}
.mc-detail{max-height:0;overflow:hidden;transition:max-height .25s ease}
.mc-detail.open{max-height:200px}
.mc-detail-inner{padding:.5rem .75rem;border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:.35rem .75rem}
.mc-field{display:flex;flex-direction:column;gap:1px}
.mc-field-lbl{font-size:.5rem;letter-spacing:.8px;text-transform:uppercase;color:var(--muted)}
.mc-field-val{font-size:.74rem}
.mc-field-full{grid-column:1/-1}

/* ── INNER TABS (Ringkasan / Filter) ───────────────────────── */
.inner-tabs{display:flex;gap:2px;background:var(--navy2);border:1px solid var(--border);border-radius:8px;padding:3px;margin-bottom:10px}
.inner-tab{flex:1;padding:.45rem .5rem;border:none;border-radius:6px;background:transparent;color:var(--muted);font-family:'Exo 2',sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:background .15s,color .15s}
.inner-tab.active{background:var(--navy3);color:var(--cyan);box-shadow:0 0 0 1px var(--border)}
.inner-tab:not(.active):hover{color:var(--white)}
.inner-panel{display:none}
.inner-panel.active{display:block}

/* ── COLLAPSIBLE CARD ──────────────────────────────────────── */
.collapsible-card{background:var(--navy3);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-top:12px}
.collapsible-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;cursor:pointer;user-select:none;font-size:.8rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--cyan);transition:background .15s}
.collapsible-header:hover{background:rgba(0,200,232,0.07)}
.collapsible-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.collapsible-body.open{max-height:2000px}
.chevron{font-size:.9rem;transition:transform .25s;display:inline-block}
.collapsible-body.open~* .chevron,.collapsible-header .chevron{transition:transform .25s}

/* ── CHART GRID ─────────────────────────────────────────────── */
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:12px}
.chart-wrap{background:var(--navy2);border:1px solid var(--border);border-radius:8px;padding:12px 16px;display:flex;flex-direction:column;align-items:center}
.chart-title{font-size:.72rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;align-self:flex-start}
.chart-wrap canvas{max-height:260px;width:100%!important}
.chart-wrap.bar-mode{height:520px}
.chart-wrap.bar-mode canvas{max-height:none!important;height:100%!important}
.chart-type-toggle{display:flex;gap:6px;justify-content:flex-end;padding:12px 12px 0}
.ctoggle{padding:3px 14px;border-radius:4px;border:1px solid rgba(100,180,220,0.3);background:transparent;color:rgba(180,220,240,0.6);font-size:.75rem;font-family:'Exo 2',sans-serif;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.ctoggle.active{background:rgba(0,200,255,0.1);color:#00c8ff;border-color:#00c8ff}

/* ── SCORING CARDS ─────────────────────────────────────────── */
.score-card{background:var(--navy2);border:1px solid var(--border);border-radius:10px;padding:.7rem .85rem;margin-bottom:6px;cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:border-color .2s,background .2s;user-select:none;-webkit-tap-highlight-color:transparent}
.score-card:active{background:rgba(0,200,232,.04);border-color:var(--border-strong)}
.score-card.tie{border-left:3px solid var(--warn)}
.sc-rank{font-family:'Bebas Neue',sans-serif;font-size:1.25rem;color:var(--muted);width:26px;text-align:center;flex-shrink:0}
.sc-body{flex:1;min-width:0}
.sc-name{font-weight:600;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sc-meta{font-size:.64rem;color:var(--muted);margin-top:2px}
.sc-score{text-align:right;flex-shrink:0}
.sc-total{font-family:'Bebas Neue',sans-serif;font-size:1.7rem;color:var(--cyan);line-height:1}
.sc-total.zero{color:var(--muted)}
.sc-jml{font-size:.56rem;color:var(--muted);white-space:nowrap}
.scoring-empty{text-align:center;color:var(--muted);padding:2.5rem;font-size:.82rem}

/* ── BOTTOM SHEET ──────────────────────────────────────────── */
.sheet-overlay{position:fixed;inset:0;background:rgba(5,13,26,.75);z-index:300;opacity:0;pointer-events:none;transition:opacity .25s}
.sheet-overlay.open{opacity:1;pointer-events:all}
.sheet-panel{position:fixed;bottom:0;left:0;right:0;background:var(--navy2);border-top:1px solid var(--border-strong);border-radius:18px 18px 0 0;z-index:301;max-height:88vh;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .28s cubic-bezier(.32,1,.54,1)}
.sheet-panel.open{transform:translateY(0)}
.sheet-handle{width:36px;height:4px;background:var(--border-strong);border-radius:2px;margin:10px auto 0;flex-shrink:0}
.sheet-header{padding:.7rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.sheet-atlet-info{flex:1;min-width:0}
.sheet-atlet-name{font-weight:700;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sheet-atlet-meta{font-size:.65rem;color:var(--muted);margin-top:2px}
.sheet-close{background:none;border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:4px 10px;font-size:.8rem;cursor:pointer;flex-shrink:0}
.sheet-body{overflow-y:auto;padding:.75rem 1rem 1.5rem;flex:1;-webkit-overflow-scrolling:touch}
.sheet-summary{display:flex;gap:1rem;margin-bottom:.85rem;padding:.6rem;background:var(--navy3);border-radius:8px;border:1px solid var(--border)}
.sheet-sum-item{text-align:center;flex:1}
.sheet-sum-val{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--cyan);line-height:1}
.sheet-sum-lbl{font-size:.52rem;letter-spacing:.7px;text-transform:uppercase;color:var(--muted);margin-top:1px}

/* Score rambahan grid */
.rambahan-block{margin-bottom:1rem}
.rambahan-label{font-size:.6rem;letter-spacing:1px;text-transform:uppercase;color:var(--cyan);margin-bottom:.45rem;display:flex;justify-content:space-between;align-items:center}
.rambahan-total{font-family:'Bebas Neue',sans-serif;font-size:.95rem;color:var(--white)}
.rambahan-clear{background:none;border:1px solid rgba(255,77,77,.35);color:var(--danger);border-radius:5px;padding:2px 7px;font-size:.58rem;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;font-family:'Exo 2',sans-serif;transition:all .15s;margin-left:6px}
.rambahan-clear:active{background:rgba(255,77,77,.15)}
.rambahan-arrows{display:flex;gap:5px;flex-wrap:wrap}
.arrow-cell{display:flex;flex-direction:column;align-items:center;gap:3px}
.arrow-lbl{font-size:.5rem;color:var(--muted)}
.arrow-val{width:40px;height:40px;border:1.5px solid var(--border);border-radius:8px;background:var(--navy3);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:1.25rem;color:var(--muted);cursor:pointer;transition:border-color .15s,background .15s;-webkit-tap-highlight-color:transparent}
.arrow-val:active{background:var(--cyan-glow)}
.arrow-val.filled{border-color:var(--cyan-dark);color:var(--white)}
.arrow-val.miss{border-color:var(--danger);color:var(--danger)}

/* Score picker */
.score-picker{position:fixed;bottom:0;left:0;right:0;background:var(--navy3);border-top:2px solid var(--border-strong);z-index:402;padding:.6rem 1rem 1.75rem;transform:translateY(100%);transition:transform .2s ease}
.score-picker.open{transform:translateY(0)}
.picker-lbl{font-size:.62rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:.55rem;text-align:center}
.picker-btns{display:flex;gap:8px;justify-content:center}
.picker-btn{width:46px;height:46px;border-radius:10px;border:1.5px solid var(--border);background:var(--navy2);color:var(--white);font-family:'Bebas Neue',sans-serif;font-size:1.4rem;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}
.picker-btn:active{border-color:var(--cyan);background:var(--cyan-glow);color:var(--cyan)}
.picker-btn.miss{border-color:rgba(255,77,77,.4);color:var(--danger)}
.picker-btn.miss:active{background:rgba(255,77,77,.1)}
.picker-cancel{display:block;width:100%;margin-top:.5rem;background:none;border:none;color:var(--muted);font-size:.75rem;cursor:pointer;padding:.4rem;font-family:'Exo 2',sans-serif}

/* ── MODAL ─────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(5,13,26,.7);z-index:400;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-panel{position:fixed;left:50%;top:50%;transform:translate(-50%,-48%) scale(.96);background:var(--navy2);border:1px solid var(--border-strong);border-radius:16px;padding:1.4rem 1.25rem 1.25rem;width:min(460px,calc(100vw - 2rem));z-index:401;opacity:0;pointer-events:none;transition:all .2s;max-height:90vh;overflow-y:auto}
.modal-panel.open{opacity:1;pointer-events:all;transform:translate(-50%,-50%) scale(1)}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:1.35rem;letter-spacing:1px;color:var(--white);margin-bottom:1rem}
.modal-fields{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.modal-field-full{grid-column:1/-1}
.modal-footer{display:flex;gap:.6rem;justify-content:flex-end;margin-top:1.1rem;padding-top:.9rem;border-top:1px solid var(--border)}
.modal-cancel{background:none;border:1px solid var(--border);color:var(--muted);padding:.45rem 1.1rem;border-radius:8px;font-size:.78rem;cursor:pointer;font-family:'Exo 2',sans-serif;transition:border-color .15s,color .15s}
.modal-cancel:hover{border-color:var(--border-strong);color:var(--white)}
.modal-save{background:rgba(0,200,232,.1);border:1px solid var(--cyan-dark);color:var(--cyan);padding:.45rem 1.4rem;border-radius:8px;font-size:.78rem;font-weight:600;cursor:pointer;font-family:'Exo 2',sans-serif;transition:background .15s}
.modal-save:hover{background:rgba(0,200,232,.18)}
.modal-delete{background:rgba(255,77,77,.08);border:1px solid rgba(255,77,77,.35);color:var(--danger);padding:.45rem .9rem;border-radius:8px;font-size:.78rem;cursor:pointer;font-family:'Exo 2',sans-serif;margin-right:auto;transition:background .15s}
.modal-delete:hover{background:rgba(255,77,77,.15)}

/* ── EVENT CARDS ───────────────────────────────────────────── */
.event-card{background:var(--navy2);border:1px solid var(--border);border-radius:12px;padding:.85rem 1rem;margin-bottom:8px;transition:border-color .2s}
.event-card.live{border-left:3px solid var(--success)}
.ev-header{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.5rem}
.ev-nama{font-weight:700;font-size:.9rem;flex:1}
.ev-badges{display:flex;gap:4px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}
.ev-meta{font-size:.68rem;color:var(--muted);display:flex;gap:.85rem;flex-wrap:wrap;margin-bottom:.55rem}
.ev-actions{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}
.ev-live-btn{padding:4px 12px;border-radius:6px;font-size:.68rem;font-weight:600;font-family:'Exo 2',sans-serif;cursor:pointer;border:none;transition:all .15s;letter-spacing:.3px}
.ev-live-btn.on{background:rgba(34,232,160,.15);border:1px solid var(--success);color:var(--success)}
.ev-live-btn.off{background:rgba(100,180,220,.08);border:1px solid var(--border);color:var(--muted)}
.ev-edit-btn{background:none;border:1px solid var(--border);color:var(--muted);padding:4px 10px;border-radius:6px;font-size:.68rem;cursor:pointer;font-family:'Exo 2',sans-serif;transition:all .15s}
.ev-edit-btn:hover{border-color:var(--cyan-dark);color:var(--cyan)}

/* ── LEADERBOARD SCREEN ────────────────────────────────────── */
#leaderboardScreen{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;
  padding:1rem 1rem 5rem;
  background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(0,200,232,.12) 0%,transparent 70%),var(--navy);
  gap:.85rem;
}
.lb-header{text-align:center;padding-top:1.5rem}
.lb-logo{width:72px;height:72px;border-radius:50%;border:2.5px solid var(--cyan);margin-bottom:.6rem;object-fit:cover;box-shadow:0 0 24px rgba(0,200,232,.25)}
.lb-title{font-family:'Bebas Neue',sans-serif;font-size:1.9rem;color:var(--cyan);letter-spacing:2px;line-height:1.05}
.lb-sub{font-size:.72rem;color:var(--muted);letter-spacing:.8px;margin-top:3px}
.lb-controls{display:flex;align-items:center;gap:.5rem;width:100%;max-width:480px}
.lb-controls .ctrl-select{flex:1}
.lb-list{width:100%;max-width:480px;display:flex;flex-direction:column;gap:6px}
.lb-empty{text-align:center;color:var(--muted);padding:2.5rem;font-size:.82rem}
.lb-card.rank-1{background:linear-gradient(135deg,#2e2000,#1a1200);border-color:gold}
.lb-card.rank-2{background:linear-gradient(135deg,#1e1e24,#111);border-color:silver}
.lb-card.rank-3{background:linear-gradient(135deg,#241400,#111);border-color:#cd7f32}
.lb-medal{font-size:1.35rem;min-width:2rem;text-align:center;flex-shrink:0}
.lb-footer{margin-top:auto;padding:1rem 0;text-align:center}
.lb-login-link{background:none;border:1px solid var(--border);color:var(--muted);padding:.4rem 1.2rem;border-radius:20px;font-size:.72rem;cursor:pointer;font-family:'Exo 2',sans-serif;letter-spacing:.5px;transition:all .2s}
.lb-login-link:hover{border-color:var(--cyan);color:var(--cyan)}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media(max-width:640px){
  .chart-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .pay-summary{grid-template-columns:repeat(2,1fr)}
  .controls{flex-direction:column}
  .ctrl-group{min-width:100%}
  .hide-mobile{display:none}
  /* Switch tabel ↔ cards */
  .table-wrap{border:none}
  .tbl-outer{display:none}
  #mobileRows{display:block}
  #mobileRegisRows{display:block}
  .mc-section{display:block}
  .table-top{display:none}
}
