@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;600&family=JetBrains+Mono:wght@400;600&display=swap";:root{color:#e7eaf2;background:radial-gradient(circle at 20% 20%,#1f3158 0,#0d1426,#050812 90%);font-family:Space Grotesk,Segoe UI,sans-serif;line-height:1.6;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--accent: #7cf2c2;--ink: #0f1624;--panel: rgba(255, 255, 255, .04);--border: rgba(255, 255, 255, .08);--muted: #a7b1c5}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 80% 10%,rgba(124,242,194,.08),transparent 28%),radial-gradient(circle at 10% 90%,rgba(93,155,255,.08),transparent 32%),var(--ink);color:#e7eaf2}#app{padding:2.5rem 1.5rem 3rem;display:flex;justify-content:center}.shell{width:min(960px,100%);background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:2rem;box-shadow:0 25px 70px #00000059,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.hero{margin-bottom:1.5rem}.eyebrow{text-transform:uppercase;letter-spacing:.25em;font-size:.8rem;color:var(--muted);margin:0 0 .4rem}h1{margin:0 0 .5rem;font-size:clamp(1.9rem,3vw,2.4rem)}.lede{margin:0;color:var(--muted);max-width:720px}.panel{background:linear-gradient(120deg,#7cf2c214,#ffffff05);border:1px solid var(--border);border-radius:14px;padding:1.5rem}.visuals{margin-top:.75rem}.visual-layout{display:grid;grid-template-columns:minmax(0,1.68fr) minmax(0,1fr);gap:1.25rem;align-items:start}.visual-layout>*{min-width:0}.controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.primary{border:1px solid transparent;background:linear-gradient(135deg,#7cf2c2,#5dbbff);color:#0b1221;border-radius:12px;padding:.75rem 1.4rem;font-size:1rem;font-weight:700;letter-spacing:.01em;box-shadow:0 14px 30px #7cf2c240;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.primary:hover{transform:translateY(-1px);box-shadow:0 18px 36px #5dbbff40}.primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.status{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-weight:500}.dot{width:11px;height:11px;border-radius:999px;display:inline-block;box-shadow:0 0 0 1px #ffffff1f}.dot-idle{background:#5c6474}.dot-pending{background:#ffd166;animation:pulse 1s ease-in-out infinite}.dot-active{background:#7cf2c2;box-shadow:0 0 0 6px #7cf2c22e}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.details{margin-top:1rem;background:#0508128c;border:1px solid var(--border);border-radius:12px;padding:1rem}.ndjson-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.ndjson-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;min-width:0;max-width:100%}.ndjson-toggle{border:1px solid var(--border);background:#ffffff0f;color:#e7eaf2;border-radius:10px;padding:.35rem .85rem;cursor:pointer;font-weight:700;letter-spacing:.02em;transition:border-color .12s ease,background .12s ease,transform .12s ease}.ndjson-toggle:hover{border-color:#7cf2c299;background:#ffffff1a;transform:translateY(-1px)}.ndjson-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.ndjson-error{display:inline-flex;align-items:center;gap:.55rem;padding:.3rem .65rem;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:linear-gradient(120deg,#ff6b6b33,#ffb4b414);color:#ffd5dd;font-weight:700;letter-spacing:.02em}.ndjson-error-label{font-size:.9rem;min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ndjson-error-button{border:1px solid rgba(255,255,255,.2);background:#ffffff0a;color:#ffd5dd;border-radius:10px;padding:.3rem .75rem;cursor:pointer;font-weight:700;letter-spacing:.02em;transition:border-color .12s ease,background .12s ease,transform .12s ease}.ndjson-error-button:hover{border-color:#ffb4c2;background:#ffffff14;transform:translateY(-1px)}.ndjson-error-button:focus-visible{outline:2px solid #ffb4c2;outline-offset:2px}.ndjson-error-details{margin:.35rem 0 .6rem}.ndjson-container{margin-top:.75rem;display:flex;flex-direction:column;gap:.35rem}.ndjson-container[hidden],.ndjson-error[hidden],.ndjson-error-details[hidden]{display:none}.dot-error{background:#ff6b6b;box-shadow:0 0 0 6px #ff6b6b38}.label{margin:0 0 .35rem;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--muted)}pre{margin:0;background:#0f1624d9;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.9rem;font-family:JetBrains Mono,SFMono-Regular,Menlo,monospace;color:#d8e2ff;white-space:pre-wrap;word-break:break-word}.note{margin:.6rem 0 0;color:var(--muted);font-size:.95rem}.visual-grid{display:grid;gap:.75rem}.visual-group{display:grid;gap:.5rem}.visual-label{margin:0;font-size:.85rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-weight:700}.visuals canvas{width:min(92%,520px);border:1px solid var(--border);border-radius:10px;background:#0f1624d9}.visual-timing{margin:-.2rem 0 .35rem;color:var(--muted);font-size:.82rem;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.repo-link{position:fixed;left:14px;bottom:14px;color:#e7eaf2;text-decoration:none;opacity:.6;font-weight:700;font-size:.95rem;background:#0f16248c;border:1px solid var(--border);border-radius:12px;padding:.55rem .8rem;box-shadow:0 12px 30px #0000004d;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:opacity .14s ease,transform .14s ease}.repo-link:hover{opacity:.95;transform:translateY(-1px)}.note-controls{display:flex;flex-direction:column;gap:.45rem;align-items:flex-start}.note-controls-header{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;width:100%}.note-grid-title{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}.note-grid-actions{display:flex;flex-wrap:wrap;gap:.35rem}.note-grid-button{border:1px solid var(--border);background:#ffffff0f;color:#e7eaf2;border-radius:9px;padding:.35rem .7rem;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:border-color .12s ease,background .12s ease,transform .12s ease}.note-grid-button:hover{border-color:#7cf2c299;background:#ffffff1f;transform:translateY(-1px)}.note-grid-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.field{display:flex;flex-direction:column;gap:.35rem;min-width:140px}.text-input{width:100%;background:#0f1624d9;border:1px solid var(--border);border-radius:8px;color:#e7eaf2;padding:.45rem .55rem;font-size:.95rem}.text-input:focus{outline:1px solid var(--accent);border-color:var(--accent)}.note-grid{display:flex;flex-direction:column;gap:.4rem;overflow-x:auto;padding:.1rem 0 .25rem;width:100%}.tone-section{width:100%;border:1px solid var(--border);border-radius:10px;padding:.65rem .75rem;background:#ffffff05}.tone-section-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.tone-section-header-main{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.tone-toggle{border:1px solid var(--border);background:#7cf2c21a;color:#e7eaf2;border-radius:10px;padding:.5rem .9rem;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:border-color .12s ease,background .12s ease,transform .12s ease}.tone-toggle:hover{border-color:#7cf2c299;transform:translateY(-1px)}.tone-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.tone-random-button{padding:.42rem .85rem}.tone-status{font-size:.85rem;color:var(--muted)}.tone-status-ok{color:var(--accent)}.tone-status-error{color:#ff9c9c}.tone-body{display:grid;gap:.6rem;margin-top:.6rem}.tone-body.collapsed{display:none}.random-section{border:1px dashed var(--border);border-radius:10px;padding:.6rem .65rem;background:#ffffff05}.random-header{display:flex;justify-content:space-between;align-items:center}.random-toggle{border:1px solid var(--border);background:#ffffff0a;color:#e7eaf2;border-radius:10px;padding:.35rem .9rem;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:border-color .12s ease,background .12s ease,transform .12s ease}.random-toggle:hover{border-color:#7cf2c299;background:#ffffff14;transform:translateY(-1px)}.random-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.random-body{display:grid;gap:.45rem;margin-top:.5rem}.random-body.collapsed{display:none}.random-actions{display:flex;flex-wrap:wrap;gap:.4rem}.random-button{border:1px solid var(--border);background:#7cf2c224;color:#e7eaf2;border-radius:9px;padding:.35rem .75rem;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:border-color .12s ease,background .12s ease,transform .12s ease}.random-button.secondary{background:#ffffff0d}.random-button:hover{border-color:#7cf2c299;background:#ffffff1f;transform:translateY(-1px)}.random-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.random-error{margin:0;padding:.4rem .6rem;border:1px solid rgba(255,255,255,.2);border-radius:9px;color:#ffd5dd;background:linear-gradient(120deg,#ff6b6b2e,#ffb4b414);font-weight:700;letter-spacing:.02em;font-size:.9rem}.tone-textarea{min-height:92px;font-family:JetBrains Mono,SFMono-Regular,Menlo,monospace;resize:vertical}.group-label{margin:.25rem 0 .1rem;font-size:.82rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-weight:700}.note-grid-row{display:grid;grid-template-columns:64px repeat(16,minmax(24px,1fr));gap:.24rem;align-items:center}.note-grid-header{color:var(--muted);font-size:.8rem}.note-row-label{display:flex;align-items:center}.note-row-label .text-input{text-align:center;font-weight:700;letter-spacing:.06em}.note-step-label{text-align:center;font-size:.8rem;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;align-items:center;line-height:1.2}.note-step-label:hover{color:#7cf2c2cc}.note-step-label:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 2px #7cf2c240;border-radius:4px}.note-step-label.rest{color:#ff9c9c}.note-step-label.rest:after{content:"R";font-size:.6rem;line-height:1}.note-step-label.tie{color:#5dbbffe6}.note-step-label.tie:after{content:"~";font-size:.75rem;line-height:1}.note-cell{height:36px;border:1px solid var(--border);background:#ffffff08;border-radius:8px;cursor:pointer;color:#e7eaf2;transition:border-color .12s ease,background .12s ease,box-shadow .12s ease}.note-cell:hover{border-color:#7cf2c299}.note-cell:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 2px #7cf2c240}.note-cell.active{background:linear-gradient(135deg,#7cf2c22e,#5dbbff2e);border-color:#7cf2c2e6;box-shadow:0 0 0 1px #7cf2c233}.note-step-label.playing{color:var(--accent);font-weight:700}.note-cell.playing{background:#ffffff12;border-color:#7cf2c266}.note-cell.active.playing{background:linear-gradient(135deg,#7cf2c261,#5dbbff61);border-color:var(--accent);box-shadow:0 0 12px #7cf2c259,0 0 0 1px #7cf2c24d}@media(max-width:720px){.shell{padding:1.5rem}.controls{flex-direction:column;align-items:flex-start}.status{font-size:.95rem}.visual-layout{grid-template-columns:1fr}}
