.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;width:100%;max-width:1320px;margin:0 auto;padding:24px clamp(16px,4vw,40px) 48px}.app-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,1fr);gap:24px;align-items:start}.app-camera,.app-panel{min-width:0}@media (max-width: 960px){.app-grid{grid-template-columns:1fr}}.app-footer{display:flex;align-items:center;justify-content:center;gap:12px;padding:24px 16px;color:var(--text-faint);font-size:13px;border-top:1px solid var(--border)}.app-footer .dot{width:4px;height:4px;border-radius:50%;background:var(--text-faint);display:inline-block}.header{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg-0) 85%,transparent);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--border)}.header-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;width:100%;max-width:1320px;margin:0 auto;padding:16px clamp(16px,4vw,40px)}.brand{display:flex;align-items:center;gap:14px}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,var(--accent-alt),var(--accent));box-shadow:var(--shadow-sm)}.brand-text{display:flex;flex-direction:column}.brand-name{font-size:20px;letter-spacing:-.02em}.brand-tag{color:var(--text-muted);font-size:12px;margin-top:2px}.mode-tabs{display:flex;justify-content:center;gap:4px;padding:4px;background:var(--surface);border:1px solid var(--border);border-radius:999px;width:fit-content;margin:0 auto}.mode-tab{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;color:var(--text-muted);font-size:14px;font-weight:500;transition:background .16s ease,color .16s ease}.mode-tab:hover{color:var(--text)}.mode-tab.is-active{background:linear-gradient(135deg,var(--accent-alt),var(--accent));color:#fff;box-shadow:var(--shadow-sm)}.mode-icon{width:18px;height:18px;display:inline-flex}.theme-toggle{width:40px;height:40px;border-radius:12px;background:var(--surface);border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;transition:background .16s ease,transform .16s ease}.theme-toggle:hover{background:var(--surface-strong);transform:translateY(-1px)}@media (max-width: 720px){.header-inner{grid-template-columns:1fr auto;grid-template-rows:auto auto;row-gap:12px}.mode-tabs{grid-column:1 / -1;width:100%;justify-content:stretch}.mode-tab{flex:1;justify-content:center}.brand-tag{display:none}}.sign-icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;color:var(--accent)}.sign-icon svg{width:100%;height:100%;overflow:visible}.sign-icon-sm{width:18px;height:18px}.sign-icon-md{width:32px;height:32px}.sign-icon-lg{width:62px;height:62px}.icon-bg{fill:color-mix(in srgb,var(--accent-alt) 14%,transparent);stroke:color-mix(in srgb,var(--accent) 42%,transparent);stroke-width:1.5}.icon-line,.icon-sweep{fill:none;stroke:currentColor;stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round}.icon-sweep{stroke-width:2.5;opacity:.65}.icon-dot,.icon-fill{fill:currentColor}.icon-letter{fill:currentColor;font:700 24px var(--font-sans)}.jc-logo-bg{fill:url(#jcLogoGradient)}.jc-logo-text{fill:#fff;font:800 22px var(--font-sans);letter-spacing:-.06em}.jc-logo-ring{fill:none;stroke:#ffffffb8;stroke-width:2.5;stroke-linecap:round;stroke-dasharray:38 18;transform-origin:32px 32px;animation:jcLogoSpin 6s linear infinite}.brand-mark .sign-icon,.mode-tab.is-active .sign-icon,.btn-primary .sign-icon{color:#fff}.theme-toggle .sign-icon,.btn .sign-icon{color:currentColor}.icon-pulse{transform-origin:32px 32px;animation:iconPulse 2.4s ease-in-out infinite}.icon-wave{animation:iconWave 2.6s ease-in-out infinite}.icon-swing{transform-origin:32px 32px;animation:iconSwing 2.8s ease-in-out infinite}.icon-float-left{animation:iconFloatLeft 2.6s ease-in-out infinite}.icon-float-right{animation:iconFloatRight 2.6s ease-in-out infinite}@keyframes iconPulse{0%,to{opacity:.78;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes iconWave{0%,to{transform:translate(0)}50%{transform:translate(2px)}}@keyframes iconSwing{0%,to{transform:rotate(0)}50%{transform:rotate(4deg)}}@keyframes iconFloatLeft{0%,to{transform:translate(0)}50%{transform:translate(-2px)}}@keyframes iconFloatRight{0%,to{transform:translate(0)}50%{transform:translate(2px)}}@keyframes jcLogoSpin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.icon-pulse,.icon-wave,.icon-swing,.icon-float-left,.icon-float-right,.jc-logo-ring{animation:none}}.camera-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-md)}.camera-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.camera-title{display:flex;align-items:center;gap:12px}.camera-title h2{font-size:18px}.status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;background:var(--surface);border:1px solid var(--border);color:var(--text-muted)}.status .status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-faint)}.status.live{color:var(--success);background:color-mix(in srgb,var(--success) 12%,transparent);border-color:color-mix(in srgb,var(--success) 30%,transparent)}.status.live .status-dot{background:var(--success);box-shadow:0 0 0 4px color-mix(in srgb,var(--success) 24%,transparent);animation:pulse 1.6s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 4px color-mix(in srgb,var(--success) 24%,transparent)}50%{box-shadow:0 0 0 8px color-mix(in srgb,var(--success) 6%,transparent)}}.tracking-counts{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px}.tracking-counts span{font-size:12px;font-weight:500;color:var(--text-muted);padding:4px 10px;border-radius:999px;background:var(--surface);border:1px solid var(--border)}.camera-stage{position:relative;border-radius:var(--radius-md);overflow:hidden;background:#000;aspect-ratio:4 / 3}.camera-video,.camera-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.camera-canvas{pointer-events:none}.camera-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;gap:8px;background:radial-gradient(circle at 50% 40%,var(--accent-soft),transparent 60%),var(--bg-2);color:var(--text)}.placeholder-icon{width:68px;height:68px;color:var(--accent);margin-bottom:4px}.camera-placeholder p{color:var(--text-muted);max-width:320px;font-size:14px}.camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:24px;background:#0000008c;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.camera-overlay.error{background:#f87171d9}.overlay-hint{font-size:12px;color:#ffffffb3}.overlay-icon{font-size:28px}.spinner{width:36px;height:36px;border-radius:50%;border:3px solid rgba(255,255,255,.25);border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.live-badge{position:absolute;bottom:14px;left:50%;transform:translate(-50%);display:inline-flex;align-items:center;gap:12px;padding:10px 18px;border-radius:999px;background:#0f1020b3;color:#fff;font-size:15px;border:1px solid rgba(255,255,255,.16);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.live-badge-label{font-weight:600;letter-spacing:.01em}.live-badge-confidence{font-size:12px;color:#ffffffb3;padding:2px 8px;border-radius:999px;background:#ffffff1a}.camera-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:12px;font-weight:600;font-size:14px;border:1px solid transparent;transition:background .16s ease,transform .12s ease,border-color .16s ease}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 8px 22px color-mix(in srgb,var(--accent) 40%,transparent)}.btn-primary:hover:not(:disabled){background:var(--accent-strong)}.btn-secondary{background:var(--surface);border-color:var(--border-strong);color:var(--text)}.btn-secondary:hover:not(:disabled){background:var(--surface-strong)}.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface);color:var(--text)}.camera-hint{flex:1;min-width:220px;font-size:12px;color:var(--text-muted)}.panel{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:18px}.panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.panel-head h2{font-size:18px}.panel-sub{margin-top:4px;color:var(--text-muted);font-size:13px;max-width:38ch}.now-pill{display:flex;flex-direction:column;align-items:flex-end;padding:8px 14px;border-radius:12px;background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);text-align:right;min-width:110px}.now-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.now-pill strong{font-size:16px;color:var(--text)}.script-box{min-height:140px;padding:18px 20px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);font-size:22px;font-weight:500;letter-spacing:.02em;line-height:1.4;color:var(--text);word-break:break-word}.script-text{white-space:pre-wrap}.script-empty{color:var(--text-muted);font-size:15px;font-weight:400;letter-spacing:0}.action-row{display:flex;flex-wrap:wrap;gap:8px}.auto-speak{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);-webkit-user-select:none;user-select:none}.auto-speak input{accent-color:var(--accent)}.recent-row{display:flex;align-items:center;gap:12px;border-top:1px dashed var(--border);padding-top:14px;flex-wrap:wrap}.recent-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint)}.recent-list{list-style:none;margin:0;padding:0;display:flex;gap:6px;flex-wrap:wrap}.recent-pill{padding:4px 10px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:12px;font-weight:500}.recent-empty{font-size:12px;color:var(--text-faint)}.practice-panel{transition:border-color .2s ease}.practice-panel.correct{border-color:color-mix(in srgb,var(--success) 60%,transparent)}.practice-panel.hold{border-color:color-mix(in srgb,var(--warning) 60%,transparent)}.score-block{display:flex;gap:16px}.score-block>div{display:flex;flex-direction:column;align-items:flex-end}.score-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint)}.score-block strong{font-size:22px;letter-spacing:-.02em}.set-picker{display:flex;flex-wrap:wrap;gap:6px}.set-chip{padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:12px;font-weight:500;transition:background .16s ease,color .16s ease,border-color .16s ease}.set-chip:hover{color:var(--text)}.set-chip.is-active{background:var(--accent);color:#fff;border-color:transparent}.target-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;padding:18px 22px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);transition:background .24s ease,border-color .24s ease,transform .24s ease}.target-card.target-correct{background:color-mix(in srgb,var(--success) 14%,transparent);border-color:color-mix(in srgb,var(--success) 50%,transparent);transform:translateY(-1px)}.target-card.target-hold{background:color-mix(in srgb,var(--warning) 12%,transparent);border-color:color-mix(in srgb,var(--warning) 40%,transparent)}.target-icon{width:72px;height:72px;display:inline-flex;align-items:center;justify-content:center}.target-body{min-width:0}.target-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint)}.target-sign{font-size:36px;letter-spacing:-.02em;margin:2px 0 6px}.target-desc{font-size:13px;color:var(--text-muted)}.feedback{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;background:var(--surface-strong);color:var(--text-muted);border:1px solid var(--border)}.feedback.ok{background:var(--success);color:#06281a;border-color:transparent}.feedback.hold{background:var(--warning);color:#2b1d04;border-color:transparent}.feedback.off{background:transparent;color:var(--text-faint)}.practice-controls{display:flex;gap:8px}@media (max-width: 540px){.target-card{grid-template-columns:auto 1fr}.target-card .feedback{grid-column:1 / -1;justify-self:start}}.learn-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between}.search-input{flex:1 1 220px;padding:10px 14px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:14px;outline:none;transition:border-color .16s ease,background .16s ease}.search-input::placeholder{color:var(--text-faint)}.search-input:focus{border-color:var(--accent);background:var(--surface-strong)}.cat-pills{display:flex;gap:6px;flex-wrap:wrap}.cat-pill{padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:12px;font-weight:500;transition:background .16s ease,color .16s ease}.cat-pill:hover{color:var(--text)}.cat-pill.is-active{background:var(--accent);color:#fff;border-color:transparent}.sign-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.sign-card{padding:14px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;gap:8px;transition:transform .16s ease,border-color .16s ease}.sign-card:hover{border-color:var(--border-strong);transform:translateY(-1px)}.sign-card-head{display:flex;align-items:center;gap:12px}.sign-card-icon{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center}.sign-card-name{font-size:18px;letter-spacing:-.01em}.sign-card-cat{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint)}.sign-card-desc{font-size:13px;color:var(--text)}.sign-card-example{font-size:12px;color:var(--text-muted);font-style:italic}.sign-empty{grid-column:1 / -1;padding:24px;text-align:center;color:var(--text-muted);font-size:14px;background:var(--surface);border-radius:var(--radius-md);border:1px dashed var(--border)}.learn-footnote{font-size:12px;color:var(--text-faint);padding:12px 14px;border-radius:12px;background:var(--surface);border:1px dashed var(--border);line-height:1.5}:root{--bg-0: #05060b;--bg-1: #0d1020;--bg-2: #15112a;--surface: rgba(255, 255, 255, .04);--surface-strong: rgba(255, 255, 255, .08);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--text: #effcff;--text-muted: #a5b4d6;--text-faint: #727d9f;--accent: #7c3aed;--accent-strong: #14b8a6;--accent-soft: rgba(124, 58, 237, .16);--accent-alt: #14b8a6;--success: #34d399;--warning: #fbbf24;--danger: #f87171;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 22px;--shadow-sm: 0 4px 12px rgba(0, 0, 0, .18);--shadow-md: 0 12px 32px rgba(0, 0, 0, .28);--shadow-lg: 0 24px 60px rgba(0, 0, 0, .4);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", Menlo, Monaco, Consolas, "Courier New", monospace;color-scheme:dark}[data-theme=light]{--bg-0: #f2fbfb;--bg-1: #ffffff;--bg-2: #e7f3ff;--surface: rgba(15, 23, 42, .04);--surface-strong: rgba(15, 23, 42, .08);--border: rgba(15, 23, 42, .08);--border-strong: rgba(15, 23, 42, .18);--text: #102033;--text-muted: #3f6470;--text-faint: #7ca0aa;--accent: #6d28d9;--accent-strong: #0f9f92;--accent-soft: rgba(20, 184, 166, .14);--accent-alt: #0f9f92;color-scheme:light}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:var(--font-sans);font-size:15px;line-height:1.5;color:var(--text);background:radial-gradient(circle at 12% 0%,rgba(124,58,237,.2) 0%,transparent 46%),radial-gradient(circle at 88% 100%,rgba(20,184,166,.14) 0%,transparent 42%),var(--bg-0);background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;font-size:inherit;cursor:pointer;border:0;background:none;color:inherit}button:disabled{cursor:not-allowed;opacity:.5}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;letter-spacing:-.01em}p{margin:0}code,pre{font-family:var(--font-mono)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-strong);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .22s ease-out both}
