@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:60vh;max-height:600px;margin:0 auto}.camera-container{position:relative;width:100%;height:100%;overflow:hidden;display:flex;align-items:center;justify-content:center}.camera-wrapper.is-landscape{aspect-ratio:4/3;height:auto;max-height:80vh;width:100%}.camera-wrapper.is-portrait{aspect-ratio:3/4;max-height:70vh;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-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:.75rem 1rem;font-size:.85rem;font-weight:700;border-radius:12px;width:100%;text-align:center;line-height:1.2}.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:.5rem;padding:.25rem;width:100%;margin-top:.25rem;z-index:5}.camera-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-primary);padding:.4rem .8rem;border-radius:8px;font-size:.7rem;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:120px;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}.exercise-select{background:#0f172acc;border:1px solid rgba(255,255,255,.1);color:#fff;padding:.75rem 2.5rem .75rem 1rem;border-radius:12px;font-family:inherit;font-weight:600;font-size:.9rem;flex:1;min-width:140px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='white' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;transition:all .2s ease}.exercise-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #6366f133}.exercise-select option{background:var(--bg-dark);color:#fff}.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-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:.5rem;border-radius:20px;z-index:102}.session-toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.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}.hud-content{display:flex;flex-direction:column;gap:.5rem;flex:1;width:100%}.status-container,.result-container{width:100%}.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;flex-direction:column;gap:0;padding:0;background:#ffffff08;border-radius:12px;border:1px solid rgba(255,255,255,.05);overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.history-item.expandable{cursor:pointer}.history-item.expandable:hover{background:#ffffff0f;border-color:#6366f14d}.history-item.expanded{background:#0f172a99;border-color:var(--accent-primary);box-shadow:0 4px 20px #0006}.history-item-main{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;width:100%}.item-index{color:var(--accent-primary);font-weight:700;font-size:.8rem;min-width:24px}.item-name{flex:1;font-weight:600;font-size:.95rem}.item-reps{color:var(--success);font-weight:700;text-align:right;display:flex;flex-direction:column;align-items:flex-end}.item-summary-small{font-size:.7rem;color:var(--text-secondary);font-weight:500;margin-top:2px}.item-right{display:flex;align-items:center;gap:.75rem;margin-left:.5rem}.item-date{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.expand-icon{font-size:.6rem;color:var(--text-secondary);transition:transform .3s ease;opacity:.5}.expand-icon.rotated{transform:rotate(180deg);color:var(--accent-primary);opacity:1}.history-item-details{padding:.75rem 1rem 1rem;background:#0003;border-top:1px solid rgba(255,255,255,.05);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.details-header{display:grid;grid-template-columns:40px 1fr 1fr;font-size:.65rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.5rem}.detail-row{display:grid;grid-template-columns:40px 1fr 1fr;font-size:.85rem;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.03)}.detail-row:last-child{border-bottom:none}.detail-index{color:var(--text-secondary);font-size:.75rem}.detail-height{color:#fff;font-weight:600}.detail-time{color:var(--accent-primary);font-weight:500}.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)}
