:root{--bg: #0a0a0c;--panel: #161619;--panel-2: #1e1e23;--border: #27272e;--ink: #f2f1f5;--muted: #8a8a95;--accent: #7c5cff;--accent-2: #ff5ca8;--accent-grad: linear-gradient(135deg, #7c5cff 0%, #ff5ca8 100%);--bronze: #8b7cff;--bronze-bright: #a78bff;--bronze-dim: #3a3170;--danger: #ff5c7a;--gold: #ffce5c;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;min-height:100dvh;margin:0}body{background:radial-gradient(1100px 560px at 50% -8%,#161425 0%,var(--bg) 58%);color:var(--ink);-webkit-tap-highlight-color:transparent;letter-spacing:.01em;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation;overscroll-behavior:none}input,textarea{-webkit-user-select:text;user-select:text}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.app{position:relative;z-index:1}.app{max-width:560px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;gap:20px;padding:max(20px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left))}@media (max-width: 520px){.app{gap:16px;padding-left:max(14px,env(safe-area-inset-left));padding-right:max(14px,env(safe-area-inset-right))}.grid{gap:22px}.row.loops,.row.shots{gap:12px}.bar .title strong{font-size:22px}.rec{padding:16px 48px;font-size:16px}.beat-dot{width:9px;height:9px}.beat-dot.down{width:11px;height:11px}.controls{padding-top:8px}}.screen{display:grid;place-items:center;height:100%;color:var(--muted)}.loadbox{display:flex;flex-direction:column;align-items:center;gap:14px}.screen.err{color:var(--danger);padding:24px;text-align:center}.bar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.bar .title{display:flex;flex-direction:column;gap:2px}.bar .title strong{font-size:19px;letter-spacing:.02em}.bar .title span{color:var(--muted);font-size:13px}.bar .meta{display:flex;gap:12px;font-size:12px;color:var(--muted);flex-wrap:wrap;justify-content:flex-end;align-items:center}.bar .meta .warn{color:var(--gold)}.link{background:none;border:none;color:var(--bronze);cursor:pointer;font-size:12px;padding:0}.link:hover{color:var(--bronze-bright)}.muted{color:var(--muted)}.player{gap:14px}.deck-top{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:38px;flex-shrink:0}.deck-actions{display:flex;align-items:center;gap:12px}.viz-wrap{position:relative;flex:1;min-height:90px}.viz{width:100%;height:100%;display:block}.viz-close{position:absolute;top:6px;right:6px;padding:4px 12px;border-radius:999px;background:#ffffff0f;border:1px solid var(--border);color:var(--muted);cursor:pointer;font-size:12px;line-height:1}.viz-close:hover{color:var(--ink)}.share-btn{background:var(--panel-2);color:var(--ink);border:1px solid var(--border);border-radius:999px;padding:12px 22px;font-size:15px;font-weight:600;cursor:pointer;transition:border-color .15s,transform .08s}.share-btn:hover{border-color:var(--accent)}.share-btn:active{transform:scale(.96)}.viz-collapsed{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:9px;margin-top:auto;background:var(--panel);border:1px solid var(--border);border-radius:14px;color:var(--muted);cursor:pointer;font-size:13px}.viz-collapsed:hover{color:var(--ink);border-color:color-mix(in srgb,var(--c) 40%,var(--border))}.viz-collapsed .chev{font-size:12px}.viz-dot{width:9px;height:9px;border-radius:50%;background:var(--c)}.grid{display:flex;flex-direction:column;gap:10px;flex-shrink:0}.row{display:grid;gap:10px}.row.loops,.row.shots{grid-template-columns:repeat(4,1fr)}.pad{position:relative;border:none;cursor:pointer;color:#fff;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px;background:linear-gradient(155deg,color-mix(in srgb,var(--c) 92%,#fff 4%),color-mix(in srgb,var(--c) 84%,#000 16%));box-shadow:0 4px 16px color-mix(in srgb,var(--c) 16%,transparent);transition:transform .09s ease,box-shadow .2s ease,filter .2s ease}.pad:disabled{opacity:.45;filter:saturate(.6)}.pad:active{transform:scale(.92)}.pad .label{font-weight:500;font-size:12px;text-transform:lowercase;letter-spacing:.04em;color:#ffffffc7}.pad .tags{font-size:9.5px;color:#ffffff73;text-align:center;line-height:1.15}.pad .bars{position:absolute;top:9px;right:11px;font-size:9px;color:#fff6}.pad.circle{border-radius:50%}.pad.square{border-radius:18px;transition:transform .34s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease}.pad.square:active{transition:transform .05s ease}.ring{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;transform:rotate(-90deg)}.ring circle{fill:none;stroke-width:4;stroke-linecap:round}.ring .track{stroke:#ffffff40}.ring .prog{stroke:#ffffffeb;transition:opacity .2s ease}.beats{display:flex;gap:10px;justify-content:center;align-items:center;height:12px}.beat-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .08s,transform .08s}.beat-dot.on{background:var(--accent)}.beat-dot.down{width:10px;height:10px}.beat-dot.down.on{background:var(--accent-2);transform:scale(1.25);box-shadow:0 0 10px #ff5ca899}.pad.circle.on{filter:brightness(1.04);box-shadow:0 0 0 1.5px color-mix(in srgb,var(--c) 55%,#fff),0 4px 16px color-mix(in srgb,var(--c) 16%,transparent)}.controls{display:flex;align-items:center;gap:14px;justify-content:center;padding-top:4px}.rec{background:var(--panel-2);color:var(--ink);border:1px solid var(--border);border-radius:999px;padding:12px 26px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .08s}.rec:active{transform:scale(.96)}.rec.live{background:var(--accent-grad);border-color:transparent;color:#fff;animation:pulse 1.2s infinite;box-shadow:0 6px 22px #ff5ca866}.rec:disabled{opacity:.4}.share{color:var(--accent-2);text-decoration:none;font-size:14px;font-weight:600}@keyframes pulse{50%{opacity:.55}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0d0ce6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;pointer-events:none}.overlay .cta{font-size:26px;font-weight:700;color:var(--bronze-bright)}.overlay p{color:var(--muted);font-size:13px;margin:0;text-align:center;padding:0 24px}.gear{background:none;border:none;color:var(--muted);cursor:pointer;padding:0 2px;line-height:1;display:inline-flex;align-items:center}.gear:hover{color:var(--bronze)}.gear .ico{display:block}.settings{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:14px;margin-top:10px;display:flex;flex-direction:column;gap:10px}.settings-row{display:flex;align-items:flex-start;justify-content:space-between}.settings-row strong{display:block;font-size:14px}.settings-row small{color:var(--muted);font-size:12px}.chips{display:flex;gap:8px}.settings .muted{font-size:11px}.uploader{display:flex;flex-direction:column;gap:14px;margin-top:24px}.drop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;pointer-events:none;background:#08080bd1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);outline:3px dashed var(--accent);outline-offset:-18px;display:flex;align-items:center;justify-content:center;animation:dropfade .12s ease}@keyframes dropfade{0%{opacity:0}to{opacity:1}}.drop-overlay-inner{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.drop-wordmark{font-family:Caveat,cursive;font-weight:700;font-size:56px;line-height:1;transform:rotate(-3deg);color:var(--ink)}.drop-overlay small{color:var(--muted)}.drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:1.5px dashed var(--border);border-radius:18px;padding:40px 18px;cursor:pointer;text-align:center;background:var(--panel);transition:border-color .15s,background .15s}.drop:hover{border-color:var(--bronze-dim)}.drop.has{border-color:var(--bronze);border-style:solid}.drop input{display:none}.drop span{font-size:15px;font-weight:600}.drop small{color:var(--muted)}.field{background:var(--panel);border:1px solid var(--border);border-radius:12px;color:var(--ink);padding:13px 14px;font-size:14px;outline:none;transition:border-color .15s}.field:focus{border-color:var(--bronze)}.field::placeholder{color:#5f5a52}.bars-row{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}.chip{background:var(--panel);border:1px solid var(--border);color:var(--ink);border-radius:999px;padding:7px 15px;cursor:pointer;font-size:13px;transition:all .15s}.chip:hover{border-color:var(--bronze-dim)}.chip.on{background:var(--bronze);border-color:var(--bronze);color:#1a1408;font-weight:600}.primary{margin-top:4px;background:var(--accent-grad);color:#fff;border:none;border-radius:14px;padding:15px;font-size:16px;font-weight:700;cursor:pointer;transition:filter .15s,transform .08s;box-shadow:0 6px 22px #7c5cff59}.primary:hover:not(:disabled){filter:brightness(1.08)}.primary:active:not(:disabled){transform:scale(.98)}.primary:disabled{opacity:.4;cursor:default;box-shadow:none}.login-view{justify-content:center;align-items:center}.login-card{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;max-width:340px;text-align:center}.login-form{display:flex;flex-direction:column;gap:12px;width:100%}.login-err{color:var(--danger);font-size:13px}.login-note{text-align:center;line-height:1.5}.brand{margin:0;font-family:Caveat,cursive;font-weight:700;font-size:64px;line-height:1;color:var(--ink);transform:rotate(-4deg);text-shadow:0 2px 10px rgba(0,0,0,.4)}.login-divider{display:flex;align-items:center;gap:12px;width:100%;color:var(--muted);font-size:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.waitlist{display:flex;flex-direction:column;gap:6px;width:100%;text-align:left}.waitlist>strong{font-size:15px}.waitlist>small{line-height:1.45;margin-bottom:4px}.waitlist-row{display:flex;gap:8px}.waitlist-row .field{flex:1}.wl-btn{margin-top:0;padding:0 20px;white-space:nowrap;box-shadow:none}.waitlist.done{align-items:flex-start;gap:4px;padding:6px 0}.waitlist.done strong{color:var(--accent-2);font-size:15px}.cta-link{background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700}.wl-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;background:#08080bc7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px}.wl-card{width:100%;max-width:360px;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:22px;display:flex;flex-direction:column;gap:14px;box-shadow:0 24px 60px #00000080;text-align:center}.wl-card .waitlist{text-align:center;align-items:center}.wl-card .link{align-self:center}.rec-canvas{position:fixed;left:-99999px;top:0;width:1px;height:1px;pointer-events:none}.auth-card{text-align:left;gap:10px;align-items:stretch}.auth-title{font-size:18px}.auth-card .login-form{width:100%}.auth-toggle{align-self:center}.save-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:9px 12px;font-size:13px;color:var(--muted);flex-shrink:0}.save-bar-actions{display:inline-flex;align-items:center;gap:8px;flex-shrink:0}.save-bar-cta{background:var(--accent-grad);color:#fff;border:none;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}.save-bar-x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:13px;padding:2px 4px}.save-bar-x:hover{color:var(--ink)}.save-card{display:flex;flex-direction:column;gap:2px;text-align:left;width:100%;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:12px 14px;cursor:pointer;color:var(--muted);transition:border-color .15s}.save-card:hover{border-color:var(--accent)}.save-card strong{color:var(--ink);font-size:14px;font-weight:600}.save-card span{font-size:13px}.deck-block{display:flex;flex-direction:column;gap:5px}.add-row{display:flex;justify-content:flex-end;height:18px}.add-mini{display:inline-flex;align-items:center;justify-content:center;width:26px;height:18px;border-radius:6px;cursor:pointer;color:var(--muted);font-size:17px;font-weight:300;line-height:1;border:1px solid var(--border);background:var(--panel);transition:color .15s,border-color .15s}.add-mini:hover{color:var(--ink);border-color:var(--accent)}.add-mini input{display:none}.library{margin-top:28px}.library h3{font-size:13px;color:var(--muted);font-weight:600;margin:0 0 12px;text-transform:uppercase;letter-spacing:.08em}.song-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.song-list li{display:flex;flex-direction:column;gap:8px}.song-main{display:flex;align-items:stretch;gap:8px}.song-swatch{width:40px;border:1px solid var(--border);border-radius:12px;cursor:pointer;flex-shrink:0}.song-swatch:hover{filter:brightness(1.1)}.swatches{display:flex;gap:10px;flex-wrap:wrap;padding:4px 2px 2px}.swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:transform .1s}.swatch:hover{transform:scale(1.12)}.swatch.on{border-color:#fff}.song-item{flex:1;text-align:left;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px 14px;cursor:pointer;color:var(--ink);display:flex;flex-direction:column;gap:3px;transition:border-color .15s}.song-item:hover{border-color:var(--bronze-dim)}.song-title{font-weight:600;font-size:14px}.song-meta{color:var(--muted);font-size:12px}.song-del{background:var(--panel);border:1px solid var(--border);border-radius:12px;color:var(--muted);cursor:pointer;padding:0 13px}.song-del:hover{color:var(--danger);border-color:#3a2630}.processing-view{justify-content:flex-start}.proc{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:64px;text-align:center}.proc h2{margin:0;font-size:20px;font-weight:600}.spinner{width:44px;height:44px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--bronze);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stages{list-style:none;padding:0;margin:0;text-align:left;color:var(--muted);font-size:14px;display:flex;flex-direction:column;gap:9px}.stages li.active{color:var(--ink);font-weight:600}.stages li.done{color:var(--bronze-bright)}.proc-detail{color:var(--bronze-bright);font-size:13px;margin:2px 0 0;text-align:center}.details{margin-top:18px;border-top:1px solid var(--border);padding-top:12px}.details summary{cursor:pointer;color:var(--muted);font-size:13px;list-style:none;-webkit-user-select:none;user-select:none;letter-spacing:.02em}.details summary::-webkit-details-marker{display:none}.details[open] summary{color:var(--ink)}.details-body{margin-top:12px;display:flex;flex-direction:column;gap:14px}.kv{display:flex;flex-direction:column;gap:7px}.kv-row{display:flex;justify-content:space-between;font-size:13px;gap:12px}.kv-k{color:var(--muted)}.kv-v{text-align:right}.pads-table{width:100%;border-collapse:collapse;font-size:12px}.pads-table th,.pads-table td{text-align:left;padding:6px 8px;border-bottom:1px solid var(--border)}.pads-table th{color:var(--muted);font-weight:500}
