*,*: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}.hidden{display:none!important}.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-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)}.rep-card .rep-score-mini{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:var(--weight-bold);border:2px solid}.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;gap:6px;align-items:center}.rep-card .rep-expand{font-size:10px;color:var(--text-muted);margin-left:6px;transition:transform var(--dur-fast) var(--ease)}.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}.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)}
