@import"https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,300..700,0..1,-50..200&display=swap";:root{color-scheme:light;--font-display: "Sora", "Avenir Next", "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--bg: #ebe9e4;--bg-overlay: radial-gradient(1200px 700px at 115% -10%, rgba(0, 0, 0, .11), transparent 58%), radial-gradient(800px 540px at -15% 0%, rgba(255, 255, 255, .92), transparent 60%), linear-gradient(180deg, #f3f2ee 0%, #e9e7e1 100%);--surface-1: #fcfbf8;--surface-2: #f2f1ec;--surface-3: #e7e5de;--text-1: #171614;--text-2: #4b4842;--text-3: #7b7770;--line: #d6d3cb;--line-strong: #bcb8ae;--accent: #111111;--accent-soft: #2c2924;--accent-contrast: #faf8f2;--positive: #1f8f55;--negative: #ca3f49;--radius-sm: 9px;--radius-md: 13px;--radius-lg: 18px;--radius-xl: 24px;--radius-pill: 999px;--shadow-panel: 0 22px 36px rgba(18, 18, 18, .1);--shadow-soft: 0 8px 16px rgba(18, 18, 18, .08);--shadow-button: 0 12px 18px rgba(14, 14, 14, .2)}.dark{color-scheme:dark;--bg: #050505;--bg-overlay: radial-gradient(1200px 780px at 118% -8%, rgba(120, 120, 120, .25), transparent 60%), radial-gradient(900px 520px at -20% -8%, rgba(64, 64, 64, .2), transparent 62%), linear-gradient(180deg, #080808 0%, #030303 100%);--surface-1: #111111;--surface-2: #191919;--surface-3: #232323;--text-1: #f4f2ec;--text-2: #c2bfb6;--text-3: #8d897f;--line: #2f2f2d;--line-strong: #444440;--accent: #f5f3eb;--accent-soft: #dddbd2;--accent-contrast: #0b0b0b;--positive: #4ecc8c;--negative: #ff7f89;--shadow-panel: 0 24px 38px rgba(0, 0, 0, .5);--shadow-soft: 0 8px 18px rgba(0, 0, 0, .35);--shadow-button: 0 12px 24px rgba(0, 0, 0, .42)}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:var(--font-display);color:var(--text-1);background-color:var(--bg);background-image:var(--bg-overlay);text-rendering:geometricPrecision}button,input,select{font:inherit;color:inherit}button{border:0;background:none;cursor:pointer}:focus-visible{outline:2px solid var(--accent-soft);outline-offset:2px}h1,h2,h3,h4,p{margin:0}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{appearance:textfield;-moz-appearance:textfield}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:20px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;direction:ltr;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.app-page{min-height:100vh;display:flex;flex-direction:column}.section-kicker{margin:0;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--text-3)}.app-top-bar{position:sticky;top:0;z-index:40;min-height:68px;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--bg) 86%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-top-bar-inner{width:min(100%,1240px);min-height:inherit;margin:0 auto;padding:8px clamp(14px,3.5vw,30px);display:flex;align-items:center;justify-content:space-between;gap:12px}.app-brand{display:inline-flex;align-items:center;gap:10px}.app-brand-mark{width:34px;height:34px;border-radius:6px;border:1px solid var(--line-strong);background:var(--accent);color:var(--accent-contrast);font-size:.82rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;letter-spacing:-.04em}.app-brand-wordmark{display:inline-grid;line-height:1.02;gap:5px}.app-brand-wordmark strong{font-size:1.08rem;letter-spacing:-.02em}.app-brand-wordmark small{font-size:.63rem;text-transform:uppercase;letter-spacing:.13em;color:var(--text-3)}.app-top-bar-right{display:inline-flex;align-items:center;gap:10px}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-3)}.status-dot.connected{background:var(--positive);box-shadow:0 0 0 4px color-mix(in srgb,var(--positive) 18%,transparent)}.status-dot.disconnected{background:var(--negative);animation:pulse-disconnected 1.8s ease-in-out infinite}@keyframes pulse-disconnected{0%,to{opacity:.48}50%{opacity:1}}.midi-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 11px;border-radius:var(--radius-pill);border:1px solid var(--line);background:var(--surface-2)}.midi-chip-label{font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--text-3)}.icon-button,.practice-icon-button{width:38px;height:38px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface-2);color:var(--text-2);display:inline-flex;align-items:center;justify-content:center;transition:border-color .16s ease,background-color .16s ease,color .16s ease}.icon-button:hover,.practice-icon-button:hover{border-color:var(--line-strong);background:var(--surface-3);color:var(--text-1)}.icon-button .material-symbols-outlined,.practice-icon-button .material-symbols-outlined{font-size:21px}.setup-main{flex:1;padding:clamp(10px,2.2vw,24px) 16px 26px;display:flex;justify-content:center}.setup-wrapper{width:min(100%,1220px);display:grid;gap:20px}.setup-content{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.4fr) minmax(0,1fr);gap:18px;align-items:stretch;height:min(700px,calc(100vh - 220px))}.setup-intro{display:grid;gap:8px}.setup-intro h1{font-size:clamp(1.85rem,4vw,2.65rem);line-height:1;letter-spacing:-.03em}.setup-intro p:last-child{max-width:640px;color:var(--text-2);font-size:.98rem}.setup-card{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-panel);padding:clamp(18px,3vw,28px);height:100%}.setup-main-panel{display:grid;grid-template-rows:auto auto auto 1fr;gap:18px;height:100%}.setup-section{display:grid;gap:14px;align-content:start}.section-head{display:flex;align-items:end;justify-content:space-between;gap:12px;padding-bottom:10px;border-bottom:1px solid var(--line)}.section-head h2{margin-top:3px;font-size:1.18rem;letter-spacing:-.02em}.section-summary{border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--surface-2);padding:5px 11px;font-size:.78rem;color:var(--text-2)}.key-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.key-stepper{display:grid;gap:8px}.key-label,.notes-label{font-size:.69rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--text-3)}.key-field{min-height:54px;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-2);display:grid;grid-template-columns:auto 1fr auto;align-items:center;overflow:hidden}.key-field>span{display:inline-flex;align-items:center;justify-content:center;text-align:center;font-size:1.15rem;font-weight:600;letter-spacing:-.03em}.stepper-control{width:42px;height:100%;border:0;border-right:1px solid var(--line);background:var(--surface-3);color:var(--text-2);display:inline-flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.stepper-control:last-child{border-right:0;border-left:1px solid var(--line)}.stepper-control:hover{background:color-mix(in srgb,var(--surface-3) 74%,var(--accent-soft) 26%);color:var(--accent-contrast)}.stepper-control .material-symbols-outlined{font-size:18px}.key-hint{font-size:.77rem;color:var(--text-3)}.range-slider{padding:6px 4px 2px}.range-track{height:8px;border-radius:var(--radius-pill);background:var(--surface-3);position:relative}.range-selection{position:absolute;top:0;bottom:0;border-radius:inherit;background:var(--accent);opacity:.75}.range-handle{position:absolute;top:50%;width:4px;height:24px;border-radius:var(--radius-pill);background:var(--accent);transform:translate(-1px,-50%)}.notes-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center}.step-button{width:50px;height:50px;border-radius:var(--radius-md);border:1px solid var(--line);background:var(--surface-2);color:var(--text-2);display:inline-flex;align-items:center;justify-content:center;transition:border-color .15s ease,background-color .15s ease,color .15s ease}.step-button:hover{border-color:var(--line-strong);background:var(--surface-3);color:var(--text-1)}.step-button .material-symbols-outlined{font-size:22px}.notes-input-wrap{min-height:56px;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-2);padding:0 12px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px}.notes-input{width:100%;border:0;background:transparent;outline:none;text-align:center;font-family:var(--font-mono);font-size:1.4rem;font-weight:600;letter-spacing:-.03em}.notes-input-wrap span{font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}.session-preview{align-self:start;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-2);padding:14px;display:grid;gap:12px}.session-preview h3{font-size:.86rem;text-transform:uppercase;letter-spacing:.14em;color:var(--text-3)}.session-preview dl{margin:0;display:grid;gap:8px}.session-preview dl div{display:flex;justify-content:space-between;gap:10px;align-items:baseline;padding-bottom:8px;border-bottom:1px dashed var(--line)}.session-preview dl div:last-child{border-bottom:0;padding-bottom:0}.session-preview dt{font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3)}.session-preview dd{margin:0;font-size:.84rem;font-weight:500;color:var(--text-1)}.setup-side-panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-2);padding:14px;display:grid;grid-template-rows:auto 1fr;gap:12px;align-content:start;height:100%;overflow:hidden}.previous-sessions-list{list-style:none;margin:0;padding:0;display:grid;align-content:start;grid-auto-rows:max-content;gap:10px;min-height:0;overflow-y:auto;overscroll-behavior:contain}.previous-sessions-empty{margin:0;font-size:.9rem;color:var(--text-3)}.previous-session-item{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-1);padding:11px;display:grid;gap:10px}.previous-session-item.active{border-color:color-mix(in srgb,var(--accent) 38%,var(--line));background:color-mix(in srgb,var(--surface-1) 78%,var(--accent) 22%)}.previous-session-meta{display:grid;gap:4px}.previous-session-meta h3{margin:0;font-size:.95rem;letter-spacing:-.01em}.previous-session-meta p{margin:0;font-size:.8rem;color:var(--text-2)}.previous-session-meta p.mono{font-size:.76rem;color:var(--text-3)}.previous-session-load-button{min-height:36px;border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:var(--surface-3);color:var(--text-1);font-size:.82rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;transition:border-color .16s ease,background-color .16s ease}.previous-session-load-button:hover{border-color:var(--accent-soft);background:color-mix(in srgb,var(--surface-3) 72%,var(--accent-soft) 28%);color:var(--accent-contrast)}.trainings-panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-2);padding:14px;display:grid;grid-template-rows:auto 1fr;gap:12px;align-content:start;height:100%;overflow:hidden}.trainings-list{list-style:none;margin:0;padding:0;display:grid;align-content:start;grid-auto-rows:max-content;gap:10px;min-height:0;overflow-y:auto;overscroll-behavior:contain}.trainings-empty{margin:0;font-size:.9rem;color:var(--text-3)}.training-item{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-1);padding:11px;display:grid;gap:10px}.training-item.active{border-color:color-mix(in srgb,var(--accent) 38%,var(--line));background:color-mix(in srgb,var(--surface-1) 78%,var(--accent) 22%)}.training-meta{display:grid;gap:4px}.training-level{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-contrast);background:var(--accent);border-radius:var(--radius-sm);padding:2px 7px;justify-self:start;opacity:.85}.training-meta h3{margin:0;font-size:.92rem;letter-spacing:-.01em}.training-meta p{margin:0;font-size:.76rem;color:var(--text-3)}.training-load-button{min-height:36px;border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:var(--surface-3);color:var(--text-1);font-size:.82rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;transition:border-color .16s ease,background-color .16s ease}.training-load-button:hover{border-color:var(--accent-soft);background:color-mix(in srgb,var(--surface-3) 72%,var(--accent-soft) 28%);color:var(--accent-contrast)}.training-actions{display:flex;gap:6px}.training-actions .training-load-button{flex:1}.training-delete-button{min-height:36px;width:36px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface-3);color:var(--text-3);display:inline-flex;align-items:center;justify-content:center;transition:border-color .16s ease,background-color .16s ease,color .16s ease}.training-delete-button .material-symbols-outlined{font-size:16px}.training-delete-button:hover{border-color:#e57373;background:color-mix(in srgb,var(--surface-3) 80%,#e57373 20%);color:#c62828}.save-training-button{min-height:42px;width:100%;border-radius:var(--radius-md);border:1px dashed var(--line-strong);background:var(--surface-2);color:var(--text-2);font-size:.84rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:border-color .15s ease,background-color .15s ease,color .15s ease}.save-training-button .material-symbols-outlined{font-size:18px}.save-training-button:hover{border-color:var(--accent-soft);background:color-mix(in srgb,var(--surface-2) 80%,var(--accent-soft) 20%);color:var(--accent-contrast)}.save-training-form{display:flex;gap:8px;width:100%}.save-training-input{flex:1;min-height:42px;border:1px solid var(--line-strong);border-radius:var(--radius-md);background:var(--surface-2);padding:0 12px;font-size:.88rem;color:var(--text-1);outline:none;transition:border-color .15s ease}.save-training-input:focus{border-color:var(--accent)}.save-training-confirm{min-height:42px;padding:0 16px;border-radius:var(--radius-md);border:1px solid var(--accent-soft);background:var(--accent);color:var(--accent-contrast);font-size:.82rem;font-weight:600;transition:opacity .15s ease}.save-training-confirm:disabled{opacity:.5}.save-training-cancel{min-height:42px;padding:0 12px;border-radius:var(--radius-md);border:1px solid var(--line);background:var(--surface-3);color:var(--text-2);font-size:.82rem;font-weight:600;transition:background-color .15s ease}.save-training-cancel:hover{background:var(--surface-2)}.setup-actions{display:grid;gap:10px;align-items:end}.start-session-button,.finish-button,.result-primary-button{min-height:50px;border-radius:var(--radius-md);border:1px solid var(--accent-soft);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 82%,white 18%),var(--accent));color:var(--accent-contrast);font-size:.96rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 20px;box-shadow:var(--shadow-button);transition:transform .16s ease,box-shadow .16s ease}.start-session-button{min-width:min(100%,260px)}.start-session-button:hover,.finish-button:hover,.result-primary-button:hover{transform:translateY(-1px)}.start-session-button .material-symbols-outlined,.finish-button .material-symbols-outlined,.result-primary-button .material-symbols-outlined{font-size:19px}.setup-footer{text-align:center;padding:0 16px 22px;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}.practice-page{min-height:100vh}.practice-header{border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--surface-1) 90%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:10px clamp(14px,3vw,24px) 12px}.practice-header-inner{width:min(100%,1250px);margin:0 auto;display:grid;grid-template-columns:minmax(0,220px) minmax(0,1fr) auto;align-items:center;gap:14px}.practice-session-meta{display:grid;gap:4px}.practice-session-meta h2{font-size:clamp(1.05rem,2.4vw,1.8rem);line-height:1;letter-spacing:-.02em;white-space:nowrap}.practice-session-meta p:last-child{font-size:.86rem;color:var(--text-2)}.practice-header-center{display:grid;justify-items:center;gap:10px}.practice-stat-list{display:inline-flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px}.practice-stat-chip{min-height:46px;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-2);display:inline-flex;align-items:center;gap:8px;padding:7px 12px}.practice-stat-chip .material-symbols-outlined{font-size:18px;color:var(--text-3)}.practice-stat-value{font-size:1.25rem;font-weight:650;letter-spacing:-.04em}.practice-stat-total{font-size:.84rem;color:var(--text-3)}.practice-notes-value{display:inline-flex;align-items:baseline;gap:2px}.timer-chip{transition:border-color .15s ease,background-color .15s ease}.timer-chip:hover{border-color:var(--line-strong);background:var(--surface-3)}.timer-chip.running{border-color:color-mix(in srgb,var(--accent) 38%,var(--line));background:color-mix(in srgb,var(--surface-2) 50%,var(--accent) 50%)}.timer-chip.running .material-symbols-outlined,.timer-chip.running .practice-stat-value{color:var(--accent-contrast)}.practice-stat-chip.success{border-color:color-mix(in srgb,var(--positive) 44%,var(--line));background:color-mix(in srgb,var(--positive) 14%,var(--surface-2))}.practice-stat-chip.success .material-symbols-outlined,.practice-stat-chip.success .practice-stat-value{color:var(--positive)}.practice-progress-row{width:min(100%,640px);display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px}.practice-progress-label{font-size:.72rem;color:var(--text-3);font-family:var(--font-mono)}.practice-progress-track{height:6px;border-radius:var(--radius-pill);background:var(--surface-3);overflow:hidden}.practice-progress-fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 72%,white 28%),var(--accent));transition:width .35s ease}.practice-header-actions{display:inline-flex;justify-content:flex-end;gap:8px}.practice-main{flex:1;position:relative;display:flex;justify-content:center;align-items:center;padding:clamp(14px,2.5vw,24px)}.missed-message{position:absolute;top:clamp(14px,3vw,24px);left:50%;transform:translate(-50%);z-index:20;border:1px solid color-mix(in srgb,var(--negative) 64%,var(--line));background:color-mix(in srgb,var(--negative) 90%,#ffffff 10%);color:#fff;border-radius:var(--radius-sm);padding:8px 14px;font-size:.86rem;font-weight:700;box-shadow:0 10px 20px color-mix(in srgb,var(--negative) 40%,transparent)}.practice-score-panel{width:min(100%,1260px);height:100%;border:1px solid var(--line);border-radius:var(--radius-xl);background:var(--surface-1);box-shadow:var(--shadow-panel);padding:clamp(10px,1.8vw,16px)}.practice-score{width:100%;height:100%;min-height:380px;border:1px solid var(--line);border-radius:var(--radius-lg);background:#faf9f4;overflow:auto hidden;padding:clamp(8px,1.6vw,14px)}.practice-score .osmd{width:max-content;min-width:100%;height:100%;min-height:350px;overflow:visible}.practice-score .osmd>div{width:max-content;min-width:100%}.practice-score .osmd svg{width:auto;min-width:100%;height:auto;display:block}.practice-footer{border-top:1px solid var(--line);background:color-mix(in srgb,var(--surface-1) 92%,transparent);padding:12px clamp(14px,3vw,24px)}.practice-footer-inner{width:min(100%,1250px);margin:0 auto;display:flex;justify-content:flex-end}.finish-button{min-width:clamp(180px,24vw,230px)}.result-main{flex:1;padding:clamp(18px,4vw,44px) 16px 26px;display:flex;justify-content:center;align-items:flex-start}.result-card{width:min(100%,900px);border:1px solid var(--line);border-radius:var(--radius-xl);background:var(--surface-1);box-shadow:var(--shadow-panel);padding:clamp(16px,3vw,30px);display:grid;gap:16px}.result-status-icon{width:48px;height:48px;border-radius:50%;border:1px solid color-mix(in srgb,var(--positive) 45%,var(--line));background:color-mix(in srgb,var(--positive) 18%,var(--surface-2));color:var(--positive);display:inline-flex;align-items:center;justify-content:center}.result-status-icon .material-symbols-outlined{font-size:26px}.result-intro{display:grid;gap:5px}.result-intro h1{font-size:clamp(1.75rem,3.6vw,2.5rem);letter-spacing:-.03em;line-height:1}.result-intro p:last-child{font-size:.82rem;color:var(--text-3);letter-spacing:.06em}.result-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.result-metric-card{min-height:150px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-2);padding:14px;display:grid;place-content:center;justify-items:center;gap:10px;text-align:center}.result-metric-card h2{font-size:.67rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3)}.result-metric-value{font-size:clamp(2rem,5vw,2.8rem);line-height:.94;font-weight:700;letter-spacing:-.05em}.result-metric-value.primary{color:color-mix(in srgb,var(--accent) 78%,var(--positive) 22%)}.result-metric-value span{margin-left:6px;font-size:.92rem;color:var(--text-3)}.result-metric-value.time{font-size:clamp(1.7rem,4vw,2.4rem)}.result-speed-delta{font-size:.82rem;font-weight:700}.result-speed-delta.up{color:var(--positive)}.result-speed-delta.down{color:var(--negative)}.result-improvements{display:grid;gap:8px}.result-improvements h3{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--text-3)}.result-improvement-row{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-2);padding:10px 12px;display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center}.result-improvement-row.empty{border-style:dashed}.result-note-badge{min-width:52px;min-height:36px;border:1px solid color-mix(in srgb,var(--negative) 45%,var(--line));border-radius:var(--radius-sm);background:color-mix(in srgb,var(--negative) 12%,var(--surface-2));color:var(--negative);display:inline-flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:700;letter-spacing:-.01em}.result-note-badge.success{border-color:color-mix(in srgb,var(--positive) 45%,var(--line));background:color-mix(in srgb,var(--positive) 12%,var(--surface-2));color:var(--positive)}.result-row-title{font-size:.98rem;font-weight:600}.result-improvement-row p{margin-top:2px;font-size:.84rem;color:var(--text-2)}.result-actions{display:inline-flex;justify-content:flex-end;gap:8px}.result-secondary-button,.back-button{min-height:44px;border-radius:var(--radius-md);border:1px solid var(--line);background:var(--surface-2);color:var(--text-2);font-size:.92rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 16px;transition:border-color .14s ease,background-color .14s ease,color .14s ease}.result-secondary-button:hover,.back-button:hover{border-color:var(--line-strong);background:var(--surface-3);color:var(--text-1)}.result-primary-button{min-width:148px}.settings-main{flex:1;padding:clamp(18px,4vw,44px) 16px 24px;display:flex;justify-content:center}.settings-wrapper{width:min(100%,820px);display:grid;gap:18px}.settings-intro{display:grid;gap:6px}.settings-intro h1{font-size:clamp(1.76rem,3.8vw,2.5rem);line-height:1;letter-spacing:-.03em}.settings-intro p:last-child{color:var(--text-2);font-size:.94rem}.settings-card{border:1px solid var(--line);border-radius:var(--radius-xl);overflow:hidden;background:var(--surface-1);box-shadow:var(--shadow-panel)}.settings-section{padding:clamp(14px,2.4vw,24px);display:grid;gap:12px}.settings-section+.settings-section{border-top:1px solid var(--line)}.settings-title{display:inline-flex;align-items:center;gap:10px}.settings-icon-box{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface-2);color:var(--text-2);display:inline-flex;align-items:center;justify-content:center}.settings-title h2{font-size:1.08rem;letter-spacing:-.02em}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.toggle-row h3{font-size:.98rem}.toggle-row p{margin-top:2px;font-size:.86rem;color:var(--text-2)}.switch{display:inline-flex;position:relative}.toggle-input{position:absolute;opacity:0;width:1px;height:1px;pointer-events:none}.toggle-track{width:52px;height:29px;border-radius:var(--radius-pill);border:1px solid var(--line);background:var(--surface-3);position:relative;transition:background-color .16s ease,border-color .16s ease}.toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:21px;height:21px;border-radius:50%;background:var(--surface-1);border:1px solid var(--line);transition:transform .16s ease}.toggle-input:checked+.toggle-track{border-color:var(--accent-soft);background:color-mix(in srgb,var(--accent) 84%,white 16%)}.toggle-input:checked+.toggle-track:after{transform:translate(23px);border-color:transparent}.settings-field{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-weight:700}.select-wrap{position:relative}.select-wrap select{width:100%;min-height:44px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface-2);appearance:none;padding:0 38px 0 12px;font-size:.92rem}.select-wrap select:disabled{opacity:.65;cursor:not-allowed}.select-wrap select:focus{border-color:var(--line-strong);outline:none}.select-wrap .material-symbols-outlined{position:absolute;top:50%;right:10px;transform:translateY(-50%);color:var(--text-3);pointer-events:none}.device-status{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--text-3)}.device-status.connected{color:var(--positive)}.device-status.disconnected{color:var(--text-3)}.settings-info{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2);padding:10px 12px;display:grid;grid-template-columns:auto 1fr;align-items:flex-start;gap:8px}.settings-info .material-symbols-outlined{margin-top:1px;font-size:17px;color:var(--text-3)}.settings-info p{font-size:.85rem;color:var(--text-2);line-height:1.45}.settings-bottom-row{border-top:1px solid var(--line);background:var(--surface-2);padding:12px clamp(14px,2.4vw,24px);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;font-size:.77rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}.settings-about-button{min-height:32px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-1);color:var(--text-2);display:inline-flex;align-items:center;gap:6px;padding:0 10px;font-size:.71rem;letter-spacing:.11em;text-transform:uppercase;font-weight:700;transition:border-color .14s ease,background-color .14s ease,color .14s ease}.settings-about-button:hover{border-color:var(--line-strong);background:var(--surface-3);color:var(--text-1)}.settings-about-button .material-symbols-outlined{font-size:16px}.settings-handle{width:80px;height:4px;border-radius:var(--radius-pill);margin:0 auto;background:var(--line-strong)}.about-page{--about-accent: #2f6fd5}.about-main{flex:1;padding:clamp(20px,4vw,52px) 16px 30px;display:flex;justify-content:center}.about-wrapper{width:min(100%,980px);display:grid;gap:clamp(24px,4vw,40px)}.about-content{width:min(100%,760px);margin:0 auto;text-align:center;display:grid;justify-items:center;gap:clamp(14px,2.5vw,20px)}.about-icon-box{width:62px;height:62px;border-radius:14px;border:1px solid color-mix(in srgb,var(--about-accent) 30%,var(--line));background:color-mix(in srgb,var(--about-accent) 10%,var(--surface-1));color:var(--about-accent);display:inline-flex;align-items:center;justify-content:center}.about-icon-box .material-symbols-outlined{font-size:30px}.about-content h1{font-size:clamp(2rem,5vw,3.2rem);line-height:1;letter-spacing:-.03em}.about-divider{width:76px;height:4px;border-radius:var(--radius-pill);background:var(--about-accent)}.about-content p{margin:0;color:var(--text-2);font-size:clamp(1.04rem,2.2vw,1.14rem);line-height:1.78}.about-content p strong{color:var(--text-1)}.about-support{margin-top:4px;display:grid;justify-items:center;gap:10px}.about-support-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}.about-support-button{min-height:52px;border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--about-accent) 60%,var(--line));color:var(--about-accent);background:var(--surface-1);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 28px;font-size:1.03rem;font-weight:700;letter-spacing:.01em;transition:transform .14s ease,box-shadow .14s ease,background-color .14s ease}.about-support-button:hover{background:color-mix(in srgb,var(--about-accent) 10%,var(--surface-1));transform:translateY(-1px);box-shadow:0 8px 14px color-mix(in srgb,var(--about-accent) 22%,transparent)}.about-support-button .material-symbols-outlined{font-size:20px}.about-support p{margin:0;font-size:.72rem;letter-spacing:.17em;text-transform:uppercase;color:var(--text-3)}.about-hero{margin:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-1);box-shadow:var(--shadow-soft)}.about-hero-image{position:relative;width:100%;height:clamp(190px,30vw,350px);background:linear-gradient(122deg,#20242a,#40454f 34%,#808791 54%,#d5d9df 72%,#f2f4f8)}.about-hero-image:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0 54px,rgba(0,0,0,.65) 54px 74px,transparent 74px 132px);transform:perspective(540px) rotateX(22deg) translateY(-28%);transform-origin:top;opacity:.78;mix-blend-mode:multiply}.about-hero-image:after{content:"";position:absolute;inset:0;background:radial-gradient(120% 120% at 0% 100%,rgba(255,255,255,.35) 0%,transparent 50%),linear-gradient(180deg,transparent 42%,rgba(243,242,238,.94) 93%,rgba(243,242,238,1) 100%)}.about-footer{border-top:1px solid var(--line);padding:24px 16px 28px;text-align:center;display:grid;gap:8px;color:var(--text-3);font-size:.82rem}.about-footer .mono{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.dark .app-top-bar{background:color-mix(in srgb,var(--bg) 78%,transparent)}.dark .app-brand-mark{box-shadow:inset 0 0 0 1px #ffffff14}.dark .practice-score{background:#f4f2ea}.dark .stepper-control:hover,.dark .result-secondary-button:hover,.dark .back-button:hover{color:var(--accent-contrast)}.dark .about-content p{color:var(--text-2)}.dark .about-content p strong{color:var(--text-1)}.dark .about-support-button{border-color:color-mix(in srgb,var(--about-accent) 55%,var(--line));background:var(--surface-2)}.dark .about-support-button:hover{background:color-mix(in srgb,var(--about-accent) 20%,var(--surface-2))}.dark .about-hero-image:after{background:radial-gradient(140% 120% at 0% 100%,rgba(8,8,8,.3) 0%,transparent 48%),linear-gradient(180deg,transparent 44%,rgba(8,8,8,.66) 92%,rgba(8,8,8,.78) 100%)}.dark .start-session-button,.dark .finish-button,.dark .result-primary-button{background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 68%,black 32%),var(--accent));color:var(--accent-contrast)}@media(max-width:1080px){.setup-content{grid-template-columns:1fr;height:auto}.setup-side-panel{height:auto;overflow:visible}.trainings-list,.previous-sessions-list{overflow:visible}.setup-actions{justify-content:stretch}.start-session-button{width:100%}}@media(max-width:920px){.app-top-bar-inner{flex-wrap:wrap}.practice-header-inner{grid-template-columns:1fr;justify-items:stretch}.practice-session-meta{text-align:center}.practice-header-center{order:2}.practice-header-actions{order:3;justify-content:center}.practice-progress-row{width:100%}.result-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.app-top-bar{min-height:auto}.app-top-bar-inner{padding-top:10px;padding-bottom:10px}.setup-intro,.settings-intro,.result-intro{text-align:left}.about-content{text-align:left;justify-items:start}.about-divider{margin-left:0}.about-support{justify-items:start}.about-support-actions{width:100%;flex-direction:column}.about-support-button{width:100%}.about-footer{text-align:left}.key-grid,.notes-row{grid-template-columns:1fr}.step-button{width:100%}.practice-stat-chip{flex:1 1 122px}.practice-footer-inner{justify-content:stretch}.finish-button,.result-secondary-button,.result-primary-button,.back-button{width:100%}.result-metrics{grid-template-columns:1fr}.result-actions{width:100%;display:grid;gap:8px}.toggle-row{align-items:flex-start;flex-direction:column}}
