/* ===== Darts Scorer — landscape-first, big-board dark UI ===== */
:root{
  --bg:#0b0f14; --surface:#141b24; --surface2:#1d2732; --elev:#26333f;
  --text:#eef3f8; --muted:#8ea0b3; --accent:#3ba3ff; --good:#2bd47a;
  --warn:#ffcf3a; --bad:#ff5b5b; --line:#243040;
  --radius:16px; --radius-sm:10px;
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;margin:0}
body{
  background:var(--bg); color:var(--text); font-family:var(--font);
  overscroll-behavior:none; touch-action:manipulation;
  -webkit-user-select:none; user-select:none;
}
button{font-family:inherit;color:inherit;border:0;background:none;cursor:pointer}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---------- App shell ---------- */
#app{height:100dvh;height:100vh;display:flex;flex-direction:column;overflow:hidden}

/* ---------- Top bar ---------- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:8px 14px;background:var(--surface);border-bottom:1px solid var(--line);
  flex:0 0 auto;
}
.tb-left{display:flex;align-items:center;gap:12px;min-width:0}
.tb-title{font-weight:800;font-size:19px;line-height:1;letter-spacing:.3px;display:flex;flex-direction:column;gap:3px;min-width:0}
.tb-sub{font-weight:600;font-size:12px;color:var(--muted);letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-right{display:flex;align-items:center;gap:8px}
.icon-btn{
  width:44px;height:44px;border-radius:12px;background:var(--surface2);
  display:grid;place-items:center;font-size:20px;font-weight:800;color:var(--text);
  border:1px solid var(--line);
}
.icon-btn:active{transform:scale(.94)}
.pill-btn{
  height:44px;padding:0 16px;border-radius:12px;background:var(--surface2);
  border:1px solid var(--line);font-weight:700;font-size:14px;color:var(--text);
  display:inline-flex;align-items:center;gap:7px;
}
.pill-btn:active{transform:scale(.96)}
.pill-btn.accent{background:color-mix(in srgb,var(--accent) 20%,transparent);border-color:color-mix(in srgb,var(--accent) 45%,transparent)}

/* ---------- Game layout ---------- */
.game{flex:1 1 auto;display:grid;grid-template-columns:minmax(0,1fr) clamp(340px,32vw,460px);gap:14px;padding:14px;min-height:0}
.board-col{display:flex;flex-direction:column;min-width:0;min-height:0;gap:10px}
.side-col{display:flex;flex-direction:column;min-height:0;gap:12px}

/* input tabs */
.input-tabs{display:flex;gap:8px;flex:0 0 auto}
.input-tabs button{
  flex:1;height:40px;border-radius:11px;background:var(--surface);border:1px solid var(--line);
  font-weight:700;font-size:14px;color:var(--muted);display:flex;align-items:center;justify-content:center;gap:6px;
}
.input-tabs button[aria-selected="true"]{background:var(--surface2);color:var(--text);border-color:color-mix(in srgb,var(--accent) 40%,var(--line))}

/* board stage */
.stage{flex:1 1 auto;display:grid;place-items:center;min-height:0;position:relative}
.board-wrap{
  aspect-ratio:1/1;height:100%;max-height:100%;max-width:100%;
  display:grid;place-items:center;filter:drop-shadow(0 18px 34px rgba(0,0,0,.55));
}
.board-svg{width:100%;height:100%;display:block}
.board-svg [data-dv]{cursor:pointer;transition:filter .05s ease}
.board-svg [data-dv]:active{filter:brightness(1.35)}
.board-svg [data-dv]:focus-visible{outline:none;stroke:var(--accent);stroke-width:6}
.board-hint{position:absolute;bottom:2px;left:50%;transform:translateX(-50%);font-size:12px;color:var(--muted);font-weight:600;background:color-mix(in srgb,var(--bg) 70%,transparent);padding:3px 10px;border-radius:20px;pointer-events:none}

