:root{color:var(--text-primary);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;background:var(--bg-primary);font-family:var(--font-ui), ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;font-synthesis:none;text-rendering:optimizelegibility;--font-display:"Bricolage Grotesque", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-ui:"Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"DM Mono", "SFMono-Regular", Consolas, "Liberation Mono", monospace;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--radius-2xl:16px;--radius-3xl:20px;--radius-full:999px;--bg-primary:#f6efe4;--bg-secondary:#fffdf9;--bg-tertiary:#f2ebe0;--bg-elevated:#f2ebe0;--bg-surface:#ece2d4;--bg-canvas:#fffaf2;--bg-canvas-grid:#e4d7c8;--text-primary:#2e2620;--text-secondary:#8c7f71;--text-tertiary:#b3a596;--text-muted:#b3a596;--text-inverse:#fff;--accent-primary:#ee6c4d;--accent-hover:#d8512f;--accent-secondary:#cf8a26;--accent-tertiary:#4a84a6;--accent-song:#7d6fd0;--accent-song-hover:#6f61c0;--accent-coral-deep:#d8512f;--border-default:#e4d7c8;--border-subtle:#3c2a1c1a;--border-strong:#ee6c4d;--status-success:#3fa46a;--status-warning:#cf8a26;--status-danger:#d95c4a;--status-info:#4a84a6;--shadow-overlay:#462d1938;--shadow-context-menu:0 12px 32px #462d1929;--shadow-card:0 14px 40px #462d1914;--shadow-card-hover:0 18px 44px #462d1921;--shadow-accent:#ee6c4d52;--overlay-dim:#462d1938;--focus-ring:color-mix(in srgb, var(--accent-primary) 42%, transparent);--surface-subtle:color-mix(in srgb, var(--bg-surface) 76%, transparent);--surface-selected:color-mix(in srgb, var(--accent-primary) 12%, var(--bg-elevated));--surface-accent:color-mix(in srgb, var(--accent-primary) 12%, transparent);--surface-song:color-mix(in srgb, var(--accent-song) 12%, transparent);--surface-info:color-mix(in srgb, var(--status-info) 12%, transparent);--surface-warning:color-mix(in srgb, var(--status-warning) 10%, transparent);--surface-danger:color-mix(in srgb, var(--status-danger) 10%, transparent);--surface-success:color-mix(in srgb, var(--status-success) 12%, transparent);--status-warning-text:var(--status-warning);--status-danger-text:var(--status-danger);--status-success-text:var(--status-success);--status-info-text:var(--status-info);--range-accent:var(--accent-song);--score-neutral-bg:color-mix(in srgb, var(--text-primary) 8%, transparent);--timeline-surface:#fffdf9;--timeline-target-band:#4a84a621;--timeline-target-line:#4a84a6a8;--timeline-target-text:var(--text-primary);--timeline-status-text:var(--text-secondary);--timeline-grid-border:#3c2a1c1a;--timeline-grid-line:#2e26200f;--timeline-grid-strong-line:#2e26201c;--timeline-grid-label:var(--text-secondary);--timeline-time-marker:#e4d7c857;--timeline-ignored-event:#8c7f7147;--timeline-pitch-line:#7d6fd0b8;--timeline-noisy-frame:#d95c4a47;--timeline-pass-line:var(--status-success);--timeline-error-line:var(--status-danger);--song-timeline-missed-region:#d95c4a24;--song-timeline-off-pitch-region:#7d6fd021;--song-timeline-reference-band:#4a84a629;--song-timeline-reference-border:#4a84a694;--song-timeline-reference-line:#4a84a6e0;--song-timeline-live-line:#7d6fd09e;--song-timeline-playhead:var(--accent-primary);--song-timeline-debug-surface:var(--bg-secondary);--song-timeline-debug-border:var(--border-default);--song-timeline-debug-bar:#61afef8a;--z-portaled-popover:10000}*{box-sizing:border-box}html,body,#root{width:100%;min-width:320px;min-height:100%;margin:0}body{background:var(--bg-primary);color:var(--text-primary);letter-spacing:0;overscroll-behavior:none;overflow-x:hidden}button,input{font:inherit}button{border:0}h1,h2,h3,p{margin:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}.visually-hidden{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.ui-button{letter-spacing:0;white-space:nowrap;cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;font-family:inherit;font-weight:650;line-height:1;transition:background-color .15s,border-color .15s,color .15s,opacity .15s;display:inline-flex}.ui-button:focus{outline:none}.ui-button:focus-visible{box-shadow:0 0 0 2px var(--focus-ring)}.ui-button:disabled{border-color:var(--border-default);background:var(--bg-secondary);color:var(--text-muted);cursor:not-allowed;opacity:.68}.ui-control--rounded{border-radius:var(--radius-lg)}.ui-control--sm{height:28px;padding:0 10px;font-size:.75rem}.ui-control--md{height:32px;padding:0 12px;font-size:.85rem}.ui-control--lg{height:36px;padding:0 16px;font-size:.95rem}.ui-icon-control--sm{width:28px;height:28px;padding:0}.ui-icon-control--md{width:32px;height:32px;padding:0}.ui-icon-control--lg{width:36px;height:36px;padding:0}.ui-button--primary{border-color:var(--accent-primary);background:var(--accent-primary);color:var(--text-inverse)}.ui-button--primary:hover:not(:disabled){border-color:var(--accent-hover);background:var(--accent-hover)}.ui-button--secondary{border-color:var(--border-default);background:var(--bg-elevated);color:var(--text-primary)}.ui-button--secondary:hover:not(:disabled){background:var(--bg-surface)}.ui-button--secondary[data-active]{border-color:var(--accent-primary);background:var(--surface-selected)}.ui-button--success{border-color:var(--status-success);background:var(--status-success);color:var(--text-inverse)}.ui-button--success:hover:not(:disabled){background:color-mix(in srgb, var(--status-success) 86%, var(--text-primary))}.ui-button--song{border-color:var(--accent-song);background:var(--accent-song);color:var(--text-inverse)}.ui-button--song:hover:not(:disabled){border-color:var(--accent-song-hover);background:var(--accent-song-hover)}.ui-button--ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.ui-button--ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary)}.ui-button--danger{border-color:var(--status-danger);background:var(--status-danger);color:var(--text-inverse)}.ui-button--danger:hover:not(:disabled){background:color-mix(in srgb, var(--status-danger) 86%, var(--text-primary))}.ui-button--icon{flex:none}.pc-app-shell{min-height:100vh;color:var(--text-primary);background:var(--bg-primary);grid-template-columns:212px minmax(0,1fr);display:grid}.pc-app-shell__sidebar{border-right:1px solid var(--border-subtle);background:var(--bg-secondary);min-width:0}.pc-app-shell__main{grid-template-rows:auto minmax(0,1fr);min-width:0;min-height:0;display:grid}.pc-app-shell__header{border-bottom:1px solid var(--border-subtle);background:var(--bg-primary);min-width:0}.pc-app-shell__content{min-width:0;min-height:0;overflow:auto}.pc-app-shell__mobile-nav{display:none}.bottom-nav,.bottom-nav__tabs,.bottom-nav__list{width:100%;min-width:0}.bottom-nav__list{align-items:flex-start;gap:0;display:flex;overflow:hidden}.bottom-nav__trigger{min-width:0;color:var(--text-tertiary);cursor:pointer;font:inherit;text-align:center;background:0 0;border:0;flex-direction:column;flex:1 1 0;align-items:center;gap:4px;padding:0 2px;display:flex}.bottom-nav__trigger:hover{color:var(--accent-coral-deep)}.bottom-nav__trigger[data-state=active]{color:var(--accent-coral-deep);background:0 0}.bottom-nav__trigger:focus-visible{border-radius:var(--radius-lg);box-shadow:0 0 0 2px var(--focus-ring);outline:none}.bottom-nav__trigger:disabled{cursor:not-allowed;opacity:.5}.bottom-nav__icon,.bottom-nav__label{justify-content:center;align-items:center;min-width:0;display:inline-flex}.bottom-nav__icon svg{stroke-width:1.7px;width:23px;height:23px}.bottom-nav__trigger[data-state=active] .bottom-nav__icon svg{stroke-width:2.1px}.bottom-nav__label{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:10.5px;font-weight:500;line-height:1.1;overflow:hidden}.bottom-nav__trigger[data-state=active] .bottom-nav__label{font-weight:700}.sidebar-nav{gap:var(--space-5);min-height:100%;padding:var(--space-5) var(--space-4);grid-template-rows:auto minmax(0,1fr) auto;display:grid}.sidebar-nav__brand,.sidebar-nav__footer{min-width:0}.ui-card{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);min-width:0;color:var(--text-primary);background:var(--bg-secondary)}.ui-card--elevated{box-shadow:var(--shadow-card)}.ui-card--interactive{cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}.ui-card--interactive:hover{border-color:color-mix(in srgb, var(--accent-primary) 32%, var(--border-default));box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.ui-card--subtle{background:var(--bg-primary)}.ui-card--dashed{border-style:dashed;border-color:var(--border-strong);background:color-mix(in srgb, var(--accent-primary) 5%, var(--bg-secondary))}.ui-card--mock,.ui-card--mock-soft,.ui-card--mock-interactive,.ui-card--mock-dashed{box-shadow:var(--mock-shadow,var(--shadow-card));background:#fffefaf0;border-color:#e3ddd4;border-radius:18px}.ui-card--mock-soft{background:var(--mock-card-soft,var(--bg-secondary))}.ui-card--mock-interactive{color:inherit;font:inherit;text-align:left;cursor:pointer}.ui-card--mock-interactive:disabled{cursor:not-allowed;opacity:.62}.ui-card--mock-dashed{box-shadow:none;background:#f4efe8ad;border-style:dashed;border-color:#d7d0c8}.ui-card--accent{border-color:color-mix(in srgb, var(--accent-primary) 32%, var(--border-subtle));background:color-mix(in srgb, var(--accent-primary) 5%, var(--bg-secondary))}.ui-card--success{border-color:color-mix(in srgb, var(--status-success) 32%, var(--border-subtle));background:var(--surface-success)}.ui-card--warning{border-color:color-mix(in srgb, var(--status-warning) 34%, var(--border-subtle));background:var(--surface-warning)}.ui-card--song{border-color:color-mix(in srgb, var(--accent-song) 32%, var(--border-subtle));background:var(--surface-song)}.ui-card--pad-none{padding:0}.ui-card--pad-sm{padding:var(--space-2)}.ui-card--pad-md{padding:var(--space-3)}.ui-card--pad-lg{padding:var(--space-5)}.ui-card__header,.ui-card__content,.ui-card__footer{min-width:0}.ui-card__header{gap:3px;display:grid}.ui-card__content{gap:var(--space-3);display:grid}.ui-card__footer{justify-content:flex-end;align-items:center;gap:var(--space-2);display:flex}.ui-card__title{overflow-wrap:anywhere;color:var(--text-primary);font-family:var(--font-display);font-size:1rem;font-weight:720;line-height:1.15}.ui-card__description{overflow-wrap:anywhere;color:var(--text-secondary);font-size:.78rem;font-weight:620;line-height:1.4}.stat-card{align-content:start;gap:var(--space-2);display:grid}.stat-card__label{align-items:center;gap:var(--space-2);min-width:0;color:var(--text-secondary);font-size:.75rem;font-weight:660;display:flex}.stat-card__icon{flex:none;display:inline-flex}.stat-card__body{justify-content:space-between;align-items:end;gap:var(--space-2);min-width:0;display:flex}.stat-card__value{min-width:0;color:var(--text-primary);font-family:var(--font-display);white-space:nowrap;align-items:baseline;font-size:1.55rem;font-weight:760;line-height:1;display:flex}.stat-card__value span{color:var(--text-secondary);margin-left:3px;font-size:.82rem;font-weight:600}.stat-card__trend{min-width:0}.stat-card__detail{overflow-wrap:anywhere;color:var(--text-tertiary);font-size:.72rem;font-weight:620;line-height:1.35}.ui-chip{border-radius:var(--radius-lg);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;min-width:0;font-weight:720;line-height:1;display:inline-flex}.ui-chip--sm{gap:5px;min-height:22px;padding:0 8px;font-size:.68rem}.ui-chip--md{gap:6px;min-height:26px;padding:0 10px;font-size:.74rem}.ui-chip--neutral{border-color:var(--border-subtle);color:var(--text-secondary);background:var(--bg-elevated)}.ui-chip--accent{color:var(--accent-coral-deep);background:var(--surface-accent)}.ui-chip--success{color:var(--status-success-text);background:var(--surface-success)}.ui-chip--warning{color:var(--status-warning-text);background:var(--surface-warning)}.ui-chip--danger{color:var(--status-danger-text);background:var(--surface-danger)}.ui-chip--info{color:var(--status-info-text);background:var(--surface-info)}.ui-chip--song{color:var(--accent-song);background:var(--surface-song)}.ui-status-pill__dot{border-radius:var(--radius-full);background:currentColor;flex:none;width:7px;height:7px}.ui-status-pill--pulse .ui-status-pill__dot{box-shadow:0 0 0 4px color-mix(in srgb, currentColor 16%, transparent)}.ui-progress{border-radius:var(--radius-full);background:var(--bg-surface);width:100%;height:8px;position:relative;overflow:hidden}.ui-progress__indicator{border-radius:inherit;width:100%;height:100%;transition:transform .24s}.ui-progress--accent .ui-progress__indicator{background:var(--accent-primary)}.ui-progress--success .ui-progress__indicator{background:var(--status-success)}.ui-progress--warning .ui-progress__indicator{background:var(--status-warning)}.ui-progress--song .ui-progress__indicator{background:var(--accent-song)}.sidebar-tabs{min-width:0}.sidebar-tabs__list{gap:3px;display:flex}.sidebar-tabs--vertical .sidebar-tabs__list{flex-direction:column}.sidebar-tabs--horizontal .sidebar-tabs__list{flex-direction:row;overflow-x:auto}.sidebar-tabs__trigger{align-items:center;gap:var(--space-2);min-height:38px;padding:0 var(--space-3);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;font:inherit;text-align:left;background:0 0;border:1px solid #0000;grid-template-columns:auto minmax(0,1fr) auto;font-size:.84rem;font-weight:680;transition:background-color .15s,border-color .15s,color .15s;display:grid}.sidebar-tabs__trigger:hover{color:var(--text-primary);background:color-mix(in srgb, var(--text-primary) 5%, transparent)}.sidebar-tabs__trigger[data-state=active]{color:var(--accent-coral-deep);background:var(--surface-accent)}.sidebar-tabs__trigger:focus-visible{box-shadow:0 0 0 2px var(--focus-ring);outline:none}.sidebar-tabs__trigger:disabled{cursor:not-allowed;opacity:.5}.sidebar-tabs__icon,.sidebar-tabs__meta{justify-content:center;align-items:center;display:inline-flex}.sidebar-tabs__label{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.tooltip-content{z-index:var(--z-portaled-popover);border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-elevated);max-width:220px;color:var(--text-primary);box-shadow:0 8px 24px var(--shadow-overlay);padding:6px 8px;font-size:.72rem;font-weight:650}.segmented{border:1px solid var(--border-default);background:var(--bg-elevated);border-radius:11px;gap:4px;padding:4px;display:inline-flex;overflow:hidden}.segmented__option{min-width:0;min-height:34px;color:var(--text-secondary);font:inherit;letter-spacing:0;cursor:pointer;background:0 0;border:0;border-radius:8px;justify-content:center;align-items:center;gap:5px;padding:7px 13px;font-size:.82rem;font-weight:700;transition:background-color .15s,box-shadow .15s,color .15s;display:inline-flex}.segmented__option:hover{color:var(--text-primary)}.segmented__option[data-active]{background:var(--bg-secondary);color:var(--text-primary);box-shadow:0 2px 6px #462d191a}.segmented__option:disabled{cursor:not-allowed;opacity:.55}.toggle-switch{border:1px solid var(--border-default);border-radius:var(--radius-full);background:var(--bg-secondary);cursor:pointer;flex-shrink:0;align-items:center;width:44px;height:24px;padding:0;transition:background-color .15s,border-color .15s,opacity .15s;display:inline-flex;position:relative}.toggle-switch[data-state=checked]{border-color:color-mix(in srgb, var(--accent-primary) 68%, var(--border-default));background:var(--accent-primary)}.toggle-switch:focus{outline:none}.toggle-switch:focus-visible{box-shadow:0 0 0 2px var(--focus-ring)}.toggle-switch:disabled{cursor:not-allowed;opacity:.55}.toggle-switch__thumb{border-radius:var(--radius-full);width:20px;height:20px;box-shadow:0 1px 4px var(--shadow-overlay);will-change:transform;background:#fff;transition:transform .12s;display:block;transform:translate(1px)}.toggle-switch__thumb[data-state=checked]{transform:translate(21px)}.dropdown-trigger{align-items:center;gap:var(--space-2);width:100%;min-height:30px;padding:0 var(--space-2);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-primary);background:var(--bg-secondary);cursor:pointer;text-align:left;grid-template-columns:minmax(0,1fr) auto;transition:background-color .15s,border-color .15s,color .15s;display:inline-grid}.dropdown-trigger:hover:not(:disabled){border-color:var(--border-strong);background:var(--bg-surface)}.dropdown-trigger:disabled{cursor:not-allowed;opacity:.55}.dropdown-trigger:focus{outline:none}.dropdown-trigger:focus-visible{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--focus-ring)}.dropdown-trigger>span:first-child,.dropdown-trigger [data-radix-select-value]{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.dropdown-trigger-icon{color:var(--text-secondary)}.dropdown-content{z-index:var(--z-portaled-popover);min-width:var(--radix-select-trigger-width);max-height:min(var(--radix-select-content-available-height), 280px);border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-elevated);box-shadow:0 12px 32px var(--shadow-overlay);overflow:hidden}.dropdown-viewport{padding:4px}.dropdown-item{align-items:center;gap:var(--space-2);border-radius:var(--radius-sm);min-height:28px;color:var(--text-primary);cursor:pointer;outline:none;grid-template-columns:minmax(0,1fr) 18px;padding:5px 7px;font-size:.78rem;font-weight:650;display:grid;position:relative}.dropdown-item[data-highlighted]{background:var(--surface-selected)}.dropdown-item[data-state=checked]{color:var(--text-primary)}.dropdown-item[data-disabled]{cursor:not-allowed;opacity:.45}.dropdown-item-indicator{color:var(--accent-primary);justify-content:center;display:inline-flex}.alert-dialog__overlay{z-index:var(--z-portaled-popover);background:var(--overlay-dim);position:fixed;inset:0}.alert-dialog__content{z-index:calc(var(--z-portaled-popover) + 1);gap:var(--space-3);width:min(420px,100vw - 32px);padding:var(--space-5);border:1px solid var(--border-default);border-radius:var(--radius-lg);background:var(--bg-secondary);box-shadow:var(--shadow-context-menu);display:grid;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.alert-dialog__title{color:var(--text-primary);font-family:var(--font-display);font-size:1rem;font-weight:740;line-height:1.2}.alert-dialog__description{color:var(--text-secondary);font-size:.82rem;font-weight:620;line-height:1.45}.alert-dialog__actions{justify-content:flex-end;gap:var(--space-2);padding-top:var(--space-1);flex-wrap:wrap;display:flex}.theme-picker{border:1px solid var(--border-default);border-radius:var(--radius-lg);background:var(--bg-elevated);flex:none;gap:2px;max-width:100%;padding:3px;display:inline-flex}.theme-option{border-radius:var(--radius-md);min-width:34px;height:28px;color:var(--text-secondary);cursor:pointer;background:0 0;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:6px;padding:0 7px;font-size:.72rem;font-weight:700;display:inline-grid}.theme-option:hover{color:var(--text-primary);background:var(--bg-surface)}.theme-option:focus-visible{box-shadow:0 0 0 2px var(--focus-ring);outline:none}.theme-option-active{color:var(--text-primary);background:var(--surface-selected)}.theme-option__label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.theme-option__swatches{border:1px solid var(--border-default);border-radius:3px;width:24px;height:14px;display:inline-flex;overflow:hidden}.theme-option__swatches span{flex:1 1 0}input[type=range]{width:100%;accent-color:var(--range-accent)}output{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:.72rem;font-weight:650}.page-header{align-items:center;gap:var(--space-3);grid-template-columns:auto minmax(0,1fr) auto;min-width:0;display:grid}.page-header__icon{border-radius:var(--radius-lg);width:44px;height:44px;color:var(--accent-primary);background:var(--surface-accent);place-items:center;display:grid}.page-header__copy{gap:2px;min-width:0;display:grid}.page-header__eyebrow{color:var(--text-tertiary);text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap;font-size:.68rem;font-weight:780;line-height:1.2;overflow:hidden}.page-header h1{overflow-wrap:anywhere;color:var(--text-primary);font-family:var(--font-display);font-size:1.38rem;font-weight:720;line-height:1.12}.page-header p{overflow-wrap:anywhere;color:var(--text-secondary);font-size:.84rem;font-weight:620;line-height:1.35}.page-header__actions{justify-content:flex-end;gap:var(--space-2);flex-wrap:wrap;display:flex}.empty-state{justify-items:center;gap:var(--space-3);text-align:center;display:grid}.empty-state__icon{border-radius:var(--radius-lg);width:44px;height:44px;color:var(--text-secondary);background:var(--bg-elevated);place-items:center;display:grid}.empty-state__copy{gap:var(--space-1);max-width:420px;display:grid}.empty-state h2{color:var(--text-primary);font-family:var(--font-display);font-size:1rem;font-weight:720}.empty-state p,.dropzone__copy p,.dropzone__privacy{color:var(--text-secondary);font-size:.8rem;font-weight:620;line-height:1.42}.empty-state__action{justify-content:center;display:flex}.dropzone{justify-items:center;gap:var(--space-3);min-height:240px;padding:var(--space-6);border:2px dashed var(--border-default);border-radius:var(--radius-lg);background:color-mix(in srgb, var(--bg-secondary) 76%, transparent);color:var(--text-primary);text-align:center;transition:background-color .15s,border-color .15s,transform .15s;display:grid}.dropzone--active,.dropzone:hover{transform:translateY(-1px)}.dropzone--accent{border-color:color-mix(in srgb, var(--accent-primary) 42%, var(--border-default));background:color-mix(in srgb, var(--accent-primary) 5%, var(--bg-secondary))}.dropzone--song{border-color:color-mix(in srgb, var(--accent-song) 42%, var(--border-default));background:color-mix(in srgb, var(--accent-song) 5%, var(--bg-secondary))}.dropzone__icon{border-radius:var(--radius-lg);width:56px;height:56px;color:var(--accent-song);background:var(--surface-song);place-items:center;display:grid}.dropzone--accent .dropzone__icon{color:var(--accent-primary);background:var(--surface-accent)}.dropzone__copy{gap:var(--space-1);max-width:420px;display:grid}.dropzone__copy h2{color:var(--text-primary);font-family:var(--font-display);font-size:1.1rem;font-weight:720}.dropzone__action{justify-content:center;display:flex}.dropzone__privacy{color:var(--text-tertiary)}.coach-bubble{align-items:start;gap:var(--space-3);grid-template-columns:auto minmax(0,1fr);min-width:0;display:grid}.coach-bubble__icon{border-radius:var(--radius-lg);width:42px;height:42px;color:var(--text-inverse);background:var(--accent-primary);box-shadow:0 8px 20px var(--shadow-accent);place-items:center;display:grid}.coach-bubble--success .coach-bubble__icon{background:var(--status-success)}.coach-bubble--warning .coach-bubble__icon{background:var(--status-warning)}.coach-bubble--info .coach-bubble__icon{background:var(--status-info)}.coach-bubble__message{min-width:0;padding:12px var(--space-4);border:1px solid var(--border-subtle);border-radius:var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg);color:var(--text-primary);background:var(--bg-secondary);font-size:.9rem;font-weight:620;line-height:1.45}.range-setup{z-index:calc(var(--z-portaled-popover) - 1);color:var(--text-primary);font-family:var(--font-ui);position:fixed;inset:0}.range-setup__scrim{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);cursor:default;background:#2c20166b;width:100%;height:100%;position:absolute;inset:0}.range-setup__stage{place-items:center;padding:24px;display:grid;position:absolute;inset:0;overflow:auto}.range-setup-card{background:var(--bg-secondary);border:1px solid #e3ddd4;border-radius:22px;flex-direction:column;width:min(620px,100vw - 32px);max-height:calc(100vh - 48px);animation:.28s cubic-bezier(.2,.8,.2,1) range-setup-in;display:flex;overflow:hidden;box-shadow:0 40px 100px #28190c57}.range-setup-card:focus{outline:none}.range-setup-card--saved{width:min(560px,100vw - 32px)}.range-setup-card__header{grid-template-columns:auto minmax(0,1fr) auto;align-items:start;gap:14px;padding:24px 26px 0;display:grid}.range-coach-head{width:44px;height:44px;color:var(--text-inverse);background:linear-gradient(145deg, #ff9f6b, var(--accent-primary));border-radius:13px;flex:none;place-items:center;display:grid;box-shadow:0 8px 20px #ee6c4d4d}.range-setup-card__header h2,.range-saved h2{color:var(--text-primary);font-family:var(--font-display);letter-spacing:0;font-size:1.38rem;font-weight:720;line-height:1.08}.range-setup-card__header p{max-width:450px;color:var(--text-secondary);margin-top:3px;font-size:.84rem;font-weight:620;line-height:1.38}.range-close-button{border:1px solid var(--border-subtle);width:32px;height:32px;color:var(--text-secondary);background:var(--bg-tertiary);cursor:pointer;border-radius:9px;place-items:center;display:grid}.range-mode-tabs{border:1px solid var(--border-subtle);background:var(--bg-tertiary);border-radius:13px;gap:4px;margin:20px 26px 0;padding:4px;display:flex}.range-mode-tab{min-width:0;min-height:42px;color:var(--text-secondary);font:inherit;letter-spacing:0;cursor:pointer;background:0 0;border-radius:10px;flex:1 1 0;justify-content:center;align-items:center;gap:8px;padding:0 12px;font-size:.88rem;font-weight:720;transition:background-color .15s,box-shadow .15s,color .15s;display:inline-flex}.range-mode-tab[data-active]{color:var(--text-primary);background:var(--bg-secondary);box-shadow:0 2px 6px #462d191f}.range-mode-tab[data-active] svg{color:var(--accent-primary)}.range-setup-card__body{min-height:300px;padding:22px 26px 6px;overflow:auto}.manual-range-editor,.sing-range-editor{gap:18px;display:grid}.range-keyboard-shell{border:1px solid var(--border-subtle);background:#fffdf9;border-radius:14px;min-width:0;padding:20px 16px 12px;overflow:hidden}.range-keyboard-shell>p{color:var(--text-tertiary);text-align:center;margin-top:8px;font-size:.75rem;font-weight:620;line-height:1.35}.range-keyboard-shell>p strong{color:var(--accent-primary)}.range-keyboard{width:100%;aspect-ratio:var(--keyboard-aspect);-webkit-user-select:none;user-select:none;position:relative}.range-keyboard svg{cursor:pointer;width:100%;height:100%;display:block;overflow:visible}.range-keyboard__band{fill:var(--accent-primary);fill-opacity:.1}.range-keyboard__white-key{fill:#fffdf9;stroke:var(--border-subtle)}.range-keyboard__white-key[data-in-range]{fill:var(--accent-primary);fill-opacity:.22}.range-keyboard__black-key{fill:#43372d;stroke:#43372d}.range-keyboard__black-key[data-in-range]{fill:var(--accent-primary);fill-opacity:.82}.range-keyboard text{fill:var(--text-tertiary);font-family:var(--font-mono);text-anchor:middle;font-size:9px}.range-keyboard__needle{stroke:var(--accent-primary);stroke-width:2.5px}.range-keyboard__needle-chip{color:var(--text-inverse);background:var(--text-primary);font-family:var(--font-mono);white-space:nowrap;border-radius:8px;padding:3px 9px;font-size:.78rem;font-weight:700;position:absolute;top:-6px;transform:translate(-50%);box-shadow:0 4px 12px #0003}.range-flag{color:var(--text-inverse);cursor:grab;background:0 0;border:0;flex-direction:column;align-items:center;padding:0;display:flex;position:absolute;top:0;transform:translate(-50%)}.range-flag:disabled{cursor:default}.range-flag>span{background:var(--accent-primary);white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:3px 9px;display:inline-flex;box-shadow:0 4px 12px #ee6c4d59}.range-flag span span{letter-spacing:.05em;opacity:.86;text-transform:uppercase;font-size:.6rem;font-weight:820}.range-flag strong{font-family:var(--font-mono);font-size:.82rem;font-weight:720}.range-flag i{background:var(--accent-primary);width:2px;height:12px}.range-stepper-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.range-note-stepper{gap:7px;min-width:0;display:grid}.range-note-stepper>span,.voice-preset-list>span{color:var(--text-secondary);font-size:.75rem;font-weight:680}.range-note-stepper>div{grid-template-columns:34px 34px minmax(0,1fr) 34px;align-items:center;gap:8px;min-width:0;display:grid}.range-note-stepper button,.range-tone-button{border:1px solid var(--border-subtle);width:34px;height:34px;color:var(--text-primary);background:var(--bg-tertiary);cursor:pointer;border-radius:9px;place-items:center;display:grid}.range-tone-button{color:var(--accent-primary)}.range-note-stepper strong{border:1.5px solid var(--accent-primary);min-width:0;height:44px;color:var(--text-primary);background:var(--bg-secondary);font-family:var(--font-mono);border-radius:11px;place-items:center;font-size:1.18rem;font-weight:720;display:grid}.voice-preset-list{gap:8px;display:grid}.voice-preset-list>div{flex-wrap:wrap;gap:8px;display:flex}.voice-preset-list button{border:1px solid var(--border-subtle);min-height:32px;color:var(--text-secondary);background:var(--bg-secondary);font:inherit;cursor:pointer;border-radius:10px;padding:0 13px;font-size:.78rem;font-weight:760}.voice-preset-list button[data-active]{border-color:var(--accent-primary);color:var(--accent-coral-deep);background:var(--surface-accent)}.range-sing-progress{justify-content:center;align-items:center;gap:10px;min-width:0;display:flex}.range-sing-progress__item{color:var(--text-secondary);white-space:nowrap;align-items:center;gap:8px;font-size:.82rem;font-weight:720;display:inline-flex;position:relative}.range-sing-progress__item>span{border-radius:var(--radius-full);width:24px;height:24px;color:var(--text-tertiary);background:var(--bg-tertiary);font-family:var(--font-mono);place-items:center;font-size:.75rem;font-weight:820;display:grid}.range-sing-progress__item[data-active],.range-sing-progress__item[data-done]{color:var(--text-primary)}.range-sing-progress__item[data-active]>span{color:var(--text-inverse);background:var(--accent-primary)}.range-sing-progress__item[data-done]>span{color:var(--text-inverse);background:var(--status-success)}.range-sing-progress__item i{background:var(--bg-surface);width:26px;height:2px}.range-sing-progress__item i[data-done]{background:var(--status-success)}.sing-range-editor__action{justify-content:center;align-items:center;min-height:64px;display:flex}.sing-range-editor__prompt{text-align:center;justify-items:center;gap:12px;display:grid}.sing-range-editor__prompt p{color:var(--text-primary);font-size:.88rem;font-weight:620;line-height:1.4}.sing-range-editor__inline{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;display:flex}.sing-range-editor__inline>span{color:var(--text-primary);font-size:.88rem;font-weight:650}.sing-range-editor__inline strong{color:var(--accent-primary);font-family:var(--font-mono)}.range-captured-label{align-items:center;gap:6px;display:inline-flex;color:var(--status-success)!important;font-weight:760!important}.range-listening-pill{color:var(--accent-primary);background:var(--surface-accent);border-radius:13px;align-items:center;gap:11px;padding:12px 20px;font-size:.9rem;font-weight:760;display:inline-flex}.range-listening-pill span{align-items:center;gap:8px;display:inline-flex}.range-listening-pill strong{font-family:var(--font-mono)}.range-eq{align-items:center;gap:3px;height:15px;display:inline-flex}.range-eq span{transform-origin:50%;background:currentColor;border-radius:2px;width:3px;height:15px;animation:.9s ease-in-out infinite range-eq}.range-capture-error{border:1px solid color-mix(in srgb, var(--status-danger) 40%, var(--border-subtle));max-width:430px;color:var(--status-danger-text);background:var(--surface-danger);border-radius:10px;padding:10px 12px;font-size:.82rem;font-weight:680;line-height:1.35}.range-setup-card__footer{border-top:1px solid var(--border-subtle);align-items:center;gap:14px;margin-top:6px;padding:14px 26px 22px;display:flex}.range-setup-card__actions,.range-saved__actions{align-items:center;gap:12px;margin-left:auto;display:flex}.range-summary{color:var(--text-secondary);white-space:nowrap;align-items:center;gap:0;font-size:.82rem;font-weight:650;display:inline-flex}.range-summary strong{color:var(--text-primary);font-family:var(--font-mono);font-weight:760}.range-summary>span{border-radius:var(--radius-full);background:var(--text-tertiary);width:3px;height:3px;margin:0 8px}.range-summary svg{color:var(--text-tertiary);margin-right:5px}.range-primary-button,.range-ghost-button,.range-text-button{font:inherit;letter-spacing:0;white-space:nowrap;cursor:pointer;border-radius:13px;justify-content:center;align-items:center;gap:8px;font-size:.9rem;font-weight:760;display:inline-flex}.range-primary-button{border:1px solid var(--accent-primary);min-height:44px;color:var(--text-inverse);background:linear-gradient(180deg, #ff9568, var(--accent-primary));padding:0 22px;box-shadow:0 10px 24px #ee6c4d4d}.range-primary-button:disabled{border-color:var(--border-subtle);color:var(--text-tertiary);background:var(--bg-tertiary);box-shadow:none;cursor:not-allowed}.range-ghost-button{border:1px solid var(--border-default);min-height:42px;color:var(--text-primary);background:var(--bg-secondary);padding:0 18px}.range-text-button{min-height:34px;color:var(--text-secondary);text-decoration:underline;-webkit-text-decoration-color:var(--text-tertiary);text-decoration-color:var(--text-tertiary);text-underline-offset:3px;background:0 0;padding:0 4px;font-size:.84rem}.range-saved{text-align:center;justify-items:center;gap:18px;padding:40px 40px 32px;display:grid}.range-saved__halo{border-radius:var(--radius-full);background:var(--surface-success);place-items:center;width:64px;height:64px;display:grid}.range-saved__check{border-radius:var(--radius-full);width:48px;height:48px;color:var(--text-inverse);background:var(--status-success);place-items:center;animation:1.3s ease-out infinite range-pulse;display:grid}.range-saved__copy p{max-width:380px;color:var(--text-secondary);margin-top:6px;font-size:.94rem;font-weight:620;line-height:1.42}.range-saved__copy strong{color:var(--text-primary);font-family:var(--font-mono)}.range-saved__stats{align-items:stretch;gap:18px;display:flex}.range-saved__stats>span{background:var(--border-subtle);width:1px}.range-stat{gap:3px;display:grid}.range-stat span{color:var(--text-secondary);font-size:.72rem;font-weight:650}.range-stat strong{color:var(--text-primary);font-family:var(--font-display);white-space:nowrap;font-size:1.12rem;font-weight:760}.range-saved__note{color:var(--text-tertiary);align-items:center;gap:6px;font-size:.78rem;font-weight:650;display:inline-flex}.range-setup-toast{width:fit-content;max-width:min(560px,100%);min-height:56px;color:var(--text-inverse);background:#2b221d;border-radius:14px;align-items:center;gap:16px;padding:13px 16px 13px 20px;animation:.26s range-setup-in;display:flex;box-shadow:0 18px 44px #0000003d}.range-setup-toast__icon{background:#ffffff24;border-radius:9px;flex:none;place-items:center;width:30px;height:30px;display:grid}.range-setup-toast__icon svg{width:17px;height:17px}.range-setup-toast__copy{flex:auto;gap:1px;min-width:0;display:grid}.range-setup-toast__copy strong,.range-setup-toast__copy span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.range-setup-toast__copy strong{color:#fffdf9;letter-spacing:0;font-size:.84rem;font-weight:760;line-height:1.2}.range-setup-toast__copy span{color:#fffdf9b8;font-size:.75rem;font-weight:620;line-height:1.2}.range-setup-toast button{min-height:36px;color:var(--text-inverse);background:var(--accent-primary);font:inherit;cursor:pointer;border-radius:10px;flex:none;padding:0 15px;font-size:.84rem;font-weight:760}.range-control-summary{align-items:center;gap:var(--space-2);min-width:0;display:flex}.range-control-summary>div{gap:2px;min-width:0;display:grid}.range-control-summary strong{color:var(--text-primary);font-family:var(--font-mono);font-size:.96rem;font-weight:760}.range-control-summary span{overflow-wrap:anywhere;color:var(--text-secondary);font-size:.73rem;font-weight:650;line-height:1.3}.range-control-summary button{border:1px solid var(--border-default);border-radius:var(--radius-md);min-height:32px;color:var(--text-primary);background:var(--bg-elevated);font:inherit;cursor:pointer;margin-left:auto;padding:0 12px;font-size:.78rem;font-weight:760}.settings-dialog{z-index:calc(var(--z-portaled-popover) - 2);color:var(--text-primary);font-family:var(--font-ui);place-items:center;padding:28px;display:grid;position:fixed;inset:0}.settings-dialog__scrim{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);cursor:default;background:#2c20166b;border:0;width:100%;height:100%;position:absolute;inset:0}.settings-dialog__panel{background:var(--bg-secondary);border:1px solid #e3ddd4;border-radius:22px;grid-template-columns:226px minmax(0,1fr);width:min(760px,100vw - 32px);min-height:min(600px,100vh - 32px);max-height:min(600px,100vh - 32px);animation:.24s cubic-bezier(.2,.8,.2,1) range-setup-in;display:grid;position:relative;overflow:hidden;box-shadow:0 40px 100px #28190c57}.settings-dialog__nav{background:var(--bg-primary);border-right:1px solid #e3ddd4;flex-direction:column;gap:14px;min-width:0;padding:22px 14px;display:flex}.settings-dialog__nav-title{align-items:center;gap:11px;min-width:0;padding:0 8px 4px;display:flex}.settings-dialog__nav-title>span{width:34px;height:34px;color:var(--accent-primary);background:var(--surface-accent);border-radius:10px;flex:none;place-items:center;display:grid}.settings-dialog__nav-title strong{font-family:var(--font-display);text-overflow:ellipsis;white-space:nowrap;font-size:1.06rem;font-weight:720;overflow:hidden}.settings-dialog__nav-list{gap:4px;display:grid}.settings-dialog__nav-list button{min-width:0;color:var(--text-secondary);font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:11px;grid-template-columns:32px minmax(0,1fr);align-items:center;gap:11px;padding:11px 12px;display:grid}.settings-dialog__nav-list button:hover,.settings-dialog__nav-list button[data-active]{color:var(--text-primary);background:var(--bg-secondary);box-shadow:0 2px 8px #462d1914}.settings-dialog__nav-list button>span:first-child{width:32px;height:32px;color:var(--text-secondary);background:var(--bg-secondary);border-radius:9px;place-items:center;display:grid}.settings-dialog__nav-list button[data-active]>span:first-child{color:var(--accent-primary);background:var(--surface-accent)}.settings-dialog__nav-list button>span:last-child{gap:2px;min-width:0;display:grid}.settings-dialog__nav-list strong,.settings-dialog__nav-list small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.settings-dialog__nav-list strong{font-size:.88rem;font-weight:720}.settings-dialog__nav-list small{color:var(--text-tertiary);font-size:.7rem;font-weight:650}.settings-dialog__content{grid-template-rows:auto minmax(0,1fr) auto;min-width:0;min-height:0;display:grid}.settings-dialog__header{align-items:center;gap:var(--space-3);border-bottom:1px solid #e3ddd4;min-width:0;padding:20px 24px;display:flex}.settings-dialog__header>div{gap:2px;min-width:0;display:grid}.settings-dialog__header h2{color:var(--text-primary);font-family:var(--font-display);margin:0;font-size:1.18rem;font-weight:720;line-height:1.15}.settings-dialog__header p{color:var(--text-secondary);margin:0;font-size:.82rem;font-weight:620;line-height:1.35}.settings-dialog__header .ui-button{flex:none;margin-left:auto}.settings-dialog__body{min-width:0;min-height:0;padding:18px 24px;overflow:auto}.settings-section{gap:18px;min-width:0;display:grid}.settings-voice-summary{justify-content:space-between;align-items:end;gap:var(--space-3);min-width:0;display:flex}.settings-voice-summary>div{gap:3px;min-width:0;display:grid}.settings-voice-summary>div:last-child{text-align:right;justify-items:end}.settings-voice-summary strong{overflow-wrap:anywhere;color:var(--text-primary);font-weight:720}.settings-voice-summary>div:last-child strong{font-family:var(--font-mono);font-size:1rem}.settings-voice-summary span{overflow-wrap:anywhere;color:var(--text-secondary);font-size:.78rem;font-weight:620;line-height:1.35}.settings-range-keyboard{padding:20px 16px 12px}.settings-range-stepper-row{margin-top:-6px}.settings-voice-actions{justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.setting-row{border-bottom:1px solid #e3ddd4;align-items:center;gap:18px;min-width:0;padding:14px 0;display:flex}.setting-row[data-last]{border-bottom:0}.setting-row>div:first-child{flex:auto;gap:3px;min-width:0;display:grid}.setting-row>div:last-child{flex:none;min-width:min(100%,220px)}.setting-row strong{color:var(--text-primary);font-size:.92rem;font-weight:720}.setting-row span{overflow-wrap:anywhere;max-width:310px;color:var(--text-secondary);font-size:.78rem;font-weight:620;line-height:1.4}.settings-tempo-control{gap:9px;width:220px;display:grid}.settings-tempo-control output{color:var(--text-primary);font-family:var(--font-mono);justify-self:end;font-size:.84rem;font-weight:720}.settings-tempo-control input[type=range]{width:100%;accent-color:var(--accent-primary)}.settings-tempo-control>div{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.settings-tempo-control button{min-width:0;min-height:30px;color:var(--text-secondary);background:var(--bg-secondary);font:inherit;cursor:pointer;border:1px solid #e3ddd4;border-radius:9px;padding:0 8px;font-size:.72rem;font-weight:720}.settings-tempo-control button[data-active]{border-color:var(--accent-primary);color:var(--accent-coral-deep);background:var(--surface-accent)}.settings-device-control{justify-items:end;gap:8px;width:220px;display:grid}.settings-device-dropdown{width:220px}.settings-device-control .ui-button{justify-self:end}.settings-level-meter{justify-items:end;gap:6px;display:grid}.settings-level-meter>div{align-items:center;gap:3px;height:30px;display:flex}.settings-level-meter>div span{width:5px;height:calc(8px + var(--meter-index,1) * 1px);background:var(--bg-tertiary);border-radius:2px;display:block}.settings-level-meter>div span:first-child{height:8px}.settings-level-meter>div span:nth-child(2){height:9px}.settings-level-meter>div span:nth-child(3){height:10px}.settings-level-meter>div span:nth-child(4){height:11px}.settings-level-meter>div span:nth-child(5){height:12px}.settings-level-meter>div span:nth-child(6){height:13px}.settings-level-meter>div span:nth-child(7){height:14px}.settings-level-meter>div span:nth-child(8){height:15px}.settings-level-meter>div span:nth-child(9){height:16px}.settings-level-meter>div span:nth-child(10){height:17px}.settings-level-meter>div span:nth-child(11){height:18px}.settings-level-meter>div span:nth-child(12){height:19px}.settings-level-meter>div span:nth-child(13){height:20px}.settings-level-meter>div span:nth-child(14){height:21px}.settings-level-meter>div span:nth-child(15){height:22px}.settings-level-meter>div span:nth-child(16){height:23px}.settings-level-meter>div span:nth-child(17){height:24px}.settings-level-meter>div span:nth-child(18){height:25px}.settings-level-meter>div span:nth-child(19){height:26px}.settings-level-meter>div span:nth-child(20){height:27px}.settings-level-meter>div span:nth-child(21){height:28px}.settings-level-meter>div span:nth-child(22){height:29px}.settings-level-meter>div span:nth-child(23),.settings-level-meter>div span:nth-child(24),.settings-level-meter>div span:nth-child(25),.settings-level-meter>div span:nth-child(26){height:30px}.settings-level-meter>div span[data-lit][data-zone=good]{background:var(--status-success)}.settings-level-meter>div span[data-lit][data-zone=warm]{background:var(--status-warning)}.settings-level-meter>div span[data-lit][data-zone=hot]{background:var(--accent-primary)}.settings-level-meter>span{color:var(--text-secondary);text-align:right;font-size:.72rem;font-weight:650}.settings-inline-error{color:var(--status-danger-text);margin:-4px 0 0;font-size:.78rem;font-weight:650}.settings-dialog__footer{align-items:center;gap:var(--space-2);border-top:1px solid #e3ddd4;padding:14px 24px;display:flex}.settings-dialog__footer>button:first-child{min-height:32px;color:var(--text-secondary);font:inherit;text-underline-offset:3px;cursor:pointer;background:0 0;border:0;align-items:center;gap:6px;padding:0;font-size:.78rem;font-weight:720;text-decoration:underline;display:inline-flex}.settings-dialog__footer .ui-button{margin-left:auto}@keyframes range-setup-in{0%{opacity:0;transform:translateY(8px)scale(.99)}to{opacity:1;transform:none}}@keyframes range-eq{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}@keyframes range-pulse{0%{box-shadow:0 0 #3fa46a66}to{box-shadow:0 0 0 10px #3fa46a00}}@media (prefers-reduced-motion:reduce){.ui-card--interactive,.ui-progress__indicator,.dropzone,.range-mode-tab{transition:none}.ui-card--interactive:hover,.dropzone--active,.dropzone:hover{transform:none}.range-setup-card,.settings-dialog__panel,.range-setup-toast,.range-eq span,.range-saved__check{animation:none}}@media (width<=760px){:root{--pc-mobile-nav-height:calc(74px + env(safe-area-inset-bottom))}.pc-app-shell{grid-template-columns:1fr;width:100vw;height:100dvh;min-height:100dvh;overflow:hidden}.pc-app-shell__sidebar{border-right:0;display:none}.pc-app-shell__main,.pc-app-shell__content{min-height:0}.pc-app-shell__content{overflow:auto}.pc-app-shell__mobile-nav{z-index:calc(var(--z-portaled-popover) - 4);min-height:var(--pc-mobile-nav-height);padding:8px 12px calc(26px + env(safe-area-inset-bottom));border-top:1px solid var(--border-subtle);background:color-mix(in srgb, var(--bg-secondary) 92%, transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);display:block;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -14px 34px #462d191a}.bottom-nav__trigger{min-height:40px}.sidebar-nav{min-height:auto}.range-setup__stage,.settings-dialog{align-items:start;padding:16px}.settings-dialog__panel{grid-template-columns:1fr;width:100%;min-height:0;max-height:calc(100vh - 32px)}.settings-dialog__nav{border-bottom:1px solid #e3ddd4;border-right:0;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;padding:14px 16px;display:grid}.settings-dialog__nav-title{padding:0}.settings-dialog__nav-title strong{display:none}.settings-dialog__nav-list{gap:6px;display:flex;overflow-x:auto}.settings-dialog__nav-list button{flex:none;grid-template-columns:auto minmax(0,1fr);min-width:118px;padding:8px}.settings-dialog__nav-list button>span:first-child{width:28px;height:28px}.settings-dialog__nav-list small{display:none}.settings-dialog__header,.settings-dialog__body,.settings-dialog__footer{padding-left:18px;padding-right:18px}.settings-dialog__header h2{font-size:1.08rem}.range-setup-card,.range-setup-card--saved{width:100%;max-height:calc(100vh - 32px)}.range-setup-card__header{grid-template-columns:auto minmax(0,1fr) auto;padding:20px 18px 0}.range-mode-tabs{margin:18px 18px 0}.range-mode-tab{min-height:40px;font-size:.8rem}.range-setup-card__body{padding:18px 18px 6px}.range-stepper-row,.settings-range-stepper-row,.range-setup-card__footer{grid-template-columns:1fr}.range-stepper-row{display:grid}.settings-voice-summary,.setting-row,.settings-voice-actions{flex-direction:column;align-items:stretch}.settings-voice-summary>div:last-child{text-align:left;justify-items:start}.setting-row>div:last-child,.settings-tempo-control,.settings-device-control,.settings-device-dropdown{width:100%;min-width:0}.settings-device-control{justify-items:stretch}.settings-level-meter{justify-items:start}.settings-level-meter>div{max-width:100%;overflow:hidden}.range-setup-card__footer,.range-setup-card__actions,.settings-dialog__footer,.range-saved__actions{flex-direction:column;align-items:stretch}.range-setup-card__footer{padding:14px 18px 18px}.range-summary,.range-setup-card__actions,.range-saved__actions{width:100%}.range-setup-card__actions{margin-left:0}.settings-dialog__footer .ui-button{width:100%;margin-left:0}.range-primary-button,.range-ghost-button{width:100%}.range-saved{padding:32px 24px 28px}.range-setup-toast{border-radius:14px;flex-direction:column;align-items:stretch;gap:10px;width:100%;min-height:auto;padding:14px}.range-setup-toast__icon{border-radius:10px;width:32px;height:32px}.range-setup-toast__copy{gap:2px}.range-setup-toast__copy strong,.range-setup-toast__copy span{white-space:normal}.range-setup-toast__copy strong{font-size:.9rem;line-height:1.12}.range-setup-toast__copy span{font-size:.8rem;line-height:1.18}.range-setup-toast button{width:100%;min-width:0;min-height:40px;font-size:.86rem}}.app-shell{background:var(--bg-primary);min-height:100vh}.pitch-shell{background:var(--bg-primary)}.pitch-shell .pc-app-shell__header{display:none}.shell-brand{align-items:center;gap:var(--space-2);min-width:0;padding:4px 8px 0;display:flex}.shell-brand__mark{border-radius:var(--radius-lg);background:#fff;border:1px solid #fd9065;flex:none;place-items:center;width:34px;height:34px;padding:2px;display:grid;overflow:hidden;box-shadow:0 6px 16px #ee6c4d2e}.shell-brand__logo{border-radius:inherit;object-fit:cover;width:100%;height:100%;display:block}.shell-brand__name{color:var(--text-primary);font-family:var(--font-display);text-overflow:ellipsis;white-space:nowrap;font-size:1.08rem;font-weight:720;line-height:1.1;overflow:hidden}.shell-local-save{align-items:center;gap:var(--space-2);min-width:0;padding:var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--bg-tertiary);display:flex}.shell-local-save__mark{border-radius:var(--radius-lg);width:28px;height:28px;color:var(--accent-primary);background:var(--surface-accent);flex:none;place-items:center;display:grid}.shell-local-save>span:last-child{gap:1px;min-width:0;display:grid}.shell-local-save strong,.shell-local-save span span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.shell-local-save strong{color:var(--text-primary);font-size:.78rem;font-weight:760}.shell-local-save span span{color:var(--text-secondary);font-size:.68rem;font-weight:640}.shell-user-card{width:100%;color:inherit;font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;transition:background-color .15s,box-shadow .15s,transform .15s}.shell-user-card:hover{background:#ffffff57}.shell-user-card:focus-visible{outline:2px solid color-mix(in srgb, var(--accent-primary) 58%, transparent);outline-offset:4px}.shell-user-card:active{transform:translateY(1px)}.shell-user-sun{color:var(--mock-muted-2,var(--text-tertiary));place-items:center;display:grid}.shell-mobile-settings-bar{display:none}.shell-topbar{justify-content:space-between;align-items:center;gap:var(--space-3);min-width:0;min-height:52px;padding:var(--space-2) var(--space-4);display:flex}.shell-topbar__copy{gap:1px;min-width:0;display:grid}.shell-topbar__copy strong{color:var(--text-primary);font-family:var(--font-display);text-overflow:ellipsis;white-space:nowrap;font-size:.96rem;font-weight:720;overflow:hidden}.shell-page{align-content:start;gap:var(--space-4);min-width:0;min-height:100%;padding:var(--space-5);display:grid}.home-mode-grid{gap:var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.home-summary-grid{gap:var(--space-3);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.home-spotlight-grid{gap:var(--space-3);grid-template-columns:minmax(0,1.35fr) minmax(260px,.65fr);display:grid}.home-recommendation-card,.home-week-card{align-content:start;display:grid}.home-card-kicker,.home-recommendation-meta{gap:var(--space-2);flex-wrap:wrap;display:flex}.home-card-kicker{align-items:center}.home-recommendation-meta span{border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-secondary);background:var(--bg-elevated);padding:4px 8px;font-size:.72rem;font-weight:720;line-height:1}.week-activity-strip{align-items:end;gap:var(--space-2);grid-template-columns:repeat(7,minmax(0,1fr));min-height:94px;display:grid}.week-activity-strip__day{min-width:0;color:var(--text-tertiary);place-items:end center;gap:6px;font-size:.66rem;font-weight:760;display:grid}.week-activity-strip__bar{border:1px solid color-mix(in srgb, var(--accent-primary) 30%, var(--border-subtle));border-radius:var(--radius-full) var(--radius-full) 3px 3px;background:linear-gradient(180deg, var(--accent-primary), var(--accent-tertiary));width:100%;max-width:24px;min-height:8px;display:block}.progress-dashboard-grid{gap:var(--space-3);grid-template-columns:minmax(260px,.8fr) minmax(0,1.2fr);align-items:start;display:grid}.progress-exercises-card{grid-row:span 2}.progress-exercise-list,.progress-session-list{gap:var(--space-2);margin:0;padding:0;list-style:none;display:grid}.progress-exercise-list li{align-items:center;gap:var(--space-3);min-width:0;padding:var(--space-2);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--bg-primary);grid-template-columns:minmax(0,1fr) minmax(82px,auto) minmax(120px,auto);display:grid}.progress-exercise-list li>span:first-child{gap:2px;min-width:0;display:grid}.progress-exercise-list strong{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:780;overflow:hidden}.progress-exercise-list span span,.progress-exercise-list li>span:nth-child(2),.progress-exercise-list li>span:nth-child(3){overflow-wrap:anywhere;color:var(--text-secondary);font-size:.7rem;font-weight:700;line-height:1.3}.progress-session-list li{gap:var(--space-2);padding:var(--space-2);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--bg-primary);grid-template-columns:auto minmax(0,1fr);align-items:start;display:grid}.shell-page .exercise-library{margin:0}.coach-workspace{grid-template-rows:auto minmax(0,1fr);width:min(1440px,100%);min-height:100vh;margin:0 auto;display:grid}.top-bar{align-items:center;gap:var(--space-3);min-height:42px;padding:4px var(--space-3);background:var(--bg-primary);grid-template-columns:minmax(0,1fr) auto;display:grid;position:relative}.top-bar:after{background:var(--border-subtle);content:"";pointer-events:none;width:100vw;height:1px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.brand-lockup{align-items:center;gap:var(--space-2);min-width:0;display:flex}.brand-mark{border:1px solid color-mix(in srgb, var(--accent-primary) 24%, var(--border-default));border-radius:var(--radius-md);width:28px;height:28px;color:color-mix(in srgb, var(--accent-primary) 88%, var(--text-primary));background:color-mix(in srgb, var(--accent-primary) 12%, transparent);flex:none;place-items:center;display:grid}.brand-copy{gap:1px;min-width:0;display:grid}.brand-lockup h1{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.86rem;font-weight:780;line-height:1.1;overflow:hidden}.brand-lockup p,.readout-label{color:var(--text-secondary);font-size:.68rem;font-weight:720;line-height:1.2}.top-actions{justify-content:flex-end;align-items:center;gap:var(--space-2);min-width:0;display:flex}.mode-action{white-space:nowrap}.session-readout{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-secondary);gap:1px;min-width:132px;padding:4px 8px;display:grid}.session-readout strong{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;font-weight:760;overflow:hidden}.exercise-library{min-height:0;margin:var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-lg);background:var(--bg-secondary);grid-template-rows:auto auto minmax(0,1fr);display:grid;overflow:hidden}.library-heading{justify-content:space-between;align-items:center;gap:var(--space-3);min-height:44px;padding:7px var(--space-3);border-bottom:1px solid var(--border-subtle);background:var(--bg-primary);display:flex}.mock-home--with-range-prompt,.mock-practice-page--with-range-prompt{padding-bottom:92px}.range-prompt-floating{right:0;bottom:max(18px, calc(env(safe-area-inset-bottom) + 12px));z-index:calc(var(--z-portaled-popover) - 2);padding:0 var(--space-6);pointer-events:none;justify-content:center;display:flex;position:fixed;left:212px}.range-prompt-floating .range-setup-toast{pointer-events:auto}.library-heading h2{color:var(--text-primary);margin-top:1px;font-size:1rem;font-weight:780}.library-heading>span{color:var(--text-tertiary);font-size:.72rem;font-weight:720}.library-filters{min-width:0;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary)}.library-filter-tabs .sidebar-tabs__list{gap:var(--space-2)}.library-filter-tabs .sidebar-tabs__trigger{border-color:var(--border-subtle);border-radius:var(--radius-full);background:var(--bg-primary);min-height:32px;padding:0 10px;font-size:.75rem}.library-filter-tabs .sidebar-tabs__trigger[data-state=active]{border-color:color-mix(in srgb, var(--accent-primary) 36%, var(--border-default))}.exercise-groups{align-content:start;gap:var(--space-4);min-height:0;padding:var(--space-3);display:grid;overflow:auto}.exercise-group{align-content:start;gap:var(--space-2);min-width:0;display:grid}.exercise-group__header{justify-content:space-between;align-items:center;gap:var(--space-3);min-width:0;display:flex}.exercise-group__header h3{overflow-wrap:anywhere;color:var(--text-primary);font-size:.78rem;font-weight:780;line-height:1.2}.exercise-group__header span{color:var(--text-tertiary);font-size:.68rem;font-weight:720}.exercise-list{align-content:start;gap:var(--space-2);display:grid}.exercise-option{align-items:center;gap:var(--space-3);min-height:70px;padding:var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-primary);background:var(--bg-primary);cursor:pointer;text-align:left;grid-template-columns:86px minmax(0,1fr) minmax(160px,auto) 72px;transition:background-color .12s,border-color .12s,box-shadow .12s;display:grid}.exercise-option:not(:disabled):hover{border-color:color-mix(in srgb, var(--accent-primary) 42%, var(--border-default));background:color-mix(in srgb, var(--accent-primary) 6%, var(--bg-primary))}.exercise-option:disabled{cursor:not-allowed;opacity:.55}.exercise-option-active{border-color:var(--accent-primary);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent-primary) 62%, transparent)}.difficulty-meter{grid-template-columns:repeat(5,1fr);gap:4px;width:78px;display:grid}.difficulty-meter span{border-radius:var(--radius-full);background:var(--border-default);height:6px}.difficulty-meter .difficulty-on{background:var(--accent-tertiary)}.exercise-copy{align-content:start;gap:3px;min-width:0;display:grid}.exercise-copy strong{overflow-wrap:anywhere;color:var(--text-primary);font-size:.92rem;font-weight:780;line-height:1.15}.exercise-copy span{color:var(--text-secondary);font-size:.74rem;font-weight:620;line-height:1.32}.exercise-copy .exercise-progress{color:var(--accent-primary);font-weight:760}.exercise-meta{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.exercise-meta span{overflow-wrap:anywhere;border:1px solid var(--border-subtle);border-radius:var(--radius-full);max-width:100%;color:var(--text-secondary);background:var(--bg-elevated);padding:3px 7px;font-size:.68rem;font-weight:760}.exercise-start{border:1px solid color-mix(in srgb, var(--accent-primary) 42%, var(--border-default));border-radius:var(--radius-md);min-width:58px;color:var(--text-primary);background:var(--surface-selected);text-align:center;justify-self:end;padding:6px 10px;font-size:.74rem;font-weight:760}.practice-layout{gap:var(--space-3);min-height:0;padding:var(--space-3);grid-template-columns:minmax(0,1fr) 342px;display:grid}.lesson-panel,.side-panel{border:1px solid var(--border-default);border-radius:var(--radius-lg);background:var(--bg-secondary);min-width:0;min-height:0;overflow:hidden}.lesson-panel{grid-template-rows:auto auto auto minmax(0,1fr) auto auto;display:grid}.side-panel{align-content:start;gap:var(--space-2);padding:var(--space-2);display:grid;overflow:auto}.exercise-strip{border-bottom:1px solid var(--border-subtle);background:var(--bg-primary);grid-template-columns:1.3fr repeat(3,minmax(90px,1fr));gap:0;display:grid}.exercise-strip>div,.control-group,.feedback-panel{background:var(--bg-secondary);min-width:0}.exercise-strip>div{min-height:58px;padding:9px var(--space-3);border-right:1px solid var(--border-subtle);align-content:center;display:grid}.exercise-strip>div:last-child{border-right:0}.exercise-strip strong{color:var(--text-primary);letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;margin-top:4px;font-size:.9rem;font-weight:780;line-height:1.15;display:block;overflow:hidden}.exercise-select-card{padding:0}.readout-dropdown-trigger{min-height:28px;color:var(--text-primary);background:0 0;border:0;border-radius:0;padding:0;font-size:.9rem;font-weight:780;line-height:1.15}.readout-dropdown-trigger:hover:not(:disabled){color:var(--accent-primary);background:0 0}.readout-dropdown-trigger:focus-visible{box-shadow:0 0 0 2px var(--focus-ring)}.practice-guidance{align-items:stretch;gap:var(--space-3);padding:var(--space-3);border-bottom:1px solid var(--border-subtle);background:var(--bg-primary);grid-template-columns:minmax(0,1fr) minmax(180px,auto);display:grid}.practice-guidance .coach-bubble__message{background:var(--bg-secondary);align-content:center;gap:3px;display:grid}.practice-guidance .coach-bubble__message strong{overflow-wrap:anywhere;color:var(--text-primary);font-family:var(--font-display);font-size:.92rem;font-weight:780;line-height:1.15}.practice-guidance .coach-bubble__message span{overflow-wrap:anywhere;color:var(--text-secondary);font-size:.78rem;font-weight:620}.practice-status-stack{min-width:0;padding:var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--bg-secondary);align-content:center;justify-items:end;gap:6px;display:grid}.practice-status-stack>span:last-child{overflow-wrap:anywhere;max-width:220px;color:var(--text-secondary);text-align:right;font-size:.74rem;font-weight:650;line-height:1.35}.practice-main-card{grid-template-rows:auto minmax(0,1fr);min-width:0;min-height:0;display:grid}.practice-target-row{border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);align-items:stretch;min-width:0;display:flex}.target-checkpoint-strip{gap:var(--space-2);min-width:0;padding:var(--space-2) var(--space-3);background:var(--bg-secondary);flex:auto;grid-template-columns:repeat(auto-fit,minmax(86px,1fr));margin:0;list-style:none;display:grid;overflow-x:auto}.target-checkpoint{align-items:center;gap:3px var(--space-2);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--bg-primary);grid-template-rows:auto auto;grid-template-columns:auto minmax(0,1fr);min-width:0;min-height:50px;padding:7px;display:grid}.target-checkpoint__chip{border-radius:var(--radius-md);width:24px;height:24px;color:var(--text-inverse);background:var(--accent-tertiary);grid-row:span 2;place-items:center;font-size:.72rem;font-weight:820;display:grid}.target-checkpoint strong{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:800;line-height:1.1;overflow:hidden}.target-checkpoint__label{min-width:0;color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;font-size:.68rem;font-weight:760;line-height:1.1;overflow:hidden}.checkpoint-status-legacy{clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.target-checkpoint--pass,.target-checkpoint--passWithWarning{border-color:color-mix(in srgb, var(--status-success) 42%, var(--border-subtle));background:var(--surface-success)}.target-checkpoint--pass .target-checkpoint__chip,.target-checkpoint--passWithWarning .target-checkpoint__chip{background:var(--status-success)}.target-checkpoint--passWithWarning{border-color:color-mix(in srgb, var(--status-warning) 46%, var(--border-subtle));background:var(--surface-warning)}.target-checkpoint--passWithWarning .target-checkpoint__chip{background:var(--status-warning)}.target-checkpoint--flat,.target-checkpoint--sharp,.target-checkpoint--wrongNote,.target-checkpoint--wrongDirection,.target-checkpoint--offContour,.target-checkpoint--unstable,.target-checkpoint--unclear,.target-checkpoint--missed{border-color:color-mix(in srgb, var(--status-danger) 40%, var(--border-subtle));background:var(--surface-danger)}.target-checkpoint--flat .target-checkpoint__chip,.target-checkpoint--sharp .target-checkpoint__chip,.target-checkpoint--wrongNote .target-checkpoint__chip,.target-checkpoint--wrongDirection .target-checkpoint__chip,.target-checkpoint--offContour .target-checkpoint__chip,.target-checkpoint--unstable .target-checkpoint__chip,.target-checkpoint--unclear .target-checkpoint__chip,.target-checkpoint--missed .target-checkpoint__chip{background:var(--status-danger)}.practice-score-readout{min-width:82px;color:var(--text-secondary);text-align:right;background:0 0;border-left:0;flex:none;align-content:center;justify-items:end;gap:2px;padding:0;font-size:.7rem;font-weight:650;line-height:1.1;display:grid}.practice-score-readout strong{color:var(--text-primary);font-size:1.1rem;font-weight:820;line-height:1}.timeline-frame{background:var(--bg-canvas);width:100%;height:100%;min-height:360px;overflow:hidden}.exercise-screen-page{background:var(--bg-primary);min-height:100vh}.exercise-screen{gap:var(--space-4);flex-direction:column;min-height:100vh;padding:26px 28px 28px;display:flex}.exercise-screen__header{align-items:center;gap:var(--space-5);grid-template-columns:minmax(240px,1fr) auto;min-width:0;display:grid}.exercise-screen__title-row,.exercise-control-bar,.exercise-screen__title-copy,.exercise-coach-row,.exercise-action-bar{min-width:0}.exercise-screen__title-row{align-items:center;gap:var(--space-4);display:flex}.exercise-back-action{background:var(--bg-secondary);border-radius:14px;flex:none;width:48px;height:48px;box-shadow:0 8px 22px #462d1912}.exercise-screen__title-copy{gap:2px;display:grid}.practice-title-dropdown{min-height:32px;box-shadow:none;color:var(--text-primary);font-family:var(--font-display);background:0 0;border:0;padding:0;font-size:1.52rem;font-weight:760;line-height:1.1}.practice-title-dropdown:hover:not(:disabled),.practice-title-dropdown:focus{background:0 0}.practice-title-dropdown .dropdown-trigger-icon{display:none}.exercise-screen__title-copy p{color:var(--text-secondary);font-size:.84rem;font-weight:660}.exercise-control-bar{justify-content:flex-end;align-items:center;gap:var(--space-3);display:flex}.exercise-setting-popover{position:relative}.exercise-setting-chip{border:1px solid var(--border-subtle);min-width:166px;height:56px;color:var(--text-primary);background:var(--bg-secondary);cursor:pointer;text-align:left;border-radius:14px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:0 14px;display:grid;box-shadow:0 8px 24px #462d190f}.exercise-setting-chip__icon{color:var(--text-secondary)}.exercise-setting-chip__copy{gap:2px;min-width:0;display:grid}.exercise-setting-chip__copy>span{color:var(--text-secondary);font-size:.72rem;font-weight:720;line-height:1}.exercise-setting-chip__copy strong{color:var(--text-primary);font-family:var(--font-mono);text-overflow:ellipsis;white-space:nowrap;font-size:.92rem;font-weight:760;line-height:1.1;overflow:hidden}.exercise-setting-chip__chevron{color:var(--text-tertiary);font-size:1.4rem;line-height:1}.exercise-setting-popover__content{z-index:20;gap:var(--space-3);width:272px;padding:var(--space-4);border:1px solid var(--border-default);background:var(--bg-secondary);border-radius:14px;display:grid;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 18px 50px #462d1938}.exercise-setting-popover__content--tempo{gap:var(--space-3);width:min(272px,100vw - 56px);padding:var(--space-4);border-radius:14px}.exercise-key-stepper{align-items:center;gap:var(--space-3);grid-template-columns:40px minmax(0,1fr) 40px;display:grid}.exercise-key-stepper button{border:1px solid var(--border-subtle);width:40px;height:40px;color:var(--text-primary);background:var(--bg-tertiary);cursor:pointer;border-radius:10px;font-size:1.15rem;font-weight:760}.exercise-key-stepper button:disabled{cursor:not-allowed;opacity:.45}.exercise-key-stepper span{justify-items:center;gap:2px;min-width:0;display:grid}.exercise-key-stepper strong{color:var(--text-primary);font-family:var(--font-display);font-size:1.55rem;line-height:1}.exercise-key-stepper small,.exercise-popover-note{color:var(--text-secondary);font-size:.76rem;font-weight:650;line-height:1.35}.exercise-popover-note{color:var(--status-success-text);background:var(--surface-success);border-radius:9px;padding:8px 10px}.exercise-segmented-row,.exercise-tempo-presets,.exercise-mode-toggle{border:1px solid var(--border-subtle);background:var(--bg-tertiary);border-radius:12px;align-items:center;gap:4px;padding:4px;display:inline-flex}.exercise-segmented-row button,.exercise-tempo-presets button,.exercise-mode-toggle button{min-height:34px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:9px;padding:0 12px;font-size:.78rem;font-weight:760}.exercise-segmented-row button[data-active],.exercise-tempo-presets button[data-active],.exercise-mode-toggle button[data-active]{color:var(--text-primary);background:var(--bg-secondary);box-shadow:0 2px 7px #462d191f}.exercise-tempo-control{gap:var(--space-3);display:grid}.exercise-tempo-slider,.exercise-transport-slider{border-radius:var(--radius-full);appearance:none;border:1px solid #3c2a1c47;outline:none;width:100%;height:10px}.exercise-tempo-slider{background:linear-gradient(90deg, var(--accent-primary) 0 var(--tempo-progress,50%), #454545 var(--tempo-progress,50%) 100%)}.exercise-setting-popover__content--tempo .exercise-tempo-slider{height:7px}.exercise-transport-slider{background:linear-gradient(90deg, var(--accent-primary) 0 var(--transport-progress,0%), var(--bg-surface) var(--transport-progress,0%) 100%);border-color:#0000;height:7px}.exercise-tempo-slider::-webkit-slider-thumb{background:var(--accent-primary);cursor:pointer;appearance:none;border:0;border-radius:50%;width:34px;height:34px;box-shadow:0 4px 12px #462d1933}.exercise-transport-slider::-webkit-slider-thumb{background:var(--accent-primary);cursor:pointer;appearance:none;border:0;border-radius:50%;width:34px;height:34px;box-shadow:0 4px 12px #462d1933}.exercise-transport-slider::-webkit-slider-thumb{background:var(--bg-secondary);border:3px solid var(--accent-primary);width:22px;height:22px}.exercise-tempo-slider::-moz-range-thumb{background:var(--accent-primary);cursor:pointer;border:0;border-radius:50%;width:34px;height:34px;box-shadow:0 4px 12px #462d1933}.exercise-transport-slider::-moz-range-thumb{background:var(--accent-primary);cursor:pointer;border:0;border-radius:50%;width:34px;height:34px;box-shadow:0 4px 12px #462d1933}.exercise-transport-slider::-moz-range-thumb{background:var(--bg-secondary);border:3px solid var(--accent-primary);width:22px;height:22px}.exercise-setting-popover__content--tempo .exercise-tempo-slider::-webkit-slider-thumb{width:24px;height:24px}.exercise-setting-popover__content--tempo .exercise-tempo-slider::-moz-range-thumb{width:24px;height:24px}.exercise-tempo-presets button{min-width:0}.exercise-setting-popover__content--tempo .exercise-tempo-presets{width:100%}.exercise-setting-popover__content--tempo .exercise-tempo-presets button{border-radius:9px;flex:1 1 0;min-height:34px;padding:0 10px;font-family:inherit;font-size:.78rem;font-weight:760}.exercise-control-divider{background:var(--border-subtle);width:1px;height:34px}.exercise-mode-toggle{border-radius:14px;height:56px;padding:5px}.exercise-mode-toggle button{align-items:center;gap:7px;height:44px;padding:0 18px;font-size:.9rem;display:inline-flex}.exercise-mode-toggle button:disabled{cursor:not-allowed;opacity:.55}.exercise-header-toggle{border:1px solid var(--border-subtle);width:52px;height:52px;color:var(--text-secondary);background:var(--bg-secondary);cursor:pointer;border-radius:13px;flex:none;place-items:center;display:inline-grid;box-shadow:0 8px 24px #462d190f}.exercise-header-toggle:hover{color:var(--text-primary);transform:translateY(-1px)}.exercise-coach-row{align-items:center;gap:var(--space-4);display:flex}.exercise-coach-mark{width:54px;height:54px;color:var(--text-inverse);background:linear-gradient(145deg, #ff9f6b, var(--accent-primary));border-radius:16px;flex:none;place-items:center;display:grid;box-shadow:0 12px 26px #ee6c4d47}.exercise-coach-bubble{border:1px solid var(--border-subtle);max-width:760px;min-height:54px;color:var(--text-primary);background:var(--bg-secondary);border-radius:6px 18px 18px;align-items:baseline;gap:5px;padding:15px 20px;font-size:1.02rem;line-height:1.35;display:flex;box-shadow:0 8px 24px #462d190d}.exercise-coach-bubble strong{font-weight:780}.exercise-coach-bubble span{color:var(--text-primary);font-weight:520}.exercise-roll-card{border:1px solid var(--border-subtle);background:var(--bg-secondary);border-radius:22px;grid-template-rows:auto minmax(0,1fr);min-width:0;height:clamp(360px,100vh - 270px,860px);min-height:360px;padding:18px 24px 24px;display:grid;box-shadow:0 20px 50px #462d191a}.practice-target-row{align-items:center;gap:var(--space-4);min-width:0;padding:0 0 var(--space-3);background:0 0;border-bottom:0;display:flex}.exercise-roll-card .note-checkpoint-strip{background:0 0;border:0;flex:auto;align-items:center;gap:28px;min-width:0;margin-top:6px;margin-bottom:8px;padding:0;display:flex;overflow-x:auto}.exercise-roll-card .note-checkpoint{border:1px solid color-mix(in srgb, var(--border-default) 78%, transparent);background:var(--bg-tertiary);border-radius:14px;flex:none;grid-template-rows:auto auto;grid-template-columns:auto minmax(0,1fr);column-gap:12px;min-width:120px;min-height:58px;padding:10px 14px;display:grid;position:relative}.exercise-roll-card .note-checkpoint--active{background:#4a84a61f;border-color:#4a84a65c;box-shadow:inset 0 0 0 1px #4a84a614}.exercise-roll-card .note-checkpoint+.note-checkpoint:before{border-top:2px dotted var(--border-default);content:"";width:18px;position:absolute;top:50%;right:calc(100% + 5px)}.exercise-roll-card .note-checkpoint__degree{border:2px dashed var(--text-tertiary);color:#0000;background:var(--bg-secondary);border-radius:50%;grid-row:1/span 2;align-self:center;place-items:center;width:28px;height:28px;font-size:0;line-height:1;display:inline-grid;position:relative}.exercise-roll-card .note-checkpoint--active .note-checkpoint__degree{border:2px dashed var(--text-tertiary);color:#0000;background:var(--bg-secondary);box-shadow:none;font-size:0}.exercise-roll-card .note-checkpoint--active .note-checkpoint__degree:after{content:"";border:2px solid #ee714b73;border-radius:50%;animation:.9s ease-out infinite checkpointReferencePulse;position:absolute;inset:-7px}@keyframes checkpointReferencePulse{0%{opacity:.9;transform:scale(.72)}80%{opacity:0;transform:scale(1.18)}to{opacity:0;transform:scale(1.18)}}.exercise-roll-card .note-checkpoint--pass,.exercise-roll-card .note-checkpoint--passWithWarning{background:color-mix(in srgb, var(--status-success) 12%, var(--bg-secondary));border-color:#0000}.exercise-roll-card .note-checkpoint__label{color:var(--text-secondary);grid-area:1/2;font-size:.78rem;font-weight:720;line-height:1.1}.exercise-roll-card .note-checkpoint strong{color:var(--text-primary);font-family:var(--font-mono);grid-area:2/2;font-size:1rem;font-weight:760;line-height:1.05}.checkpoint-status-legacy{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.exercise-roll-card .note-checkpoint--pass .note-checkpoint__degree,.exercise-roll-card .note-checkpoint--passWithWarning .note-checkpoint__degree{color:var(--text-inverse);background:var(--status-success);border:0;font-size:0}.exercise-roll-card .note-checkpoint--pass .note-checkpoint__degree svg,.exercise-roll-card .note-checkpoint--passWithWarning .note-checkpoint__degree svg{color:currentColor;stroke-linecap:round;stroke-linejoin:round;display:block}.exercise-roll-card .note-checkpoint--flat .note-checkpoint__degree,.exercise-roll-card .note-checkpoint--sharp .note-checkpoint__degree,.exercise-roll-card .note-checkpoint--wrongNote .note-checkpoint__degree,.exercise-roll-card .note-checkpoint--wrongDirection .note-checkpoint__degree,.exercise-roll-card .note-checkpoint--offContour .note-checkpoint__degree,.exercise-roll-card .note-checkpoint--unstable .note-checkpoint__degree,.exercise-roll-card .note-checkpoint--unclear .note-checkpoint__degree,.exercise-roll-card .note-checkpoint--missed .note-checkpoint__degree{color:var(--text-inverse);background:var(--status-warning);border:0;font-size:.76rem}.practice-score-readout{min-width:78px;color:var(--text-secondary);text-align:right;flex:none}.practice-score-readout strong{color:var(--text-secondary);font-family:var(--font-display);font-size:2rem;font-weight:780;line-height:1;display:block}.practice-score-readout strong span{color:var(--text-secondary);font-size:1.12rem;font-weight:620}.practice-score-readout>span{margin-top:4px;font-size:.76rem;font-weight:650;display:block}.exercise-roll-card .timeline-frame{border:1px solid var(--border-subtle);background:#fffdf9;border-radius:16px;min-height:0}.exercise-roll-card .pitch-timeline{--timeline-surface:#fffdf9;--timeline-target-band:#4a84a621;--timeline-target-line:#4a84a6a8;--timeline-grid-border:transparent;--timeline-grid-line:#2e26200f;--timeline-grid-strong-line:#2e26201c;--timeline-time-marker:#e4d7c857}.exercise-action-bar{align-items:center;gap:14px;min-height:58px;display:flex}.exercise-primary-action{min-width:142px}.exercise-restart-action.ui-button{border-color:color-mix(in srgb, var(--border-default) 88%, transparent);width:52px;height:52px;color:var(--text-primary);background:var(--bg-secondary);border-radius:13px}.exercise-restart-action.ui-button:hover:not(:disabled){background:var(--bg-secondary)}.exercise-auto-center{flex:auto;justify-content:center;min-width:0;display:flex}.exercise-auto-pill{max-width:100%;min-height:48px;color:var(--text-primary);background:var(--bg-secondary);white-space:nowrap;border:0;border-radius:13px;justify-content:center;align-items:center;gap:10px;padding:12px 24px;font-size:.98rem;font-weight:760;display:inline-flex}.exercise-auto-pill small{color:var(--text-secondary);font-size:.82rem;font-weight:620}.exercise-auto-pill--accent{color:var(--accent-primary);background:color-mix(in srgb, var(--accent-primary) 12%, transparent)}.exercise-auto-pill--info{color:#3a6e8c;background:#4a84a61f}.exercise-auto-pill--success{color:var(--status-success-text);background:var(--surface-success)}.exercise-auto-pill--warning{color:var(--status-warning-text);background:var(--surface-warning)}.exercise-auto-pill--idle{color:var(--text-secondary);background:var(--bg-secondary)}button.exercise-auto-pill{cursor:pointer}.exercise-eq-bars{align-items:center;gap:3px;height:16px;display:inline-flex}.exercise-eq-bars i{border-radius:var(--radius-full);transform-origin:50%;background:currentColor;width:3px;height:15px;animation:.9s ease-in-out infinite exerciseEq}.exercise-eq-bars i:nth-child(2){animation-delay:.12s}.exercise-eq-bars i:nth-child(3){animation-delay:.24s}@keyframes exerciseEq{0%,to{transform:scaleY(.35)}50%{transform:scaleY(1)}}@media (prefers-reduced-motion:reduce){.exercise-roll-card .note-checkpoint--active .note-checkpoint__degree:after,.exercise-eq-bars i{animation:none}}.exercise-transport-scrub{min-width:160px;padding:0 var(--space-2);flex:auto;gap:10px;display:grid;position:relative}.exercise-transport-scrub p{color:var(--text-tertiary);text-align:center;font-size:.76rem;font-weight:620;line-height:1}.exercise-detail-grid{gap:var(--space-3);margin-top:var(--space-5);padding-top:var(--space-2);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.exercise-detail-grid .control-group,.exercise-detail-grid .feedback-panel{min-height:100%}.song-practice-layout{grid-template-columns:minmax(0,1fr) 360px}.song-workbench{grid-template-rows:auto minmax(0,1fr) auto auto}.song-timeline-frame{min-height:420px}.song-stage-panel{min-width:0;padding:var(--space-3);border-bottom:1px solid var(--border-subtle);background:var(--bg-primary)}.song-stage-panel .dropzone{min-height:184px}.song-stage-actions{justify-content:center;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.song-upload-button{justify-content:center;align-items:center;gap:var(--space-2);min-height:36px;padding:0 var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);background:var(--bg-elevated);cursor:pointer;font-size:.82rem;font-weight:720;display:inline-flex;position:relative;overflow:hidden}.song-upload-button:hover{background:var(--bg-surface)}.song-upload-button input{opacity:0;cursor:pointer;position:absolute;inset:0}.song-upload-button:has(input:disabled){cursor:not-allowed;opacity:.55}.song-pipeline-card,.song-ready-card{gap:var(--space-3);display:grid}.song-stage-heading{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.song-stage-heading>span:last-child{color:var(--text-secondary);font-size:.74rem;font-weight:650}.song-pipeline-steps{gap:var(--space-2);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.song-pipeline-step{align-content:start;gap:var(--space-2);min-width:0;padding:var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--bg-primary);display:grid}.song-pipeline-step div{gap:2px;min-width:0;display:grid}.song-pipeline-step strong,.song-pipeline-step span{overflow-wrap:anywhere}.song-pipeline-step strong{color:var(--text-primary);font-size:.78rem;font-weight:780}.song-pipeline-step span{color:var(--text-secondary);font-size:.68rem;font-weight:650;line-height:1.3}.song-ready-chips{gap:var(--space-2);flex-wrap:wrap;display:flex}.pitch-timeline{width:100%;height:100%;display:block}.transport-row{align-items:center;gap:var(--space-2);min-height:48px;padding:var(--space-2);border-top:1px solid var(--border-subtle);background:var(--bg-primary);display:flex}.transport-row .primary-action{min-width:142px}.error-banner{margin:0 var(--space-2) var(--space-2);padding:9px var(--space-3);border:1px solid color-mix(in srgb, var(--status-danger) 48%, var(--border-default));border-radius:var(--radius-md);color:var(--status-danger-text);background:var(--surface-danger);font-size:.78rem;font-weight:650}.control-group,.feedback-panel{gap:var(--space-2);padding:var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-primary);display:grid}.group-heading{align-items:center;gap:var(--space-2);color:var(--text-secondary);display:flex}.group-heading h2{color:var(--text-primary);letter-spacing:0;font-size:.78rem;font-weight:760}.control-group label{align-items:center;gap:var(--space-2);color:var(--text-secondary);grid-template-columns:86px minmax(0,1fr);font-size:.76rem;font-weight:650;display:grid}.control-group label output{grid-column:2}.toggle-row{grid-template-columns:minmax(0,1fr) auto!important}.clip-player{width:100%}.clip-actions{justify-content:space-between;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:.74rem;font-weight:650;display:flex}.clip-error{color:var(--status-danger-text);font-size:.76rem;font-weight:650}.coach-summary{color:var(--text-secondary);font-size:.78rem;font-weight:620;line-height:1.45}.feedback-list{gap:var(--space-2);margin:0;padding:0;list-style:none;display:grid}.feedback-list li{align-items:center;gap:var(--space-2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-secondary);grid-template-columns:30px minmax(0,1fr) auto;min-height:46px;padding:7px;display:grid}.segment-pill{border-radius:var(--radius-md);width:24px;height:24px;color:var(--text-inverse);background:var(--accent-tertiary);place-items:center;font-size:.76rem;font-weight:820;display:grid}.target-copy{gap:2px;min-width:0;display:grid}.target-name{overflow-wrap:anywhere;min-width:0;color:var(--text-primary);font-size:.82rem;font-weight:780}.target-detail{color:var(--text-secondary);font-size:.7rem;font-weight:620;line-height:1.25}.score-badge{overflow-wrap:anywhere;border:1px solid var(--border-subtle);border-radius:var(--radius-full);max-width:122px;color:var(--text-secondary);background:var(--score-neutral-bg);padding:4px 7px;font-size:.68rem;font-weight:780}.score-pass{color:var(--status-success-text);background:var(--surface-success)}.score-passWithWarning{color:var(--status-warning-text);background:var(--surface-warning)}.score-flat,.score-sharp,.score-wrongNote,.score-unstable,.score-unclear,.score-missed{color:var(--status-danger-text);background:var(--surface-danger)}.history-list{gap:var(--space-2);margin:0;padding:0;list-style:none;display:grid}.history-list li{gap:var(--space-2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-secondary);grid-template-columns:auto minmax(0,1fr);align-items:start;padding:8px;display:grid}.history-result{border-radius:var(--radius-full);padding:3px 7px;font-size:.66rem;font-weight:820}.history-pass{color:var(--status-success-text);background:var(--surface-success)}.history-fail{color:var(--status-danger-text);background:var(--surface-danger)}.history-copy{gap:3px;min-width:0;display:grid}.history-copy strong,.history-copy span,.history-empty{overflow-wrap:anywhere;line-height:1.3}.history-copy strong{color:var(--text-primary);font-size:.74rem;font-weight:720}.history-copy span,.history-empty{color:var(--text-secondary);font-size:.72rem;font-weight:650}.file-input-row input[type=file]{width:100%;min-width:0;color:var(--text-secondary);font-size:.76rem;font-weight:650}.song-section-readout{justify-content:space-between;gap:var(--space-2);color:var(--text-tertiary);flex-wrap:wrap;font-size:.72rem;font-weight:740;display:flex}.song-full-action{width:100%}.analysis-meter{align-items:center;gap:var(--space-2);color:var(--text-secondary);grid-template-columns:58px minmax(0,1fr) 44px;font-size:.74rem;font-weight:720;display:grid}.analysis-meter progress{width:100%;accent-color:var(--accent-primary)}.control-group .segmented{grid-template-columns:repeat(3,minmax(0,1fr));width:100%;display:grid}.control-group .segmented__option{height:30px}.reference-quality{flex-wrap:wrap;gap:6px;display:flex}.reference-quality span{border:1px solid color-mix(in srgb, var(--accent-tertiary) 32%, var(--border-subtle));border-radius:var(--radius-full);color:color-mix(in srgb, var(--accent-tertiary) 88%, var(--text-primary));background:color-mix(in srgb, var(--accent-tertiary) 14%, transparent);padding:3px 7px;font-size:.68rem;font-weight:780}.reference-quality p{flex:100%}.song-debug-toggle{padding-top:4px}.song-debug-panel{border-color:color-mix(in srgb, var(--accent-primary) 28%, var(--border-subtle));background:color-mix(in srgb, var(--accent-primary) 5%, var(--bg-primary))}.song-debug-readout{gap:5px var(--space-2);padding:var(--space-2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-secondary);grid-template-columns:minmax(64px,auto) minmax(0,1fr);font-size:.72rem;font-weight:720;display:grid}.song-debug-readout strong{overflow-wrap:anywhere;color:var(--text-primary);font-weight:820}.song-debug-note-list{gap:var(--space-2);max-height:260px;margin:0;padding:0;list-style:none;display:grid;overflow:auto}.song-debug-note-list li{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-secondary);gap:2px;padding:7px;font-size:.7rem;font-weight:650;line-height:1.25;display:grid}.song-debug-note-list strong{color:var(--accent-primary);font-weight:820}.song-reason-list{padding-left:var(--space-4);color:var(--text-secondary);gap:7px;margin:0;font-size:.76rem;font-weight:620;line-height:1.35;display:grid}.song-region-list{max-height:280px;overflow:auto}@media (width<=1320px){.exercise-screen__header{grid-template-columns:1fr;align-items:start}.exercise-control-bar{flex-wrap:wrap;justify-content:flex-start}}@media (width<=980px){.home-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.home-spotlight-grid,.progress-dashboard-grid{grid-template-columns:1fr}.progress-exercises-card{grid-row:auto}.song-pipeline-steps{grid-template-columns:repeat(2,minmax(0,1fr))}.pitch-shell{grid-template-columns:1fr}.pitch-shell .pc-app-shell__main{grid-template-rows:auto minmax(0,1fr)!important}.pitch-shell .pc-app-shell__header{display:block}.shell-mobile-settings-bar{min-height:54px;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-subtle);background:var(--bg-primary);justify-content:space-between;align-items:center;display:flex}.shell-mobile-settings-bar>span{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.86rem;font-weight:760;overflow:hidden}.pitch-shell .pc-app-shell__sidebar{z-index:5;position:sticky;top:0}.pitch-shell .sidebar-nav{gap:var(--space-2);padding:var(--space-2);grid-template-rows:auto auto;display:grid}.pitch-shell .sidebar-nav__brand,.pitch-shell .sidebar-nav__footer{display:none}.pitch-shell .pc-app-shell__sidebar .sidebar-tabs__list{flex-direction:row;overflow-x:auto}.pitch-shell .pc-app-shell__sidebar .sidebar-tabs__trigger{flex:1 0 auto;min-width:92px}.range-prompt-floating{left:0}.shell-page{padding:var(--space-3)}.coach-workspace{min-height:auto}.exercise-screen{padding:var(--space-4)}.exercise-screen__header{grid-template-columns:1fr;align-items:start}.exercise-control-bar{flex-wrap:wrap;justify-content:flex-start}.exercise-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.top-bar,.practice-guidance,.practice-layout{grid-template-columns:1fr}.top-bar{align-items:stretch}.top-actions{flex-wrap:wrap;justify-content:space-between}.mode-action{flex:auto}.practice-layout{display:grid}.exercise-option{grid-template-columns:78px minmax(0,1fr) auto}.exercise-start{display:none}}@media (width<=680px){.shell-topbar{flex-direction:column;align-items:stretch}.home-summary-grid,.home-mode-grid,.page-header{grid-template-columns:1fr}.page-header__actions{justify-content:stretch}.page-header__actions .ui-button{flex:auto}.theme-picker{width:100%}.theme-option{flex:1 1 0;justify-content:center}.theme-option__label{display:none}.session-readout{min-width:min(100%,160px)}.exercise-screen{gap:var(--space-3);padding:var(--space-3)}.exercise-control-bar{flex-wrap:nowrap;justify-content:flex-start;width:100%;padding-bottom:2px;overflow-x:auto}.exercise-screen__title-row{align-items:start}.exercise-back-action{width:40px;height:40px}.practice-title-dropdown{font-size:1.2rem}.exercise-setting-chip{min-width:138px;height:50px}.exercise-setting-popover__content{width:min(272px,100vw - 32px);left:0;right:auto}.exercise-setting-popover__content--tempo{width:min(272px,100vw - 32px)}.exercise-setting-popover__content--tempo .exercise-tempo-presets button{min-height:34px;padding:0 10px;font-size:.78rem}.exercise-control-divider{display:none}.exercise-mode-toggle{flex:none;width:auto;height:50px}.exercise-mode-toggle button{flex:none;justify-content:center;height:38px;padding:0 13px}.exercise-header-toggle{width:50px;height:50px}.exercise-coach-row{align-items:flex-start}.exercise-coach-mark{border-radius:13px;width:42px;height:42px}.exercise-coach-bubble{min-height:42px;padding:11px 14px;font-size:.9rem;display:grid}.exercise-roll-card{height:clamp(300px,100vh - 460px,400px);min-height:310px;padding:var(--space-3);border-radius:18px}.practice-target-row{align-items:flex-start;gap:var(--space-2);flex-direction:column}.exercise-roll-card .note-checkpoint-strip{gap:var(--space-2);width:100%}.exercise-roll-card .note-checkpoint+.note-checkpoint:before{display:none}.exercise-roll-card .note-checkpoint{min-width:106px;padding:9px 10px}.practice-score-readout{align-self:flex-end}.exercise-roll-card .timeline-frame{height:auto;min-height:0}.exercise-action-bar{flex-wrap:wrap}.exercise-auto-center{flex-basis:calc(100% - 66px);order:1;justify-content:flex-start}.exercise-auto-pill{white-space:normal;justify-content:flex-start;width:100%;padding:11px 14px}.exercise-auto-pill small{display:none}.exercise-primary-action{flex:160px}.exercise-transport-scrub{flex-basis:100%;order:3}.exercise-detail-grid{grid-template-columns:1fr}.exercise-library,.practice-layout{margin:var(--space-2)}.practice-layout{padding:0}.practice-status-stack{justify-items:start}.practice-status-stack>span:last-child{text-align:left;max-width:none}.library-heading{flex-direction:column;align-items:start}.mock-home--with-range-prompt,.mock-practice-page--with-range-prompt{padding-bottom:112px}.range-prompt-floating{bottom:max(12px, calc(env(safe-area-inset-bottom) + 8px));padding:0 var(--space-3)}.progress-exercise-list li{grid-template-columns:1fr;align-items:start}.library-filter-tabs .sidebar-tabs__trigger{grid-template-columns:auto minmax(0,1fr)}.library-filter-tabs .sidebar-tabs__meta{display:none}.exercise-strip{grid-template-columns:1fr 1fr}.exercise-strip>div:nth-child(2n){border-right:0}.exercise-option{grid-template-columns:1fr;align-items:start}.difficulty-meter{width:100%}.exercise-meta{justify-content:flex-start}.timeline-frame{height:50vh;min-height:320px}.song-timeline-frame{min-height:300px}.song-stage-actions,.song-pipeline-steps{grid-template-columns:1fr}.song-stage-actions{flex-direction:column;align-items:stretch}.song-stage-actions .ui-button,.song-upload-button{width:100%}.transport-row{flex-wrap:wrap}.transport-row .primary-action{flex:180px}.control-group label,.control-group label output{grid-column:auto;grid-template-columns:1fr}}@media (width<=760px){html,body{width:100%;height:100%;overflow:hidden!important}#root,.pc-app-shell.pitch-shell{width:100vw!important;height:100dvh!important;min-height:100dvh!important}.pc-app-shell.pitch-shell{grid-template-columns:1fr!important;overflow:hidden!important}.pitch-shell .pc-app-shell__sidebar{display:none!important}.pitch-shell .pc-app-shell__main{grid-template-rows:auto minmax(0,1fr)!important;min-height:0!important}.pitch-shell .pc-app-shell__header{z-index:6;position:relative}.pitch-shell .pc-app-shell__content{background:var(--mock-shell)!important;min-height:0!important;overflow:auto!important}.pc-app-shell--with-mobile-nav .mock-home,.pc-app-shell--with-mobile-nav .mock-practice-page,.pc-app-shell--with-mobile-nav .mock-song-page,.pc-app-shell--with-mobile-nav .mock-progress-page{padding-bottom:calc(22px + var(--pc-mobile-nav-height,84px))!important}.pc-app-shell--with-mobile-nav .mock-home--with-range-prompt,.pc-app-shell--with-mobile-nav .mock-practice-page--with-range-prompt{padding-bottom:calc(112px + var(--pc-mobile-nav-height,84px))!important}.pc-app-shell--with-mobile-nav .range-prompt-floating{bottom:calc(10px + var(--pc-mobile-nav-height,84px))!important;padding:0 12px!important;left:0!important}.range-prompt-floating .range-setup-toast{width:min(100%,560px)}.mobile-home{min-height:100%;padding:18px 18px calc(22px + var(--pc-mobile-nav-height,84px));background:var(--mock-shell);-webkit-overflow-scrolling:touch;align-content:start;gap:18px;display:grid;overflow:auto}.mobile-home--with-range-prompt{padding-bottom:calc(112px + var(--pc-mobile-nav-height,84px))}.mobile-home__header{align-items:center;gap:12px;min-width:0;padding:6px 4px 0;display:flex}.mobile-home__greeting{flex:auto;gap:2px;min-width:0;display:grid}.mobile-home__greeting h1{overflow-wrap:anywhere;color:var(--mock-ink);font-family:var(--font-display), ui-sans-serif, system-ui, sans-serif;letter-spacing:0;font-size:24px;font-weight:600;line-height:1.08}.mobile-home__greeting p{color:var(--mock-muted);font-size:13px;font-weight:400;line-height:1.25}.mobile-streak-chip{border:1px solid var(--mock-line);min-height:40px;color:var(--mock-ink);background:var(--mock-surface-2);border-radius:12px;flex:none;align-items:center;gap:7px;padding:8px 11px;display:flex}.mobile-streak-chip svg{color:var(--mock-coral)}.mobile-streak-chip span{font-family:var(--font-display), ui-sans-serif, system-ui, sans-serif;font-size:17px;font-weight:700;line-height:1}.mobile-resume-card{border:1px solid var(--mock-line);background:linear-gradient(135deg, #fff6ef, var(--mock-card));border-radius:20px;min-width:0;display:grid;overflow:hidden;box-shadow:0 12px 30px #462d1917}.mobile-resume-card .mock-pitch-preview{border-right:0!important;border-bottom:1px solid var(--mock-line)!important;background:#fffdf9!important;border-left:0!important;height:96px!important;min-height:96px!important}.mobile-resume-card .mock-pitch-preview svg{width:92%!important;height:78%!important}.mobile-resume-card__copy{gap:9px;min-width:0;padding:15px 17px 17px;display:grid}.mobile-kicker{color:var(--mock-coral-dark);letter-spacing:.07em;text-transform:uppercase;align-items:center;gap:7px;font-size:11px;font-weight:700;line-height:1;display:flex}.mobile-kicker svg{stroke-width:2px}.mobile-resume-card__title-row{flex-wrap:wrap;align-items:baseline;gap:9px;min-width:0;display:flex}.mobile-resume-card__title-row h2{overflow-wrap:anywhere;color:var(--mock-ink);font-family:var(--font-display), ui-sans-serif, system-ui, sans-serif;letter-spacing:0;font-size:23px;font-weight:700;line-height:1.05}.mobile-resume-card__title-row span{color:var(--mock-muted);font-family:var(--font-mono), ui-monospace, monospace;white-space:nowrap;font-size:12.5px;font-weight:400}.mobile-resume-card__copy p{color:var(--mock-muted);font-size:13px;font-weight:400;line-height:1.35}.mobile-primary-action{color:#fff;background:linear-gradient(180deg, #ff9568, var(--mock-coral));width:100%;min-height:46px;font:inherit;white-space:nowrap;cursor:pointer;border:0;border-radius:13px;justify-content:center;align-items:center;gap:8px;margin-top:5px;padding:14px;font-size:15.5px;font-weight:600;line-height:1;display:inline-flex;box-shadow:0 8px 20px #ee6c4d4d}.mobile-primary-action:disabled{cursor:not-allowed;opacity:.58}.mobile-home__section{gap:12px;min-width:0;display:grid}.mobile-section-title{color:var(--mock-ink);font-family:var(--font-display), ui-sans-serif, system-ui, sans-serif;letter-spacing:0;margin:0 4px;font-size:18px;font-weight:600;line-height:1.1}.mobile-mode-list{flex-direction:column;gap:12px;min-width:0;display:flex}.mobile-mode-card{border:1px solid var(--mock-line);min-width:0;min-height:78px;color:var(--mock-ink);background:var(--mock-card);font:inherit;text-align:left;cursor:pointer;border-radius:17px;align-items:center;gap:14px;padding:16px;display:flex}.mobile-mode-card>svg{color:var(--mock-muted-2);stroke-width:1.7px;flex:none}.mobile-mode-icon{border-radius:14px;flex:0 0 46px;place-items:center;width:46px;height:46px;display:grid}.mobile-mode-icon--practice{color:var(--mock-coral);background:#ee6c4d1f}.mobile-mode-icon--song{color:var(--mock-purple);background:var(--mock-purple-soft)}.mobile-mode-copy{flex:auto;gap:2px;min-width:0;display:grid}.mobile-mode-copy strong{color:var(--mock-ink);font-family:var(--font-display), ui-sans-serif, system-ui, sans-serif;letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;font-size:17px;font-weight:600;line-height:1.15;overflow:hidden}.mobile-mode-copy>span:not(.mobile-mode-progress){color:var(--mock-muted);font-size:12.5px;font-weight:400;line-height:1.25}.mobile-mode-progress{background:var(--mock-surface-2);border-radius:3px;width:100%;height:5px;margin-top:6px;display:block;position:relative;overflow:hidden}.mobile-mode-progress span{width:var(--mobile-mode-progress,0%);border-radius:inherit;background:linear-gradient(90deg, #ff9568, var(--mock-coral));position:absolute;inset:0 auto 0 0}.mobile-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:11px;min-width:0;display:grid}.mobile-stat-card{border:1px solid var(--mock-line);background:var(--mock-card);min-width:0;min-height:84px;box-shadow:none;border-radius:16px;align-content:start;gap:6px;padding:13px 14px;display:grid}.mobile-stat-card__label{min-width:0;color:var(--mock-muted);align-items:center;gap:6px;font-size:11.5px;font-weight:500;line-height:1.15;display:flex}.mobile-stat-card__icon{flex:none;display:inline-flex}.mobile-stat-card__body{justify-content:space-between;align-items:flex-end;gap:6px;min-width:0;display:flex}.mobile-stat-card__value{min-width:0;color:var(--mock-ink);font-family:var(--font-display), ui-sans-serif, system-ui, sans-serif;letter-spacing:0;white-space:nowrap;font-size:24px;font-weight:700;line-height:1}.mobile-stat-card__value span{color:var(--mock-muted);margin-left:2px;font-size:12px;font-weight:500}.mobile-stat-card__value--accent{color:var(--mock-coral-dark)}.mobile-stat-card__value--green{color:var(--mock-green)}.mobile-stat-card__trend{flex:0 56px;min-width:40px;display:block}.mobile-stat-card__trend .mock-accuracy-sparkline{stroke-width:3px;width:56px;height:26px}.mobile-exercise-page{background:var(--mock-shell);height:100%;min-height:100%;overflow:hidden}.mobile-exercise-screen{background:var(--mock-shell);height:100dvh;min-height:100dvh;color:var(--mock-ink);flex-direction:column;display:flex;position:relative;overflow:hidden}.mobile-exercise-header{align-items:center;gap:11px;padding:14px 16px 10px;display:flex}.mobile-exercise-icon-button,.mobile-exercise-header-spacer{flex:0 0 36px;place-items:center;width:36px;height:36px;display:inline-grid}.mobile-exercise-icon-button{border:1px solid var(--mock-line);color:var(--mock-muted);background:var(--mock-card);cursor:pointer;border-radius:11px}.mobile-exercise-title{flex:auto;gap:2px;min-width:0;display:grid}.mobile-exercise-title h1{color:var(--mock-ink);font-family:var(--font-display), ui-sans-serif, system-ui, sans-serif;letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;font-size:18px;font-weight:600;line-height:1.1;overflow:hidden}.mobile-exercise-title p{color:var(--mock-muted);text-overflow:ellipsis;white-space:nowrap;font-size:11.5px;font-weight:400;line-height:1.2;overflow:hidden}.mobile-exercise-mode-segment{border:1px solid var(--mock-line);background:var(--mock-surface-2);border-radius:12px;align-items:center;gap:4px;margin:0 16px 12px;padding:4px;display:flex}.mobile-exercise-mode-segment button{min-width:0;height:34px;color:var(--mock-muted);font:inherit;cursor:pointer;background:0 0;border:0;border-radius:9px;flex:1 1 0;justify-content:center;align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.mobile-exercise-mode-segment button[data-active]{color:var(--mock-ink);background:var(--mock-card);box-shadow:0 2px 6px #462d191f}.mobile-exercise-mode-segment button[data-active] svg{color:var(--mock-coral)}.mobile-exercise-mode-segment button:disabled{cursor:not-allowed;opacity:.58}.mobile-exercise-coach{align-items:flex-start;gap:11px;padding:0 16px 14px;display:flex}.mobile-exercise-coach__mark{color:#fff;background:linear-gradient(145deg, #ff9f6b, var(--mock-coral));border-radius:12px;flex:0 0 38px;place-items:center;width:38px;height:38px;display:grid;box-shadow:0 6px 16px #ee6c4d4d}.mobile-exercise-coach__bubble{border:1px solid var(--mock-line);background:var(--mock-card);border-radius:4px 15px 15px;flex:auto;gap:2px;min-width:0;padding:11px 15px;font-size:14.5px;line-height:1.4;display:grid}.mobile-exercise-coach__bubble strong{color:var(--mock-ink);font-size:14.5px;font-weight:700}.mobile-exercise-coach__bubble span{color:var(--mock-ink);font-size:14.5px;font-weight:400}.mobile-exercise-roll-card{border:1px solid var(--mock-line);background:var(--mock-card);border-radius:18px;flex-direction:column;flex:auto;min-width:0;min-height:150px;margin:0 16px;padding:14px;display:flex;overflow:hidden;box-shadow:0 14px 34px #462d1917}.mobile-exercise-stones .note-checkpoint-strip{scrollbar-width:none;gap:7px;margin:0 0 9px;padding:0;display:flex;overflow:auto hidden}.mobile-exercise-stones .note-checkpoint-strip::-webkit-scrollbar{display:none}.mobile-exercise-stones .note-checkpoint{border:1px solid var(--mock-line);background:var(--mock-surface-2);border-radius:12px;flex:0 0 calc(33.3333% - 4.66667px);grid-template-rows:auto auto;grid-template-columns:21px minmax(0,1fr);align-items:center;column-gap:8px;min-width:0;max-width:122px;min-height:47px;padding:7px 10px;display:grid}.mobile-exercise-stones .note-checkpoint+.note-checkpoint:before{display:none}.mobile-exercise-stones .note-checkpoint__degree{border:1.4px dashed var(--mock-muted-2);width:21px;height:21px;color:var(--mock-muted-2);background:var(--mock-card);border-radius:50%;grid-area:1/1/span 2;font-size:10.5px;position:relative}.mobile-exercise-stones .note-checkpoint--target .note-checkpoint__degree{color:#0000;font-size:0}.mobile-exercise-stones .note-checkpoint--active .note-checkpoint__degree{border-color:var(--mock-muted-2);color:#0000;background:var(--mock-card);font-size:0}.mobile-exercise-stones .note-checkpoint--active .note-checkpoint__degree:after{border-radius:inherit;content:"";animation:1.1s ease-out infinite mobileExerciseCheckpointPulse;position:absolute;inset:-5px;box-shadow:0 0 #4a84a673}@keyframes mobileExerciseCheckpointPulse{0%{box-shadow:0 0 #4a84a673}to{box-shadow:0 0 0 9px #4a84a600}}.mobile-exercise-stones .note-checkpoint--pass,.mobile-exercise-stones .note-checkpoint--passWithWarning{background:#3fa46a1f;border-color:#0000}.mobile-exercise-stones .note-checkpoint--flat,.mobile-exercise-stones .note-checkpoint--sharp,.mobile-exercise-stones .note-checkpoint--wrongNote,.mobile-exercise-stones .note-checkpoint--wrongDirection,.mobile-exercise-stones .note-checkpoint--offContour,.mobile-exercise-stones .note-checkpoint--unstable,.mobile-exercise-stones .note-checkpoint--unclear,.mobile-exercise-stones .note-checkpoint--missed{background:#cf8a2621;border-color:#0000}.mobile-exercise-stones .note-checkpoint--pass .note-checkpoint__degree,.mobile-exercise-stones .note-checkpoint--passWithWarning .note-checkpoint__degree{color:#fff;background:var(--mock-green);border:0}.mobile-exercise-stones .note-checkpoint--flat .note-checkpoint__degree,.mobile-exercise-stones .note-checkpoint--sharp .note-checkpoint__degree,.mobile-exercise-stones .note-checkpoint--wrongNote .note-checkpoint__degree,.mobile-exercise-stones .note-checkpoint--wrongDirection .note-checkpoint__degree,.mobile-exercise-stones .note-checkpoint--offContour .note-checkpoint__degree,.mobile-exercise-stones .note-checkpoint--unstable .note-checkpoint__degree,.mobile-exercise-stones .note-checkpoint--unclear .note-checkpoint__degree,.mobile-exercise-stones .note-checkpoint--missed .note-checkpoint__degree{color:#fff;background:var(--mock-amber);border:0}.mobile-exercise-stones .note-checkpoint__label{color:var(--mock-muted);grid-area:1/2;font-size:9.5px;font-weight:500;line-height:1.1}.mobile-exercise-stones .note-checkpoint strong{color:var(--mock-ink);font-family:var(--font-mono), ui-monospace, monospace;text-overflow:ellipsis;white-space:nowrap;grid-area:2/2;font-size:12.5px;font-weight:600;line-height:1.1;overflow:hidden}.mobile-exercise-scoreline{justify-content:flex-end;align-items:center;gap:7px;margin:0 0 8px;display:flex}.mobile-exercise-scoreline strong{color:var(--mock-muted);font-family:var(--font-display), ui-sans-serif, system-ui, sans-serif;font-size:20px;font-weight:700;line-height:1}.mobile-exercise-scoreline strong span{color:var(--mock-muted);font-size:13px;font-weight:500}.mobile-exercise-scoreline>span{color:var(--mock-muted);font-size:11.5px;font-weight:400}.mobile-exercise-roll-card .timeline-frame{border:1px solid var(--mock-line);background:#fffdf9;border-radius:13px;flex:auto;min-height:0;overflow:hidden}.mobile-exercise-roll-card .pitch-timeline{--timeline-surface:#fffdf9;--timeline-target-band:#6ea0c024;--timeline-target-line:#4a84a6b3;--timeline-grid-border:transparent;--timeline-grid-line:#46301e0b;--timeline-grid-strong-line:#46301e1a;--timeline-grid-label:#a89a8b;--timeline-pitch-line:#7d6fd0d1;width:100%;height:100%}.mobile-exercise-action{justify-content:center;align-items:center;min-height:80px;padding:14px 16px 12px;display:flex}.mobile-exercise-status-pill{max-width:100%;min-height:52px;font:inherit;text-align:center;white-space:nowrap;border:0;border-radius:13px;justify-content:center;align-items:center;gap:9px;padding:13px 22px;font-size:14.5px;font-weight:600;line-height:1;display:inline-flex}button.mobile-exercise-status-pill{cursor:pointer}.mobile-exercise-status-pill small{display:none}.mobile-exercise-status-pill--idle{color:var(--mock-muted);background:var(--mock-card)}.mobile-exercise-status-pill--info{color:#3a6e8c;background:#4a84a61f}.mobile-exercise-status-pill--accent{color:var(--mock-coral);background:#ee6c4d1f}.mobile-exercise-status-pill--success{color:var(--mock-green);background:#3fa46a1f}.mobile-exercise-status-pill--warning{color:var(--mock-amber);background:#cf8a261f}.mobile-exercise-manual-transport{flex-direction:column;gap:12px;width:100%;display:flex}.mobile-exercise-manual-transport>p{color:var(--mock-muted-2);text-align:center;margin-top:-4px;font-size:11.5px;line-height:1.2}.mobile-exercise-manual-actions{gap:10px;display:flex}.mobile-exercise-manual-actions button{border:1px solid var(--mock-line);min-width:0;height:46px;color:var(--mock-muted);background:var(--mock-card);font:inherit;cursor:pointer;border-radius:13px;flex:1 1 0;justify-content:center;align-items:center;gap:8px;font-size:13.5px;font-weight:600;display:flex}.mobile-exercise-manual-actions button.is-primary{color:#fff;background:linear-gradient(180deg, #ff9568, var(--mock-coral));border:0;flex-grow:1.4;box-shadow:0 10px 22px #ee6c4d4d}.mobile-exercise-manual-actions button:disabled{cursor:not-allowed;opacity:.52}.mobile-exercise-dock{flex:none;gap:9px;padding:0 16px 24px;display:flex}.mobile-exercise-dock-chip{border:1px solid var(--mock-line);min-width:0;height:50px;color:var(--mock-ink);background:var(--mock-card);font:inherit;cursor:pointer;border-radius:13px;flex:1 1 0;align-items:center;gap:8px;padding:0 11px;display:flex}.mobile-exercise-dock-chip[data-active]{border-color:var(--mock-coral)}.mobile-exercise-dock-chip__icon{color:var(--mock-muted);flex:none;display:inline-flex}.mobile-exercise-dock-chip__copy{text-align:left;gap:1px;min-width:0;display:grid}.mobile-exercise-dock-chip__copy span{color:var(--mock-muted);white-space:nowrap;font-size:9.5px;font-weight:500;line-height:1.1}.mobile-exercise-dock-chip__copy strong{color:var(--mock-ink);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;line-height:1.12;overflow:hidden}.mobile-exercise-dock-chip__copy strong[data-mono]{font-family:var(--font-mono), ui-monospace, monospace}.mobile-exercise-sheet{z-index:calc(var(--z-portaled-popover) - 1);pointer-events:none;flex-direction:column;justify-content:flex-end;display:flex;position:fixed;inset:0}.mobile-exercise-sheet[data-state=open]{pointer-events:auto}.mobile-exercise-sheet__backdrop{cursor:pointer;opacity:0;background:#281c1257;border:0;position:absolute;inset:0}.mobile-exercise-sheet[data-state=open] .mobile-exercise-sheet__backdrop{animation:.26s both mobileExerciseBackdropIn}.mobile-exercise-sheet[data-state=closed] .mobile-exercise-sheet__backdrop{animation:.22s both mobileExerciseBackdropOut}.mobile-exercise-sheet__panel{background:var(--mock-card);border-radius:22px 22px 0 0;gap:16px;padding:10px 20px 30px;display:grid;position:relative;transform:translateY(110%);box-shadow:0 -16px 50px #281c1238}.mobile-exercise-sheet[data-state=open] .mobile-exercise-sheet__panel{animation:.3s cubic-bezier(.2,.85,.25,1) both mobileExerciseSheetIn}.mobile-exercise-sheet[data-state=closed] .mobile-exercise-sheet__panel{animation:.24s both mobileExerciseSheetOut}@keyframes mobileExerciseSheetIn{0%{transform:translateY(110%)}to{transform:translateY(0)}}@keyframes mobileExerciseSheetOut{0%{transform:translateY(0)}to{transform:translateY(110%)}}@keyframes mobileExerciseBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes mobileExerciseBackdropOut{0%{opacity:1}to{opacity:0}}@media (prefers-reduced-motion:reduce){.mobile-exercise-stones .note-checkpoint--active .note-checkpoint__degree:after,.mobile-exercise-sheet__backdrop,.mobile-exercise-sheet__panel{transition:none!important;animation:none!important}.mobile-exercise-sheet[data-state=open] .mobile-exercise-sheet__backdrop{opacity:1}.mobile-exercise-sheet[data-state=closed] .mobile-exercise-sheet__backdrop{opacity:0}.mobile-exercise-sheet[data-state=open] .mobile-exercise-sheet__panel{transform:translateY(0)}.mobile-exercise-sheet[data-state=closed] .mobile-exercise-sheet__panel{transform:translateY(110%)}}.mobile-exercise-sheet__handle{background:var(--mock-surface-3);border-radius:3px;width:38px;height:4px;margin:0 auto}.mobile-exercise-sheet__header{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.mobile-exercise-sheet__header h2{color:var(--mock-ink);font-family:var(--font-display), ui-sans-serif, system-ui, sans-serif;letter-spacing:0;font-size:18px;font-weight:600;line-height:1.1}.mobile-exercise-sheet__header span{color:var(--mock-muted);font-size:12px}.mobile-key-sheet,.mobile-strictness-sheet,.mobile-tempo-sheet{gap:14px;display:grid}.mobile-key-stepper{justify-content:center;align-items:center;gap:16px;display:flex}.mobile-key-stepper button{border:1px solid var(--mock-line);width:52px;height:52px;color:var(--mock-ink);background:var(--mock-surface-2);font:inherit;cursor:pointer;border-radius:14px;font-size:24px;line-height:1}.mobile-key-stepper button:disabled{cursor:not-allowed;opacity:.48}.mobile-key-stepper span{text-align:center;min-width:116px;display:grid}.mobile-key-stepper strong{color:var(--mock-ink);font-family:var(--font-display), ui-sans-serif, system-ui, sans-serif;font-size:38px;font-weight:700;line-height:1}.mobile-key-stepper small{color:var(--mock-muted);font-size:12px;font-weight:400}.mobile-sheet-note{color:var(--mock-muted-2);align-items:flex-start;gap:8px;font-size:12.5px;line-height:1.45;display:flex}.mobile-sheet-note strong{color:var(--mock-ink);font-family:var(--font-mono), ui-monospace, monospace;font-weight:600}.mobile-sheet-note--success{color:var(--mock-green);background:#3fa46a1a;border-radius:12px;align-items:center;padding:11px 13px;font-weight:600}.mobile-sheet-option-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.mobile-sheet-option-grid button{border:1.5px solid var(--mock-line);min-width:0;color:var(--mock-ink);background:var(--mock-card);font:inherit;cursor:pointer;border-radius:13px;gap:3px;padding:13px 0;display:grid}.mobile-sheet-option-grid button[data-active]{border-color:var(--mock-coral);background:#ee6c4d14}.mobile-sheet-option-grid strong{color:var(--mock-ink);font-size:14.5px;font-weight:700;line-height:1.1}.mobile-sheet-option-grid button[data-active] strong{color:var(--mock-coral-dark)}.mobile-sheet-option-grid span{color:var(--mock-muted);font-family:var(--font-mono), ui-monospace, monospace;font-size:11.5px}.mobile-tempo-readout{justify-content:space-between;align-items:baseline;display:flex}.mobile-tempo-readout>span{color:var(--mock-muted);font-size:13px}.mobile-tempo-readout strong{color:var(--mock-ink);font-family:var(--font-mono), ui-monospace, monospace;font-size:22px;font-weight:600}.mobile-tempo-readout strong span{color:var(--mock-muted);margin-left:3px;font-size:13px;font-weight:400}.mobile-sheet-option-grid--tempo{margin-top:0}.mock-home{min-height:100%!important;padding:18px 18px calc(22px + var(--pc-mobile-nav-height,84px))!important;gap:18px!important;overflow:auto!important}.mock-home__header{grid-template-columns:1fr!important;align-items:start!important;gap:12px!important}.mock-home__header h1{font-size:24px!important}.mock-week-streak{justify-self:start!important;max-width:100%!important;overflow-x:auto!important}.mock-resume-card{grid-template-columns:1fr!important;height:auto!important;min-height:0!important;max-height:none!important}.mock-pitch-preview{border-right:0!important;border-bottom:1px solid var(--mock-line)!important;border-left:0!important;order:-1!important;height:96px!important;min-height:96px!important}.mock-pitch-preview svg{width:92%!important;height:78%!important}.mock-resume-card__copy{padding:15px 17px 17px!important}.mock-resume-card h2{font-size:23px!important}.mock-resume-card__actions,.mock-primary-action{width:100%!important}.mock-primary-action{min-height:46px!important}.mock-mode-grid{grid-template-columns:1fr!important;gap:12px!important}.mock-mode-card,.mock-interval-card{min-height:0!important;padding:16px!important}.mock-song-dropzone{min-height:136px!important}.mock-stat-grid,.progress-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:11px!important}.mock-stat-card,.progress-metric-card{min-height:84px!important;padding:13px 14px!important}.mock-stat-card .stat-card__value,.mock-stat-card__value{font-size:24px!important}.mock-practice-page{height:auto!important;min-height:100%!important;padding:18px 18px calc(22px + var(--pc-mobile-nav-height,84px))!important;overflow:visible!important}.mock-practice-page .exercise-library{overflow:visible!important}.library-heading{flex-direction:column!important;align-items:flex-start!important;gap:6px!important}.library-heading__stat{display:none!important}.library-filters{margin:0 -18px!important;padding:14px 18px 4px!important;overflow-x:auto!important}.library-filter-tabs .sidebar-tabs__list{flex-wrap:nowrap!important;overflow-x:auto!important}.library-filter-tabs .sidebar-tabs__trigger{flex:none!important;min-width:0!important}.exercise-groups{gap:20px!important;margin:0!important;padding:14px 0 0!important;overflow:visible!important}.exercise-list{grid-template-columns:1fr!important}.exercise-option{gap:12px!important;min-height:58px!important;padding:11px 13px!important}.exercise-copy strong{white-space:normal!important}.exercise-score{flex-basis:48px!important;width:48px!important}.exercise-start{flex-basis:34px!important;width:34px!important;min-width:34px!important;height:34px!important}.mock-song-page{height:100%!important;min-height:100%!important;padding:18px 18px calc(22px + var(--pc-mobile-nav-height,84px))!important;overflow:auto!important}.mock-song-page__header{align-items:flex-start!important;gap:12px!important;display:flex!important}.mock-song-title{align-items:flex-start!important}.mock-song-title h1{font-size:23px!important}.mock-song-title p{font-size:12.5px!important}.mock-song-layout,.mock-song-page__header,.mock-song-card-heading{grid-template-columns:1fr!important}.mock-song-layout{gap:14px!important;display:grid!important}.mock-song-side-panel{overflow:visible!important}.mock-song-page--empty,.mock-song-page--processing{grid-template-rows:auto auto!important;align-content:start!important}.mock-song-empty{grid-template-rows:auto auto!important;gap:16px!important;height:auto!important}.mock-song-empty__drop{min-height:280px!important;padding:32px 22px!important}.mock-song-how ol,.mock-song-page .song-pipeline-steps{grid-template-columns:1fr!important;gap:14px!important}.mock-song-how li:not(:last-child):after{display:none!important}.mock-song-processing-card{padding:22px 20px!important}.mock-song-processing-card__header{grid-template-columns:42px minmax(0,1fr) auto!important}.mock-song-processing-card__header>strong{font-size:20px!important}.mock-song-processing-steps{max-width:none!important}.mock-song-timeline-card{min-height:300px!important}.mock-song-transport{flex-wrap:wrap!important}.mock-song-transport .primary-action{flex:100%!important}.mock-progress-page{height:100%!important;min-height:100%!important;padding:18px 18px calc(22px + var(--pc-mobile-nav-height,84px))!important;overflow:auto!important}.progress-main-grid{grid-template-columns:1fr!important;gap:14px!important}.progress-week-content{flex-direction:column!important;align-items:flex-start!important;gap:14px!important}.progress-week-strip{max-width:100%!important;overflow-x:auto!important}.progress-recent-panel{align-self:stretch!important}.pitch-shell:not(.pc-app-shell--with-mobile-nav) .pc-app-shell__content{padding-bottom:0!important}.pitch-shell:not(.pc-app-shell--with-mobile-nav) .pc-app-shell__main{grid-template-rows:minmax(0,1fr)!important}.pitch-shell:not(.pc-app-shell--with-mobile-nav) .pc-app-shell__header{display:none!important}.exercise-screen-page{min-height:100%!important}.exercise-screen{gap:12px!important;min-height:100dvh!important;padding:14px 16px 18px!important}.exercise-screen__header{gap:12px!important}.exercise-screen__title-row{gap:10px!important}.exercise-control-bar{width:100%!important;padding-bottom:4px!important;overflow-x:auto!important}.exercise-header-toggle{z-index:2!important;flex:0 0 50px!important;order:-1!important;position:sticky!important;left:0!important}.exercise-coach-bubble{line-height:1.25!important}.exercise-roll-card{height:clamp(310px,100dvh - 410px,420px)!important;min-height:310px!important}.exercise-action-bar{align-items:stretch!important}}
