:root{--color-bg: #0f1419;--color-text: #e8eaed;--color-text-muted: #9aa3ad;--color-text-subtle: #7d8a96;--color-text-caption: #b8c0c9;--color-surface: #151b22;--color-surface-input: #1a222c;--color-surface-hover: #1e2a36;--color-surface-nav-hover: #263545;--color-border: #2a3441;--color-border-strong: #2f3d4d;--color-border-hover: #4a5f78;--color-correct-border: #2d6a4f;--color-correct-bg: rgba(45, 106, 79, .25);--color-wrong-border: #9b2226;--color-wrong-bg: rgba(155, 34, 38, .2);--radius-sm: 8px;--radius-pill: 999px;--radius-panel: 12px;--focus-ring: 0 0 0 2px var(--color-bg), 0 0 0 4px #4a90d9;font-family:DM Sans,system-ui,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;min-height:100dvh}#root{min-height:100vh;min-height:100dvh}button,select{font:inherit}.app{max-width:min(960px,100%);margin:0 auto;padding:max(1.25rem,env(safe-area-inset-top)) max(1rem,env(safe-area-inset-right)) max(2.5rem,env(safe-area-inset-bottom)) max(1rem,env(safe-area-inset-left))}.app-hub{max-width:min(640px,100%)}.app-play{max-width:none;margin:0;padding:0;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.app-browse{max-width:min(960px,100%)}.app-complete{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;max-width:none;margin:0;padding:max(1rem,env(safe-area-inset-top)) max(1rem,env(safe-area-inset-right)) max(1rem,env(safe-area-inset-bottom)) max(1rem,env(safe-area-inset-left))}.app-header{margin-bottom:1.25rem}.app-header h1{margin:0 0 .35rem;font-size:clamp(1.35rem,4vw,1.65rem);font-weight:700;letter-spacing:-.02em}.app-header p{margin:0;color:var(--color-text-muted);font-size:clamp(.875rem,2.5vw,.95rem);line-height:1.45}.toolbar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end;margin-bottom:1rem}.toolbar label{flex:1 1 200px;min-width:min(100%,200px);font-size:.8rem;color:var(--color-text-muted);display:flex;flex-direction:column;gap:.25rem}.toolbar select{width:100%;max-width:100%;min-width:0;min-height:44px;padding:.45rem .6rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface-input);color:var(--color-text)}.toolbar select:focus-visible{outline:none;box-shadow:var(--focus-ring)}.frame-nav{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;flex:1 1 auto;justify-content:flex-start}@media(min-width:520px){.frame-nav{flex-wrap:nowrap;justify-content:flex-end;margin-left:auto}}.frame-nav button{min-height:44px;min-width:44px;padding:.45rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-surface-hover);color:var(--color-text);cursor:pointer}.frame-nav button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.frame-nav button:hover:not(:disabled){background:var(--color-surface-nav-hover)}.frame-nav button:disabled{opacity:.45;cursor:not-allowed}.frame-nav-status{font-size:.85rem;color:var(--color-text-muted);flex:1 1 100%;text-align:center;order:-1}@media(min-width:520px){.frame-nav-status{flex:0 1 auto;order:0;text-align:inherit}}.mirror-toggle{min-height:44px;padding:.45rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-surface-hover);color:var(--color-text);cursor:pointer;font-size:.8rem}.mirror-toggle:hover{background:var(--color-surface-nav-hover)}.mirror-toggle:focus-visible{outline:none;box-shadow:var(--focus-ring)}.mirror-toggle[aria-pressed=true]{border-color:#4a6fa5;background:#4a6fa533}.frame-caption{font-size:.9rem;color:var(--color-text-caption);margin:0 0 .75rem;min-height:2.75rem}.scenario-meta{font-size:.8rem;color:var(--color-text-subtle);margin-bottom:.75rem}.tag-list{display:flex;flex-wrap:wrap;gap:.35rem;list-style:none;padding:0;margin:.35rem 0 0}.tag-list li{background:var(--color-surface-hover);border:1px solid var(--color-border-strong);border-radius:var(--radius-pill);padding:.15rem .55rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}.court-wrap{background:var(--color-surface);border-radius:var(--radius-panel);border:1px solid var(--color-border);padding:clamp(.5rem,2vw,.75rem);margin-bottom:1.25rem}.court-svg{width:100%;height:auto;display:block;border-radius:var(--radius-sm)}.court-token-shift{transition:transform .95s cubic-bezier(.22,1,.36,1)}.court-shift-advantage{transition-duration:1.05s;transition-timing-function:cubic-bezier(.2,.85,.25,1)}.court-shift-setback{transition-duration:1.2s;transition-timing-function:cubic-bezier(.45,0,.55,1)}.court-shift-lapse{transition-duration:1.35s;transition-timing-function:cubic-bezier(.55,.05,.45,.95)}.court-token-ring{animation:court-ring-pulse 1.1s ease-in-out infinite}.court-token-disc{transform-origin:center;transform-box:fill-box;animation:court-token-breathe 1.2s ease-in-out infinite}.court-token-ring-setback{transform-origin:center;transform-box:fill-box;animation:court-ring-wobble 1.35s ease-in-out infinite}.court-token-disc-setback{transform-origin:center;transform-box:fill-box;animation:court-token-shrink 1.25s ease-in-out infinite}.court-token-ring-lapse{transform-origin:center;transform-box:fill-box;animation:court-ring-stutter .9s ease-in-out infinite}.court-token-disc-lapse{transform-origin:center;transform-box:fill-box;animation:court-token-late 1.1s ease-in-out infinite}.court-pass-line{animation:court-pass-fade .85s ease-out forwards;opacity:0}.court-pass-dot{animation:court-pass-pop .68s ease-out .18s forwards;opacity:0}.court-pass-line-advantage{animation:court-pass-snap .78s cubic-bezier(.18,.9,.25,1) forwards}.court-pass-dot-advantage{transform-origin:center;transform-box:fill-box;animation:court-pass-pop-strong .62s cubic-bezier(.2,.95,.3,1) .12s forwards}.court-pass-line-setback{animation:court-pass-fade-weak 1.05s ease-out forwards}.court-pass-dot-setback{transform-origin:center;transform-box:fill-box;animation:court-pass-pop-weak .82s ease-out .26s forwards}.court-pass-line-lapse{animation:court-pass-fade-late 1.28s ease-out forwards}.court-pass-dot-lapse{transform-origin:center;transform-box:fill-box;animation:court-pass-pop-late .95s ease-out .38s forwards}@keyframes court-ring-pulse{0%,to{opacity:.55}50%{opacity:1}}@keyframes court-token-breathe{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes court-pass-fade{0%{opacity:0}to{opacity:1}}@keyframes court-pass-pop{0%{opacity:0}to{opacity:1}}@keyframes court-ring-wobble{0%,to{opacity:.45;transform:rotate(0)}35%{opacity:.85;transform:rotate(-2.5deg)}65%{opacity:.75;transform:rotate(2deg)}}@keyframes court-token-shrink{0%,to{transform:scale(1)}50%{transform:scale(.94)}}@keyframes court-ring-stutter{0%,to{opacity:.4}20%{opacity:.55}40%{opacity:.95}55%{opacity:.5}70%{opacity:.88}}@keyframes court-token-late{0%,to{transform:scale(1)}35%{transform:scale(.96)}65%{transform:scale(1.03)}}@keyframes court-pass-snap{0%{opacity:0;stroke-dashoffset:2.5}to{opacity:1;stroke-dashoffset:0}}@keyframes court-pass-pop-strong{0%{opacity:0;transform:scale(.35)}70%{opacity:1;transform:scale(1.12)}to{opacity:1;transform:scale(1)}}@keyframes court-pass-fade-weak{0%{opacity:0}to{opacity:.72}}@keyframes court-pass-pop-weak{0%{opacity:0;transform:scale(.85)}to{opacity:.75;transform:scale(1)}}@keyframes court-pass-fade-late{0%{opacity:0}to{opacity:.68}}@keyframes court-pass-pop-late{0%{opacity:0;transform:scale(.55)}55%{opacity:.55;transform:scale(.92)}to{opacity:.7;transform:scale(1)}}@media(prefers-reduced-motion:reduce){.court-token-shift,.court-token-ring,.court-token-disc,.court-token-ring-setback,.court-token-disc-setback,.court-token-ring-lapse,.court-token-disc-lapse,.court-pass-line,.court-pass-dot,.court-pass-line-advantage,.court-pass-dot-advantage,.court-pass-line-setback,.court-pass-dot-setback,.court-pass-line-lapse,.court-pass-dot-lapse{animation:none!important;transition:none!important}.court-pass-line,.court-pass-line-advantage,.court-pass-line-setback,.court-pass-line-lapse,.court-pass-dot,.court-pass-dot-advantage,.court-pass-dot-setback,.court-pass-dot-lapse{opacity:1}.court-token-ring-setback,.court-token-disc-setback,.court-token-ring-lapse,.court-token-disc-lapse{transform:none}}.drill-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-panel);padding:clamp(.85rem,3vw,1.1rem)}.drill-panel-head{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem .75rem;margin-bottom:.5rem}.drill-panel h2{margin:0;font-size:1rem;font-weight:600}.drill-step{font-size:.75rem;color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.04em}.drill-perspective{margin:0 0 .35rem;font-size:.78rem;font-weight:600;color:#8ab4d9;text-transform:uppercase;letter-spacing:.05em}.drill-role{margin:0 0 .65rem;font-size:.82rem;color:var(--color-text-muted);line-height:1.4}.drill-tabs{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.65rem}.drill-tab{min-height:44px;padding:.35rem .75rem;border-radius:var(--radius-pill);border:1px solid var(--color-border-strong);background:var(--color-surface-input);color:var(--color-text-muted);font-size:.78rem;cursor:pointer}.drill-tab:hover{border-color:var(--color-border-hover);color:var(--color-text)}.drill-tab:focus-visible{outline:none;box-shadow:var(--focus-ring)}.drill-tab.active{border-color:#4a6fa5;background:#4a6fa526;color:var(--color-text)}.drill-prompt{margin:0 0 .85rem;font-size:.95rem;line-height:1.45}.options{display:flex;flex-direction:column;gap:.5rem}.option-btn{text-align:left;min-height:44px;padding:.6rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-surface-input);color:var(--color-text);cursor:pointer}.option-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.option-btn:hover:not(:disabled){border-color:var(--color-border-hover)}.option-btn.correct{border-color:var(--color-correct-border);background:var(--color-correct-bg);animation:option-reveal-correct .55s cubic-bezier(.22,1,.36,1) both;box-shadow:0 0 #2d6a4f59}.option-btn.wrong{border-color:var(--color-wrong-border);background:var(--color-wrong-bg);animation:option-reveal-wrong .65s cubic-bezier(.45,0,.55,1) both}@keyframes option-reveal-correct{0%{opacity:.88;transform:translate(-6px) scale(.99);box-shadow:0 0 #2d6a4f00}55%{transform:translate(2px) scale(1.01);box-shadow:0 0 0 4px #2d6a4f33}to{opacity:1;transform:translate(0) scale(1);box-shadow:0 0 #2d6a4f00}}@keyframes option-reveal-wrong{0%{opacity:.9;transform:translate(5px)}22%{transform:translate(-5px)}44%{transform:translate(4px)}66%{transform:translate(-2px)}to{opacity:1;transform:translate(0)}}@media(prefers-reduced-motion:reduce){.option-btn.correct,.option-btn.wrong{animation:none}}.drill-feedback{margin-top:.85rem;font-size:.88rem;color:var(--color-text-caption);line-height:1.45}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hub{padding-bottom:.5rem}.hub-hero{position:relative;margin-bottom:1.5rem;padding:1.35rem 1.25rem 1.25rem;border-radius:var(--radius-panel);border:1px solid var(--color-border);background:var(--color-surface);overflow:hidden;text-align:center}.hub-hero--compact{margin-bottom:1.25rem;padding:1.1rem 1rem 1rem}.hub-hero-accent{position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,#4a6fa5,#8ab4d9 45%,#e8a598d9);opacity:.95}.hub-hero-inner{position:relative}.hub-eyebrow{margin:0 0 .4rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#8ab4d9}.hub-title{margin:0 0 .5rem;font-size:clamp(1.45rem,5vw,1.8rem);font-weight:700;letter-spacing:-.03em;line-height:1.15}.hub-subtitle{color:var(--color-text-caption);font-size:.9rem;line-height:1.45;max-width:28rem;margin:0 auto}.hub-grid{display:grid;gap:.65rem}.hub-card{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;padding:1rem 1.1rem;border-radius:var(--radius-panel);border:1px solid var(--color-border-strong);background:var(--color-surface-input);color:var(--color-text);text-align:left;cursor:pointer;box-shadow:0 1px #00000040;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.hub-card:hover:not(:disabled){border-color:var(--color-border-hover);background:var(--color-surface-hover);box-shadow:0 2px 8px #0003}.hub-card:focus-visible{outline:none;box-shadow:var(--focus-ring)}.hub-card:disabled{opacity:.45;cursor:not-allowed}.hub-card-feature{border-color:#4a6fa58c;background:linear-gradient(155deg,rgba(74,111,165,.22),var(--color-surface-input) 55%);box-shadow:0 0 0 1px #4a6fa51f,0 1px #00000040}.hub-card-feature:hover:not(:disabled){border-color:#8ab4d98c;background:linear-gradient(155deg,rgba(74,111,165,.3),var(--color-surface-hover) 50%)}.hub-card-secondary{border-style:dashed;border-color:var(--color-border);background:var(--color-surface)}.hub-card-kicker{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-subtle)}.hub-card-title{font-size:1.05rem;font-weight:700;letter-spacing:-.02em}.hub-card-desc{font-size:.84rem;color:var(--color-text-muted);line-height:1.4}.hub-card-meta{margin-top:.2rem;font-size:.72rem;font-weight:600;font-variant-numeric:tabular-nums;color:#8ab4d9;letter-spacing:.02em}.hub-footer-hint{margin:1.25rem 0 0;padding-top:1rem;border-top:1px solid var(--color-border);text-align:center;font-size:.78rem;color:var(--color-text-subtle);line-height:1.45}.hub-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;min-height:44px;padding:.5rem 1.1rem;border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-surface-hover);color:var(--color-text);font-size:.9rem;font-weight:600;cursor:pointer}.hub-btn:hover{background:var(--color-surface-nav-hover)}.hub-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.hub-btn-primary{border-color:#4a6fa5;background:#4a6fa559}.hub-btn-ghost{border-color:transparent;background:transparent;color:var(--color-text-muted)}.hub-btn-ghost:hover{background:var(--color-surface-hover);color:var(--color-text)}.tag-pick-list{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.45rem}.tag-pick-btn{width:100%;text-align:left;min-height:44px;padding:.55rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.9rem;cursor:pointer}.tag-pick-btn:hover{border-color:var(--color-border-hover);background:var(--color-surface-hover)}.tag-pick-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.complete-card{max-width:22rem;text-align:center}.complete-title{margin:0 0 .5rem;font-size:1.35rem}.complete-lead{margin:0 0 1.25rem;color:var(--color-text-muted);font-size:.92rem;line-height:1.45}.complete-actions{display:flex;flex-direction:column;gap:.5rem}.play-shell{flex:1;display:flex;flex-direction:column;min-height:0;min-height:100dvh;background:var(--color-bg)}.play-top-bar{flex-shrink:0;display:flex;align-items:center;gap:.5rem;padding:max(.5rem,env(safe-area-inset-top)) max(.65rem,env(safe-area-inset-right)) .35rem max(.65rem,env(safe-area-inset-left))}.play-back{flex-shrink:0;min-height:40px;padding:.35rem .6rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-muted);font-size:.88rem;cursor:pointer}.play-back:hover{color:var(--color-text);background:var(--color-surface-hover)}.play-back:focus-visible{outline:none;box-shadow:var(--focus-ring)}.play-top-meta{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;gap:.5rem}.play-mode-pill{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#8ab4d9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:42vw}.play-progress{font-size:.78rem;font-weight:600;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.play-mirror{flex-shrink:0;min-height:40px;padding:.35rem .65rem;border-radius:var(--radius-pill);border:1px solid var(--color-border-strong);background:var(--color-surface-input);color:var(--color-text);font-size:.78rem;font-weight:600;cursor:pointer}.play-mirror:hover{border-color:var(--color-border-hover)}.play-mirror.active{border-color:#4a6fa5;background:#4a6fa533}.play-mirror:focus-visible{outline:none;box-shadow:var(--focus-ring)}.play-main{flex:1;display:flex;flex-direction:column;min-height:0;padding:0 max(.65rem,env(safe-area-inset-right)) max(.5rem,env(safe-area-inset-bottom)) max(.65rem,env(safe-area-inset-left));gap:.35rem}.play-court-zone{flex:1 1 0;min-height:0;display:flex;flex-direction:column}.play-caption{flex-shrink:0;margin:0 0 .25rem;font-size:clamp(.72rem,2.8vw,.82rem);color:var(--color-text-caption);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.play-caption-placeholder{min-height:0;margin:0}.play-court-wrap{flex:1 1 0;min-height:0;margin-bottom:0;display:flex;flex-direction:column}.play-court-wrap .court-svg{flex:1 1 0;width:100%;height:100%;min-height:0;object-fit:contain;object-position:top center}.play-drill-zone{flex-shrink:0;max-height:min(48vh,22rem);overflow-y:auto;overscroll-behavior:contain;padding-bottom:.25rem}.drill-panel-compact{padding:.65rem .75rem}.drill-panel-compact .drill-panel-head{margin-bottom:.35rem;align-items:center}.drill-perspective-badge{margin-left:auto;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.15rem .45rem;border-radius:var(--radius-pill);border:1px solid var(--color-border-strong)}.drill-perspective-badge--offense{color:#8ab4d9;border-color:#8ab4d973}.drill-perspective-badge--defense{color:#e8a598;border-color:#e8a59873}.drill-perspective-badge--neutral{color:var(--color-text-muted)}.drill-role-compact{margin:0 0 .35rem;font-size:.72rem;line-height:1.35}.drill-prompt-compact{margin:0 0 .5rem;font-size:clamp(.82rem,2.6vw,.9rem);line-height:1.35}.drill-prompt-swap-explanation{color:var(--color-text-muted);font-size:clamp(.78rem,2.4vw,.85rem)}.options-compact{gap:.35rem}.option-btn-compact{padding:.45rem .6rem;font-size:clamp(.78rem,2.4vw,.85rem);line-height:1.3}.drill-feedback-compact{margin-top:.5rem;font-size:.78rem}.play-next-row{margin-top:.5rem}.play-next-btn{width:100%;min-height:44px;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .85rem;border-radius:var(--radius-sm);border:1px solid #4a6fa5;background:#4a6fa547;color:var(--color-text);font-size:.9rem;font-weight:700;cursor:pointer}.play-next-btn:hover{background:#4a6fa566}.play-next-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.play-next-hint{font-size:.72rem;font-weight:500;color:var(--color-text-muted)}.play-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1rem;text-align:center;color:var(--color-text-muted)}.browse-shell{padding-bottom:2rem}.browse-header{margin-bottom:1rem}.browse-back{display:inline-block;margin-bottom:.5rem;padding:.35rem .5rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-muted);font-size:.88rem;cursor:pointer}.browse-back:hover{color:var(--color-text);background:var(--color-surface-hover)}.browse-title{margin:0 0 .35rem;font-size:clamp(1.25rem,4vw,1.5rem)}.browse-lead{margin:0;color:var(--color-text-muted);font-size:.88rem;line-height:1.45}
