@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800;900&family=Barlow:wght@400;500;600&family=DM+Mono:wght@400;500&display=swap');

:root {
  --bg:       #06101E;
  --surface:  #090F1C;
  --card:     #0C1F38;
  --card-hi:  #102848;
  --border:   rgba(0,150,255,0.12);
  --blue:     #0077FF;
  --blue-hi:  #3399FF;
  --cyan:     #00C4FF;
  --gold:     #FFD100;
  --silver:   #90B8E0;
  --bronze:   #C08848;
  --text:     #C8DFFF;
  --muted:    #3A6080;
  --danger:   #FF3B4E;
  --success:  #00CC88;
  --radius:   14px;
  --radius-sm:9px;
  --shadow:   0 8px 32px rgba(0,40,120,0.35);
  --glow:     0 0 20px rgba(0,150,255,0.2);
  --trans:    0.18s cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{font-size:16px}
body{
  font-family:'Barlow',sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100dvh;
  overscroll-behavior:none;
  -webkit-font-smoothing:antialiased;
}

/* ── SCREENS ──────────────────────────────────────────────────────────────── */
.screen{display:none;min-height:100dvh;flex-direction:column}
.screen.active{display:flex}

/* ── HEADER ───────────────────────────────────────────────────────────────── */
.app-header{
  background:var(--surface);
  padding:14px 18px 12px;
  display:flex;align-items:center;gap:12px;
  position:sticky;top:0;z-index:100;
  border-bottom:1px solid var(--border);
}
.logo-mark{
  width:34px;height:34px;
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:17px;color:#fff;
  flex-shrink:0;box-shadow:var(--glow);
}
.header-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:17px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--cyan);flex:1;
}
.header-sub{font-size:11px;color:var(--muted);letter-spacing:.05em;text-transform:uppercase}
.btn-icon{
  width:34px;height:34px;
  background:rgba(0,150,255,.08);border:none;
  border-radius:8px;color:var(--cyan);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:18px;transition:background var(--trans);
}
.btn-icon:active{background:rgba(0,150,255,.2)}

/* ── AUTH SCREEN ──────────────────────────────────────────────────────────── */
#screen-auth{
  background:radial-gradient(ellipse at 50% -10%,rgba(0,100,220,.35) 0%,var(--bg) 65%);
  align-items:center;justify-content:center;padding:40px 24px;
}
.auth-logo{
  width:90px;height:90px;
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  border-radius:22px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:46px;color:#fff;
  margin:0 auto 20px;
  box-shadow:0 12px 40px rgba(0,100,255,.4);
}
.auth-title{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:40px;letter-spacing:.05em;
  text-transform:uppercase;color:#fff;text-align:center;
  line-height:1;margin-bottom:6px;
}
.auth-sub{font-size:13px;color:var(--muted);text-align:center;margin-bottom:40px;letter-spacing:.04em}
.pin-display{display:flex;gap:12px;justify-content:center;margin-bottom:28px}
.pin-dot{
  width:58px;height:58px;border-radius:14px;
  background:rgba(0,100,255,.08);
  border:2px solid rgba(0,150,255,.2);
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Mono',monospace;font-size:30px;color:var(--cyan);
  transition:all var(--trans);
}
.pin-dot.filled{border-color:var(--cyan);background:rgba(0,196,255,.1);box-shadow:0 0 12px rgba(0,196,255,.2)}
.pin-dot.error{border-color:var(--danger);background:rgba(255,59,78,.1);animation:shake .3s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-7px)}75%{transform:translateX(7px)}}
.pin-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:280px}
.pin-key{
  height:62px;
  background:rgba(0,80,160,.15);
  border:1px solid rgba(0,150,255,.12);border-radius:12px;
  font-family:'DM Mono',monospace;font-size:26px;font-weight:500;
  color:var(--text);cursor:pointer;
  transition:background var(--trans),transform var(--trans);-webkit-user-select:none;
}
.pin-key:active{background:rgba(0,150,255,.25);transform:scale(.95)}
.pin-key.delete{font-size:20px;color:var(--cyan)}
.pin-key.empty{visibility:hidden}
.pin-error{
  text-align:center;font-size:13px;color:var(--danger);
  margin-top:14px;min-height:18px;letter-spacing:.03em;
}

