.upload-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);animation:fadeIn .4s ease}.drop-zone{width:100%;max-width:480px;padding:var(--space-3xl) var(--space-xl);border:1px dashed var(--border);border-radius:var(--radius-lg);background:var(--black-light);cursor:pointer;transition:all var(--transition-base);text-align:center;position:relative;overflow:hidden}.drop-zone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 50%,var(--accent-dim) 0%,transparent 70%);opacity:0;transition:opacity var(--transition-base)}.drop-zone:hover,.drop-zone.active{border-color:var(--accent);background:var(--black-elevated)}.drop-zone:hover:before,.drop-zone.active:before{opacity:1}.upload-icon,.file-icon{width:48px;height:48px;margin:0 auto var(--space-lg);color:var(--accent);position:relative}.upload-text{font-family:var(--font-accent);font-size:1.1rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--text-primary);margin-bottom:var(--space-xs);position:relative}.upload-subtext{font-size:.9rem;color:var(--text-secondary);margin-bottom:var(--space-lg);position:relative}.upload-hint{font-size:.75rem;color:var(--text-muted);position:relative}.file-selected{position:relative}.file-name{font-family:var(--font-accent);font-size:1rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--accent);word-break:break-all;margin-bottom:var(--space-xs)}.file-size{color:var(--text-secondary);font-size:.85rem}.analyze-btn{padding:var(--space-md) var(--space-2xl)}.tips{max-width:480px;width:100%;padding:var(--space-lg);background:var(--black-light);border:1px solid var(--border);border-radius:var(--radius-lg)}.tips h3{font-family:var(--font-body);font-size:.85rem;font-weight:400;letter-spacing:.02em;color:var(--text-tertiary);margin-bottom:var(--space-md)}.tips ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}.tips li{font-size:.875rem;color:var(--text-secondary);padding-left:var(--space-lg);position:relative}.tips li:before{content:"";position:absolute;left:0;top:.55em;width:4px;height:4px;background:var(--accent);border-radius:50%}.video-trimmer{max-width:720px;margin:0 auto;animation:fadeIn .4s ease}.video-trimmer h2{font-family:var(--font-display);font-size:1.5rem;font-weight:300;letter-spacing:.02em;color:var(--text-primary);text-align:center;margin-bottom:var(--space-xs)}.trimmer-hint{text-align:center;font-size:.9rem;color:var(--text-secondary);margin-bottom:var(--space-xl)}.video-container{background:var(--black);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-md);border:1px solid var(--border)}.video-container video{width:100%;max-height:360px;display:block;object-fit:contain;background:var(--black)}.playback-controls{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl)}.play-btn,.play-selection-btn{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border);background:var(--black-elevated);cursor:pointer;font-family:var(--font-accent);font-size:.8rem;font-weight:300;font-style:italic;letter-spacing:.02em;transition:all var(--transition-fast)}.play-btn{color:var(--text-primary)}.play-btn:hover{border-color:var(--border-hover);background:var(--black-hover)}.play-selection-btn{color:var(--accent);border-color:var(--accent-dim)}.play-selection-btn:hover{background:var(--accent-dim)}.time-display{margin-left:auto;font-family:SF Mono,Monaco,monospace;font-size:.8rem;color:var(--text-tertiary);letter-spacing:.02em}.trim-controls{background:var(--black-light);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-xl)}.trim-slider-container{position:relative;height:48px;margin-bottom:var(--space-lg)}.slider-track{position:absolute;top:50%;left:0;right:0;height:4px;background:var(--black-hover);border-radius:2px;transform:translateY(-50%)}.slider-selection{position:absolute;top:0;height:100%;background:var(--accent);border-radius:2px;opacity:.6}.slider-playhead{position:absolute;top:-6px;width:2px;height:16px;background:var(--text-primary);transform:translate(-50%);border-radius:1px}.slider-inputs{position:absolute;top:0;left:0;right:0;bottom:0}.trim-slider{position:absolute;width:100%;height:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;pointer-events:none}.trim-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:24px;background:var(--accent);border-radius:var(--radius-sm);cursor:pointer;pointer-events:auto;border:none;box-shadow:0 2px 8px #0006}.trim-slider::-moz-range-thumb{width:12px;height:24px;background:var(--accent);border-radius:var(--radius-sm);cursor:pointer;pointer-events:auto;border:none;box-shadow:0 2px 8px #0006}.start-slider::-webkit-slider-thumb{background:var(--success)}.end-slider::-webkit-slider-thumb{background:#f87171}.start-slider::-moz-range-thumb{background:var(--success)}.end-slider::-moz-range-thumb{background:#f87171}.trim-values{display:flex;justify-content:space-between;align-items:flex-start}.trim-value{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.trim-value label{font-family:var(--font-accent);font-size:.65rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--text-tertiary)}.trim-value span{font-family:SF Mono,Monaco,monospace;font-size:.95rem;color:var(--text-primary)}.trim-value span.warning{color:var(--warning)}.warning-text{font-size:.7rem!important;color:var(--warning)!important}.set-btn{padding:var(--space-xs) var(--space-sm);font-family:var(--font-accent);font-size:.65rem;font-weight:300;font-style:italic;letter-spacing:.02em;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.set-btn:hover{border-color:var(--border-hover);color:var(--text-primary)}.selection-info{flex:1;max-width:120px}.trimmer-actions{display:flex;justify-content:center;gap:var(--space-md)}.frame-preview{padding:var(--space-xl);animation:fadeIn .4s ease}.frame-preview h2{font-family:var(--font-display);font-size:1.1rem;font-weight:300;letter-spacing:.02em;color:var(--text-primary);margin-bottom:var(--space-xs)}.frame-subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:var(--space-lg)}.frames-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-md)}.frames-grid.five-phases{grid-template-columns:repeat(5,1fr)}@media (max-width: 700px){.frames-grid.five-phases{grid-template-columns:repeat(3,1fr)}}@media (max-width: 450px){.frames-grid.five-phases{grid-template-columns:repeat(2,1fr)}}.frame-item{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all var(--transition-base);background:var(--black);border:1px solid var(--border)}.frame-item:hover{border-color:var(--border-hover);transform:translateY(-2px)}.frame-item.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 8px 24px -8px var(--accent-glow)}.frame-image-container{position:relative;aspect-ratio:9/16;background:var(--black)}.frame-image-container img{width:100%;height:100%;object-fit:cover}.expand-btn{position:absolute;top:var(--space-sm);right:var(--space-sm);width:28px;height:28px;border-radius:var(--radius-sm);background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1);color:var(--text-primary);font-size:.9rem;cursor:pointer;opacity:0;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.frame-item:hover .expand-btn{opacity:1}.expand-btn:hover{background:#000000e6;border-color:var(--accent);color:var(--accent)}.frame-label{display:block;padding:var(--space-sm) var(--space-sm);font-family:var(--font-body);font-size:.75rem;font-weight:400;letter-spacing:.02em;text-align:center;color:var(--text-secondary);background:var(--black-elevated);border-top:1px solid var(--border)}.frame-item.selected .frame-label{background:var(--accent-dim);color:var(--accent);border-top-color:var(--accent-dim)}.frame-indicators{display:flex;justify-content:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:var(--black);border-top:1px solid var(--border)}.indicator{font-family:var(--font-accent);font-size:.7rem;font-weight:300;font-style:italic;letter-spacing:.02em;padding:2px 6px;border-radius:var(--radius-sm)}.indicator.good{background:var(--success-dim);color:var(--success)}.indicator.improve{background:var(--warning-dim);color:var(--warning)}.frame-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-xl);animation:fadeIn .2s ease}.frame-modal-content{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.frame-modal-content img{max-width:100%;max-height:75vh;border-radius:var(--radius-lg);border:1px solid var(--border)}.modal-phase{font-family:var(--font-accent);font-size:1rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--accent)}.modal-close{padding:var(--space-sm) var(--space-lg);background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-accent);font-size:.75rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{border-color:var(--border-hover);color:var(--text-primary)}.analysis-results{display:flex;flex-direction:column;gap:var(--space-xl);animation:fadeIn .4s ease .1s both}.overview{background:var(--black-light);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);text-align:center;animation:fadeIn .4s ease}.overview h2{font-family:var(--font-display);font-size:1.1rem;font-weight:300;letter-spacing:.02em;color:var(--accent);margin-bottom:var(--space-md)}.assessment{font-family:var(--font-accent);font-size:1.1rem;color:var(--text-primary);max-width:600px;margin:0 auto var(--space-lg);line-height:1.7}.priority-box{display:inline-flex;align-items:center;gap:var(--space-sm);background:var(--accent-dim);border:1px solid rgba(200,232,77,.2);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-lg)}.priority-label{font-family:var(--font-accent);font-size:.7rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--accent)}.priority-text{font-size:.9rem;color:var(--text-primary)}.phase-detail{border-top:1px solid var(--border)}.phase-detail-empty{border-top:1px solid var(--border);padding:var(--space-xl);text-align:center}.phase-detail-empty p{font-family:var(--font-accent);font-size:.95rem;color:var(--text-tertiary)}.phase-detail-header{background:var(--accent-dim);padding:var(--space-md) var(--space-xl);border-bottom:1px solid rgba(200,232,77,.15)}.phase-detail-header h3{font-family:var(--font-body);font-size:.95rem;font-weight:400;letter-spacing:.02em;color:var(--accent);margin:0}.phase-detail-content{display:grid;grid-template-columns:180px 1fr;gap:var(--space-xl);padding:var(--space-xl)}@media (max-width: 640px){.phase-detail-content{grid-template-columns:1fr}}.phase-detail-image{aspect-ratio:9/16;border-radius:var(--radius-lg);overflow:hidden;background:var(--black);border:1px solid var(--border)}.phase-detail-image img{width:100%;height:100%;object-fit:cover}.phase-detail-feedback{display:flex;flex-direction:column;gap:var(--space-lg)}.feedback-section h4{font-family:var(--font-accent);font-size:.7rem;font-weight:300;font-style:italic;letter-spacing:.02em;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border)}.feedback-section.strengths h4{color:var(--success)}.feedback-section.improvements h4{color:var(--warning)}.feedback-section ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}.feedback-section li{display:flex;align-items:flex-start;gap:var(--space-sm);font-size:.9rem;color:var(--text-secondary);line-height:1.6}.feedback-section .icon{flex-shrink:0;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-accent);font-size:.7rem;font-weight:300;font-style:italic;margin-top:2px}.feedback-section.strengths .icon{background:var(--success-dim);color:var(--success)}.feedback-section.improvements .icon{background:var(--warning-dim);color:var(--warning)}.improvement-list{display:flex;flex-direction:column;gap:var(--space-md)}.improvement-item{background:var(--black-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md)}.improvement-item .issue{display:flex;align-items:flex-start;gap:var(--space-sm);font-size:.9rem;color:var(--text-secondary);margin-bottom:var(--space-sm);line-height:1.5}.improvement-item .tip{padding:var(--space-sm) var(--space-md);background:var(--accent-dim);border-left:2px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.85rem;color:var(--text-primary);line-height:1.5}.improvement-item .tip-label{font-family:var(--font-accent);font-size:.65rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--accent);margin-right:var(--space-xs)}.drills-section{background:var(--black-light);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);animation:fadeIn .4s ease .2s both}.drills-section h3{font-family:var(--font-body);font-size:.95rem;font-weight:400;letter-spacing:.02em;color:var(--info);margin-bottom:var(--space-lg)}.drills{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-md)}.drill{padding:var(--space-lg);background:var(--info-dim);border:1px solid rgba(96,165,250,.15);border-radius:var(--radius-lg)}.drill h4{font-family:var(--font-accent);font-size:.85rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--info);margin-bottom:var(--space-sm)}.drill p{font-size:.9rem;color:var(--text-secondary);line-height:1.6}.password-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);background:radial-gradient(ellipse at 50% 0%,rgba(200,232,77,.03) 0%,transparent 50%),var(--black)}.password-gate-content{width:100%;max-width:360px;text-align:center}.brand-mark{margin-bottom:var(--space-xl);text-align:center}.brand-logo{max-width:160px;height:auto;display:block;margin:0 auto var(--space-md)}.brand-name{font-family:var(--font-condensed);font-size:2.5rem;font-weight:300;letter-spacing:.15em;text-transform:uppercase;color:var(--text-primary)}.password-tagline{font-family:var(--font-accent);font-size:1rem;color:var(--text-secondary);margin-bottom:var(--space-2xl)}.password-form{display:flex;flex-direction:column;gap:var(--space-md)}.password-input{width:100%;padding:var(--space-md) var(--space-lg);background:var(--black-elevated);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;color:var(--text-primary);text-align:center;letter-spacing:.1em;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.password-input::placeholder{color:var(--text-tertiary);letter-spacing:.02em}.password-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.password-error{font-size:.875rem;color:#ef4444}.password-submit{padding:var(--space-md) var(--space-xl);background:var(--accent);border:none;border-radius:var(--radius-md);font-family:var(--font-accent);font-size:.95rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--black);cursor:pointer;transition:all var(--transition-fast)}.password-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-glow)}.password-submit:disabled{opacity:.5;cursor:not-allowed}.password-hint{margin-top:var(--space-xl);font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--black)}.header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-xl);border-bottom:1px solid var(--border);background:var(--black);position:sticky;top:0;z-index:100}.header-brand{display:flex;align-items:center;gap:var(--space-sm)}.header-logo{height:36px;width:auto}.header-title{font-family:var(--font-condensed);font-size:1.25rem;font-weight:300;letter-spacing:.12em;text-transform:uppercase;color:var(--text-primary)}.header-badge{font-family:var(--font-accent);font-size:.75rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--accent);padding:var(--space-xs) var(--space-sm);border:1px solid var(--accent);border-radius:var(--radius-sm)}.main{flex:1;padding:var(--space-2xl);max-width:1100px;margin:0 auto;width:100%}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);text-align:center}.loading-spinner-container{position:relative;width:180px;height:180px;margin-bottom:var(--space-xl)}.loading-spinner{width:180px;height:180px;color:var(--accent)}.loading-logo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90px;height:90px;object-fit:contain;border-radius:var(--radius-md)}.loading-title{font-family:var(--font-display);font-size:1.5rem;font-weight:300;letter-spacing:.02em;color:var(--text-primary);margin-bottom:var(--space-sm)}.loading-subtitle{font-family:var(--font-accent);font-size:.95rem;color:var(--text-secondary)}.error-state{text-align:center;padding:var(--space-3xl)}.error-icon{width:48px;height:48px;margin:0 auto var(--space-lg);display:flex;align-items:center;justify-content:center;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:50%;font-family:var(--font-accent);font-size:1.25rem;font-style:italic;color:#ef4444}.error-title{font-family:var(--font-display);font-size:1.25rem;font-weight:300;letter-spacing:.02em;color:var(--text-primary);margin-bottom:var(--space-sm)}.error-message{color:var(--text-secondary);margin-bottom:var(--space-xl)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);font-family:var(--font-accent);font-size:.85rem;font-weight:300;font-style:italic;letter-spacing:.02em;cursor:pointer;transition:all var(--transition-fast);border:none}.btn-primary{background:var(--accent);color:var(--black)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-glow)}.btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-hover);color:var(--text-primary)}.results-container{display:flex;flex-direction:column;gap:var(--space-xl)}.phase-breakdown{background:var(--black-light);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;animation:fadeIn .4s ease .1s both}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.results-actions{display:flex;justify-content:center;padding-top:var(--space-lg)}.footer{padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--border);text-align:center}.footer span{font-family:var(--font-accent);font-size:.75rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--text-muted)}@media (max-width: 768px){.main{padding:var(--space-lg)}}@font-face{font-family:GT Standard;src:url(/fonts/GT-Standard-L-Standard-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:GT Standard Condensed;src:url(/fonts/GT-Standard-L-Condensed-Light.woff2) format("woff2");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:GT Planar;src:url(/fonts/GT-Planar-Italic-15-Light-Trial.woff2) format("woff2");font-weight:300;font-style:italic;font-display:swap}@font-face{font-family:GT Planar Retalic;src:url(/fonts/GT-Planar-Retalic-15-Light-Trial.woff2) format("woff2");font-weight:300;font-style:normal;font-display:swap}:root{--black: #0a0a0a;--black-light: #141414;--black-elevated: #1a1a1a;--black-hover: #222222;--accent: #c8e84d;--accent-dim: rgba(200, 232, 77, .15);--accent-glow: rgba(200, 232, 77, .4);--success: #34d399;--success-dim: rgba(52, 211, 153, .15);--warning: #fbbf24;--warning-dim: rgba(251, 191, 36, .15);--info: #60a5fa;--info-dim: rgba(96, 165, 250, .15);--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-tertiary: #666666;--text-muted: #444444;--border: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .15);--font-body: "GT Standard", -apple-system, sans-serif;--font-condensed: "GT Standard Condensed", -apple-system, sans-serif;--font-accent: "GT Planar", Georgia, serif;--font-display: "GT Planar Retalic", Georgia, serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--black);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh}::selection{background:var(--accent);color:var(--black)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--black)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
