*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0b;--card:#141416;--card-2:#1c1c1f;--border:#2a2a2e;--border-hover:var(--border-hover);--card-hover:var(--card-hover);--text:#f1f5f9;--muted:#64748b;--a:#6366f1;--green:#22c55e;--red:#ef4444;--radius:10px}[data-theme=light]{--bg:#f8fafc;--card:#fff;--card-2:#f1f5f9;--border:#e2e8f0;--border-hover:#cbd5e1;--card-hover:#e8edf2;--text:#0f172a;--muted:#64748b}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.5}.app{max-width:760px;margin:0 auto;padding:0 16px 48px}.app-header{border-bottom:1px solid var(--border);margin-bottom:24px;padding:40px 0 24px}.header-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.header-actions{flex-shrink:0;gap:6px;margin-top:4px;display:flex}.app-header h1{letter-spacing:-.03em;font-size:1.75rem;font-weight:700}.title-eq{color:var(--a)}.app-header p{color:var(--muted);margin-top:4px;font-size:.9rem}.icon-btn{background:var(--card-2);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:8px;transition:color .15s,border-color .15s,background .15s;display:flex}.icon-btn:hover{color:var(--text);border-color:var(--border-hover);background:var(--card-hover)}.icon-btn[data-tooltip]{position:relative}.icon-btn[data-tooltip]:after{content:attr(data-tooltip);background:var(--card-2);border:1px solid var(--border);color:var(--text);white-space:nowrap;pointer-events:none;opacity:0;border-radius:6px;padding:4px 8px;font-size:.72rem;font-weight:500;transition:opacity .15s,transform .15s;position:absolute;bottom:calc(100% + 8px);right:0;transform:translateY(4px)}.icon-btn[data-tooltip]:hover:after{opacity:1;transform:translateY(0)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:20px}.card h2{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-size:.75rem;font-weight:600}.track-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;display:grid}.track-btn{background:var(--card-2);border:1px solid var(--border);color:var(--text);cursor:pointer;text-align:left;border-radius:8px;flex-direction:column;gap:4px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.track-btn:hover:not(:disabled){border-color:var(--border-hover);background:var(--card-hover)}.track-btn.active{border-color:var(--a);background:#6366f114}.track-btn:disabled{opacity:.5;cursor:default}.track-name{font-size:.95rem;font-weight:600}.track-desc{color:var(--muted);font-size:.78rem}.audio-controls{border-top:1px solid var(--border);flex-direction:column;gap:10px;margin-top:14px;padding-top:14px;display:flex}.control-row{align-items:center;gap:10px;display:flex}.control-row-pair{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=480px){.control-row-pair{grid-template-columns:1fr}}.control-label{color:var(--muted);flex-shrink:0;min-width:54px;font-size:.75rem;font-weight:600}.control-value{color:var(--muted);text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:34px;font-size:.75rem}.control-value-time{min-width:max-content}.control-duration{opacity:.5;font-size:.7rem}.control-slider{appearance:none;background:linear-gradient(to right, var(--a) var(--fill,80%), var(--border) var(--fill,80%));cursor:pointer;border-radius:2px;outline:none;flex:1;height:4px}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--a);cursor:pointer;border-radius:50%;width:14px;height:14px;transition:transform .1s,box-shadow .1s}.control-slider::-webkit-slider-thumb:hover{transform:scale(1.25);box-shadow:0 0 0 4px #6366f12e}.control-slider:active::-webkit-slider-thumb{transform:scale(1.1)}.control-slider::-moz-range-track{background:var(--border);border-radius:2px;height:4px}.control-slider::-moz-range-progress{background:var(--a);border-radius:2px;height:4px}.control-slider::-moz-range-thumb{background:var(--a);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.btn-primary{background:var(--a);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:.9rem;font-weight:600;transition:opacity .15s}.btn-primary:hover{opacity:.88}.btn-primary.large{padding:14px 36px;font-size:1.05rem}.btn-ghost{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:5px 12px;font-size:.8rem;transition:all .15s}.btn-ghost:hover{color:var(--text);border-color:var(--border-hover)}.score-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.score-header h2{margin:0}.score-body{flex-direction:column;gap:10px;display:flex}.score-number{align-items:baseline;gap:4px;display:flex}.score-big{letter-spacing:-.04em;font-size:2.4rem;font-weight:800}.score-sep{color:var(--muted);font-size:1.5rem}.score-total{color:var(--muted);font-size:1.4rem}.score-bar-wrap{align-items:center;gap:10px;display:flex}.score-bar{background:var(--card-2);border-radius:4px;flex:1;height:8px;overflow:hidden}.score-fill{border-radius:4px;height:100%;transition:width .4s}.score-pct{color:var(--muted);min-width:36px;font-size:.85rem;font-weight:600}.score-note{color:var(--muted);font-size:.82rem}.error{color:var(--red);margin-top:10px;font-size:.82rem}.app-footer{border-top:1px solid var(--border);color:var(--muted);flex-wrap:wrap;justify-content:space-between;gap:12px;margin-top:8px;padding-top:20px;font-size:.82rem;display:flex}.app-footer a{color:var(--a);text-decoration:none}.app-footer a:hover{text-decoration:underline}.info-modal{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;width:calc(100vw - 32px);max-width:540px;margin:auto;padding:0}.info-modal::backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0000008c}@keyframes modal-in{0%{opacity:0;transform:translateY(-6px)scale(.98)}to{opacity:1;transform:none}}.info-modal[open]{animation:.18s modal-in}.info-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.info-modal-header h2{letter-spacing:-.01em;text-transform:none;color:var(--text);margin:0;font-size:.95rem;font-weight:700}.info-modal-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;transition:color .15s;display:flex}.info-modal-close:hover{color:var(--text)}.info-modal-body{flex-direction:column;gap:20px;max-height:70vh;padding:20px;display:flex;overflow-y:auto}.info-warning{background:color-mix(in srgb, var(--a) 12%, transparent);border:1px solid color-mix(in srgb, var(--a) 40%, transparent);color:var(--text);border-radius:8px;padding:12px 16px;font-size:.85rem;line-height:1.5}.info-warning strong{color:var(--a)}.info-section h3{letter-spacing:.08em;text-transform:uppercase;color:var(--a);margin-bottom:8px;font-size:.7rem;font-weight:700}.info-section p{color:var(--muted);font-size:.875rem;line-height:1.65}.info-section p strong{color:var(--text)}.info-section p em{color:var(--text);font-style:italic}.info-mode-list{flex-direction:column;gap:8px;display:flex}.info-mode-item{color:var(--muted);border-left:2px solid var(--border);padding-left:10px;font-size:.875rem;line-height:1.5}.info-mode-item strong{color:var(--text)}.info-level-row{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.info-level-badge{background:var(--card-2);border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:8px 14px;font-size:.82rem;line-height:1.4}.info-level-badge strong{color:var(--text);margin-bottom:2px;font-size:.88rem;display:block}.trainer-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;min-height:160px;display:flex}.trainer-modepick h2{margin-bottom:16px}.mode-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.mode-card{background:var(--card-2);border:2px solid var(--border);color:var(--text);cursor:pointer;text-align:center;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:20px 12px;transition:all .15s;display:flex}.mode-card:hover{border-color:var(--a);background:#6366f114}.mode-sign{letter-spacing:-.02em;color:var(--a);font-size:1.5rem;font-weight:800}.mode-label{font-size:.95rem;font-weight:700}.mode-desc{color:var(--muted);font-size:.75rem;line-height:1.4}.mode-badge{color:var(--a);background:#6366f11a;border:1px solid #6366f140;border-radius:6px;padding:2px 10px;font-size:.75rem;font-weight:700}.trainer-start{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;min-height:160px;display:flex}.trainer-start-top{align-items:center;gap:10px;display:flex}.muted{color:var(--muted)}.start-desc{color:var(--muted);font-size:.9rem}.start-desc strong{color:var(--text)}.level-chip{color:var(--a);letter-spacing:.06em;text-transform:uppercase;background:#6366f126;border:1px solid #6366f166;border-radius:20px;padding:3px 12px;font-size:.78rem;font-weight:700}.trainer-card{flex-direction:column;gap:18px;display:flex}.trainer-header{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.trainer-status{color:var(--muted);font-size:.88rem}.trainer-result{font-size:1rem;font-weight:700}.result-correct{color:var(--green)}.result-incorrect{color:var(--red)}.playback-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.play-toggle{background:var(--card-2);border:2px solid var(--border);color:var(--text);cursor:pointer;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 22px;font-size:1rem;font-weight:600;transition:all .15s;display:flex}.play-toggle-eq{color:#6366f1;background:#6366f138;border-color:#6366f1}.play-toggle-eq:hover{color:#818cf8;background:#6366f152}.play-toggle-eq.ptog-eq{background:var(--a);border-color:var(--a);color:#fff}.play-toggle-eq.ptog-eq:hover{background:#4f52d4;border-color:#4f52d4}.play-toggle-flat{color:#14b8a6;background:#14b8a638;border-color:#14b8a6}.play-toggle-flat:hover{color:#2dd4bf;background:#14b8a652}.play-toggle-flat.ptog-flat{color:#fff;background:#14b8a6;border-color:#14b8a6}.play-toggle-flat.ptog-flat:hover{background:#0d9488;border-color:#0d9488}.playback-tip{color:var(--muted);margin-left:4px;font-size:.75rem}.freq-graph-wrap{background:var(--card-2);border:1px solid var(--border);border-radius:8px;line-height:0;overflow:hidden}.freq-graph-svg{display:block}.graph-label{fill:var(--muted);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:9px}.graph-grid{stroke:var(--border);stroke-width:1px}.graph-zero{stroke:var(--border-hover);stroke-width:1.5px}.graph-curve-gray{fill:none;stroke:var(--muted);stroke-width:1.2px;opacity:.35}.graph-border{fill:none;stroke:var(--border);stroke-width:1px}@keyframes graph-in{0%{opacity:0}to{opacity:1}}.graph-reveal{animation:.25s graph-in}.graph-fill-boost{fill:#6366f121}.graph-fill-cut{fill:#f9731621}.graph-curve-boost{fill:none;stroke:var(--a);stroke-width:2px;stroke-linejoin:round}.graph-curve-cut{fill:none;stroke:#f97316;stroke-width:2px;stroke-linejoin:round}.graph-peak-boost{stroke:var(--a);stroke-width:1px;stroke-dasharray:3 3;opacity:.5}.graph-peak-cut{stroke:#f97316;stroke-width:1px;stroke-dasharray:3 3;opacity:.5}.graph-placeholder{fill:var(--muted);stroke:var(--card-2);stroke-width:8px;paint-order:stroke;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:11px}.freq-graph-card{padding-bottom:14px}.freq-grid{gap:6px;display:flex}.freq-grid-mixed{flex-direction:column;gap:10px;display:flex}.mixed-row{flex-direction:column;gap:6px;display:flex}.mixed-row-label{letter-spacing:.07em;text-transform:uppercase;font-size:.72rem;font-weight:700}.boost-label{color:var(--green)}.cut-label{color:#f97316}.mixed-dir-reveal{margin-left:auto;font-size:.78rem}.mixed-dir-reveal strong{color:var(--text)}.freq-btn{background:var(--card-2);border:2px solid var(--border);min-width:0;color:var(--text);cursor:pointer;border-radius:10px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-height:70px;padding:14px 2px;transition:all .13s;display:flex}.freq-btn:hover:not(:disabled){border-color:var(--border-hover);background:var(--card-hover)}.freq-btn:disabled{cursor:default}.freq-btn.f-selected{border-color:var(--a);color:var(--a);background:#6366f12e}.freq-btn.f-hit{border-color:var(--green);color:var(--green);background:#22c55e2e}.freq-btn.f-missed{color:#f97316;background:#f973162e;border-color:#f97316}.freq-btn.f-wrong{border-color:var(--red);color:var(--red);background:#ef444426}.freq-num{letter-spacing:-.02em;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:clamp(.6rem,1.8vw,1rem);font-weight:700;overflow:hidden}.freq-unit{opacity:.7;font-size:clamp(.5rem,1.2vw,.65rem)}.freq-legend{flex-wrap:wrap;gap:18px;display:flex}.legend-item{color:var(--muted);align-items:center;gap:6px;font-size:.78rem;display:flex}.legend-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.ld-hit{background:var(--green)}.ld-missed{background:#f97316}.ld-wrong{background:var(--red)}.streak-row{border-top:1px solid var(--border);align-items:center;gap:12px;padding-top:14px;display:flex}.streak-label{color:var(--muted);flex:1;font-size:.78rem}.wrong-label{color:#f97316}.streak-pips{gap:6px;display:flex}.pip{background:var(--card-2);border:1.5px solid var(--border);border-radius:50%;width:12px;height:12px;transition:all .2s}.pip-correct{background:var(--green);border-color:var(--green)}.pip-wrong{background:#f97316;border-color:#f97316}.trainer-action{justify-content:flex-end;display:flex}.btn-primary:disabled{opacity:.35;cursor:default}@media (width<=600px){.freq-btn{min-height:60px}}@media (width<=400px){.playback-tip{display:none}.freq-grid{gap:4px}}