/* ── HOME SCREEN ──────────────────────────────────────────────────────────── */
#screen-home{background:var(--surface);flex:1}
.home-hero{
  padding:24px 20px 20px;
  background:linear-gradient(180deg,rgba(0,80,180,.12) 0%,transparent 100%);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:14px;
}
.home-hero-text h1{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:28px;letter-spacing:.05em;
  text-transform:uppercase;color:#fff;line-height:1;
}
.home-hero-text p{font-size:13px;color:var(--muted);margin-top:3px;letter-spacing:.03em}
.home-hero-text{flex:1}
.stat-chips{display:flex;gap:8px;margin-top:12px}
.stat-chip{
  background:rgba(0,100,255,.12);border:1px solid var(--border);
  border-radius:8px;padding:6px 12px;
  font-family:'DM Mono',monospace;font-size:12px;color:var(--cyan);
}

.tab-bar{
  display:flex;background:var(--surface);
  border-bottom:1px solid var(--border);padding:0 8px;
}
.tab-btn{
  flex:1;padding:13px 8px 11px;background:none;
  border:none;border-bottom:2px solid transparent;
  font-family:'Barlow Condensed',sans-serif;font-weight:600;
  font-size:14px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);cursor:pointer;transition:all var(--trans);
}
.tab-btn.active{color:var(--cyan);border-bottom-color:var(--cyan)}
.tab-content{display:none;flex:1;overflow-y:auto}
.tab-content.active{display:block}

/* circuit table */
.circuit-header{padding:18px 18px 10px;display:flex;justify-content:space-between;align-items:flex-end}
.circuit-header h2{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:20px;text-transform:uppercase;color:var(--cyan);
}
.circuit-header span{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.circuit-table{
  margin:0 14px 4px;border-radius:var(--radius);
  overflow-x:auto;border:1px solid var(--border);
  -webkit-overflow-scrolling:touch;scrollbar-width:none;
}
.circuit-table::-webkit-scrollbar{display:none}
.c-tiebreak-note{
  margin:0 14px 14px;
  font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);
  letter-spacing:.03em;padding:5px 10px;
  background:rgba(0,0,0,.15);border-radius:0 0 var(--radius) var(--radius);
  border:1px solid var(--border);border-top:none;
}
.c-scroll{min-width:480px}
.c-row{
  display:grid;
  align-items:center;padding:10px 10px;gap:4px;
  border-bottom:1px solid rgba(0,100,255,.06);
}
.c-row:last-child{border-bottom:none}
.c-row.c-head{background:rgba(0,0,0,.25);padding:6px 10px}
.c-row.c-head span{
  font-family:'DM Mono',monospace;font-size:9px;
  letter-spacing:.07em;text-transform:uppercase;color:var(--muted);
  text-align:center;
}
.c-row.c-head span:nth-child(2){text-align:left}
.c-row.c-top{background:rgba(0,150,255,.06)}
.c-rank{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);text-align:center}
.c-rank.hi{color:var(--gold);font-weight:500}
.c-name{
  font-family:'Barlow Condensed',sans-serif;font-weight:600;
  font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.c-pts{font-family:'DM Mono',monospace;font-size:11px;text-align:center;color:var(--muted)}
.c-pts.total{font-size:13px;font-weight:600;color:var(--gold);text-align:center}
.c-pts.c-top-wk{color:#00DD66;font-weight:600;background:rgba(0,180,80,.12);border-radius:4px}
.c-pts.pos{color:var(--success);font-weight:500}
.c-pts.neg{color:var(--danger)}

/* history */
.history-list{padding:14px;display:flex;flex-direction:column;gap:10px}
.j-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);padding:15px;cursor:pointer;
  transition:background var(--trans);
}
.j-card:active{background:var(--card-hi)}
.j-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.j-num{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:18px;text-transform:uppercase;color:var(--cyan);
}
.j-meta{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.j-tag{
  display:inline-block;padding:3px 8px;border-radius:5px;
  font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.05em;
  background:rgba(0,100,255,.15);color:var(--blue-hi);border:1px solid var(--border);
}
.j-podium{display:flex;gap:8px;flex-wrap:wrap}
.j-podium-item{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text)}

