*,: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)}.comment-item{border-bottom:1px solid #ffffff0d;padding:.4rem 0}.comment-timestamp{color:var(--accent);cursor:pointer}.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}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-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)}
