*,: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;--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)}.divider{border-top:1px solid var(--border-light);margin-top:1rem;padding-top:.75rem}.project-item{cursor:pointer;background:#1e1e1e66;border:1px solid #ffffff0f;border-radius:10px;padding:.85rem 1rem;transition:background .2s,border-color .2s,transform .15s}.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-item{border-bottom:1px solid #ffffff0d;padding:.4rem 0}.comment-timestamp{color:var(--accent);cursor:pointer}.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{margin-top:.25rem;padding-left:1.5rem;list-style:none}.reply-form{gap:.5rem;margin-top:.25rem;padding-left:1.5rem;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:.75rem}.upload-tabs{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.upload-tabs button{padding:.3rem .65rem}.upload-tabs button.active{color:#d9ebff;background:#4a90d929;border-color:#4a90d973}.locked-panel{background:#1e1e1e4d;border:1px dashed #ffffff1f;border-radius:10px;align-items:center;gap:.75rem;padding:1rem;display:flex}footer{border-top:1px solid var(--border);opacity:.5;margin-top:2rem;padding-top:1rem;font-size:.7rem}.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 1rem;position:sticky;top:0;box-shadow:0 2px 12px #0006}.navbar-inner{justify-content:space-between;align-items:center;max-width:640px;margin:0 auto;display:flex}.navbar-logo{font-size:1.2rem;font-weight:600}.navbar-logo-btn{background:0 0;border:none;padding:0}.navbar-logo-btn:hover{color:var(--accent-hover);background:0 0}.navbar-actions{align-items:center;gap:.75rem;display:flex}.app-content{background:#1e1e1e66;border-left:1px solid #ffffff0a;border-right:1px solid #ffffff0a;flex-direction:column;max-width:640px;min-height:calc(100vh - 53px);margin:0 auto;padding:1.5rem 1rem;display:flex;box-shadow:-4px 0 16px #0000004d,4px 0 16px #0000004d}.app-content>footer{margin-top:auto;font-size:.7rem}.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-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}.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}}.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}}