/* FAB */
.fab{
  position:fixed;bottom:24px;right:20px;
  width:56px;height:56px;border-radius:16px;
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  border:none;color:#fff;font-size:26px;
  box-shadow:0 6px 24px rgba(0,100,255,.45);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:transform var(--trans),box-shadow var(--trans);
  z-index:50;-webkit-user-select:none;
}
.fab:active{transform:scale(.93);box-shadow:0 3px 12px rgba(0,100,255,.4)}

/* ── SETUP SCREEN ──────────────────────────────────────────────────────────── */
#screen-setup{background:var(--surface);overflow-y:auto}
.steps-bar{
  display:flex;align-items:center;justify-content:center;
  padding:16px 20px 0;gap:6px;
}
.step-dot{
  width:8px;height:8px;border-radius:4px;
  background:rgba(0,150,255,.2);
  transition:all var(--trans);
}
.step-dot.done{background:var(--blue);width:20px}
.step-dot.active{background:var(--cyan);width:28px;box-shadow:0 0 8px rgba(0,196,255,.5)}
.setup-step{display:none;padding:20px 18px}
.setup-step.active{display:block}
.step-title{
  font-family:'Barlow Condensed',sans-serif;font-weight:800;
  font-size:26px;text-transform:uppercase;letter-spacing:.04em;
  color:#fff;margin-bottom:4px;
}
.step-hint{font-size:13px;color:var(--muted);margin-bottom:20px;line-height:1.4}

/* courts grid */
.courts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:8px}
.court-opt{
  background:var(--card);border:2px solid var(--border);
  border-radius:var(--radius);padding:18px 14px;
  text-align:center;cursor:pointer;transition:all var(--trans);-webkit-user-select:none;
}
.court-opt.sel{border-color:var(--cyan);background:rgba(0,196,255,.08);box-shadow:var(--glow)}
.court-opt:active{transform:scale(.97)}
.court-opt .c-big{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:44px;color:var(--cyan);display:block;line-height:1;
}
.court-opt .c-sub{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.court-opt .c-hrs{font-family:'DM Mono',monospace;font-size:11px;color:var(--blue-hi);margin-top:4px}

/* sector selector */
.sector-opt{
  flex:1;min-width:130px;padding:13px 16px;border-radius:var(--radius-sm);
  background:var(--card);border:1.5px solid var(--border);
  color:var(--text);font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:15px;letter-spacing:.03em;text-align:center;cursor:pointer;
  transition:var(--trans);user-select:none;
}
.sector-opt:active{transform:scale(.97)}
.sector-opt.sel{border-color:var(--cyan);background:rgba(0,196,255,.08);color:#fff;box-shadow:var(--glow)}

/* format cards */
.format-cards{display:flex;flex-direction:column;gap:12px}
.format-card{
  background:var(--card);border:2px solid var(--border);
  border-radius:var(--radius);padding:18px;cursor:pointer;
  display:flex;align-items:center;gap:14px;
  transition:all var(--trans);-webkit-user-select:none;
}
.format-card:active{background:var(--card-hi)}
.format-card.sel{border-color:var(--cyan);background:rgba(0,196,255,.08)}
.format-icon{font-size:32px;flex-shrink:0}
.format-info .f-name{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:20px;text-transform:uppercase;color:#fff;
}
.format-info .f-desc{font-size:13px;color:var(--muted);margin-top:3px;line-height:1.4}

/* modality cards */
.modality-cards{display:flex;flex-direction:column;gap:10px}
.mod-card{
  background:var(--card);border:2px solid var(--border);
  border-radius:var(--radius);padding:16px;cursor:pointer;
  transition:all var(--trans);-webkit-user-select:none;
}
.mod-card:active{background:var(--card-hi)}
.mod-card.sel{border-color:var(--cyan);background:rgba(0,196,255,.08)}
.mod-card .m-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.mod-card .m-name{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:18px;text-transform:uppercase;color:#fff;
}
.mod-card .m-badge{
  font-family:'DM Mono',monospace;font-size:10px;
  background:rgba(0,100,255,.2);border:1px solid var(--border);
  border-radius:5px;padding:3px 7px;color:var(--blue-hi);white-space:nowrap;flex-shrink:0;
}
.mod-card .m-desc{font-size:13px;color:var(--muted);margin-top:5px;line-height:1.4}
.mod-card .m-rounds{
  margin-top:8px;display:flex;gap:6px;
}
.mod-pill{
  font-family:'DM Mono',monospace;font-size:10px;
  background:rgba(0,0,0,.2);border-radius:5px;padding:3px 8px;color:var(--muted);
}

/* WA paste */
.wa-section{margin-bottom:18px}
.wa-section label{
  display:block;font-family:'Barlow Condensed',sans-serif;
  font-weight:600;font-size:14px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--cyan);margin-bottom:8px;
}
.wa-textarea{
  width:100%;min-height:100px;padding:12px;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-sm);color:var(--text);
  font-family:'Barlow',sans-serif;font-size:14px;
  resize:vertical;outline:none;transition:border-color var(--trans);
  -webkit-appearance:none;
}
.wa-textarea:focus{border-color:var(--cyan)}
.wa-textarea::placeholder{color:var(--muted)}
.wa-parse-btn{
  margin-top:8px;padding:10px 18px;width:100%;
  background:rgba(0,150,255,.15);border:1px solid var(--border);
  border-radius:var(--radius-sm);
  font-family:'Barlow Condensed',sans-serif;font-weight:600;
  font-size:15px;letter-spacing:.04em;color:var(--cyan);
  cursor:pointer;transition:background var(--trans);-webkit-user-select:none;
}
.wa-parse-btn:active{background:rgba(0,150,255,.28)}
.wa-result{
  margin-top:8px;font-size:13px;min-height:18px;
  font-family:'DM Mono',monospace;color:var(--success);
}
.section-divider{
  display:flex;align-items:center;gap:10px;margin:18px 0;
}
.section-divider::before,.section-divider::after{
  content:'';flex:1;border-top:1px solid var(--border);
}
.section-divider span{font-size:12px;color:var(--muted);white-space:nowrap}

