@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700&family=DM+Sans:wght@300;400;500;600&display=swap";:root{--bg: #0a0a0b;--bg-card: #111113;--bg-elevated: #18181c;--border: #2a2a30;--border-light: #3a3a42;--gold: #c9a84c;--gold-light: #e8c96a;--gold-dim: rgba(201, 168, 76, .15);--text: #f0ece4;--text-muted: #7a7880;--text-soft: #b8b4ac;--red: #e05555;--green: #4caf82;--font-display: "Playfair Display", Georgia, serif;--font-body: "DM Sans", sans-serif;--radius: 12px;--radius-lg: 20px;--shadow: 0 8px 40px rgba(0,0,0,.6);--glow: 0 0 60px rgba(201, 168, 76, .08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background-color:var(--bg);color:var(--text);min-height:100vh;font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:9999;opacity:.35}.page{max-width:1140px;margin:0 auto;padding:48px 24px 80px}.page-centered{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 24px}.grid-two{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}.stack-gap{display:grid;gap:24px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;position:relative;transition:border-color .3s ease,box-shadow .3s ease}.card:hover{border-color:var(--border-light);box-shadow:var(--glow)}.card h2{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--text);margin-bottom:24px;letter-spacing:-.01em}h1,h2,h3{font-family:var(--font-display)}.stack{display:grid;gap:14px}input,select,textarea{font-family:var(--font-body);font-size:14px;padding:14px 18px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);width:100%;transition:border-color .2s ease,box-shadow .2s ease;outline:none;appearance:none}input::placeholder,textarea::placeholder{color:var(--text-muted)}input:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px #c9a84c1f}select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a7880' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}select option{background:var(--bg-elevated)}textarea{resize:vertical;min-height:100px}button{font-family:var(--font-body);font-size:14px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:14px 28px;border-radius:var(--radius);border:none;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}.btn-primary{background:var(--gold);color:#0a0a0b}.btn-primary:hover{background:var(--gold-light);transform:translateY(-1px);box-shadow:0 6px 24px #c9a84c4d}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover{border-color:var(--border-light);color:var(--text);background:var(--bg-elevated)}.message{padding:14px 18px;border-radius:var(--radius);font-size:14px;font-weight:500;display:flex;align-items:center;gap:10px}.success{background:#4caf821a;color:#6dd4a8;border:1px solid rgba(76,175,130,.2)}.error{background:#e055551a;color:#f08080;border:1px solid rgba(224,85,85,.2)}.auth-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}@media(max-width:800px){.auth-page{grid-template-columns:1fr}.auth-visual{display:none}}.auth-visual{background:var(--bg-elevated);position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;overflow:hidden;border-right:1px solid var(--border)}.auth-visual:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 60%,rgba(201,168,76,.12) 0%,transparent 65%),radial-gradient(ellipse at 80% 20%,rgba(201,168,76,.06) 0%,transparent 50%)}.auth-visual-rings{position:absolute;width:600px;height:600px;border-radius:50%;border:1px solid rgba(201,168,76,.08);top:50%;left:50%;transform:translate(-50%,-50%);animation:ringPulse 8s ease-in-out infinite}.auth-visual-rings:before,.auth-visual-rings:after{content:"";position:absolute;border-radius:50%;border:1px solid rgba(201,168,76,.05);top:50%;left:50%;transform:translate(-50%,-50%)}.auth-visual-rings:before{width:400px;height:400px;animation:ringPulse 8s ease-in-out infinite 1s}.auth-visual-rings:after{width:200px;height:200px;border-color:#c9a84c1f;animation:ringPulse 8s ease-in-out infinite 2s}@keyframes ringPulse{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.04)}}.auth-visual-content{position:relative;z-index:1;text-align:center}.auth-visual-logo{font-family:var(--font-display);font-size:2.8rem;font-weight:900;font-style:italic;color:var(--text);letter-spacing:-.02em;margin-bottom:12px}.auth-visual-logo span{color:var(--gold)}.auth-visual-tagline{font-size:15px;color:var(--text-muted);font-weight:300;letter-spacing:.08em;text-transform:uppercase;margin-bottom:48px}.auth-visual-quote{font-family:var(--font-display);font-size:1.35rem;font-style:italic;color:var(--text-soft);line-height:1.5;max-width:360px}.auth-visual-quote cite{display:block;font-family:var(--font-body);font-size:12px;font-style:normal;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-top:16px}.auth-form-side{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 48px;background:var(--bg)}.auth-form-box{width:100%;max-width:420px}.auth-form-header{margin-bottom:36px}.auth-form-header h1{font-size:2.4rem;font-weight:700;letter-spacing:-.03em;color:var(--text);line-height:1.1;margin-bottom:10px}.auth-form-header p{color:var(--text-muted);font-size:15px;font-weight:300}.auth-form-header p a,.auth-switch-link{color:var(--gold);text-decoration:none;font-weight:500;transition:opacity .2s}.auth-form-header p a:hover,.auth-switch-link:hover{opacity:.8;text-decoration:underline}.field-label{display:block;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px}.field-group{display:grid;gap:6px}.divider{height:1px;background:var(--border);margin:8px 0}.role-select-group{display:grid;grid-template-columns:1fr 1fr;gap:10px}.role-option{position:relative}.role-option input[type=radio]{position:absolute;opacity:0;width:0;height:0}.role-option label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-elevated);cursor:pointer;transition:all .2s ease;font-size:13px;font-weight:500;color:var(--text-muted);gap:8px}.role-option label .role-icon{font-size:20px}.role-option input[type=radio]:checked+label{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}.role-option label:hover{border-color:var(--border-light);color:var(--text)}.app-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr}.topbar{background:#0a0a0bd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.topbar-inner{max-width:1140px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:20px}.topbar-logo{font-family:var(--font-display);font-size:1.4rem;font-weight:900;font-style:italic;color:var(--text);text-decoration:none;letter-spacing:-.02em}.topbar-logo span{color:var(--gold)}.topbar-nav{display:flex;align-items:center;gap:4px;list-style:none}.topbar-nav a{font-size:14px;font-weight:500;color:var(--text-muted);text-decoration:none;padding:8px 16px;border-radius:8px;transition:all .2s}.topbar-nav a:hover{color:var(--text);background:var(--bg-elevated)}.topbar-nav a.active{color:var(--gold)}.topbar-right{display:flex;align-items:center;gap:12px}.topbar-user-badge{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:100px}.topbar-user-badge .role-pill{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:100px;background:var(--gold-dim);color:var(--gold)}.btn-logout{font-size:13px;font-weight:500;color:var(--text-muted);background:none;border:1px solid var(--border);padding:8px 16px;border-radius:8px;cursor:pointer;font-family:var(--font-body);text-transform:none;letter-spacing:0;transition:all .2s}.btn-logout:hover{color:var(--red);border-color:#e055554d;background:#e055550f;transform:none;box-shadow:none}.page-header{margin-bottom:40px}.page-header-eyebrow{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}.page-header h1{font-size:clamp(2rem,4vw,3rem);font-weight:900;letter-spacing:-.04em;line-height:1.05;color:var(--text)}.page-header p{margin-top:12px;font-size:15px;color:var(--text-muted);font-weight:300;max-width:480px}.section-heading{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:20px;display:flex;align-items:center;gap:12px}.section-heading:after{content:"";flex:1;height:1px;background:var(--border)}.music-grid{display:grid;gap:10px}.music-item{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);gap:16px;transition:all .2s ease}.music-item:hover{border-color:var(--border-light);background:#1e1e24;transform:translate(4px)}.music-item-left{display:flex;align-items:center;gap:14px;min-width:0}.music-index{font-size:12px;font-weight:700;color:var(--text-muted);width:20px;text-align:right;flex-shrink:0;font-family:var(--font-display);font-style:italic}.music-disc{width:40px;height:40px;border-radius:50%;background:var(--gold-dim);border:1px solid rgba(201,168,76,.2);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.music-info{min-width:0}.music-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.music-artist{font-size:12px;color:var(--text-muted);margin-top:2px}.music-play-link{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);text-decoration:none;padding:8px 14px;border:1px solid rgba(201,168,76,.25);border-radius:8px;flex-shrink:0;transition:all .2s}.music-play-link:hover{background:var(--gold-dim);border-color:var(--gold)}.music-play-btn{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);background:transparent;padding:8px 14px;border:1px solid rgba(201,168,76,.25);border-radius:8px;flex-shrink:0;cursor:pointer;transition:all .2s}.music-play-btn:hover{background:var(--gold-dim);border-color:var(--gold);transform:none;box-shadow:none}.music-play-btn.playing{color:#f08080;border-color:#e0555559}.music-play-btn.playing:hover{background:#e0555514;border-color:#e0555580}.music-item-active{border-color:#c9a84c4d!important;background:#c9a84c0a!important}.music-disc-playing{animation:discSpin 2s linear infinite;border-color:var(--gold)!important;background:#c9a84c40!important}@keyframes discSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.album-expand-hint{font-size:11px;color:var(--text-muted);letter-spacing:.04em;margin-top:4px;transition:color .2s}.album-card:hover .album-expand-hint{color:var(--gold)}.album-card-expanded{border-color:#c9a84c40!important}.album-songs-animated{animation:fadeInUp .25s ease forwards}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(10,10,11,.25);border-top-color:#0a0a0b;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}button:disabled{opacity:.7;cursor:not-allowed;transform:none!important;box-shadow:none!important}.album-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all .2s ease}.album-card:hover{border-color:var(--border-light);transform:translateY(-2px);box-shadow:0 12px 40px #0006}.album-cover{width:100%;aspect-ratio:1;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-card) 100%);border-radius:var(--radius);margin-bottom:16px;display:flex;align-items:center;justify-content:center;font-size:48px;border:1px solid var(--border);position:relative;overflow:hidden;max-height:160px}.album-cover:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 30%,rgba(201,168,76,.08) 0%,transparent 60%)}.album-name{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:4px}.album-meta{font-size:12px;color:var(--text-muted);margin-bottom:12px}.album-songs-list{font-size:12px;color:var(--text-soft);line-height:1.8;padding-top:12px;border-top:1px solid var(--border)}.album-songs-list span{color:var(--text-muted);font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:10px;display:block;margin-bottom:6px}.albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state-icon{font-size:40px;margin-bottom:16px;opacity:.4}.empty-state p{font-size:14px}.studio-hero{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-elevated) 100%);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;margin-bottom:24px;position:relative;overflow:hidden}.studio-hero:before{content:"";position:absolute;top:-60px;right:-60px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.1) 0%,transparent 70%)}.studio-hero-eyebrow{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}.studio-hero h1{font-size:2.2rem;font-weight:900;letter-spacing:-.03em;color:var(--text);margin-bottom:8px}.studio-hero p{color:var(--text-muted);font-size:15px;font-weight:300}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:32px;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--bg-elevated);position:relative}.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;padding:0;border:none;background:transparent}.upload-zone:hover{border-color:var(--gold);background:var(--gold-dim)}.upload-zone-icon{font-size:32px;margin-bottom:12px;opacity:.6}.upload-zone-text{font-size:14px;color:var(--text-muted);line-height:1.5}.upload-zone-text strong{color:var(--gold);font-weight:600}.upload-zone.has-file{border-color:#4caf8266;background:#4caf820d}.upload-zone.has-file .upload-zone-text{color:#6dd4a8}.locked-card{text-align:center;padding:80px 40px}.locked-card-icon{font-size:56px;margin-bottom:20px;opacity:.3}.locked-card h2{font-size:1.8rem;font-weight:700;margin-bottom:12px;text-align:center}.locked-card p{color:var(--text-muted);font-size:15px;max-width:360px;margin:0 auto;text-align:center}.locked-card strong{color:var(--gold)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-in{animation:fadeInUp .5s ease forwards}.animate-in-delay-1{animation-delay:.1s;opacity:0}.animate-in-delay-2{animation-delay:.2s;opacity:0}.animate-in-delay-3{animation-delay:.3s;opacity:0}@media(max-width:640px){.auth-form-side{padding:40px 24px}.page{padding:32px 16px 60px}.studio-hero{padding:28px 24px}.studio-hero h1{font-size:1.7rem}.topbar-user-badge{display:none}}
