:root{--font-display:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;font-family:var(--font-display);color:#f5fbff;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#061625}*{box-sizing:border-box}html,body,#root{width:100%;min-width:320px;min-height:100%;margin:0}body{min-height:100svh;overflow:hidden}button,input,meter{font:inherit}.squat-app{--bg:#0d0f0e;--panel:#171a18;--panel-soft:#1e231f;--line:#30362f;--text:#f7f6ed;--muted:#aeb5a8;--lime:#d7ff6d;--cyan:#64d9ff;--amber:#ffc65a;--red:#ff6b5f;--shadow:0 20px 70px #00000061;background:linear-gradient(135deg, #d7ff6d12, transparent 28%), radial-gradient(circle at 76% 22%, #64d9ff1f, transparent 34%), var(--bg);width:100vw;height:100svh;min-height:720px;color:var(--text);grid-template:"header header header"76px"left analyzer right"minmax(0,1fr)/252px minmax(0,1fr) 330px;gap:14px;padding:14px;display:grid;overflow:hidden}.app-header{grid-area:header;justify-content:space-between;align-items:center;min-width:0;padding:0 4px;display:flex}.brand,.status-strip,.group-title,.rail-button,.reset-button,.depth-header,.notes-card>div{align-items:center;display:flex}.brand{gap:14px;min-width:0}.brand svg{width:40px;height:40px;color:var(--lime);background:#d7ff6d1a;border:1px solid #d7ff6d52;padding:8px}.brand h1{letter-spacing:0;margin:0;font-size:31px;font-weight:900;line-height:1}.brand span,.status-strip,.group-title,.threshold-panel dt,.coach-card span,.angle-grid span,.depth-header span,.notes-card span{color:var(--muted);letter-spacing:0;text-transform:uppercase;font-size:12px;font-weight:800}.brand span{margin-top:5px;display:block}.status-strip{border:1px solid var(--line);min-height:40px;box-shadow:var(--shadow);background:#171a18b8;gap:10px;padding:0 13px}.status-dot{background:var(--amber);border-radius:50%;width:10px;height:10px;box-shadow:0 0 18px}.status-dot.is-loading{background:var(--amber)}.status-dot.is-ready{background:var(--lime)}.status-dot.is-error{background:var(--red)}.left-rail,.right-panel,.analyzer{min-height:0}.left-rail{flex-direction:column;grid-area:left;gap:12px;display:flex}.right-panel{flex-direction:column;grid-area:right;gap:12px;display:flex}.control-group,.coach-card,.angle-grid,.depth-card,.notes-card,.metric-ring{border:1px solid var(--line);box-shadow:var(--shadow);background:#171a18db;border-radius:8px}.control-group{padding:14px}.group-title{gap:8px;margin-bottom:12px}.group-title svg{width:17px;height:17px;color:var(--lime)}.segmented{border:1px solid var(--line);background:#101311;grid-template-columns:1fr 1fr;gap:4px;padding:4px;display:grid}button{color:inherit;cursor:pointer;border:0;border-radius:6px}.segmented button{min-height:39px;color:var(--muted);background:0 0;font-size:13px;font-weight:900}.segmented button.is-active{background:var(--lime);color:#11140f}.rail-button,.reset-button{width:100%;min-height:43px;color:var(--text);text-align:left;background:#111412;border:1px solid #0000;gap:10px;margin-top:8px;padding:0 12px;font-size:14px;font-weight:850}.rail-button:hover,.reset-button:hover,.play-button:hover{border-color:#d7ff6d7a}.rail-button.is-active{background:#d7ff6d1f;border-color:#d7ff6d99}.rail-button svg,.reset-button svg{width:18px;height:18px;color:var(--lime)}.threshold-panel dl{gap:10px;margin:0;display:grid}.threshold-panel div{justify-content:space-between;gap:12px;display:flex}.threshold-panel dt,.threshold-panel dd{margin:0}.threshold-panel dd{color:var(--text);font-size:14px;font-weight:900}.reset-button{background:#ff6b5f1c;min-height:52px;margin-top:auto}.analyzer{grid-area:analyzer;grid-template-rows:minmax(0,1fr) 82px;gap:12px;display:grid}.video-shell{border:1px solid var(--line);min-height:0;box-shadow:var(--shadow);background:#0b0e0c;border-radius:8px;position:relative;overflow:hidden}.input-video,.pose-canvas{width:100%;height:100%;position:absolute;inset:0}.input-video{object-fit:contain;background:#0b0e0c;transform:scaleX(-1)}.pose-canvas{z-index:2}.camera-empty{z-index:4;text-align:center;background:linear-gradient(135deg,#0b0e0ce6,#0f1518e0),radial-gradient(circle at 50% 45%,#ff6b5f29,#0000 35%);place-content:center;justify-items:center;gap:12px;padding:28px;display:grid;position:absolute;inset:0}.camera-empty svg{width:38px;height:38px;color:var(--red)}.camera-empty strong{font-size:26px;line-height:1.05}.camera-empty p{max-width:520px;color:var(--muted);margin:0;font-size:15px;font-weight:650;line-height:1.45}.camera-empty button{min-height:43px;color:var(--text);background:#d7ff6d24;border:1px solid #d7ff6d94;padding:0 16px;font-size:14px;font-weight:900}.stage-badge{z-index:3;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0b0e0cd1;border:1px solid #d7ff6d52;border-radius:8px;min-width:154px;padding:12px 14px;position:absolute;top:18px;left:18px}.stage-badge span,.stage-badge strong{display:block}.stage-badge span{color:var(--lime);font-size:25px;font-weight:950;line-height:1}.stage-badge strong{color:var(--muted);margin-top:6px;font-size:13px}.play-button{z-index:3;width:46px;height:46px;color:var(--text);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0b0e0cd1;border:1px solid #f7f6ed33;place-items:center;display:grid;position:absolute;bottom:18px;right:18px}.play-button svg{width:22px;height:22px}.phase-track{border:1px solid var(--line);min-height:82px;box-shadow:var(--shadow);background:#171a18db;border-radius:8px;grid-template-columns:repeat(5,1fr);gap:8px;padding:10px;display:grid}.phase-step{border:1px solid var(--line);color:var(--muted);text-align:center;background:#101311;border-radius:6px;place-items:center;font-size:13px;font-weight:900;display:grid}.phase-step.is-reached{color:var(--text);border-color:#64d9ff6b}.phase-step.is-current{color:var(--lime);background:#d7ff6d1f;border-color:#d7ff6dad}.score-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.metric-ring{text-align:center;place-items:center;min-height:132px;padding:16px;display:grid}.metric-ring strong{font-size:54px;font-weight:950;line-height:.9}.metric-ring span{color:var(--muted);text-transform:uppercase;margin-top:10px;font-size:13px;font-weight:900}.metric-ring.is-good strong{color:var(--lime)}.metric-ring.is-warn strong{color:var(--amber)}.coach-card{grid-template-columns:48px 1fr;gap:13px;min-height:154px;padding:16px;display:grid}.coach-card.is-warning{border-color:#ff6b5f73}.coach-card.is-ok{border-color:#d7ff6d6b}.coach-icon{width:48px;height:48px;color:var(--cyan);background:#64d9ff1a;border-radius:8px;place-items:center;display:grid}.coach-card.is-warning .coach-icon{color:var(--red);background:#ff6b5f1f}.coach-card.is-ok .coach-icon{color:var(--lime);background:#d7ff6d1f}.coach-icon svg{width:25px;height:25px}.coach-card strong{margin-top:6px;font-size:27px;line-height:1.05;display:block}.coach-card p,.notes-card p{color:var(--muted);margin:9px 0 0;font-size:14px;font-weight:650;line-height:1.42}.angle-grid{background:var(--line);grid-template-columns:1fr 1fr;gap:1px;display:grid;overflow:hidden}.angle-grid div{background:var(--panel);min-height:82px;padding:14px}.angle-grid strong{margin-top:8px;font-size:27px;line-height:1;display:block}.depth-card,.notes-card{padding:16px}.depth-header{justify-content:space-between}.depth-header strong,.notes-card strong{color:var(--text);font-size:22px}.depth-bar{background:#0f1210;border-radius:999px;height:13px;margin-top:14px;overflow:hidden}.depth-bar span{border-radius:inherit;background:linear-gradient(90deg, var(--cyan), var(--lime));height:100%;transition:width .18s;display:block}.notes-card>div{justify-content:space-between}@media (width<=1080px){.squat-app{grid-template:"header header"70px"left analyzer"minmax(460px,1fr)"right right"/220px minmax(0,1fr);min-height:100svh;overflow:auto}.right-panel{grid-template-columns:1fr 1.2fr 1fr;display:grid}.angle-grid,.depth-card,.notes-card{display:none}}@media (width<=760px){.squat-app{grid-template:"header""left""analyzer"minmax(420px,58vh)"right"/1fr;gap:10px;padding:10px}.app-header,.right-panel{display:block}.brand h1{font-size:25px}.status-strip{width:max-content;max-width:100%;margin-top:10px}.left-rail{flex-direction:column;gap:10px;min-height:auto;display:flex}.reset-button{min-height:46px;margin-top:0}.analyzer{grid-template-rows:minmax(0,1fr) auto}.phase-track{grid-template-columns:1fr}.score-row,.angle-grid{margin-bottom:10px}.stage-badge span{font-size:20px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important}}