/* player inputs */
.players-list{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.player-row{display:flex;align-items:center;gap:8px}
.p-num{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);width:22px;text-align:right;flex-shrink:0}
.p-input{
  flex:1;padding:11px 13px;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-sm);color:var(--text);
  font-family:'Barlow',sans-serif;font-size:15px;
  outline:none;transition:border-color var(--trans);-webkit-appearance:none;
}
.p-input:focus{border-color:var(--cyan)}
.p-input::placeholder{color:var(--muted);opacity:.6}
.gender-toggle{
  display:flex;border-radius:8px;overflow:hidden;
  border:1px solid var(--border);flex-shrink:0;
}
.gender-btn{
  padding:10px 10px;background:transparent;border:none;
  font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);
  cursor:pointer;transition:all var(--trans);-webkit-user-select:none;
}
.gender-btn.active-m{background:rgba(0,100,255,.3);color:var(--blue-hi)}
.gender-btn.active-f{background:rgba(255,80,180,.25);color:#FF88CC}
/* pair inputs */
.pair-row{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:12px;
  display:flex;align-items:center;gap:10px;
}
.pair-num{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);width:22px;text-align:right;flex-shrink:0}
.pair-inputs{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:7px}
.pair-sep{font-family:'DM Mono',monospace;font-size:14px;color:var(--muted);flex-shrink:0}

/* setup actions */
.setup-actions{padding:0 18px 32px;display:flex;flex-direction:column;gap:10px}

/* ── BUTTONS ──────────────────────────────────────────────────────────────── */
.btn-primary{
  padding:16px 24px;width:100%;
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  color:#fff;border:none;border-radius:var(--radius);
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:18px;letter-spacing:.05em;text-transform:uppercase;
  cursor:pointer;box-shadow:0 4px 20px rgba(0,100,255,.3);
  transition:opacity var(--trans),transform var(--trans);-webkit-user-select:none;
}
.btn-primary:active{opacity:.88;transform:scale(.98)}
.btn-primary:disabled{opacity:.35;cursor:not-allowed}
.btn-secondary{
  padding:14px 24px;width:100%;
  background:transparent;color:var(--cyan);
  border:1.5px solid rgba(0,150,255,.3);border-radius:var(--radius);
  font-family:'Barlow Condensed',sans-serif;font-weight:600;
  font-size:16px;letter-spacing:.05em;text-transform:uppercase;
  cursor:pointer;transition:all var(--trans);-webkit-user-select:none;
}
.btn-secondary:active{background:rgba(0,150,255,.1)}
.btn-danger{
  padding:14px 24px;width:100%;
  background:transparent;color:var(--danger);
  border:1.5px solid rgba(255,59,78,.3);border-radius:var(--radius);
  font-family:'Barlow Condensed',sans-serif;font-weight:600;
  font-size:16px;letter-spacing:.05em;text-transform:uppercase;
  cursor:pointer;transition:all var(--trans);-webkit-user-select:none;
}
.btn-danger:active{background:rgba(255,59,78,.1)}

