:root{--bg: #0b1120;--bg-elev: #111a2e;--bg-elev-2: #1a2540;--fg: #e6edf7;--fg-dim: #98a3b8;--accent: #7cc4ff;--accent-strong: #3aa3ff;--good: #4ade80;--warn: #fbbf24;--bad: #f87171;--radius: 14px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,system-ui,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:radial-gradient(1200px 800px at 70% -10%,#1a2a55 0%,var(--bg) 60%);color:var(--fg);-webkit-font-smoothing:antialiased;overflow-x:hidden}button{font:inherit;color:inherit;cursor:pointer;border:none;background:var(--accent-strong);color:#04111e;padding:.7rem 1.2rem;border-radius:var(--radius);font-weight:600;transition:transform .06s ease,background .2s ease,opacity .2s ease}button:hover:not(:disabled){background:var(--accent)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed}button.link{background:transparent;color:var(--fg-dim);padding:.4rem .6rem;font-weight:500}button.link:hover{color:var(--fg);background:transparent}.menu{max-width:900px;margin:0 auto;padding:clamp(2rem,6vw,5rem) 1.5rem}.menu-header h1{font-size:clamp(2rem,5vw,3.2rem);margin:0 0 .5rem;letter-spacing:-.02em}.menu-header p{color:var(--fg-dim);max-width:56ch;line-height:1.55;margin:0}.menu-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin:2.5rem 0 1.5rem}.card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;background:var(--bg-elev);color:var(--fg);padding:1.5rem 1.5rem 1.6rem;border:1px solid #243155;border-radius:var(--radius);gap:.5rem;transition:border-color .2s ease,transform .1s ease,background .2s ease}.card:hover:not(:disabled){border-color:var(--accent);background:var(--bg-elev-2)}.card-eyebrow{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}.card-title{font-size:1.4rem;font-weight:600}.card-desc{color:var(--fg-dim);font-size:.95rem;line-height:1.5}.menu-footer{margin-top:1rem}.status{display:inline-block;font-size:.85rem;padding:.3rem .7rem;border-radius:999px;background:var(--bg-elev);color:var(--fg-dim)}.status-ok{color:var(--good)}.lesson{min-height:100vh;min-height:100dvh;padding:1rem clamp(1rem,3vw,2rem);display:flex;flex-direction:column;gap:1rem;transition:background-color .2s ease}.lesson-bar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.lesson-stats{margin-left:auto;display:flex;gap:1rem;font-size:.95rem;color:var(--fg-dim)}.lesson-stats b{color:var(--fg);margin-left:.3rem}.dots{display:flex;gap:4px;flex-wrap:wrap}.dot{width:22px;height:22px;border-radius:6px;background:var(--bg-elev);color:var(--fg-dim);font-size:.7rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.dot-done{background:var(--good);color:#04111e}.dot-current{background:var(--accent-strong);color:#04111e}.lesson-grid{flex:1;display:grid;grid-template-columns:minmax(260px,1fr) minmax(320px,1.4fr);gap:1rem}.target-card,.cam-card{background:var(--bg-elev);border:1px solid #243155;border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.target-eyebrow{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}.target-letter{font-size:clamp(6rem,18vw,12rem);font-weight:700;line-height:.9;letter-spacing:-.05em}.target-ref{width:100%;max-width:220px;aspect-ratio:322 / 424;object-fit:contain;background:#f5f7fb;border-radius:10px;border:1px solid #243155;padding:.6rem}.skip{margin-top:auto}.cam-card{gap:.8rem}.webcam-wrap{position:relative;width:100%;aspect-ratio:4/3;background:#000;border-radius:10px;overflow:hidden}.webcam-wrap video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.crop-guide{position:absolute;pointer-events:none;transition:left .06s linear,top .06s linear,width .06s linear,height .06s linear}.crop-corner{position:absolute;width:22px;height:22px;border:3px solid rgba(124,196,255,.9);filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}.crop-corner-tl{top:-3px;left:-3px;border-right:0;border-bottom:0;border-radius:6px 0 0}.crop-corner-tr{top:-3px;right:-3px;border-left:0;border-bottom:0;border-radius:0 6px 0 0}.crop-corner-bl{bottom:-3px;left:-3px;border-right:0;border-top:0;border-radius:0 0 0 6px}.crop-corner-br{bottom:-3px;right:-3px;border-left:0;border-top:0;border-radius:0 0 6px}.crop-guide-fallback .crop-corner{border-color:#7cc4ff59}.crop-guide-tracking .crop-corner{border-color:#4ade80f2}.webcam-error{padding:1.5rem;border:1px solid var(--bad);border-radius:10px;color:var(--bad)}.cam-readout{width:100%;display:flex;flex-direction:column;gap:.4rem}.cam-readout.small .bar-label{width:3.5rem}.bar{display:grid;grid-template-columns:4.5rem 1fr 3rem;gap:.6rem;align-items:center;font-size:.85rem}.bar-label{color:var(--fg-dim);font-weight:500}.bar-track{height:8px;background:var(--bg-elev-2);border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:var(--fg-dim);transition:width .12s ease}.bar-pct{color:var(--fg-dim);font-variant-numeric:tabular-nums}.bar-hot .bar-fill{background:var(--good)}.bar-hot .bar-label,.bar-hot .bar-pct{color:var(--good)}.hint{margin:0;padding:.6rem .8rem;background:#fbbf241a;color:var(--warn);border-radius:8px;font-size:.9rem}.meter{display:flex;flex-direction:column;gap:.45rem;width:100%}.meter-head{display:flex;justify-content:space-between;align-items:baseline;font-size:.9rem;color:var(--fg-dim)}.meter-label b{color:var(--fg);margin-left:.15rem}.meter-bucket{font-weight:700;letter-spacing:.02em;transition:color .25s ease}.meter-track{position:relative;height:14px;background:var(--bg-elev-2);border-radius:999px;overflow:hidden}.meter-fill{position:absolute;inset:0 auto 0 0;border-radius:999px;transition:width .18s ease-out,background-color .25s ease,background .25s ease}.meter-hold{position:absolute;inset:0 auto 0 0;background:#ffffff8c;mix-blend-mode:overlay;border-radius:999px;transition:width .06s linear}.meter-status{min-height:1.2em;font-size:.85rem;color:var(--fg-dim);transition:color .2s ease}.meter-locked .meter-status{color:var(--good)}.flash-good{background-color:#4ade802e}.challenge{min-height:100vh;min-height:100dvh;padding:1rem clamp(1rem,3vw,2rem);display:flex;flex-direction:column;gap:1rem;transition:background-color .2s ease}.challenge-bar{display:flex;align-items:center;gap:1rem}.challenge-timer{margin-left:auto;font-size:1.6rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--accent)}.challenge-timer[data-low=true]{color:var(--bad)}.challenge-score{font-size:1.1rem;color:var(--fg-dim)}.challenge-score b{color:var(--fg);margin-left:.3rem}.challenge-stage{flex:1;display:grid;grid-template-columns:1fr minmax(280px,380px);gap:1.5rem;align-items:stretch}.big-target{background:var(--bg-elev);border:1px solid #243155;border-radius:var(--radius);font-size:clamp(8rem,30vw,22rem);font-weight:700;letter-spacing:-.05em;display:flex;align-items:center;justify-content:center}.cam-tile{background:var(--bg-elev);border:1px solid #243155;border-radius:var(--radius);padding:1rem;display:flex;flex-direction:column;gap:.8rem}.results{max-width:600px;margin:0 auto;padding:clamp(2rem,8vh,6rem) 1.5rem;text-align:center}.results h1{font-size:clamp(1.8rem,5vw,2.6rem);margin:0 0 1.5rem}.stats{list-style:none;padding:0;margin:0 0 2rem;display:grid;gap:.75rem}.stats li{display:flex;justify-content:space-between;background:var(--bg-elev);border:1px solid #243155;padding:.9rem 1.2rem;border-radius:10px;font-size:1.05rem}.stats li span{color:var(--fg-dim)}.results-actions{display:flex;justify-content:center;gap:1rem;align-items:center}.debug{position:fixed;bottom:1rem;right:1rem;width:min(560px,calc(100vw - 2rem));background:#0b1120f5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #2a3a66;border-radius:var(--radius);padding:.9rem 1rem 1rem;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:.8rem;z-index:100;box-shadow:0 12px 40px #00000080}.debug-bar{display:flex;align-items:center;gap:.6rem;margin-bottom:.7rem}.debug-title{font-weight:600;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;font-size:.7rem}.debug-hint{color:var(--fg-dim);font-size:.7rem}.debug-close{margin-left:auto;font-size:1.2rem;padding:0 .4rem}.debug-body{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start}.debug-thumb{display:flex;flex-direction:column;gap:.4rem;align-items:center}.debug-thumb canvas{width:192px;height:192px;border:1px solid #2a3a66;border-radius:6px;image-rendering:pixelated;background:#000}.debug-caption{color:var(--fg-dim);font-size:.7rem}.debug-cols{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;min-width:0}.debug-col{display:flex;flex-direction:column;gap:.25rem;min-width:0}.debug-col-title{color:var(--fg-dim);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.2rem}.debug-row{display:grid;grid-template-columns:3rem 1fr 3rem;gap:.4rem;align-items:center}.debug-row-label{color:var(--fg)}.debug-row-bar{height:6px;background:var(--bg-elev-2);border-radius:999px;overflow:hidden}.debug-row-fill{display:block;height:100%;background:var(--accent);transition:width .1s ease}.debug-row-pct{color:var(--fg-dim);font-variant-numeric:tabular-nums;text-align:right}@media (max-width: 640px){.debug-body{grid-template-columns:1fr}.debug-thumb canvas{width:144px;height:144px}}@media (max-width: 760px){.lesson,.challenge{padding:.75rem;gap:.6rem}.lesson-grid{grid-template-columns:1fr;gap:.6rem}.cam-card{order:1;padding:.8rem;gap:.6rem}.target-card{order:2;flex-direction:row;align-items:center;flex-wrap:wrap;padding:.75rem .9rem;gap:.9rem}.target-eyebrow{display:none}.target-letter{font-size:3.5rem;line-height:1}.target-ref{max-width:84px;margin-left:auto;padding:.3rem}.skip{flex-basis:100%;text-align:right;margin-top:0;padding:.2rem 0}.lesson-bar{flex-wrap:wrap;gap:.5rem;row-gap:.4rem}.lesson-stats{font-size:.85rem;gap:.6rem}.dots{order:5;flex-basis:100%;gap:3px}.dot{width:18px;height:18px;font-size:.6rem;border-radius:4px}.challenge-stage{grid-template-columns:1fr;gap:.6rem}.cam-tile{order:1;padding:.75rem;gap:.6rem}.big-target{order:2;font-size:clamp(4rem,22vw,8rem);padding:.6rem;min-height:7rem}.challenge-bar{flex-wrap:wrap;gap:.5rem;row-gap:.3rem}.challenge-timer{font-size:1.3rem}.challenge-score{font-size:.95rem}.meter-head{font-size:.85rem}.meter-status{font-size:.8rem}.crop-label{bottom:-1.3rem;font-size:.65rem}.crop-corner{width:18px;height:18px;border-width:2px}}.fatal{max-width:500px;margin:4rem auto;padding:2rem;text-align:center}
