*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-panel: #ffffff;--bg-video: #e8e8e8;--text-primary: #1a1a1a;--text-secondary: #666666;--text-muted: #888888;--border-color: #e0e0e0;--border-dark: #cccccc;--shadow-color: rgba(0, 0, 0, .1);--overlay-bg: rgba(255, 255, 255, .95);--btn-secondary-bg: #e8e8e8;--btn-secondary-text: #1a1a1a;--audio-panel-bg: #f0f0f0;--model-panel-bg: #f8f8f8;--progress-bar-bg: #e0e0e0;--consent-bg: linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,245,245,.98));--consent-section-bg: rgba(0, 0, 0, .02);--consent-section-border: #e0e0e0;--sticky-bar-bg: #f5f5f5;--consent-card-bg: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,248,248,.98));--consent-overlay-bg: radial-gradient(circle at top, rgba(13, 122, 62, .08), transparent 35%), rgba(245, 245, 245, .95);--header-gradient: none;--btn-primary-bg: linear-gradient(90deg, #0d7a3e, #1a9e52);--btn-primary-shadow: rgba(13, 122, 62, .3);--slider-track-bg: #d0d0d0;--slider-thumb-bg: #0d7a3e;--onboarding-bg: linear-gradient(180deg, rgba(245,245,245,.95), rgba(240,240,240,.98));--onboarding-border: rgba(0,0,0,.08)}body.dark-theme{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-panel: #1a1a1a;--bg-video: #111111;--text-primary: #e5e5e5;--text-secondary: #aaaaaa;--text-muted: #888888;--border-color: #333333;--border-dark: #555555;--shadow-color: rgba(0, 0, 0, .4);--overlay-bg: rgba(15, 15, 15, .95);--btn-secondary-bg: #2a2a2a;--btn-secondary-text: #e5e5e5;--audio-panel-bg: #1a1a1a;--model-panel-bg: #1a1a1a;--progress-bar-bg: #333333;--consent-bg: linear-gradient(180deg, rgba(28,28,28,.98), rgba(18,18,18,.98));--consent-section-bg: rgba(255, 255, 255, .03);--consent-section-border: #2d2d2d;--sticky-bar-bg: #0f0f0f;--consent-card-bg: linear-gradient(180deg, rgba(28,28,28,.98), rgba(18,18,18,.98));--consent-overlay-bg: radial-gradient(circle at top, rgba(13, 122, 62, .12), transparent 35%), rgba(10, 10, 10, .92);--header-gradient: none;--btn-primary-bg: linear-gradient(90deg, #0d7a3e, #1a9e52);--btn-primary-shadow: rgba(13, 122, 62, .3);--slider-track-bg: #333;--slider-thumb-bg: #0d7a3e;--onboarding-bg: linear-gradient(180deg, rgba(15,15,15,.85), rgba(10,10,10,.98));--onboarding-border: rgba(255,255,255,.08)}body{background:var(--bg-primary);color:var(--text-primary);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;min-height:100vh;padding:1rem}.app{max-width:1000px;margin:0 auto;display:flex;flex-direction:column;min-height:calc(100vh - 2rem)}.app-header{text-align:center;padding:1rem 1rem .5rem;position:relative}.header-content{display:flex;align-items:center;justify-content:center;gap:12px}.header-logo{flex-shrink:0;width:48px;height:48px}.header-text{text-align:center}.header-text h1{font-size:1.8rem;font-weight:700;color:#0d7a3e;margin-bottom:.25rem}.app-subtitle{font-size:.95rem;color:var(--text-secondary)}.theme-toggle{position:absolute;top:50%;right:1rem;transform:translateY(-50%);background:var(--bg-panel);border:1px solid var(--border-color);border-radius:8px;padding:8px;cursor:pointer;color:var(--text-primary);transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.theme-toggle:hover{background:var(--bg-secondary);border-color:var(--border-dark)}.theme-icon-sun{display:none}.theme-icon-moon,body.dark-theme .theme-icon-sun{display:block}body.dark-theme .theme-icon-moon{display:none}.sticky-bar{position:sticky;top:0;z-index:50;background:var(--sticky-bar-bg);padding:.75rem 0;display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem}.sticky-bar .controls,.sticky-bar .model-panel,.sticky-bar .calibration-panel{background:var(--bg-panel);border-radius:8px;padding:.5rem .75rem;border:1px solid var(--border-color);margin:0;flex-shrink:0}.sticky-bar .controls{display:flex;align-items:center;gap:.5rem}.sticky-bar .button-group{display:flex;gap:.5rem}.sticky-bar .model-panel{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap}.sticky-bar .model-status{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.sticky-bar .model-progress{display:flex;align-items:center;gap:.3rem;min-width:80px}.sticky-bar .progress-bar{width:50px;height:6px;background:var(--progress-bar-bg);border-radius:3px;overflow:hidden}.sticky-bar .progress-fill{height:100%;background:var(--btn-primary-bg);border-radius:3px;transition:width .3s}.sticky-bar .progress-text{font-size:.75rem;color:var(--text-muted);min-width:28px}.sticky-bar .calibration-panel{display:flex;align-items:center;gap:.5rem}.sticky-bar .calibration-status{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.sticky-bar .audio-panel{display:flex;align-items:center;gap:.5rem;background:var(--audio-panel-bg);border-radius:8px;padding:.5rem .75rem;border:1px solid var(--border-color);margin:0;flex-shrink:0}.sticky-bar .audio-label{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.sticky-bar .audio-controls{display:flex;align-items:center;gap:.5rem}.audio-volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100px;height:36px;background:transparent;cursor:pointer}.audio-volume-slider::-webkit-slider-runnable-track{height:8px;background:var(--slider-track-bg);border-radius:4px}.audio-volume-slider::-moz-range-track{height:8px;background:var(--slider-track-bg);border-radius:4px;border:none}.audio-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:var(--slider-thumb-bg);border:2px solid var(--bg-secondary);box-shadow:0 2px 4px #0003;margin-top:-8px;cursor:pointer;transition:transform .15s ease}.audio-volume-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.audio-volume-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--slider-thumb-bg);border:2px solid var(--bg-secondary);box-shadow:0 2px 4px #0003;cursor:pointer}.audio-volume-slider:disabled{opacity:.4;cursor:not-allowed}.audio-volume-slider:disabled::-webkit-slider-thumb{background:#888}.audio-volume-slider:disabled::-moz-range-thumb{background:#888}.btn-mute{background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border:1px solid var(--border-dark);padding:.3rem .6rem;border-radius:4px;font-size:.75rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-mute:hover:not(:disabled){background:var(--border-color);border-color:var(--border-dark)}.btn-mute:disabled{opacity:.5;cursor:not-allowed}.app-main{width:100%;display:flex;flex-direction:column;align-items:center}.status-panel{background:var(--bg-panel);border-radius:8px;padding:.75rem 1rem;border:1px solid var(--border-color);margin-bottom:1rem}.camera-status{font-size:1rem;font-weight:600}.camera-status--idle{color:#888}.camera-status--requesting{color:orange}.camera-status--active{color:#0c6}.camera-status--error,.camera-status--denied{color:#f55}.camera-error{color:#f88;background:#ff55551a;border-left:4px solid #ff5555;padding:.75rem;border-radius:4px;margin-top:.5rem;font-size:.9rem}.video-container{position:relative;background:var(--bg-video);border-radius:12px;overflow:hidden;aspect-ratio:16/9;border:1px solid var(--border-color);max-height:55vh}.camera-video{width:100%;height:100%;object-fit:contain;display:none;transform:scaleX(-1)}.video-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-video);color:var(--text-muted)}.video-placeholder{text-align:center}.video-placeholder svg{stroke:var(--text-muted);margin-bottom:1rem;opacity:.5}.video-placeholder p{font-size:1.2rem}.btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-primary{background:var(--btn-primary-bg);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 10px var(--btn-primary-shadow)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border:1px solid var(--border-dark)}.btn-secondary:hover:not(:disabled){background:var(--border-color);border-color:var(--border-dark)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-pip{background:var(--bg-panel);color:#00bfff;border:1px solid #00bfff}.btn-pip:hover:not(:disabled){background:#00bfff1a}.btn-pip--active{background:#00bfff;color:#000}.btn-pip:disabled{opacity:.5;cursor:not-allowed}.btn-guard{background:var(--bg-panel);color:#22c55e;border:1px solid #22c55e}.btn-guard:hover:not(:disabled){background:#22c55e1a}.btn-guard--active{background:#22c55e;color:#000}.btn-guard:disabled{opacity:.5;cursor:not-allowed}.support-warning{background:#ffa5001a;border:1px solid #ffa500;color:#ffcc80;padding:1rem;border-radius:8px;font-size:.95rem;margin-top:1rem}.app-footer{margin-top:2rem;padding:1rem;text-align:center;border-top:1px solid var(--border-color);color:var(--text-muted);font-size:.85rem}.footer-note{margin-top:.3rem;font-size:.8rem;color:var(--text-secondary)}.app-footer a{color:#7dd3fc;text-decoration:none}.app-footer a:hover{color:#bae6fd;text-decoration:underline}.error-screen{text-align:center;padding:3rem;background:var(--bg-panel);border-radius:12px;border:1px solid #ff5555;max-width:600px;margin:3rem auto}.error-screen h2{color:#f55;margin-bottom:1rem}.error-screen p{margin-bottom:2rem;color:var(--text-secondary)}.error-screen button{background:#f55;color:#fff;border:none;padding:.8rem 2rem;border-radius:6px;font-size:1rem;cursor:pointer}.logo-loader{display:flex;align-items:center;gap:10px;padding:8px 0;transition:opacity .5s ease,transform .5s ease}.logo-loader.loaded{opacity:0;transform:translateY(-10px);pointer-events:none;height:0;overflow:hidden}.logo-loader-bar{display:flex;align-items:flex-end;gap:4px;height:32px}.logo-loader-segment{width:24px;height:100%;border-radius:6px;background:var(--progress-bar-bg);transition:background .3s ease,opacity .3s ease,transform .3s ease;opacity:.3;transform:scaleY(.6)}.logo-loader-segment[data-segment="0"]{--segment-color: #0d7a3e}.logo-loader-segment[data-segment="1"]{--segment-color: #1a9e52}.logo-loader-segment[data-segment="2"]{--segment-color: #0d7a3e}.logo-loader-segment[data-segment="3"]{--segment-color: #5dd68a}.logo-loader-segment[data-segment="4"]{--segment-color: #96e8b4}.logo-loader-segment.filled{background:var(--segment-color);opacity:1;transform:scaleY(1)}.logo-loader-segment[data-segment="0"].filled{height:100%}.logo-loader-segment[data-segment="1"].filled{height:90%}.logo-loader-segment[data-segment="2"].filled{height:80%}.logo-loader-segment[data-segment="3"].filled{height:70%}.logo-loader-segment[data-segment="4"].filled{height:60%}.logo-loader .progress-text{font-size:.75rem;color:var(--text-muted);min-width:28px}#onboarding-bar{position:fixed;bottom:0;left:0;right:0;background:var(--onboarding-bg);border-top:1px solid var(--onboarding-border);padding:10px 20px;z-index:9999;display:flex;align-items:center;justify-content:center;gap:14px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;color:var(--text-secondary)}#onboarding-bar.onboarding--done{border-top-color:#22c55e66}.onboarding-step{display:flex;align-items:center;gap:8px}.step-icon{font-size:15px;line-height:1}.step-text{font-size:12px;white-space:nowrap}.onboarding-dots{display:flex;gap:5px;align-items:center}.onboarding-dot{width:5px;height:5px;border-radius:50%;background:var(--border-dark);transition:background .2s,box-shadow .2s}.onboarding-dot.active{background:#22c55e;box-shadow:0 0 5px #22c55e99}.onboarding-close{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;padding:4px 6px;line-height:1;border-radius:4px;transition:color .2s,background .2s}.onboarding-close:hover{color:var(--text-secondary);background:#ffffff0f}.footer-text{margin-bottom:.35rem;color:#bdbdbd}.footer-links{margin-top:.35rem;display:flex;align-items:center;justify-content:center;gap:.65rem;flex-wrap:wrap}.footer-links a{color:#7dd3fc;text-decoration:none;transition:color .2s ease,opacity .2s ease}.footer-links a:hover{color:#bae6fd;text-decoration:underline}.footer-links a:focus-visible{outline:2px solid #00bfff;outline-offset:2px;border-radius:4px}.footer-separator{color:#555}.app{width:100%;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;min-height:calc(100vh - 2rem);position:relative}.app-shell{width:100%;display:flex;flex-direction:column;align-items:center;transition:filter .25s ease,opacity .25s ease}.app-shell.is-locked{filter:blur(4px);opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none}.app-header,.sticky-bar,.status-panel,.app-main,.app-footer{width:min(100%,980px);margin-left:auto;margin-right:auto}.app-header{text-align:center;padding:1.2rem 1rem .75rem}.app-header h1{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;line-height:1.1;word-break:break-word;color:#0d7a3e}.app-subtitle{font-size:1rem;color:var(--text-secondary);max-width:680px;margin:.25rem auto 0}.sticky-bar{justify-content:center;align-items:stretch;gap:.75rem}.sticky-bar .controls,.sticky-bar .model-panel,.sticky-bar .calibration-panel{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap;min-height:56px}.status-panel{width:min(100%,980px)}.app-main{width:min(100%,980px);display:flex;flex-direction:column;align-items:center}.video-container{width:100%;max-width:980px;margin:0 auto;background:var(--bg-video);border-radius:16px;overflow:hidden;aspect-ratio:16 / 9;border:1px solid var(--border-color);max-height:60vh}.support-warning{width:100%;max-width:980px;margin-top:1rem}.app-footer{margin-top:2rem;padding:1rem 1rem 2rem;text-align:center;border-top:1px solid var(--border-color);color:var(--text-muted);font-size:.9rem}body.has-consent-overlay{overflow:hidden}.consent-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:16px;background:var(--consent-overlay-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:opacity .25s ease,visibility .25s ease;overflow-y:auto}.consent-overlay--hidden{opacity:0;visibility:hidden;pointer-events:none}.consent-card{width:min(100%,860px);max-height:min(92dvh,900px);overflow-y:auto;background:var(--consent-card-bg);border:1px solid rgba(255,255,255,.08);border-radius:22px;box-shadow:0 20px 60px #00000073;padding:24px}.consent-badge{display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px;padding:6px 12px;border-radius:999px;background:#2bbf651f;border:1px solid rgba(13,122,62,.28);color:#0d7a3e;font-size:.85rem;font-weight:700}.consent-card h2{font-size:clamp(1.4rem,3vw,2.1rem);line-height:1.2;margin-bottom:.75rem;color:var(--text-primary)}.consent-lead{color:var(--text-secondary);margin-bottom:1.25rem;font-size:clamp(.875rem,2.5vw,1rem)}.consent-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:1rem}.consent-section{background:var(--consent-section-bg);border:1px solid var(--consent-section-border);border-radius:16px;padding:16px}.consent-section h3{font-size:1rem;margin-bottom:.65rem;color:var(--text-primary)}.consent-section ul{margin:0;padding-left:1.1rem;color:var(--text-secondary)}.consent-section li+li{margin-top:.45rem}.consent-note{margin-top:.25rem;margin-bottom:1.2rem;padding:12px 14px;border-radius:14px;background:#ffa50014;border:1px solid rgba(255,165,0,.2);color:#ffd79a}.consent-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.debug-overlay{object-fit:contain}@media (max-width: 768px){body{padding-top:env(safe-area-inset-top,12px);padding-bottom:env(safe-area-inset-bottom,12px);padding-left:max(12px,env(safe-area-inset-left,12px));padding-right:max(12px,env(safe-area-inset-right,12px))}.app{min-height:calc(100vh - env(safe-area-inset-top,12px) - env(safe-area-inset-bottom,12px))}.app-header{padding-top:max(1rem,env(safe-area-inset-top,1rem))}.sticky-bar{flex-direction:column;align-items:stretch;top:0;padding:.5rem 0}.sticky-bar .controls,.sticky-bar .model-panel,.sticky-bar .calibration-panel{width:100%;justify-content:center}.button-group{width:100%;justify-content:center;flex-wrap:wrap}.status-panel{padding:.75rem}.video-container{max-height:38vh;border-radius:14px}.consent-card{padding:18px;border-radius:18px;max-height:85dvh}.consent-grid{grid-template-columns:1fr}.consent-actions{flex-direction:column;gap:10px}.consent-actions .btn{width:100%;max-width:280px;min-height:44px;display:flex;align-items:center;justify-content:center}.consent-lead{font-size:clamp(.8rem,3vw,.95rem)}.consent-note{font-size:clamp(.75rem,2.5vw,.9rem)}.consent-section h3{font-size:clamp(.85rem,3vw,1rem)}.consent-section ul{font-size:clamp(.8rem,2.5vw,.95rem)}.app-subtitle{font-size:.9rem;display:block}.app-header h1{font-size:1.5rem}.app-subtitle{font-size:.85rem}.sticky-bar .btn{padding:.3rem .6rem;font-size:.75rem}.sticky-bar .model-status,.sticky-bar .calibration-status{font-size:.7rem}}@media (max-width: 480px){body{padding:.5rem;padding-top:env(safe-area-inset-top,8px);padding-bottom:env(safe-area-inset-bottom,8px);padding-left:max(8px,env(safe-area-inset-left,8px));padding-right:max(8px,env(safe-area-inset-right,8px))}.app-header h1{font-size:1.6rem}.app-subtitle{font-size:.82rem}.sticky-bar .btn{width:100%}.consent-overlay{padding:12px}.consent-card{padding:14px;max-height:80dvh}.consent-lead{font-size:clamp(.75rem,3.5vw,.9rem)}.consent-note{font-size:clamp(.7rem,3vw,.85rem)}.consent-section ul{font-size:clamp(.75rem,3vw,.9rem)}.consent-section h3{font-size:clamp(.8rem,3.5vw,.95rem)}.consent-actions .btn{min-height:48px;font-size:15px}.header-logo{width:36px;height:36px}.theme-toggle{right:.5rem;width:36px;height:36px;padding:6px}.theme-toggle svg{width:20px;height:20px}.audio-volume-slider{min-height:44px;height:44px;width:100%}.audio-volume-slider::-webkit-slider-thumb{width:32px;height:32px;margin-top:-14px}.audio-volume-slider::-moz-range-thumb{width:32px;height:32px}.audio-volume-slider::-webkit-slider-runnable-track{height:10px}.audio-volume-slider::-moz-range-track{height:10px}.sticky-bar{flex-direction:row;flex-wrap:wrap;gap:.4rem;padding:.4rem 0}.sticky-bar .controls,.sticky-bar .model-panel,.sticky-bar .calibration-panel,.sticky-bar .audio-panel{padding:.3rem .5rem;display:flex;align-items:center;gap:.3rem;flex-wrap:wrap}.sticky-bar .btn{font-size:.7rem;padding:.25rem .5rem;min-width:unset}.sticky-bar .model-progress{display:none}.sticky-bar .model-status{font-size:.65rem}.sticky-bar .calibration-status,.app-subtitle{display:none}.video-container{max-height:30vh}#onboarding-bar{padding:6px 12px;font-size:11px;gap:8px}.step-text{font-size:10px}.onboarding-dots{gap:4px}.onboarding-dot{width:4px;height:4px}.footer-links{flex-direction:column;gap:.35rem}.footer-separator{display:none}}@media (max-height: 480px) and (orientation: landscape){#onboarding-bar{display:none}}@media (min-width: 769px){.sticky-bar .controls,.sticky-bar .model-panel,.sticky-bar .calibration-panel,.sticky-bar .audio-panel{max-width:600px}.sticky-bar{justify-content:center}}.consent-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.beta-status-tag{background:#ffffff1a;border:1px dashed #e5e7eb;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