/* ── JORNADA SCREEN ───────────────────────────────────────────────────────── */
#screen-jornada{background:var(--surface)}
.rounds-nav{
  display:flex;padding:12px 14px;gap:6px;
  overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.rounds-nav::-webkit-scrollbar{display:none}
.round-pill{
  flex-shrink:0;padding:8px 16px;border-radius:20px;
  background:rgba(0,100,255,.1);border:1.5px solid rgba(0,150,255,.15);
  font-family:'DM Mono',monospace;font-size:13px;color:var(--muted);
  cursor:pointer;transition:all var(--trans);-webkit-user-select:none;
}
.round-pill.active{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:var(--glow)}
.round-pill.done{border-color:rgba(0,150,255,.4);color:var(--blue-hi)}
.round-pill.is-final{
  background:linear-gradient(135deg,rgba(255,180,0,.2),rgba(255,80,0,.1));
  border-color:rgba(255,200,0,.4);color:var(--gold);
}
.round-pill.is-final.active{
  background:linear-gradient(135deg,#CC8800,#FF6600);
  border-color:var(--gold);color:#fff;box-shadow:0 0 16px rgba(255,160,0,.4);
}
.round-pill:active{transform:scale(.95)}

.courts-container{padding:0 14px;display:flex;flex-direction:column;gap:10px}
.court-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
}
.court-label-bar{
  background:rgba(0,0,0,.25);padding:9px 14px;
  display:flex;justify-content:space-between;align-items:center;
}
.court-label{
  font-family:'DM Mono',monospace;font-size:12px;
  letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
}
.court-place-label{
  font-family:'Barlow Condensed',sans-serif;font-weight:600;
  font-size:13px;letter-spacing:.04em;color:var(--gold);
}
.court-body{padding:14px;display:flex;align-items:center;gap:10px}
.team-col{flex:1}
.team-name{
  font-family:'Barlow Condensed',sans-serif;font-weight:600;
  font-size:17px;line-height:1.25;letter-spacing:.02em;
}
.team-name span{display:block}
.vs-col{display:flex;flex-direction:column;align-items:center;gap:8px}
.score-inputs{display:flex;align-items:center;gap:6px}
.score-in{
  width:50px;height:50px;
  background:rgba(0,0,0,.3);border:2px solid rgba(0,150,255,.2);
  border-radius:10px;text-align:center;
  font-family:'DM Mono',monospace;font-size:24px;font-weight:500;
  color:var(--text);outline:none;-webkit-appearance:none;
  transition:border-color var(--trans);
}
.score-in:focus{border-color:var(--cyan)}
.score-in.has-val{border-color:rgba(0,150,255,.5);color:var(--cyan)}
.score-dash{font-family:'DM Mono',monospace;font-size:18px;color:var(--muted);opacity:.5}
.vs-lbl{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:.1em}
.team-col.right{text-align:right}

/* ranking in jornada */
.rank-header-row{
  padding:8px 14px 0;display:grid;
  grid-template-columns:30px 1fr repeat(4,38px);gap:4px;
}
.rank-header-row span{
  font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted);text-align:center;
}
.rank-header-row span:nth-child(2){text-align:left}
.ranking-list{padding:10px 14px;display:flex;flex-direction:column;gap:5px}
.rank-row{
  background:var(--card);border:1px solid rgba(0,100,255,.06);
  border-radius:var(--radius-sm);padding:10px 12px;
  display:grid;grid-template-columns:30px 1fr repeat(4,38px);
  align-items:center;gap:4px;transition:background var(--trans);
}
.rank-row.r1{border-color:rgba(255,209,0,.3);background:rgba(255,209,0,.06)}
.rank-row.r2{border-color:rgba(144,184,224,.2)}
.r-badge{font-family:'DM Mono',monospace;font-size:13px;font-weight:500;text-align:center}
.r-badge.gold{color:var(--gold)}.r-badge.silver{color:var(--silver)}.r-badge.bronze{color:var(--bronze)}.r-badge.n{color:var(--muted);font-size:11px}
.r-name{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.r-stat{font-family:'DM Mono',monospace;font-size:11px;text-align:center;color:var(--muted)}
.r-stat.main{color:var(--cyan);font-weight:500;font-size:12px}
.r-stat.pos{color:var(--success)}.r-stat.neg{color:var(--danger)}

/* round actions */
.round-actions{padding:14px 14px 28px;display:flex;flex-direction:column;gap:8px}

/* edit banner */
.j-edit-banner{
  background:rgba(255,160,0,.12);border-bottom:1px solid rgba(255,160,0,.25);
  padding:9px 16px;font-size:12px;color:#FFB830;
  font-family:'DM Mono',monospace;letter-spacing:.02em;
  display:flex;align-items:center;gap:6px;
}

/* results view */
.res-wrap{padding:12px 14px;display:flex;flex-direction:column;gap:12px}
.res-round-block{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
}
.res-round-hdr{
  background:rgba(0,0,0,.25);padding:8px 14px;
  font-family:'DM Mono',monospace;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;color:var(--cyan);
}
.res-match{
  display:grid;grid-template-columns:28px 1fr 52px 1fr;
  align-items:center;gap:6px;padding:10px 12px;
  border-bottom:1px solid rgba(0,100,255,.06);
}
.res-match:last-child{border-bottom:none}
.res-court-lbl{
  font-family:'DM Mono',monospace;font-size:10px;
  color:var(--muted);text-align:center;
}
.res-team{
  font-family:'Barlow Condensed',sans-serif;font-weight:600;
  font-size:14px;color:var(--muted);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.res-team.res-right{text-align:right}
.res-team.res-win{color:#fff}
.res-score-lbl{
  font-family:'DM Mono',monospace;font-size:14px;font-weight:600;
  color:var(--cyan);text-align:center;white-space:nowrap;
}

/* ── RESULT SCREEN ────────────────────────────────────────────────────────── */
#screen-result{background:var(--surface)}
.result-body{padding:24px 20px;flex:1}
.result-heading{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:32px;letter-spacing:.05em;text-transform:uppercase;
  color:#fff;text-align:center;margin-bottom:28px;
}
.podium-wrap{display:flex;align-items:flex-end;justify-content:center;gap:8px;margin-bottom:32px}
.podium-place{flex:1;max-width:115px;display:flex;flex-direction:column;align-items:center;gap:6px}
.p-medal{font-size:30px}
.p-name{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:14px;text-align:center;text-transform:uppercase;letter-spacing:.03em;line-height:1.2}
.p-stat{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.p-block{width:100%;border-radius:8px 8px 0 0;background:rgba(0,100,255,.1);border:1px solid var(--border)}
.podium-place.first .p-block{height:80px;background:rgba(255,209,0,.15);border-color:rgba(255,209,0,.4)}
.podium-place.second .p-block{height:56px}
.podium-place.third .p-block{height:40px}
.result-full-list{margin-top:4px}
.result-row{
  display:flex;align-items:center;gap:10px;padding:10px 0;
  border-bottom:1px solid var(--border);
}
.result-row:last-child{border-bottom:none}
.result-rank{font-family:'DM Mono',monospace;font-size:13px;color:var(--muted);width:24px}
.result-name{flex:1;font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:16px}
.result-pts{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted)}
.result-actions{padding:0 20px 40px;display:flex;flex-direction:column;gap:9px}

/* ── CONFIRM ──────────────────────────────────────────────────────────────── */
.confirm-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.75);z-index:250;
  align-items:center;justify-content:center;padding:24px;
  backdrop-filter:blur(4px);
}
.confirm-overlay.open{display:flex}
.confirm-box{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);padding:28px 22px;width:100%;max-width:360px;text-align:center;
}
.confirm-box h3{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:22px;text-transform:uppercase;color:var(--cyan);margin-bottom:10px;
}
.confirm-box p{font-size:14px;color:var(--muted);margin-bottom:24px;line-height:1.5}
.confirm-btns{display:flex;gap:10px}
.confirm-btns .btn-primary,.confirm-btns .btn-secondary{flex:1;padding:13px}

