: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}
