*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #3b82f6;--color-primary-dark: #2563eb;--color-bg: #f8fafc;--color-surface: #ffffff;--color-text: #1e293b;--color-text-muted: #64748b;--color-border: #e2e8f0;--color-accent: #f59e0b;--color-playing: #3b82f6;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--max-width: 1200px}html{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--color-text);background:var(--color-bg);line-height:1.6}body{min-height:100vh}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:.75rem 1.5rem;display:flex;align-items:center;gap:2rem;box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.app-title{text-decoration:none;color:var(--color-text)}.app-title h1{font-size:1.25rem;font-weight:700;white-space:nowrap}.app-nav ul{display:flex;list-style:none;gap:.5rem}.nav-link{text-decoration:none;color:var(--color-text-muted);padding:.375rem .75rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;transition:background .15s,color .15s}.nav-link:hover{background:var(--color-bg);color:var(--color-text)}.nav-link.active{background:var(--color-primary);color:#fff}.app-main{flex:1;padding:1.5rem;max-width:var(--max-width);width:100%;margin:0 auto}.exercise-menu h2{font-size:1.5rem;margin-bottom:1rem}.exercise-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.exercise-card{display:block;text-decoration:none;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;transition:box-shadow .15s,border-color .15s}.exercise-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary)}.exercise-card h3{font-size:1.125rem;margin-bottom:.5rem}.exercise-card p{color:var(--color-text-muted);font-size:.875rem}.exercise-view{display:flex;flex-direction:column;gap:1rem}.exercise-toolbar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.exercise-toolbar .exercise-settings-menu{margin-left:auto}.notation-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;overflow-x:auto}.playback-controls{display:flex;gap:.5rem;align-items:center}.playback-controls button{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.playback-controls button:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-primary)}.playback-controls button:disabled{opacity:.5;cursor:not-allowed}.playback-controls button.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.playback-controls button.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.abcjs-note.abcjs-playing,.abcjs-note.abcjs-playing *{fill:var(--color-playing)!important}.btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.btn:hover{background:var(--color-bg)}.btn-icon{padding:.5rem}.loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--color-text-muted);font-size:1rem}.notation-toggle{display:inline-flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:.125rem;width:max-content}.notation-toggle__btn{flex:0 0 auto;padding:.25rem .625rem;border:none;border-radius:calc(var(--radius) - 2px);background:transparent;color:var(--color-text-muted);font-size:.75rem;font-weight:500;white-space:nowrap;cursor:pointer;transition:background-color .15s ease,color .15s ease}.notation-toggle__btn:not(.notation-toggle__btn--active):hover{background:var(--color-bg);color:var(--color-text)}.notation-toggle__btn--active{background:var(--color-primary);color:#fff}.auth-section{margin-left:auto;display:flex;align-items:center;gap:.75rem}.google-signin-button{min-width:40px;min-height:36px}.settings-menu{position:relative}.settings-trigger{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.settings-trigger:hover{background:var(--color-bg);color:var(--color-text);border-color:var(--color-primary)}.settings-popover{position:absolute;top:calc(100% + .5rem);right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:.5rem;width:max-content;z-index:200}.user-menu{position:relative}.user-menu-trigger{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--color-border);border-radius:50%;background:var(--color-surface);padding:0;cursor:pointer;overflow:hidden}.user-menu-trigger:hover{border-color:var(--color-primary)}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-avatar--initial{display:inline-flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;font-weight:600;font-size:.875rem}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:180px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:.5rem;z-index:200}.user-menu-name{padding:.375rem .5rem;font-size:.875rem;font-weight:600;color:var(--color-text);border-bottom:1px solid var(--color-border);margin-bottom:.25rem}.user-menu-item{display:block;width:100%;text-align:left;padding:.5rem;border:none;border-radius:calc(var(--radius) - 2px);background:transparent;color:var(--color-text);font-size:.875rem;cursor:pointer}.user-menu-item:hover{background:var(--color-bg)}.auth-error{font-size:.8125rem;color:#dc2626;white-space:nowrap}.exercise-settings-menu{position:relative;display:inline-flex;z-index:50}.exercise-settings-trigger{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.exercise-settings-trigger:hover,.exercise-settings-trigger:focus-visible{background:var(--color-bg);color:var(--color-text);border-color:var(--color-primary)}.exercise-settings-popover{position:absolute;top:calc(100% + .5rem);right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:.75rem 1rem;min-width:240px;width:max-content;max-width:min(640px,calc(100vw - 2rem));max-height:calc(100vh - 8rem);overflow:auto;z-index:200}.exercise-settings-popover__header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem;border-bottom:1px solid var(--color-border);padding-bottom:.5rem}.exercise-settings-popover__header h3{font-size:.95rem;font-weight:600;color:var(--color-text);margin:0}.exercise-settings-popover__close{background:none;border:none;font-size:1.4rem;line-height:1;cursor:pointer;color:var(--color-text-muted);padding:0 .25rem}.exercise-settings-popover__close:hover{color:var(--color-text)}.exercise-settings-popover__body{display:flex;flex-direction:column;gap:.5rem}.settings-body input[type=number]:disabled{opacity:.55;cursor:not-allowed}.settings-body{display:grid;gap:.75rem}.settings-field{display:flex;flex-direction:column;gap:.25rem}.settings-field label{font-size:.85rem;color:var(--color-text-muted)}.settings-field input[type=number]{padding:.4rem .5rem;border:1px solid var(--color-border);border-radius:4px;font-size:.9rem;width:6rem;background:var(--color-bg);color:var(--color-text)}.settings-clef-group{border:1px solid var(--color-border);border-radius:6px;padding:.75rem;margin:0}.settings-clef-group legend{padding:0 .5rem;font-size:.9rem;font-weight:600;color:var(--color-text)}.settings-toggle{flex-direction:row;align-items:center;gap:.5rem}.settings-toggle input[type=checkbox]{width:1rem;height:1rem}.settings-range{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.settings-range label{font-size:.8rem;color:var(--color-text-muted);display:flex;align-items:center;gap:.5rem}.settings-range input[type=range]{flex:1}.range-label-text{display:inline-block;min-width:5rem}.history-container{max-width:800px;margin:0 auto;padding:1rem}.history-container h2{margin-bottom:1.5rem}.history-loading,.history-empty{text-align:center;padding:3rem 1rem;color:var(--color-text-muted)}.history-empty p+p{margin-top:.5rem;font-size:.9rem}.history-error{background:#fef2f2;color:#991b1b;padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.history-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.history-record{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);gap:1rem}.history-record-info{flex:1;min-width:0}.history-record-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.history-record-type{font-weight:600;text-transform:capitalize}.history-status-badge{font-size:.75rem;padding:.125rem .5rem;border-radius:999px;font-weight:500}.history-status-completed{background:#dcfce7;color:#166534}.history-status-abandoned{background:#fef3c7;color:#92400e}.history-record-date{font-size:.85rem;color:var(--color-text-muted);margin-bottom:.25rem}.history-record-config{font-size:.85rem;color:var(--color-text-muted)}.history-delete-btn{flex-shrink:0;font-size:.85rem;color:#991b1b;background:transparent;border:1px solid #fecaca;padding:.375rem .75rem}.history-delete-btn:hover{background:#fef2f2;border-color:#f87171}.history-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;padding:1rem 0}.history-page-info{font-size:.9rem;color:var(--color-text-muted)}.kpi-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;margin-bottom:1.5rem}@media(max-width:720px){.kpi-strip{grid-template-columns:repeat(2,minmax(0,1fr))}}.kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:.75rem 1rem;display:flex;flex-direction:column;gap:.25rem;min-height:4.5rem}.kpi-label{font-size:.75rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.kpi-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.2}.history-trend{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem;margin-bottom:1.5rem;color:var(--color-primary-dark)}.history-trend__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.history-trend__tabs,.history-trend__metric-toggle{display:inline-flex;flex-wrap:wrap;gap:.25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:.25rem}.history-trend__tab,.history-trend__metric-btn{background:transparent;border:none;padding:.375rem .75rem;border-radius:calc(var(--radius) - 2px);font-size:.85rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;min-height:2rem;transition:background .15s,color .15s}.history-trend__tab:hover,.history-trend__metric-btn:hover{color:var(--color-text)}.history-trend__tab--active,.history-trend__metric-btn--active{background:var(--color-primary);color:#fff}.history-trend__tab--active:hover,.history-trend__metric-btn--active:hover{color:#fff}.history-trend__chart{position:relative;width:100%;overflow-x:auto}.history-trend__chart svg{display:block;max-width:100%;height:auto;color:var(--color-primary-dark)}.history-trend__chart svg text{fill:var(--color-text-muted)}.history-trend__axis-unit{position:absolute;top:.25rem;left:.25rem;font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.history-trend__placeholder{color:var(--color-text-muted);text-align:center;padding:1.5rem 0;font-size:.9rem}.history-record{flex-direction:column;align-items:stretch;gap:0}.history-record-row{width:100%}.history-record-row__header{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%}.history-record-row__toggle{flex-shrink:0;font-size:.85rem;min-height:2.25rem}.history-record-row__toggle:before{content:"▸";display:inline-block;margin-right:.25rem;transition:transform .15s ease-out}.history-record-row__toggle[aria-expanded=true]:before{transform:rotate(90deg)}.history-record-row__detail{border-top:1px solid var(--color-border);background:var(--color-bg);margin:1rem -1.25rem -1rem;padding:1rem 1.25rem;border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius)}.history-record-row__error{display:flex;align-items:center;gap:.75rem;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius);padding:.5rem .75rem;font-size:.875rem}.history-detail__legacy-banner{font-size:.875rem;color:var(--color-text-muted);background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius);padding:.75rem 1rem;font-style:italic}.history-detail-table{width:100%;border-collapse:collapse;font-size:.875rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.history-detail-table th,.history-detail-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--color-border);vertical-align:top}.history-detail-table th{font-weight:600;font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;background:var(--color-bg)}.history-detail-table tbody tr:nth-child(2n){background:var(--color-bg)}.history-detail-table tbody tr:last-child td{border-bottom:none}.history-detail-table td:first-child{width:2rem;text-align:center;font-weight:700}.history-detail-table tbody tr td:first-child span[aria-label=Correct]{color:#166534}.history-detail-table tbody tr td:first-child span[aria-label=Incorrect]{color:#991b1b}.heatmap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem;margin-bottom:1.5rem}.heatmap__header{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem 1rem;margin-bottom:.75rem}.heatmap__title{font-size:1rem;font-weight:600;color:var(--color-text);margin:0;flex:1 1 auto}.heatmap__axis-label{font-size:.8rem;color:var(--color-text-muted)}.heatmap__axis-toggle{font-size:.8rem;padding:.25rem .625rem;min-height:2rem}.heatmap__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(7.5rem,1fr));gap:.375rem}.heatmap--note-reading .heatmap__grid,.heatmap--circle-of-fifths .heatmap__grid{grid-template-columns:repeat(auto-fill,minmax(6.5rem,1fr))}.heatmap-cell{display:flex;flex-direction:column;align-items:stretch;justify-content:center;min-height:3.5rem;padding:.375rem .5rem;border-radius:calc(var(--radius) - 2px);border:1px solid var(--color-border);color:var(--color-text);background:var(--color-surface);font-size:.8rem;line-height:1.25;text-shadow:0 0 1px rgba(255,255,255,.6)}.heatmap-cell__key{font-weight:600;font-size:.85rem;color:var(--color-text)}.heatmap-cell__value{color:var(--color-text);font-variant-numeric:tabular-nums}.heatmap--locked{background:var(--color-surface);border:1px dashed var(--color-border);color:var(--color-text-muted);text-align:center;padding:1.5rem;margin-bottom:1.5rem;border-radius:var(--radius);font-size:.9rem}@media(max-width:720px){.heatmap{padding:.75rem}.heatmap__grid{overflow-x:auto;grid-auto-flow:column;grid-auto-columns:minmax(7rem,1fr);grid-template-columns:none;padding-bottom:.5rem}.heatmap--note-reading .heatmap__grid,.heatmap--circle-of-fifths .heatmap__grid{grid-auto-columns:minmax(6rem,1fr)}.history-record-row__header{flex-wrap:wrap}.history-record-row__toggle{width:100%}}.save-error{background:#fef2f2;color:#991b1b;padding:.75rem 1rem;border-radius:var(--radius);margin-top:1rem;text-align:center}.toast{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius);box-shadow:0 4px 12px #00000026;z-index:1000;animation:toast-slide-in .3s ease-out;max-width:400px}@keyframes toast-slide-in{0%{transform:translateY(1rem);opacity:0}to{transform:translateY(0);opacity:1}}.toast-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.toast-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.toast-info{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}.toast-message{flex:1;font-size:.9rem}.toast-close{background:none;border:none;font-size:1.25rem;cursor:pointer;color:inherit;opacity:.7;padding:0;line-height:1}.toast-close:hover{opacity:1}@media(max-width:767px){.app-header{padding:.5rem .75rem;gap:.5rem;flex-wrap:wrap}.app-title h1{font-size:1.1rem}.app-nav{order:3;width:100%}.app-nav ul{gap:.25rem;flex-wrap:wrap}.nav-link{font-size:.8125rem;padding:.25rem .5rem}.auth-section{font-size:.75rem;order:2}.auth-error{font-size:.75rem}.app-main{padding:.75rem}.exercise-view{gap:.75rem}.exercise-toolbar{gap:.5rem}.exercise-toolbar h2{width:100%;font-size:1.25rem;margin-bottom:.25rem}.playback-controls{flex-wrap:wrap;gap:.375rem}.playback-controls button,.btn{font-size:.8125rem;padding:.375rem .75rem}.notation-container{padding:.75rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.notation-container svg{max-width:none;width:auto;height:auto}.settings-body{grid-template-columns:1fr;gap:.75rem}.settings-field input[type=number]{width:100%;max-width:none}.settings-clef-group{grid-column:span 1}.exercise-settings-popover{padding:.75rem}}@media(min-width:768px){.app-header{padding:.75rem 2rem}.app-content{padding:1.5rem 2rem}.exercise-toolbar{flex-wrap:nowrap}.settings-body{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.settings-clef-group{grid-column:span 1}.notation-container{max-width:100%;overflow-x:auto}.exercise-menu{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}}@media(min-width:1024px){.app-header{padding:.75rem 3rem}.app-content{padding:2rem 3rem;max-width:1200px;margin:0 auto}.notation-container{max-width:900px;margin:0 auto}.notation-container svg{max-width:100%}}.ear-training-exercise{max-width:var(--max-width);margin:0 auto;padding:1rem}.ear-training-exercise__header{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;min-height:2.25rem}.ear-training-exercise__header h2{margin:0;text-align:center;font-size:1.5rem}.ear-training-exercise__header .exercise-settings-menu{position:absolute;right:0;top:50%;transform:translateY(-50%)}.ear-training-exercise h2{text-align:center;margin-bottom:1rem;font-size:1.5rem}.ear-training-notation{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem;margin-bottom:1.5rem;min-height:160px}.ear-training-notation svg{display:block;width:100%;height:auto;max-width:100%}.answer-button{padding:.5rem .75rem;min-width:52px;min-height:44px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease;-webkit-user-select:none;user-select:none}.answer-button:hover:not(:disabled){background:#f1f5f9;border-color:var(--color-primary);box-shadow:var(--shadow)}.answer-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.answer-button:disabled{cursor:default;opacity:.6}.answer-button--correct{background:#dcfce7;border-color:#22c55e;color:#166534}.answer-button--correct:disabled{opacity:1}.answer-button--incorrect{background:#fee2e2;border-color:#f87171;color:#991b1b}.answer-button--incorrect:disabled{opacity:1}.interval-grid{display:grid;grid-template-columns:auto repeat(8,1fr);gap:.375rem;max-width:600px;margin:0 auto}.interval-grid__row-label{display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;font-size:.8rem;font-weight:600;color:var(--color-text-muted);min-width:20px}.interval-grid__empty{visibility:hidden}.interval-grid__header{text-align:center;font-size:.75rem;font-weight:600;color:var(--color-text-muted);padding-bottom:.25rem}.interval-grid--quantity{display:grid;grid-template-columns:repeat(7,1fr);gap:.375rem}.interval-score-grid{display:grid;grid-template-columns:auto repeat(8,1fr);gap:.25rem;max-width:600px;margin:1rem auto 0}.interval-score-grid--quantity{grid-template-columns:repeat(7,1fr)}.interval-score-grid__header{text-align:center;font-size:.75rem;font-weight:600;color:var(--color-text-muted);padding-bottom:.25rem}.interval-score-grid__row-label{display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;font-size:.8rem;font-weight:600;color:var(--color-text-muted)}.interval-score-grid__empty{visibility:hidden}.interval-score-grid__cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.35rem .25rem;border-radius:var(--radius);color:#0f172a;font-size:.75rem;line-height:1.1;min-height:48px;text-align:center}.interval-score-grid__cell--empty{color:var(--color-text-muted)}.interval-score-grid__cell-label{font-weight:700;font-size:.8rem}.interval-score-grid__cell-pct{font-weight:600}.interval-score-grid__cell-count,.interval-score-grid__cell-time{font-size:.65rem;color:#1e293b}.key-grid{max-width:600px;margin:0 auto}.key-grid__section{margin-bottom:1rem}.key-grid__section-label{font-size:.85rem;font-weight:600;color:var(--color-text-muted);margin-bottom:.5rem;text-align:center}.key-grid__buttons{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.375rem}.replay-button{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:0 auto 1.5rem;padding:.5rem 1.25rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-size:.9rem;cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.replay-button:hover:not(:disabled){background:#f1f5f9;border-color:var(--color-primary)}.replay-button:disabled{cursor:default;opacity:.5}@media(max-width:480px){.interval-grid{grid-template-columns:auto repeat(8,1fr);gap:.25rem}.interval-grid .answer-button{padding:.375rem .25rem;min-width:36px;font-size:.75rem}.interval-grid__row-label{font-size:.7rem;padding-right:.25rem}.key-grid__buttons{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}}@media(max-width:360px){.interval-grid{gap:.125rem}.interval-grid .answer-button{padding:.25rem .125rem;min-width:32px;min-height:40px;font-size:.7rem}.key-grid__buttons{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.key-grid__buttons .answer-button{min-height:44px;font-size:.8rem}}.ear-training-toggle{display:flex;justify-content:center;gap:.25rem;margin-bottom:.75rem;flex-wrap:wrap}.ear-training-toggle__btn{padding:.375rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.ear-training-toggle__btn:not(.ear-training-toggle__btn--active):hover{border-color:var(--color-primary)}.ear-training-toggle__btn--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.interval-settings{display:flex;flex-direction:column;gap:.5rem}.interval-settings__toggle{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;cursor:pointer}.exercise-stats{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem;margin-top:1.5rem}.exercise-stats__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.exercise-stats__title{font-size:1rem;font-weight:600;margin:0}.exercise-stats__reset{font-size:.8125rem;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius);padding:.25rem .625rem;cursor:pointer;color:var(--color-text-muted)}.exercise-stats__reset:hover{border-color:var(--color-primary);color:var(--color-primary)}.exercise-stats__empty{color:var(--color-text-muted);font-size:.875rem;text-align:center;padding:.5rem 0}.score-bar-chart{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(32px,1fr);column-gap:.375rem;padding:0;margin:0;align-items:end;overflow-x:auto;scrollbar-width:thin}.score-bar-chart__col{display:flex;flex-direction:column;align-items:stretch;min-width:0}.score-bar-chart__track{position:relative;width:100%;height:88px;background-color:var(--color-surface);background-image:repeating-linear-gradient(0deg,rgba(148,163,184,.16) 0 1px,transparent 1px 25%);border:1px solid var(--color-border);border-radius:4px;overflow:hidden}.score-bar-chart__fill{position:absolute;inset:0;min-width:4px;min-height:3px;transform:scaleY(var(--fill));transform-origin:bottom center;transition:transform .4s ease-out;border-radius:3px 3px 0 0}@media(prefers-reduced-motion:reduce){.score-bar-chart__fill{transition:none}}.score-bar-chart__fill--good{background:linear-gradient(180deg,#4ade80,#22c55e)}.score-bar-chart__fill--ok{background:linear-gradient(180deg,#facc15,#eab308)}.score-bar-chart__fill--poor{background:linear-gradient(180deg,#f87171,#ef4444)}.score-bar-chart__fill--unasked{background:repeating-linear-gradient(45deg,var(--color-border) 0 5px,transparent 5px 10px)}.score-bar-chart__percent{position:absolute;top:2px;left:50%;transform:translate(-50%);color:var(--color-text);font-size:.625rem;font-weight:700;font-variant-numeric:tabular-nums;background:#ffffffeb;padding:0 4px;border-radius:999px;line-height:1.3;pointer-events:none;letter-spacing:-.01em}.score-bar-chart__label{margin-top:.375rem;color:var(--color-text);font-size:.6875rem;font-weight:500;line-height:1.2;text-align:center;overflow-wrap:anywhere}.score-bar-chart__count{color:var(--color-text-muted);font-size:.625rem;text-align:center;font-variant-numeric:tabular-nums;line-height:1.2}.chromatic-score-circle{margin:1.25rem auto 0;display:flex;flex-direction:column;gap:.75rem;align-items:stretch;max-width:220px}.chromatic-score-circle__title{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text);text-align:center}.chromatic-score-circle__slice{cursor:help;outline:none}.chromatic-score-circle__slice:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px}.chromatic-score-circle__table{width:100%;border-collapse:collapse;font-size:.75rem;color:var(--color-text)}.chromatic-score-circle__table caption{font-weight:600;text-align:left;padding-bottom:.25rem}.chromatic-score-circle__table th,.chromatic-score-circle__table td{padding:.2rem .375rem;border-bottom:1px solid var(--color-border);text-align:left;font-variant-numeric:tabular-nums}.chromatic-score-circle__table thead th{font-weight:600;color:var(--color-text-muted)}.chromatic-dual-ring-circle{width:100%;max-width:300px;margin:1.25rem auto 0;display:flex;flex-direction:column;gap:.75rem}.chromatic-dual-ring-circle__title{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text);text-align:center}.chromatic-dual-ring-circle svg{width:100%;height:auto;display:block}.chromatic-dual-ring-circle__slice{cursor:help;outline:none}.chromatic-dual-ring-circle__slice:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px}.chromatic-dual-ring-circle__path{transition:filter .16s ease}.chromatic-dual-ring-circle__slice:hover .chromatic-dual-ring-circle__path,.chromatic-dual-ring-circle__slice:focus-visible .chromatic-dual-ring-circle__path{filter:brightness(1.07) saturate(1.08)}.chromatic-dual-ring-circle__pct{font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.01em;fill:#fff;paint-order:stroke;stroke:#0f172a8c;stroke-width:2.25;stroke-linejoin:round;pointer-events:none}.chromatic-dual-ring-circle__time{font-weight:500;font-variant-numeric:tabular-nums;fill:#fffffff0;paint-order:stroke;stroke:#0f172a73;stroke-width:1.6;stroke-linejoin:round;pointer-events:none}.chromatic-dual-ring-circle__pitch-label{font-weight:600;fill:var(--color-text);letter-spacing:-.01em}@media(max-width:480px){.chromatic-dual-ring-circle{max-width:280px}.chromatic-score-circle{max-width:220px}.chromatic-score-circle__table{font-size:.7rem}}
