*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#121212;--bg-surface:#1e1e1e;--bg-hover:#2a2a2a;--border:#333;--border-light:#444;--text:#e0e0e0;--text-muted:#999;--accent:#4a90d9;--accent-hover:#5ba0e9;--danger:#c0392b;--danger-hover:#e74c3c;--radius:8px;--radius-sm:4px;--app-max-width:1080px;--font:system-ui, -apple-system, sans-serif}html{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit;color:inherit}input,textarea,select{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem}input:focus,textarea:focus,select:focus{border-color:var(--accent);outline:none}button{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;padding:.4rem .8rem}button:hover{background:var(--bg-hover)}button:disabled{opacity:.5;cursor:not-allowed}.container{max-width:600px;margin:2rem auto;padding:0 1rem}.container-sm{max-width:400px;margin:4rem auto;padding:0 1rem}.card{-webkit-backdrop-filter:blur(12px);background:#1e1e1e80;border:1px solid #ffffff0f;border-radius:12px;padding:1.25rem}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-row{align-items:center;gap:.5rem;display:flex}.flex-col{flex-direction:column;gap:.5rem;display:flex}.flex-1{flex:1}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:.75rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{opacity:.7}.text-dimmed{opacity:.5}.text-accent{color:var(--accent)}.text-error{color:var(--danger)}.text-center{text-align:center}.w-full{width:100%}.list-none{list-style:none}.link-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}.link-btn:hover{color:var(--accent-hover);background:0 0}.btn-danger{background:var(--danger);color:#fff;border:none}.btn-danger:hover{background:var(--danger-hover)}.btn-danger-subtle{color:#f0b1aa;background:#c0392b14;border-color:#c0392b38}.btn-danger-subtle:hover{color:#ffd5d1;background:#c0392b24;border-color:#c0392b61}.divider{border-top:1px solid var(--border-light);margin-top:1rem;padding-top:.75rem}.projects-view,.profile-view{flex-direction:column;gap:1.25rem;display:flex}.projects-header,.profile-header{align-items:flex-start;gap:1rem;padding:.25rem 0 .5rem;display:flex}.projects-header{justify-content:space-between}.project-create-panel{background:#1e1e1e59;border:1px solid #ffffff0f;border-radius:10px;grid-template-columns:minmax(0,.8fr) minmax(320px,1.2fr);align-items:center;gap:1rem;padding:1rem;display:grid}.project-create-copy h3{margin:0 0 .2rem;font-size:1rem}.project-create-controls{align-items:center;gap:.5rem;min-width:0;display:flex}.project-create-controls input{min-width:0}.project-create-error{grid-column:1/-1}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;list-style:none;display:grid}.profile-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.profile-card{min-width:0;margin-bottom:0}.profile-form{flex-direction:column;gap:.65rem;display:flex}.profile-form input{min-width:0}.profile-checkbox{cursor:pointer;align-items:center;gap:.6rem;padding:.45rem 0;display:flex}.profile-danger{grid-column:1/-1}.profile-danger h3{color:#f0b1aa}.danger-card{border-color:#c0392b38}.profile-confirm-row{align-items:center;gap:.5rem;display:flex}.project-item{cursor:pointer;background:#1e1e1e66;border:1px solid #ffffff0f;border-radius:10px;min-height:7rem;padding:1rem;transition:background .2s,border-color .2s,transform .15s}.project-card-topline{justify-content:space-between;align-items:flex-start;gap:.75rem;min-width:0;margin-bottom:1.5rem;display:flex}.project-card-topline strong{text-overflow:ellipsis;min-width:0;overflow:hidden}.project-item:hover{background:#4a90d914;border-color:#4a90d940;transform:translateY(-1px)}.badge{color:#d9ebff;white-space:nowrap;background:#4a90d91f;border:1px solid #4a90d959;border-radius:999px;align-items:center;min-height:1.35rem;padding:.1rem .45rem;font-size:.72rem;line-height:1;display:inline-flex}.badge-muted{color:var(--text-muted);background:#ffffff0a;border-color:#ffffff1f}.badge-pro{color:#fff;background:#4a90d93d;border-color:#5ba0e980;font-weight:600}.comment-list{flex-direction:column;gap:.65rem;margin-top:1rem;font-size:.9rem;list-style:none;display:flex}.comment-item{border-top:1px solid #ffffff0f;padding:.75rem 0 0}.comment-main{grid-template-columns:auto minmax(0,1fr);align-items:start;gap:.65rem;display:grid}.comment-timestamp{color:var(--accent);cursor:pointer;white-space:nowrap;background:#4a90d91a;border:1px solid #4a90d93d;border-radius:999px;padding:.15rem .45rem;font-size:.75rem;line-height:1.2}.comment-timestamp:hover{background:#4a90d92e}.comment-content{min-width:0}.comment-meta{color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:.15rem;font-size:.78rem;display:flex}.comment-meta strong{color:var(--text);font-size:.85rem}.comment-content p,.reply-item p{overflow-wrap:anywhere}.comment-reply-btn{color:var(--text-muted);background:0 0;border:none;padding:0;font-size:.75rem}.comment-reply-btn:hover{color:var(--accent-hover);background:0 0}.project-view{flex-direction:column;gap:1.25rem;display:flex}.project-header,.section-header,.panel-header,.track-card-header,.stem-lane-header{align-items:center;gap:.75rem;display:flex}.project-header{padding:.25rem 0 .5rem}.project-title-group{flex:1;min-width:0}.project-title-group h2{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.active-control,.upload-tabs button.active{color:#d9ebff;background:#4a90d929;border-color:#4a90d973}.project-workspace-tools{grid-template-columns:minmax(0,1fr);gap:1rem;display:grid}.project-workspace-tools>*,.project-settings-panel{min-width:0}.project-workspace-tools.with-settings{grid-template-columns:minmax(0,1.4fr) minmax(320px,.8fr);align-items:start}.panel-header{justify-content:space-between;margin-bottom:.85rem}.panel-header h3,.section-header h3{margin:0;font-size:1rem}.settings-form{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.85rem;display:flex}.settings-form input{min-width:0}.member-list{max-height:16rem;margin-bottom:.85rem;overflow:auto}.member-row{align-items:center;gap:.5rem;min-width:0;padding:.35rem 0;display:flex}.tracks-section{flex-direction:column;gap:1rem;display:flex}.section-header{justify-content:space-between}.empty-state{color:var(--text-muted);background:#1e1e1e47;border:1px dashed #ffffff1f;border-radius:10px;padding:1.5rem}.track-card{margin-bottom:0}.track-card-header{justify-content:space-between;margin-bottom:1rem}.track-title-area{align-items:center;gap:.75rem;min-width:0;display:flex}.track-title-area strong{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.track-actions,.inline-confirm,.stem-mix-controls,.stem-revision-controls{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.play-btn{border-radius:999px;justify-content:center;align-items:center;min-width:2.25rem;min-height:2.25rem;padding:0;display:inline-flex}.button-label{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface);cursor:pointer;align-items:center;min-height:1.9rem;padding:.35rem .65rem;display:inline-flex}.button-label:hover{background:var(--bg-hover)}.waveform-region{padding:.35rem 0}.comment-composer{grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;gap:.5rem;margin-top:.75rem;display:grid}.confirm-card{justify-content:center;align-items:center;gap:.5rem;padding:1rem;display:flex}.stem-lane{border-radius:var(--radius);cursor:grab;min-width:0;margin-bottom:.9rem;padding:.75rem;transition:opacity .2s,background .2s,border-color .2s}.stem-lane-header{flex-wrap:wrap;gap:.65rem;margin-bottom:.65rem}.stem-drag-handle{color:var(--text-muted);cursor:grab;-webkit-user-select:none;user-select:none;font-size:.8rem}.stem-color-dot{border-radius:50%;flex-shrink:0;width:.55rem;height:.55rem;display:inline-block}.stem-title{text-overflow:ellipsis;white-space:nowrap;flex:18rem;min-width:10rem;overflow:hidden}.stem-mix-controls{border-radius:var(--radius);background:#12121273;border:1px solid #ffffff0f;padding:.25rem}.stem-toggle{opacity:.55;min-width:1.9rem;min-height:1.8rem;padding:.25rem .45rem}.stem-toggle.active{opacity:1;color:#d9ebff;background:#4a90d92e;border-color:#4a90d96b}.stem-toggle.muted{color:#ffd5d1;background:#c0392b24;border-color:#c0392b5c}.stem-volume{width:7.5rem;max-width:24vw}.stem-revision-controls{margin-left:auto}.stem-waveform-region{padding-top:.5rem}.stem-transport{z-index:20;border-radius:var(--radius);-webkit-backdrop-filter:blur(12px);background:#121212e6;border:1px solid #ffffff14;margin:0 -.5rem .75rem;padding:.55rem .5rem;position:sticky;top:4.25rem;box-shadow:0 8px 20px #00000047}.stem-transport input[type=range]{min-width:7rem}.reply-list{border-left:1px solid #ffffff14;margin:.6rem 0 0 3rem;padding-left:.75rem;list-style:none}.reply-item{color:var(--text-muted);padding:.25rem 0}.reply-form{gap:.5rem;margin:.65rem 0 0 3rem;display:flex}.upload-form{background:#1e1e1e4d;border:1px dashed #ffffff1a;border-radius:10px;flex-wrap:wrap;align-items:center;gap:.5rem;padding:1rem;display:flex}.upload-form input[type=file]{flex:200px;min-width:0}.upload-form input[type=text]{flex:150px;min-width:0}.upload-panel{background:#1e1e1e59;border:1px solid #ffffff0f;border-radius:10px;padding:1rem}.upload-tabs{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.upload-tabs button{padding:.3rem .65rem}.locked-panel{background:#1e1e1e4d;border:1px dashed #ffffff1f;border-radius:10px;align-items:center;gap:.75rem;padding:1rem;display:flex}.app-shell{background:linear-gradient(160deg,#0f0c29 0%,#1a1a2e 50%,#16213e 100%) fixed;min-height:100vh}.navbar{z-index:100;-webkit-backdrop-filter:blur(12px);background:#0f0c29cc;border-bottom:1px solid #ffffff0f;padding:.75rem 1.5rem;position:sticky;top:0;box-shadow:0 2px 12px #0006}.navbar-inner{width:min(100%, var(--app-max-width));justify-content:space-between;align-items:center;margin:0 auto;display:flex}.navbar-logo{font-size:1.2rem;font-weight:600}.navbar-logo-btn{background:0 0;border:none;align-items:center;gap:.55rem;padding:0;display:inline-flex}.navbar-logo-btn:hover{color:var(--accent-hover);background:0 0}.navbar-logo-mark{color:#fff;background:#4a90d947;border:1px solid #4a90d973;border-radius:8px;justify-content:center;align-items:center;width:1.8rem;height:1.8rem;font-size:1rem;font-weight:700;display:inline-flex}.navbar-actions{align-items:center;gap:.6rem;min-width:0;display:flex}.account-button{background:#ffffff0a;border-color:#ffffff14;align-items:center;gap:.5rem;max-width:18rem;display:inline-flex}.account-button:hover{background:#4a90d91a;border-color:#4a90d947}.account-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.logout-button{color:var(--text-muted);background:0 0;border-color:#ffffff14}.logout-button:hover{color:var(--text);background:#ffffff0d}.app-content{width:min(100% - 3rem, var(--app-max-width));background:#1e1e1e66;border-left:1px solid #ffffff0a;border-right:1px solid #ffffff0a;flex-direction:column;min-height:calc(100vh - 53px);margin:0 auto;padding:1.75rem 1.5rem;display:flex;box-shadow:-4px 0 16px #0000004d,4px 0 16px #0000004d}.app-footer{color:var(--text-muted);opacity:1;border-top:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:1rem;margin-top:auto;padding-top:1.25rem;font-size:.75rem;display:flex}.app-footer-links{flex-wrap:wrap;align-items:center;gap:.9rem;display:flex}.app-footer a{color:var(--text-muted)}.app-footer a:hover{color:var(--accent-hover)}.app-version{color:var(--text-muted);white-space:nowrap}.glass-card{-webkit-backdrop-filter:blur(12px);background:#1e1e1e80;border:1px solid #ffffff0f;border-radius:12px;padding:1.25rem;transition:border-color .2s}.banner-warning{-webkit-backdrop-filter:blur(8px);background:#332b0099;border:1px solid #ffc80026;border-radius:10px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.landing{background:linear-gradient(-45deg,#0f0c29,#1a1a2e,#16213e,#0f0c29) 0 0/400% 400%;min-height:100vh;animation:15s infinite auth-gradient}.landing-nav{justify-content:space-between;align-items:center;max-width:800px;margin:0 auto;padding:1rem 1.5rem;display:flex}.landing-nav-actions{align-items:center;gap:.75rem;display:flex}.landing-hero{text-align:center;max-width:640px;margin:0 auto;padding:6rem 1.5rem 4rem}.landing-hero h1{margin-bottom:1.25rem;font-size:2.8rem;font-weight:700;line-height:1.15}.landing-subtitle{color:var(--text-muted);max-width:480px;margin:0 auto 2rem;font-size:1.15rem;line-height:1.6}.landing-features{grid-template-columns:repeat(3,1fr);gap:1.25rem;max-width:800px;margin:0 auto;padding:0 1.5rem 4rem;display:grid}.feature-card{-webkit-backdrop-filter:blur(12px);text-align:center;background:#1e1e1e80;border:1px solid #ffffff0f;border-radius:12px;padding:1.5rem}.feature-card h3{margin-bottom:.5rem;font-size:1rem}.feature-card p{color:var(--text-muted);font-size:.85rem;line-height:1.5}.feature-icon{margin-bottom:.75rem;font-size:1.8rem;display:block}.landing-demo{max-width:640px;margin:0 auto;padding:0 1.5rem 3rem}.demo-player{-webkit-backdrop-filter:blur(12px);background:#1e1e1e99;border:1px solid #ffffff14;border-radius:12px;padding:1.25rem;box-shadow:0 4px 24px #0000004d}.demo-header{align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.9rem;display:flex}.demo-play{background:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;display:flex}.demo-time{color:var(--text-muted);margin-left:auto;font-size:.8rem}.demo-waveform{align-items:center;gap:2px;height:60px;margin-bottom:1rem;display:flex;position:relative}.demo-bar{background:#4a90d94d;border-radius:1px;flex:1;min-width:0}.demo-bar-played{background:var(--accent)}.demo-comment-marker{background:#ffc80099;border-radius:1px;width:2px;height:100%;position:absolute;top:0}.demo-comments{flex-direction:column;gap:.35rem;font-size:.82rem;display:flex}.demo-comment{border-bottom:1px solid #ffffff0a;padding:.3rem 0}.demo-comment-reply{color:var(--text-muted);padding-left:1.5rem}.demo-comment-ts{color:var(--accent);margin-right:.25rem}@keyframes comment-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.demo-comment-anim{opacity:0;animation:.4s forwards comment-appear}.landing-footer{text-align:center;opacity:.5;max-width:800px;margin:0 auto;padding:1.5rem;font-size:.7rem}.landing-footer-links{flex-wrap:wrap;justify-content:center;gap:.9rem;display:flex}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.75rem 2rem;font-size:1rem;font-weight:500;transition:background .2s}.btn-primary:hover{background:var(--accent-hover)}.btn-outline{color:var(--text);cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:8px;padding:.45rem 1.2rem;transition:border-color .2s}.btn-outline:hover{background:0 0;border-color:#ffffff59}@media (width<=600px){.landing-hero h1{font-size:2rem}.landing-features{grid-template-columns:1fr}}@media (width<=960px){.project-workspace-tools.with-settings{grid-template-columns:1fr}}@media (width<=720px){.navbar{padding:.75rem 1rem}.app-content{width:100%;box-shadow:none;border-left:0;border-right:0;padding:1rem}.navbar-inner{gap:1rem}.navbar-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem}.account-button{max-width:min(13rem,54vw)}.logout-button{padding-inline:.55rem}.app-footer{flex-direction:column;align-items:flex-start}.app-footer-links{gap:.7rem}.project-create-panel{grid-template-columns:1fr}.project-create-controls{flex-direction:column;align-items:stretch}.project-create-controls input,.project-create-controls button{width:100%}.projects-grid{grid-template-columns:1fr}.profile-header{flex-wrap:wrap}.profile-grid{grid-template-columns:1fr}.profile-confirm-row{flex-direction:column;align-items:stretch}.profile-confirm-row input,.profile-confirm-row button{width:100%}.project-header,.panel-header,.track-card-header{flex-wrap:wrap;align-items:flex-start}.project-title-group,.track-title-area{flex:100%;order:-1}.upload-form,.settings-form,.comment-composer{flex-direction:column;align-items:stretch;display:flex}.upload-form input,.upload-form button,.settings-form input,.settings-form button{width:100%;max-width:100%}.upload-form input[type=file],.upload-form input[type=text]{flex-basis:auto}.track-actions,.stem-mix-controls,.stem-revision-controls{flex-wrap:wrap}.stem-mix-controls{width:100%}.stem-volume{flex:1;width:auto;max-width:none}.stem-revision-controls{width:100%;margin-left:0}.stem-title{flex-basis:100%;min-width:0}}.auth-page{background:linear-gradient(-45deg,#0f0c29,#1a1a2e,#16213e,#0f0c29) 0 0/400% 400%;justify-content:center;align-items:center;min-height:100vh;animation:15s infinite auth-gradient;display:flex}@keyframes auth-gradient{0%,to{background-position:0%}50%{background-position:100%}}.auth-card{-webkit-backdrop-filter:blur(16px);background:#1e1e1eb3;border:1px solid #ffffff14;border-radius:16px;width:100%;max-width:400px;margin:1rem;padding:2.5rem 2rem;box-shadow:0 8px 32px #0006}.auth-card h1{text-align:center;margin-bottom:.25rem;font-size:1.8rem}.auth-card h2{text-align:center;color:var(--text-muted);margin-bottom:1.5rem;font-size:1rem;font-weight:400}.auth-card input:not([type=checkbox]){background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;width:100%;padding:.65rem .75rem;transition:border-color .2s}.auth-card input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #4a90d926}.auth-card button[type=submit]{background:var(--accent);color:#fff;border:none;border-radius:8px;width:100%;padding:.65rem;font-weight:500;transition:background .2s}.auth-card button[type=submit]:hover{background:var(--accent-hover)}.pricing-table{justify-content:center;gap:2rem;max-width:700px;margin:0 auto;padding:2rem 1rem;display:flex}.pricing-card{-webkit-backdrop-filter:blur(16px);text-align:center;background:#1e1e1eb3;border:1px solid #ffffff14;border-radius:16px;flex:1;padding:2rem 1.5rem;box-shadow:0 8px 32px #0006}.pricing-card button{width:100%;padding:.75rem 2rem;font-size:1rem}.pricing-price{margin:.5rem 0;font-size:2.5rem;font-weight:700}.pricing-period{opacity:.6;font-size:1rem;font-weight:400}.pricing-annual{opacity:.7;margin-top:-.5rem;font-size:.85rem}.pricing-features{text-align:left;margin:1.5rem 0;padding:0;list-style:none}.pricing-features li{border-bottom:1px solid #222;padding:.4rem 0}.pricing-features li:before{content:"✓ ";color:#4a90d9}.pricing-disabled{opacity:.5}.pricing-disabled:before{content:"✗ "!important;color:#e06c75!important}.pricing-wip{font-style:italic}.pricing-wip:before{content:"✓ "!important;color:#e5c07b!important}@media (width<=600px){.pricing-table{flex-direction:column;align-items:center}.pricing-card{width:100%;max-width:320px}.stem-revision-controls{width:100%;margin-left:0}input[type=range]{width:40px!important}}
