@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary:#07080d;--bg-secondary:#0e1017;--bg-card:#13151e;--bg-input:#191c28;--bg-hover:#1e2130;--text-primary:#e8eaf0;--text-secondary:#8790a5;--text-muted:#545b70;--accent:#00d4aa;--accent-dim:#00d4aa26;--accent-glow:#00d4aa4d;--color-good:#00d4aa;--color-fair:#ffa726;--color-poor:#ef5350;--color-neutral:#607d8b;--border:#1e2235;--border-focus:#00d4aa;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{flex-direction:column;width:100%;height:100%;display:flex;position:relative}.screen{flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.setup-screen{background:var(--bg-primary);justify-content:flex-start;padding:24px;overflow-y:auto}.setup-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:440px;margin:auto 0;padding:36px 32px}.setup-header{text-align:center;margin-bottom:32px}.logo-mark{color:var(--accent);filter:drop-shadow(0 0 12px var(--accent-glow));margin-bottom:8px;font-size:36px}.setup-header h1{letter-spacing:-.02em;margin-bottom:4px;font-size:22px;font-weight:600}.setup-header .subtitle{color:var(--text-secondary);font-size:13px;font-weight:400}.form-grid{flex-direction:column;gap:16px;margin-bottom:28px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:500}.form-group .optional{color:var(--text-muted);text-transform:none;font-weight:400}.form-group input,.form-group select,.form-group textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);outline:none;padding:10px 12px;font-size:14px;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 2px var(--accent-dim)}.form-group textarea{resize:vertical;min-height:72px;line-height:1.4}.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238790a5' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.form-row{gap:12px;display:flex}.flex-1{flex:1}.flex-2{flex:2}.setup-guidance{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff08;padding:14px 16px}.setup-guidance h2,.setup-guidance h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:12px}.setup-guidance h3{margin-top:12px}.setup-guidance ul{flex-direction:column;gap:6px;padding-left:16px;display:flex}.setup-guidance li{color:var(--text-primary);font-size:13px;line-height:1.35}.btn-primary{background:var(--accent);width:100%;color:var(--bg-primary);border-radius:var(--radius-md);font-family:var(--font-body);cursor:pointer;letter-spacing:-.01em;border:none;padding:12px 24px;font-size:15px;font-weight:600;transition:all .15s}.btn-primary:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 0 20px var(--accent-glow)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{width:100%;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-body);cursor:pointer;background:0 0;margin-top:10px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .15s}.btn-secondary:hover{border-color:var(--text-secondary);color:var(--text-primary)}.btn-stop{background:var(--color-poor);color:#fff;border-radius:var(--radius-md);font-family:var(--font-body);cursor:pointer;letter-spacing:.02em;border:none;margin-top:16px;padding:16px 48px;font-size:16px;font-weight:600;transition:all .15s}.btn-stop:hover{filter:brightness(1.15);box-shadow:0 0 20px #ef535066}.btn-download{background:var(--accent);width:100%;color:var(--bg-primary);border-radius:var(--radius-md);font-family:var(--font-body);cursor:pointer;border:none;padding:14px 24px;font-size:16px;font-weight:600;transition:all .15s}.btn-download:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 0 20px var(--accent-glow)}.btn-download:disabled{opacity:.6;cursor:wait}.btn-text{color:var(--text-muted);font-family:var(--font-body);cursor:pointer;background:0 0;border:none;padding:8px 16px;font-size:13px;transition:color .15s}.btn-text:hover{color:var(--text-primary)}.capture-screen{z-index:1;background:0 0;padding:0;position:relative}.capture-viewport{border-bottom:3px solid var(--color-poor);background:0 0;flex:1;width:100%;transition:border-color .3s;position:relative;overflow:hidden}.capture-video{object-fit:cover;width:100%;height:100%}.capture-video-persistent{object-fit:cover;z-index:0;width:100%;height:100%;position:fixed;top:0;left:0}.capture-overlay{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.capture-badges{flex-wrap:wrap;gap:6px;display:flex;position:absolute;bottom:12px;left:12px}.badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:var(--font-mono);color:var(--text-primary);background:#000000a6;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;display:inline-flex}.badge-good{color:var(--color-good)}.badge-fair{color:var(--color-fair)}.badge-poor{color:var(--color-poor)}.recording-indicator{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:var(--font-mono);color:var(--color-poor);background:#ef535033;border:1px solid #ef53504d;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:11px;font-weight:600;display:flex;position:absolute;top:12px;right:12px}.capture-session-panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-md);max-width:min(300px,100vw - 120px);color:var(--text-secondary);background:#000000a6;border:1px solid #ffffff1a;flex-direction:column;gap:3px;padding:8px 12px;font-size:12px;display:flex;position:absolute;top:12px;left:12px}.capture-session-title{color:var(--text-primary);font-weight:600}.recording-dot{background:var(--color-poor);border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite blink}.low-coverage-warning{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#ffa72633;border:1px solid #ffa72666;border-radius:24px;align-items:center;gap:8px;padding:8px 18px;animation:.3s ease-out fadeIn;display:flex;position:absolute;top:12px;left:50%;transform:translate(-50%)}.warning-icon{font-size:18px}.warning-text{font-family:var(--font-body);color:var(--color-fair);white-space:nowrap;font-size:12px;font-weight:500}.camera-error-overlay{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#07080deb;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:fixed;inset:0}.camera-error-overlay p{color:var(--color-fair);text-align:center;max-width:320px;font-size:15px}.camera-error-overlay .btn-secondary{width:auto;padding:10px 24px}.results-screen{background:var(--bg-primary);padding:24px;overflow-y:auto}.results-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;padding:32px 28px}.results-card h2{text-align:center;margin-bottom:24px;font-size:20px;font-weight:600}.status-banner{border-radius:var(--radius-md);text-align:center;flex-direction:column;gap:4px;margin-bottom:24px;padding:16px;display:flex}.status-banner h3{letter-spacing:-.01em;font-size:16px;font-weight:600}.status-banner p{opacity:.9;font-size:13px}.status-banner.fail{color:var(--color-poor);background:#ef535026;border:1px solid #ef53504d}.status-banner.marginal{color:var(--color-fair);background:#ffa72626;border:1px solid #ffa7264d}.status-banner.pass{color:var(--color-good);background:#00d4aa26;border:1px solid #00d4aa4d}.diagnostic-bullet{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;margin-bottom:20px;padding:16px}.diagnostic-bullet h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:12px;font-weight:600}.diagnostic-bullet ul{flex-direction:column;gap:8px;list-style:none;display:flex}.diagnostic-bullet li{color:var(--text-primary);align-items:flex-start;gap:8px;font-size:13px;line-height:1.4;display:flex}.diagnostic-bullet li:before{content:"•";color:var(--color-fair);font-weight:700}.results-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;display:grid}.results-grid.compact{grid-template-columns:repeat(3,1fr);margin-bottom:12px}.result-item{background:var(--bg-input);border-radius:var(--radius-sm);flex-direction:column;align-items:center;gap:2px;padding:10px 8px;display:flex}.result-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:500}.result-value{font-family:var(--font-mono);color:var(--text-primary);font-size:16px;font-weight:500}.result-item.metric-error{background:#ef53501a;border:1px solid #ef535033}.result-item.metric-error .result-label,.result-item.metric-error .result-value{color:var(--color-poor)}.result-item.metric-warning{background:#ffa7261a;border:1px solid #ffa72633}.result-item.metric-warning .result-label,.result-item.metric-warning .result-value{color:var(--color-fair)}.usability-badges{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.usability-badge{text-align:center;border-radius:var(--radius-sm);letter-spacing:.02em;flex:1;min-width:100px;padding:8px 12px;font-size:12px;font-weight:600}.usability-badge.usable{color:var(--color-good);background:#00d4aa1f;border:1px solid #00d4aa33}.usability-badge.unusable{color:var(--color-poor);background:#ef53501f;border:1px solid #ef535033}.usability-badge.neutral{color:var(--color-neutral);background:#607d8b1f;border:1px solid #607d8b33}.auto-tags{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.auto-tag{color:var(--color-fair);background:#ffa7261a;border:1px solid #ffa72633;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:500}.auto-tag.neutral{color:var(--text-secondary);background:#607d8b1f;border-color:#607d8b33}.view-info{color:var(--text-muted);text-align:center;font-size:12px;font-family:var(--font-mono);margin-bottom:20px}.exercise-observations-panel{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;margin-bottom:20px;padding:16px}.exercise-observations-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.exercise-observations-header h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:12px;font-weight:600}.exercise-observations-header p,.observation-meta{color:var(--text-primary);font-size:12px}.btn-small{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);cursor:pointer;padding:6px 12px;font-size:11px}.btn-small:hover{border-color:var(--accent)}.observation-meta,.observation-flags{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.observation-meta span{background:var(--bg-input);border-radius:var(--radius-sm);color:var(--text-secondary);padding:4px 8px}.rep-list{flex-direction:column;gap:8px;display:flex}.rep-detail{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px}.rep-detail summary{cursor:pointer;color:var(--text-primary);grid-template-columns:1fr auto auto;gap:12px;font-size:13px;display:grid}.rep-detail-grid{grid-template-columns:1fr auto;gap:6px 12px;margin-top:10px;font-size:12px;display:grid}.rep-detail-grid span,.phase-list{color:var(--text-secondary)}.rep-detail-grid strong{font-family:var(--font-mono);color:var(--text-primary);font-weight:500}.phase-list{flex-direction:column;gap:4px;margin-top:10px;font-size:12px;display:flex}.download-section{margin-top:8px;margin-bottom:8px}.download-hint{color:var(--text-muted);text-align:center;margin-top:8px;font-size:11px;line-height:1.4}.error-text{color:var(--color-poor);text-align:center;margin-bottom:8px;font-size:13px}.processing-screen,.engine-loading{flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100%;display:flex}.engine-loading{z-index:10;background:var(--bg-primary);position:absolute;inset:0}.engine-loading p,.processing-screen p{color:var(--text-secondary);font-size:14px}.loading-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.08)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}
