*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0a;--surface: rgba(255, 255, 255, .04);--surface-hover: rgba(255, 255, 255, .07);--border: rgba(255, 255, 255, .08);--border-focus: rgba(29, 185, 84, .45);--accent: #1db954;--accent-dim: rgba(29, 185, 84, .15);--accent-glow: 0 0 28px rgba(29, 185, 84, .4);--text: #ffffff;--text-secondary: rgba(255, 255, 255, .62);--text-muted: rgba(255, 255, 255, .35);--radius-lg: 20px;--radius-md: 12px;--radius-sm: 10px;--font: "Inter", system-ui, -apple-system, sans-serif}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;display:flex;flex-direction:column}.app-container{display:flex;flex-direction:column;height:100dvh;position:relative;overflow:hidden}.bg-gradient{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 70% 50% at 15% 5%,rgba(29,185,84,.09) 0%,transparent 60%),radial-gradient(ellipse 50% 55% at 85% 95%,rgba(29,185,84,.06) 0%,transparent 60%);animation:ambient-shift 12s ease-in-out infinite alternate}@keyframes ambient-shift{0%{opacity:.7}to{opacity:1}}.header{position:relative;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.5rem;border-bottom:1px solid var(--border);background:#0a0a0ad9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.header-logo{display:flex;align-items:center;gap:.5rem;font-weight:800;font-size:1.0625rem;letter-spacing:-.025em}.header-logo svg{color:var(--accent);flex-shrink:0}.logo-text{display:inline-flex;align-items:baseline}.logo-music{color:var(--accent)}.logo-shared-c{background:linear-gradient(135deg,var(--accent) 30%,#a78bfa 70%);-webkit-background-clip:text;background-clip:text;color:transparent}.logo-chat{color:#a78bfa}.header-actions{display:flex;align-items:center;gap:.75rem}.status-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:500;color:var(--text-secondary);padding:.3rem .75rem;background:var(--surface);border:1px solid var(--border);border-radius:100px}.status-badge:before{content:"";display:block;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);flex-shrink:0}.main{flex:1;position:relative;z-index:1;overflow:hidden;display:flex;flex-direction:column}.login-outer{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem}.login-card{width:100%;max-width:420px;text-align:center;padding:3rem 2.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.login-eyebrow{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:1.25rem}.login-title{font-size:clamp(1.75rem,4vw,2.25rem);font-weight:800;letter-spacing:-.035em;line-height:1.15;margin-bottom:.875rem}.login-subtitle{font-size:.9375rem;color:var(--text-secondary);line-height:1.65;margin-bottom:2.25rem}.chat-outer{flex:1;display:flex;flex-direction:column;max-width:820px;width:100%;margin:0 auto;overflow:hidden}.messages-list{flex:1;overflow-y:auto;padding:1.5rem 1.5rem .75rem;display:flex;flex-direction:column;gap:.875rem;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.messages-list::-webkit-scrollbar{width:4px}.messages-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-muted);font-size:.9rem;min-height:200px}.chat-empty-icon{font-size:2rem;margin-bottom:.25rem}.message{display:flex;flex-direction:column;max-width:min(78%,620px)}.message.user{align-self:flex-end;align-items:flex-end}.message.assistant{align-self:flex-start;align-items:flex-start}.message-bubble{padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.9375rem;line-height:1.65;white-space:pre-wrap;word-break:break-word}.message.user .message-bubble{background:var(--accent-dim);border:1px solid rgba(29,185,84,.25);border-bottom-right-radius:4px}.message.assistant .message-bubble{background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px}.message-meta{font-size:.7rem;color:var(--text-muted);margin-top:.3rem;padding:0 .25rem}.message.system{align-self:center;align-items:center;max-width:min(90%,520px)}.message-system-note{padding:.4rem .875rem;background:#1db95412;border:1px solid rgba(29,185,84,.18);border-radius:999px;font-size:.8125rem;color:var(--text-secondary);font-style:italic;text-align:center;line-height:1.45}.typing-indicator{display:inline-flex;align-items:center;gap:3px;padding:.7rem .875rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);border-bottom-left-radius:4px;align-self:flex-start}.typing-bar{width:3px;background:var(--accent);border-radius:3px;animation:music-pulse .9s ease-in-out infinite}.typing-bar:nth-child(1){height:12px;animation-delay:0s}.typing-bar:nth-child(2){height:20px;animation-delay:.14s}.typing-bar:nth-child(3){height:8px;animation-delay:.28s}.typing-bar:nth-child(4){height:16px;animation-delay:.42s}@keyframes music-pulse{0%,to{transform:scaleY(.45);opacity:.45}50%{transform:scaleY(1);opacity:1}}.input-bar{display:flex;align-items:flex-end;gap:.625rem;padding:1rem 1.5rem;border-top:1px solid var(--border);background:#0a0a0ae6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.input-field{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:.9375rem;line-height:1.5;padding:.6875rem 1rem;resize:none;outline:none;overflow-x:hidden;overflow-y:auto;transition:border-color .2s;height:44px;font-size:1rem}.input-field::placeholder{color:var(--text-muted)}.input-field:focus{border-color:var(--border-focus)}.btn-send{width:44px;height:44px;flex-shrink:0;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#000;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s}.btn-send:disabled{opacity:.45;cursor:not-allowed}.btn-send:not(:disabled):hover{opacity:.85}.btn-ghost{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font);font-size:.8rem;padding:.3rem .75rem;cursor:pointer;transition:border-color .2s,color .2s;white-space:nowrap}.btn-ghost:hover{border-color:#fff3;color:var(--text)}.btn-spotify{display:inline-flex;align-items:center;justify-content:center;gap:.625rem;background:var(--accent);color:#000;font-family:var(--font);font-weight:700;font-size:.9375rem;padding:.875rem 2rem;border:none;border-radius:100px;cursor:pointer;transition:transform .15s,box-shadow .15s}.btn-spotify:hover{box-shadow:var(--accent-glow)}.app-container:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;pointer-events:none;opacity:.03;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)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:128px 128px;mix-blend-mode:overlay}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.header-menu{position:relative}.btn-menu{display:flex;align-items:center;justify-content:center;position:relative;width:36px;height:36px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:border-color .2s,color .2s}.btn-menu:hover,.btn-menu[aria-expanded=true]{border-color:#fff3;color:var(--text)}.menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:#121212f7;border:1px solid var(--border);border-radius:var(--radius-md);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 8px 32px #00000080;padding:.5rem 0;z-index:200}.menu-section-label{font-size:.7rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);padding:.35rem 1rem .5rem}.menu-info{font-size:.825rem;color:var(--text-muted);padding:.35rem 1rem .5rem}.menu-open-spotify{display:block;color:#1db954;text-decoration:none;transition:opacity .15s}.menu-open-spotify:hover{opacity:.8;text-decoration:underline}.menu-item{display:flex;align-items:center;gap:.55rem;width:100%;background:none;border:none;color:var(--text-secondary);font-family:var(--font);font-size:.875rem;padding:.55rem 1rem;cursor:pointer;text-align:left;transition:background .15s,color .15s}.menu-item:hover{background:var(--surface-hover);color:var(--text)}.menu-device-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-device-item.selected{color:var(--accent)}.menu-divider{height:1px;background:var(--border);margin:.4rem 0}.menu-logout-item{color:var(--text-secondary)}.menu-logout-item:hover{color:#ff5f5f}.btn-dj{display:flex;align-items:center;justify-content:center;position:relative;width:36px;height:36px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:border-color .2s,color .2s,background .2s}.btn-dj:hover{border-color:#fff3;color:var(--text)}.btn-dj.dj-active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.dj-dot{position:absolute;top:5px;right:5px;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent);animation:dj-pulse 1.8s ease-in-out infinite}@keyframes dj-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}.player-bar{position:relative;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.625rem 1.25rem;background:#0a0a0abf;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.player-track{display:flex;align-items:center;gap:.75rem;min-width:0;flex:1}.player-album-art{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0}.player-album-placeholder{background:var(--surface);border:1px solid var(--border)}.player-track-info{display:flex;flex-direction:column;min-width:0}.player-track-name{font-size:.875rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-track-artist{font-size:.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-controls{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.player-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:none;border:none;color:var(--text-secondary);cursor:pointer;transition:color .15s,background .15s}.player-btn:hover:not(:disabled){color:var(--text);background:var(--surface)}.player-btn:disabled{opacity:.35;cursor:default}.player-btn-play{width:38px;height:38px;background:var(--accent);color:#000}.player-btn-play:hover:not(:disabled){background:var(--accent);color:#000;opacity:.85}.player-badge{display:none;align-items:center;gap:.35rem;font-size:.72rem;color:var(--text-muted);flex-shrink:0}@media(min-width:480px){.player-badge{display:flex}}.player-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent);flex-shrink:0}.player-badge-external{color:var(--text-muted);font-size:.72rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.player-volume{display:none;align-items:center;gap:.375rem;flex-shrink:0}@media(min-width:560px){.player-volume{display:flex}}.player-volume-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;transition:color .15s;flex-shrink:0}.player-volume-btn:hover{color:var(--text)}.player-volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:80px;height:3px;border-radius:2px;outline:none;cursor:pointer;background:linear-gradient(to right,var(--accent) 0%,var(--accent) var(--vol, 80%),rgba(255,255,255,.15) var(--vol, 80%),rgba(255,255,255,.15) 100%);transition:height .15s}.player-volume-slider:hover{height:4px}.player-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--text);cursor:pointer;transition:transform .1s,background .15s}.player-volume-slider:hover::-webkit-slider-thumb{transform:scale(1.2);background:var(--accent)}.player-volume-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;border:none;background:var(--text);cursor:pointer;transition:transform .1s,background .15s}.player-volume-slider:hover::-moz-range-thumb{transform:scale(1.2);background:var(--accent)}.player-queue-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;flex-shrink:0;transition:color .15s}.player-queue-btn:hover{color:var(--text)}.queue-drawer{position:relative;z-index:9;background:#0a0a0aeb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border)}.queue-drawer-inner{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1.25rem;max-height:280px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.queue-drawer-inner::-webkit-scrollbar{width:4px}.queue-drawer-inner::-webkit-scrollbar-track{background:transparent}.queue-drawer-inner::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.queue-drawer-title{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.queue-empty{font-size:.82rem;color:var(--text-muted);padding:.5rem 0}.queue-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.125rem}.queue-item-btn{display:flex;align-items:center;gap:.625rem;width:100%;padding:.375rem .5rem;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:background .15s}.queue-item-btn:hover{background:var(--surface-hover)}.queue-item-art{width:32px;height:32px;border-radius:4px;object-fit:cover;flex-shrink:0}.queue-item-art-placeholder{background:var(--surface);border:1px solid var(--border)}.queue-item-info{display:flex;flex-direction:column;min-width:0}.queue-item-name{font-size:.82rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-item-artist{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-bubble{display:flex;flex-direction:column;gap:.3rem}.msg-h1,.msg-h2,.msg-h3{font-weight:700;line-height:1.3;margin-top:.5rem}.msg-h1{font-size:1rem}.msg-h2{font-size:.9375rem}.msg-h3{font-size:.875rem;color:var(--accent)}.msg-p{margin:0;line-height:1.55}.msg-list-item{padding-left:1rem;line-height:1.55;position:relative}.msg-list-item--bullet:before{content:"•";position:absolute;left:0;color:var(--accent)}.track-actions{display:inline-flex;align-items:center;gap:.3rem;vertical-align:middle}.track-actions-label{font-size:.78rem;color:var(--text-muted)}.btn-track{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;border:none;cursor:pointer;flex-shrink:0;transition:transform .15s,opacity .15s}.btn-track:hover{transform:scale(1.15)}.btn-track:active{transform:scale(.92)}.btn-track-play{background:var(--accent);color:#000}.btn-track-queue{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.btn-track-queue:hover{color:var(--text)}.festival-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:flex;align-items:flex-start;justify-content:center;background:#000000c7;padding:2rem 1rem;overflow-y:auto}.festival-wrapper{display:flex;flex-direction:column;align-items:stretch;width:100%;max-width:860px;margin-bottom:2rem}.festival-toolbar{display:flex;justify-content:flex-end;align-items:center;gap:.5rem;padding-bottom:.5rem}.festival-download-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);border-radius:6px;color:#ffffffd9;font-size:.82rem;font-weight:600;letter-spacing:.03em;cursor:pointer;transition:background .2s,color .2s,border-color .2s}.festival-download-btn:hover:not(:disabled){background:#ffffff38;color:#fff;border-color:#ffffff73}.festival-download-btn:disabled{opacity:.45;cursor:not-allowed}.festival-poster{position:relative;width:100%;background:linear-gradient(155deg,#3d0066,#c0006e 38%,#f50 72%,#ffc200);padding:2rem 2.5rem;color:#fff;text-align:center;overflow:hidden}.fp-deco{position:absolute;top:0;pointer-events:none;z-index:0}.fp-deco--left{left:0}.fp-deco--right{right:0}.festival-close{background:#ffffff12;border:1px solid rgba(255,255,255,.1);border-radius:50%;color:#ffffff73;width:32px;height:32px;font-size:.78rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,color .2s}.festival-close:hover{background:#ffffff24;color:#fff}.fp-header{position:relative;z-index:1;padding-bottom:.6rem}.fp-title{font-family:Bebas Neue,Barlow Condensed,Impact,Franklin Gothic Heavy,sans-serif;font-size:clamp(2.8rem,10vw,6rem);font-weight:400;letter-spacing:.04em;line-height:.88;text-transform:uppercase;margin-bottom:.1rem}.fp-title-main{color:#fff}.fp-title-accent{color:var(--accent)}.fp-year{font-family:Bebas Neue,Barlow Condensed,Impact,sans-serif;font-size:clamp(1.3rem,3.5vw,2rem);font-weight:400;letter-spacing:.18em;color:#fff6;margin-bottom:.2rem;line-height:1}.fp-location{font-family:Barlow Condensed,Arial Narrow,Arial,sans-serif;font-size:clamp(.85rem,1.8vw,1.1rem);font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:#fff9;margin-bottom:.25rem;line-height:1}.fp-tagline{font-family:Barlow Condensed,Arial Narrow,Arial,sans-serif;font-size:clamp(.62rem,1.05vw,.68rem);font-weight:600;letter-spacing:.42em;font-style:italic;color:#ffffff8c;text-transform:uppercase;margin-bottom:.2rem}.fp-daterange{font-family:Barlow Condensed,sans-serif;font-size:clamp(.6rem,.9vw,.62rem);font-weight:600;letter-spacing:.22em;color:#ffffff80;text-transform:uppercase}.fp-lineup{position:relative;z-index:1}.fp-day{padding:.25rem 1.5rem;border-top:1px solid rgba(255,255,255,.22)}.fp-dateline{font-family:Barlow Condensed,Arial Narrow,Arial,sans-serif;font-size:clamp(.58rem,.82vw,.62rem);font-weight:700;letter-spacing:.22em;color:#ffffff8c;text-transform:uppercase;margin-bottom:.25rem}.fp-tier-1{margin:0 0 .15rem;line-height:1}.fp-headliner{font-family:Bebas Neue,Barlow Condensed,Impact,Franklin Gothic Heavy,sans-serif;font-size:clamp(2.4rem,7.5vw,4.8rem);font-weight:400;letter-spacing:.03em;line-height:1;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.85),0 1px 3px rgba(0,0,0,.9)}.fp-headliner-dot{font-family:Bebas Neue,Barlow Condensed,Impact,sans-serif;font-size:clamp(2.4rem,7.5vw,4.8rem);color:#ffffff73;font-weight:400}.fp-headliner.fp-fav{color:var(--accent)}.fp-tier-2{font-family:Barlow Condensed,Impact,Arial Narrow,sans-serif;font-size:clamp(1.5rem,3.8vw,2.4rem);font-weight:800;letter-spacing:.05em;color:#fffffff2;text-transform:uppercase;margin:0 0 .05rem;line-height:1.05;text-shadow:0 1px 6px rgba(0,0,0,.8)}.fp-tier-3{font-family:Barlow Condensed,Arial Narrow,Arial,sans-serif;font-size:clamp(1.1rem,2.2vw,1.55rem);font-weight:700;letter-spacing:.06em;color:#ffffffe6;text-transform:uppercase;margin:0 0 .05rem;line-height:1.1;text-shadow:0 1px 5px rgba(0,0,0,.75)}.fp-tier-4{font-family:Barlow Condensed,Arial Narrow,Arial,sans-serif;font-size:clamp(.95rem,1.6vw,1.2rem);font-weight:600;letter-spacing:.08em;color:#fff;text-transform:uppercase;margin:0;line-height:1.1;text-shadow:0 1px 5px rgba(0,0,0,.8)}.fp-dot{color:#ffffff61}.fp-fav{color:var(--accent)}.fp-generated-by{position:relative;z-index:1;font-family:Barlow Condensed,Arial Narrow,Arial,sans-serif;font-size:clamp(.55rem,.8vw,.65rem);font-weight:600;letter-spacing:.18em;color:#ffffff59;margin-top:.6rem;padding-bottom:.2rem}.festival-status{position:relative;z-index:1;color:#ffffff73;font-size:.9rem;margin:3rem 0;letter-spacing:.04em}.festival-error{color:#ff6b6b}@media(max-width:600px){.festival-overlay{padding:0}.festival-wrapper{margin-bottom:0;padding:.5rem .5rem 0}.festival-poster{padding:2.5rem 1.25rem 2rem}.fp-deco{opacity:.3}}
