:root{
  --bg:#0a0e14; --panel:#121826; --panel2:#0c131e; --line:#1f2937; --ink:#eef2f7; --mut:#8a97a8;
  --y:#fae023; --grn:#2ee06a; --red:#ff3b46; --blue:#3b82f6; --rad:14px;
  --safe-b:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{background:radial-gradient(1200px 600px at 50% -10%,#16202c,var(--bg) 60%);color:var(--ink);
  font:16px/1.45 -apple-system,system-ui,Segoe UI,Roboto,sans-serif;overscroll-behavior:none;user-select:none}
#app{max-width:760px;margin:0 auto;min-height:100%;display:flex;flex-direction:column}
button{font:inherit;color:inherit;border:0;background:none;cursor:pointer}
input,select,textarea{font:inherit;font-size:16px;color:var(--ink);background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:12px;width:100%;-webkit-appearance:none}
.row{display:flex;gap:10px}.row>*{flex:1}.wrap{flex-wrap:wrap}
.sp{flex:1}.mut{color:var(--mut)}.center{text-align:center}.hide{display:none!important}

/* top bar */
.bar{display:flex;align-items:center;gap:12px;padding:calc(14px + env(safe-area-inset-top,0px)) 16px 14px;position:sticky;top:0;
  background:linear-gradient(#0a0e14ee,#0a0e14cc);backdrop-filter:blur(8px);z-index:5;border-bottom:1px solid var(--line)}
.content,.box,.linescore{-webkit-overflow-scrolling:touch}
.lu .pl .mv{color:var(--mut);padding:6px 7px;font-size:13px;flex:0 0 auto;background:#1a2230;border:1px solid var(--line);border-radius:8px;margin-left:2px}
.bar .ttl{font-weight:900;letter-spacing:.3px;font-size:18px}
.bar .ttl small{display:block;font-size:10px;color:var(--y);letter-spacing:3px;font-weight:800;text-transform:uppercase}
.crest{height:30px;width:30px;border-radius:6px;object-fit:contain}
.iconbtn{width:40px;height:40px;border-radius:10px;background:var(--panel);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:18px}
.content{flex:1;padding:14px 16px calc(20px + var(--safe-b))}

/* generic */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--rad);padding:16px;margin-bottom:12px}
.btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;padding:14px;font-weight:700}
.btn.pri{background:var(--y);color:#0a0e14;border-color:var(--y);font-weight:900}
.btn.ghost{background:transparent}
.btn.danger{color:var(--red);border-color:#3a2226}
.btn:active{transform:translateY(1px);filter:brightness(1.08)}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:.5px;
  text-transform:uppercase;padding:4px 9px;border-radius:999px;background:#1e2636;color:var(--mut)}
.pill.live{background:rgba(255,59,70,.16);color:var(--red)}
.pill.final{background:#1e2636;color:var(--mut)}
.label{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.12em;font-weight:700;margin-bottom:6px}

/* games list */
.glist .g{display:flex;align-items:center;gap:12px;padding:14px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--rad);margin-bottom:10px}
.glist .g .vs{font-weight:800}.glist .g .sc{font-weight:900;font-variant-numeric:tabular-nums}
.glist .g .meta{font-size:12px;color:var(--mut)}

/* lineup editor */
.lu .pl{display:flex;align-items:center;gap:8px;padding:8px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;margin-bottom:7px}
.lu .pl .ord{width:24px;text-align:center;color:var(--mut);font-weight:800}
.lu .pl input.num{flex:0 0 56px;text-align:center}
.lu .pl input.nm{flex:1}
.lu .pl .x{color:var(--red);padding:6px 10px}

/* SCORE screen */
.scorehead{background:var(--panel2);border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;margin-bottom:12px}
.teamline{display:flex;align-items:center;padding:10px 14px;gap:10px}
.teamline+.teamline{border-top:1px solid var(--line)}
.teamline .nm{font-weight:800;font-size:17px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.teamline.bat .nm{color:var(--y)}
.teamline .rhe{display:flex;gap:14px;color:var(--mut);font-size:12px;font-variant-numeric:tabular-nums}
.teamline .rhe b{color:var(--ink);font-size:15px}
.teamline .big{font-size:30px;font-weight:900;font-variant-numeric:tabular-nums;min-width:46px;text-align:right}
.teamline .big.win{color:var(--grn)}
.linescore{display:flex;gap:0;overflow-x:auto;border-top:1px solid var(--line);background:#05080d}
.linescore .c{flex:0 0 30px;text-align:center;font-size:12px;padding:5px 0;font-variant-numeric:tabular-nums;border-right:1px solid #11161f}
.linescore .c.h{color:var(--mut);font-weight:800}

.situ{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:12px}
.situ .inn{font-size:20px;font-weight:900;color:var(--y);display:flex;align-items:center;gap:7px}
.outs{display:flex;gap:6px;align-items:center}.outs i{width:14px;height:14px;border-radius:50%;border:2px solid var(--mut)}
.outs i.on{background:var(--red);border-color:var(--red)}
.count{font-size:20px;font-weight:900;font-variant-numeric:tabular-nums}.count .l{font-size:11px;color:var(--mut);margin-right:5px;font-weight:700}

/* diamond */
.diawrap{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:var(--rad);padding:14px;margin-bottom:12px}
.diamond{position:relative;width:120px;height:120px;flex:0 0 120px}
.base{position:absolute;width:34px;height:34px;background:#1b2433;border:2px solid #33405a;transform:rotate(45deg);
  display:flex;align-items:center;justify-content:center}
.base.on{background:var(--y);border-color:var(--y);box-shadow:0 0 14px var(--y)}
.base b{transform:rotate(-45deg);font-size:11px;font-weight:800;color:#0a0e14}
.b1{right:0;top:43px}.b2{left:43px;top:0}.b3{left:0;top:43px}.bh{left:43px;top:86px;background:transparent;border-color:#33405a}
.atbat{flex:1;min-width:0}
.atbat .l{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.1em;font-weight:700}
.atbat .who{font-size:22px;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.atbat .who .n{color:var(--y)}
.atbat .deck{color:var(--mut);font-size:13px;margin-top:3px}

/* outcome grid */
.grp{margin-bottom:10px}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.grid.g3{grid-template-columns:repeat(3,1fr)}
.ob{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 6px;font-weight:800;font-size:14px;text-align:center;line-height:1.15}
.ob.hit{border-color:#2a5a3a}.ob.hit:active{background:#13251a}
.ob.out{border-color:#3a2226}.ob.out:active{background:#251316}
.ob.walk{border-color:#2a3f5a}.ob.walk:active{background:#13202f}
.ob.pitch{padding:12px 4px;font-size:13px}
.ob:active{transform:translateY(1px)}
.ob small{display:block;font-size:10px;color:var(--mut);font-weight:700;margin-top:2px}

.actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px}

/* box score */
.box{overflow-x:auto;border:1px solid var(--line);border-radius:var(--rad);margin-bottom:14px}
table{border-collapse:collapse;width:100%;font-size:12px;font-variant-numeric:tabular-nums;white-space:nowrap}
th,td{padding:7px 8px;text-align:center;border-bottom:1px solid #11161f}
th{color:var(--mut);font-size:10px;text-transform:uppercase;position:sticky;top:0;background:var(--panel2)}
td.nm,th.nm{text-align:left;position:sticky;left:0;background:var(--panel);font-weight:700}
tr.tot td{font-weight:900;border-top:2px solid var(--line);background:var(--panel2)}

/* sheet (runner menu / modals) */
.sheet{position:fixed;inset:0;background:#000a;display:flex;align-items:flex-end;justify-content:center;z-index:30}
.sheet .inner{width:100%;max-width:760px;background:var(--panel);border-top-left-radius:20px;border-top-right-radius:20px;
  padding:18px 16px calc(20px + var(--safe-b));border:1px solid var(--line)}
.sheet h3{margin:0 0 14px}
.toast{position:fixed;left:50%;bottom:calc(24px + var(--safe-b));transform:translateX(-50%) translateY(20px);
  background:#1b2433;border:1px solid var(--line);color:var(--ink);padding:11px 18px;border-radius:999px;font-weight:700;
  font-size:14px;opacity:0;transition:.25s;pointer-events:none;z-index:50}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.empty{text-align:center;color:var(--mut);padding:50px 20px}
.empty .big{font-size:46px;margin-bottom:10px}
.grow{flex:1}

/* save-mode badge + demo banner */
.modebadge{display:flex;align-items:center;gap:8px;padding:9px 13px;border-radius:11px;border:1px solid var(--line);
  background:var(--panel2);font-size:13px;margin-bottom:12px;cursor:pointer}
.modebadge b{font-weight:800}
.modebadge .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.modebadge.mode-turbo{border-color:rgba(59,130,246,.5)} .modebadge.mode-turbo .dot{background:var(--blue)} .modebadge.mode-turbo b{color:var(--blue)}
.modebadge.mode-direct{border-color:rgba(46,224,106,.5)} .modebadge.mode-direct .dot{background:var(--grn)} .modebadge.mode-direct b{color:var(--grn)}
.demobanner{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 13px;border-radius:11px;margin-bottom:12px;
  background:rgba(250,224,35,.12);border:1px solid rgba(250,224,35,.5);color:var(--y);font-size:13px}
.demobanner span{color:var(--ink)}
.demoreset{margin-left:auto;background:var(--y);color:#0a0e14;font-weight:800;border:0;border-radius:8px;padding:6px 12px;cursor:pointer}
.demoend{padding:13px 14px;border-radius:12px;margin-bottom:14px;text-align:center;
  background:rgba(250,224,35,.14);border:1px solid rgba(250,224,35,.55);color:var(--y);font-size:14px}
.demoend b{font-size:15px}.demoend .mut{color:var(--ink)}

/* group labels above each outcome cluster */
.glabel{font-size:10px;color:var(--mut);text-transform:uppercase;letter-spacing:.12em;font-weight:800;margin:0 2px 6px}
.ob.run{border-color:#3a3550;background:var(--panel)}.ob.run:active{background:#1c1830}

/* tappable "now batting" hint */
.atbat{cursor:pointer}
.edit-hint{font-size:9px;color:var(--mut);letter-spacing:.04em;text-transform:none}

/* fielder position selector */
.posgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.pos{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:14px 4px;font-weight:800;display:flex;flex-direction:column;align-items:center;gap:2px}
.pos b{font-size:16px}.pos small{font-size:10px;color:var(--mut)}
.pos:active{background:#1a2230;transform:translateY(1px)}

/* runner advancement override rows */
.advrow{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}
.advname{flex:0 0 38%;min-width:0;font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.advname small{display:block;font-size:11px;color:var(--mut);font-weight:600}
.advopts{display:flex;flex-wrap:wrap;gap:6px;flex:1;justify-content:flex-end}
.advb{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:8px 10px;font-size:13px;font-weight:700;min-width:44px}
.advb.sel{background:var(--y);color:#0a0e14;border-color:var(--y)}
.advb.score.sel{background:var(--grn);border-color:var(--grn);color:#04140a}
.advb.out.sel{background:var(--red);border-color:var(--red);color:#fff}
.advb:active{transform:translateY(1px)}

/* ===== REMOTE COCKPIT — Live Feed panel ===== */
.btn.livefeed-on{border-color:var(--red);color:var(--red)}
.livefeed{padding:12px}
.lf-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.lf-close{flex:0 0 auto;color:var(--mut);font-size:16px;padding:2px 8px}
.lf-tabs{display:flex;gap:6px;margin-bottom:10px}
.lf-tab{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:9px 4px;font-size:12px;font-weight:800}
.lf-tab.on{background:var(--y);color:#0a0e14;border-color:var(--y)}
.lf-tab:active{transform:translateY(1px)}
.lf-frame{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-radius:10px;overflow:hidden;border:1px solid var(--line)}
.lf-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.lf-cam{position:relative;width:100%;aspect-ratio:16/9;background:#05080d;border-radius:10px;overflow:hidden;border:1px solid var(--line)}
.lf-camimg{width:100%;height:100%;object-fit:cover;display:block}
.lf-caplabel{position:absolute;left:8px;bottom:8px;background:#000a;color:var(--ink);font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px}
.lf-note{font-size:11px;margin-top:9px;line-height:1.35}

/* ===== Spectator view (inline fan preview) ===== */
.spectator{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:12px;overflow:hidden}
.spectempty{padding:24px 8px;text-align:center}
.spect-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.spect-badge{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--y)}
.spect-score{background:#05080d;border:1px solid var(--line);border-radius:10px;overflow:hidden;margin-bottom:10px}
.spect-trow{display:flex;align-items:center;justify-content:space-between;padding:9px 14px}
.spect-trow+.spect-trow{border-top:1px solid var(--line)}
.spect-tn{font-weight:800;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.spect-tn.win{color:var(--grn)}
.spect-ts{font-size:26px;font-weight:900;font-variant-numeric:tabular-nums;min-width:42px;text-align:right}
.spect-ts.win{color:var(--grn)}
.spect-situ{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--mut);font-weight:700;margin-bottom:10px;padding:0 2px}
.spect-pbplabel{font-size:10px;color:var(--mut);text-transform:uppercase;letter-spacing:.12em;font-weight:800;margin:0 2px 6px}
.spect-pbp{display:flex;flex-direction:column;gap:5px;max-height:280px;overflow-y:auto}
.spect-prow{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--panel);border:1px solid var(--line);border-radius:9px;font-size:13px}
.spect-prow.marker{background:#10141d;color:var(--mut);font-weight:800;justify-content:center}
.spect-pt{flex:1;min-width:0}
.spect-psc{flex:0 0 auto;font-size:12px;font-weight:800;color:var(--y);font-variant-numeric:tabular-nums}
.spect-pmk{font-size:12px}

/* ===== Share / Watch links ===== */
.sharerow{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--line)}
.shareinfo{flex:1;min-width:0}
.sharelabel{font-weight:700;font-size:14px}
.shareurl{display:block;font-size:12px;color:var(--blue);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none}
.copybtn{flex:0 0 auto;padding:9px 16px;font-size:13px}

/* play-by-play editor */
.playlist{display:flex;flex-direction:column;gap:6px}
.playrow{display:flex;align-items:center;gap:8px;padding:9px 11px;background:var(--panel2);border:1px solid var(--line);border-radius:10px}
.playrow.marker{background:#10141d;color:var(--mut);font-weight:800;justify-content:center}
.playrow .pi{flex:0 0 34px;font-size:11px;color:var(--y);font-weight:800;font-variant-numeric:tabular-nums}
.playrow .pt{flex:1;min-width:0;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.playrow .pdel{flex:0 0 auto;color:var(--red);padding:4px 8px;font-weight:800}
.playrow .pins{flex:0 0 auto;color:var(--grn);padding:4px 8px;font-weight:800}
.playrow.marker .pi,.playrow.marker .pdel,.playrow.marker .pins{display:none}

/* ===== Live mirror (Watch the tablet game) ===== */
.mir-tabs{display:flex;gap:8px;margin-bottom:12px;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:4px}
.mir-tab{flex:1;padding:10px 8px;border-radius:9px;font-weight:800;font-size:14px;color:var(--mut)}
.mir-tab.on{background:var(--panel);color:var(--ink);box-shadow:0 1px 0 #0006}
.mir-row.atbat td{background:rgba(250,224,35,.12);font-weight:800}
.mir-row.atbat td.nm{background:rgba(250,224,35,.16);color:var(--y)}
.mir-row.ondeck td.nm{color:var(--ink)}
.mir-row.ondeck td{background:rgba(59,130,246,.07)}
