:root {
  color-scheme: dark;
  --ink: #f4f0e6;
  --muted: #a8a39a;
  --panel: #1b1a17;
  --panel-2: #24221e;
  --line: rgba(244, 240, 230, 0.12);
  --red: #d33b32;
  --green: #168052;
  --cream: #e6dfc9;
  --black: #1b1b19;
  --gold: #d3a94f;
  font-family: Inter, system-ui, sans-serif;
  background: #11100e;
  color: var(--ink);
}

* { box-sizing: border-box; }
html, body, #app { min-height: 100%; margin: 0; }
body {
  min-height: 100vh;
  min-height: 100dvh;
  background:
    radial-gradient(circle at 15% 0%, rgba(211, 169, 79, 0.09), transparent 32rem),
    #11100e;
  overscroll-behavior: none;
}
button, input, select { font: inherit; }
button { color: inherit; }

.shell { min-height: 100dvh; display: flex; flex-direction: column; }
.shell:has(.game) { height: 100dvh; min-height: 0; overflow: hidden; }
.topbar {
  min-height: 66px; padding: max(14px, env(safe-area-inset-top)) 20px 12px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  border-bottom: 1px solid var(--line); background: rgba(17,16,14,.9); backdrop-filter: blur(18px);
  position: sticky; top: 0; z-index: 20;
}
.brand { display: flex; align-items: center; gap: 11px; }
.brand-mark { width: 32px; height: 32px; }
.brand h1 { font: 800 23px/1 Barlow Condensed, sans-serif; letter-spacing: .055em; text-transform: uppercase; margin: 0; }
.status-pill { color: var(--muted); border: 1px solid var(--line); padding: 7px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; }

