@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&display=swap";.viz-container{--viz-accent: #f97316;--viz-accent-soft: #fb923c;--viz-bg: #030712;--viz-panel: #090f1f;--viz-panel-alt: #0f172a;--viz-border: rgba(255, 255, 255, .1);--viz-text: #e2e8f0;--viz-muted: #94a3b8;--viz-success: #16a34a;font-family:Space Grotesk,Helvetica Neue,sans-serif;background:var(--viz-bg);color:var(--viz-text);min-height:100vh;position:relative}.viz-design-label{position:fixed;bottom:20px;right:20px;background:var(--viz-accent);color:#fff;padding:8px 16px;border-radius:999px;font-size:12px;font-weight:600;z-index:1000;box-shadow:0 4px 12px #f973164d}.viz-card-stack{display:flex;flex-direction:column;height:100vh;overflow:hidden}.viz-progress-bar{height:4px;background:var(--viz-panel-alt);position:fixed;top:0;left:0;right:0;z-index:100}.viz-progress-fill{height:100%;background:linear-gradient(90deg,var(--viz-accent),var(--viz-accent-soft));transition:width .5s ease}.viz-back-btn{position:fixed;top:24px;left:24px;background:var(--viz-panel);border:1px solid var(--viz-border);color:var(--viz-text);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:100;transition:all .2s ease}.viz-back-btn:hover{background:var(--viz-panel-alt);border-color:var(--viz-accent)}.viz-card-container{flex:1;display:flex;align-items:center;justify-content:center;padding:80px 24px 24px}.viz-card{width:100%;max-width:800px;display:flex;flex-direction:column;gap:32px}.viz-card-enter{animation:cardSlideIn .4s ease}@keyframes cardSlideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.viz-card-content{flex:1;display:flex;flex-direction:column;gap:16px}.viz-step-label{color:var(--viz-accent);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.viz-title{font-size:clamp(28px,5vw,42px);font-weight:700;line-height:1.2;margin:0}.viz-subtitle{color:var(--viz-muted);font-size:16px;margin:0}.viz-genre-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-top:16px}.viz-genre-card{background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:12px;padding:16px;text-align:left;cursor:pointer;transition:all .2s ease;position:relative}.viz-genre-card:hover:not(:disabled){border-color:var(--viz-accent);background:var(--viz-panel-alt)}.viz-genre-card.selected{border-color:var(--viz-accent);background:#f973161a}.viz-genre-card:disabled{opacity:.4;cursor:not-allowed}.viz-genre-images{display:flex;gap:4px;margin-bottom:12px}.viz-genre-image-placeholder{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--viz-panel-alt),var(--viz-border))}.viz-genre-name{display:block;font-weight:600;font-size:15px;margin-bottom:4px}.viz-genre-artists{display:block;font-size:12px;color:var(--viz-muted)}.viz-genre-check{position:absolute;top:12px;right:12px;width:24px;height:24px;background:var(--viz-accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.viz-selection-count{text-align:center;color:var(--viz-muted);font-size:14px;padding:12px}.viz-next-btn{background:var(--viz-accent);color:#fff;border:none;padding:16px 32px;border-radius:999px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;margin:0 auto}.viz-next-btn:hover:not(:disabled){background:var(--viz-accent-soft);transform:translateY(-2px)}.viz-next-btn:disabled{opacity:.5;cursor:not-allowed}.viz-btn-row{display:flex;gap:16px;justify-content:center}.viz-skip-btn{background:transparent;color:var(--viz-muted);border:1px solid var(--viz-border);padding:16px 24px;border-radius:999px;font-size:14px;cursor:pointer;transition:all .2s ease}.viz-skip-btn:hover{border-color:var(--viz-muted);color:var(--viz-text)}.viz-search-container{position:relative;max-width:500px;margin:24px auto}.viz-search-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--viz-muted)}.viz-search-input{width:100%;background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:999px;padding:16px 20px 16px 52px;font-size:16px;color:var(--viz-text);outline:none;transition:all .2s ease}.viz-search-input:focus{border-color:var(--viz-accent)}.viz-search-input::placeholder{color:var(--viz-muted)}.viz-artist-suggestions{text-align:center;margin-top:32px}.viz-suggestions-label{color:var(--viz-muted);font-size:14px;margin-bottom:16px}.viz-artist-chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.viz-artist-chip{display:flex;align-items:center;gap:8px;background:var(--viz-panel);border:1px solid var(--viz-border);border-radius:999px;padding:8px 16px 8px 8px;cursor:pointer;transition:all .2s ease;font-size:14px;color:var(--viz-text)}.viz-artist-chip:hover{border-color:var(--viz-accent);background:var(--viz-panel-alt)}.viz-artist-chip-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--viz-accent),var(--viz-accent-soft))}.viz-decade-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-top:24px}.viz-decade-btn{background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:12px;padding:20px 16px;text-align:center;cursor:pointer;transition:all .2s ease}.viz-decade-btn:hover{border-color:var(--viz-accent);background:var(--viz-panel-alt)}.viz-decade-btn.selected{border-color:var(--viz-accent);background:#f973161a}.viz-decade-label{display:block;font-size:24px;font-weight:700;margin-bottom:4px}.viz-decade-vibe{display:block;font-size:11px;color:var(--viz-muted)}.viz-binary-choice{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:32px;max-width:600px;margin-left:auto;margin-right:auto}.viz-choice-card{background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:16px;padding:32px 24px;text-align:center;cursor:pointer;transition:all .2s ease}.viz-choice-card:hover{border-color:var(--viz-accent);background:var(--viz-panel-alt)}.viz-choice-card.selected{border-color:var(--viz-accent);background:#f973161a}.viz-choice-icon{color:var(--viz-accent);margin-bottom:16px}.viz-choice-card h3{font-size:18px;font-weight:600;margin:0 0 8px}.viz-choice-card p{font-size:13px;color:var(--viz-muted);margin:0}.viz-pill-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:32px}.viz-pill{background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:999px;padding:14px 28px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;color:var(--viz-text)}.viz-pill:hover{border-color:var(--viz-accent);background:var(--viz-panel-alt)}.viz-pill.selected{border-color:var(--viz-accent);background:var(--viz-accent);color:#fff}.viz-placeholder{background:var(--viz-panel);border:2px dashed var(--viz-border);border-radius:12px;padding:60px;text-align:center;color:var(--viz-muted);font-size:14px;margin:24px 0}.viz-complete-card{text-align:center}.viz-complete-icon{color:var(--viz-success);margin-bottom:24px}.viz-summary{display:flex;gap:24px;justify-content:center;margin:32px 0}.viz-summary-item{background:var(--viz-panel);border-radius:12px;padding:16px 24px}.viz-summary-label{display:block;font-size:12px;color:var(--viz-muted);margin-bottom:4px}.viz-summary-value{font-weight:600}.viz-final-btn{background:#1db954}.viz-final-btn:hover:not(:disabled){background:#1ed760}.viz-chat{display:flex;flex-direction:column;height:100vh;max-width:600px;margin:0 auto}.viz-chat-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--viz-panel);border-bottom:1px solid var(--viz-border)}.viz-chat-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--viz-accent),var(--viz-accent-soft));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}.viz-chat-info h2{font-size:16px;margin:0}.viz-chat-status{font-size:12px;color:var(--viz-success)}.viz-chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.viz-message{display:flex;gap:12px;max-width:85%;animation:messageIn .3s ease}@keyframes messageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.viz-message-juke{align-self:flex-start}.viz-message-user{align-self:flex-end;flex-direction:row-reverse}.viz-message-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--viz-accent),var(--viz-accent-soft));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;flex-shrink:0}.viz-message-bubble{background:var(--viz-panel);border-radius:18px;padding:12px 16px}.viz-message-user .viz-message-bubble{background:var(--viz-accent)}.viz-message-bubble p{margin:0;font-size:15px;line-height:1.4}.viz-message-time{font-size:10px;color:var(--viz-muted);align-self:flex-end;margin-top:4px}.viz-typing-indicator{display:flex;gap:4px;padding:16px 20px;background:var(--viz-panel);border-radius:18px}.viz-typing-indicator span{width:8px;height:8px;background:var(--viz-muted);border-radius:50%;animation:typing 1.4s infinite}.viz-typing-indicator span:nth-child(2){animation-delay:.2s}.viz-typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.viz-chat-genres{margin-top:12px}.viz-chat-genre-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.viz-chat-genre-btn{background:var(--viz-panel-alt);border:1px solid var(--viz-border);border-radius:999px;padding:8px 14px;font-size:13px;cursor:pointer;transition:all .2s ease;color:var(--viz-text)}.viz-chat-genre-btn:hover:not(:disabled){border-color:var(--viz-accent)}.viz-chat-genre-btn.selected{background:var(--viz-accent);border-color:var(--viz-accent);color:#fff}.viz-chat-genre-btn:disabled{opacity:.4;cursor:not-allowed}.viz-chat-send-btn{background:var(--viz-accent);color:#fff;border:none;border-radius:999px;padding:10px 20px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.viz-chat-send-btn:hover:not(:disabled){background:var(--viz-accent-soft)}.viz-chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.viz-chat-input-area{margin-top:12px;display:flex;flex-direction:column;gap:8px}.viz-chat-text-input{background:var(--viz-panel-alt);border:1px solid var(--viz-border);border-radius:12px;padding:12px 16px;font-size:14px;color:var(--viz-text);outline:none}.viz-chat-text-input:focus{border-color:var(--viz-accent)}.viz-chat-skip{background:transparent;border:none;color:var(--viz-muted);font-size:12px;cursor:pointer;text-decoration:underline}.viz-chat-decades{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.viz-chat-decade-btn{background:var(--viz-panel-alt);border:1px solid var(--viz-border);border-radius:8px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;color:var(--viz-text)}.viz-chat-decade-btn:hover{border-color:var(--viz-accent);background:#f973161a}.viz-chat-binary{display:flex;gap:12px;margin-top:12px}.viz-chat-choice-btn{flex:1;background:var(--viz-panel-alt);border:1px solid var(--viz-border);border-radius:12px;padding:16px;text-align:center;cursor:pointer;transition:all .2s ease;color:var(--viz-text)}.viz-chat-choice-btn:hover{border-color:var(--viz-accent);background:#f973161a}.viz-choice-emoji{display:block;font-size:24px;margin-bottom:8px}.viz-chat-final{padding:20px;animation:messageIn .3s ease}.viz-chat-final-btn{width:100%;background:#1db954;color:#fff;border:none;border-radius:999px;padding:16px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .2s ease}.viz-chat-final-btn:hover{background:#1ed760}.viz-progressive{display:flex;min-height:100vh}.viz-prog-sidebar{width:280px;background:var(--viz-panel);border-right:1px solid var(--viz-border);position:fixed;top:0;left:0;bottom:0;padding:32px 24px;display:flex;flex-direction:column}.viz-prog-logo{font-size:24px;font-weight:700;color:var(--viz-accent);margin-bottom:48px}.viz-prog-nav{display:flex;flex-direction:column;gap:8px}.viz-prog-nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;color:var(--viz-muted)}.viz-prog-nav-item:hover:not(:disabled){background:var(--viz-panel-alt);color:var(--viz-text)}.viz-prog-nav-item.active{background:#f973161a;color:var(--viz-accent)}.viz-prog-nav-item.completed{color:var(--viz-success)}.viz-prog-nav-item.locked{opacity:.4;cursor:not-allowed}.viz-prog-nav-number{width:28px;height:28px;border-radius:50%;background:var(--viz-panel-alt);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.viz-prog-nav-item.active .viz-prog-nav-number{background:var(--viz-accent);color:#fff}.viz-prog-nav-item.completed .viz-prog-nav-number{background:var(--viz-success);color:#fff}.viz-prog-nav-label{font-size:14px;font-weight:500}.viz-prog-content{flex:1;margin-left:280px;padding:60px 80px}.viz-prog-section{min-height:80vh;padding:40px 0;border-bottom:1px solid var(--viz-border);opacity:.4;transition:opacity .3s ease}.viz-prog-section.active{opacity:1}.viz-prog-section.locked{filter:blur(2px);pointer-events:none}.viz-prog-section-header{margin-bottom:32px}.viz-prog-section-number{color:var(--viz-accent);font-size:13px;font-weight:600;letter-spacing:.05em}.viz-prog-section-header h2{font-size:32px;margin:8px 0}.viz-prog-section-header p{color:var(--viz-muted);margin:0}.viz-prog-genre-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.viz-prog-genre-card{background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease;display:flex;gap:16px;align-items:center;text-align:left;position:relative;color:var(--viz-text)}.viz-prog-genre-card:hover:not(:disabled){border-color:var(--viz-accent);background:var(--viz-panel-alt)}.viz-prog-genre-card.selected{border-color:var(--viz-accent);background:#f973161a}.viz-prog-genre-card:disabled{opacity:.4;cursor:not-allowed}.viz-prog-genre-art{width:60px;height:60px;flex-shrink:0}.viz-prog-genre-art-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;height:100%}.viz-prog-genre-art-grid div{background:linear-gradient(135deg,var(--viz-panel-alt),var(--viz-border));border-radius:4px}.viz-prog-genre-art-grid div:first-child{grid-column:span 2}.viz-prog-genre-info h3{font-size:15px;margin:0 0 4px}.viz-prog-genre-info p{font-size:12px;color:var(--viz-muted);margin:0}.viz-prog-genre-check{position:absolute;top:12px;right:12px;width:24px;height:24px;background:var(--viz-accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.viz-prog-section-footer{display:flex;align-items:center;justify-content:space-between;margin-top:32px;padding-top:24px;border-top:1px solid var(--viz-border)}.viz-prog-selection-count{color:var(--viz-muted);font-size:14px}.viz-prog-continue-btn{background:var(--viz-accent);color:#fff;border:none;padding:14px 32px;border-radius:999px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.viz-prog-continue-btn:hover:not(:disabled){background:var(--viz-accent-soft)}.viz-prog-continue-btn:disabled{opacity:.5;cursor:not-allowed}.viz-prog-skip-btn{background:transparent;color:var(--viz-muted);border:1px solid var(--viz-border);padding:14px 24px;border-radius:999px;font-size:14px;cursor:pointer;transition:all .2s ease}.viz-prog-skip-btn:hover{border-color:var(--viz-muted);color:var(--viz-text)}.viz-prog-search-area{max-width:500px;margin:32px 0}.viz-prog-search-box{position:relative}.viz-prog-search-box svg{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--viz-muted)}.viz-prog-search-box input{width:100%;background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:12px;padding:16px 20px 16px 52px;font-size:16px;color:var(--viz-text);outline:none;transition:all .2s ease}.viz-prog-search-box input:focus{border-color:var(--viz-accent)}.viz-prog-subsection{margin-bottom:40px}.viz-prog-subsection h3{font-size:18px;margin-bottom:16px}.viz-prog-mood-grid{display:flex;flex-wrap:wrap;gap:12px}.viz-prog-mood-card{background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:12px;padding:16px 20px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:10px;color:var(--viz-text)}.viz-prog-mood-card:hover{border-color:var(--viz-accent);background:var(--viz-panel-alt)}.viz-prog-mood-card.selected{border-color:var(--viz-accent);background:#f973161a}.viz-prog-mood-icon{font-size:20px}.viz-prog-mood-label{font-size:14px;font-weight:500}.viz-prog-workout-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.viz-prog-workout-card{background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:12px;text-align:left;color:var(--viz-text)}.viz-prog-workout-card:hover{border-color:var(--viz-accent);background:var(--viz-panel-alt)}.viz-prog-workout-card.selected{border-color:var(--viz-accent);background:#f973161a}.viz-prog-workout-icon{font-size:24px}.viz-prog-workout-label{display:block;font-weight:600;font-size:14px}.viz-prog-workout-desc{display:block;font-size:12px;color:var(--viz-muted)}.viz-prog-binary-row{display:flex;gap:16px}.viz-prog-binary-card{flex:1;background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:16px;padding:24px;text-align:center;cursor:pointer;transition:all .2s ease;color:var(--viz-text)}.viz-prog-binary-card:hover{border-color:var(--viz-accent);background:var(--viz-panel-alt)}.viz-prog-binary-card.selected{border-color:var(--viz-accent);background:#f973161a}.viz-prog-binary-icon{font-size:32px;display:block;margin-bottom:12px}.viz-prog-binary-label{display:block;font-weight:600;font-size:16px;margin-bottom:4px}.viz-prog-binary-desc{display:block;font-size:13px;color:var(--viz-muted)}.viz-prog-decade-row{display:flex;flex-wrap:wrap;gap:12px}.viz-prog-decade-btn{background:var(--viz-panel);border:2px solid var(--viz-border);border-radius:12px;padding:16px 20px;text-align:center;cursor:pointer;transition:all .2s ease;min-width:100px;color:var(--viz-text)}.viz-prog-decade-btn:hover{border-color:var(--viz-accent);background:var(--viz-panel-alt)}.viz-prog-decade-btn.selected{border-color:var(--viz-accent);background:#f973161a}.viz-prog-decade-label{display:block;font-size:20px;font-weight:700;margin-bottom:4px}.viz-prog-decade-vibe{display:block;font-size:11px;color:var(--viz-muted)}.viz-prog-location-note{margin-top:12px;font-size:13px;color:var(--viz-muted)}.viz-prog-complete{text-align:center;border-bottom:none}.viz-prog-complete-content{max-width:500px;margin:0 auto;padding:60px 0}.viz-prog-complete-icon{color:var(--viz-accent);margin-bottom:24px}.viz-prog-complete-content h2{font-size:32px;margin-bottom:12px}.viz-prog-complete-content p{color:var(--viz-muted);font-size:16px;margin-bottom:40px}.viz-prog-summary-grid{display:flex;gap:16px;justify-content:center;margin-bottom:40px}.viz-prog-summary-card{background:var(--viz-panel);border-radius:12px;padding:16px 24px;min-width:100px}.viz-prog-summary-label{display:block;font-size:12px;color:var(--viz-muted);margin-bottom:4px}.viz-prog-summary-value{font-weight:600}.viz-prog-final-btn{background:#1db954;color:#fff;border:none;padding:18px 40px;border-radius:999px;font-size:16px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:12px;transition:all .2s ease}.viz-prog-final-btn:hover{background:#1ed760;transform:translateY(-2px)}@media(max-width:960px){.viz-prog-sidebar{display:none}.viz-prog-content{margin-left:0;padding:40px 24px}}@media(max-width:600px){.viz-binary-choice{grid-template-columns:1fr}.viz-prog-binary-row{flex-direction:column}}.onboarding{min-height:100vh;background:var(--clr-bg);color:var(--clr-text);display:flex;flex-direction:column}.onboarding__progress{position:fixed;top:0;left:0;right:0;height:4px;background:var(--clr-panel-alt);z-index:100}.onboarding__progress-fill{height:100%;background:linear-gradient(90deg,var(--clr-accent),var(--clr-accent-soft));transition:width .4s ease}.onboarding__back{position:fixed;top:20px;left:20px;width:44px;height:44px;background:var(--clr-panel);border:1px solid var(--clr-border);border-radius:50%;color:var(--clr-text);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:100;transition:all .2s ease}.onboarding__back:hover{background:var(--clr-panel-alt);border-color:var(--clr-accent)}.onboarding__restart{position:fixed;top:20px;right:20px;width:44px;height:44px;background:var(--clr-panel);border:1px solid var(--clr-border);border-radius:50%;color:var(--clr-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:100;transition:all .2s ease}.onboarding__restart:hover{background:var(--clr-panel-alt);border-color:var(--clr-accent);color:var(--clr-accent)}.onboarding__main{flex:1;display:flex;align-items:center;justify-content:center;padding:80px 24px 40px}.onboarding__card{width:100%;max-width:720px;animation:cardEnter .4s ease}@keyframes cardEnter{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.onboarding__header{text-align:center;margin-bottom:32px}.onboarding__step-label{display:inline-block;color:var(--clr-accent);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.onboarding__title{font-size:clamp(24px,5vw,36px);font-weight:700;line-height:1.2;margin:0 0 8px}.onboarding__subtitle{color:var(--clr-muted);font-size:16px;margin:0}.onboarding__content{margin-bottom:32px}.onboarding__footer{display:flex;flex-direction:column;align-items:center;gap:16px}.onboarding__btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 32px;border-radius:var(--radius-pill);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.onboarding__btn--primary{background:var(--clr-accent);color:#fff}.onboarding__btn--primary:hover:not(:disabled){background:var(--clr-accent-soft);transform:translateY(-2px)}.onboarding__btn--primary:disabled{opacity:.5;cursor:not-allowed}.onboarding__btn--secondary{background:transparent;color:var(--clr-muted);border:1px solid var(--clr-border);padding:14px 24px;font-size:14px}.onboarding__btn--secondary:hover{border-color:var(--clr-muted);color:var(--clr-text)}.onboarding__btn--spotify{background:#1db954;color:#fff}.onboarding__btn--spotify:hover:not(:disabled){background:#1ed760;transform:translateY(-2px)}.onboarding__btn-row{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.onboarding__genre-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.onboarding__genre-card{background:var(--clr-panel);border:2px solid var(--clr-border);border-radius:var(--radius-lg);padding:20px;text-align:center;cursor:pointer;transition:all .2s ease;position:relative}.onboarding__genre-card:hover:not(:disabled){border-color:var(--clr-accent);background:var(--clr-panel-alt);transform:translateY(-2px)}.onboarding__genre-card--selected{border-color:var(--clr-accent);background:#f973161a}.onboarding__genre-card:disabled{opacity:.4;cursor:not-allowed}.onboarding__genre-artists{display:flex;justify-content:center;margin-bottom:16px}.onboarding__genre-artist-img{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--clr-panel-alt),var(--clr-border));overflow:hidden;border:3px solid var(--clr-panel);margin-left:-12px;box-shadow:0 2px 8px #0000004d}.onboarding__genre-artist-img:first-child{margin-left:0}.onboarding__genre-artist-img img{width:100%;height:100%;object-fit:cover}.onboarding__genre-name{display:block;font-weight:700;font-size:18px;margin-bottom:6px}.onboarding__genre-artist-names{display:block;font-size:13px;color:var(--clr-muted);line-height:1.4}.onboarding__genre-check{position:absolute;top:12px;right:12px;width:28px;height:28px;background:var(--clr-accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.onboarding__selection-count{text-align:center;color:var(--clr-muted);font-size:14px;margin-top:16px}.onboarding__search{position:relative;max-width:480px;margin:0 auto 24px}.onboarding__search-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--clr-muted);pointer-events:none}.onboarding__search-input{width:100%;background:var(--clr-panel);border:2px solid var(--clr-border);border-radius:var(--radius-pill);padding:16px 20px 16px 52px;font-size:16px;color:var(--clr-text);outline:none;transition:all .2s ease}.onboarding__search-input:focus{border-color:var(--clr-accent)}.onboarding__search-input::placeholder{color:var(--clr-muted)}.onboarding__search-results{position:absolute;top:100%;left:0;right:0;background:var(--clr-panel);border:1px solid var(--clr-border);border-radius:var(--radius-md);margin-top:8px;max-height:300px;overflow-y:auto;z-index:50}.onboarding__search-result{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s ease;border:none;background:transparent;width:100%;text-align:left;color:var(--clr-text)}.onboarding__search-result:hover{background:var(--clr-panel-alt)}.onboarding__search-result-img{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--clr-accent),var(--clr-accent-soft));overflow:hidden;flex-shrink:0}.onboarding__search-result-img img{width:100%;height:100%;object-fit:cover}.onboarding__search-result-name{font-weight:500}.onboarding__search-loading{padding:16px;text-align:center;color:var(--clr-muted)}.onboarding__selected-artist{display:flex;align-items:center;gap:16px;background:var(--clr-panel);border:2px solid var(--clr-accent);border-radius:var(--radius-md);padding:16px;max-width:400px;margin:0 auto}.onboarding__selected-artist-img{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--clr-accent),var(--clr-accent-soft));overflow:hidden;flex-shrink:0}.onboarding__selected-artist-img img{width:100%;height:100%;object-fit:cover}.onboarding__selected-artist-info{flex:1}.onboarding__selected-artist-name{font-size:18px;font-weight:600;margin-bottom:4px}.onboarding__selected-artist-label{font-size:13px;color:var(--clr-accent)}.onboarding__selected-artist-remove{background:transparent;border:none;color:var(--clr-muted);cursor:pointer;padding:8px;transition:color .15s ease}.onboarding__selected-artist-remove:hover{color:var(--clr-error)}.onboarding__mood-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.onboarding__mood-card{background:var(--clr-panel);border:2px solid var(--clr-border);border-radius:var(--radius-md);padding:16px 20px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:10px;color:var(--clr-text)}.onboarding__mood-card:hover{border-color:var(--clr-accent);background:var(--clr-panel-alt)}.onboarding__mood-card--selected{border-color:var(--clr-accent);background:#f973161a}.onboarding__mood-icon{font-size:24px}.onboarding__mood-label{font-size:14px;font-weight:500}.onboarding__workout-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.onboarding__workout-card{background:var(--clr-panel);border:2px solid var(--clr-border);border-radius:var(--radius-md);padding:16px;cursor:pointer;transition:all .2s ease;text-align:left;color:var(--clr-text)}.onboarding__workout-card:hover{border-color:var(--clr-accent);background:var(--clr-panel-alt)}.onboarding__workout-card--selected{border-color:var(--clr-accent);background:#f973161a}.onboarding__workout-icon{font-size:28px;margin-bottom:8px}.onboarding__workout-label{display:block;font-weight:600;font-size:14px;margin-bottom:4px}.onboarding__workout-desc{display:block;font-size:12px;color:var(--clr-muted)}.onboarding__decade-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.onboarding__decade-btn{background:var(--clr-panel);border:2px solid var(--clr-border);border-radius:var(--radius-md);padding:16px 20px;text-align:center;cursor:pointer;transition:all .2s ease;min-width:100px;color:var(--clr-text)}.onboarding__decade-btn:hover{border-color:var(--clr-accent);background:var(--clr-panel-alt)}.onboarding__decade-btn--selected{border-color:var(--clr-accent);background:#f973161a}.onboarding__decade-label{display:block;font-size:22px;font-weight:700;margin-bottom:4px}.onboarding__decade-vibe{display:block;font-size:11px;color:var(--clr-muted)}.onboarding__binary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:500px;margin:0 auto}.onboarding__binary-card{background:var(--clr-panel);border:2px solid var(--clr-border);border-radius:var(--radius-lg);padding:32px 24px;text-align:center;cursor:pointer;transition:all .2s ease;color:var(--clr-text)}.onboarding__binary-card:hover{border-color:var(--clr-accent);background:var(--clr-panel-alt)}.onboarding__binary-card--selected{border-color:var(--clr-accent);background:#f973161a}.onboarding__binary-icon{font-size:40px;margin-bottom:16px}.onboarding__binary-label{display:block;font-size:18px;font-weight:600;margin-bottom:8px}.onboarding__binary-desc{font-size:13px;color:var(--clr-muted)}.onboarding__pill-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.onboarding__pill{background:var(--clr-panel);border:2px solid var(--clr-border);border-radius:var(--radius-pill);padding:14px 28px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;color:var(--clr-text)}.onboarding__pill:hover{border-color:var(--clr-accent);background:var(--clr-panel-alt)}.onboarding__pill--selected{border-color:var(--clr-accent);background:var(--clr-accent);color:#fff}.onboarding__location-selected{display:flex;align-items:center;gap:12px;background:var(--clr-panel);border:2px solid var(--clr-accent);border-radius:var(--radius-md);padding:16px;max-width:400px;margin:0 auto}.onboarding__location-icon{width:48px;height:48px;background:#f973161a;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--clr-accent);flex-shrink:0}.onboarding__location-info{flex:1}.onboarding__location-name{font-size:16px;font-weight:600}.onboarding__location-country{font-size:13px;color:var(--clr-muted)}.onboarding__location-remove{background:transparent;border:none;color:var(--clr-muted);cursor:pointer;padding:8px}.onboarding__location-remove:hover{color:var(--clr-error)}.onboarding__complete{text-align:center}.onboarding__complete-icon{color:var(--clr-success);margin-bottom:24px}.onboarding__summary{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin:32px 0}.onboarding__summary-item{background:var(--clr-panel);border-radius:var(--radius-md);padding:16px 24px;min-width:100px}.onboarding__summary-label{display:block;font-size:12px;color:var(--clr-muted);margin-bottom:4px}.onboarding__summary-value{font-weight:600}@media(max-width:768px){.onboarding__main{padding:70px 16px 32px;align-items:flex-start}.onboarding__card{max-width:100%}.onboarding__title{font-size:24px}.onboarding__subtitle{font-size:14px}.onboarding__header{margin-bottom:24px}.onboarding__genre-grid{grid-template-columns:repeat(2,1fr);gap:12px}.onboarding__genre-card{padding:16px 12px}.onboarding__genre-artist-img{width:44px;height:44px;margin-left:-10px}.onboarding__genre-name{font-size:15px}.onboarding__genre-artist-names{font-size:11px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;white-space:normal}.onboarding__binary-grid{grid-template-columns:1fr;gap:12px}.onboarding__binary-card{padding:20px 16px;display:flex;align-items:center;text-align:left;gap:16px}.onboarding__binary-icon{font-size:32px;margin-bottom:0}.onboarding__binary-label{font-size:16px;margin-bottom:4px}.onboarding__workout-grid{grid-template-columns:1fr 1fr;gap:10px}.onboarding__workout-card{padding:14px 12px}.onboarding__decade-grid{gap:10px}.onboarding__decade-btn{padding:12px 16px;min-width:80px}.onboarding__decade-label{font-size:18px}.onboarding__pill-row{gap:10px}.onboarding__pill{padding:12px 20px;font-size:14px}.onboarding__mood-grid{gap:10px}.onboarding__mood-card{padding:14px 16px}.onboarding__btn{padding:14px 24px;font-size:15px;width:100%;max-width:320px}.onboarding__search{margin-bottom:20px}.onboarding__search-input{padding:14px 16px 14px 48px;font-size:16px}.onboarding__summary{gap:10px}.onboarding__summary-item{padding:12px 16px;min-width:80px}.onboarding__back,.onboarding__restart{width:40px;height:40px;top:16px}.onboarding__back{left:16px}.onboarding__restart{right:16px}.onboarding__selected-artist{padding:14px;gap:12px}.onboarding__selected-artist-img{width:52px;height:52px}.onboarding__selected-artist-name{font-size:16px}.onboarding__location-selected{padding:14px}.onboarding__location-icon{width:40px;height:40px}}@media(max-width:480px){.onboarding__main{padding:60px 12px 24px}.onboarding__title{font-size:22px}.onboarding__genre-grid{grid-template-columns:repeat(2,1fr);gap:10px}.onboarding__genre-card{padding:14px 10px}.onboarding__genre-artist-img{width:36px;height:36px;margin-left:-8px}.onboarding__genre-name{font-size:14px}.onboarding__genre-artist-names{font-size:10px}.onboarding__workout-grid{grid-template-columns:1fr}.onboarding__decade-btn{padding:10px 14px;min-width:70px}.onboarding__decade-label{font-size:16px}.onboarding__decade-vibe{font-size:10px}.onboarding__pill{padding:10px 16px;font-size:13px}}@media(max-width:360px){.onboarding__genre-grid{grid-template-columns:1fr}.onboarding__genre-card{display:flex;align-items:center;gap:12px;text-align:left;padding:12px}.onboarding__genre-artists{margin-bottom:0;flex-shrink:0}.onboarding__genre-artist-img{width:32px;height:32px}.onboarding__genre-check{top:50%;transform:translateY(-50%)}}:root{--font-sans: "Space Grotesk", "Helvetica Neue", sans-serif;--line-height-base: 1.5;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-bold: 700;--clr-bg: #030712;--clr-panel: #090f1f;--clr-panel-alt: #0f172a;--clr-accent: #f97316;--clr-accent-soft: #fb923c;--clr-border: rgba(255, 255, 255, .1);--clr-text: #e2e8f0;--clr-muted: #94a3b8;--clr-success: #16a34a;--clr-success-soft: rgba(34, 197, 94, .2);--clr-error: #ef4444;--clr-error-soft: rgba(248, 113, 113, .2);--clr-warning: #facc15;--clr-warning-soft: rgba(250, 204, 21, .2);--radius-sm: .65rem;--radius-md: .95rem;--radius-lg: 1.2rem;--radius-xl: 1.5rem;--radius-pill: 999px;--shadow-lg: 0 25px 80px rgba(2, 6, 23, .45)}:root{color-scheme:dark;font-family:var(--font-sans);line-height:var(--line-height-base);font-weight:var(--font-weight-normal)}body{font-family:var(--font-sans);line-height:var(--line-height-base);font-weight:var(--font-weight-normal)}body{margin:0;background-color:#1a2a4a;background-image:linear-gradient(125deg,#b0602a,#6a3c3a 32%,#243a63,#2b4f9c 78%,#2e5bbb);color:var(--clr-text);min-height:100vh}*{box-sizing:border-box;margin:0}a{color:var(--clr-accent);text-decoration:none}a:hover{text-decoration:underline}main{min-height:100vh}input,button,textarea,select{font:inherit}::-webkit-scrollbar{width:.65rem}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--clr-panel-alt);border-radius:.5rem}:root{--sidebar-width: 240px}body.no-scroll{overflow:hidden;height:100vh}body.no-scroll .app-shell__content{overflow:hidden}.app-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:auto 1fr auto;min-height:100vh}.app-shell--sidebar-collapsed{--sidebar-width: 0px}.app-shell__content{display:flex;flex-direction:column;gap:2rem;padding:2rem clamp(1.5rem,3.2vw,3.5rem);grid-column:2 / 3;grid-row:1 / 3;width:100%;max-width:min(1820px,100%);min-width:320px;margin:0 auto}.sidebar{background:#090f1fcc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-right:1px solid var(--clr-border);padding:2rem;display:flex;flex-direction:column;gap:1.5rem;grid-column:1 / 2;grid-row:1 / 4;position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;transition:transform .2s ease,padding .2s ease}.app-shell--sidebar-collapsed .sidebar{width:0;min-width:0;transform:translate(-140%);padding:0;border-right:none;opacity:0;visibility:hidden;pointer-events:none}.sidebar__brand{display:flex;align-items:center;gap:.75rem;font-size:1.2rem;letter-spacing:.05em}.sidebar__close{margin-left:auto;border:1px solid transparent;border-radius:999px;background:#0f172a99;color:var(--clr-muted);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer}.sidebar__close:hover,.sidebar__close:focus-visible{border-color:#f8fafc26;color:var(--clr-text)}.sidebar__close{display:none}.sidebar-overlay{display:none;border:none;position:fixed;inset:0;background:#020617b3;z-index:15}.sidebar__burst{width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,#facc15,#f97316,#ef4444);display:inline-block}.sidebar__nav,.sidebar-search{display:flex;flex-direction:column;gap:.5rem}.sidebar-search__form{display:flex;flex-direction:column;gap:.35rem}.sidebar-search__form label{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--clr-muted)}.sidebar-search__input{width:100%;border-radius:var(--radius-md);border:1px solid var(--clr-border);background:#0f172ad9;color:var(--clr-text);padding:.55rem .75rem}.sidebar-search__input::placeholder{color:var(--clr-muted)}.sidebar-search__input:disabled{opacity:.5;cursor:not-allowed}.sidebar-search__results{border:1px solid var(--clr-border);border-radius:var(--radius-md);background:#020617e6;padding:.5rem;display:flex;flex-direction:column;gap:.5rem;max-height:320px;overflow-y:auto}.sidebar-search__section{display:flex;flex-direction:column;gap:.35rem}.sidebar-search__section h4{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--clr-muted)}.sidebar-search__item{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.35rem .25rem;border-radius:var(--radius-sm);border:none;background:transparent;color:inherit;cursor:pointer;text-align:left}.sidebar-search__item:hover,.sidebar-search__item:focus-visible{background:#f8fafc14}.sidebar-search__item>div{display:flex;flex-direction:column;gap:.1rem}.sidebar-search__item p{font-size:.9rem}.sidebar-search__item span{font-size:.7rem;color:var(--clr-muted)}.sidebar-search__badge{font-size:.65rem;color:var(--clr-muted)}.sidebar-search__status{font-size:.75rem;color:var(--clr-muted)}.sidebar__link{padding:.5rem .75rem;border-radius:var(--radius-sm);color:var(--clr-muted);font-weight:500;display:flex;align-items:center;gap:.5rem;background:transparent;border:none;cursor:pointer;text-align:left;width:100%}.sidebar__link--active{background:#f9731626;color:var(--clr-text)}.sidebar__link--danger{color:var(--clr-error)}.sidebar__link--danger:hover,.sidebar__link--danger:focus-visible{background:var(--clr-error-soft);color:#fee2e2}.sidebar__footer{margin-top:auto;display:flex;flex-direction:column;gap:.45rem}.sidebar__micro-link{align-self:flex-start;font-size:.72rem;letter-spacing:.02em;color:#94a3b8e6;text-decoration:underline;text-underline-offset:2px;padding:.05rem 0}.sidebar__micro-link:hover,.sidebar__micro-link:focus-visible{color:#e2e8f0fa}.sidebar__footnote{margin-top:0;font-size:.75rem;color:var(--clr-muted)}.mobile-nav-toggle{display:inline-flex;border:1px solid rgba(148,163,184,.4);border-radius:.75rem;background:#0f172acc;padding:.5rem;width:44px;height:44px;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:.3rem}.mobile-nav-toggle__bar{display:block;width:18px;height:2px;border-radius:999px;background:var(--clr-text)}.app-shell__toolbar{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:.75rem;padding:.5rem .75rem .25rem}.app-shell__toolbar-slot{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center}.app-shell__title{justify-self:center;font-size:1.5rem;font-weight:600;letter-spacing:.02em}.app-shell__toolbar .mobile-nav-toggle{position:static}.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;color:var(--clr-muted)}.muted{color:var(--clr-muted)}.pill{padding:.35rem .75rem;border-radius:var(--radius-pill);border:1px solid var(--clr-border);color:var(--clr-muted);font-size:.85rem}.pill--accent{border-color:var(--clr-accent);color:var(--clr-accent)}.pill--link{border-color:transparent;color:var(--clr-accent);background:transparent;cursor:pointer;padding:.35rem .5rem}.pill--link:hover,.pill--link:focus-visible{color:var(--clr-accent-soft)}.btn{border:none;border-radius:var(--radius-md);padding:.75rem 1.25rem;font-weight:600;cursor:pointer;transition:transform .12s ease}.btn-primary{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a}.btn-ghost{background:transparent;color:var(--clr-text);border:1px solid var(--clr-border)}.btn-link{background:transparent;color:var(--clr-accent);padding:.35rem .5rem}.btn-link:hover,.btn-link:focus-visible{text-decoration:underline}.btn:disabled{opacity:.6;cursor:not-allowed}.card{background:#0f172ae6;border:1px solid var(--clr-border);border-radius:var(--radius-xl);box-shadow:0 25px 80px #02061773}.card__body{padding:1.75rem;display:flex;flex-direction:column;gap:1rem}.card--compact{padding:1rem}.field{display:flex;flex-direction:column;gap:.35rem}.field__label{font-size:.85rem;color:var(--clr-muted)}.field__input{background:#0f172acc;border:1px solid var(--clr-border);border-radius:var(--radius-md);padding:.85rem 1rem;color:var(--clr-text)}.field__input--error{border-color:#f87171}.field__error{color:#f38585;font-size:.75rem}.status-banner{display:flex;align-items:flex-start;gap:.65rem;border-radius:var(--radius-md);padding:.85rem 1.1rem;border:1px solid var(--clr-border);background:#0f172acc;font-size:.9rem}.status-banner__dot{width:.55rem;height:.55rem;border-radius:50%;background:currentColor;box-shadow:0 0 12px currentColor;margin-top:.25rem;flex-shrink:0}.status-banner__message{flex:1}.status-banner--info{color:var(--clr-accent);border-color:#f9731659;background:#f973161f}.status-banner--success{color:var(--clr-success);border-color:#16a34a59;background:var(--clr-success-soft)}.status-banner--warning{color:var(--clr-warning);border-color:#facc1559;background:var(--clr-warning-soft)}.status-banner--error{color:var(--clr-error);border-color:#ef444459;background:var(--clr-error-soft)}.profile{display:flex;flex-direction:column;gap:1.5rem;padding:2.5rem 0 3rem;position:relative}.profile:before,.profile:after{content:"";position:absolute;inset:0;border-radius:2.5rem;pointer-events:none}.profile:before{background:radial-gradient(circle at 10% 10%,rgba(249,115,22,.15),transparent 45%)}.profile:after{background:radial-gradient(circle at 80% 0%,rgba(14,165,233,.08),transparent 55%);mix-blend-mode:screen}.profile__stack,.profile__sections{display:flex;flex-direction:column}.profile__stack{gap:1.25rem;width:100%;max-width:760px;margin:0 auto;position:relative;z-index:1}.profile__sections{gap:.65rem}.profile__section{padding:1.6rem 1.75rem;border-radius:var(--radius-xl);border:1px solid rgba(148,163,184,.18);background:linear-gradient(145deg,#070b19f2,#060812e6);box-shadow:0 25px 60px #02061773;position:relative;overflow:hidden;z-index:0}.profile__section:before{content:"";position:absolute;inset:0;border-radius:inherit;border:1px solid rgba(94,234,212,.05);pointer-events:none;opacity:.6}.profile__section>*{position:relative;z-index:1}.profile__section--about{background:linear-gradient(120deg,#0d1736f2,#111029f2)}.profile__section--stacked{border-radius:var(--radius-lg)}.profile__section--stacked+.profile__section--stacked{margin-top:-.2rem}.profile__section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.profile__section-subtitle{color:#e2e8f0b3;font-size:.85rem;margin-top:.2rem}.profile__section-body{display:flex;flex-direction:column;gap:.75rem}.profile__section-body--accent{background:#020617cc;border:1px solid rgba(94,234,212,.06);border-radius:1rem;padding:1.25rem}.profile__section-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.profile__section-list li{border-radius:var(--radius-md);border:1px solid rgba(248,250,252,.08);background:#0f172a8c;padding:.85rem 1rem;display:flex;align-items:center;justify-content:space-between}.profile__section-list li span{font-size:.95rem}.profile__section-empty{color:#e2e8f0a6;font-style:italic}.profile__section-footer{margin-top:1rem;display:flex;justify-content:flex-end}.profile__timestamp-pill{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;border-radius:999px;border:1px solid rgba(148,163,184,.35);padding:.35rem .85rem;color:#e2e8f0cc}.profile__bio{margin:0;line-height:1.6;color:#f8fafce0}.profile__hero{display:flex;justify-content:space-between;gap:1.5rem;align-items:center;flex-wrap:wrap;background:linear-gradient(135deg,#0f172af2,#0a1122e6);border:1px solid rgba(59,130,246,.22)}.profile__hero-details{display:flex;flex-direction:column;gap:.85rem;flex:1}.profile__identity{display:flex;align-items:center;gap:1rem}.profile__identity img,.profile__avatar-placeholder{width:88px;height:88px;border-radius:1rem;object-fit:cover}.profile__identity img{border:1px solid var(--clr-border)}.profile__avatar-placeholder{border:1px dashed var(--clr-border);background:#94a3b826}.profile__location{font-size:.9rem;color:var(--clr-muted)}.profile__tagline{margin:0;font-size:1rem;color:var(--clr-muted)}.profile__hero-actions{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;flex-wrap:wrap}.profile__mode-pill{font-size:.78rem;color:#f8fafcd9;border:1px solid rgba(248,250,252,.25);border-radius:999px;padding:.35rem .85rem;background:#0f172a80;text-transform:uppercase;letter-spacing:.08em}.profile__timestamp{font-size:.75rem;color:var(--clr-muted)}.profile__editor{display:flex;flex-direction:column;gap:1rem}.profile__editor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.profile__textarea{min-height:120px;resize:vertical}.profile__editor-actions{display:flex;justify-content:flex-end;gap:.75rem}.profile__empty-state{display:flex;flex-direction:column;gap:.75rem;text-align:center}.search{display:flex;flex-direction:column;gap:1rem}.search__field{display:flex;gap:.75rem;align-items:center}.search__field input{flex:1;border-radius:.9rem;border:1px solid var(--clr-border);background:#090f1fcc;padding:1rem 1.25rem;color:var(--clr-text)}.search__filters{display:flex;flex-wrap:wrap;gap:.5rem}.chip{border-radius:999px;border:1px solid var(--clr-border);background:transparent;padding:.4rem 1rem;color:var(--clr-muted);cursor:pointer}.chip--active{background:#f973162e;color:var(--clr-text)}.library,.auth-grid{display:flex;flex-direction:column;gap:1.5rem}.library--story{padding-bottom:2rem;width:100%;display:flex;justify-content:center}.catalog-shell{width:min(1560px,100%);border:0;box-shadow:none;background:transparent}.catalog-shell__body{display:flex;flex-direction:column;padding:.25rem 0;gap:1.25rem;width:100%}.search--catalog{gap:.75rem}.catalog-search-island{border:1px solid rgba(148,163,184,.18);border-radius:var(--radius-lg);background:linear-gradient(145deg,#080d1deb,#081225e6);padding:.85rem 1rem;box-shadow:0 10px 20px #0206173d;position:sticky;top:.85rem;z-index:9}.catalog-nav{display:flex;align-items:center;justify-content:space-between;gap:.75rem;border:1px solid rgba(148,163,184,.18);border-radius:var(--radius-lg);padding:.65rem .75rem;background:#0f172ab8}.catalog-nav__crumbs{display:flex;align-items:center;flex-wrap:wrap;gap:.25rem}.catalog-nav__crumb--active{color:var(--clr-text)}.catalog-nav__crumb{display:inline-flex;align-items:center;padding:.35rem .5rem;border-radius:var(--radius-sm)}.catalog-content{display:grid;grid-template-columns:1fr;gap:1rem;width:100%}.catalog-content--detail{grid-template-columns:1fr}.catalog-results{border:1px solid rgba(148,163,184,.18);border-radius:var(--radius-lg);background:#080e1dd1;padding:1rem;display:flex;flex-direction:column;gap:.85rem}.catalog-results__header h3{margin-top:.25rem}.catalog-section{display:flex;flex-direction:column;gap:.55rem}.catalog-loading{position:relative;display:flex;flex-direction:column;align-items:center;gap:.8rem;min-height:180px;justify-content:center;border:1px solid rgba(148,163,184,.22);border-radius:var(--radius-lg);background:linear-gradient(160deg,#080e1ed1,#0d1a33c7);overflow:hidden}.catalog-loading__halo{position:absolute;inset:auto auto -48% -22%;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,#f9731659,#f9731600 68%);filter:blur(8px);animation:catalogHalo 1.8s ease-in-out infinite alternate}.catalog-loading__bars{display:inline-flex;align-items:flex-end;gap:.35rem;z-index:1}.catalog-loading__bars span{width:7px;border-radius:999px;background:linear-gradient(180deg,#fbbf24f2,#f97316cc);animation:catalogBars .95s ease-in-out infinite}.catalog-loading__bars span:nth-child(1){height:15px;animation-delay:0s}.catalog-loading__bars span:nth-child(2){height:26px;animation-delay:.08s}.catalog-loading__bars span:nth-child(3){height:34px;animation-delay:.16s}.catalog-loading__bars span:nth-child(4){height:24px;animation-delay:.24s}.catalog-loading__bars span:nth-child(5){height:16px;animation-delay:.32s}.catalog-loading__label{margin:0;z-index:1;font-size:.88rem;color:#e2e8f0f2;letter-spacing:.03em}@keyframes catalogBars{0%,to{transform:scaleY(.55);opacity:.58}50%{transform:scaleY(1.05);opacity:1}}@keyframes catalogHalo{0%{transform:translateZ(0) scale(.95);opacity:.72}to{transform:translate3d(26px,-10px,0) scale(1.08);opacity:1}}.catalog-section h4{font-size:.95rem;letter-spacing:.12em;text-transform:uppercase;color:var(--clr-muted)}.catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:.8rem}.catalog-card{border:1px solid rgba(148,163,184,.22);border-radius:var(--radius-lg);background:linear-gradient(145deg,#0f172aeb,#0a1122eb);padding:.9rem;color:var(--clr-text);text-align:left;display:flex;flex-direction:column;gap:.35rem;cursor:pointer}.catalog-card:disabled{opacity:.55;cursor:not-allowed}.catalog-card:not(:disabled):hover,.catalog-card:not(:disabled):focus-visible{border-color:#f973168c;transform:translateY(-1px)}.catalog-card h5{font-size:1rem}.catalog-card__media{width:100%;aspect-ratio:1 / 1;border-radius:.8rem;border:1px solid rgba(148,163,184,.2);background:#0f172acc;display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:1.35rem;color:var(--clr-muted)}.catalog-card__media img{width:100%;height:100%;object-fit:cover}.catalog-card__media--genre{background:linear-gradient(140deg,#f9731640,#0ea5e933);color:#f8fafce6}.catalog-track-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.catalog-track-list--table{border:1px solid rgba(148,163,184,.24);border-radius:var(--radius-lg);overflow:hidden;gap:0}.catalog-track-item{border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-md);background:#080e1db8;padding:.7rem .85rem;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.75rem;transition:border-color .12s ease,background-color .12s ease,transform .12s ease}.catalog-track-list--table .catalog-track-item{border:0;border-bottom:1px solid rgba(148,163,184,.2);border-radius:0;background:#080e1dbd}.catalog-track-list--table .catalog-track-item:last-child{border-bottom:0}.catalog-track-item--header{background:#0f172ae6;color:var(--clr-muted);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;pointer-events:none}.catalog-track-main{display:grid;grid-template-columns:2rem minmax(0,1fr);align-items:center;gap:.6rem;min-width:0}.catalog-track-index{color:#94a3b8e0;font-size:.82rem;font-variant-numeric:tabular-nums}.catalog-track-main__text{min-width:0}.catalog-track-main__text strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.catalog-track-item--interactive{cursor:pointer}.catalog-track-item--interactive:hover{border-color:#f9731680;background:#0f172ae0;transform:translateY(-1px)}.catalog-track-list--table .catalog-track-item--interactive:hover{transform:none}.catalog-track-item--active{border-color:#f97316f2;box-shadow:inset 3px 0 #f97316f2}.catalog-track-meta{display:inline-flex;align-items:center;justify-content:flex-end;gap:.55rem;min-width:90px;font-variant-numeric:tabular-nums}.catalog-track-state{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--clr-accent-soft);border:1px solid rgba(249,115,22,.4);border-radius:999px;padding:.2rem .45rem}.catalog-detail{min-height:420px;border:1px solid rgba(148,163,184,.18);border-radius:var(--radius-lg);background:linear-gradient(150deg,#070b19f5,#050914f0)}.catalog-detail__body{padding:1.25rem;display:flex;flex-direction:column;gap:.95rem}.catalog-detail--full{min-height:min(78vh,920px)}.catalog-placeholder{display:flex;flex-direction:column;gap:.75rem}.detail-view{display:flex;flex-direction:column;gap:.9rem}.catalog-hero{display:grid;grid-template-columns:160px minmax(0,1fr);gap:1rem;border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-lg);padding:.95rem;background:linear-gradient(140deg,#120e1ddb,#081838d1)}.catalog-hero__art{width:160px;height:160px;border-radius:.85rem;border:1px solid rgba(148,163,184,.25);overflow:hidden;background:#0f172ad9;color:var(--clr-muted);display:inline-flex;align-items:center;justify-content:center;font-size:2rem}.catalog-hero__art img{width:100%;height:100%;object-fit:cover}.catalog-hero__body{display:flex;flex-direction:column;gap:.55rem;min-width:0}.catalog-hero__body h3{margin-top:0}.catalog-hero__lede{margin:0;color:#e2e8f0f2;line-height:1.45}.catalog-hero__facts{display:flex;flex-wrap:wrap;gap:.4rem}.catalog-hero__supporting{margin:0;color:#94a3b8f2;font-size:.88rem}.detail-actions{display:flex;gap:.75rem;flex-wrap:wrap}.catalog-chip-row{display:flex;flex-wrap:wrap;gap:.45rem}.catalog-detail-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.catalog-detail-list__row{border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-md);background:#080e1db3;padding:.7rem;display:grid;grid-template-columns:auto 42px 1fr auto;gap:.75rem;align-items:center}.catalog-detail-list__art{width:42px;height:42px;border-radius:.6rem;border:1px solid rgba(148,163,184,.2);overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--clr-muted);background:#0f172acc}.catalog-detail-list__art img{width:100%;height:100%;object-fit:cover}.auth-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.auth-grid--centered{min-height:calc(100vh - 5rem);justify-content:center;overflow:hidden;align-items:center}.login-form__actions{display:flex;flex-direction:column;gap:.65rem}.login-form__link,.login-form__spotify{text-align:center}.results{display:flex;flex-direction:column;gap:1.25rem}.results__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.result-list{background:#09091499;border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1rem;display:flex;flex-direction:column;gap:.75rem}.result-list ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.playback-dock{grid-column:2 / 3;grid-row:3 / 4;border-top:1px solid rgba(148,163,184,.2);background:#050914eb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:sticky;bottom:0;z-index:5}.playback-dock__panel{display:grid;grid-template-columns:minmax(220px,1fr) 2fr minmax(200px,.7fr);gap:1.5rem;padding:1rem 2.5rem;align-items:center}.playback-dock__meta{display:flex;align-items:center;gap:1rem;min-width:0}.playback-dock__meta--empty{padding:.5rem 0;font-size:.95rem;color:var(--clr-muted)}.playback-dock__artwork{width:56px;height:56px;border-radius:var(--radius-md);overflow:hidden;border:1px solid rgba(148,163,184,.25);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem}.playback-dock__artwork img{width:100%;height:100%;object-fit:cover}.playback-dock__details{display:flex;flex-direction:column;gap:.2rem;min-width:0}.playback-dock__title{font-weight:600;margin:0}.playback-dock__subtitle{margin:0;font-size:.85rem;color:var(--clr-muted)}.playback-dock__subtitle--album{font-size:.78rem}.playback-dock__artwork-link{display:inline-flex;border-radius:var(--radius-md)}.playback-dock__link{color:var(--clr-text);text-decoration:none}.playback-dock__subtitle .playback-dock__link,.playback-dock__subtitle--album .playback-dock__link{color:var(--clr-muted)}.playback-dock__link:hover,.playback-dock__link:focus-visible{text-decoration:underline;text-underline-offset:2px}.playback-dock__controls{display:flex;flex-direction:column;gap:.75rem}.playback-dock__buttons{display:flex;gap:.5rem}.playback-dock__control{width:44px;height:44px;border-radius:var(--radius-pill);border:1px solid rgba(148,163,184,.35);background:#0f172ab3;color:var(--clr-text);display:flex;align-items:center;justify-content:center}.playback-dock__control:disabled{opacity:.5;cursor:not-allowed}.playback-dock__control svg{width:18px;height:18px;fill:currentColor}.playback-dock__progress{display:grid;grid-template-columns:auto 1fr auto;gap:.5rem;align-items:center;font-size:.8rem;color:var(--clr-muted)}.playback-dock__progress-track{position:relative;height:8px;border-radius:999px;background:#33415599;overflow:visible}.playback-dock__progress-bar{position:absolute;inset:0 auto 0 0;height:100%;border-radius:inherit;background:linear-gradient(90deg,#f97316,#fb923c)}.playback-dock__scrubber{position:absolute;inset:-8px 0;width:100%;margin:0;appearance:none;background:transparent;cursor:pointer}.playback-dock__scrubber:disabled{cursor:not-allowed}.playback-dock__scrubber::-webkit-slider-runnable-track{height:8px;background:transparent}.playback-dock__scrubber::-moz-range-track{height:8px;background:transparent;border:0}.playback-dock__scrubber::-webkit-slider-thumb{appearance:none;width:14px;height:14px;margin-top:-3px;border-radius:50%;border:1px solid rgba(250,204,21,.95);background:#facc15f2;box-shadow:0 0 #facc1573;transform:scale(.65);opacity:0;transition:opacity .14s ease,transform .14s ease}.playback-dock__scrubber::-moz-range-thumb{width:14px;height:14px;border-radius:50%;border:1px solid rgba(250,204,21,.95);background:#facc15f2;box-shadow:0 0 #facc1573;transform:scale(.65);opacity:0;transition:opacity .14s ease,transform .14s ease}.playback-dock__progress-track:hover .playback-dock__scrubber::-webkit-slider-thumb,.playback-dock__scrubber:focus-visible::-webkit-slider-thumb,.playback-dock__scrubber:active::-webkit-slider-thumb{opacity:1;transform:scale(1);animation:scrubOrbPulse 1.2s ease-in-out infinite}.playback-dock__progress-track:hover .playback-dock__scrubber::-moz-range-thumb,.playback-dock__scrubber:focus-visible::-moz-range-thumb,.playback-dock__scrubber:active::-moz-range-thumb{opacity:1;transform:scale(1);animation:scrubOrbPulse 1.2s ease-in-out infinite}.playback-dock__status{display:flex;flex-direction:column;gap:.25rem;align-items:flex-end}.playback-dock__device{margin:0;font-size:.9rem}.playback-dock__provider{margin:0;font-size:.7rem;letter-spacing:.3em;color:var(--clr-muted)}.playback-dock__error{margin:0;color:var(--clr-warning);font-size:.8rem}.playback-dock__spinner{width:12px;height:12px;border-radius:50%;border:2px solid rgba(148,163,184,.2);border-top-color:var(--clr-accent);animation:spin .75s linear infinite}.stats{font-size:.85rem;color:var(--clr-accent-soft)}.track-card{display:flex;align-items:center;gap:1rem;width:100%;border:1px solid var(--clr-border);background:#0f172ad9;cursor:default;text-align:left;transition:border-color .14s ease,transform .14s ease}.track-card:disabled{opacity:.6;cursor:not-allowed}.track-card--interactive{cursor:pointer}.track-card--interactive:hover:not(:disabled),.track-card--interactive:focus-visible:not(:disabled){border-color:#f9731673;transform:translateY(-1px)}.track-card--active{border-color:#f97316e6;box-shadow:0 10px 30px #f9731659}.track-card__actions{margin-left:auto;width:42px;height:42px;border-radius:50%;border:1px solid rgba(148,163,184,.4);display:flex;align-items:center;justify-content:center;background:#0f172ab3}.track-card__actions svg{width:16px;height:16px;fill:currentColor}.track-card__spinner{width:16px;height:16px;border:2px solid rgba(249,115,22,.2);border-top-color:var(--clr-accent);border-radius:50%;animation:spin .8s linear infinite}.spinner{display:flex;gap:.35rem}.spinner__dot{width:.5rem;height:.5rem;border-radius:50%;background:var(--clr-accent);animation:pulse 1s infinite ease-in-out}.spinner__dot:nth-child(2){animation-delay:.1s}.spinner__dot:nth-child(3){animation-delay:.2s}@keyframes pulse{0%,to{transform:scale(.8);opacity:.6}50%{transform:scale(1);opacity:1}}@keyframes scrubOrbPulse{0%{box-shadow:0 0 #facc1559}to{box-shadow:0 0 0 8px #facc1500}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:960px){.app-shell{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.app-shell--sidebar-open{overflow:hidden}.sidebar{position:fixed;inset:0 auto 0 0;width:min(86vw,320px);max-width:100%;grid-row:auto;grid-column:auto;transform:translate(-110%);transition:transform .2s ease;z-index:20;flex-direction:column;align-items:stretch;justify-content:flex-start}.sidebar--open{transform:translate(0)}.sidebar__close{display:inline-flex}.app-shell__content{grid-column:1;grid-row:2 / 3;padding:1.5rem}.playback-dock{grid-column:1;grid-row:3 / 4;position:sticky}.playback-dock__panel{grid-template-columns:1fr;gap:1rem}.sidebar__nav{flex-direction:column}.sidebar-overlay--visible{display:block}.profile__hero{flex-direction:column;align-items:flex-start;gap:1rem}.profile__hero-actions{width:100%;align-items:flex-start;text-align:left}.catalog-content{grid-template-columns:1fr}.catalog-detail{min-height:0}}@media(max-width:720px){.app-shell__content{padding:1.25rem;gap:1.5rem}.sidebar{padding:1.25rem;gap:1rem;flex-direction:column;align-items:stretch}.sidebar__nav{flex-direction:column;align-items:stretch;gap:.35rem}.sidebar__link{width:100%;padding:.4rem .6rem;font-size:.95rem}.sidebar-search{width:100%}.sidebar-search__results{max-height:240px}.app-header{flex-direction:column;align-items:flex-start}.card__body{padding:1.25rem}.results__grid{grid-template-columns:1fr}.playback-dock__panel{padding:.85rem 1.25rem}.playback-dock__meta,.playback-dock__buttons{flex-wrap:wrap}.profile{padding:1.75rem 0 2rem}.profile__section{padding:1.25rem}.profile__section-header{flex-direction:column;align-items:flex-start}.profile__section-list li{flex-direction:column;align-items:flex-start;gap:.35rem}.catalog-nav{flex-direction:column;align-items:flex-start}.catalog-grid,.catalog-hero{grid-template-columns:1fr}.catalog-hero__art{width:112px;height:112px}.catalog-track-item,.catalog-detail-list__row{grid-template-columns:1fr;align-items:flex-start}.catalog-track-main{grid-template-columns:1.6rem minmax(0,1fr)}.catalog-track-meta{width:100%;justify-content:flex-start;min-width:0}}@media(max-width:560px){.sidebar{align-items:flex-start}.sidebar__nav{flex-direction:column;align-items:stretch}.playback-dock__panel{gap:.75rem;padding:.75rem 1rem}.playback-dock__artwork{width:48px;height:48px}.playback-dock__status{align-items:flex-start}.profile__section{padding:1.05rem}}
