*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f172a;--surface:#1e293b;--border:#334155;--text:#f1f5f9;--muted:#94a3b8;--green:#4ade80;--yellow:#facc15;--red:#f87171;--accent:#6366f1}html,body{background:var(--bg);height:100%;color:var(--text);font-family:Inter,system-ui,sans-serif;font-size:16px}.layout{flex-direction:column;gap:16px;max-width:680px;min-height:100dvh;margin:0 auto;padding:16px;display:flex}.header{justify-content:space-between;align-items:center;display:flex}.logo{letter-spacing:-.5px;color:var(--green);font-size:1.4rem;font-weight:700}.tabs{gap:4px;display:flex}.auth-area{align-items:center;gap:8px;margin-left:auto;padding-right:8px;display:flex}.auth-name{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:.75rem;overflow:hidden}.btn-auth{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;font-size:.75rem;transition:border-color .15s,color .15s}.btn-auth:hover{border-color:var(--accent);color:var(--accent)}.tab{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;padding:6px 14px;font-size:.85rem;transition:all .15s}.tab.active,.tab:hover{background:var(--accent);border-color:var(--accent);color:#fff}#start-screen{justify-content:center;display:flex}.btn{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:10px;padding:10px 20px;font-size:.95rem;transition:all .15s}.btn:hover{border-color:var(--accent);color:var(--accent)}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;padding:14px 28px;font-size:1.1rem}.btn-primary:hover{color:#fff;background:#4f46e5;border-color:#4f46e5}.note-display-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px}#note-display{flex-direction:column;align-items:center;gap:12px;display:flex}.note-name{letter-spacing:-2px;color:var(--green);font-size:4rem;font-weight:800;line-height:1}.raw-hz{color:var(--muted);min-height:1.1em;font-family:monospace;font-size:.8rem}.cents{color:var(--muted);min-height:1.4em;font-size:1rem;transition:color .2s}.meter{width:100%;max-width:300px}.meter-track{background:var(--bg);border-radius:4px;height:8px;position:relative;overflow:hidden}.meter-center{background:var(--border);width:2px;height:100%;position:absolute;top:0;left:50%;transform:translate(-50%)}.meter-bar{background:var(--green);border-radius:2px;width:12px;height:100%;transition:left 80ms ease-out;position:absolute;top:0;left:calc(50% - 6px)}.meter-labels{color:var(--muted);justify-content:space-between;margin-top:4px;font-size:.7rem;display:flex}#trace-container{border:1px solid var(--border);border-radius:12px;height:160px;overflow:hidden}.game-hud{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;align-items:center;gap:10px;padding:24px;display:flex}.hud-top-row{justify-content:space-between;align-items:center;width:100%;display:flex}.hud-controls{gap:6px;display:flex}.btn-sm{border-radius:7px;padding:4px 10px;font-size:.75rem}.round-counter{color:var(--muted);font-size:.85rem}.streak{min-height:1.4em;font-size:1rem}.target-note{letter-spacing:-3px;color:var(--yellow);font-size:5rem;font-weight:900;line-height:1}.target-note .octave{color:var(--muted);font-size:2.5rem}.target-hz{color:var(--muted);font-family:monospace;font-size:.8rem}.phase-label{min-height:1.5em;color:var(--text);font-size:1.1rem;font-weight:600;transition:all .2s}.phase-label.whistle{color:var(--green)}.phase-label.result{color:var(--yellow)}.round-score{font-size:2rem;font-weight:800}.score-perfect{color:var(--green)}.score-great{color:#86efac}.score-ok{color:var(--yellow)}.score-miss{color:var(--red)}.game-result{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;align-items:center;gap:16px;padding:32px;display:flex}.result-title{color:var(--muted);font-size:1.2rem}.final-score{color:var(--green);font-size:5rem;font-weight:900}.final-score span{color:var(--muted);font-size:1.5rem}.round-breakdown{flex-direction:column;gap:6px;width:100%;display:flex}.round-row{color:var(--muted);align-items:center;gap:10px;font-size:.95rem;display:flex}.rr-num{min-width:56px;font-size:.8rem}.rr-note{color:var(--text);min-width:36px;font-weight:700}.rr-icon{margin-left:auto;font-size:1.1rem;font-weight:800}.rr-icon.perfect{color:var(--green)}.rr-icon.great{color:#86efac}.rr-icon.ok{color:var(--yellow)}.rr-icon.miss{color:var(--red)}.song-idle,.song-countdown,.song-result{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;align-items:center;gap:16px;padding:24px;display:flex}.song-title{font-size:1.3rem;font-weight:700}.song-key{color:var(--muted);font-size:.85rem}.song-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.countdown-num{color:var(--yellow);font-size:7rem;font-weight:900;line-height:1}.song-hud{flex-direction:column;align-items:center;gap:16px;display:flex}.song-live-note{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:4px;min-width:180px;padding:20px 32px;font-size:4.5rem;font-weight:900;line-height:1;transition:color .1s;display:flex}.song-live-octave{color:var(--muted);font-size:2rem;font-weight:400}.song-live-lyric{color:var(--muted);margin-top:4px;font-size:1rem;font-weight:600}.song-live-cents{min-height:1.3em;font-family:monospace;font-size:.9rem;transition:color .1s}.song-strip{scroll-snap-type:x mandatory;scrollbar-width:none;box-sizing:border-box;gap:6px;width:100%;padding:8px 50%;display:flex;overflow-x:auto}.song-strip::-webkit-scrollbar{display:none}.snote{scroll-snap-align:center;border:1px solid var(--border);background:var(--bg);opacity:.4;border-radius:8px;flex-direction:column;flex-shrink:0;align-items:center;gap:2px;min-width:52px;padding:6px 4px;transition:all .15s;display:flex}.snote .sn{color:var(--muted);font-size:.85rem;font-weight:700}.snote .sl{color:var(--muted);text-align:center;font-size:.6rem}.snote.active{opacity:1;border-color:var(--yellow);background:#facc1514;transform:scale(1.12)}.snote.active .sn,.snote.active .sl{color:var(--yellow)}.snote.hit{opacity:1;border-color:var(--green);background:#4ade8014}.snote.hit .sn{color:var(--green)}.snote.close{opacity:1;border-color:var(--yellow);background:#facc1514}.snote.close .sn{color:var(--yellow)}.snote.miss{opacity:1;border-color:var(--red);background:#f8717114}.snote.miss .sn{color:var(--red)}.song-note-grid{flex-wrap:wrap;justify-content:center;gap:6px;width:100%;display:flex}.song-note-cell{border:1px solid var(--border);background:var(--bg);border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:2px;width:54px;min-height:62px;padding:4px 2px;display:flex}.snc-note{color:var(--muted);font-size:.85rem;font-weight:700;line-height:1}.snc-lyric{color:var(--muted);text-align:center;font-size:.62rem}.snc-cents{color:var(--muted);font-family:monospace;font-size:.58rem}.song-note-cell.hit{border-color:var(--green);background:#4ade8014}.song-note-cell.hit .snc-note{color:var(--green)}.song-note-cell.close{border-color:var(--yellow);background:#facc1514}.song-note-cell.close .snc-note{color:var(--yellow)}.song-note-cell.miss{border-color:var(--red);background:#f8717114}.song-note-cell.miss .snc-note{color:var(--red)}.song-grade{font-size:6rem;font-weight:900;line-height:1}.song-score{color:var(--muted);margin-top:-8px;font-size:1.3rem}#status-bar{color:var(--muted);text-align:center;font-size:.8rem}.hint{color:var(--muted);text-align:center;font-size:.9rem}.lock-bar-wrap{background:var(--bg);border:1px solid var(--border);border-radius:4px;width:100%;max-width:260px;height:8px;overflow:hidden}.lock-bar{background:var(--green);border-radius:4px;height:100%;transition:width 80ms linear}.octave-hint{border-radius:20px;min-height:1.6em;padding:4px 12px;font-size:.85rem;font-weight:600}.octave-hint.ok{color:var(--green);background:#4ade801a;border:1px solid #4ade804d}.octave-hint.warn{color:var(--yellow);background:#facc151a;border:1px solid #facc154d}.octave-badge{vertical-align:middle;border-radius:10px;padding:2px 7px;font-size:.7rem;font-weight:600}.octave-badge.ok{color:var(--green);background:#4ade801f}.octave-badge.warn{color:var(--yellow);background:#facc151f}.melody-hud{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;align-items:center;gap:20px;padding:24px;display:flex}.melody-phase{color:var(--text);font-size:1.1rem;font-weight:600}.melody-notes{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.melody-note-box{border:2px solid var(--border);background:var(--bg);width:72px;height:86px;color:var(--muted);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding-top:18px;font-size:1.8rem;font-weight:800;line-height:1;transition:border-color .2s,color .2s,background .2s,transform .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.melody-note-box span{color:var(--muted);font-size:.9rem;font-weight:400}.note-seq{color:var(--muted);opacity:.6;letter-spacing:.03em;font-size:.62rem;font-weight:500;position:absolute;top:5px;left:50%;transform:translate(-50%)}.note-timer-bar{background:var(--yellow);border-radius:0 0 10px 10px;width:0%;height:4px;position:absolute;bottom:0;left:0}.melody-note-box.current .note-timer-bar{animation:1.05s linear forwards note-fill}@keyframes note-fill{0%{width:0%}to{width:100%}}.melody-note-box.upcoming{color:#facc1566;background:#facc1505;border-color:#facc154d}.melody-note-box.upcoming span,.melody-note-box.upcoming .note-seq{color:#facc1566}.melody-note-box.active-waiting{border-color:var(--green);color:var(--green);animation:1.1s ease-in-out infinite waiting-pulse}.melody-note-box.active-waiting span{color:var(--green)}.melody-note-box.active-waiting .note-seq{color:var(--green);opacity:.8}@keyframes waiting-pulse{0%,to{box-shadow:0 0 #4ade8000}50%{box-shadow:0 0 14px 5px #4ade8040}}.melody-note-box.current{border-color:var(--yellow);color:var(--yellow);background:#facc1514;transform:scale(1.08);box-shadow:0 0 20px #facc1533}.melody-note-box.current span{color:var(--yellow)}.melody-note-box.hit{border-color:var(--green);color:var(--green);background:#4ade8014}.melody-note-box.hit span{color:var(--green)}.melody-note-box.close{border-color:var(--yellow);color:var(--yellow);background:#facc1514}.melody-note-box.close span{color:var(--yellow)}.melody-note-box.miss{border-color:var(--red);color:var(--red);background:#f8717114}.melody-note-box.miss span{color:var(--red)}.melody-hint{color:var(--muted);font-size:.78rem}.match-lock-wrap{background:var(--bg);border:1px solid var(--border);border-radius:10px;width:100%;max-width:320px;height:20px;overflow:hidden}.match-lock-bar{background:var(--green);border-radius:10px;height:100%;transition:width 60ms linear}.phase-label.success{color:var(--green);font-size:1.5rem}.phase-label.listen{color:var(--muted)}.hit-count{color:var(--green);min-width:80px;font-size:.85rem;font-weight:600}.btn-skip{color:var(--red);border:1px solid var(--red);background:#f8717114;border-radius:10px;width:100%;max-width:260px;padding:10px 24px;font-size:.85rem}.btn-skip:hover{color:var(--red);background:#f871712e}.match-actions{flex-direction:column;align-items:center;gap:10px;width:100%;display:flex}.btn-replay{color:var(--muted);border-color:var(--border);font-size:.8rem}.hit-count-row{justify-content:flex-end;width:100%;min-height:1.4em;display:flex}.match-top-row{justify-content:space-between;align-items:center;width:100%;min-height:2rem;display:flex}.match-top-left,.match-top-right{align-items:center;display:flex}.challenge-badge{color:var(--yellow);background:#facc151a;border:1px solid #facc154d;border-radius:20px;padding:4px 14px;font-size:.8rem;font-weight:700}.phase-label.challenge-success{color:var(--yellow);font-size:1.6rem}.range-pos-wrap{width:100%;max-width:260px}.range-pos-track{background:#6366f126;border:1px solid #6366f14d;border-radius:3px;height:6px;margin-bottom:4px;position:relative}.range-pos-dot{background:var(--accent);border-radius:50%;width:12px;height:12px;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 0 6px #6366f199}.range-pos-labels{color:var(--muted);justify-content:space-between;font-size:.68rem;display:flex}.range-pos-center{color:var(--accent);font-weight:600}.range-pos-dot.live{background:var(--green);z-index:2;width:10px;height:10px;box-shadow:0 0 6px #4ade80b3}.range-pos-wrap.outside{justify-content:center;display:flex}.range-pos-outside{color:var(--yellow);background:#facc1514;border:1px solid #facc1540;border-radius:20px;padding:3px 10px;font-size:.8rem;font-weight:600}.range-wizard{gap:20px}.range-step-num{color:var(--muted);font-size:.8rem}.range-step-title{text-align:center;font-size:1.2rem;font-weight:700}.range-existing{color:var(--muted);font-size:.85rem}.range-record-wrap{background:var(--bg);border:1px solid var(--border);border-radius:6px;width:100%;max-width:300px;height:12px;overflow:hidden}.range-record-bar{background:var(--accent);border-radius:6px;height:100%;transition:width 50ms linear}.range-recording-label{color:var(--accent);font-size:.9rem;font-weight:600;animation:1s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.range-detected{color:var(--green);font-size:4rem;font-weight:900;line-height:1}.range-detected-hz{color:var(--muted);font-family:monospace;font-size:.85rem}.range-actions{gap:10px;display:flex}.range-confirm-row{align-items:center;gap:16px;display:flex}.range-confirm-note{flex-direction:column;align-items:center;gap:4px;display:flex}.range-confirm-arrow{color:var(--muted);font-size:1.5rem}.range-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.range-graph-wrap{width:100%;max-width:460px}.range-graph-caption{color:var(--muted);text-align:center;opacity:.7;margin-top:4px;font-size:.7rem}.range-note-count{color:var(--text);text-align:center;font-size:1rem}.range-note-count strong{color:var(--accent);font-size:1.3rem}.melody-breakdown{flex-direction:column;gap:8px;width:100%;display:flex}.melody-result-row{align-items:center;gap:12px;font-size:.9rem;display:flex}.mnote{min-width:36px;font-size:1rem;font-weight:700}.mnote.hit{color:var(--green)}.mnote.close{color:var(--yellow)}.mnote.miss{color:var(--red)}.mstatus{flex:1}.mstatus.hit{color:var(--green)}.mstatus.close{color:var(--yellow)}.mstatus.miss{color:var(--red)}.mcents{color:var(--muted);text-align:right;min-width:48px;font-family:monospace;font-size:.8rem}.melody-big-note{color:var(--yellow);text-align:center;text-shadow:0 0 30px #facc1566;margin:4px 0 8px;font-size:4.5rem;font-weight:800;line-height:1}.melody-big-octave{color:#facc15b3;vertical-align:super;font-size:2rem;font-weight:400}.melody-big-hz{color:var(--muted);margin-top:4px;font-size:.85rem;font-weight:400}.scales-dir-row{align-items:center;gap:6px;margin-bottom:12px;display:flex}.scales-dir-btn{background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:6px;width:34px;height:34px;font-size:1rem;transition:border-color .15s,color .15s}.scales-dir-btn.active{border-color:var(--accent);color:var(--accent);background:#6366f11a}.scales-dir-label{color:var(--muted);margin-left:4px;font-size:.8rem}.scales-big-note{color:var(--yellow);text-align:center;text-shadow:0 0 30px #facc1566;margin:4px 0 8px;font-size:4.5rem;font-weight:800;line-height:1}.scales-big-octave{color:#facc15b3;vertical-align:super;font-size:2rem;font-weight:400}.scales-big-hz{color:var(--muted);margin-top:4px;font-size:.85rem;font-weight:400}.scales-strip{flex-wrap:wrap;justify-content:center;gap:6px;margin:10px 0 4px;display:flex}.scale-note-pip{border:1px solid var(--border);background:var(--surface);width:38px;height:46px;color:var(--muted);border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:1px;font-size:1rem;font-weight:700;transition:border-color .15s,color .15s;display:flex}.pip-note{font-size:.95rem;font-weight:700;line-height:1}.pip-oct{color:var(--muted);font-size:.65rem}.scale-note-pip.current{border-color:var(--yellow);color:var(--yellow);background:#facc1514;box-shadow:0 0 10px #facc1533}.scale-note-pip.current .pip-oct{color:#facc15b3}.scale-note-pip.hit{border-color:var(--green);color:var(--green);background:#4ade8014}.scale-note-pip.hit .pip-oct{color:#4ade80b3}.scale-note-pip.close{border-color:var(--yellow);color:var(--yellow);background:#facc150f}.scale-note-pip.miss{border-color:var(--red);color:var(--red);background:#f871710f}.scales-skip{margin-top:8px;font-size:.8rem}.scales-result-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.home-grid{grid-template-columns:1fr 1fr;gap:16px;max-width:480px;margin:24px auto 0;padding:0 8px;display:grid}.mode-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;text-align:center;-webkit-user-select:none;user-select:none;border-radius:12px;padding:20px 16px;transition:border-color .15s,background .15s}.mode-card:hover{border-color:var(--accent);background:#6366f112}.mode-card-icon{margin-bottom:8px;font-size:2rem}.mode-card-name{margin-bottom:6px;font-size:1rem;font-weight:700}.mode-card-desc{color:var(--muted);font-size:.78rem;line-height:1.4}.home-range-badge{color:var(--green);background:#4ade8014;border:1px solid #4ade8040;border-radius:20px;margin-top:4px;padding:1px 8px;font-size:.72rem;display:inline-block}.home-range-badge.no-range{color:var(--muted);border-color:var(--border);background:0 0}
