*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}button{font-family:inherit;cursor:pointer;border:none}input,select{font-family:inherit}:root{--bg-primary: #0f1117;--bg-secondary: #161822;--bg-surface: #1c1f2e;--bg-elevated: #242738;--bg-hover: #2a2e42;--text-primary: #f0ece4;--text-secondary: #9b97a0;--text-muted: #6b6775;--text-inverse: #0f1117;--accent: #5ab68a;--accent-dim: #3d7e60;--accent-glow: rgba(90, 182, 138, .15);--amber: #e8b339;--amber-dim: #a07b22;--amber-glow: rgba(232, 179, 57, .12);--red: #d4644a;--red-dim: #8c3d2e;--red-glow: rgba(212, 100, 74, .12);--blue: #5b8fd4;--blue-dim: #3a5e8c;--border: rgba(255, 255, 255, .06);--border-focus: var(--accent);--font-body: 15px;--font-label: 13px;--font-heading: 22px;--font-hero: 28px;--font-small: 12px;--weight-regular: 400;--weight-medium: 500;--weight-semi: 600;--weight-bold: 700;--line-height: 1.55;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;--sp-6: 32px;--sp-7: 48px;--sp-8: 64px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--r-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--ease: cubic-bezier(.25, .1, .25, 1);--dur-fast: .15s;--dur-med: .25s;--dur-slow: .4s}body{background:var(--bg-primary);color:var(--text-primary);line-height:var(--line-height);font-size:var(--font-body);min-height:100vh}#app{max-width:840px;margin:0 auto;padding:var(--sp-7) var(--sp-5);min-height:100vh}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r-sm)}.text-hero{font-size:var(--font-hero);font-weight:var(--weight-bold);line-height:1.3;letter-spacing:-.02em}.text-h1{font-size:var(--font-heading);font-weight:var(--weight-semi);line-height:1.35}.text-h2{font-size:18px;font-weight:var(--weight-semi);line-height:1.4}.text-body{font-size:var(--font-body);font-weight:var(--weight-regular)}.text-label{font-size:var(--font-label);font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.text-small{font-size:var(--font-small);color:var(--text-muted)}.text-muted{color:var(--text-secondary)}.text-accent{color:var(--accent)}.text-amber{color:var(--amber)}.text-red{color:var(--red)}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-5);box-shadow:var(--shadow-sm);transition:box-shadow var(--dur-med) var(--ease)}.card:hover{box-shadow:var(--shadow-md)}.card--elevated{background:var(--bg-elevated);box-shadow:var(--shadow-md)}.card--amber{border-color:var(--amber-dim);background:linear-gradient(135deg,var(--bg-surface),rgba(232,179,57,.04))}.card--red{border-color:var(--red-dim);background:linear-gradient(135deg,var(--bg-surface),rgba(212,100,74,.04))}.card--accent{border-color:var(--accent-dim);background:linear-gradient(135deg,var(--bg-surface),rgba(90,182,138,.04))}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-5);border-radius:var(--r-full);font-size:var(--font-body);font-weight:var(--weight-semi);transition:all var(--dur-fast) var(--ease);min-height:44px}.btn-primary{background:var(--accent);color:var(--text-inverse)}.btn-primary:hover{background:#4ea87c;transform:translateY(-1px);box-shadow:0 4px 12px var(--accent-glow)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:#ffffff1f}.btn-ghost{background:transparent;color:var(--text-secondary);padding:var(--sp-2) var(--sp-3)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover)}.btn-amber{background:#e8b33926;color:var(--amber);border:1px solid var(--amber-dim)}.btn-amber:hover{background:#e8b33940}.input{width:100%;padding:var(--sp-3) var(--sp-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-size:var(--font-body);min-height:44px;transition:border-color var(--dur-fast) var(--ease)}.input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px var(--accent-glow)}.input::placeholder{color:var(--text-muted)}.input--error{border-color:var(--red)}.pill-group{display:flex;gap:var(--sp-2)}.pill{padding:var(--sp-2) var(--sp-4);border-radius:var(--r-full);font-size:var(--font-body);font-weight:var(--weight-medium);background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);transition:all var(--dur-fast) var(--ease);cursor:pointer;min-height:40px;display:flex;align-items:center}.pill:hover{background:var(--bg-hover);color:var(--text-primary)}.pill--active{background:var(--accent-glow);color:var(--accent);border-color:var(--accent-dim)}.chip{display:inline-flex;align-items:center;gap:var(--sp-1);padding:3px var(--sp-2);border-radius:var(--r-full);font-size:var(--font-small);font-weight:var(--weight-medium)}.chip--good{background:var(--accent-glow);color:var(--accent)}.chip--warn{background:var(--amber-glow);color:var(--amber)}.chip--bad{background:var(--red-glow);color:var(--red)}.stepper{display:flex;flex-direction:column;gap:var(--sp-4)}.stepper-step{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);transition:all var(--dur-med) var(--ease)}.stepper-step--active{background:var(--accent-glow);color:var(--accent)}.stepper-step--done{color:var(--accent)}.stepper-step--pending{color:var(--text-muted)}.stepper-step--error{background:var(--red-glow);color:var(--red)}.stepper-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;font-size:14px}.badge{display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1) var(--sp-3);border-radius:var(--r-full);font-size:var(--font-small);font-weight:var(--weight-semi)}.badge--green{background:var(--accent-glow);color:var(--accent)}.badge--amber{background:var(--amber-glow);color:var(--amber)}.badge--red{background:var(--red-glow);color:var(--red)}.score-ring{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:var(--weight-bold);background:conic-gradient(var(--accent) calc(var(--score) * 1%),var(--bg-secondary) 0%);position:relative}.score-ring:after{content:attr(data-score);position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;background:var(--bg-surface);display:flex;align-items:center;justify-content:center}.drop-zone{border:2px dashed var(--border);border-radius:var(--r-lg);padding:var(--sp-7) var(--sp-5);text-align:center;cursor:pointer;transition:all var(--dur-med) var(--ease)}.drop-zone:hover,.drop-zone--active{border-color:var(--accent-dim);background:var(--accent-glow)}.drop-zone--error{border-color:var(--red-dim);background:var(--red-glow)}.banner{padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);font-size:var(--font-body);display:flex;align-items:flex-start;gap:var(--sp-3)}.banner--amber{background:var(--amber-glow);border:1px solid var(--amber-dim);color:var(--amber)}.banner--green{background:var(--accent-glow);border:1px solid var(--accent-dim);color:var(--accent)}.banner--red{background:var(--red-glow);border:1px solid var(--red-dim);color:var(--red)}.tooltip-wrap{position:relative;display:inline-flex}.tooltip-wrap .tooltip{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-sm);padding:var(--sp-2) var(--sp-3);font-size:var(--font-small);color:var(--text-secondary);white-space:nowrap;z-index:100;box-shadow:var(--shadow-md)}.tooltip-wrap:hover .tooltip{display:block}.accordion-trigger{display:flex;align-items:center;gap:var(--sp-2);width:100%;background:none;color:var(--text-secondary);font-size:var(--font-body);padding:var(--sp-2) 0;cursor:pointer;border:none}.accordion-trigger:hover{color:var(--text-primary)}.accordion-content{overflow:hidden;max-height:0;transition:max-height var(--dur-med) var(--ease)}.accordion-content--open{max-height:2000px}.section{margin-bottom:var(--sp-7)}.section-title{margin-bottom:var(--sp-4)}.stack{display:flex;flex-direction:column}.stack>*+*{margin-top:var(--sp-4)}.stack--tight>*+*{margin-top:var(--sp-2)}.stack--loose>*+*{margin-top:var(--sp-6)}.row{display:flex;align-items:center;gap:var(--sp-3)}.row--between{justify-content:space-between}.row--wrap{flex-wrap:wrap}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.animate-in{animation:fadeIn var(--dur-slow) var(--ease) both}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-in-1{animation-delay:0ms}.animate-in-2{animation-delay:.1s}.animate-in-3{animation-delay:.2s}.animate-in-4{animation-delay:.3s}.animate-in-5{animation-delay:.4s}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.w-full{width:100%}.text-center{text-align:center}.text-right{text-align:right}.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mt-5{margin-top:var(--sp-5)}.mb-2{margin-bottom:var(--sp-2)}.mb-3{margin-bottom:var(--sp-3)}.mb-4{margin-bottom:var(--sp-4)}.guidance-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:border-color var(--dur-med) var(--ease)}.guidance-panel[open]{border-color:#ffffff1a}.guidance-summary{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);cursor:pointer;list-style:none;font-size:var(--font-body);font-weight:var(--weight-medium);color:var(--text-secondary);transition:color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease);-webkit-user-select:none;user-select:none}.guidance-summary::-webkit-details-marker{display:none}.guidance-summary:after{content:"▸";margin-left:auto;transition:transform var(--dur-med) var(--ease);font-size:14px;color:var(--text-muted)}.guidance-panel[open] .guidance-summary:after{transform:rotate(90deg)}.guidance-summary:hover{color:var(--text-primary);background:var(--bg-hover)}.guidance-icon{font-size:16px;flex-shrink:0}.guidance-title{flex:1}.guidance-tag{font-size:var(--font-small);color:var(--accent);font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:.05em}.guidance-body{padding:0 var(--sp-4) var(--sp-4) var(--sp-4);animation:fadeIn var(--dur-med) var(--ease) both}.guidance-diagram{display:flex;justify-content:center;margin-bottom:var(--sp-3);padding:var(--sp-3);background:var(--bg-primary);border-radius:var(--r-sm)}.guidance-diagram svg{max-width:100%;height:auto}.guidance-bullets{list-style:none;padding:0;margin:0}.guidance-bullets li{position:relative;padding:var(--sp-2) 0 var(--sp-2) var(--sp-5);font-size:var(--font-body);color:var(--text-secondary);line-height:1.5;border-bottom:1px solid var(--border)}.guidance-bullets li:last-child{border-bottom:none}.guidance-bullets li:before{content:"•";position:absolute;left:var(--sp-2);color:var(--accent);font-weight:var(--weight-bold)}.guidance-steps{padding:0 0 0 var(--sp-5);margin:0}.guidance-steps li{padding:var(--sp-2) 0;font-size:var(--font-body);color:var(--text-secondary);line-height:1.5}.guidance-steps li::marker{color:var(--accent);font-weight:var(--weight-semi)}.guidance-trust{margin-top:var(--sp-3);padding-top:var(--sp-3);border-top:1px solid var(--border);font-size:var(--font-small);color:var(--text-muted)}.camera-check-toggle{display:flex;align-items:center;gap:var(--sp-3);cursor:pointer;font-size:var(--font-body);color:var(--text-secondary);padding:var(--sp-2) 0;-webkit-user-select:none;user-select:none}.camera-check-toggle input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.camera-check-checkbox{width:20px;height:20px;border:2px solid var(--text-muted);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--dur-fast) var(--ease);background:var(--bg-secondary)}.camera-check-toggle input:checked+.camera-check-checkbox{background:var(--accent);border-color:var(--accent)}.camera-check-toggle input:checked+.camera-check-checkbox:after{content:"✓";color:var(--text-inverse);font-size:13px;font-weight:var(--weight-bold);line-height:1}.camera-check-toggle input:focus-visible+.camera-check-checkbox{outline:2px solid var(--accent);outline-offset:2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;transition:opacity var(--dur-med) var(--ease);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--sp-7);max-width:480px;width:90%;box-shadow:var(--shadow-lg)}.guidance-subtitle{font-size:var(--font-small);color:var(--text-muted);margin-bottom:var(--sp-3);letter-spacing:.02em}.camera-guide-image-wrap{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(255,255,255,.06);background:#0f111799;margin-bottom:var(--sp-3);max-width:900px}.camera-guide-img{display:block;width:100%;height:auto;opacity:0;transition:opacity .3s var(--ease);cursor:zoom-in}.camera-guide-img.loaded{opacity:1}@keyframes skeleton-pulse{0%,to{opacity:.15}50%{opacity:.25}}.camera-guide-skeleton{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,#ffffff0a 8%,#ffffff14 18%,#ffffff0a 33%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;min-height:180px;border-radius:var(--r-lg)}.camera-guide-view-larger{position:absolute;bottom:var(--sp-3);right:var(--sp-3);display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1) var(--sp-3);background:#0f1117bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text-secondary);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);font-size:12px;font-family:var(--font-sans);cursor:pointer;opacity:0;transition:opacity .2s var(--ease),background .15s}.camera-guide-image-wrap:hover .camera-guide-view-larger{opacity:1}.camera-guide-view-larger:hover{background:#0f1117e6;color:var(--text-primary)}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);opacity:0;transition:opacity .2s var(--ease);cursor:zoom-out}.lightbox-overlay.lightbox-visible{opacity:1}.lightbox-container{position:relative;max-width:95vw;max-height:95vh;cursor:default}.lightbox-img{display:block;max-width:95vw;max-height:90vh;width:auto;height:auto;border-radius:var(--r-lg);box-shadow:var(--shadow-lg)}.lightbox-close{position:absolute;top:calc(-1 * var(--sp-6));right:0;display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1) var(--sp-3);background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:var(--r-md);color:var(--text-secondary);font-size:13px;font-family:var(--font-sans);cursor:pointer;transition:background .15s,color .15s}.lightbox-close:hover{background:#ffffff24;color:var(--text-primary)}.camera-guide-callout{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:rgba(var(--amber-rgb, 217, 172, 83),.08);border:1px solid rgba(var(--amber-rgb, 217, 172, 83),.2);border-radius:var(--r-md);color:var(--amber);font-size:var(--font-small);margin-top:var(--sp-2)}.score-ring-hero{position:relative;width:160px;height:160px;margin:0 auto}.score-ring-hero svg{width:100%;height:100%;transform:rotate(-90deg)}.score-ring-hero .ring-bg{fill:none;stroke:var(--bg-elevated);stroke-width:8}.score-ring-hero .ring-fill{fill:none;stroke-width:8;stroke-linecap:round;stroke-dasharray:408;stroke-dashoffset:408;transition:stroke-dashoffset 1.5s cubic-bezier(.4,0,.2,1)}.score-ring-hero .ring-fill.ring-good{stroke:var(--accent)}.score-ring-hero .ring-fill.ring-fair{stroke:var(--amber)}.score-ring-hero .ring-fill.ring-poor{stroke:var(--red)}.score-ring-hero .ring-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.score-ring-hero .ring-score{font-size:42px;font-weight:var(--weight-bold);line-height:1;letter-spacing:-.03em}.score-ring-hero .ring-unit{font-size:13px;font-weight:var(--weight-medium);color:var(--text-secondary);margin-top:4px;text-transform:uppercase;letter-spacing:.08em}.results-hero{text-align:center;padding:var(--sp-6) 0 var(--sp-5)}.results-hero .hero-metrics{display:flex;justify-content:center;gap:var(--sp-6);margin-top:var(--sp-5)}.results-hero .hero-metric{text-align:center}.results-hero .hero-metric-value{font-size:20px;font-weight:var(--weight-bold);color:var(--text-primary)}.results-hero .hero-metric-label{font-size:11px;font-weight:var(--weight-medium);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}.focus-card{background:linear-gradient(135deg,#5ab68a0f,#5ab68a05);border:1px solid rgba(90,182,138,.15);border-radius:var(--r-lg);padding:var(--sp-5);position:relative;overflow:hidden}.focus-card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--accent);border-radius:3px 0 0 3px}.focus-card--warn{background:linear-gradient(135deg,#e8b3390f,#e8b33905);border-color:#e8b33926}.focus-card--warn:before{background:var(--amber)}.focus-card .focus-tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--sp-3)}.focus-card .focus-cue{font-size:17px;font-weight:var(--weight-semi);line-height:1.5;color:var(--text-primary);margin-bottom:var(--sp-3)}.focus-card .focus-why{font-size:13px;line-height:1.6;color:var(--text-secondary)}.focus-card .focus-affected{display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--sp-3)}.focus-card .focus-rep-tag{font-size:11px;font-weight:var(--weight-medium);padding:2px 8px;border-radius:var(--r-full);background:#ffffff0d;color:var(--text-secondary)}.rep-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-3) var(--sp-4);margin-top:var(--sp-2);cursor:pointer;transition:background var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease)}.rep-card:hover{background:var(--bg-elevated);border-color:#ffffff1a}.rep-card--flagged{border-left:3px solid var(--amber)}.rep-card .rep-header{display:flex;align-items:center;justify-content:space-between}.rep-card .rep-info{display:flex;align-items:center;gap:var(--sp-3);min-width:0;flex:1}.rep-card .rep-score-mini{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:var(--weight-bold);border:2px solid;flex-shrink:0}.rep-card .rep-score-mini.score-good{border-color:var(--accent);color:var(--accent)}.rep-card .rep-score-mini.score-fair{border-color:var(--amber);color:var(--amber)}.rep-card .rep-score-mini.score-poor{border-color:var(--red);color:var(--red)}.rep-card .rep-name{font-weight:var(--weight-semi);font-size:15px}.rep-card .rep-tempo{font-size:12px;color:var(--text-muted);margin-top:2px}.rep-card .rep-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:var(--sp-2);padding-top:var(--sp-2);border-top:1px solid rgba(255,255,255,.04)}.rep-card .rep-expand{font-size:10px;color:var(--text-muted);margin-left:auto;transition:transform var(--dur-fast) var(--ease);flex-shrink:0}.rep-card .rep-expand.expanded{transform:rotate(180deg)}.rep-detail-section{margin-top:var(--sp-3);padding-top:var(--sp-3);border-top:1px solid var(--border)}.coaching-item{display:flex;gap:var(--sp-3);align-items:flex-start;padding:var(--sp-2) 0}.coaching-item+.coaching-item{border-top:1px solid rgba(255,255,255,.03);margin-top:var(--sp-2);padding-top:var(--sp-2)}.coaching-num{min-width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:var(--weight-bold);flex-shrink:0}.coaching-num--warn{background:#e8b33926;color:var(--amber)}.coaching-num--alert{background:#d4644a26;color:var(--red)}.coaching-fix{font-size:14px;font-weight:var(--weight-semi);color:var(--text-primary);line-height:1.4}.coaching-metric{font-size:12px;color:var(--text-muted);margin-top:2px}.coaching-tip{font-size:12px;color:var(--text-secondary);line-height:1.5;font-style:italic;margin-top:4px}@media (max-width: 480px){#app{padding-left:var(--sp-3);padding-right:var(--sp-3);padding-top:var(--sp-4)}.results-hero .hero-metrics{gap:var(--sp-3);flex-wrap:wrap;justify-content:center}.results-hero .hero-metric{min-width:70px}.focus-card{padding:var(--sp-3) var(--sp-4)}.focus-card .focus-cue{font-size:15px}.rep-card{padding:var(--sp-3)}.rep-card .rep-name{font-size:14px}.rep-card .rep-tempo{font-size:11px}.chip{font-size:11px;padding:2px 6px}.coaching-fix{font-size:13px}.coaching-metric,.coaching-tip{font-size:11px}}.score-ring-lg{position:relative;width:120px;height:120px;display:inline-block}@media (max-width: 480px){.score-ring-lg{width:80px;height:80px}}.stat-divider{width:1px;height:32px;background:var(--border)}.nav-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-2) 0;margin-bottom:var(--sp-4)}.nav-bar .btn{font-size:13px;padding:var(--sp-2) var(--sp-3)}:root{--live-accent: #ef4444;--live-accent-dim: #991b1b;--live-accent-glow: rgba(239, 68, 68, .12)}.home-cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}@media (max-width: 480px){.home-cta-grid{grid-template-columns:1fr}}.card--live{border-color:var(--live-accent-dim);position:relative;overflow:hidden}.card--live:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--live-accent),transparent);opacity:.6}.card--live:hover{border-color:var(--live-accent);box-shadow:0 4px 16px var(--live-accent-glow)}.badge--new{background:var(--live-accent-glow);color:var(--live-accent);border:1px solid var(--live-accent-dim);font-size:10px;padding:2px 8px;margin-top:var(--sp-2);text-transform:uppercase;letter-spacing:.08em}.live-setup{max-width:520px;margin:0 auto;animation:fadeIn var(--dur-slow) var(--ease) both}.live-setup__header{text-align:center;margin-bottom:var(--sp-5)}.live-setup__header .btn-ghost{position:absolute;left:var(--sp-5);top:var(--sp-5)}.live-setup__form .form-label{font-size:var(--font-label);font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);display:block;margin-bottom:var(--sp-2)}.live-setup__form .btn-group{display:flex;gap:var(--sp-2)}.live-setup__form .btn-option{flex:1;padding:var(--sp-2) var(--sp-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-secondary);font-size:var(--font-body);font-weight:var(--weight-medium);transition:all var(--dur-fast) var(--ease);min-height:40px}.live-setup__form .btn-option:hover{background:var(--bg-hover);color:var(--text-primary)}.live-setup__form .btn-option.active{background:var(--accent-glow);color:var(--accent);border-color:var(--accent-dim)}.live-setup__form .weight-input-row{display:flex;gap:var(--sp-3);align-items:center}.live-setup__form .input-field{flex:1;padding:var(--sp-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-size:var(--font-body);min-height:40px}.live-setup__form .input-field:focus{border-color:var(--accent);outline:none}.live-setup__form .btn-group--small .btn-option{padding:var(--sp-1) var(--sp-3);min-height:36px;font-size:var(--font-small)}.live-preview-container{position:relative;background:var(--bg-secondary);border:1px solid var(--border);overflow:hidden;aspect-ratio:16/9}.live-preview-container video{width:100%;height:100%;object-fit:cover}.quality-badge{position:absolute;bottom:var(--sp-3);left:var(--sp-3);padding:var(--sp-1) var(--sp-3);border-radius:var(--r-full);font-size:var(--font-small);font-weight:var(--weight-semi)}.quality-badge--checking{background:var(--amber-glow);color:var(--amber)}.quality-badge--good{background:var(--accent-glow);color:var(--accent)}.quality-badge--error{background:var(--red-glow);color:var(--red)}.btn-lg{width:100%;padding:var(--sp-4) var(--sp-5);border-radius:var(--r-lg);font-size:16px;font-weight:var(--weight-semi);display:flex;align-items:center;justify-content:center;background:var(--accent);color:var(--text-inverse);transition:all var(--dur-fast) var(--ease)}.btn-lg:hover:not(:disabled){background:#4ea87c}.btn-lg:disabled{opacity:.4;cursor:not-allowed}.btn-danger{background:var(--live-accent);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.live-active{display:flex;flex-direction:column;min-height:80vh;justify-content:space-between;animation:fadeIn var(--dur-slow) var(--ease) both}.live-hud{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--sp-4) 0}.live-hud__timer{text-align:left}.live-hud__timer .text-mono{font-family:JetBrains Mono,SF Mono,Cascadia Code,monospace;font-variant-numeric:tabular-nums;font-size:24px;color:var(--text-secondary)}.live-hud__reps{text-align:center;display:flex;flex-direction:column;align-items:center}.live-hud__reps .text-hero{font-size:64px;line-height:1;transition:transform .15s ease}.live-hud__confidence{display:flex;flex-direction:column;align-items:flex-end;gap:var(--sp-1)}.confidence-dot{width:12px;height:12px;border-radius:50%;background:var(--text-muted)}.confidence-dot--high{background:var(--accent)}.confidence-dot--medium{background:var(--amber)}.confidence-dot--low{background:var(--red);animation:pulse 1.5s ease-in-out infinite}@keyframes repPulse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.pulse{animation:repPulse .3s ease-out}.live-cue-display{display:flex;align-items:center;justify-content:center;padding:var(--sp-4) var(--sp-5);border-radius:var(--r-lg);text-align:center;animation:fadeIn .2s ease;margin:var(--sp-4) 0}.live-cue-display--correction{background:var(--amber-glow);border:1px solid var(--amber-dim);color:var(--amber)}.live-cue-display--safety{background:var(--red-glow);border:1px solid var(--red-dim);color:var(--red)}.live-cue-display--setup{background:#5b8fd41f;border:1px solid var(--blue-dim);color:var(--blue)}.live-cue-display--count{background:var(--accent-glow);border:1px solid var(--accent-dim);color:var(--accent)}.live-warning-banner{display:flex;align-items:center;justify-content:center;padding:var(--sp-3) var(--sp-4);background:var(--red-glow);border:1px solid var(--red-dim);border-radius:var(--r-md);color:var(--red);font-size:var(--font-body);font-weight:var(--weight-medium);animation:fadeIn .2s ease}.live-controls{padding:var(--sp-5) 0}.live-controls .btn-lg{border-radius:var(--r-lg)}.surface-card{background:var(--bg-surface);border:1px solid var(--border)}.radius-lg{border-radius:var(--r-lg)}.p-3{padding:var(--sp-3)}.mb-1{margin-bottom:var(--sp-1)}.mt-1{margin-top:var(--sp-1)}.angle-select-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);max-width:420px;margin:0 auto}.angle-btn{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);padding:var(--sp-5) var(--sp-3);background:var(--bg-surface);border:2px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:all var(--dur-fast) var(--ease);position:relative;color:var(--text-secondary)}.angle-btn:hover{background:var(--bg-elevated);border-color:#ffffff26;color:var(--text-primary);transform:translateY(-2px)}.angle-btn--recommended{border-color:var(--accent);background:linear-gradient(135deg,#5ab68a0f,#5ab68a05)}.angle-btn--recommended:hover{border-color:var(--accent);background:linear-gradient(135deg,#5ab68a1a,#5ab68a0a)}.angle-btn-icon{width:48px;height:48px;opacity:.8}.angle-btn-label{font-size:16px;font-weight:var(--weight-semi);color:var(--text-primary)}.angle-btn-desc{font-size:12px;color:var(--text-muted);text-align:center}.badge--rec{position:absolute;top:var(--sp-2);right:var(--sp-2);font-size:10px;font-weight:var(--weight-bold);padding:2px 8px;border-radius:var(--r-full);background:var(--accent);color:var(--bg-primary);text-transform:uppercase;letter-spacing:.05em}@media (max-width: 480px){.angle-select-grid{gap:var(--sp-2)}.angle-btn{padding:var(--sp-4) var(--sp-2)}.angle-btn-label{font-size:14px}}.exercise-tabs{display:flex;gap:var(--sp-2);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding:2px 0}.exercise-tabs::-webkit-scrollbar{display:none}.ex-tab{flex-shrink:0;padding:6px 14px;font-size:12px;font-weight:var(--weight-semi);color:var(--text-muted);background:#ffffff0a;border:1px solid transparent;border-radius:20px;transition:all .2s ease;cursor:pointer}.ex-tab:hover{color:var(--text-secondary);background:#ffffff0f}.ex-tab--active{color:var(--accent);background:#5ab68a1a;border-color:#5ab68a40}.set-tabs{display:flex;gap:var(--sp-1);overflow-x:auto;scrollbar-width:none;padding:2px 0}.set-tabs::-webkit-scrollbar{display:none}.set-tab{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--sp-2) var(--sp-3);background:var(--bg-elevated);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;min-width:64px}.set-tab:hover{background:var(--bg-hover)}.set-tab--active{border-color:var(--accent);background:#5ab68a14}.set-tab-angle{font-size:14px}.set-tab-label{font-size:10px;color:var(--text-muted);font-weight:var(--weight-semi)}.set-tab-score{font-size:14px;font-weight:var(--weight-bold)}.skeleton-row{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.8s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.session-card-clickable:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003;background:var(--bg-hover)!important}.session-card-clickable:active{transform:translateY(0);box-shadow:none}.hidden{display:none!important}