/* ── TOAST ────────────────────────────────────────────────────────────────── */
.toast{
  position:fixed;bottom:28px;left:50%;
  transform:translateX(-50%) translateY(100px);
  background:var(--card-hi);color:var(--text);
  border:1px solid var(--border);border-radius:24px;
  padding:11px 22px;font-size:14px;z-index:300;
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  white-space:nowrap;box-shadow:var(--shadow);
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ── EMPTY STATE ──────────────────────────────────────────────────────────── */
.empty-state{text-align:center;padding:48px 24px;color:var(--muted)}
.empty-state .e-ico{font-size:44px;margin-bottom:14px}
.empty-state p{font-family:'Barlow Condensed',sans-serif;font-size:16px;text-transform:uppercase;letter-spacing:.04em}

/* ── BACKUP MODAL ──────────────────────────────────────────────────────────── */
.backup-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.75);z-index:200;
  align-items:flex-end;justify-content:center;
  backdrop-filter:blur(4px);
}
.backup-overlay.open{display:flex}
.backup-sheet{
  background:var(--card);border-radius:20px 20px 0 0;
  padding:28px 22px 44px;width:100%;max-width:480px;
  animation:slideUp .25s cubic-bezier(.4,0,.2,1);
}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
.backup-sheet h2{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:22px;text-transform:uppercase;color:var(--cyan);margin-bottom:6px;
}
.backup-sheet p{font-size:13px;color:var(--muted);margin-bottom:22px;line-height:1.5}
.backup-actions{display:flex;flex-direction:column;gap:10px}
.file-input-wrap{position:relative;overflow:hidden}
.file-input-wrap input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}

