:root{--bg: #0a0e1a;--bg-elev: #131a2c;--bg-elev-2: #1c2540;--surface: rgba(19, 26, 44, .7);--border: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .12);--fg: #e8eef9;--fg-dim: #98a3b8;--fg-muted: #6b7691;--accent: #7cc4ff;--accent-strong: #3aa3ff;--accent-soft: rgba(124, 196, 255, .12);--accent-glow: rgba(58, 163, 255, .25);--good: #4ade80;--warn: #fbbf24;--bad: #f87171;--radius: 14px;--radius-lg: 20px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 8px 24px rgba(0, 0, 0, .25);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .45);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,system-ui,sans-serif;font-feature-settings:"cv11","ss01"}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:radial-gradient(ellipse 70% 80% at 80% -10%,rgba(58,163,255,.1) 0%,transparent 55%),radial-gradient(ellipse 60% 60% at 0% 100%,rgba(124,196,255,.05) 0%,transparent 50%),var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;overflow-x:hidden}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}button{font:inherit;color:inherit;cursor:pointer;border:none;background:var(--accent-strong);color:#04111e;padding:.7rem 1.3rem;border-radius:var(--radius);font-weight:600;letter-spacing:-.005em;transition:transform .06s ease,background .2s ease,opacity .2s ease,box-shadow .2s ease;box-shadow:0 4px 14px #3aa3ff33}button:hover:not(:disabled){background:var(--accent);box-shadow:0 6px 20px #7cc4ff4d}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}button.link{background:transparent;color:var(--fg-dim);padding:.4rem .6rem;font-weight:500;box-shadow:none}button.link:hover{color:var(--fg);background:transparent;box-shadow:none}.menu{max-width:720px;margin:0 auto;padding:clamp(3rem,12vh,7rem) 1.5rem;display:flex;flex-direction:column;align-items:center;text-align:center}.menu-logo{display:flex;align-items:center;justify-content:center;gap:.7rem;margin-bottom:2.5rem}.menu-logo-mark{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-strong) 100%);display:flex;align-items:center;justify-content:center;color:#061122;box-shadow:0 8px 24px var(--accent-glow)}.menu-logo-mark svg{width:24px;height:24px}.menu-logo-text{font-size:1.05rem;font-weight:600;letter-spacing:-.005em;color:var(--fg)}.menu-header h1{font-size:clamp(2.2rem,5vw,3rem);margin:0 0 .7rem;letter-spacing:-.025em;font-weight:700;background:linear-gradient(180deg,var(--fg) 0%,#c2cee0 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.menu-header p{color:var(--fg-dim);max-width:48ch;line-height:1.6;margin:0 auto;font-size:1.05rem}.menu-cards{display:grid;grid-template-columns:1fr;gap:1rem;margin:3rem 0 2rem;width:100%;max-width:420px}.card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;background:var(--bg-elev);color:var(--fg);padding:1.5rem 1.6rem 1.7rem;border:1px solid var(--border);border-radius:var(--radius-lg);gap:.5rem;transition:border-color .2s ease,transform .15s ease,background .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-sm)}.card:hover:not(:disabled){border-color:var(--border-strong);background:var(--bg-elev-2);transform:translateY(-2px);box-shadow:var(--shadow-md)}.card-eyebrow{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}.card-title{font-size:1.4rem;font-weight:600;letter-spacing:-.01em}.card-desc{color:var(--fg-dim);font-size:.95rem;line-height:1.5}.menu-footer{margin-top:1rem;min-height:32px}.loading{display:inline-flex;align-items:center;gap:.7rem;font-size:.85rem;color:var(--fg-dim);padding:.45rem 1rem .45rem .85rem;background:var(--bg-elev);border-radius:var(--radius-pill);border:1px solid var(--border)}.loading-dots{display:inline-flex;align-items:center;gap:4px}.loading-dots span{width:6px;height:6px;background:var(--accent);border-radius:50%;animation:pulse-dot 1.3s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.18s}.loading-dots span:nth-child(3){animation-delay:.36s}@keyframes pulse-dot{0%,70%,to{opacity:.3;transform:scale(.85)}35%{opacity:1;transform:scale(1)}}.status-ok{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--good);padding:.45rem 1rem .45rem .85rem;background:#4ade8014;border-radius:var(--radius-pill);border:1px solid rgba(74,222,128,.18)}.status-ok:before{content:"";width:6px;height:6px;background:var(--good);border-radius:50%;box-shadow:0 0 10px 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;padding:0;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;border:1px solid var(--border);box-shadow:none}.dot-done{background:var(--good);color:#04111e;border-color:transparent}.dot-current{background:var(--accent-strong);color:#04111e;border-color:transparent;box-shadow:0 0 0 3px var(--accent-soft)}.dot-clickable{cursor:pointer;transition:transform .12s ease,background .18s ease,color .18s ease,border-color .18s ease}.dot-clickable:hover{transform:scale(1.12);background:var(--bg-elev-2);color:var(--fg);border-color:var(--border-strong)}.dot-clickable.dot-done:hover{filter:brightness(1.1);background:var(--good);color:#04111e}.dot-clickable.dot-current,.dot-clickable.dot-current:hover{cursor:default;transform:scale(1);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 var(--border);border-radius:var(--radius-lg);padding:1.5rem;display:flex;flex-direction:column;gap:1rem;align-items:flex-start;box-shadow:var(--shadow-sm)}.target-eyebrow{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:600}.target-letter{font-size:clamp(6rem,18vw,12rem);font-weight:700;line-height:.9;letter-spacing:-.05em;background:linear-gradient(180deg,var(--fg) 0%,#b1bccd 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.target-ref{width:100%;max-width:220px;aspect-ratio:322 / 424;object-fit:contain;background:#f5f7fb;border-radius:var(--radius);border:1px solid var(--border);padding:.6rem;animation:fade-in .3s ease}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.reveal-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--accent-soft);color:var(--accent);border:1px solid rgba(124,196,255,.22);border-radius:var(--radius-pill);font-size:.85rem;font-weight:500;letter-spacing:-.005em;cursor:pointer;transition:background .18s ease,border-color .18s ease,color .18s ease;box-shadow:none}.reveal-btn:hover{background:#7cc4ff2e;border-color:#7cc4ff66;color:var(--fg)}.reveal-btn svg{width:14px;height:14px}.skip{margin-top:auto}.cam-card{gap:.8rem}.webcam-wrap{position:relative;width:100%;aspect-ratio:4/3;background:#000;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.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:var(--radius);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}.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;letter-spacing:-.025em;background:linear-gradient(180deg,var(--fg) 0%,#c2cee0 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.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 var(--border);padding:.95rem 1.2rem;border-radius:var(--radius);font-size:1.05rem;box-shadow:var(--shadow-sm)}.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 var(--border-strong);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:var(--shadow-lg)}.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 var(--border-strong);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{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:.85rem 1rem;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}.reveal-btn{margin-left:auto}.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}.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}
