.bb-board *,.bb-board ::after,.bb-board ::before{box-sizing:border-box}
.bb-board{--bb-bg:#1a2332;--bb-text:#b0b8c8;--bb-t1:#64b5f6;--bb-t2:#ef5350;--bb-border:#2a3a4a;--bb-accent:#ffd740;--bb-current:#ffffff;background:var(--bb-bg);border-radius:8px;overflow:hidden;border:1px solid var(--bb-border)}
.bb-table thead .bb-cell,.bb-title{font-weight:700;color:var(--bb-text)}
.bb-title{text-align:center;padding:.5em .7em;font-size:.85em;letter-spacing:.04em;border-bottom:1px solid var(--bb-border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bb-table-wrap{overflow-x:auto}
.bb-table{width:100%;border-collapse:collapse;font-size:clamp(.9rem,2.2vw,1.3rem)}
.bb-table thead{background:rgba(0,0,0,.25)}
.bb-table thead .bb-cell{font-size:.65em;text-transform:uppercase;letter-spacing:.08em;padding:.35em .45em}
.bb-cell{padding:.45em .5em;text-align:center;color:var(--bb-text);border-bottom:1px solid var(--bb-border);line-height:1.4}
.bb-cell--name{text-align:left;padding-left:.6em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:6em}
.bb-cell--inning{font-variant-numeric:tabular-nums;min-width:1.6em;font-weight:600}
.bb-cell--inning.bb-cell--live{color:var(--bb-current);font-weight:800}
.bb-cell--yet{opacity:.35}
.bb-cell--total{font-weight:800;font-size:1.1em;font-variant-numeric:tabular-nums;border-left:1px solid var(--bb-border);min-width:2em}
.bb-cell--total.bb-cell--runs{border-left:2px solid var(--bb-border);font-size:1.2em}
.bb-row--t1 .bb-cell--total,.bb-row--t1 .bb-name{color:var(--bb-t1)}
.bb-row--t2 .bb-cell--total,.bb-row--t2 .bb-name{color:var(--bb-t2)}
.bb-row--batting{background:rgba(255,215,64,.07)}
.bb-row--batting .bb-cell--runs{color:var(--bb-current)}
.bb-row--winner .bb-name{color:var(--bb-accent)!important}
.bb-bat{display:inline-block;width:1.2em;text-align:center;font-size:.9em;vertical-align:middle;line-height:1;margin-right:.25em;filter:drop-shadow(0 0 4px var(--bb-accent))}
.bb-bat--hidden{visibility:hidden}
.bb-name{font-weight:700;letter-spacing:.02em}
.bb-input{background:0 0;border:1px solid transparent;border-radius:3px;color:inherit;font:inherit;font-weight:inherit;text-align:center;width:2.4em;padding:.1em 0;margin:0;-moz-appearance:textfield}
.bb-input::-webkit-inner-spin-button,.bb-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.bb-input:hover{border-color:rgba(255,255,255,.2)}
.bb-input:focus{outline:0;border-color:var(--bb-accent);background:rgba(0,0,0,.25)}
.bb-input--total{width:2em}
.bb-count{display:flex;align-items:center;justify-content:center;gap:1.5em;padding:.6em .7em;border-top:1px solid var(--bb-border);background:rgba(0,0,0,.2)}
.bb-count__diamond{flex:0 0 auto}
.bb-diamond{width:3em;height:3em;display:block}
.bb-diamond__base{fill:transparent;stroke:var(--bb-text);stroke-width:1.4;opacity:.5}
.bb-diamond__base--on{fill:var(--bb-accent);stroke:var(--bb-accent);opacity:1}
.bb-diamond__home{fill:var(--bb-text);opacity:.65}
.bb-count__cells{display:flex;gap:.6em}
.bb-count__cell{display:flex;flex-direction:column;align-items:center;min-width:1.8em}
.bb-count__label{font-size:.55em;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--bb-text)}
.bb-count__val{font-size:1.4em;font-weight:800;color:var(--bb-current);font-variant-numeric:tabular-nums}
.bb-status-bar{text-align:center;padding:.45em .7em;font-size:.78em;font-weight:700;text-transform:uppercase;letter-spacing:.1em;line-height:1.4;min-height:2em;border-top:1px solid var(--bb-border);color:var(--bb-text)}
.bb-status--current{color:var(--bb-current)}
.bb-status--winner{color:var(--bb-accent);font-size:1em}
.number-font-roboto-mono .bb-cell--inning,.number-font-roboto-mono .bb-cell--total,.number-font-roboto-mono .bb-count__val{font-family:"Roboto Mono",monospace}
.number-font-major-mono .bb-cell--inning,.number-font-major-mono .bb-cell--total,.number-font-major-mono .bb-count__val{font-family:"Major Mono Display",monospace}
.number-font-share-tech .bb-cell--inning,.number-font-share-tech .bb-cell--total,.number-font-share-tech .bb-count__val{font-family:"Share Tech Mono",monospace}
.number-font-mono .bb-cell--inning,.number-font-mono .bb-cell--total,.number-font-mono .bb-count__val{font-family:"JetBrains Mono",monospace}
.number-font-azeret-mono .bb-cell--inning,.number-font-azeret-mono .bb-cell--total,.number-font-azeret-mono .bb-count__val{font-family:"Azeret Mono",monospace}
.number-font-segment .bb-cell--inning,.number-font-segment .bb-cell--total,.number-font-segment .bb-count__val{font-family:"DSEG7 Classic",monospace}
/* Column headers (inning numbers, R/H/E) stay legible in Arial regardless of the chosen number font. */
.bb-table thead .bb-cell{font-family:Arial,sans-serif}
.baseball-admin{display:grid;grid-template-columns:360px 1fr;grid-template-areas:"controls board";gap:1.25rem;max-width:1100px;margin:0 auto;padding:1rem;align-items:start}
.baseball-admin__board{position:sticky;top:1rem;grid-area:board}
.baseball-admin .bb-bat,.baseball-admin .bb-count__cell,.baseball-admin .bb-diamond__base,.baseball-admin .bb-status{cursor:pointer;user-select:none;transition:filter .12s,text-shadow .15s,transform .08s,background-color .12s,opacity .12s}
.baseball-admin .bb-count__cell:hover{filter:brightness(1.35);background:rgba(255,255,255,.08)}
.baseball-admin .bb-count__cell:active{transform:scale(.96)}
.baseball-admin .bb-status:hover{filter:brightness(1.35);text-shadow:0 0 10px currentColor}
.baseball-admin .bb-status:active{transform:scale(.97)}
.baseball-admin .bb-bat:hover{filter:drop-shadow(0 0 8px var(--bb-accent)) brightness(1.2)}
.baseball-admin .bb-bat:active{transform:scale(.85)}
.baseball-admin .bb-diamond__base:hover{filter:drop-shadow(0 0 6px var(--bb-accent));opacity:1}
.baseball-admin__controls{display:flex;flex-direction:column;gap:.75rem;grid-area:controls}
.ctrl-section{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:.75rem}
.ctrl-section__title{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 .5rem}
.pitch-grid,.result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}
.result-grid{grid-template-columns:repeat(2,1fr)}
.btn-event{background:var(--input-bg);color:var(--text);border:2px solid var(--border);border-radius:6px;padding:.7rem .5rem;font-size:.95rem;font-weight:800;cursor:pointer;font-family:inherit;transition:background .15s,color .15s,transform 50ms}
.btn-event:hover:not(:disabled){background:#3773c1;color:#fff;border-color:#3773c1}
.btn-event:active:not(:disabled){transform:scale(.96)}
.btn-event:disabled{opacity:.4;cursor:default}
.btn-event--ball{border-color:#42a5f5;color:#42a5f5}
.btn-event--strike{border-color:#ffb300;color:#ffb300}
.btn-event--out{border-color:#ef5350;color:#ef5350}
.btn-event--out:hover:not(:disabled){background:#ef5350;color:#fff;border-color:#ef5350}
.btn-event--run{border-color:#4caf50;color:#4caf50}
.btn-event--run:hover:not(:disabled){background:#4caf50;color:#fff;border-color:#4caf50}
.btn-event--hit{border-color:#ffd740;color:#ffd740}
.btn-event--hit:hover:not(:disabled){background:#ffd740;color:#000;border-color:#ffd740}
.btn-event--error,.btn-event--walk{font-size:.85rem}
.btn-event small{font-size:.75em;opacity:.75;font-weight:600}
.bases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}
.btn-base{background:var(--input-bg);color:var(--text);border:2px solid var(--border);border-radius:6px;padding:.6rem .5rem;font-size:.95rem;font-weight:800;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}
.btn-base:hover:not(:disabled){background:var(--btn-hover)}
.btn-base.is-on{background:#ffd740;color:#000;border-color:#ffd740}
.btn-base:disabled{opacity:.4;cursor:default}
.btn-base>kbd,.btn-event>kbd,.btn>kbd{font-family:inherit;font-size:.6em;opacity:.5;margin-left:.35em;border:1px solid;padding:0 .25em;border-radius:3px;display:inline-block;vertical-align:middle;font-weight:600}
.ctrl-row{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.ctrl-row+.ctrl-row{margin-top:.4rem}
.ctrl-input{background:var(--input-bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.75rem;padding:.25rem .4rem;font-family:monospace;min-width:0;flex:1}
.ctrl-input[readonly]{opacity:.8}
.inning-tag{display:inline-block;margin-left:.4rem;padding:.1rem .35rem;background:var(--btn-bg);color:var(--btn-text);border-radius:3px;font-size:.65rem;font-weight:700;letter-spacing:.05em}
.confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:200}
.confirm-overlay.show{display:flex}
.confirm-box{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:1.25rem 1.5rem;max-width:360px;text-align:center}
.confirm-box__msg{margin:0 0 1rem;font-size:.9rem}
.confirm-box__btns{display:flex;gap:.5rem;justify-content:center}
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(100%);background:var(--panel,#16213e);color:var(--text,#eee);border:1px solid var(--border,#0f3460);padding:.4rem 1rem;border-radius:6px;font-size:.8rem;font-weight:600;pointer-events:none;opacity:0;transition:opacity .2s,transform .2s;z-index:300}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.match-ended-banner{position:fixed;top:32px;left:0;right:0;background:#1565c0;color:#fff;text-align:center;font-size:.85rem;font-weight:700;padding:.3rem .5rem;text-transform:uppercase;letter-spacing:.08em;z-index:50;font-family:Arial,sans-serif}
.baseball-home{display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:1.5rem;max-width:1000px;margin:0 auto;padding:1.5rem 1rem;align-items:start;--brand-accent:#1565c0}
.baseball-home__form{display:flex;flex-direction:column;gap:.75rem}
.baseball-home__preview{position:sticky;top:3rem}
.baseball-live-body{margin:0;padding:0;background:#000;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;font-family:Arial,sans-serif}
.baseball-live{width:94vw;max-width:1080px}
.baseball-live .bb-board{font-size:clamp(1rem,3.5vw,2rem)}
.baseball-live .bb-table{font-size:inherit}
.baseball-live .bb-cell{padding:.55em}
.baseball-live .bb-cell--total{font-size:1.25em}
.baseball-live .bb-cell--total.bb-cell--runs{font-size:1.4em}
.baseball-live-overlay,.fullscreen-btn{position:fixed;color:#fff;font-family:Arial,sans-serif}
.baseball-live-overlay{inset:0;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;z-index:100;text-align:center;padding:2rem;font-size:1.1rem;line-height:1.6}
.baseball-live-overlay[hidden]{display:none}
.baseball-live-overlay a{color:#1565c0}
.fullscreen-btn{bottom:.75rem;right:.75rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:.4rem .6rem;font-size:.8rem;cursor:pointer;z-index:40;opacity:.5;transition:opacity .2s}
.fullscreen-btn:hover{opacity:1;background:rgba(255,255,255,.2)}
@media (max-width:768px){.baseball-admin{grid-template-columns:1fr;grid-template-areas:"board""controls"}
.baseball-admin__board{position:static}
.baseball-home{grid-template-columns:1fr}
.baseball-home__preview{position:static;order:-1}
}