.setup { width: min(980px, 100%); margin: auto; padding: 42px 22px 60px; }
.eyebrow { color: var(--gold); text-transform: uppercase; letter-spacing: .16em; font: 700 12px/1 Inter, sans-serif; margin-bottom: 12px; }
.hero h2 { font: 700 clamp(42px, 7vw, 72px)/.9 Barlow Condensed, sans-serif; letter-spacing: -.02em; text-transform: uppercase; white-space: nowrap; margin: 0; max-width: 760px; }
.hero p { color: var(--muted); max-width: 560px; line-height: 1.6; white-space: nowrap; margin: 16px 0 32px; }
.setup-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.card { background: linear-gradient(145deg, rgba(36,34,30,.96), rgba(25,24,21,.96)); border: 1px solid var(--line); border-radius: 20px; padding: 22px; box-shadow: 0 18px 50px rgba(0,0,0,.2); }
.card h3 { font: 700 22px/1 Barlow Condensed, sans-serif; text-transform: uppercase; letter-spacing: .06em; margin: 0 0 16px; }
.game-options { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; }
.choice { cursor: pointer; }
.choice input { position: absolute; opacity: 0; pointer-events: none; }
.choice span { display: grid; place-items: center; min-height: 66px; border-radius: 12px; background: #151411; border: 1px solid var(--line); font: 700 21px Barlow Condensed, sans-serif; transition: .2s ease; }
.choice input:checked + span { color: #16130c; background: var(--gold); border-color: var(--gold); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(211,169,79,.18); }
.field-label { display: block; color: var(--muted); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; margin: 18px 0 8px; }
.stepper { display: grid; grid-template-columns: 46px 1fr 46px; gap: 8px; }
.stepper button, .icon-button { border: 1px solid var(--line); background: #151411; border-radius: 11px; cursor: pointer; }
.stepper strong { display: grid; place-items: center; background: #151411; border-radius: 11px; font: 700 26px Barlow Condensed, sans-serif; }
.player-inputs { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
input[type="text"] { width: 100%; color: var(--ink); background: #151411; border: 1px solid var(--line); border-radius: 11px; padding: 13px 14px; outline: none; }
input[type="text"]:focus { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(211,169,79,.12); }
.toggle-row { display: flex; align-items: center; justify-content: space-between; margin-top: 18px; color: var(--muted); font-size: 14px; }
.switch { position: relative; width: 48px; height: 28px; }
.switch input { opacity: 0; }
.switch span { position: absolute; inset: 0; background: #11100e; border: 1px solid var(--line); border-radius: 99px; transition: .2s; }
.switch span::after { content: ""; position: absolute; width: 20px; height: 20px; left: 3px; top: 3px; background: var(--muted); border-radius: 50%; transition: .2s; }
.switch input:checked + span { background: var(--green); }
.switch input:checked + span::after { transform: translateX(20px); background: white; }
.primary { width: 100%; margin-top: 18px; border: 0; border-radius: 13px; padding: 15px 20px; color: #13100a; background: var(--gold); font-weight: 800; cursor: pointer; text-transform: uppercase; letter-spacing: .08em; box-shadow: 0 10px 30px rgba(211,169,79,.18); }

.game { height: calc(100dvh - 66px); min-height: 560px; display: grid; grid-template-columns: minmax(0, 1fr) minmax(400px, 470px); }
.board-side { min-height: 0; display: flex; flex-direction: column; padding: 10px; position: relative; }
.board-viewport { flex: 1; min-height: 420px; display: grid; place-items: center; overflow: hidden; border-radius: 22px; background: radial-gradient(circle, #25231f 0%, #151411 62%, #0f0e0c 100%); border: 1px solid var(--line); touch-action: none; position: relative; }
.board-stage { width: min(100%, calc(100dvh - 96px)); aspect-ratio: 1; transform-origin: center; will-change: transform; }
.dartboard { width: 100%; height: 100%; display: block; overflow: visible; filter: drop-shadow(0 22px 20px rgba(0,0,0,.48)); }
.dartboard .scoring { cursor: crosshair; stroke: #5b554b; stroke-width: .7; transition: filter .08s, opacity .08s; }
.dartboard .scoring:active { filter: brightness(1.5); opacity: .82; }
.dartboard text { fill: var(--cream); font: 700 22px Barlow Condensed, sans-serif; text-anchor: middle; dominant-baseline: central; pointer-events: none; }
.zoom-hint { position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%); padding: 7px 10px; border-radius: 99px; background: rgba(0,0,0,.55); color: #c5c0b7; font-size: 11px; pointer-events: none; transition: opacity .3s; }

.score-side { min-height: 0; border-left: 1px solid var(--line); background: var(--panel); display: flex; flex-direction: column; }
.throw-strip { min-height: 52px; padding: 0 15px; display: flex; align-items: center; justify-content: space-between; gap: 12px; border-bottom: 1px solid var(--line); }
.throw-strip strong { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 16px; }
.throw-strip span { flex: none; color: var(--gold); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.score-workspace { min-height: 0; flex: 1; display: grid; grid-template-columns: minmax(0, 1fr) 142px; gap: 9px; padding: 10px; }
.scoreboard-panel { min-width: 0; overflow: auto; }
.score-actions { align-self: start; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); grid-auto-rows: 76px; gap: 7px; }
.score-actions button { min-width: 0; padding: 7px 4px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px; font-size: 11px; line-height: 1.1; }
.score-actions button span { font: 800 23px/1 Barlow Condensed, sans-serif; color: var(--gold); }
.score-actions .danger span { color: #e77770; }
.cricket-board { min-width: 0; height: 100%; display: grid; grid-template-rows: auto repeat(7, minmax(28px, 1fr)); overflow: hidden; border: 1px solid var(--line); border-radius: 13px; background: #13120f; }
.cricket-head, .cricket-row { display: grid; grid-template-columns: repeat(var(--left-count), minmax(0, 1fr)) 38px repeat(var(--right-count), minmax(0, 1fr)); align-items: center; text-align: center; }
.cricket-head { min-height: 45px; background: #24211b; border-bottom: 1px solid var(--line); }
.cricket-head .cricket-player { align-self: stretch; min-width: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 3px 2px 0; border-top: 2px solid transparent; }
.cricket-head .cricket-player.active { color: var(--gold); border-top-color: var(--gold); }
.cricket-player strong { width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 11px; }
.cricket-player > span { font: 800 14px/1 Barlow Condensed, sans-serif; }
.cricket-player small { width: 100%; display: grid; grid-template-columns: 1fr 1fr; margin-top: 3px; color: var(--muted); font: 700 7px/1 Barlow Condensed, sans-serif; text-transform: uppercase; }
.cricket-player i { font-style: normal; }
.cricket-head > b { color: var(--muted); font: 700 9px Barlow Condensed, sans-serif; text-transform: uppercase; }
.cricket-row { border-bottom: 1px solid rgba(244,240,230,.07); }
.cricket-row:last-child { border-bottom: 0; }
.cricket-row > b { font: 800 16px Barlow Condensed, sans-serif; color: var(--cream); }
.cricket-player-cells { height: 100%; min-width: 0; display: grid; grid-template-columns: 1fr 1fr; align-items: center; }
.cricket-player-cells.reverse .cricket-points { order: 2; }
.cricket-player-cells.reverse .cricket-mark { order: 1; }
.cricket-points { min-width: 0; overflow: hidden; font: 800 13px Barlow Condensed, sans-serif; color: var(--gold); font-style: normal; }
.cricket-mark { width: 24px; height: 24px; margin: auto; display: grid; place-items: center; position: relative; font: 800 20px/1 Barlow Condensed, sans-serif; color: var(--ink); font-style: normal; }
.cricket-mark.empty { color: #5f5b54; font-size: 15px; }
.cricket-mark.closed { border: 2px solid var(--green); border-radius: 50%; color: white; background: rgba(22,128,82,.2); }
.cricket-mark:not(.empty) b { position: absolute; width: 3px; height: 22px; border-radius: 99px; background: currentColor; transform: rotate(42deg); }
.cricket-mark.double b:first-child, .cricket-mark.x-close b:first-child { transform: rotate(42deg); }
.cricket-mark.double b:last-child, .cricket-mark.x-close b:last-child { transform: rotate(-42deg); }
.cricket-mark.closed b { height: 18px; width: 2.5px; }
.x01-board { height: 100%; min-height: 0; display: flex; flex-direction: column; gap: 7px; }
.x01-players { flex: none; display: grid; gap: 6px; }
.x01-player { padding: 7px 9px; border-radius: 11px; background: #141310; border: 1px solid var(--line); }
.x01-player.active { border-color: rgba(211,169,79,.55); box-shadow: inset 3px 0 var(--gold); }
.x01-player-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.x01-player-top strong { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 12px; }
.x01-player-top > b { font: 800 29px/.8 Barlow Condensed, sans-serif; }
.x01-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 3px; margin-top: 6px; }
.x01-stats span { color: var(--muted); font: 700 7px/1 Barlow Condensed, sans-serif; text-align: center; text-transform: uppercase; }
.x01-stats b { display: block; margin-bottom: 2px; color: var(--cream); font: 800 13px/1 Barlow Condensed, sans-serif; text-transform: none; }
.checkout-panel { flex: 1; min-height: 0; display: flex; flex-direction: column; overflow: hidden; border: 1px solid var(--line); border-radius: 11px; background: #13120f; }
.checkout-heading { flex: none; display: flex; align-items: center; justify-content: space-between; gap: 7px; padding: 7px 9px; background: #24211b; border-bottom: 1px solid var(--line); }
.checkout-heading strong { font: 800 12px Barlow Condensed, sans-serif; text-transform: uppercase; letter-spacing: .04em; }
.checkout-heading span { color: var(--gold); font-size: 8px; font-weight: 800; text-transform: uppercase; }
.checkout-routes { min-height: 0; overflow-y: auto; padding: 5px; scrollbar-width: thin; }
.checkout-routes > div { min-height: 28px; display: flex; align-items: center; gap: 4px; padding: 3px 5px; border-bottom: 1px solid rgba(244,240,230,.06); }
.checkout-routes > div:last-child { border-bottom: 0; }
.checkout-routes span { min-width: 30px; padding: 3px 4px; border-radius: 5px; background: #24221e; font: 800 13px Barlow Condensed, sans-serif; text-align: center; }
.checkout-routes span.finish { color: white; background: var(--green); }
.checkout-routes p { margin: 18px 8px; color: var(--muted); font-size: 11px; text-align: center; }
.score-header { padding: 18px 18px 12px; border-bottom: 1px solid var(--line); }
.score-header-row { display: flex; justify-content: space-between; align-items: center; }
.score-header h2 { margin: 0; font: 800 34px/.9 Barlow Condensed, sans-serif; text-transform: uppercase; }
.game-chip { color: var(--gold); border: 1px solid rgba(211,169,79,.3); background: rgba(211,169,79,.08); padding: 6px 9px; border-radius: 99px; font-size: 11px; font-weight: 800; letter-spacing: .08em; }
.darts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 7px; margin-top: 15px; }
.dart-slot { min-height: 54px; display: grid; place-items: center; border-radius: 11px; background: #141310; border: 1px solid var(--line); }
.dart-slot span { font: 800 21px Barlow Condensed, sans-serif; }
.dart-slot small { color: var(--muted); font-size: 10px; }
.players { padding: 12px; overflow-y: auto; flex: 1; }
.player-card { display: grid; grid-template-columns: 34px 1fr auto; align-items: center; gap: 10px; padding: 12px; margin-bottom: 8px; border: 1px solid transparent; border-radius: 14px; background: #171613; transition: .2s; }
.player-card.active { background: #28251e; border-color: rgba(211,169,79,.4); box-shadow: inset 3px 0 var(--gold); }
.player-card.winner { border-color: var(--green); }
.player-order { width: 28px; height: 28px; display: grid; place-items: center; border-radius: 50%; color: var(--muted); background: #0f0e0c; font: 700 13px Barlow Condensed; }
.player-name { font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.player-meta { color: var(--muted); font-size: 11px; margin-top: 3px; }
.big-score { font: 800 38px/.9 Barlow Condensed, sans-serif; text-align: right; }
.cricket-score { color: var(--gold); font: 800 26px Barlow Condensed, sans-serif; text-align: right; }
.marks { grid-column: 2 / 4; display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; margin-top: 5px; }
.mark { text-align: center; padding: 4px 1px; border-radius: 5px; background: #11100e; color: var(--muted); font: 700 11px Barlow Condensed; }
.mark.closed { color: white; background: var(--green); }
.score-footer { padding: 12px 16px max(14px, env(safe-area-inset-bottom)); border-top: 1px solid var(--line); display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.secondary, .danger { border: 1px solid var(--line); border-radius: 11px; padding: 12px; background: #141310; font-weight: 700; cursor: pointer; }
.danger { color: #e77770; }
.toast { position: fixed; left: 50%; top: 82px; transform: translate(-50%, -10px); z-index: 60; width: max-content; max-width: calc(100vw - 28px); background: var(--cream); color: #171512; border-radius: 99px; padding: 11px 17px; font-size: 13px; font-weight: 800; text-align: center; opacity: 0; pointer-events: none; transition: .2s; box-shadow: 0 10px 30px rgba(0,0,0,.35); }
.toast.show { opacity: 1; transform: translate(-50%, 0); }
.modal-backdrop { position: absolute; inset: 10px; z-index: 50; background: rgba(0,0,0,.72); backdrop-filter: blur(8px); display: grid; place-items: center; padding: 20px; border-radius: 22px; }
.modal { width: min(420px, 100%); background: var(--panel-2); border: 1px solid var(--line); border-radius: 22px; padding: 28px; text-align: center; }
.modal .trophy { font: 800 70px/.8 Barlow Condensed; color: var(--gold); }
.modal h2 { font: 800 42px/.95 Barlow Condensed; text-transform: uppercase; margin: 18px 0 8px; }
.modal p { color: var(--muted); }

@media (max-width: 820px) {
  .setup-grid { grid-template-columns: 1fr; }
  .game { height: calc(100dvh - 66px); min-height: 0; display: flex; flex-direction: column; overflow: hidden; }
  .board-side { flex: none; height: min(calc(100vw + 12px), 53dvh); min-height: 0; padding: 6px; }
  .modal-backdrop { inset: 6px; border-radius: 16px; }
  .modal { width: min(360px, 100%); padding: 20px; }
  .modal .trophy { font-size: 56px; }
  .modal h2 { margin-top: 13px; font-size: 34px; }
  .board-viewport { flex: 1; min-height: 0; border-radius: 16px; }
  .board-stage { width: min(100%, 52dvh); }
  .zoom-hint { bottom: 6px; padding: 5px 8px; font-size: 9px; }
  .score-side { flex: 1; min-height: 0; border-left: 0; border-top: 1px solid var(--line); }
  .throw-strip { min-height: 38px; padding: 0 11px; }
  .score-workspace { padding: 7px; gap: 7px; grid-template-columns: minmax(0, 1fr) 124px; }
  .score-actions { grid-auto-rows: 68px; gap: 6px; }
  .score-actions button { font-size: 10px; padding: 5px 3px; }
}
@media (max-width: 480px) {
  .topbar { min-height: 58px; padding-left: 14px; padding-right: 14px; }
  .brand h1 { font-size: 20px; }
  .setup { padding: 28px 14px 46px; }
  .hero h2 { font-size: clamp(37px, 11vw, 46px); }
  .hero p { font-size: 13px; }
  .card { padding: 17px; border-radius: 16px; }
  .player-inputs { grid-template-columns: 1fr; }
  .game { height: calc(100dvh - 58px); }
  .board-side { height: min(calc(100vw + 8px), 49dvh); padding: 4px; }
  .modal-backdrop { inset: 4px; padding: 12px; }
  .modal { padding: 16px; }
  .modal .trophy { font-size: 48px; }
  .modal h2 { margin: 10px 0 5px; font-size: 30px; }
  .modal p { margin: 7px 0; font-size: 12px; }
  .modal .primary { margin-top: 10px; padding: 11px; }
  .board-stage { width: min(100%, 48dvh); }
  .throw-strip { min-height: 36px; }
  .score-workspace { grid-template-columns: minmax(0, 1fr) 116px; padding: 6px; gap: 6px; }
  .score-actions { grid-auto-rows: 64px; gap: 5px; }
  .score-actions button { font-size: 9px; }
  .score-actions button span { font-size: 20px; }
  .x01-player { padding: 6px 7px; }
  .x01-player-top > b { font-size: 25px; }
  .x01-stats b { font-size: 12px; }
  .checkout-routes span { min-width: 27px; font-size: 12px; }
  .cricket-head { min-height: 45px; }
  .cricket-board { grid-template-rows: auto repeat(7, minmax(25px, 1fr)); }
}