/* keypad */
.keypad{flex:1 1 auto;display:flex;flex-direction:column;gap:10px;min-height:0}
.mult-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;flex:0 0 auto}
.mult-row button{
  height:56px;border-radius:12px;background:var(--surface);border:1px solid var(--line);
  font-weight:800;font-size:16px;color:var(--muted);letter-spacing:.5px;
}
.mult-row button[aria-pressed="true"]{color:#0b0f14;background:var(--warn);border-color:var(--warn)}
.num-grid{flex:1 1 auto;display:grid;grid-template-columns:repeat(5,1fr);grid-auto-rows:1fr;gap:8px;min-height:0}
.num-grid button{
  border-radius:12px;background:var(--surface2);border:1px solid var(--line);
  font-weight:800;font-size:clamp(18px,2.4vw,26px);color:var(--text);
  display:flex;align-items:center;justify-content:center;
}
.num-grid button:active{transform:scale(.95);background:var(--elev)}
.num-grid button.wide{grid-column:span 1}
.num-grid button.bull{color:var(--warn)}
.num-grid button.miss{color:var(--bad)}

/* ---------- Player cards ---------- */
.players{display:flex;flex-direction:column;gap:10px;overflow:auto;flex:1 1 auto;min-height:0;padding-right:2px}
.pcard{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:12px 14px;display:flex;flex-direction:column;gap:8px;position:relative;flex:0 0 auto;
}
.pcard.active{
  border-color:color-mix(in srgb,var(--accent) 65%,transparent);
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 45%,transparent),0 0 26px color-mix(in srgb,var(--accent) 22%,transparent);
  background:color-mix(in srgb,var(--accent) 8%,var(--surface));
}
.pc-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.pc-name{font-weight:800;font-size:17px;display:flex;align-items:center;gap:8px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pc-dot{width:12px;height:12px;border-radius:50%;flex:0 0 auto}
.pc-legs{display:flex;gap:4px;flex:0 0 auto}
.pip{width:11px;height:11px;border-radius:50%;background:var(--line)}
.pip.on{background:var(--warn)}
.pc-mid{display:flex;align-items:flex-end;justify-content:space-between;gap:10px}
.pc-rem{font-weight:800;font-size:clamp(40px,6vw,64px);line-height:.9;letter-spacing:-1px;font-variant-numeric:tabular-nums}
.pcard.active .pc-rem{color:var(--accent)}
.pc-rem.bustflash{color:var(--bad)!important}
.pc-turn-total{font-weight:800;font-size:26px;color:var(--muted);font-variant-numeric:tabular-nums}
.pc-turn-total.big{color:var(--good)}
.pc-darts{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.dchip{
  min-width:52px;height:38px;padding:0 10px;border-radius:9px;background:var(--surface2);
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:15px;color:var(--text);font-variant-numeric:tabular-nums;
}
.dchip.empty{color:var(--muted);opacity:.5}
.dchip.bust{background:color-mix(in srgb,var(--bad) 25%,transparent);border-color:var(--bad);color:var(--bad)}
.pc-meta{display:flex;gap:12px;font-size:12.5px;color:var(--muted);font-weight:600;flex-wrap:wrap}
.pc-meta b{color:var(--text);font-weight:800}
.pc-checkout{
  font-size:13px;font-weight:700;color:var(--good);
  background:color-mix(in srgb,var(--good) 14%,transparent);
  border:1px solid color-mix(in srgb,var(--good) 35%,transparent);
  border-radius:9px;padding:6px 10px;display:flex;gap:6px;align-items:center;
}
.pc-checkout .co-darts{color:var(--text)}

/* ---------- Bottom controls ---------- */
.controls{display:grid;grid-template-columns:1fr 1fr 1.5fr;gap:10px;flex:0 0 auto}
.btn{
  height:60px;border-radius:14px;font-weight:800;font-size:17px;letter-spacing:.4px;
  display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line);
  background:var(--surface2);color:var(--text);
}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.4}
.btn-miss{color:var(--bad)}
.btn-undo{color:var(--warn)}
.btn-next{background:var(--elev);color:var(--muted)}
.btn-next.ready{background:var(--good);color:#07230f;border-color:var(--good);box-shadow:0 0 22px color-mix(in srgb,var(--good) 40%,transparent);animation:pulse 1.3s ease-in-out infinite}
@keyframes pulse{50%{box-shadow:0 0 30px color-mix(in srgb,var(--good) 60%,transparent)}}

/* ---------- Setup screen ---------- */
.setup{flex:1 1 auto;overflow:auto;display:grid;place-items:start center;padding:20px}
.setup-card{
  width:min(760px,94vw);background:var(--surface);border:1px solid var(--line);border-radius:22px;
  padding:24px 26px;display:flex;flex-direction:column;gap:22px;margin:auto 0;
}
.setup-logo{display:flex;align-items:center;gap:12px}
.setup-logo .big{font-weight:900;font-size:30px;letter-spacing:.3px}
.setup-logo .sub{color:var(--muted);font-weight:600;font-size:13px}
.field{display:flex;flex-direction:column;gap:9px}
.field > label{font-weight:800;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{
  min-width:74px;height:48px;padding:0 16px;border-radius:12px;background:var(--surface2);
  border:1px solid var(--line);font-weight:800;font-size:15px;color:var(--text);
}
.seg button[aria-pressed="true"]{background:color-mix(in srgb,var(--accent) 22%,transparent);border-color:var(--accent);color:var(--text)}
.toggle-row{display:flex;gap:12px;flex-wrap:wrap}
.toggle{
  flex:1;min-width:160px;height:56px;border-radius:12px;background:var(--surface2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;padding:0 16px;font-weight:800;font-size:15px;
}
.toggle[aria-pressed="true"]{border-color:var(--good);background:color-mix(in srgb,var(--good) 14%,transparent)}
.toggle .sw{width:46px;height:26px;border-radius:20px;background:var(--line);position:relative;transition:background .15s}
.toggle .sw::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:left .15s}
.toggle[aria-pressed="true"] .sw{background:var(--good)}
.toggle[aria-pressed="true"] .sw::after{left:23px}
.players-setup{display:flex;flex-direction:column;gap:10px}
.psrow{display:flex;gap:10px;align-items:center}
.psrow .num{width:34px;height:52px;display:grid;place-items:center;font-weight:800;color:var(--muted);flex:0 0 auto}
.psrow input{
  flex:1;height:52px;border-radius:12px;background:var(--surface2);border:1px solid var(--line);
  color:var(--text);font-size:16px;font-weight:600;padding:0 14px;-webkit-user-select:text;user-select:text;
}
.psrow input:focus{outline:none;border-color:var(--accent)}
.psrow .rm{width:52px;height:52px;border-radius:12px;background:var(--surface2);border:1px solid var(--line);color:var(--bad);font-size:22px;font-weight:800;flex:0 0 auto}
.addp{height:50px;border-radius:12px;background:var(--surface2);border:1px dashed var(--line);color:var(--muted);font-weight:800;font-size:14px}
.start-btn{
  height:66px;border-radius:16px;background:var(--good);color:#07230f;font-weight:900;font-size:20px;letter-spacing:.5px;
  box-shadow:0 10px 30px color-mix(in srgb,var(--good) 35%,transparent);
}
.start-btn:active{transform:scale(.98)}
.setup-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media (max-width:640px){.setup-grid{grid-template-columns:1fr}}

/* ---------- Winner overlay ---------- */
.overlay{position:fixed;inset:0;background:rgba(3,6,10,.72);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:50;padding:20px}
.win-card{
  width:min(520px,92vw);background:var(--surface);border:1px solid var(--line);border-radius:24px;
  padding:34px;text-align:center;display:flex;flex-direction:column;gap:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.win-crown{font-size:56px}
.win-name{font-weight:900;font-size:34px}
.win-sub{color:var(--muted);font-weight:700;font-size:15px}
.win-stats{display:flex;justify-content:center;gap:26px;margin-top:4px}
.win-stat{display:flex;flex-direction:column;gap:2px}
.win-stat b{font-size:24px;font-weight:900}
.win-stat span{font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.win-actions{display:flex;gap:12px;margin-top:6px}
.win-actions button{flex:1;height:58px;border-radius:14px;font-weight:800;font-size:16px}
.win-actions .rematch{background:var(--good);color:#07230f}
.win-actions .home{background:var(--surface2);border:1px solid var(--line);color:var(--text)}

/* ---------- Toast ---------- */
#toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);z-index:60;
  background:var(--elev);color:var(--text);padding:14px 22px;border-radius:14px;font-weight:800;font-size:16px;
  border:1px solid var(--line);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;box-shadow:0 12px 30px rgba(0,0,0,.5)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.gold{background:color-mix(in srgb,var(--warn) 22%,var(--elev));border-color:var(--warn)}

/* portrait nudge */
.rotate-tip{display:none}
@media (orientation:portrait) and (min-width:600px){
  .game{grid-template-columns:1fr}
  .rotate-tip{display:flex;gap:8px;align-items:center;justify-content:center;padding:8px;color:var(--warn);font-weight:700;font-size:13px;background:color-mix(in srgb,var(--warn) 12%,transparent);border-bottom:1px solid var(--line)}
}

/* ---------- Mode menu + setup extras ---------- */
.setup-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.mode-seg button{flex:1;min-width:120px}
.hint{margin:0;color:var(--muted);font-size:13px;font-weight:600;line-height:1.5;background:var(--surface2);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.install-lg{height:48px}

/* ATC dimmed segments */
.board-svg .dim{cursor:default;opacity:.9}

/* corner stat in place of leg pips (ATC/Count Up) */
.pc-corner{font-size:12px;font-weight:700;color:var(--muted);background:var(--surface2);border:1px solid var(--line);border-radius:8px;padding:3px 9px}

/* keypad NEXT button */
.num-grid button.next2{background:var(--elev);color:var(--muted);font-size:14px}
.num-grid button.next2.ready{background:var(--good);color:#07230f;border-color:var(--good)}

/* ---------- Cricket grid ---------- */
.cricket-panel{display:flex;flex-direction:column;gap:10px;flex:1 1 auto;min-height:0}
.ck-turn{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:8px 12px;flex:0 0 auto}
.ck-turn-name{font-weight:800;font-size:15px}
.ck-chips{display:flex;gap:6px}
.cricket-wrap{flex:1 1 auto;overflow:auto;border:1px solid var(--line);border-radius:14px;background:var(--surface)}
table.cricket{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
table.cricket th,table.cricket td{border-bottom:1px solid var(--line);text-align:center;padding:8px 6px}
.ck-th{width:66px}
.ck-tgt{position:sticky;left:0;background:var(--surface2);font-weight:800;font-size:16px;width:66px;color:var(--text)}
.ck-ph{font-size:13px;font-weight:800;line-height:1.25}
.ck-ph.act{background:color-mix(in srgb,var(--accent) 15%,transparent)}
.ck-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:5px;vertical-align:middle}
.ck-pts{display:block;font-size:22px;font-weight:800;color:var(--accent)}
.ck-closed{display:block;font-size:10.5px;color:var(--muted);font-weight:700}
.ck-cell{font-size:22px;font-weight:800;color:var(--text);height:46px}
.ck-cell.act{background:color-mix(in srgb,var(--accent) 8%,transparent)}
.ck-cell.done{color:var(--good)}
.ck-close{color:var(--good)}
