﻿/* ── Reset & Base ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Palette ─────────────────────────────────────────────────────────── */
:root {
  --bg:        #0d1117;
  --bg2:       #161b22;
  --bg3:       #21262d;
  --bg4:       #2d333b;
  --bg-deep:   #0a0a0d;
  --bg-oche:   #0d2918;
  --bg-hero:   #0d0d13;
  --red:       #c0392b;
  --red-h:     #e74c3c;
  --red-dk:    #6e040e;
  --accent:    #58a6ff;
  --accent2:   #1f6feb;
  --green:     #3fb950;
  --green-dk:  #238636;
  --amber:     #d29922;
  --gold:      #ffd700;
  --purple:    #bc8cff;
  --white:     #e6edf3;
  --muted:     #8b949e;
  --border:    #30363d;
  --radius:    8px;
  --radius-sm: 5px;
  --shadow:    0 4px 24px rgba(0,0,0,0.7);
}

html { font-size: 16px; scroll-behavior: smooth; }
body { background:var(--bg); color:var(--white); font-family:'Segoe UI',system-ui,sans-serif; line-height:1.5; min-height:100vh; display:flex; flex-direction:column; }
.main-content { flex:1; }
a { color:var(--accent); text-decoration:none; }
a:hover { color:#79b8ff; }
input,select,textarea { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius-sm); color:var(--white); font-family:inherit; font-size:1rem; padding:10px 14px; width:100%; transition:border-color .2s; }
input:focus,select:focus { outline:none; border-color:var(--accent); }
input::placeholder { color:var(--muted); }
label { color:var(--muted); font-size:.85rem; display:block; margin-bottom:4px; }

