:root{--bg: #0e1117;--panel: #161b22;--accent: #00e6a0;--accent-2: #ff465a;--text: #e6edf3;--muted: #8b949e}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#000;color:var(--text)}.app{position:relative;width:100vw;height:100dvh;overflow:hidden;background:#000}.camera-view{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.video-wrap{position:absolute;top:0;right:0;bottom:0;left:0}.video,.overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.video{object-fit:cover;transform:scaleX(-1)}.overlay{pointer-events:none}.loading,.error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;color:var(--muted)}.error{color:var(--accent-2)}.hud{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;display:flex;flex-direction:column;justify-content:space-between;padding:max(16px,env(safe-area-inset-top)) 16px calc(72px + env(safe-area-inset-bottom));pointer-events:none}.hud-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.brand{margin:0;font-size:20px;letter-spacing:-.5px;text-shadow:0 1px 4px rgba(0,0,0,.6)}.brand .dot{color:var(--accent)}.status{display:flex;align-items:center;gap:8px;font-size:13px;text-transform:capitalize;color:var(--text);background:#0006;padding:6px 10px;border-radius:999px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.status .dotled{width:9px;height:9px;border-radius:50%;background:var(--muted)}.status-connected .dotled{background:var(--accent)}.status-error .dotled,.status-disconnected .dotled{background:var(--accent-2)}.fps{color:var(--muted)}.prediction{align-self:flex-start;display:flex;flex-direction:column;gap:6px;max-width:min(420px,80vw);padding:14px 16px;border-radius:14px;background:#0000006b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:2px solid transparent;transition:border-color .15s ease}.pose-label{font-size:clamp(28px,9vw,48px);font-weight:700;text-transform:capitalize;line-height:1.05;transition:color .15s ease}.confidence{display:flex;align-items:center;gap:10px}.confidence-bar{flex:1;height:8px;background:#ffffff2e;border-radius:4px;overflow:hidden}.confidence-fill{height:100%;background:var(--accent);transition:width .15s ease}.confidence-num{font-variant-numeric:tabular-nums;width:42px;text-align:right}.matched-badge{display:none;align-self:flex-start;margin-top:2px;font-size:13px;font-weight:600;color:#04150f;background:var(--accent);padding:3px 10px;border-radius:999px}.app.matched .matched-badge{display:inline-block}.app.matched .pose-label{color:var(--accent)}.app.matched .prediction{border-color:var(--accent)}.app.matched .video-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;box-shadow:inset 0 0 0 4px var(--accent)}.capture-flash{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:var(--accent);opacity:0}.app.flash .capture-flash{animation:capture-flash .45s ease}@keyframes capture-flash{0%{opacity:0}25%{opacity:.45}to{opacity:0}}.tabbar{position:absolute;left:0;right:0;bottom:0;z-index:20;display:flex;background:#0d1117eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid #21262d;padding-bottom:env(safe-area-inset-bottom)}.tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;font:inherit;font-size:15px;font-weight:600;color:var(--muted);background:none;border:none;padding:16px 0;cursor:pointer}.tab.active{color:var(--accent);box-shadow:inset 0 2px 0 var(--accent)}.tab .count{min-width:20px;padding:0 6px;font-size:12px;font-weight:700;line-height:20px;text-align:center;color:#04150f;background:var(--accent);border-radius:999px}.photos-view{position:absolute;top:0;right:0;bottom:56px;left:0;z-index:5;overflow-y:auto;background:var(--bg);padding:max(16px,env(safe-area-inset-top)) 16px 16px}.photos-header{display:flex;align-items:center;justify-content:space-between;margin:0 0 14px}.photos-header h2{margin:0;font-size:22px}.photos-empty{color:var(--muted);font-size:14px;line-height:1.5;padding:32px 8px;text-align:center}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}.thumb{position:relative;width:100%;aspect-ratio:3 / 4;padding:0;border:3px solid var(--accent);border-radius:10px;overflow:hidden;background:#000;cursor:pointer;box-shadow:0 2px 8px #00000080}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.thumb:before{content:"✓";position:absolute;top:3px;right:5px;font-size:14px;font-weight:700;color:var(--accent);text-shadow:0 1px 3px rgba(0,0,0,.9)}.thumb-label{position:absolute;left:0;right:0;bottom:0;font-size:11px;text-transform:capitalize;text-align:center;color:var(--text);background:#0000008c;padding:2px 0}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:20px;background:#000000e6}.lightbox img{max-width:100%;max-height:78vh;border-radius:10px;border:3px solid var(--accent)}.lightbox-bar{display:flex;align-items:center;gap:12px}.lightbox-label{text-transform:capitalize;font-weight:600;color:var(--accent)}.btn{font:inherit;font-size:15px;color:var(--text);text-decoration:none;background:var(--panel);border:1px solid #30363d;padding:8px 18px;border-radius:8px;cursor:pointer}.btn:hover{border-color:var(--accent)}.btn-danger{color:var(--accent-2)}.btn-danger:hover{border-color:var(--accent-2)}.hud-stack-top{display:flex;flex-direction:column;gap:12px}.hud-actions{display:flex;align-items:center;gap:8px}.pill-btn{pointer-events:auto;font:inherit;font-size:13px;font-weight:600;color:var(--text);background:#0006;border:1px solid rgba(255,255,255,.15);padding:6px 12px;border-radius:999px;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pill-btn:hover{border-color:var(--accent)}.candidates{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;pointer-events:auto}.candidates::-webkit-scrollbar{display:none}.candidate{flex:0 0 auto;width:60px;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px 4px;border:2px solid transparent;border-radius:10px;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;color:var(--muted)}.candidate .pose-skeleton{width:100%;height:42px;color:var(--muted)}.candidate-name{font-size:10px;text-transform:capitalize;color:var(--muted)}.candidate.current{border-color:#ffffff80}.candidate.current .pose-skeleton,.candidate.current .candidate-name{color:var(--text)}.candidate.matched{border-color:var(--accent)}.candidate.matched .pose-skeleton,.candidate.matched .candidate-name{color:var(--accent)}.hud-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.ctrl-btn{pointer-events:auto;font:inherit;font-size:14px;font-weight:600;color:var(--text);background:#00000080;border:1px solid rgba(255,255,255,.2);padding:10px 16px;border-radius:999px;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.ctrl-btn:hover{border-color:var(--accent)}.start-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:24px;background:#00000059}.start-btn{font:inherit;font-size:18px;font-weight:700;color:#04150f;background:var(--accent);border:none;padding:16px 30px;border-radius:999px;cursor:pointer;box-shadow:0 6px 20px #0006}.start-hint{margin:0;max-width:280px;text-align:center;font-size:13px;color:var(--text);text-shadow:0 1px 4px rgba(0,0,0,.8)}.sheet{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:flex;align-items:flex-end;justify-content:center;background:#0009}.sheet-panel{width:100%;max-width:560px;max-height:85dvh;overflow-y:auto;background:var(--bg);border-radius:16px 16px 0 0;border-top:1px solid #21262d;padding:18px 18px calc(18px + env(safe-area-inset-bottom))}.sheet-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sheet-head h2{margin:0;font-size:20px}.pose-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}.pose-ref{display:flex;gap:14px;align-items:flex-start}.pose-ref-skel{flex:0 0 auto;width:64px;height:84px;color:var(--accent);background:var(--panel);border-radius:10px;padding:4px}.pose-ref-name{font-size:16px;font-weight:700;text-transform:capitalize}.pose-ref-sanskrit{margin-left:8px;font-size:13px;font-weight:500;font-style:italic;color:var(--accent)}.pose-ref-desc{margin:4px 0 0;font-size:13px;line-height:1.5;color:var(--muted)}
