:root{--bg: #0f172a;--bg-soft: #1e293b;--bg-card: #1f2a44;--fg: #e2e8f0;--fg-dim: #94a3b8;--accent: #38bdf8;--accent-2: #f472b6;--warn: #fb923c;--ok: #4ade80;--danger: #ef4444;--white-key: #f8fafc;--white-key-pressed: #facc15;--black-key: #0b1220;--black-key-pressed: #f97316;--hint: #22d3ee;--next: #f472b6;--safe-top: env(safe-area-inset-top);--safe-bottom: env(safe-area-inset-bottom);--safe-left: env(safe-area-inset-left);--safe-right: env(safe-area-inset-right)}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Yu Gothic UI,Segoe UI,sans-serif;-webkit-tap-highlight-color:transparent;overflow-x:hidden;height:100vh;height:-webkit-fill-available;height:100dvh;width:100vw;width:100dvw;overscroll-behavior:contain}body.on-play{overflow:hidden;touch-action:none;position:fixed;inset:0}#app{min-height:100vh;min-height:100dvh}body.on-play #app{height:100dvh;height:-webkit-fill-available}button{font-family:inherit;font-size:1rem;cursor:pointer}a{color:var(--accent);text-decoration:none}.landing{padding:1.2rem 1rem 2rem;max-width:720px;margin:0 auto}.landing-hero{text-align:center;padding:1.5rem 1rem 2rem;background:linear-gradient(180deg,#1e293b,#0f172a);border-radius:16px;margin-bottom:1.5rem}.landing-hero h1{font-size:2.5rem;margin:.6rem 0 .4rem}.landing-hero .tagline{color:var(--fg-dim);margin:0 0 1.2rem}.logo-mark{display:inline-flex;gap:2px;padding:8px;background:#fff;border-radius:8px}.logo-mark .key.w{width:12px;height:36px;background:#fff;border-right:1px solid #cbd5e1}.btn-primary{background:var(--accent);color:#0f172a;border:0;padding:.85rem 1.6rem;border-radius:9999px;font-weight:700;box-shadow:0 4px 12px #38bdf84d}.btn-primary:active{transform:translateY(1px)}.btn-secondary{background:var(--bg-card);color:var(--fg);border:1px solid #334155;padding:.7rem 1.2rem;border-radius:8px}.install-block,.features-block,.usage-block{background:var(--bg-card);padding:1rem 1.2rem;border-radius:12px;margin-bottom:1rem}.install-grid,.features-grid{display:grid;gap:.8rem;grid-template-columns:1fr}@media (min-width: 700px){.install-grid,.features-grid{grid-template-columns:1fr 1fr}}.install-grid article,.features-grid article{background:var(--bg-soft);padding:.9rem 1rem;border-radius:8px}.install-grid h3,.features-grid h3{margin:0 0 .4rem;color:var(--accent)}.install-grid ol{margin:0;padding-left:1.2rem}.install-grid ol li{margin-bottom:.3rem}.note{color:var(--fg-dim);font-size:.9rem;margin-top:.6rem}.usage-block ul,.usage-block ol{margin:0;padding-left:1.2rem}.usage-block li{margin-bottom:.4rem;line-height:1.55}.usage-block p{line-height:1.6;margin:.4rem 0 .6rem}.usage-block code,.hint-box code{background:#0b1220;padding:.1rem .4rem;border-radius:4px;color:var(--accent);font-size:.95em}.landing-footer{text-align:center;margin-top:1.5rem}.copyright{color:var(--fg-dim);font-size:.8rem;margin-top:.6rem}.play-screen{display:flex;flex-direction:column;height:100vh;height:-webkit-fill-available;height:100dvh;padding-left:var(--safe-left);padding-right:var(--safe-right);overflow:hidden}.play-header{display:flex;align-items:center;gap:.5rem;padding:calc(.4rem + var(--safe-top)) .7rem .4rem;background:var(--bg-soft);border-bottom:1px solid #1e293b;flex-shrink:0}.icon-btn{background:transparent;border:0;color:var(--fg);font-size:1.4rem;padding:.3rem .5rem}.mode-tabs{display:flex;background:#0b1220;border-radius:9999px;padding:2px}.mode-tab{background:transparent;border:0;color:var(--fg-dim);padding:.4rem .85rem;border-radius:9999px;font-size:.9rem}.mode-tab.active{background:var(--accent);color:#0f172a;font-weight:700}.now-playing{margin-left:auto;font-size:.78rem;color:var(--fg-dim);text-align:right;max-width:50%;line-height:1.3}.np-row{display:flex;gap:.4rem;justify-content:flex-end}.np-label{color:var(--accent);font-weight:600}.octave-bar{display:flex;gap:.4rem;padding:.4rem .7rem;align-items:center;background:var(--bg-soft);flex-shrink:0;flex-wrap:wrap}.oct-btn{background:var(--bg-card);color:var(--fg);border:1px solid #334155;border-radius:6px;padding:.35rem .75rem;font-size:.85rem}.oct-btn.active{background:var(--accent);color:#0f172a;border-color:var(--accent);font-weight:700}.oct-btn.flash{border-color:var(--hint);box-shadow:0 0 #22d3eeb3;animation:pulse-oct 1.1s infinite;color:var(--hint)}@keyframes pulse-oct{0%,to{box-shadow:0 0 #22d3eeb3}50%{box-shadow:0 0 0 8px #22d3ee00}}.cursor-info{margin-left:auto;font-size:.85rem;color:var(--accent-2);font-weight:600}.keyboard{flex:1 1 auto;min-height:140px;position:relative;background:#0b1220;display:grid;grid-template-rows:1fr;padding:.5rem;user-select:none;touch-action:none;overflow:hidden}.whites{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;height:100%;position:relative;z-index:1;min-width:0}.blacks{position:absolute;top:.5rem;left:.5rem;right:.5rem;display:grid;grid-template-columns:repeat(7,1fr);gap:0;height:60%;pointer-events:none;z-index:2;min-width:0}.key{border-radius:6px 6px 8px 8px;transition:background-color .05s,transform .05s;display:flex;align-items:flex-end;justify-content:center;padding-bottom:.6rem}.key.white{background:var(--white-key);color:#475569;box-shadow:inset 0 -4px #cbd5e1;min-width:0}.key.white.pressed{background:var(--white-key-pressed);transform:translateY(2px);box-shadow:inset 0 -1px #ca8a04}.key.white.hint{background:linear-gradient(180deg,#cffafe,#67e8f9);animation:pulse-hint 1.2s infinite}.key.white.next{background:linear-gradient(180deg,#fce7f3,#f9a8d4)}.key.black{pointer-events:auto;background:var(--black-key);color:#f8fafc;box-shadow:inset 0 -4px #000;align-self:start;height:100%;justify-self:end;width:70%;margin-right:-35%;border-radius:0 0 6px 6px;min-width:0}.key.black.pressed{background:var(--black-key-pressed);transform:translateY(2px);box-shadow:inset 0 -1px #7c2d12}.key.black.hint{background:linear-gradient(180deg,#0e7490,#06b6d4);animation:pulse-hint 1.2s infinite}.key.black.next{background:linear-gradient(180deg,#831843,#db2777)}.key-label{font-size:.85rem;font-weight:600;opacity:.6}@keyframes pulse-hint{0%,to{box-shadow:0 0 #22d3ee99}50%{box-shadow:0 0 0 12px #22d3ee00}}.bottom-controls{display:grid;grid-template-columns:repeat(3,minmax(0,auto)) minmax(0,1fr) minmax(0,1fr);gap:.4rem;padding:.5rem .7rem;background:var(--bg-soft);align-items:center;flex-shrink:0}.ctl-btn{background:var(--bg-card);color:var(--fg);border:1px solid #334155;border-radius:6px;padding:.4rem .7rem;font-size:.85rem;white-space:nowrap}.ctl-btn.active{background:var(--accent-2);color:#0f172a;border-color:var(--accent-2)}.slider{display:flex;flex-direction:column;gap:2px;font-size:.7rem;color:var(--fg-dim);min-width:0}.slider input{width:100%;min-width:0}.bottom-nav{display:grid;grid-template-columns:repeat(4,1fr);gap:.3rem;padding:.4rem .4rem calc(.4rem + var(--safe-bottom));background:var(--bg);border-top:1px solid #1e293b;flex-shrink:0}.bottom-nav a{display:block;text-align:center;background:var(--bg-card);padding:.55rem 0;border-radius:6px;font-size:.85rem;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-screen{padding:0;min-height:100vh;min-height:100dvh;padding-left:var(--safe-left);padding-right:var(--safe-right);display:flex;flex-direction:column}.list-header{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:.6rem;padding:calc(.4rem + var(--safe-top)) .8rem .6rem;background:var(--bg-soft);border-bottom:1px solid #1e293b}.list-header h2{margin:0;font-size:1.1rem}.list-count{margin-left:auto;color:var(--fg-dim);font-size:.85rem}.cat-tabs{display:flex;gap:.3rem;padding:.5rem .7rem;overflow-x:auto;background:var(--bg-soft);white-space:nowrap}.cat-tab{background:var(--bg-card);color:var(--fg);border:1px solid #334155;border-radius:9999px;padding:.35rem .85rem;font-size:.85rem;flex-shrink:0}.cat-tab.active{background:var(--accent);color:#0f172a;border-color:var(--accent);font-weight:700}.preset-list,.song-list{list-style:none;margin:0;padding:.4rem .5rem 7rem;flex:1}.preset-item,.song-item{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.7rem .8rem;background:var(--bg-card);margin-bottom:.4rem;border-radius:8px;border:1px solid transparent}.preset-item.selected,.song-item.selected{border-color:var(--accent);background:#1e3a5f}.preset-name{font-size:.95rem}.preset-actions,.song-actions{display:flex;gap:.3rem}.btn-mini{background:var(--bg-soft);color:var(--fg);border:1px solid #334155;padding:.3rem .6rem;border-radius:6px;font-size:.8rem}.btn-mini.danger{color:var(--danger);border-color:var(--danger)}.btn-mini.danger.armed{background:var(--danger);color:#fff;animation:pulse-arm .6s infinite}.song-item.arming{border-color:var(--danger)}@keyframes pulse-arm{0%,to{opacity:1}50%{opacity:.7}}.song-info{flex:1;min-width:0}.song-title{font-weight:600}.song-meta{color:var(--fg-dim);font-size:.78rem;margin-top:2px}.empty{padding:1.5rem;text-align:center;color:var(--fg-dim)}.list-footer{position:fixed;bottom:0;left:0;right:0;padding:.7rem calc(.8rem + var(--safe-right)) calc(.7rem + var(--safe-bottom)) calc(.8rem + var(--safe-left));background:var(--bg-soft);border-top:1px solid #1e293b;display:flex;gap:.5rem}.list-footer .btn-primary{flex:1}.form-block{padding:1rem 1rem 7rem;max-width:720px;margin:0 auto;width:100%}.form-label{display:block;margin:1rem 0 .4rem;color:var(--fg-dim);font-size:.85rem}.form-block input[type=text],.form-block textarea{width:100%;background:var(--bg-card);color:var(--fg);border:1px solid #334155;border-radius:8px;padding:.6rem .8rem;font-family:inherit;font-size:1rem}.form-block textarea{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;min-height:8rem;resize:vertical}.hint-box{background:var(--bg-card);border-radius:8px;padding:.6rem .9rem;margin-top:.6rem}.hint-box summary{cursor:pointer;color:var(--accent);font-weight:600}.hint-box ul{margin:.5rem 0 0;padding-left:1.2rem;line-height:1.6}.parse-status{margin-top:.6rem;color:var(--fg-dim);font-size:.85rem}.parse-status .warn{color:var(--warn)}.form-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.form-actions .btn-primary{flex:1}.toast-container{position:fixed;left:50%;bottom:calc(1.2rem + var(--safe-bottom));transform:translate(-50%);display:flex;flex-direction:column-reverse;gap:.4rem;z-index:10000;pointer-events:none}.toast{background:#0b1220;color:var(--fg);border:1px solid #334155;padding:.7rem 1rem;border-radius:9999px;font-size:.9rem;box-shadow:0 8px 24px #0006;opacity:0;transform:translateY(8px);transition:opacity .18s ease,transform .18s ease}.toast.show{opacity:1;transform:translateY(0)}.toast-success{border-color:var(--ok);color:var(--ok)}.toast-error{border-color:var(--danger);color:var(--danger)}.landing{padding-top:calc(.6rem + var(--safe-top));padding-bottom:calc(2rem + var(--safe-bottom));padding-left:calc(1rem + var(--safe-left));padding-right:calc(1rem + var(--safe-right))}@media (max-height: 520px){.play-header{padding-top:calc(.2rem + var(--safe-top));padding-bottom:.2rem;gap:.4rem}.play-header h1,.play-header h2{font-size:.9rem}.mode-tab{padding:.25rem .6rem;font-size:.8rem}.now-playing{font-size:.7rem;line-height:1.15}.octave-bar{padding:.25rem .6rem}.oct-btn{padding:.2rem .6rem;font-size:.78rem}.cursor-info{font-size:.78rem}.keyboard{padding:.3rem;min-height:110px}.key-label{font-size:.7rem;padding:0}.key{padding-bottom:.3rem}.bottom-controls{padding:.3rem .5rem;gap:.3rem}.ctl-btn{padding:.3rem .55rem;font-size:.78rem}.slider{font-size:.62rem}.bottom-nav{padding:.25rem .3rem calc(.25rem + var(--safe-bottom));gap:.25rem}.bottom-nav a{padding:.4rem 0;font-size:.78rem}}@media (max-height: 420px){.now-playing{font-size:.65rem;max-width:55%;line-height:1.1}.np-row{display:inline;gap:0}.np-row+.np-row:before{content:" ／ ";color:var(--fg-dim)}.np-label{margin-right:.15rem}.keyboard{min-height:90px}}@media (max-width: 380px){.bottom-controls{grid-template-columns:repeat(3,minmax(0,1fr))}.bottom-controls .slider{grid-column:span 3 / span 3;flex-direction:row;align-items:center;gap:.4rem}.bottom-controls .slider span{flex-shrink:0}}.cat-tabs{padding-left:calc(.7rem + var(--safe-left));padding-right:calc(.7rem + var(--safe-right))}
