:root{--bg: #0a0e0a;--surface: #111611;--card: #161e16;--border: #1e2e1e;--green: #4ade80;--green-accent: #86efac;--yellow: #facc15;--text: #e8f5e8;--muted: #6b8f6b;--red: #f87171;--blue: #60a5fa;--pink: #f472b6;--orange: #fb923c;--font: "DM Mono", "Fira Code", "Courier New", monospace;--radius: 10px;--border-1: 1px solid var(--border)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}html,body{overflow-x:hidden}body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.6;-webkit-font-smoothing:antialiased}#root{display:flex;flex-direction:column}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;border-bottom:var(--border-1);background:var(--surface)}.app-logo{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green);font-weight:500}.app-logo span{color:var(--muted)}.card{background:var(--card);border:var(--border-1);border-radius:var(--radius);padding:1.5rem}.label{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:.75rem}button{font-family:var(--font);cursor:pointer;letter-spacing:.08em;font-size:.8125rem;border-radius:var(--radius);border:none;transition:background .15s ease,color .15s ease,border-color .15s ease,opacity .15s ease;line-height:1;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:44px}button:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--green);color:#0a0e0a;padding:.75rem 2rem;font-weight:500}.btn-primary:hover:not(:disabled){background:var(--green-accent)}.btn-secondary{background:transparent;color:var(--text);padding:.75rem 2rem;border:var(--border-1)}.btn-secondary:hover:not(:disabled){border-color:var(--green);color:var(--green)}.roast-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;padding:1.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.roast-modal{background:var(--surface);border:1px solid rgba(239,68,68,.4);border-radius:16px;padding:2.5rem 2rem;max-width:480px;width:100%;display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center;box-shadow:0 0 60px #ef444426}.roast-modal-icon{font-size:3rem;line-height:1}.roast-modal-title{font-size:1.125rem;font-weight:500;letter-spacing:.05em;color:var(--text);margin:0}.roast-modal-roast{font-size:.9375rem;color:#f87171;line-height:1.6;margin:0}.roast-modal-warning{font-size:.75rem;color:var(--muted);background:#ffffff0a;border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;line-height:1.6;width:100%}.roast-modal-warning--danger{background:#ef44440f;border-color:#ef444459;color:#f87171}.roast-modal-warning strong{display:block;margin-bottom:.25rem;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}.roast-modal-close{width:100%;margin-top:.25rem}.error-banner{background:#f8717114;border:1px solid rgba(248,113,113,.3);border-radius:var(--radius);padding:1rem 1.25rem;color:var(--red);font-size:.8125rem;line-height:1.5}.error-banner strong{display:block;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.25rem;opacity:.8}.error-banner--roast{background:#ef44440f;border-color:#ef444459;color:#f87171;display:flex;flex-direction:column;gap:.5rem}.error-banner--roast strong:before{content:"🔥 "}.yt-manual-banner{background:#facc150f;border-color:#facc1540;color:var(--yellow);display:flex;flex-direction:column;gap:.5rem}.yt-manual-banner p{margin:0;opacity:.8}.yt-download-btn{display:inline-block;text-decoration:none;text-align:center;margin-top:.25rem;align-self:flex-start}.yt-native-banner{font-size:.75rem;padding:.65rem .9rem;border-radius:var(--radius);background:#4ade8012;border:1px solid rgba(74,222,128,.25);color:var(--green);line-height:1.5}.yt-native-banner.yt-native-info{background:#60a5fa12;border-color:#60a5fa40;color:var(--blue)}.yt-native-banner code{font-family:var(--font);background:#ffffff0f;padding:.1em .35em;border-radius:3px}.upload-step{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;min-height:100vh}.upload-wordmark{margin-bottom:3rem;text-align:center}.app-logo{width:280px;height:auto;display:block;margin:0 auto}.app-logo--small{width:140px}.upload-tagline{font-size:.875rem;color:var(--muted);letter-spacing:.03em;text-align:center;margin-top:.875rem;line-height:1.5}.upload-features{display:flex;gap:.625rem;flex-wrap:wrap;justify-content:center;margin-top:.75rem}.upload-features span{font-size:.6875rem;letter-spacing:.08em;color:var(--green);background:#4ade8012;border:1px solid rgba(74,222,128,.2);border-radius:99px;padding:.25rem .75rem}.drop-zone{width:100%;max-width:560px;border:2px dashed var(--border);border-radius:16px;padding:4rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;cursor:pointer;transition:border-color .2s ease,background .2s ease;background:var(--surface);text-align:center}.drop-zone:hover,.drop-zone.dragging{border-color:var(--green);background:#4ade800a}.drop-zone.dragging{border-style:solid}.drop-icon{font-size:2.5rem;line-height:1;opacity:.6}.drop-zone h2{font-size:1rem;letter-spacing:.05em;font-weight:400;color:var(--text)}.drop-zone p{font-size:.75rem;color:var(--muted);line-height:1.6}.drop-zone .browse-btn{background:transparent;border:var(--border-1);color:var(--green);padding:.5rem 1.5rem;font-size:.75rem;letter-spacing:.1em;border-color:var(--green);margin-top:.5rem}.drop-zone .browse-btn:hover{background:#4ade8014}.upload-error{margin-top:1rem;font-size:.75rem;color:var(--red);text-align:center}.upload-tabs{display:flex;gap:0;margin-bottom:1.5rem;border:var(--border-1);border-radius:8px;overflow:hidden;max-width:560px;width:100%}.upload-tab{flex:1;background:var(--surface);border:none;color:var(--muted);padding:.6rem 1rem;font-family:var(--font);font-size:.75rem;letter-spacing:.08em;cursor:pointer;transition:background .15s,color .15s}.upload-tab:first-child{border-right:var(--border-1)}.upload-tab.active{background:#4ade8014;color:var(--green)}.upload-tab:hover:not(.active){background:#ffffff08;color:var(--text)}.yt-input-wrap{width:100%;max-width:560px;border:2px dashed var(--border);border-radius:16px;padding:3rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;background:var(--surface);text-align:center}.yt-input-wrap h2{font-size:1rem;letter-spacing:.05em;font-weight:400;color:var(--text)}.yt-input-wrap p{font-size:.75rem;color:var(--muted)}.yt-input-row{display:flex;gap:.5rem;width:100%;flex-wrap:wrap;justify-content:center}.yt-input{flex:1;min-width:220px;background:var(--bg);border:var(--border-1);border-radius:6px;color:var(--text);font-family:var(--font);font-size:.75rem;padding:.55rem .75rem;outline:none;transition:border-color .15s}.yt-input:focus{border-color:var(--green)}.yt-input--valid,.yt-input--valid:focus{border-color:var(--green)}.yt-input--invalid,.yt-input--invalid:focus{border-color:#f87171}.yt-input-wrap .browse-btn:disabled{opacity:.4;cursor:not-allowed}.yt-input-wrap .browse-btn{background:transparent;border:var(--border-1);color:var(--green);padding:.5rem 1.25rem;font-size:.75rem;letter-spacing:.1em;border-color:var(--green);white-space:nowrap}.yt-input-wrap .browse-btn:hover{background:#4ade8014}.yt-embed{width:100%;height:100%;border:none;border-radius:8px;display:block}.config-step{flex:1;display:flex;flex-direction:column}.config-header{display:flex;align-items:center;gap:1rem;padding:1rem 2rem;border-bottom:var(--border-1);background:var(--surface)}.config-header-actions{margin-left:auto;display:flex;gap:.5rem}.btn-sm{padding:.375rem .875rem;font-size:.7rem}.config-logo{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green);font-weight:500;flex:1}.config-video-name{font-size:.75rem;color:var(--muted);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.config-body{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:0;max-height:calc(100vh - 57px);overflow:hidden}@media (max-width: 768px){.config-body{grid-template-columns:1fr;max-height:none;overflow:visible}.config-preview{border-right:none;border-bottom:var(--border-1);max-height:40vh;min-height:200px}.config-preview video,.config-preview .yt-embed{max-height:40vh}}.config-preview{background:#000;display:flex;align-items:center;justify-content:center;border-right:var(--border-1);overflow:hidden}.config-preview video,.config-preview .yt-embed{width:100%;height:100%;object-fit:contain;max-height:calc(100vh - 57px)}.config-panel{display:flex;flex-direction:column;overflow-y:auto;padding:2rem;gap:1.75rem;background:var(--surface)}.apikey-section{display:flex;flex-direction:column;gap:.5rem}.apikey-section input{background:var(--card);border:var(--border-1);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:.8125rem;padding:.65rem 1rem;outline:none;transition:border-color .15s ease;width:100%}.apikey-section input:focus{border-color:var(--green)}.apikey-section input::placeholder{color:var(--muted)}.apikey-hint{font-size:.6875rem;color:var(--muted);line-height:1.5;opacity:.8}.selector-group{display:flex;gap:.5rem;flex-wrap:wrap}.selector-btn{background:var(--card);border:var(--border-1);color:var(--muted);padding:.5rem 1rem;font-size:.75rem;letter-spacing:.05em;flex:1;min-width:0}.selector-btn:hover{border-color:var(--muted);color:var(--text)}.selector-btn.active{border-color:var(--green);color:var(--green);background:#4ade800f}.roast-toggle{display:flex;align-items:center;gap:.625rem;width:100%;background:var(--card);border:1px solid rgba(239,68,68,.3);color:var(--muted);padding:.625rem 1rem;font-size:.75rem;letter-spacing:.05em;cursor:pointer;transition:border-color .15s,background .15s,color .15s;text-align:left}.roast-toggle:hover{border-color:#ef444499;color:var(--text)}.roast-toggle.active{border-color:#ef4444;color:#ef4444;background:#ef444414}.roast-toggle-icon{font-size:1rem;line-height:1}.roast-toggle-text{flex:1}.roast-toggle-pill{font-size:.6rem;font-weight:700;letter-spacing:.08em;padding:.15rem .45rem;border-radius:999px;border:1px solid currentColor;opacity:.8}.roast-warning{margin-top:.5rem;font-size:.7rem;color:#ef4444b3;letter-spacing:.03em}.slider-row{display:flex;align-items:center;gap:.75rem}.slider-label{font-size:.6875rem;color:var(--muted);white-space:nowrap}input[type=range]{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:3px;background:var(--border);border-radius:2px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--green);cursor:pointer;border:2px solid var(--bg)}input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--green);cursor:pointer;border:2px solid var(--bg)}.slider-value{font-size:.75rem;color:var(--green);min-width:2ch;text-align:center}.config-cta{margin-top:auto;padding-top:.5rem;display:flex;flex-direction:row;gap:.75rem}.config-cta .btn-secondary{flex-shrink:0;padding:1rem 1.25rem;font-size:.8rem;letter-spacing:.08em}.config-cta .btn-primary{flex:1;padding:1rem;font-size:.875rem;letter-spacing:.12em}.analysing-step{flex:1;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;padding:2rem}.analysing-logo{font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--green);opacity:.6}.analysing-icon{font-size:3rem;animation:spin 4s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.analysing-status{display:flex;align-items:center;gap:.25rem;font-size:.9375rem;color:var(--text);letter-spacing:.02em}.analysing-dots{display:inline-flex;gap:2px}.analysing-dots span{animation:dotPulse 1.4s infinite ease-in-out;color:var(--green);font-size:1.2em;line-height:1}.analysing-dots span:nth-child(1){animation-delay:0s}.analysing-dots span:nth-child(2){animation-delay:.2s}.analysing-dots span:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:.15;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}.analysing-tip{font-size:.75rem;color:var(--muted);letter-spacing:.05em}.results-step{flex:1;display:flex;flex-direction:column}.results-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;border-bottom:var(--border-1);background:var(--surface);gap:1rem;flex-wrap:wrap}.results-logo{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green);font-weight:500}.results-actions-top{display:flex;gap:.75rem}.results-actions-top button{padding:.5rem 1.25rem;font-size:.75rem}.results-body{flex:1;padding:2rem;max-width:1100px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:1.25rem}.report-header-card{background:var(--card);border:var(--border-1);border-radius:var(--radius);padding:1.75rem 2rem}.report-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.report-title{display:flex;flex-direction:column;gap:.25rem}.report-title .label{margin-bottom:0}.report-player{font-size:1.25rem;letter-spacing:.06em;color:var(--text)}.skill-badge{padding:.35rem .9rem;border-radius:6px;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;white-space:nowrap}.skill-badge.beginner{background:#60a5fa26;color:var(--blue);border:1px solid rgba(96,165,250,.3)}.skill-badge.intermediate{background:#facc151f;color:var(--yellow);border:1px solid rgba(250,204,21,.25)}.skill-badge.advanced{background:#4ade801f;color:var(--green);border:1px solid rgba(74,222,128,.25)}.skill-badge.elite{background:#f472b61f;color:var(--pink);border:1px solid rgba(244,114,182,.25)}.report-summary{font-size:.875rem;color:var(--text);line-height:1.7;opacity:.9}.report-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media (max-width: 640px){.report-two-col{grid-template-columns:1fr}}.strengths-card,.improvements-card{background:var(--card);border:var(--border-1);border-radius:var(--radius);padding:1.5rem}.strengths-card{border-color:#4ade8033}.improvements-card{border-color:#facc1526}.strengths-list,.improvements-list{list-style:none;display:flex;flex-direction:column;gap:.65rem}.strengths-list li{font-size:.8125rem;line-height:1.5;color:var(--green-accent);padding-left:1.25rem;position:relative}.strengths-list li:before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:500}.improvements-list li{font-size:.8125rem;line-height:1.5;color:#fde68a;padding-left:1.25rem;position:relative}.improvements-list li:before{content:"→";position:absolute;left:0;color:var(--yellow)}.analysis-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media (max-width: 640px){.analysis-grid{grid-template-columns:1fr}}.analysis-card{background:var(--card);border:var(--border-1);border-radius:var(--radius);padding:1.5rem}.analysis-card.full-width{grid-column:1 / -1}.analysis-card p{font-size:.8125rem;line-height:1.7;color:var(--text);opacity:.85}.drills-card{background:var(--card);border:var(--border-1);border-radius:var(--radius);padding:1.5rem 2rem;border-color:#86efac2e}.drills-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media (max-width: 640px){.drills-grid{grid-template-columns:1fr}}.drill-item{display:flex;gap:.875rem;align-items:flex-start}.drill-number{font-size:.625rem;letter-spacing:.15em;color:var(--green);background:#4ade801a;border:1px solid rgba(74,222,128,.2);border-radius:4px;padding:.2rem .4rem;white-space:nowrap;margin-top:.15rem;flex-shrink:0}.drill-text{font-size:.8125rem;line-height:1.7;color:var(--text);opacity:.85}.priority-fix-banner{display:flex;align-items:flex-start;gap:.875rem;background:#fb923c14;border:1px solid rgba(251,146,60,.3);border-radius:12px;padding:1rem 1.25rem}.priority-fix-icon{font-size:1.25rem;line-height:1;flex-shrink:0;margin-top:.1rem}.priority-fix-label{font-size:.625rem;letter-spacing:.15em;text-transform:uppercase;color:#fb923ccc;margin-bottom:.25rem}.priority-fix-text{font-size:.9375rem;font-weight:500;color:var(--text);line-height:1.5}.scores-panel{padding:1.5rem}.scores-panel-inner{display:flex;align-items:center;gap:2rem}@media (max-width: 640px){.scores-panel-inner{flex-direction:column;align-items:stretch;gap:1.25rem}}.radar-svg{flex-shrink:0}.score-bars{flex:1;display:flex;flex-direction:column;gap:.625rem}.score-bar-row{display:flex;align-items:center;gap:.625rem}.score-bar-label{font-size:.75rem;color:var(--muted);width:7rem;flex-shrink:0}.score-bar-track{flex:1;height:5px;background:#ffffff12;border-radius:99px;overflow:hidden}.score-bar-fill{height:100%;border-radius:99px}.score-bar-num{font-size:.8125rem;font-weight:500;width:1.5rem;text-align:right;flex-shrink:0}.bullet-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem;padding:0}.bullet-list li{font-size:.8125rem;line-height:1.55;color:var(--text);padding-left:1.1rem;position:relative}.bullet-list li:before{content:"▸";position:absolute;left:0;color:var(--bullet-color, rgba(56,189,248,.9));font-size:.625rem;top:.25em}.common-errors-card{padding:1.5rem}.common-errors-list{list-style:none;display:flex;flex-direction:column;gap:.625rem;padding:0;margin:0}.common-errors-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.8125rem;line-height:1.55;color:var(--text)}.error-num{font-size:.625rem;letter-spacing:.1em;color:#f87171e6;background:#f871711a;border:1px solid rgba(248,113,113,.2);border-radius:4px;padding:.15rem .35rem;flex-shrink:0;margin-top:.1rem;font-weight:600}.shot-breakdown-card{padding:1.5rem}.shot-breakdown-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.shot-item{background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:.75rem .875rem;display:flex;flex-direction:column;gap:.375rem}.shot-badge{font-size:.625rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:#38bdf8e6;background:#38bdf81a;border:1px solid rgba(56,189,248,.2);border-radius:4px;padding:.15rem .4rem;align-self:flex-start}.shot-observation{font-size:.775rem;line-height:1.5;color:var(--text);opacity:.8}.results-bottom-actions{display:flex;gap:1rem;padding:1.5rem 2rem;border-top:var(--border-1);background:var(--surface);justify-content:center}.results-bottom-actions button{min-width:160px}.tier-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.tier-card{background:var(--card);border:var(--border-1);border-radius:var(--radius);padding:.875rem;display:flex;flex-direction:column;gap:.35rem;text-align:left;color:var(--muted);transition:border-color .15s ease,background .15s ease,color .15s ease}.tier-card:hover{border-color:var(--muted);color:var(--text)}.tier-card.active{border-color:var(--green);background:#4ade800d;color:var(--text)}.tier-card-top{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.tier-icon{font-size:1rem;line-height:1}.tier-name{font-size:.875rem;font-weight:500;letter-spacing:.03em;color:var(--text)}.tier-badge{font-size:.5rem;letter-spacing:.12em;text-transform:uppercase;padding:.15rem .4rem;border-radius:3px;font-weight:500;margin-left:auto}.tier-badge-best{background:#4ade8026;color:var(--green);border:1px solid rgba(74,222,128,.3)}.tier-badge-default{background:#6b8f6b26;color:var(--muted);border:1px solid var(--border)}.tier-tagline{font-size:.6875rem;line-height:1.4;color:inherit;opacity:.85}.tier-card.active .tier-tagline{opacity:1}.tier-bullets{list-style:none;display:flex;flex-direction:column;gap:.15rem;margin-top:.1rem}.tier-bullets li{font-size:.625rem;letter-spacing:.03em;color:var(--muted);padding-left:.875rem;position:relative;line-height:1.4}.tier-bullets li:before{content:"·";position:absolute;left:.25rem;color:var(--border)}.tier-card.active .tier-bullets li:before{color:var(--green);opacity:.6}.tier-footer{display:flex;align-items:center;justify-content:space-between;gap:.25rem;margin-top:.25rem;padding-top:.375rem;border-top:1px solid var(--border)}.tier-time{font-size:.5625rem;letter-spacing:.08em;color:var(--muted);opacity:.7}.tier-model{font-size:.5625rem;letter-spacing:.04em;color:var(--muted);opacity:.6;text-align:right}.tier-card.active .tier-model{color:var(--green);opacity:.6}.analysis-card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.analysis-card-score{font-size:1rem;font-weight:500;letter-spacing:-.01em;line-height:1;flex-shrink:0}.frame-strip-section{overflow:hidden}.frame-strip{display:flex;gap:.625rem;overflow-x:auto;padding-bottom:.5rem;margin-top:.75rem;scrollbar-width:thin;scrollbar-color:var(--border) transparent;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity}.frame-strip::-webkit-scrollbar{height:4px}.frame-strip::-webkit-scrollbar-track{background:transparent}.frame-strip::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.frame-thumb{flex-shrink:0;width:110px;background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;padding:0;display:flex;flex-direction:column;align-items:stretch;scroll-snap-align:start;transition:border-color .15s,transform .15s;position:relative}.frame-thumb:hover{border-color:var(--muted);transform:translateY(-2px)}.frame-thumb.has-moment{border-width:1.5px}.frame-thumb.is-strength{border-color:var(--green);box-shadow:0 0 0 1px #4ade8033}.frame-thumb.is-improvement{border-color:var(--yellow);box-shadow:0 0 0 1px #facc1533}.frame-thumb-img-wrap{position:relative;aspect-ratio:16/9;overflow:hidden;background:#000}.frame-thumb-img-wrap img{width:100%;height:100%;object-fit:cover;display:block}.frame-badge{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;line-height:1}.frame-badge.strength{background:var(--green);color:#0a0e0a}.frame-badge.improvement{background:var(--yellow);color:#0a0e0a}.frame-time{display:block;font-size:.625rem;color:var(--muted);padding:.3rem .5rem .1rem;letter-spacing:.05em}.frame-km-label{display:block;font-size:.5625rem;letter-spacing:.04em;padding:0 .5rem .4rem;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frame-thumb.is-strength .frame-km-label{color:var(--green)}.frame-thumb.is-improvement .frame-km-label{color:var(--yellow)}.frame-expanded{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0e0ae6;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.frame-expanded-inner{background:var(--card);border:var(--border-1);border-radius:var(--radius);max-width:860px;width:100%;overflow:hidden;display:flex;flex-direction:column}.frame-expanded-inner img{width:100%;max-height:55vh;object-fit:contain;background:#000;display:block}.frame-expanded-meta{padding:1rem 1.25rem .75rem;display:flex;flex-direction:column;gap:.35rem}.frame-expanded-time{font-size:.75rem;color:var(--muted);letter-spacing:.05em}.frame-expanded-km{font-size:.8125rem;font-weight:500;letter-spacing:.04em}.frame-expanded-km.strength{color:var(--green)}.frame-expanded-km.improvement{color:var(--yellow)}.frame-expanded-obs{font-size:.8125rem;color:var(--text);line-height:1.6;opacity:.85}.frame-expanded-close{align-self:flex-end;background:transparent;border:var(--border-1);color:var(--muted);font-size:.75rem;padding:.4rem .875rem;margin:0 1.25rem 1rem;letter-spacing:.08em}.frame-expanded-close:hover{color:var(--text);border-color:var(--muted)}.radar-section{padding:1.5rem}.radar-body{display:grid;grid-template-columns:260px 1fr;gap:2rem;align-items:center;margin-top:.75rem}@media (max-width: 640px){.radar-body{grid-template-columns:1fr}.radar-chart-wrap{max-width:260px;margin:0 auto}}.radar-chart-wrap{flex-shrink:0}.radar-svg{width:100%;max-width:260px;display:block}.score-bars{display:flex;flex-direction:column;gap:.875rem}.score-bar-row{display:flex;flex-direction:column;gap:.3rem}.score-bar-meta{display:flex;align-items:baseline;justify-content:space-between}.score-bar-label{font-size:.75rem;color:var(--text);letter-spacing:.04em}.score-bar-value{font-size:.9375rem;font-weight:500;letter-spacing:-.01em}.score-bar-max{font-size:.625rem;opacity:.45;font-weight:400}.score-bar-track{height:5px;background:var(--border);border-radius:3px;overflow:hidden}.score-bar-fill{height:100%;border-radius:3px;transition:width .8s cubic-bezier(.16,1,.3,1)}.pose-court-row{display:flex;flex-direction:column;gap:1.25rem}.pose-court-row.has-both{display:grid;grid-template-columns:1fr auto;gap:1.25rem;align-items:start}@media (max-width: 760px){.pose-court-row.has-both{grid-template-columns:1fr}}.pose-stats-section{flex:1}.pose-stats-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.pose-stats-source{font-size:.625rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);opacity:.7}.pose-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}@media (max-width: 500px){.pose-stats-grid{grid-template-columns:1fr}}.pose-stat-card{background:var(--surface);border:var(--border-1);border-radius:8px;padding:.875rem 1rem;display:flex;flex-direction:column;gap:.3rem;align-items:flex-start}.pose-stat-name{margin-bottom:0!important}.pose-stat-value{font-size:1.375rem;font-weight:500;color:var(--text);letter-spacing:-.02em;line-height:1}.pose-stat-label{font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;font-weight:500;padding:.2rem .5rem;border-radius:4px}.pose-quality-good{color:var(--green);background:#4ade801a;border:1px solid rgba(74,222,128,.2)}.pose-quality-ok{color:var(--yellow);background:#facc1514;border:1px solid rgba(250,204,21,.15)}.pose-quality-bad{color:var(--red);background:#f8717114;border:1px solid rgba(248,113,113,.15)}.pose-quality-neutral{color:var(--muted);background:transparent;border:1px solid var(--border)}.pose-range-note{font-size:.6875rem;color:var(--muted);margin-top:.875rem;line-height:1.5}.pose-range-hint{opacity:.6}.pose-warning{font-size:.8125rem;color:var(--yellow);opacity:.85;line-height:1.5}.court-heatmap-section{flex-shrink:0}.court-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.court-method-badge{font-size:.5625rem;font-family:var(--font);letter-spacing:.06em;padding:.2em .55em;border-radius:3px;font-weight:600;text-transform:uppercase}.court-method-badge.badge-opencv{background:#4ade801f;color:var(--green);border:1px solid rgba(74,222,128,.3)}.court-method-badge.badge-pose{background:#facc1514;color:var(--yellow);border:1px solid rgba(250,204,21,.2)}.court-heatmap-wrap{display:flex;gap:1.25rem;align-items:flex-start;margin-top:.25rem}.court-svg-wrap{flex-shrink:0}.court-svg{width:120px;display:block;border-radius:4px;overflow:hidden}.court-heatmap-info{display:flex;flex-direction:column;gap:1rem;padding-top:.25rem}.court-legend{display:flex;flex-direction:column;gap:.35rem}.court-legend-bar{width:80px;height:8px;border-radius:4px;background:linear-gradient(to right,#4ade8014,#4ade80d9);border:1px solid var(--border)}.court-legend-labels{display:flex;justify-content:space-between;width:80px;font-size:.5625rem;color:var(--muted);letter-spacing:.05em}.court-stats{display:flex;flex-direction:column;gap:.4rem}.court-stat-row{display:flex;flex-direction:column;gap:.1rem}.court-stat-key{font-size:.5625rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.court-stat-val{font-size:.75rem;color:var(--text)}input[type=url],input[type=text],input[type=password]{font-size:16px}@supports (padding: env(safe-area-inset-bottom)){.upload-step{padding-bottom:calc(2rem + env(safe-area-inset-bottom))}.results-bottom-actions{padding-bottom:calc(1.5rem + env(safe-area-inset-bottom))}.config-cta{padding-bottom:env(safe-area-inset-bottom)}}@media (max-width: 768px){.results-body{padding:1.25rem 1rem}.results-header{padding:.75rem 1rem}.report-header-card,.drills-card,.scores-panel,.common-errors-card,.shot-breakdown-card{padding:1.25rem 1rem}}@media (max-width: 480px){.upload-step{padding:2.5rem 1rem 1.25rem;justify-content:flex-start}.upload-wordmark{margin-bottom:2rem}.app-logo{width:200px}.app-logo--small{width:110px}.upload-tabs{margin-bottom:1rem}.drop-zone{padding:2.5rem 1.25rem;border-radius:12px}.drop-zone h2{font-size:.9375rem}.yt-input-wrap{padding:2rem 1.25rem;border-radius:12px}.yt-input-row{flex-direction:column;align-items:stretch}.yt-input-row .browse-btn{width:100%;text-align:center}.yt-input{font-size:.875rem}.config-header{padding:.75rem 1rem;gap:.5rem}.config-video-name{max-width:110px;font-size:.6875rem}.config-panel{padding:1.25rem 1rem;gap:1.25rem}.config-cta{flex-direction:column-reverse}.config-cta .btn-secondary,.config-cta .btn-primary{width:100%;text-align:center;padding:1rem}.tier-card{padding:.75rem .625rem}.tier-name{font-size:.8125rem}.selector-btn{flex:1 1 calc(50% - .25rem);min-width:0}.results-body{padding:.875rem;gap:.875rem}.results-header{padding:.625rem .875rem}.results-actions-top button{padding:.5rem .75rem;font-size:.7rem;min-height:36px}.report-header-card{padding:1rem .875rem}.report-player{font-size:1.1rem}.priority-fix-text{font-size:.875rem}.results-bottom-actions{padding:.875rem;gap:.5rem}.results-bottom-actions button{flex:1;min-width:0;padding:.875rem .5rem}.scores-panel-inner{align-items:center}.radar-svg{width:160px;height:160px}.score-bar-label{width:6rem;font-size:.7rem}.frame-thumb{width:120px}.shot-breakdown-grid{grid-template-columns:1fr 1fr}.analysis-card,.strengths-card,.improvements-card,.drills-card,.common-errors-card,.shot-breakdown-card,.scores-panel{padding:1rem .875rem}.analysing-step{padding:1.5rem 1rem}}
