:root{--bg: #0d0b09;--surface: #161311;--surface-2: #1f1a16;--line: #2c2620;--text: #ece5d8;--text-dim: #9a907f;--amber: #f5a83c;--amber-deep: #c97f1d;--felt: #8e2b35;--teal: #52b3b5;--green: #67c587;--danger: #d4604f;--radius: 10px;--sat: env(safe-area-inset-top, 0px);--sab: env(safe-area-inset-bottom, 0px);--font-ui: "Schibsted Grotesk", system-ui, sans-serif;--font-display: "Instrument Serif", Georgia, serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, monospace}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{height:100%;overscroll-behavior:none}body{background:radial-gradient(120% 60% at 50% -10%,#1a1410 0%,var(--bg) 55%),var(--bg);color:var(--text);font-family:var(--font-ui);font-size:16px;line-height:1.45;-webkit-font-smoothing:antialiased}#app{height:100dvh;display:flex;flex-direction:column}.screen{display:none;flex:1;min-height:0;flex-direction:column;padding:calc(var(--sat) + 16px) 18px calc(var(--sab) + 16px);overflow-y:auto}.screen.active{display:flex}#screen-play.active{padding:calc(var(--sat) + 8px) 0 0;overflow:hidden}.hidden{display:none!important}.home-hero{text-align:center;padding:26px 0 22px}.hero-keys{display:flex;justify-content:center;gap:3px;margin-bottom:18px;animation:drop-in .7s cubic-bezier(.2,.9,.3,1.2) both}.hero-keys i{width:14px;height:44px;background:var(--text);border-radius:0 0 3px 3px;opacity:.92}.hero-keys i.b{background:#25201b;height:28px;width:10px;margin:0 -7px;z-index:1;border:1px solid #3a332b;border-top:none}@keyframes drop-in{0%{transform:translateY(-30px);opacity:0}}.brand{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:52px;letter-spacing:.01em;color:var(--amber);text-shadow:0 0 40px rgba(245,168,60,.25);animation:fade-up .6s .15s ease both}.tagline{color:var(--text-dim);margin-top:6px;font-size:15px;animation:fade-up .6s .3s ease both}@keyframes fade-up{0%{transform:translateY(10px);opacity:0}}.search-row{display:flex;gap:8px}.search-row input{flex:1;min-width:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);color:var(--text);font:inherit;padding:13px 14px;outline:none}.search-row input:focus{border-color:var(--amber-deep)}.hint{color:var(--text-dim);font-size:13px;margin:10px 2px 14px}.btn{font:inherit;font-weight:700;border:none;border-radius:var(--radius);padding:13px 18px;min-height:48px;cursor:pointer;touch-action:manipulation}.btn-primary{background:linear-gradient(180deg,var(--amber),var(--amber-deep));color:#241300}.btn-primary:active{filter:brightness(.9)}.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--line)}.btn-ghost:active{background:var(--surface-2)}.icon-btn{background:none;border:none;color:var(--text);font-size:19px;min-width:48px;min-height:44px;cursor:pointer}.link-btn{background:none;border:none;color:var(--amber);font:inherit;text-decoration:underline;cursor:pointer;min-height:44px}.status{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);color:var(--text-dim);padding:12px 14px;margin-bottom:10px}.status.error{border-color:var(--danger);color:var(--danger)}.result-list{list-style:none}.result-list li{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line)}.result-list .result-name{flex:1;min-width:0;padding:13px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-list .result-meta{color:var(--text-dim);font-size:12px;font-family:var(--font-mono)}.result-list .btn{padding:8px 14px;min-height:40px}#search-more{width:100%;margin-top:10px}.divider{border-top:1px solid var(--line);margin:20px 0}.upload-label{display:block;text-align:center;width:100%}.section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin:18px 0 8px}.diag-row{margin-top:auto;padding-top:24px;display:flex;align-items:center;gap:8px}.diag{font-size:12px;font-family:var(--font-mono);padding:4px 10px;border-radius:999px;border:1px solid var(--line);color:var(--text-dim)}.diag.ok{color:var(--green);border-color:var(--green)}.diag.bad{color:var(--danger);border-color:var(--danger)}.diag-row .link-btn{margin-left:auto}.bar{display:flex;align-items:center;gap:6px;margin:-6px -8px 8px}.bar-title{font-family:var(--font-display);font-weight:400;font-size:24px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scroll-body{flex:1;overflow-y:auto;min-height:0}.track-list{list-style:none}.track-list li{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--line)}.track-list input[type=checkbox]{width:20px;height:20px;accent-color:var(--amber)}.track-main{flex:1;min-width:0}.track-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-sub{color:var(--text-dim);font-size:12px;font-family:var(--font-mono)}.hand-badge{font:700 12px var(--font-ui);border:1px solid var(--line);background:var(--surface);color:var(--text-dim);border-radius:999px;padding:6px 12px;min-width:44px;min-height:36px;cursor:pointer}.hand-badge.right{color:var(--amber);border-color:var(--amber-deep)}.hand-badge.left{color:var(--teal);border-color:var(--teal)}.seg{display:flex;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.seg button{flex:1;font:inherit;font-weight:500;background:none;border:none;color:var(--text-dim);padding:12px 0;min-height:46px;cursor:pointer}.seg button.on{background:var(--amber);color:#241300;font-weight:700}.seg-sm button{min-height:38px;padding:8px 10px;font-size:14px}.field-row{display:flex;gap:10px}.field{flex:1;display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-dim)}.field select{font:inherit;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:11px 10px;min-height:46px}.fold-report{color:var(--text-dim);font-size:13px;margin-top:14px}.fold-warning{color:var(--amber);font-size:13px;margin-top:6px}.setup-actions{display:flex;gap:10px;padding-top:12px}.setup-actions .btn{flex:1}.play-hud{display:flex;align-items:center;height:52px;padding:0 4px}.play-title-wrap{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.2}.play-title{font-weight:700;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.play-time{color:var(--text-dim);font-size:12px;font-family:var(--font-mono)}.seek{width:100%;height:22px;accent-color:var(--amber);background:transparent;touch-action:none}.fall-area{position:relative;flex:1;min-height:0}.fall-area canvas{position:absolute;inset:0;touch-action:none}.mic-pip{position:absolute;top:8px;right:10px;width:10px;height:34px;border:1px solid var(--line);border-radius:5px;background:#161311b3;overflow:hidden;display:flex;align-items:flex-end}.mic-pip i{display:block;width:100%;height:0%;background:var(--green);transition:height 80ms linear}.mic-pip.off{opacity:.3}.banner{position:absolute;left:12px;right:12px;top:12px;background:var(--surface-2);border:1px solid var(--amber-deep);color:var(--text);border-radius:var(--radius);padding:12px 14px;text-align:center;z-index:3}.btn-skip{position:absolute;right:12px;bottom:14px;z-index:3;background:var(--surface-2);border:1px solid var(--amber);color:var(--amber);animation:fade-up .25s ease both}.chip-row{display:flex;gap:6px;justify-content:center;align-items:center;height:40px;padding:4px 8px;overflow-x:auto}.chip{font:700 13px var(--font-mono);border-radius:999px;border:1px solid var(--line);color:var(--text-dim);background:var(--surface);padding:5px 12px;white-space:nowrap}.chip.confirming{color:#241300;background:var(--amber);border-color:var(--amber);animation:chip-blink .5s ease-in-out infinite alternate}.chip.hit{color:#06200f;background:var(--green);border-color:var(--green)}.chip.left-hand{border-color:var(--teal);color:var(--teal)}.chip.left-hand.confirming{color:#032021;background:var(--teal)}@keyframes chip-blink{0%{filter:brightness(1)}to{filter:brightness(1.35)}}.keys{width:100%;height:128px;padding-bottom:var(--sab);box-sizing:content-box;background:var(--bg);touch-action:none}.tuner-body{display:flex;flex-direction:column;gap:18px;padding-top:12px}.tuner-display{display:flex;flex-direction:column;gap:16px}.tuner-note{font-family:var(--font-display);font-size:88px;text-align:center;line-height:1;color:var(--amber);min-height:96px}.cents-scale{padding:0 8px}.cents-track{position:relative;height:10px;background:var(--surface);border:1px solid var(--line);border-radius:6px}.cents-track:after{content:"";position:absolute;left:50%;top:-4px;bottom:-4px;width:2px;background:var(--line)}#cents-needle{position:absolute;top:-5px;left:50%;width:4px;height:18px;background:var(--amber);border-radius:2px;transition:left 90ms linear,background 90ms linear}.cents-labels{display:flex;justify-content:space-between;color:var(--text-dim);font-size:11px;font-family:var(--font-mono);margin-top:4px}.meter-row{display:flex;gap:14px}.meter-row label{flex:1;font-size:12px;color:var(--text-dim);display:flex;flex-direction:column;gap:4px}.meter-row progress{width:100%;height:8px;accent-color:var(--green)}.tuner-meta{display:flex;justify-content:space-between;color:var(--text-dim);font-family:var(--font-mono);font-size:13px}.results-body{margin:auto;width:100%;max-width:360px;text-align:center;display:flex;flex-direction:column;gap:22px}.results-title{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:40px;color:var(--amber)}.results-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}.results-stats div{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px}.results-stats dt{color:var(--text-dim);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.results-stats dd{font-family:var(--font-mono);font-size:30px;margin-top:2px}.results-actions{display:flex;flex-direction:column;gap:10px}.sheet-backdrop{position:fixed;inset:0;background:#0000008c;z-index:9}.sheet{position:fixed;left:0;right:0;bottom:0;z-index:10;background:var(--surface);border-top:1px solid var(--line);border-radius:18px 18px 0 0;padding:10px 18px calc(var(--sab) + 16px);max-height:80dvh;overflow-y:auto;animation:sheet-up .25s ease both}@keyframes sheet-up{0%{transform:translateY(30%);opacity:.5}}.sheet-handle{width:42px;height:4px;border-radius:2px;background:var(--line);margin:4px auto 12px}.sheet-title{font-family:var(--font-display);font-weight:400;font-size:24px;margin-bottom:8px}.set-row{display:flex;flex-direction:column;gap:6px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}.set-row>span b{color:var(--amber);font-family:var(--font-mono);font-weight:500}.set-row input[type=range]{width:100%;height:26px;accent-color:var(--amber)}.set-toggle{flex-direction:row;align-items:center;justify-content:space-between}.set-toggle input{width:22px;height:22px;accent-color:var(--amber)}.sheet-close{width:100%;margin-top:14px}.debug-panel{position:fixed;left:6px;right:6px;bottom:calc(var(--sab) + 140px);z-index:8;background:#0d0b09eb;border:1px solid var(--line);border-radius:var(--radius);padding:8px 10px;font:11px var(--font-mono);color:var(--text-dim);max-height:38dvh;overflow-y:auto}.debug-head{display:flex;gap:12px;align-items:center;color:var(--text)}.dbg-bot{margin-left:auto;display:flex;gap:4px;align-items:center}.dbg-watchers{margin-top:6px;display:flex;flex-direction:column;gap:3px}.dbg-watchers .w-armed{color:var(--text-dim)}.dbg-watchers .w-confirming{color:var(--amber)}.dbg-watchers .w-latched{color:var(--green)}.dbg-slider{display:flex;align-items:center;gap:8px;margin-top:6px}.dbg-slider input{flex:1;accent-color:var(--amber)}@media(min-width:700px){#screen-home,#screen-setup,#screen-tuner{max-width:560px;width:100%;margin:0 auto}}