/* Buttons */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:10px 20px; border:none; border-radius:var(--radius-sm); font-size:.92rem; font-weight:700; cursor:pointer; transition:background .15s,transform .1s; text-decoration:none; font-family:'Segoe UI',sans-serif; }
.btn:active { transform:scale(.97); }
.btn-primary { background:var(--red); color:#fff; }
.btn-primary:hover { background:var(--red-h); color:#fff; }
.btn-accent  { background:var(--accent2); color:#fff; }
.btn-accent:hover  { background:var(--accent); color:#000; }
.btn-green   { background:var(--green-dk); color:#fff; }
.btn-green:hover   { background:var(--green); color:#000; }
.btn-amber   { background:#7a5c10; color:var(--amber); border:1px solid var(--amber); }
.btn-amber:hover   { background:var(--amber); color:#000; }
.btn-ghost   { background:var(--bg3); color:var(--white); border:1px solid var(--border); }
.btn-ghost:hover   { background:var(--bg4); color:var(--white); }
.btn-danger  { background:var(--red-dk); color:#fff; }
.btn-danger:hover  { background:var(--red); color:#fff; }
.btn-full { width:100%; }
.btn-sm   { padding:6px 14px; font-size:.82rem; }
.btn-lg   { padding:14px 32px; font-size:1.05rem; letter-spacing:.02em; }

/* Cards */
.card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:18px; }
.card-title { font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--red); margin-bottom:14px; }

/* Nav stripe + bar */
.nav-stripe { height:4px; background:var(--red); width:100%; }
.nav { display:flex; align-items:center; justify-content:space-between; background:var(--bg-deep); border-bottom:1px solid var(--border); padding:0 20px; height:54px; position:sticky; top:0; z-index:100; }
.nav-brand { display:flex; align-items:center; gap:10px; text-decoration:none; }
.nav-brand-icon { font-size:1.5rem; color:var(--red); }
.nav-brand-text { display:flex; flex-direction:column; line-height:1.1; }
.nav-brand-text .title { font-size:1rem; font-weight:800; color:var(--white); letter-spacing:.04em; }
.nav-brand-text .sub   { font-size:.62rem; font-weight:800; color:var(--red); letter-spacing:.12em; }
.nav-links { display:flex; align-items:center; gap:6px; }
.nav-user  { display:flex; align-items:center; gap:12px; }

/* ── Mobile hamburger & nav drawer ─────────────────────── */
.nav-hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px 4px; margin-left:auto; z-index:200; }
.nav-hamburger span { display:block; width:24px; height:2px; background:var(--white); border-radius:2px; transition:transform .25s, opacity .25s; }
.nav-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mob-nav-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.65); z-index:490; }
.mob-nav-overlay.open { display:block; }

.mob-nav { position:fixed; top:0; right:-320px; width:290px; max-width:88vw; height:100%; background:var(--bg2); border-left:1px solid var(--border); z-index:500; overflow-y:auto; transition:right .28s cubic-bezier(.4,0,.2,1); display:flex; flex-direction:column; }
.mob-nav.open { right:0; }

.mob-nav-head { display:flex; align-items:center; justify-content:space-between; padding:14px 18px; border-bottom:1px solid var(--border); background:var(--bg-deep); }
.mob-nav-logo { display:flex; align-items:center; gap:8px; text-decoration:none; }
.mob-nav-logo-icon { font-size:1.3rem; color:var(--red); }
.mob-nav-logo-text { font-size:.85rem; font-weight:800; letter-spacing:.04em; color:var(--white); }
.mob-nav-close { background:none; border:none; color:var(--muted); font-size:1.3rem; cursor:pointer; padding:4px 8px; line-height:1; }
.mob-nav-close:hover { color:var(--white); }

.mob-nav-user { display:flex; align-items:center; gap:12px; padding:16px 18px; border-bottom:1px solid var(--border); }
.mob-nav-avatar { width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:1.05rem; color:#fff; flex-shrink:0; overflow:hidden; position:relative; }
.mob-nav-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; position:absolute; inset:0; }
.mob-nav-info .dn { font-size:.92rem; font-weight:700; color:var(--white); display:block; line-height:1.2; }
.mob-nav-info .un { font-size:.73rem; color:var(--muted); display:block; }

.mob-nav-links { display:flex; flex-direction:column; flex:1; padding:8px 0; }
.mob-nav-links a { display:flex; align-items:center; gap:14px; padding:14px 20px; color:var(--white); font-size:.93rem; font-weight:600; text-decoration:none; border-bottom:1px solid rgba(48,54,61,.4); transition:background .12s; }
.mob-nav-links a:hover, .mob-nav-links a:active { background:var(--bg3); }
.mob-nav-links a .mnav-icon { font-size:1.1rem; width:22px; text-align:center; flex-shrink:0; }
.mob-nav-links a.mnav-green { color:var(--green); }
.mob-nav-links a.mnav-red { color:var(--red-h); }
.mob-nav-links a.mnav-amber { color:var(--amber); }
.mob-nav-links a.mnav-admin { color:#e74c3c; }

.mob-nav-foot { padding:16px 18px; border-top:1px solid var(--border); }

@media(max-width:768px) {
  .nav-links { display:none !important; }
  .nav-user  { display:none !important; }
  .nav-hamburger { display:flex; }
}
.nav-avatar { width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:.9rem; flex-shrink:0; color:#fff; }
.nav-name .dn { font-size:.88rem; font-weight:700; color:var(--white); display:block; line-height:1.15; }
.nav-name .un { font-size:.70rem; color:#555; display:block; }

/* Page */
.page      { max-width:1080px; margin:0 auto; padding:28px 20px; }
.page-wide { max-width:1400px; margin:0 auto; padding:24px 16px; }

/* Grid */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.grid-6 { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; }
@media(max-width:900px){ .grid-6{grid-template-columns:repeat(3,1fr);} .grid-4{grid-template-columns:repeat(2,1fr);} .grid-3{grid-template-columns:repeat(2,1fr);} }
@media(max-width:600px){ .grid-2,.grid-3,.grid-4,.grid-6{grid-template-columns:1fr;} }

/* Flex helpers */
.flex         { display:flex; }
.flex-center  { display:flex; align-items:center; justify-content:center; }
.flex-between { display:flex; align-items:center; justify-content:space-between; }
.flex-gap     { display:flex; align-items:center; gap:10px; }

/* Type */
.text-muted  { color:var(--muted); }
.text-accent { color:var(--accent); }
.text-green  { color:var(--green); }
.text-red    { color:var(--red); }
.text-gold   { color:var(--gold); }
.text-amber  { color:var(--amber); }
.text-purple { color:var(--purple); }
.text-sm  { font-size:.85rem; }
.text-xs  { font-size:.74rem; }
.text-bold { font-weight:700; }
.text-center { text-align:center; }
.section-label { font-size:.72rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--red); margin-bottom:8px; }
h1 { font-size:1.85rem; font-weight:800; }
h2 { font-size:1.35rem; font-weight:700; }
h3 { font-size:1.05rem; font-weight:600; }
.mb-4{margin-bottom:4px;}.mb-8{margin-bottom:8px;}.mb-16{margin-bottom:16px;}.mb-24{margin-bottom:24px;}
.mt-8{margin-top:8px;}.mt-16{margin-top:16px;}

/* Forms */
.form-group { margin-bottom:16px; }
.form-error { color:var(--red); font-size:.85rem; background:rgba(192,57,43,.12); border:1px solid rgba(192,57,43,.3); border-radius:var(--radius-sm); padding:10px 14px; margin-bottom:16px; }

/* Auth */
.auth-wrap { min-height:calc(100vh - 58px); display:flex; align-items:center; justify-content:center; padding:20px; }
.auth-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:36px 32px; width:100%; max-width:400px; box-shadow:var(--shadow); }
.auth-logo { text-align:center; margin-bottom:28px; }
.auth-logo .dart-icon { font-size:2.8rem; display:block; margin-bottom:8px; }
.auth-logo h1 { font-size:1.5rem; letter-spacing:.04em; }
.auth-logo p { color:var(--red); font-size:.8rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; margin-top:3px; }
.auth-footer { text-align:center; margin-top:14px; font-size:.85rem; color:var(--muted); }

/* Landing */
.hero { background:var(--bg-hero); text-align:center; padding:70px 20px 56px; }
.hero .dart-big { font-size:4rem; display:block; margin-bottom:14px; }
.hero h1 { font-size:2.4rem; margin-bottom:4px; letter-spacing:.02em; }
.hero h1 .pdc { color:var(--red); }
.hero .sub { color:var(--red); font-size:.8rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; margin-bottom:14px; }
.hero p { color:var(--muted); font-size:1rem; max-width:560px; margin:0 auto 26px; }
.hero-cta { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.features-section { padding:36px 20px 48px; max-width:1000px; margin:0 auto; }
.features { display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:12px; }
.feature-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:16px; }
.feature-card .icon { font-size:1.5rem; margin-bottom:8px; }
.feature-card h3 { font-size:.9rem; margin-bottom:5px; }
.feature-card p { color:var(--muted); font-size:.82rem; }

/* Dashboard hero strip */
.dash-hero { background:var(--bg-hero); text-align:center; padding:26px 20px 20px; margin-bottom:16px; }
.dash-hero h2 { font-size:1.7rem; margin-bottom:3px; }
.dash-hero .subline { color:var(--red); font-size:.78rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; margin-bottom:14px; }

/* Stat tile */
.stat-tile { background:var(--bg-hero); border:1px solid var(--border); border-radius:var(--radius-sm); padding:12px; text-align:center; }
.stat-tile .tile-val { font-size:1.7rem; font-weight:800; line-height:1; }
.stat-tile .tile-lbl { color:var(--muted); font-size:.68rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; margin-top:4px; }

/* Quick start */
.quick-btn { display:flex; align-items:center; justify-content:center; padding:18px 14px; border:none; border-radius:var(--radius-sm); font-size:.95rem; font-weight:700; cursor:pointer; transition:background .15s; text-decoration:none; font-family:'Segoe UI',sans-serif; width:100%; color:var(--white); }
.quick-red   { background:#c0392b; }
.quick-red:hover   { background:var(--red-h); color:var(--white); }
.quick-red2  { background:#8e1c10; }
.quick-red2:hover  { background:#c0392b; color:var(--white); }
.quick-grn   { background:#1a3a1a; }
.quick-grn:hover   { background:#2d7a2d; color:var(--white); }
.quick-acc   { background:#1f4080; }
.quick-acc:hover   { background:var(--accent2); color:var(--white); }
.quick-muted { background:#1e1e2a; }
.quick-muted:hover { background:#39394a; color:var(--white); }

/* Online dot */
.dot { display:inline-block; width:8px; height:8px; border-radius:50%; }
.dot-green { background:var(--green); }
.dot-grey  { background:var(--muted); }

/* Friend row */
.friend-row { display:flex; align-items:center; gap:10px; padding:10px 0; border-bottom:1px solid var(--border); }
.friend-row:last-child { border-bottom:none; }
.friend-avatar { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:.9rem; flex-shrink:0; position:relative; overflow:hidden; }
.friend-info { flex:1; min-width:0; }
.friend-info .name { font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-size:.9rem; }
.friend-info .sub  { font-size:.76rem; color:var(--muted); }

/* Recent game rows */
.game-row { display:flex; align-items:stretch; background:var(--bg-hero); border:1px solid var(--border); border-radius:var(--radius-sm); overflow:hidden; margin-bottom:4px; }
.game-row-strip { width:4px; flex-shrink:0; }
.game-row-strip.win  { background:var(--green-dk); }
.game-row-strip.loss { background:var(--red-dk); }
.game-row-pill { display:flex; align-items:center; justify-content:center; padding:0 10px; font-size:.72rem; font-weight:800; letter-spacing:.05em; min-width:48px; }
.game-row-pill.win  { color:var(--white); background:var(--green-dk); }
.game-row-pill.loss { color:var(--white); background:var(--red-dk); }
.game-row-info { flex:1; padding:9px 12px; }
.game-row-info .gmode { font-size:.9rem; font-weight:700; }
.game-row-info .gdate { font-size:.74rem; color:#555; }
.game-row-opp  { font-size:.78rem; color:var(--muted); padding:9px 12px; display:flex; align-items:center; }
.game-row-legs { font-size:.76rem; color:#555; padding:9px 14px; display:flex; align-items:center; }

/* Notif banner */
.notif-banner { background:#1a1a0a; border:1px solid var(--amber); border-radius:var(--radius-sm); padding:12px 16px; margin-top:12px; }

/* Setup */
.setup-grid { display:grid; grid-template-columns:1fr 310px; gap:18px; align-items:start; }
@media(max-width:760px){ .setup-grid{grid-template-columns:1fr;} }
.players-preview { display:flex; flex-direction:column; gap:6px; margin-top:10px; }
.preview-row { display:flex; align-items:center; gap:10px; padding:7px 12px; background:var(--bg3); border-radius:var(--radius-sm); font-size:.88rem; }
.preview-row .badge { font-size:.66rem; font-weight:800; letter-spacing:.06em; padding:2px 8px; border-radius:20px; text-transform:uppercase; }
.badge-you    { background:var(--red);      color:#fff; }
.badge-friend { background:var(--accent2);  color:#fff; }
.badge-guest  { background:#7a5c10;         color:var(--amber); }
.badge-bot    { background:#2e1a4a;         color:var(--purple); }
.seg-control { display:flex; background:var(--bg3); border-radius:var(--radius-sm); padding:3px; gap:3px; }
.seg-btn { flex:1; padding:7px 10px; background:transparent; border:none; border-radius:4px; color:var(--muted); font-size:.88rem; font-weight:600; font-family:'Segoe UI',sans-serif; cursor:pointer; transition:background .12s,color .12s; }
.seg-btn.active { background:var(--red); color:#fff; }

/* Game screen */
.game-header { background:var(--bg2); border-bottom:1px solid var(--border); padding:8px 18px; display:flex; align-items:center; justify-content:space-between; }
.game-header .game-title { font-size:.95rem; font-weight:800; letter-spacing:.04em; color:var(--white); }
.game-header .leg-info { font-size:.8rem; color:var(--accent); font-weight:600; }

/* ── New fullscreen game layout ─────────────────────────────────────── */
/* Top bar */
.gm-topbar { display:flex; align-items:center; height:42px; background:var(--bg-deep); border-bottom:1px solid var(--border); padding:0 14px; gap:12px; flex-shrink:0; }
.gm-topbar-title { flex:1; font-size:.88rem; font-weight:700; color:var(--white); text-align:center; letter-spacing:.02em; }
.gm-topbar-info  { font-size:.8rem; color:var(--accent); font-weight:600; white-space:nowrap; }

/* Main layout */
.gm-layout  { display:flex; flex:1; overflow:hidden; min-height:0; }

/* Player cards (left) */
.gm-players { flex:1; display:flex; min-width:0; overflow:hidden; }
.gm-player-card { flex:1; display:flex; flex-direction:column; border-right:1px solid var(--border); background:var(--bg); overflow-y:auto; transition:background .15s; }
.gm-player-card:last-child { border-right:none; }
.gm-player-card.active { background:rgba(88,166,255,.04); outline:2px solid var(--accent); outline-offset:-2px; }

.gm-pc-header { padding:12px 14px 8px; background:var(--bg2); border-bottom:1px solid var(--border); flex-shrink:0; }
.gm-pc-name-row { display:flex; align-items:center; justify-content:space-between; margin-bottom:3px; }
.gm-pc-name { font-size:.92rem; font-weight:700; letter-spacing:.02em; }
.gm-turn-badge { background:var(--accent2); color:#fff; font-size:.6rem; font-weight:800; letter-spacing:.06em; padding:2px 7px; border-radius:3px; text-transform:uppercase; }
.gm-pc-sl { font-size:.74rem; color:var(--muted); }
.gm-pc-score { font-size:4.5rem; font-weight:900; line-height:1; padding:14px 14px 6px; letter-spacing:-3px; color:var(--white); }
.gm-pc-score.active { color:var(--accent); }
.gm-pc-darts { font-size:.74rem; color:var(--muted); padding:0 14px 8px; flex-shrink:0; }
.gm-bot-wait { padding:14px; color:var(--muted); text-align:center; font-size:.85rem; }

/* Right panel */
.gm-right { width:360px; flex-shrink:0; border-left:1px solid var(--border); display:flex; flex-direction:column; background:var(--bg2); overflow-y:auto; min-height:0; }

.gm-turn-hdr { padding:9px 16px; font-size:.92rem; font-weight:700; color:var(--accent); border-bottom:1px solid var(--border); background:var(--bg-deep); flex-shrink:0; }

/* Oche in right panel */
.gm-oche { flex-shrink:0; padding:16px 16px 12px; border-bottom:1px solid #1a3a1a; }
.oche-require { font-size:.68rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--amber); text-align:center; margin-bottom:4px; }

/* Match scorecard */
.gm-scorecard { flex-shrink:0; background:var(--bg); }
.gm-sc-header { background:var(--red); color:#fff; font-size:.68rem; font-weight:800; letter-spacing:.1em; padding:5px 14px; display:flex; align-items:center; justify-content:space-between; }
.gm-sc-hdr-sub { font-weight:400; opacity:.85; font-size:.65rem; letter-spacing:.04em; }
.gm-sc-row { display:flex; align-items:center; padding:9px 14px; border-bottom:1px solid var(--border); gap:8px; }
.gm-sc-row.active { background:rgba(88,166,255,.04); }
.gm-sc-arrow { color:var(--red); font-size:.72rem; width:13px; flex-shrink:0; }
.gm-sc-name-wrap { flex:1; min-width:0; }
.gm-sc-pname { font-size:.78rem; font-weight:800; letter-spacing:.03em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.gm-sc-avg { font-size:.68rem; color:var(--muted); font-weight:400; margin-left:5px; }
.gm-sc-circles-row { display:flex; align-items:center; gap:5px; margin-top:5px; }
.gm-sc-lbl { font-size:.58rem; color:#555; font-weight:800; letter-spacing:.06em; }
.sc-dot { width:11px; height:11px; border-radius:50%; border:1px solid #444; display:inline-block; margin:0 2px; background:transparent; }
.sc-dot.filled-set { background:var(--gold);  border-color:var(--gold); }
.sc-dot.filled-leg { background:var(--green); border-color:var(--green); }
.sc-sep { width:1px; height:14px; background:var(--border); }

/* Entry area */
.gm-entry { padding:10px; display:flex; flex-direction:column; gap:7px; flex-shrink:0; }
.gm-score-entry {
  width:100%; background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius-sm);
  color:var(--white); font-size:2.2rem; font-weight:900; text-align:center;
  padding:8px 10px; font-family:'Segoe UI',sans-serif; letter-spacing:-1px;
  -moz-appearance:textfield; appearance:textfield;
}
.gm-score-entry::-webkit-inner-spin-button,
.gm-score-entry::-webkit-outer-spin-button { -webkit-appearance:none; margin:0; }
.gm-score-entry:focus { outline:2px solid var(--accent); outline-offset:0; }
.gm-score-entry::placeholder { color:var(--bg4); }
.gm-darts-used-lbl { font-size:.62rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.gm-darts-row { display:flex; gap:6px; }
.gm-dart-btn {
  flex:1; padding:14px 0; font-size:1.5rem; font-weight:900;
  background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius-sm);
  color:var(--muted); cursor:pointer; transition:background .12s,color .12s;
  font-family:'Segoe UI',sans-serif; text-align:center;
}
.gm-dart-btn:hover  { background:var(--bg4); }
.gm-dart-btn.active { background:var(--accent2); color:#fff; border-color:var(--accent2); }
.gm-entry-display { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius-sm); padding:10px 14px; font-size:2.8rem; font-weight:900; color:var(--white); text-align:center; letter-spacing:-1px; min-height:58px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.gm-cursor { display:inline-block; width:2px; height:2.2rem; background:var(--white); margin-left:2px; animation:blink .85s step-end infinite; vertical-align:middle; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
.gm-entry-darts-lbl { font-size:.62rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.gm-submit-btn { padding:14px; font-size:1rem; font-weight:800; letter-spacing:.04em; }
.gm-bust-btn   { padding:13px; font-size:.95rem; font-weight:700; flex-shrink:0; }

/* Bottom stats bar */
.gm-statsbar { height:44px; background:var(--bg-deep); border-top:1px solid var(--border); display:flex; align-items:stretch; flex-shrink:0; }
.gm-stat-player { flex:1; display:flex; align-items:center; gap:0; border-right:1px solid var(--border); padding:0 10px; overflow:hidden; }
.gm-stat-player:last-child { border-right:none; }
.gm-stat-player.active .gm-stat-name { color:var(--accent); }
.gm-stat-name { font-size:.76rem; font-weight:700; color:var(--white); white-space:nowrap; padding-right:12px; border-right:1px solid var(--border); margin-right:10px; }
.gm-stat-item { display:flex; flex-direction:column; align-items:center; padding:0 8px; border-right:1px solid var(--border); line-height:1.1; }
.gm-stat-item:last-child { border-right:none; }
.gm-stat-lbl { font-size:.5rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:#555; }
.gm-stat-val { font-size:.88rem; font-weight:800; color:var(--white); }

/* Checkout hint bar (inside player cards) */
.hint-bar { background:var(--bg3); border-bottom:1px solid var(--border); padding:5px 16px; font-size:.78rem; color:var(--muted); min-height:28px; flex-shrink:0; }
.hint-darts { color:var(--amber); font-weight:700; font-size:.85rem; }
.leg-scores-wrap { padding:9px 16px; flex:1; }
.leg-chips { display:flex; flex-wrap:wrap; gap:4px; margin-top:4px; }
.chip { display:inline-block; padding:2px 7px; border-radius:4px; font-size:.74rem; font-weight:800; }
.chip-gold  { background:rgba(255,215,0,.15);   color:var(--gold); }
.chip-amber { background:rgba(210,153,34,.15);  color:var(--amber); }
.chip-green { background:rgba(63,185,80,.15);   color:var(--green); }
.chip-white { background:var(--bg4);            color:var(--white); }
.chip-red   { background:rgba(192,57,43,.15);   color:var(--red-h); }

/* Oche score entry — dark green felt */
.score-entry { border-top:1px solid var(--border); }
.oche-panel { background:var(--bg-oche); padding:14px 16px 10px; border-bottom:1px solid #1a3a1a; }
.oche-label { font-size:.7rem; font-weight:800; letter-spacing:.14em; color:var(--amber); text-align:center; margin-bottom:2px; }
.oche-score { font-size:4.2rem; font-weight:900; line-height:1; text-align:center; color:var(--white); letter-spacing:-3px; min-height:66px; }
.oche-score.busted { color:var(--red-h); }
.oche-hint  { text-align:center; font-size:.88rem; font-weight:700; color:var(--amber); min-height:20px; margin-top:4px; }
.numpad-wrap { background:var(--bg2); padding:10px; }
.darts-label { font-size:.68rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:4px; }
.numpad { display:grid; grid-template-columns:repeat(3,1fr); gap:5px; }
.numpad-btn { padding:13px 0; font-size:1.1rem; font-weight:800; background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius-sm); color:var(--white); cursor:pointer; transition:background .12s; text-align:center; font-family:'Segoe UI',sans-serif; }
.numpad-btn:hover  { background:var(--bg4); }
.numpad-btn:active { background:var(--accent2); color:#fff; }
.numpad-btn.del    { color:var(--amber); }
.numpad-btn.submit { background:var(--red); color:#fff; grid-column:span 2; font-size:.95rem; letter-spacing:.04em; }
.numpad-btn.submit:hover { background:var(--red-h); }

/* Camera */
.cam-panel { padding:10px 14px 12px; border-top:1px solid var(--border); background:var(--bg2); }
.cam-title { font-size:.66rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); display:flex; align-items:center; justify-content:space-between; margin-bottom:7px; }
.cam-frame { width:200px; height:200px; border-radius:var(--radius-sm); object-fit:cover; display:block; border:1px solid var(--border); }
.cam-qr    { width:200px; height:200px; border-radius:var(--radius-sm); display:block; }
.cam-status-bar { display:flex; align-items:center; justify-content:space-between; margin-top:5px; font-size:.76rem; }
.cam-live    { color:var(--green); font-weight:700; }
.cam-waiting { color:var(--muted); }

/* Toasts */
.toast-container { position:fixed; top:70px; right:20px; display:flex; flex-direction:column; gap:8px; z-index:999; max-width:340px; pointer-events:none; }
.toast { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius-sm); padding:12px 14px; box-shadow:var(--shadow); animation:slideIn .2s ease; pointer-events:all; }
.toast.toast-info    { border-left:3px solid var(--accent); }
.toast.toast-warn    { border-left:3px solid var(--amber); }
.toast.toast-success { border-left:3px solid var(--green); }
.toast.toast-danger  { border-left:3px solid var(--red-h); }
.toast-title { font-weight:700; margin-bottom:3px; font-size:.88rem; }
.toast-body  { font-size:.82rem; color:var(--muted); }
.toast-actions { display:flex; gap:7px; margin-top:8px; }
@keyframes slideIn { from{opacity:0;transform:translateX(16px)} to{opacity:1;transform:translateX(0)} }

/* Game over */
.game-over-overlay { position:fixed; inset:0; background:rgba(0,0,0,.88); display:flex; align-items:center; justify-content:center; z-index:500; backdrop-filter:blur(6px); }
.game-over-card { background:var(--bg2); border:1px solid var(--border); border-top:4px solid var(--red); border-radius:var(--radius); padding:44px 36px; text-align:center; max-width:420px; width:90%; box-shadow:var(--shadow); }
.game-over-card .trophy { font-size:3.5rem; margin-bottom:10px; }
.game-over-card h2 { font-size:1.2rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.game-over-card .winner-name { color:var(--gold); font-size:2.2rem; font-weight:900; letter-spacing:-1px; margin-bottom:22px; }

/* Stats */
.hero-banner { background:var(--bg-hero); border:1px solid var(--border); border-left:5px solid var(--red); border-radius:var(--radius); padding:22px 24px; display:flex; align-items:center; gap:20px; margin-bottom:16px; }
.hero-avatar { width:68px; height:68px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.7rem; font-weight:900; flex-shrink:0; overflow:hidden; }
.hero-avg-box { margin-left:auto; text-align:center; background:#1a0a0d; border-radius:var(--radius-sm); padding:10px 18px; border:1px solid var(--border); }
.hero-avg-box .avg-num { font-size:2rem; font-weight:900; line-height:1; }
.hero-avg-box .avg-lbl { font-size:.66rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-top:3px; }
.perf-row { display:flex; align-items:center; justify-content:space-between; padding:8px 12px; background:var(--bg3); border-radius:var(--radius-sm); margin-bottom:4px; font-size:.86rem; }
.perf-val { font-weight:700; }
.band-bar { height:7px; border-radius:4px; }
.form-pill { display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:50%; font-size:.74rem; font-weight:800; }
.form-pill.w { background:rgba(63,185,80,.2);  color:var(--green); }
.form-pill.l { background:rgba(192,57,43,.2); color:var(--red-h); }

/* ── Site Footer ──────────────────────────────────────────────────────── */
.site-footer { background:var(--bg-deep); border-top:1px solid var(--border); padding:20px; margin-top:auto; }
.site-footer-inner { max-width:1080px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:.82rem; color:var(--muted); }
.site-footer-links { display:flex; align-items:center; gap:8px; }
.site-footer-links a { color:var(--muted); }
.site-footer-links a:hover { color:var(--white); }
.site-footer-sep { color:var(--border); }
.site-footer-credit { }
.site-footer-credit a { color:var(--accent); font-weight:600; }
.site-footer-credit a:hover { color:#79b8ff; }
@media(max-width:600px){ .site-footer-inner { flex-direction:column; align-items:center; text-align:center; } }

/* ── Mobile page action bars ──────────────────────────────────────────── */
/* Use .page-actions around button groups that sit in page headers.        */
/* On mobile they become a horizontally-scrollable pill strip.             */
.page-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
/* Page headers: title on left, actions on right → stack on mobile */
.page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
@media(max-width:640px) {
  /* Header with title + actions: title stays on top, actions scroll */
  .page-header { flex-direction: column; gap: 10px; }
  .page-actions {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
    width: 100%;
    scrollbar-width: none;
  }
  .page-actions::-webkit-scrollbar { display: none; }
  /* Prevent buttons shrinking inside scrollable strip */
  .page-actions .btn { flex-shrink: 0; }
  /* Generic flex-between + flex-gap header pattern: wrap instead of overflow */
  .flex-between { flex-wrap: wrap; gap: 10px; }
  /* Bump btn-sm tap targets on touch devices */
  .btn-sm { padding: 8px 14px; font-size: .84rem; }
  /* Hero banner (stats page) — stack avatar/info/avg vertically */
  .hero-banner { flex-direction: column; align-items: flex-start; gap: 14px; }
  .hero-avg-box { margin-left: 0; width: 100%; text-align: left; display: flex; align-items: center; gap: 14px; }
}

/* ── Legal pages (Terms / Privacy) ───────────────────────────────────── */
.legal-page { max-width:760px; margin:0 auto; padding:36px 20px 60px; }
.legal-page h1 { font-size:1.75rem; margin-bottom:6px; }
.legal-page .legal-meta { font-size:.82rem; color:var(--muted); margin-bottom:32px; padding-bottom:18px; border-bottom:1px solid var(--border); }
.legal-page h2 { font-size:1.05rem; font-weight:700; margin:28px 0 8px; color:var(--white); }
.legal-page p, .legal-page li { font-size:.9rem; color:#c9d1d9; line-height:1.7; }
.legal-page ul { padding-left:1.4em; margin-top:6px; }
.legal-page li { margin-bottom:4px; }
.legal-page a { color:var(--accent); }
