:root{--bg: #0a0a0a;--fg: #e8e2d5;--fg-dim: #8a8478;--accent: #d4b78b;--panel: #141414;--line: #2a2a2a;--danger: #c45c5c;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%;background:var(--bg);color:var(--fg);overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (max-width: 640px),(max-height: 720px){.player{padding:max(env(safe-area-inset-top),.5rem) max(env(safe-area-inset-right),.75rem) max(env(safe-area-inset-bottom),1.5rem) max(env(safe-area-inset-left),.75rem)}.player-stage{gap:1.25rem;padding:.5rem 0 1.5rem}.visualiser{width:min(80vw,320px);height:min(80vw,320px);max-height:50vh}}button{font:inherit;background:transparent;color:var(--fg);border:1px solid var(--line);border-radius:999px;padding:.5em 1em;cursor:pointer;transition:background .15s,border-color .15s}button:hover{background:var(--panel);border-color:var(--fg-dim)}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.player{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem 0;background:radial-gradient(ellipse at center,#14110d 0%,var(--bg) 70%)}.player-stage{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.visualiser-stage{position:relative;display:grid;place-items:center}.visualiser{width:min(70vw,480px);height:min(70vw,480px);max-height:60vh;display:block}.visualiser-stage-score .visualiser-score{width:min(90vw,640px);height:min(38vw,280px);max-height:40vh}.visualiser-mode-toggle{position:absolute;top:8px;right:8px;width:32px;height:32px;padding:0;border-radius:50%;display:grid;place-items:center;background:#14110d73;border:1px solid var(--fg-dim);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);cursor:pointer;color:var(--fg-dim);transition:background .15s,border-color .15s,color .15s,transform .08s}.visualiser-mode-toggle:hover{background:#1e1a1499;border-color:var(--fg);color:var(--fg)}.visualiser-mode-toggle:active{transform:scale(.94)}.visualiser-mode-toggle svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.visualiser-stage-score .play-button-overlay{top:8px;left:8px;transform:none;width:56px;height:56px}.visualiser-stage-score .play-button-overlay:active{transform:scale(.97)}.visualiser-stage-score .play-button-overlay svg{width:22px;height:22px}.play-button-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;border-radius:50%;display:grid;place-items:center;padding:0;background:#14110d80;border:1px solid var(--fg-dim);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);cursor:pointer;transition:background .15s,border-color .15s,transform .08s}.play-button-overlay:hover{background:#1e1a14a6;border-color:var(--fg)}.play-button-overlay:active{transform:translate(-50%,-50%) scale(.97)}.play-button-overlay svg{width:28px;height:28px;fill:var(--fg)}.transport-controls{display:flex;align-items:center;gap:1rem}.play-button{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--fg-dim)}.play-button svg{width:24px;height:24px;fill:var(--fg)}.settings-button{min-width:36px;height:36px;border-radius:999px;display:grid;place-items:center;padding:0 .6em}.settings-button svg{width:16px;height:16px;stroke:var(--fg-dim);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.settings-button.is-active{border-color:var(--accent);color:var(--accent)}.settings-button.is-active svg{stroke:var(--accent)}.timer-readout{font-size:.78rem;letter-spacing:.04em;color:var(--accent);font-variant-numeric:tabular-nums}.timer-control{position:relative;display:inline-flex}.timer-menu{position:absolute;bottom:calc(100% + .6rem);left:50%;transform:translate(-50%);background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:.35rem;display:flex;flex-direction:column;gap:.2rem;min-width:110px;box-shadow:0 8px 24px #00000080;z-index:5}.timer-menu-item{background:transparent;border:1px solid transparent;border-radius:6px;color:var(--fg);font:inherit;font-size:.8rem;letter-spacing:.05em;padding:.4em .8em;text-align:left;cursor:pointer}.timer-menu-item:hover{border-color:var(--fg-dim);background:var(--bg)}.timer-menu-item.is-cancel{margin-top:.2rem;border-top:1px solid var(--line);color:var(--fg-dim);font-size:.75rem;border-radius:0 0 6px 6px}.timer-menu-item.is-cancel:hover{color:var(--danger);border-color:transparent;border-top-color:var(--line)}.section-display{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-dim);min-height:1em}.now-playing{width:min(80vw,360px);display:flex;flex-direction:column;gap:.45rem}.now-playing-text{display:flex;align-items:baseline;gap:.55rem;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-dim);justify-content:center}.now-playing-key{color:var(--fg);font-variant-numeric:tabular-nums}.now-playing-sep{opacity:.5}.now-playing-section{color:var(--fg-dim)}.now-playing-section-idle{font-style:italic}.tension-bar{width:100%;height:2px;background:var(--line);border-radius:999px;overflow:hidden}.tension-bar-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .4s ease-out}.mode-switch{display:inline-flex;border:1px solid var(--line);border-radius:999px;padding:3px;gap:2px}.mode-switch-button{border:none;background:transparent;color:var(--fg-dim);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:.35em 1.1em;border-radius:999px;cursor:pointer;transition:background .15s,color .15s}.mode-switch-button:hover{color:var(--fg);background:var(--panel)}.mode-switch-button.is-active{color:var(--bg);background:var(--accent)}.preset-group{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:100%}.preset-group-label{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-dim);opacity:.7}.mood-button-era{margin-left:.4em;font-size:.62rem;letter-spacing:.04em;opacity:.55;font-variant-numeric:tabular-nums;text-transform:none}.mood-button.is-active .mood-button-era{opacity:.7}.main-fx-stack{display:flex;flex-direction:column;align-items:stretch;gap:.5rem;width:min(70vw,360px)}.main-fx-stack .reverb-control{width:100%}@media (max-width: 640px),(max-height: 720px){.settings-button{min-width:44px;min-height:44px}.play-button-overlay{width:72px;height:72px}.feedback-button{padding:.5em .95em}.now-playing,.main-fx-stack{width:min(92vw,360px)}}.mood-row{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem;max-width:min(70vw,480px)}.feedback-row{display:flex;gap:.5rem;align-items:center}.reverb-control{width:min(70vw,360px);display:flex;flex-direction:column;gap:.5rem}.thin-row{display:grid;grid-template-columns:5.5em 1fr auto auto;align-items:center;gap:.7rem;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-dim)}.thin-label{color:var(--fg-dim)}.thin-value{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.68rem;letter-spacing:0;text-transform:none;font-variant-numeric:tabular-nums;color:var(--fg-dim);min-width:3em;text-align:right}.thin-range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:1px;background:var(--line);outline:none;margin:0;cursor:pointer}.thin-range::-webkit-slider-runnable-track{height:1px;background:var(--line)}.thin-range::-moz-range-track{height:1px;background:var(--line)}.thin-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:10px;height:10px;border-radius:50%;background:var(--accent);border:none;margin-top:-4.5px;transition:transform .08s}.thin-range::-moz-range-thumb{width:10px;height:10px;border:none;border-radius:50%;background:var(--accent);transition:transform .08s}.thin-range:hover::-webkit-slider-thumb,.thin-range:focus-visible::-webkit-slider-thumb{transform:scale(1.2)}.thin-range:hover::-moz-range-thumb,.thin-range:focus-visible::-moz-range-thumb{transform:scale(1.2)}.reverb-expand{background:transparent;border:1px solid var(--line);border-radius:999px;width:22px;height:22px;padding:0;display:grid;place-items:center;color:var(--fg-dim);cursor:pointer;transition:border-color .15s,color .15s}.reverb-expand:hover{color:var(--fg);border-color:var(--fg-dim)}.reverb-expand svg{width:10px;height:10px}.reverb-expand-body{display:flex;flex-direction:column;gap:.5rem;padding-top:.4rem;margin-top:.1rem;border-top:1px solid var(--line)}.thin-select-row{grid-template-columns:5.5em 1fr auto}.thin-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid var(--line);border-radius:999px;color:var(--fg);font:inherit;font-size:.7rem;letter-spacing:.06em;padding:.25em 1.8em .25em .7em;cursor:pointer;text-transform:lowercase;background-image:linear-gradient(45deg,transparent 50%,var(--fg-dim) 50%),linear-gradient(135deg,var(--fg-dim) 50%,transparent 50%);background-position:calc(100% - 14px) 50%,calc(100% - 10px) 50%;background-size:4px 4px,4px 4px;background-repeat:no-repeat;transition:border-color .15s,background-color .15s}.thin-select:hover{border-color:var(--fg-dim)}.thin-select option{background:var(--panel);color:var(--fg)}.feedback-button{display:inline-flex;align-items:center;gap:.4rem;padding:.35em .85em;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--fg-dim);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:border-color .15s,color .15s,background .15s,transform .08s}.feedback-button svg{width:14px;height:14px;fill:currentColor}.feedback-button:disabled{opacity:.35;cursor:not-allowed}.feedback-button:not(:disabled):hover{color:var(--fg);border-color:var(--fg-dim)}.feedback-button.feedback-like:not(:disabled):hover{color:#8bc99a;border-color:#8bc99a}.feedback-button.feedback-dislike:not(:disabled):hover{color:var(--danger);border-color:var(--danger)}.feedback-key{display:inline-block;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.62rem;letter-spacing:0;padding:2px 6px;border:1px solid currentColor;border-radius:3px;opacity:1;line-height:1}@media (hover: none) and (pointer: coarse){.feedback-key{display:none}}@keyframes feedback-flash-like{0%{transform:scale(1);background:transparent;border-color:var(--line);color:var(--fg-dim)}35%{transform:scale(1.12);background:#8bc99a40;border-color:#8bc99a;color:var(--fg)}to{transform:scale(1);background:transparent;border-color:var(--line);color:var(--fg-dim)}}@keyframes feedback-flash-dislike{0%{transform:scale(1);background:transparent;border-color:var(--line);color:var(--fg-dim)}35%{transform:scale(1.12);background:#c45c5c40;border-color:var(--danger);color:var(--fg)}to{transform:scale(1);background:transparent;border-color:var(--line);color:var(--fg-dim)}}.feedback-button.feedback-like.is-flashing{animation:feedback-flash-like .28s ease-out}.feedback-button.feedback-dislike.is-flashing{animation:feedback-flash-dislike .28s ease-out}.feedback-controls{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--line)}.feedback-controls .meta{font-size:.72rem;color:var(--fg-dim);margin:0 0 .4rem}.danger-button{color:var(--danger);border-color:var(--line)}.danger-button:not(:disabled):hover{background:#c45c5c1a;border-color:var(--danger)}.mood-button{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-dim);padding:.3em .85em;border-radius:999px;border:1px solid var(--line);background:transparent;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.mood-button:hover{color:var(--fg);border-color:var(--fg-dim)}.mood-button.is-active{color:var(--bg);background:var(--accent);border-color:var(--accent)}.piano-select-wrap{position:relative;display:inline-flex;align-items:center}.piano-select-wrap:after{content:"▾";position:absolute;right:.6rem;pointer-events:none;color:var(--fg-dim);font-size:.7rem}.piano-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;border:1px solid var(--line);color:var(--fg);font:inherit;font-size:.8rem;letter-spacing:.05em;padding:.4em 1.8em .4em .9em;border-radius:999px;cursor:pointer;transition:border-color .15s,background .15s}.piano-select:hover{border-color:var(--fg-dim);background:var(--panel)}.piano-select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.piano-select option{background:var(--panel);color:var(--fg)}.loading-status{font-size:.75rem;color:var(--fg-dim);margin-top:.5em}.param-panel{position:fixed;top:0;right:0;bottom:0;width:min(440px,100vw);background:var(--panel);border-left:1px solid var(--line);overflow-y:auto;padding:1.25rem;z-index:10;box-shadow:-8px 0 24px #0006;transform:translate(100%);transition:transform .25s ease-out}.param-panel.open{transform:translate(0)}.param-panel h1{font-size:.95rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:0 0 1.25rem}.param-panel h2{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-dim);margin:1.5rem 0 .5rem;padding-bottom:.25rem;border-bottom:1px solid var(--line)}.param-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.75rem;padding:.35rem 0;font-size:.85rem}.param-row label{color:var(--fg)}.param-row .meta{color:var(--fg-dim);font-size:.7rem;font-variant-numeric:tabular-nums}.param-row input[type=range]{grid-column:1 / -1;width:100%;accent-color:var(--accent)}.param-row select,.param-row input[type=number],.param-row input[type=text]{background:var(--bg);color:var(--fg);border:1px solid var(--line);border-radius:4px;padding:4px 6px;font:inherit;width:110px}.param-row input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.param-panel-close{position:sticky;top:0;float:right;margin:-.5rem -.5rem 0 0;background:var(--panel);border:1px solid var(--line);border-radius:50%;width:30px;height:30px;padding:0;display:grid;place-items:center}.param-panel-close svg{width:14px;height:14px;stroke:var(--fg);stroke-width:1.75;stroke-linecap:round;fill:none}.manual-panel{position:fixed;top:0;left:0;bottom:0;width:min(520px,100vw);background:var(--panel);border-right:1px solid var(--line);overflow-y:auto;padding:1.25rem 1.5rem;z-index:10;box-shadow:8px 0 24px #0006;transform:translate(-100%);transition:transform .25s ease-out;line-height:1.55}.manual-panel.open{transform:translate(0)}.manual-panel h1{font-size:.95rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:0 0 1.25rem}.manual-panel h2{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin:2rem 0 .6rem;padding-bottom:.3rem;border-bottom:1px solid var(--line)}.manual-panel h3{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-dim);margin:1.2rem 0 .4rem}.manual-panel p{font-size:.88rem;color:var(--fg);margin:0 0 .85rem}.manual-panel ul{margin:.4rem 0 .9rem;padding-left:1.1rem}.manual-panel li{font-size:.85rem;color:var(--fg);margin-bottom:.45rem}.manual-panel li ul{margin:.3rem 0 .4rem}.manual-panel strong{color:var(--accent);font-weight:600}.manual-panel em{color:var(--fg);font-style:italic}.manual-panel-close{position:sticky;top:0;float:right;margin:-.5rem -.75rem 0 0;background:var(--panel);border:1px solid var(--line);border-radius:50%;width:30px;height:30px;padding:0;display:grid;place-items:center;cursor:pointer;z-index:1}.manual-panel-close svg{width:14px;height:14px;stroke:var(--fg);stroke-width:1.75;stroke-linecap:round;fill:none}.preset-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.preset-row button{font-size:.75rem;padding:.3em .8em}.matrix{display:grid;grid-template-columns:auto repeat(7,1fr);gap:2px;font-size:.65rem;margin:.5rem 0}.matrix-cell{background:var(--bg);padding:4px;text-align:center;font-variant-numeric:tabular-nums}.matrix-header{color:var(--fg-dim);font-weight:600;background:transparent}.matrix-cell input{width:100%;background:transparent;border:none;color:var(--fg);font:inherit;text-align:center;padding:0}.matrix-cell input:focus{outline:1px solid var(--accent)}
