:root{--bg-900: #080B11;--bg-800: #0D121F;--bg-700: #0F1626;--bg-600: #090D16;--bg-500: #151D30;--line: #1e293b;--line-dim: rgba(30,41,59,.6);--text-hi: #e2e8f0;--text-mid: #94a3b8;--text-low: #64748b;--amber: #e59f42;--amber-dim: #c5691b;--amber-light: #f5daaa;--amber-faint: rgba(229,159,66,.08);--good: #34d399;--bad: #f87171;--good-bg: rgba(52,211,153,.1);--bad-bg: rgba(248,113,113,.08);--radius: 12px;--radius-lg: 16px;--radius-xl: 20px;--display: "Playfair Display", Georgia, serif;--sans: "Plus Jakarta Sans", system-ui, sans-serif;--mono: "IBM Plex Mono", ui-monospace, monospace;--sidebar: 256px}*{box-sizing:border-box;margin:0;padding:0}html{color-scheme:dark}body{font-family:var(--sans);background:var(--bg-900);color:var(--text-hi);-webkit-font-smoothing:antialiased;min-height:100svh}a{color:inherit;text-decoration:none}@media (min-width: 768px){::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-900)}::-webkit-scrollbar-thumb{background:var(--bg-500);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--line)}}h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.15}.muted{color:var(--text-mid)}.error-text{color:var(--bad);font-size:.875rem}.eyebrow{font-family:var(--mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--amber)}.shell{display:flex;min-height:100svh}@media (max-width: 767px){.shell{flex-direction:column}.main{padding-bottom:5rem}}.sidebar{width:var(--sidebar);background:var(--bg-800);border-right:1px solid var(--line-dim);display:flex;flex-direction:column;justify-content:space-between;padding:1.5rem;position:sticky;top:0;height:100svh;flex-shrink:0}@media (max-width: 767px){.sidebar{display:none}}.brand{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}.brand-icon{width:40px;height:40px;border-radius:14px;background:linear-gradient(135deg,var(--amber) 0%,var(--amber-dim) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0}.brand-icon svg{width:20px;height:20px;color:#0a0a0a;stroke-width:2.5}.brand-name{font-family:var(--display);font-size:1.5rem;font-weight:600;color:#fff;line-height:1}.brand-sub{font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:#e59f42b3;margin-top:.2rem}.sidebar-nav{display:flex;flex-direction:column;gap:.375rem}.navlink{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;color:var(--text-mid);cursor:pointer;border:none;background:none;text-decoration:none;width:100%;text-align:left;transition:background .15s,color .15s}.navlink svg{width:16px;height:16px;flex-shrink:0}.navlink:hover{background:#1e293b80;color:var(--text-hi)}.navlink.active{background:#1e293bcc;color:var(--amber);border-left:2px solid var(--amber);padding-left:calc(1rem - 2px)}.sidebar-user{border-top:1px solid var(--line-dim);padding-top:1.5rem}.sidebar-signout{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-low);background:none;border:none;cursor:pointer;padding:.5rem .25rem;width:100%;text-align:left;transition:color .15s}.sidebar-signout:hover{color:var(--bad)}.sidebar-signout svg{width:14px;height:14px}.mobile-header{display:none;position:sticky;top:0;z-index:40;background:#0d121feb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line-dim);padding:1rem 1.25rem;align-items:center;justify-content:space-between}@media (max-width: 767px){.mobile-header{display:flex}}.mobile-brand{display:flex;align-items:center;gap:.625rem}.mobile-brand-icon{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,var(--amber) 0%,var(--amber-dim) 100%);display:flex;align-items:center;justify-content:center}.mobile-brand-icon svg{width:15px;height:15px;color:#0a0a0a;stroke-width:2.5}.mobile-brand-name{font-family:var(--display);font-size:1.1rem;font-weight:600;color:#fff;line-height:1}.mobile-brand-sub{font-family:var(--mono);font-size:.55rem;letter-spacing:.15em;text-transform:uppercase;color:#e59f42bf}.mobile-nav{position:fixed;bottom:0;left:0;right:0;z-index:40;background:#0d121ff5;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(30,41,59,.8);padding:.5rem 1rem calc(.5rem + env(safe-area-inset-bottom));display:none;align-items:center;justify-content:space-around}@media (max-width: 767px){.mobile-nav{display:flex}}.mobile-nav-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem .75rem;border:none;background:none;cursor:pointer;color:var(--text-mid);transition:color .15s,transform .1s}.mobile-nav-btn:active{transform:scale(.88)}.mobile-nav-btn.active{color:var(--amber)}.mobile-nav-btn svg{width:20px;height:20px}.mobile-nav-btn span{font-size:.55rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.main{flex:1;min-width:0;overflow-y:auto;padding:1rem}@media (min-width: 640px){.main{padding:1.5rem}}@media (min-width: 768px){.main{padding:2.5rem}}.page-content{max-width:56rem;margin:0 auto}.page-head{margin-bottom:1.5rem}.page-head h1{font-size:clamp(1.75rem,5vw,3rem);margin:.375rem 0 .25rem;color:#fff}.page-head p{font-size:.875rem;color:var(--text-mid);line-height:1.6}@media (min-width: 768px){.page-head p{font-size:1rem}}.card{background:#0f1626d9;border:1px solid rgba(30,41,59,.8);border-radius:var(--radius-lg);padding:1.25rem;position:relative;overflow:hidden}@media (min-width: 768px){.card{padding:2rem}}.field{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}.field label{font-size:.625rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-mid)}.field input,.field textarea,.field select{font-family:var(--sans);font-size:1rem;background:var(--bg-600);border:1px solid rgba(30,41,59,.7);border-radius:var(--radius);color:var(--text-hi);padding:.75rem 1rem;width:100%;outline:none;transition:border-color .15s,box-shadow .15s}.field textarea{resize:vertical;min-height:96px}.field input:focus,.field textarea:focus,.field select:focus{border-color:#e59f42b3;box-shadow:0 0 0 3px #e59f4226}.btn{font-family:var(--sans);font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--line);background:#1e293b80;color:var(--text-hi);padding:.625rem 1.25rem;border-radius:var(--radius);cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;justify-content:center;transition:background .15s,border-color .15s,transform .1s;white-space:nowrap}.btn:hover{background:#1e293be6}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn svg{width:14px;height:14px;flex-shrink:0}.btn-primary{background:linear-gradient(90deg,var(--amber) 0%,var(--amber-dim) 100%);border-color:var(--amber);color:#1a0d00;width:100%;height:3rem;border-radius:var(--radius);font-size:.75rem}.btn-primary:hover{filter:brightness(1.08)}.btn-primary:disabled{background:#1e293bcc;border-color:var(--line);color:var(--text-low);filter:none}.btn-success{border-color:#34d3994d;background:#34d3991a;color:var(--good)}.btn-success:hover{background:#34d3992e}.chip{display:inline-flex;align-items:center;gap:.375rem;font-size:.8rem;background:#1e293b99;border:1px solid rgba(30,41,59,.5);border-radius:999px;padding:.25rem .35rem .25rem .7rem;white-space:nowrap;flex-shrink:0}.chip button{border:none;background:transparent;color:var(--text-low);cursor:pointer;font-size:1rem;line-height:1;padding:0 .3rem}.chip button:hover{color:var(--bad)}.preset-row{display:flex;flex-wrap:wrap;gap:.5rem;padding-bottom:.5rem}.preset-chip{font-size:.75rem;flex-shrink:0;background:#1e293b80;border:1px solid rgba(30,41,59,.5);color:var(--text-mid);padding:.5rem .75rem;border-radius:999px;cursor:pointer;transition:all .15s;white-space:nowrap}.preset-chip:hover{background:#1e293be6;border-color:#e59f4259;color:var(--amber-light)}.preset-chip:active{transform:scale(.95)}.meter{display:flex;gap:3px;align-items:flex-end}.meter span{width:3px;background:#e59f4280;border-radius:1px;transform-origin:bottom}.meter span:nth-child(3n){background:var(--amber);opacity:.9}@keyframes meter-bar{0%{transform:scaleY(.15);opacity:.2}to{transform:scaleY(1);opacity:1}}.meter.active span{animation:meter-bar ease-in-out infinite alternate}.gen-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0b0f19f5;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.25rem;text-align:center;border-radius:var(--radius-lg)}.gen-overlay h3{font-size:1.25rem;color:#fff;margin-bottom:.375rem}@media (min-width: 768px){.gen-overlay h3{font-size:1.5rem}}.gen-overlay-sub{font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:1rem}.gen-progress-bar{width:12rem;height:4px;background:#1e293bcc;border-radius:999px;overflow:hidden;margin-bottom:1rem}.gen-progress-fill{height:100%;background:var(--amber);border-radius:999px;transition:width .4s ease}.gen-overlay-step{font-size:.8rem;color:var(--text-mid);max-width:22rem;line-height:1.6}@keyframes log-in{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:none}}.log-enter{animation:log-in .15s ease-out both}@keyframes count-pop{0%{transform:scale(1)}35%{transform:scale(1.45)}65%{transform:scale(.88)}to{transform:scale(1)}}.count-pop{display:inline-block;animation:count-pop .32s ease-out both}.history-card{background:#0f162673;border:1px solid rgba(30,41,59,.8);border-radius:var(--radius);padding:1rem;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;transition:background .15s,border-color .15s}.history-card:hover{background:#0f1626bf}@keyframes slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.playlist-tracks{animation:slide-down .18s ease-out both;border-top:1px solid var(--line-dim);padding-top:.5rem;margin-top:.75rem;width:100%;max-height:60vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--line) transparent}.playlist-tracks .track-row{padding:.5rem 0}.playlist-tracks .track-row:last-child{border-bottom:none}.playlist-tracks .title{font-size:.85rem}.playlist-tracks .artist{font-size:.775rem}.history-card-title{font-weight:600;font-size:.9rem;color:var(--text-hi);transition:color .15s}.history-card:hover .history-card-title{color:var(--amber-light)}.history-badge{background:#e59f421a;color:var(--amber);font-size:.6rem;font-weight:700;padding:.2rem .4rem;border-radius:4px;border:1px solid rgba(229,159,66,.15);white-space:nowrap}.icon-btn{width:36px;height:36px;border-radius:var(--radius);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.icon-btn:active{transform:scale(.88)}.icon-btn svg{width:16px;height:16px}.toggle-wrap{display:flex;align-items:center;justify-content:space-between;padding:.875rem 0;border-bottom:1px solid var(--line-dim)}.toggle-wrap:last-child{border-bottom:none}.toggle-lbl{font-weight:600;font-size:.875rem}.toggle-desc{color:var(--text-low);font-size:.75rem;margin-top:.125rem}.auth-wrap{display:grid;place-items:center;min-height:100svh;padding:1.25rem;background:var(--bg-900)}.auth-card{width:100%;max-width:24rem}.auth-toggle{background:none;border:none;color:var(--amber);cursor:pointer;font-size:.875rem;font-family:var(--sans)}.track-row{display:grid;grid-template-columns:2rem 1fr auto;gap:.75rem;align-items:center;padding:.625rem 0;border-bottom:1px solid var(--line-dim)}.track-row .idx{font-family:var(--mono);color:var(--text-low);font-size:.8rem}.track-row .title{font-weight:500;font-size:.9rem}.track-row .artist{color:var(--text-mid);font-size:.825rem}.track-row .dur{font-family:var(--mono);color:var(--text-low);font-size:.775rem}.row{display:flex;gap:1rem;flex-wrap:wrap}.row>*{flex:1;min-width:200px}.toast{position:fixed;bottom:6rem;left:50%;transform:translate(-50%);z-index:50;background:#151d30f5;border:1px solid rgba(229,159,66,.3);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius);padding:.875rem 1.25rem;display:flex;align-items:center;gap:.75rem;max-width:min(22rem,90vw);box-shadow:0 8px 32px #0006}@media (min-width: 768px){.toast{bottom:auto;top:1.5rem}}.toast-text{font-size:.8rem;color:var(--amber-light);font-weight:500;line-height:1.4}.toast-close{border:none;background:none;color:#e59f4280;cursor:pointer;padding:.25rem;margin-left:auto}.toast-close:hover{color:var(--amber)}.toast-close svg{width:16px;height:16px}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}.chat-textarea{min-height:2.75rem}@media (max-width: 767px){.chat-textarea{min-height:5.5rem}}.chat-window{display:flex;flex-direction:column;border:1px solid rgba(229,159,66,.3);border-radius:var(--radius-lg);overflow:hidden;background:#090d16d9;box-shadow:0 0 0 1px #e59f420f,0 4px 32px #00000059}.chat-messages{min-height:180px;max-height:58vh;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem;scrollbar-width:thin;scrollbar-color:var(--line) transparent}@media (max-width: 767px){.chat-messages{min-height:100px;max-height:38vh;padding:.75rem}.chat-bubble-user,.chat-bubble-ai{max-width:96%;font-size:.875rem}.chat-bubble-ai{padding:.6rem .75rem}}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:2rem 1.25rem;color:var(--text-low);text-align:center;flex:1;min-height:160px}.chat-bubble-user{align-self:flex-end;max-width:82%;background:#e59f421a;border:1px solid rgba(229,159,66,.2);border-radius:var(--radius) var(--radius) 4px var(--radius);padding:.65rem 1rem;font-size:.9rem;line-height:1.5;color:var(--amber-light)}.chat-bubble-ai{align-self:flex-start;max-width:92%;background:#0f1626e6;border:1px solid rgba(30,41,59,.9);border-radius:var(--radius) var(--radius) var(--radius) 4px;padding:.75rem 1rem;font-size:.875rem;line-height:1.5;color:var(--text-hi)}.chat-bubble-result{max-width:100%;width:100%}.chat-bubble-error{border-color:#f8717140;background:#f871710d;color:var(--bad)}@keyframes bubble-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.chat-bubble-user,.chat-bubble-ai{animation:bubble-in .18s ease-out both}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}