/* ── CIRCUIT TABS BAR ─────────────────────────────────────────────────────── */
.circuit-tabs-bar{
  display:flex;gap:6px;padding:12px 14px 4px;
  overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.circuit-tabs-bar::-webkit-scrollbar{display:none}
.circ-tab{
  flex-shrink:0;padding:7px 16px;border-radius:20px;
  background:rgba(0,100,255,.1);border:1.5px solid rgba(0,150,255,.15);
  font-family:'Barlow Condensed',sans-serif;font-weight:600;
  font-size:14px;letter-spacing:.04em;color:var(--muted);
  cursor:pointer;transition:all var(--trans);white-space:nowrap;-webkit-user-select:none;
}
.circ-tab.active{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:var(--glow)}
.circ-tab:active{transform:scale(.95)}
.circ-tab.add-circ{
  font-size:20px;padding:4px 14px;
  border-style:dashed;color:var(--cyan);background:transparent;
}

/* ── CIRCUIT SHEET (bottom sheet) ─────────────────────────────────────────── */
.circuit-sheet-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.75);z-index:200;
  align-items:flex-end;justify-content:center;
  backdrop-filter:blur(4px);
}
.circuit-sheet-overlay.open{display:flex}
.circuit-sheet-panel{
  background:var(--card);border-radius:20px 20px 0 0;
  padding:22px 18px 44px;width:100%;max-width:480px;
  animation:slideUp .25s cubic-bezier(.4,0,.2,1);
  max-height:80dvh;overflow-y:auto;
}
.cs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.cs-header h2{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:20px;text-transform:uppercase;color:var(--cyan);
}
.circuit-sheet-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.circuit-sheet-item{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius-sm);padding:14px 16px;cursor:pointer;
  transition:all var(--trans);
}
.circuit-sheet-item:active{background:var(--card-hi)}
.circuit-sheet-item.active{border-color:var(--cyan);background:rgba(0,196,255,.06)}
.csi-name{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:18px;text-transform:uppercase;color:#fff;
}
.csi-meta{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);margin-top:2px}
.new-circuit-row{
  display:flex;gap:8px;align-items:center;
  margin-bottom:8px;
}
.new-circuit-row .p-input{flex:1}

/* ── SUPER SMASH — GROUP DIVIDER ─────────────────────────────────────────── */
.ss-group-divider {
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:13px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--cyan);
  padding:12px 4px 4px;margin-top:8px;
  border-top:1px solid rgba(0,196,255,.15);
}

