: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}#root{min-height:100vh}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-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}
