@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;700;800&display=swap";.app-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:1rem;gap:1.5rem;background-color:var(--bg-primary);color:var(--text-primary)}.header{text-align:center;margin-bottom:.5rem;flex-shrink:0}h1{font-size:clamp(1.5rem,4vw,2.5rem);font-weight:800;letter-spacing:-.02em;margin-bottom:.2rem}.subtitle{color:var(--text-secondary);font-size:.85rem;max-width:400px}.camera-section{width:100%;max-width:800px;display:flex;flex-direction:column;gap:1.5rem}.camera-view-module{display:flex;flex-direction:column;width:100%}.camera-wrapper{position:relative;width:100%;min-height:200px;background-color:#000;border-radius:20px;overflow:hidden;box-shadow:0 10px 30px -5px #00000080;border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;height:30vh;max-height:400px;margin:0 auto}.camera-container{position:relative;width:100%;height:100%;overflow:hidden;display:flex;align-items:center;justify-content:center}.camera-wrapper.is-portrait{aspect-ratio:3/4;max-height:25vh;width:auto}.camera-video,.camera-canvas{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain}.camera-canvas{background:transparent}.camera-video{background:#000}.camera-container.needs-rotation .camera-video,.camera-container.needs-rotation .camera-canvas{width:auto;height:100%}.hud-content{display:flex;align-items:center;gap:1.5rem;flex:1}.hud-top{display:flex;align-items:center;gap:1rem}.rep-counter{padding:.5rem 1rem;border-radius:12px;display:flex;align-items:center;gap:.5rem;background:#6366f11a;border:1px solid rgba(99,102,241,.2)}.rep-label{font-size:.65rem;font-weight:700;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.05em}.rep-value{font-size:2rem;font-weight:800;line-height:1;color:#fff}.fps-badge{font-size:.7rem;font-weight:600;color:var(--success);padding:6px 12px;background:#0f172a99;border-radius:100px;border:1px solid rgba(16,185,129,.2)}.feedback-inline{flex:1;display:flex;align-items:center}.feedback-message-compact{padding:.5rem 1rem;font-size:.9rem;font-weight:600;border-radius:100px;width:100%}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:8px 16px;border-radius:100px;font-weight:500;font-size:.8rem;letter-spacing:.02em}.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.result-overlay{background:#0f172ae6;display:flex;align-items:center;justify-content:center;text-align:center;padding:2rem}.result-card{max-width:320px;width:100%;padding:3rem 2rem;display:flex;flex-direction:column;gap:1rem}.result-title{font-size:1.5rem;font-weight:700;color:var(--success)}.result-stat{display:flex;flex-direction:column}.stat-value{font-size:5rem;font-weight:800;line-height:1}.stat-label{color:var(--text-secondary);font-weight:600}.btn-primary{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;font-weight:700;margin-top:1rem}.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 10px 15px -3px #6366f14d}.camera-toolbar{display:flex;justify-content:center;gap:.75rem;padding:.5rem;width:100%;margin-top:.5rem;z-index:5}.camera-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-primary);padding:.6rem 1.2rem;border-radius:12px;font-size:.75rem;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex:1;max-width:200px;text-align:center}.camera-btn:hover{background:#ffffff1a;border-color:var(--accent-primary)}.camera-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:0 0 15px #6366f14d}.footer-info{margin-top:auto;color:var(--text-secondary);font-size:.8rem;text-align:center;opacity:.7}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.exercise-controls{padding:1rem;border-radius:20px;display:flex;flex-direction:column;gap:1rem;z-index:5;background:#0f172a66;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.exercise-selector{display:flex;gap:.5rem;background:#ffffff0d;padding:4px;border-radius:12px}.selector-btn{flex:1;padding:8px;border:none;background:transparent;color:var(--text-secondary);font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;font-size:.9rem}.selector-btn.active{background:var(--accent-primary);color:#fff;box-shadow:0 4px 12px #6366f14d}.exercise-tips h4{font-size:.8rem;margin-bottom:.3rem;color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.05em}.exercise-tips ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.2rem}.exercise-tips li{font-size:.8rem;color:var(--text-secondary);display:flex;align-items:center;gap:.4rem}.exercise-tips li:before{content:"•";color:var(--accent-primary)}.orientation-selector{padding:1rem;background:#ffffff0d;border-radius:16px;display:flex;flex-direction:column;gap:.75rem}.selector-label{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.orientation-options{display:flex;gap:.5rem;flex-wrap:wrap}.option-btn{flex:1;min-width:80px;padding:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff08;color:var(--text-secondary);font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;font-size:.75rem}.option-btn:hover{background:#ffffff14;border-color:#fff3}.option-btn.active{background:var(--accent-secondary);color:#fff;border-color:var(--accent-secondary);box-shadow:0 4px 10px #f43f5e4d}.start-btn{width:100%;padding:.8rem;font-size:.9rem;letter-spacing:.1em}.session-controls{width:100%;margin-top:-.5rem;padding:.75rem;border-radius:20px;z-index:102}.session-toolbar{display:flex;align-items:center;gap:1rem}.session-toggle-btn{padding:.75rem 1.5rem;border-radius:12px;font-weight:800;font-size:.9rem;letter-spacing:.05em;cursor:pointer;transition:all .2s;min-width:140px;border:none;text-transform:uppercase}.session-toggle-btn.start{background:var(--accent-primary);color:#fff;box-shadow:0 4px 15px #6366f166}.session-toggle-btn.stop{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.session-toggle-btn.stop:hover{background:#ef444433;border-color:#ef4444}.status-container,.result-container{flex:1}.result-card-compact{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;border-radius:12px}.result-title-compact{font-size:.8rem;font-weight:700;color:var(--success)}.stat-value-compact{font-size:1.5rem;font-weight:800}.stat-label-compact{font-size:.7rem;color:var(--text-secondary)}.btn-primary-compact{padding:.4rem .8rem;font-size:.75rem;border-radius:8px;background:var(--success);color:#fff;border:none;font-weight:600}.system-info-compact{font-size:9px;font-family:monospace;opacity:.3;position:absolute;right:1.5rem;bottom:.5rem}.history-section{width:100%;max-width:800px;padding:1.5rem;border-radius:20px;margin-top:1rem}.history-section h3{font-size:1rem;margin-bottom:.5rem}.history-list{display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;min-height:0}.history-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#ffffff08;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.item-index{color:var(--accent-primary);font-weight:700;font-size:.8rem}.item-name{flex:1;font-weight:600}.item-reps{color:var(--success);font-weight:700}.item-date{font-size:.75rem;color:var(--text-secondary)}.no-history{text-align:center;color:var(--text-secondary);padding:1rem}.active-session{border:2px solid var(--accent-primary);animation:border-pulse 2s infinite}@keyframes border-pulse{0%{border-color:#6366f14d}50%{border-color:#6366f1}to{border-color:#6366f14d}}:root{font-family:Outfit,Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;--bg-dark: #0f172a;--bg-card: rgba(30, 41, 59, .5);--accent-primary: #6366f1;--accent-secondary: #818cf8;--text-primary: #f8fafc;--text-secondary: #94a3b8;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;color:var(--text-primary);background-color:var(--bg-dark);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-height:100vh;background:radial-gradient(circle at 50% -20%,#1e293b 0%,var(--bg-dark) 80%);overflow-x:hidden}#root{width:100%;min-height:100vh}.glass{background:var(--bg-card);backdrop-filter:blur(16px) saturate(120%);-webkit-backdrop-filter:blur(16px) saturate(120%);border:1px solid rgba(255,255,255,.08);border-radius:20px}.glass-dark{background:#0f172acc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.05)}.gradient-text{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.soft-shadow{box-shadow:0 20px 25px -5px #0003,0 10px 10px -5px #0000001a}button{cursor:pointer;border:none;border-radius:12px;padding:12px 24px;font-family:inherit;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}button:active{transform:scale(.96)}