.ss-group-block { margin-bottom:20px; }
.ss-group-title {
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;font-size:14px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--cyan);
  padding:8px 4px;margin-bottom:4px;
  border-left:3px solid var(--cyan);padding-left:10px;
}

/* ── SUPER SMASH TIMER ───────────────────────────────────────────────────── */
#ss-timer-bar {
  margin:12px 0 8px;
  border-radius:var(--radius-sm);
  overflow:hidden;
  border:1px solid rgba(0,150,255,.2);
  background:var(--surface);
}

/* Phase dot row */
.sst-dots {
  display:flex;align-items:center;gap:3px;
  padding:8px 12px 6px;
  overflow-x:auto;scrollbar-width:none;
}
.sst-dots::-webkit-scrollbar{display:none}
.tp-dot {
  flex-shrink:0;
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.12);
  transition:all .2s;
}
.tp-dot.tp-r  { width:10px;height:10px; }
.tp-dot.tp-f  { width:12px;height:12px;border-radius:3px; }
.tp-dot.done  { background:rgba(0,196,255,.4); }
.tp-dot.active.tp-r { background:var(--blue);box-shadow:0 0 6px var(--blue); }
.tp-dot.active.tp-d { background:rgba(255,255,255,.35); }
.tp-dot.active.tp-f { background:#FFD100;box-shadow:0 0 8px #FFD100; }

/* Body */
.sst-body {
  display:flex;align-items:center;gap:12px;
  padding:10px 14px 12px;
}
.sst-label {
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:15px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--muted);
  min-width:80px;
}
.sst-time {
  font-family:'DM Mono',monospace;
  font-size:28px;font-weight:500;
  color:#fff;letter-spacing:.04em;
  flex:1;text-align:center;
  transition:color .3s;
}
.sst-time.urgent { color:#FF4455;animation:pulse-timer .8s ease-in-out infinite; }
@keyframes pulse-timer {
  0%,100% { opacity:1; } 50% { opacity:.5; }
}
.sst-btns { display:flex;gap:8px;flex-shrink:0; }
.sst-btn {
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:13px;letter-spacing:.04em;
  padding:8px 14px;border-radius:var(--radius-sm);
  border:1.5px solid rgba(0,150,255,.3);
  background:rgba(0,100,255,.12);color:var(--cyan);
  cursor:pointer;white-space:nowrap;
  transition:all .15s;
}
.sst-btn:active { background:rgba(0,100,255,.25); }
.sst-btn.sst-play { background:rgba(0,120,255,.2);border-color:var(--blue); }
.sst-btn.sst-next { color:var(--muted);border-color:rgba(255,255,255,.1); }

/* Rest / break tint */
.sst-rest .sst-label, .sst-break .sst-label  { color:rgba(255,200,80,.7); }
.sst-rest .sst-time,  .sst-break .sst-time   { color:rgba(255,200,80,.9); }
/* Finals tint */
.sst-final .sst-label { color:rgba(255,209,0,.8); }
.sst-final .sst-time  { color:#FFD100; }

/* Progress bar */
.sst-progress {
  height:3px;background:rgba(255,255,255,.06);
}
.sst-fill {
  height:100%;background:var(--blue);
  transition:width .5s linear;
}
.sst-rest .sst-fill, .sst-break .sst-fill { background:rgba(255,200,80,.6); }
.sst-final .sst-fill                      { background:#FFD100; }

.sst-done {
  text-align:center;padding:16px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:15px;color:var(--muted);
}

/* ── SYNC DOT ────────────────────────────────────────────────────────────── */
.sync-dot {
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:transparent;flex-shrink:0;transition:background .3s;
}
.sync-dot.syncing { background:#CEE64A; animation:sync-pulse .8s ease-in-out infinite; }
.sync-dot.ok      { background:#CEE64A; }
.sync-dot.err     { background:#D85B3A; }
@keyframes sync-pulse {
  0%,100% { opacity:1; } 50% { opacity:.25; }
}

/* ── SAFE AREA ────────────────────────────────────────────────────────────── */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .setup-actions,.round-actions,.result-actions{
    padding-bottom:calc(24px + env(safe-area-inset-bottom));
  }
}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(0,100,255,.2);border-radius:2px}
