:root{--bg:#181d24;--track:#12161c;--surface:#20262f;--card:#20262f;--surface-2:#28303a;--elevated:#343d49;--border:#333b46;--hairline:#262d36;--fg:#eef2f6;--muted:#8b96a3;--faint:#5b6672;--on-accent:#fff;--court:#1f9d5b;--court-strong:#178a4e;--red:#e76a60;--blue:#5e93e6;--win:#2dbd75;--loss:#e76a60;--warn:#e8a23f;--info:#5e93e6;--motion:#c14fbe;--court-soft:#2dbd7529;--red-soft:#e76a6029;--blue-soft:#5e93e629;--win-soft:#2dbd7529;--loss-soft:#e76a6029;--warn-soft:#e8a23f2e;--info-soft:#5e93e629;--court-surface:#2f7a4f;--court-runoff:#141921;--court-line:#dfeee6;--court-net:#bfe3d0;--press:#ffffff0f;--ring:#ffffff4d;--scrim:#0009;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-pill:999px;--sh-1:0 1px 2px #00000080;--sh-2:0 4px 16px #00000080;--sh-pop:0 12px 32px #000000a6;--glow-court:#2dbd7573;--glow-red:#e76a6066;--glow-blue:#5e93e666;--glow-motion:#c14fbe6b;--highlight:#ffffff1f;color:var(--fg);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:system-ui,-apple-system,Hiragino Kaku Gothic ProN,sans-serif}[data-theme=light]{--bg:#eef0f2;--track:#e9edf0;--surface:#fff;--card:#fff;--surface-2:#f6f8f9;--elevated:#fff;--border:#e2e5e9;--hairline:#eceff1;--fg:#1a1a1a;--muted:#8a8f98;--faint:#aab0b8;--on-accent:#fff;--court:#0b6b3a;--court-strong:#095a30;--red:#d83a2e;--blue:#2e6fd8;--win:#1a9d57;--loss:#d83a2e;--warn:#e65100;--info:#1565c0;--motion:#ad1fa0;--court-soft:#0b6b3a1a;--red-soft:#d83a2e1f;--blue-soft:#2e6fd81f;--win-soft:#1a9d5724;--loss-soft:#d83a2e1f;--warn-soft:#fff3e0;--info-soft:#e3f2fd;--court-surface:#3a8f5f;--court-runoff:#2c6e49;--court-line:#fff;--court-net:#eaf6ef;--press:#0000000f;--ring:#0000002e;--scrim:#11182770;--sh-1:0 1px 2px #0000000f;--sh-2:0 4px 16px #0f172a1f;--sh-pop:0 12px 32px #0f172a33;--glow-court:#0b6b3a47;--glow-red:#d83a2e42;--glow-blue:#2e6fd842;--glow-motion:#ad1fa042;--highlight:#fff0;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}html,body{background:var(--bg);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;overscroll-behavior:none;margin:0;padding:0}#root{max-width:760px;padding:env(safe-area-inset-top) 14px calc(env(safe-area-inset-bottom) + 24px);margin:0 auto}button{font:inherit;cursor:pointer;touch-action:manipulation}.btn,.seg button,.chip,.theme-toggle,.navbtn,.match-card-row,input[type=text],input[type=date],textarea{transition:background .16s,border-color .16s,color .16s,box-shadow .16s,filter .16s,transform 70ms}:focus-visible{outline:2px solid var(--court);outline-offset:2px}input:focus-visible,textarea:focus-visible{outline:none}@media (prefers-reduced-motion:reduce){*{transition:none!important}}h1{margin:16px 0 4px;font-size:20px}h2{margin:20px 0 8px;font-size:16px}.muted{color:var(--muted);font-size:13px}.main-tabs{margin:4px 0 14px}.appbar{background:var(--bg);z-index:100;align-items:center;gap:10px;padding:4px 0;display:flex;position:sticky;top:0}.appbar .title{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:17px;font-weight:700;overflow:hidden}.appbar-actions{flex:none;align-items:center;gap:8px;display:flex}.auth-email{max-width:150px;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700;overflow:hidden}.theme-toggle{border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface);width:42px;height:42px;color:var(--muted);flex:none;justify-content:center;align-items:center;padding:0;font-size:20px;line-height:1;display:inline-flex}.theme-toggle:active{transform:scale(.92)}@media (hover:hover){.theme-toggle:hover{color:var(--fg);border-color:var(--muted)}}.card{background:var(--card);border-radius:var(--r-lg);box-shadow:var(--sh-1);border:1px solid var(--border);padding:14px}.card+.card{margin-top:10px}.match-card-row{align-items:center;gap:10px;display:flex;position:relative}.match-card-row:active{transform:scale(.992)}@media (hover:hover){.match-card-row:hover{border-color:var(--muted)}}.match-card-main{text-align:left;min-width:0;color:var(--fg);background:0 0;border:none;flex:1;padding:0}.mc-body{flex-direction:column;gap:7px;display:flex}.mc-meta{color:var(--muted);letter-spacing:.02em;font-size:12px;line-height:1.3}.mc-teams{color:var(--fg);font-size:16px;font-weight:700;line-height:1.45}.mc-teams .vs{color:var(--muted);margin:0 8px;font-weight:600}.mc-players,.mc-info{color:var(--muted);font-size:13px;line-height:1.55}.mc-sep{margin:0 8px}.match-menu{flex:none;position:relative}.match-menu-btn{min-width:42px;min-height:42px;padding:0;font-size:28px;line-height:1}.match-menu-popover{z-index:150;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--elevated);min-width:132px;box-shadow:var(--sh-pop);position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.match-menu-popover button{border:none;border-bottom:1px solid var(--hairline);background:var(--elevated);width:100%;min-height:42px;color:var(--fg);text-align:left;padding:9px 13px;font-size:14px;font-weight:700;display:block}.match-menu-popover button:last-child{border-bottom:none}.match-menu-popover button:disabled{color:var(--muted)}.match-menu-popover button.danger{color:var(--red)}.confirm-overlay{z-index:300;background:var(--scrim);justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.confirm-dialog{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);width:min(100%,360px);box-shadow:var(--sh-pop);padding:18px}.confirm-dialog h2{margin:0;font-size:18px}.confirm-message{color:var(--muted);margin:12px 0 18px;line-height:1.55}.confirm-actions{justify-content:flex-end;gap:8px;display:flex}.btn{letter-spacing:.01em;min-height:44px;color:var(--fg);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-1), inset 0 1px 0 var(--highlight);justify-content:center;align-items:center;gap:6px;padding:11px 18px;font-size:15px;font-weight:700;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;box-shadow:none}.btn-primary{background:var(--court);color:var(--on-accent);box-shadow:0 1px 2px #0000004d, 0 8px 20px -8px var(--glow-court), inset 0 1px 0 #ffffff2e;border-color:#0000}.btn-red{background:var(--red);color:var(--on-accent);box-shadow:0 1px 2px #0000004d, 0 8px 20px -8px var(--glow-red), inset 0 1px 0 #ffffff2e;border-color:#0000}.btn-blue{background:var(--blue);color:var(--on-accent);box-shadow:0 1px 2px #0000004d, 0 8px 20px -8px var(--glow-blue), inset 0 1px 0 #ffffff2e;border-color:#0000}.btn-ghost{color:var(--muted);box-shadow:none;background:0 0;border-color:#0000}.btn-lg{border-radius:var(--r-lg);min-height:56px;padding:18px 16px;font-size:17px}.btn-block{width:100%}@media (hover:hover){.btn:hover{border-color:var(--muted)}.btn-primary:hover,.btn-red:hover,.btn-blue:hover{filter:brightness(1.08);border-color:#0000;transform:translateY(-1px)}.btn-ghost:hover{background:var(--surface-2);color:var(--fg);border-color:#0000}}.row{gap:8px;display:flex}.row>*{flex:1}label.field,.field{margin:12px 0 0;display:block}label.field>.lbl,.field>.lbl{color:var(--muted);margin-bottom:4px;font-size:12px;display:block}input[type=text],input[type=date],textarea{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);width:100%;color:var(--fg);padding:11px 12px;font-family:inherit;font-size:16px}textarea{resize:none;min-height:44px;overflow:hidden}input[type=text]:focus,input[type=date]:focus,textarea:focus{border-color:var(--court);box-shadow:0 0 0 3px var(--court-soft);outline:none}.form-error{border:1px solid color-mix(in srgb, var(--red) 46%, var(--border));border-radius:var(--r-md);background:color-mix(in srgb, var(--red) 12%, var(--surface));color:var(--fg);margin:0 0 12px;padding:10px 12px;font-size:14px;font-weight:700}.inline-add{grid-template-columns:minmax(0,1fr) auto;gap:8px;display:grid}.inline-add .btn{min-width:72px}.profile-form{gap:18px;display:grid}.profile-section{border-bottom:1px solid var(--border);gap:10px;padding-bottom:18px;display:grid}.profile-section:last-child{border-bottom:0;padding-bottom:0}.profile-section-title{margin:0;font-size:16px;font-weight:800;line-height:1.35}.profile-team-add{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.profile-team-add .btn{min-width:72px}.profile-player-add{gap:10px;display:grid}.profile-player-mode{gap:8px;display:grid}.profile-mode-title{color:var(--muted);font-size:13px;font-weight:800}.profile-name-list{gap:6px;padding-top:4px;display:grid}.profile-name-list div{color:var(--muted);font-size:15px}.danger-text{color:var(--loss)}.dropdown{width:100%;position:relative}.dropdown-trigger{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);width:100%;min-height:46px;color:var(--fg);font:inherit;text-align:left;padding:11px 38px 11px 12px;font-size:16px;transition:background .16s,border-color .16s,color .16s,box-shadow .16s,filter .16s,transform 70ms;position:relative}.dropdown-trigger:after{content:"";border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);width:9px;height:9px;position:absolute;top:50%;right:14px;transform:translateY(-70%)rotate(45deg)}.dropdown.open .dropdown-trigger,.dropdown-trigger:focus{border-color:var(--court);box-shadow:0 0 0 3px var(--court-soft);outline:none}.dropdown.open .dropdown-trigger:after{transform:translateY(-30%)rotate(225deg)}.dropdown-value,.dropdown-placeholder{text-overflow:ellipsis;white-space:nowrap;min-width:0;display:block;overflow:hidden}.dropdown-placeholder{color:var(--muted)}.dropdown-panel{z-index:220;border:1px solid var(--border);border-radius:var(--r-md);background:var(--elevated);max-height:min(280px,46vh);box-shadow:var(--sh-pop);gap:2px;padding:4px;display:grid;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:auto}.dropdown-option{border-radius:var(--r-sm);width:100%;min-height:40px;color:var(--fg);font:inherit;text-align:left;background:0 0;border:none;padding:9px 10px;font-size:15px}.dropdown-option.active{background:var(--surface-2)}.dropdown-option.selected{background:var(--court-soft);color:var(--fg);font-weight:700}.dropdown-option:disabled{cursor:default;opacity:.38}.seg{border:1px solid var(--border);border-radius:var(--r-md);background:var(--track);gap:3px;padding:3px;display:flex}.seg button{border-radius:calc(var(--r-md) - 4px);color:var(--muted);background:0 0;border:none;flex:1;padding:9px 10px;font-size:14px;font-weight:700}.seg button.on{background:var(--court);color:var(--on-accent);box-shadow:0 1px 2px #0000004d, 0 6px 16px -8px var(--glow-court), inset 0 1px 0 #ffffff29}.seg.seg-red button.on{background:var(--red);box-shadow:0 1px 2px #0000004d, 0 6px 16px -8px var(--glow-red), inset 0 1px 0 #ffffff29}.seg.seg-blue button.on{background:var(--blue);box-shadow:0 1px 2px #0000004d, 0 6px 16px -8px var(--glow-blue), inset 0 1px 0 #ffffff29}.seg button:active{transform:scale(.97)}@media (hover:hover){.seg button:not(.on):hover{color:var(--fg)}}.main-tabs .seg button{padding:12px 10px;font-size:15px}.score-table{border-collapse:collapse;font-variant-numeric:tabular-nums;width:100%}.score-table th,.score-table td{text-align:center;border-bottom:1px solid var(--border);padding:8px 4px}.score-table th:first-child,.score-table td:first-child{text-align:left;font-weight:600}.score-table td.win{font-weight:800}.dot{vertical-align:middle;border-radius:50%;width:9px;height:9px;margin-right:6px;display:inline-block}.dot-red{background:var(--red)}.dot-blue{background:var(--blue)}.badges{flex-wrap:wrap;gap:6px;margin:8px 0;display:flex}.badge{border-radius:var(--r-pill);background:var(--surface-2);color:var(--muted);padding:4px 10px;font-size:12px;font-weight:600}.badge-final{background:var(--warn-soft);color:var(--warn)}.badge-deuce{background:var(--loss-soft);color:var(--loss)}.badge-red{background:var(--red);color:var(--on-accent)}.badge-blue{background:var(--blue);color:var(--on-accent)}.bignum{font-variant-numeric:tabular-nums;font-size:40px;font-weight:800;line-height:1}.empty{text-align:center;color:var(--muted);padding:40px 20px}.mk{width:20px;height:20px;color:var(--on-accent);vertical-align:middle;border-radius:50%;justify-content:center;align-items:center;margin:0 5px;font-size:12px;font-weight:800;display:inline-flex}.mk-red{background:var(--red)}.mk-blue{background:var(--blue)}.score-table{border-collapse:collapse;background:var(--surface);border:2px solid var(--border);font-variant-numeric:tabular-nums;width:100%;margin-top:8px}.score-table th,.score-table td{border:1px solid var(--border);vertical-align:middle;padding:12px 14px}.score-table thead th{background:var(--surface-2);vertical-align:top;padding:14px}.st-header-row th{border-bottom:2px solid var(--border)}.st-team{width:45%}.st-team.red{text-align:left}.st-team.blue{text-align:right}.st-team-name{font-size:17px;font-weight:800}.st-team.red .st-team-name{color:var(--red)}.st-team.blue .st-team-name{color:var(--blue)}.st-players{color:var(--muted);flex-direction:column;gap:3px;margin-top:6px;font-size:14px;font-weight:400;display:flex}.st-team.blue .st-players{align-items:flex-end}.st-total-score{font-variant-numeric:tabular-nums;white-space:nowrap;font-size:32px;font-weight:800}.st-total-score .g.red{color:var(--red)}.st-total-score .g.blue{color:var(--blue)}.st-total-score .dash{color:var(--muted);margin:0 2px;font-weight:400}.st-winner{margin-top:2px;font-size:16px}.st-g{text-align:center;vertical-align:middle;width:60px}.st-center{text-align:center;background:var(--surface-2);width:52px}.st-label{color:var(--muted);font-size:18px;font-weight:800;display:block}.st-gscore{margin-top:2px;font-size:18px;font-weight:800;display:block}.gw-red{color:var(--red)}.gw-blue{color:var(--blue)}.st-gscore .dash{color:var(--muted);margin:0 2px}.circled{box-sizing:border-box;vertical-align:middle;border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:1.5em;height:1.5em;line-height:1;display:inline-flex}.st-meta{color:var(--muted);text-align:center;margin:8px 0 2px;font-size:13px}.st-srv{color:var(--muted);border:1px solid var(--border);background:var(--surface-2);vertical-align:middle;border-radius:6px;align-items:center;gap:2px;margin-right:6px;padding:2px 6px 2px 4px;font-size:12px;font-weight:800;display:inline-flex}.st-marks.blue .st-srv{margin-left:0;margin-right:6px}.st-srv .mk{width:16px;height:16px;margin:0;font-size:10px}.st-srv.rcv{color:var(--faint)}.st-marks{width:45%;min-height:36px}.st-marks.red{text-align:right}.st-marks.blue{text-align:left}.st-mk{text-align:center;cursor:pointer;border-radius:4px;width:28px;height:28px;font-size:22px;font-weight:700;line-height:28px;display:inline-block}.st-mk:active{background:var(--press)}.st-mk.win{color:var(--red)}.st-marks.blue .st-mk.win{color:var(--blue)}.st-mk.lose{color:var(--faint)}.st-draft{color:var(--muted);border:1px dashed var(--muted);cursor:pointer;font-size:11px}.st-row.st-empty td{opacity:.4;min-height:28px}.st-row.st-active td{background:var(--court-soft)}.sheet{display:none}.sheet-game{align-items:stretch;gap:6px;display:flex}.game-label{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);flex-direction:column;flex:none;justify-content:center;align-items:center;gap:3px;width:34px;display:flex}.game-label .gno{font-size:14px;font-weight:800}.game-label .srv{width:16px;height:16px;color:var(--on-accent);border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:800;display:flex}.game-label .srv.mk-red{background:var(--red)}.game-label .srv.mk-blue{background:var(--blue)}.pt-row{flex-wrap:wrap;flex:1;align-content:flex-start;gap:4px;display:flex}.pt-cell{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);flex-direction:column;justify-content:center;align-items:center;gap:3px;min-width:46px;min-height:44px;padding:4px 6px;display:flex}.pt-cell:active{transform:scale(.96)}.pt-cell.win-red{border-color:var(--red);box-shadow:inset 0 -3px 0 var(--red)}.pt-cell.win-blue{border-color:var(--blue);box-shadow:inset 0 -3px 0 var(--blue)}.pt-cell.draft{border-style:dashed;border-color:var(--muted)}.pt-score{font-variant-numeric:tabular-nums;font-size:13px;font-weight:800}.pt-dots{align-items:center;gap:2px;min-height:8px;display:flex}.bd{border-radius:50%;width:7px;height:7px;display:inline-block}.bd-red{background:var(--red)}.bd-blue{background:var(--blue)}.bd.term{outline:2px solid var(--ring);outline-offset:1px}.bd-add{color:var(--muted);font-size:12px;font-style:normal;font-weight:700}.record-cta{margin-top:16px}.detail-toggle{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);width:100%;color:var(--fg);text-align:left;margin-top:12px;padding:10px;font-size:14px;font-weight:700}.detail-toggle:after{content:"▸";float:right;transition:transform .2s}.detail-toggle.open:after{transform:rotate(90deg)}.formation-editor{margin-top:8px}.fm-tabs{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.fm-tab{border:1px solid var(--border);background:var(--surface);min-width:0;color:var(--fg);text-align:center;white-space:nowrap;border-radius:6px;flex:1;padding:6px 4px;font-size:11px;font-weight:600}.fm-tab.on{background:var(--court);color:var(--on-accent);border-color:var(--court)}.fm-canvas{touch-action:none;border:1px solid var(--border);width:100%;height:300px;display:block}.editor{height:100vh;overflow:hidden}.editor .server-chip{background:var(--surface-2);border-radius:var(--r-pill);align-items:center;padding:3px 10px 3px 4px;font-size:13px;font-weight:700;display:inline-flex}.btn.icon{justify-content:center;align-items:center;min-width:36px;min-height:36px;padding:4px 8px;font-size:18px;display:inline-flex}.btn.icon.on{color:var(--court)}.btn-settings{min-width:44px;min-height:44px;color:var(--muted);justify-content:center;align-items:center;padding:8px;font-size:26px;line-height:1;display:inline-flex}.court-row{gap:8px;height:82vh;min-height:500px;margin-top:6px;display:flex}.court-col{flex-direction:column;flex:0 auto;align-items:stretch;min-width:0;height:100%;display:flex}.court-team-label{border:1px solid var(--border);background:var(--surface);border-radius:0;align-items:center;gap:10px;padding:8px 6px;font-size:12px;line-height:1.3;display:flex;overflow:hidden}.court-team-label .ct-name{white-space:nowrap;text-overflow:ellipsis;flex:none;max-width:40%;font-size:13px;font-weight:800;overflow:hidden}.ct-red .ct-name{color:var(--red)}.ct-blue .ct-name{color:var(--blue)}.ct-roster{gap:10px;display:flex}.ct-player{color:var(--fg);white-space:nowrap;text-overflow:ellipsis;align-items:center;font-size:12px;display:inline-flex;overflow:hidden}.ct-serve-badge{border-radius:var(--r-pill);background:var(--court);color:var(--on-accent);flex:none;margin-left:5px;padding:1px 6px;font-size:10px;font-weight:800;line-height:1.5}.ct-receive-badge{color:var(--muted);border:1px solid var(--border);background:0 0}.court-wrap{flex:0 auto;align-self:center;min-width:0;min-height:0;max-height:100%;position:relative}.side-panel{flex-direction:column;flex:1 1 0;gap:5px;min-width:0;padding:2px;display:flex}.sp-top{grid-template-columns:26px minmax(0,1fr) 26px;align-items:center;gap:4px;min-height:26px;display:grid}.sp-top:before{content:"";width:26px;height:26px}.ball-label{text-align:center;background:var(--surface-2);border-radius:4px;justify-content:center;align-items:center;min-width:0;min-height:26px;padding:4px;font-size:13px;font-weight:800;display:flex}.sp-reset{border:1px solid var(--border);background:var(--surface);cursor:pointer;width:26px;height:26px;color:var(--muted);border-radius:4px;font-size:13px}.sp-reset-placeholder{visibility:hidden;pointer-events:none}.sp-act{border:1px solid var(--border);background:var(--surface-2);color:var(--muted);cursor:pointer;text-align:center;border-radius:3px;width:100%;padding:4px 6px;font-size:10px;font-weight:600}.sp-toggle{background:var(--track);border-radius:4px;gap:2px;padding:1px;display:flex}.sp-tgl{cursor:pointer;color:var(--muted);text-align:center;background:0 0;border:none;border-radius:3px;flex:1;padding:8px 2px;font-size:12px;font-weight:700}.sp-tgl.on{background:var(--elevated);color:var(--fg);box-shadow:var(--sh-1)}.sp-types{grid-template-columns:repeat(3,1fr);gap:2px;display:grid}.sp-type{border:1px solid var(--border);background:var(--surface);color:var(--fg);text-align:center;cursor:pointer;border-radius:3px;padding:8px 1px;font-size:12px;font-weight:600}.sp-type.on{background:var(--court);color:var(--on-accent);border-color:var(--court)}.sp-add-on-types{grid-template-columns:repeat(2,1fr)}.sp-add-on-chip{font-size:11px}.sp-add-on-chip.on{background:var(--loss);color:var(--on-accent);border-color:var(--loss)}.sp-effectiveness-scale{border:1px solid var(--border);background:var(--track);border-radius:5px;grid-template-columns:repeat(5,minmax(0,1fr));gap:2px;padding:2px;display:grid}.sp-effectiveness{min-width:0;min-height:32px;color:var(--muted);font-variant-numeric:tabular-nums;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:5px 0;font-size:12px;font-weight:800}.sp-effectiveness.on{background:var(--court);color:var(--on-accent);box-shadow:0 1px 2px #0000004d, 0 6px 16px -8px var(--glow-court), inset 0 1px 0 #ffffff29}.sp-effectiveness:disabled{cursor:default;opacity:.55}.sp-shot-group{flex-direction:column;gap:4px;display:flex}.sp-group-label{color:var(--muted);font-size:11px;font-weight:800}.sp-motion{width:100%;color:var(--muted);cursor:pointer;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);justify-content:center;align-items:center;gap:7px;padding:10px 8px;font-size:12px;font-weight:700;display:flex}.sp-motion:before{content:"";opacity:.55;border:2px solid;border-radius:50%;flex:none;width:16px;height:16px}.sp-motion.on{background:var(--motion);color:var(--on-accent);box-shadow:0 4px 12px -4px var(--glow-motion);border-color:#0000}.sp-motion.on:before{content:"✓";opacity:1;background:#ffffff47;border-color:#0000;justify-content:center;align-items:center;font-size:11px;font-weight:900;line-height:1;display:inline-flex}.sp-motion:not(:disabled):active{transform:scale(.98)}.sp-motion:disabled{opacity:.5;cursor:default}.sp-results{flex-direction:column;gap:3px;margin-top:auto;display:flex}.sp-serve-style{background:var(--track);border-radius:5px;gap:2px;padding:2px;display:flex}.sp-ss{cursor:pointer;color:var(--muted);text-align:center;background:0 0;border:none;border-radius:4px;flex:1;padding:5px 2px;font-size:11px;font-weight:700}.sp-ss.on{background:var(--elevated);color:var(--fg);box-shadow:var(--sh-1)}.sp-result-label{text-align:center;border-radius:5px;padding:6px;font-size:14px;font-weight:800}.sp-end-in,.sp-end-winner{background:var(--court-soft);color:var(--court)}.sp-end-fault{background:var(--loss-soft);color:var(--loss)}.sp-end-out{background:var(--warn-soft);color:var(--warn)}.sp-end-net{background:var(--info-soft);color:var(--info)}.sp-winner{border:2px solid var(--court);background:var(--surface);width:100%;color:var(--court);cursor:pointer;text-align:center;border-radius:5px;padding:10px;font-size:14px;font-weight:700}.sp-winner.on{background:var(--court);color:var(--on-accent)}.sp-view{flex-direction:column;gap:4px;margin-top:auto;display:flex}.sp-btn{border:1px solid var(--border);background:var(--surface);color:var(--fg);text-align:center;cursor:pointer;border-radius:4px;padding:6px;font-size:11px;font-weight:600}.sp-del{border-color:var(--red);color:var(--red)}.place-legend{border-radius:var(--r-pill);background:#00000059;gap:8px;padding:6px 10px;display:flex;position:absolute;top:10px;left:50%;transform:translate(-50%)}.place-legend .mk{opacity:.35;width:24px;height:24px;margin:0;font-size:13px}.place-legend .mk.placed{opacity:1}.place-legend .legend-label{color:#ffffffb3;align-self:center;font-size:11px;line-height:1}.place-legend .legend-sep{color:#ffffff4d;align-self:center;font-size:16px}@keyframes pulse{0%,to{box-shadow:0 0 #fff9}50%{box-shadow:0 0 0 6px #fff0}}.chips{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.type-chips{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.chip{border-radius:var(--r-pill);border:1px solid var(--border);background:var(--surface);color:var(--fg);flex:none;padding:9px 14px;font-size:14px;font-weight:700}.chip:active{transform:scale(.96)}.chip.on{background:var(--court);color:var(--on-accent);box-shadow:0 4px 12px -4px var(--glow-court);border-color:#0000}@media (hover:hover){.chip:not(.on):hover{border-color:var(--muted)}}.end-chips{margin-top:6px}.chip-end{background:var(--surface);border-color:var(--red);color:var(--red);flex:1;justify-content:center;font-weight:700}.chip-end.suggested{background:var(--red);color:var(--on-accent);box-shadow:0 0 0 2px var(--red-soft)}.chip-reset{background:var(--surface);border:1.5px solid var(--border);color:var(--muted);text-align:center;border-radius:var(--r-sm);width:100%;padding:10px 8px;font-size:13px;font-weight:600}.ballnav{align-items:center;gap:8px;margin-top:12px;display:flex}.navbtn{border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);width:52px;height:48px;color:var(--fg);box-shadow:var(--sh-1), inset 0 1px 0 var(--highlight);flex:none;font-size:20px;font-weight:700}.navbtn:not(:disabled):active{transform:scale(.95)}.navbtn:disabled{opacity:.3;box-shadow:none}.ball-strip{flex:1;gap:5px;padding:2px;display:flex;overflow-x:auto}.ball-dot{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);min-width:36px;height:48px;color:var(--on-accent);flex:none;justify-content:center;align-items:center;padding:0 8px;font-size:14px;font-weight:700;display:inline-flex}.ball-dot.bd-red{background:var(--red);border-color:var(--red)}.ball-dot.bd-blue{background:var(--blue);border-color:var(--blue)}.ball-dot.term{border-color:var(--fg)}.ball-dot.pending{background:var(--surface-2);color:var(--muted);border-color:var(--border)}.ball-dot.on{border-color:var(--court);border-width:2px}.analysis-search{flex-direction:column;gap:12px;padding-bottom:16px;display:flex}.analysis-filter-row{scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:8px;margin:-2px;padding:2px;display:flex;overflow-x:auto}.analysis-filter-row::-webkit-scrollbar{display:none}.analysis-filter-row button{border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface);min-height:38px;color:var(--muted);white-space:nowrap;flex:none;padding:0 14px;font-size:13px;font-weight:800}.analysis-filter-row button.on{background:var(--court);color:var(--on-accent);box-shadow:0 6px 16px -10px var(--glow-court);border-color:#0000}.analysis-count{color:var(--muted);align-items:baseline;gap:5px;font-size:13px;font-weight:800;display:inline-flex}.analysis-count strong{color:var(--fg);font-size:24px;line-height:1}.analysis-result-list{flex-direction:column;gap:8px;display:flex}.analysis-result-row{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);min-height:58px;color:var(--fg);text-align:left;grid-template-columns:minmax(112px,auto) 66px 48px 30px minmax(0,1fr);align-items:center;gap:8px;padding:10px 12px;display:grid}.analysis-result-row:active{background:var(--surface-2);transform:scale(.992)}.analysis-scene{border-radius:var(--r-pill);background:var(--court-soft);min-width:0;color:var(--court);text-overflow:ellipsis;white-space:nowrap;padding:5px 9px;font-size:12px;font-weight:900;overflow:hidden}.analysis-result-row strong{font-variant-numeric:tabular-nums;font-size:14px;font-weight:900}.analysis-result-row span{color:var(--muted);font-variant-numeric:tabular-nums;font-size:13px;font-weight:800}.analysis-result-row em{background:var(--surface-2);width:28px;height:28px;color:var(--fg);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-style:normal;font-weight:900;display:inline-flex}.analysis-result-row small{min-width:0;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700;overflow:hidden}@media (width<=520px){.analysis-result-row{grid-template-columns:minmax(0,1fr) 64px 44px 30px}.analysis-result-row small{grid-column:1/-1}}
