*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #080808;--surface: #0f0f0f;--card: #151515;--border: #242424;--border-bright: #333333;--accent: #ff2d2d;--accent-dim: #8a1a1a;--accent2: #ff7500;--accent3: #b8ff2e;--text: #f1f1f1;--muted: #8a8a8a;--muted2: #b5b5b5;--font: "SF Mono", "Fira Code", "Cascadia Code", "Consolas", monospace}html,body,#root{min-height:100dvh;background:var(--bg);color:var(--text);font-family:var(--font);font-size:13px;line-height:1.4;-webkit-font-smoothing:antialiased}.app{max-width:480px;margin:0 auto;padding:0 0 100px;min-height:100dvh}.header{position:sticky;top:0;z-index:50;background:var(--bg);border-bottom:1px solid var(--border);padding:14px 16px 12px;display:flex;align-items:center;justify-content:space-between}.header-logo{font-size:11px;letter-spacing:.18em;font-weight:700;text-transform:uppercase;color:var(--accent)}.header-fp{font-size:10px;letter-spacing:.15em;color:var(--muted2);display:flex;align-items:center;gap:6px}.fp-badge{background:var(--card);border:1px solid var(--border);padding:3px 8px;border-radius:3px;color:var(--accent3);font-size:12px;letter-spacing:.12em}.section{padding:16px;border-bottom:1px solid var(--border)}.section-label{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}.controls-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.control-group{display:flex;flex-direction:column;gap:5px}.control-group.full-width{grid-column:1 / -1}.control-label{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}select,input[type=number],input[type=text]{width:100%;background:var(--card);border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:12px;padding:9px 10px;border-radius:4px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}select:focus,input:focus{border-color:var(--border-bright)}.bpm-row{display:flex;align-items:center;gap:8px}.bpm-row input{flex:1}.bpm-tap{background:var(--card);border:1px solid var(--border);color:var(--muted2);font-family:var(--font);font-size:10px;letter-spacing:.12em;padding:9px 12px;border-radius:4px;cursor:pointer;white-space:nowrap}.bpm-tap:active{border-color:var(--accent2);color:var(--accent2)}.seed-row{display:flex;align-items:center;gap:8px}.seed-row input{flex:1;font-size:11px;letter-spacing:.08em}.seed-randomize{background:transparent;border:1px solid var(--border);color:var(--muted2);font-family:var(--font);font-size:16px;padding:7px 12px;border-radius:4px;cursor:pointer}.seed-randomize:active{color:var(--accent);border-color:var(--accent)}.generate-section{padding:16px;border-bottom:1px solid var(--border)}.btn-generate{width:100%;height:64px;background:var(--accent);color:#fff;font-family:var(--font);font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;border:none;border-radius:4px;cursor:pointer}.btn-generate:active{background:#cc2020;transform:scale(.99)}.btn-generate.generating{background:var(--accent-dim);cursor:wait}.telemetry-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.telemetry-card{background:var(--card);border:1px solid var(--border);border-radius:4px;padding:12px 10px 10px}.tel-name{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted2);margin-bottom:8px}.tel-value{font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px;line-height:1}.tel-value.bounce{color:var(--accent2)}.tel-value.pocket{color:var(--accent3)}.tel-value.darkness{color:var(--accent)}.tel-value.energy{color:#ffd33d}.tel-value.density{color:#6ec6ff}.tel-value.tension{color:#ff6ad5}.tel-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.tel-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}.tel-bar-fill.bounce{background:var(--accent2)}.tel-bar-fill.pocket{background:var(--accent3)}.tel-bar-fill.darkness{background:var(--accent)}.tel-bar-fill.energy{background:#ffd33d}.tel-bar-fill.density{background:#6ec6ff}.tel-bar-fill.tension{background:#ff6ad5}.mutation-btns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px}.btn-mutate{background:var(--card);border:1px solid var(--border);color:var(--muted2);font-family:var(--font);font-size:9px;letter-spacing:.14em;text-transform:uppercase;padding:12px 4px;border-radius:4px;cursor:pointer}.btn-mutate:hover{border-color:var(--border-bright);color:var(--text)}.btn-mutate.melody:active{border-color:var(--accent3);color:var(--accent3)}.btn-mutate.bass:active{border-color:var(--accent);color:var(--accent)}.btn-mutate.chords:active{border-color:var(--accent2);color:var(--accent2)}.mutation-tree{display:flex;flex-wrap:wrap;gap:6px}.mutation-node{font-size:9px;letter-spacing:.1em;padding:4px 8px;border-radius:3px;border:1px solid var(--border);color:var(--muted2);background:var(--card)}.mutation-node.active{border-color:var(--accent3);color:var(--accent3)}.mutation-node.melody{border-left:2px solid var(--accent3)}.mutation-node.bass{border-left:2px solid var(--accent)}.mutation-node.chords{border-left:2px solid var(--accent2)}.snapshot-actions{display:flex;gap:8px;margin-bottom:12px}.btn-save-snap{flex:1;background:var(--card);border:1px solid var(--border);color:var(--muted2);font-family:var(--font);font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:10px;border-radius:4px;cursor:pointer}.btn-save-snap:active{border-color:var(--accent3);color:var(--accent3)}.snapshots-list{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto}.snapshot-card{background:var(--card);border:1px solid var(--border);border-radius:4px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px;cursor:pointer}.snapshot-card:hover{border-color:var(--border-bright)}.snap-left{flex:1;min-width:0}.snap-label{font-size:11px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}.snap-meta{font-size:9px;color:var(--muted);letter-spacing:.08em}.snap-scores{display:flex;gap:6px;flex-shrink:0}.snap-score{font-size:9px;padding:2px 5px;border-radius:2px;background:var(--surface);border:1px solid var(--border)}.snap-score.b{color:var(--accent2)}.snap-score.p{color:var(--accent3)}.snap-score.d{color:var(--accent)}.snap-delete{background:transparent;border:none;color:var(--muted);font-size:14px;cursor:pointer;padding:4px;border-radius:3px}.snap-delete:hover{color:var(--accent)}.empty-state{font-size:10px;color:var(--muted);text-align:center;padding:16px 0;letter-spacing:.1em}.export-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:var(--bg);border-top:1px solid var(--border);padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom))}.btn-export{width:100%;height:52px;background:var(--surface);border:1px solid var(--border-bright);color:var(--text);font-family:var(--font);font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px}.btn-export:not(:disabled):hover{background:var(--card);border-color:var(--accent3);color:var(--accent3)}.btn-export:disabled{opacity:.35;cursor:default}.btn-export.exporting{border-color:var(--accent2);color:var(--accent2)}.btn-export.fallback{margin-top:8px;text-decoration:none;border-color:var(--accent3);color:var(--accent3);background:#0a1a0a}.btn-preview{width:100%;height:48px;background:var(--card);border:1px solid var(--border-bright);color:var(--accent3);font-family:var(--font);font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;border-radius:4px;cursor:pointer}.btn-preview:active{background:var(--surface)}.toast{position:fixed;top:56px;left:50%;transform:translate(-50%);max-width:calc(100% - 24px);background:#1a1a1a;border:1px solid var(--border-bright);color:#fff;font-size:13px;font-weight:700;letter-spacing:.12em;padding:12px 18px;border-radius:6px;z-index:100;pointer-events:none;opacity:0;transition:opacity .2s;text-align:center;box-shadow:0 8px 24px #0009}.toast.visible{opacity:1}.toast.success{border-color:var(--accent3);color:#d8ff7a;background:#141a0a}.toast.error{border-color:var(--accent);color:#ffb3b3;background:#1a0a0a}.export-meta{opacity:.6;font-size:9px;letter-spacing:.1em}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
