*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #09090f;--bg2: #12121c;--bg3: #1a1a28;--border: #2a2a3e;--purple: #7c3aed;--purple-light:#a855f7;--purple-glow: rgba(124,58,237,.35);--gold: #f59e0b;--gold-light: #fcd34d;--green: #10b981;--red: #ef4444;--text: #e2e8f0;--text-muted: #64748b;--radius: 12px}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.app{min-height:100vh;display:flex;flex-direction:column}.setup-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;background:radial-gradient(ellipse at 50% 0%,rgba(124,58,237,.15) 0%,transparent 70%)}.setup-logo{font-size:3.5rem;margin-bottom:.5rem;filter:drop-shadow(0 0 20px var(--purple))}.setup-title{font-size:2.2rem;font-weight:800;background:linear-gradient(135deg,var(--purple-light),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.25rem}.setup-subtitle{color:var(--text-muted);font-size:.95rem;margin-bottom:2.5rem}.setup-card{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:2rem;width:100%;max-width:560px;box-shadow:0 0 40px #7c3aed1a}.setup-section{margin-bottom:1.5rem}.setup-label{display:block;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.6rem}.setup-input,.setup-textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.75rem 1rem;font-size:.95rem;outline:none;transition:border-color .2s;font-family:inherit}.setup-input:focus,.setup-textarea:focus{border-color:var(--purple)}.setup-textarea{resize:vertical;min-height:80px}.event-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem}.event-btn{background:var(--bg3);border:2px solid var(--border);border-radius:var(--radius);color:var(--text-muted);padding:.75rem .25rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:.3rem;font-size:.75rem;font-weight:600}.event-btn .emoji{font-size:1.6rem}.event-btn:hover{border-color:var(--purple);color:var(--text)}.event-btn.active{border-color:var(--purple);background:#7c3aed33;color:var(--purple-light);box-shadow:0 0 12px var(--purple-glow)}.mood-slider{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;outline:none;background:linear-gradient(to right,var(--green),var(--gold),var(--red))}.mood-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 8px #0006}.mood-row{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);margin-top:.3rem}.btn-start{width:100%;background:linear-gradient(135deg,var(--purple),#5b21b6);border:none;border-radius:var(--radius);color:#fff;font-size:1.05rem;font-weight:700;padding:.9rem;cursor:pointer;transition:all .2s;box-shadow:0 4px 20px var(--purple-glow);margin-top:.5rem}.btn-start:hover{transform:translateY(-1px);box-shadow:0 6px 25px var(--purple-glow)}.btn-start:disabled{opacity:.5;cursor:not-allowed;transform:none}.library-info{text-align:center;font-size:.8rem;color:var(--text-muted);margin-top:1rem}.dj-screen{flex:1;display:flex;flex-direction:column}.dj-header{background:var(--bg2);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.dj-header-left{display:flex;align-items:center;gap:.75rem}.dj-logo{font-size:1.5rem}.dj-title{font-weight:800;font-size:1rem;color:var(--purple-light)}.event-badge{background:#7c3aed33;border:1px solid var(--purple);border-radius:20px;padding:.2rem .75rem;font-size:.75rem;color:var(--purple-light);font-weight:600}.dj-header-right{display:flex;align-items:center;gap:.75rem}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:pulse 2s infinite}.status-dot.paused{background:var(--gold);box-shadow:0 0 6px var(--gold);animation:none}.btn-sm{background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);padding:.35rem .75rem;font-size:.78rem;cursor:pointer;transition:all .2s}.btn-sm:hover{border-color:var(--purple);color:var(--text)}.btn-stop{border-color:var(--red);color:var(--red)}.btn-stop:hover{background:#ef44441a}.dj-body{flex:1;display:grid;grid-template-columns:290px 1fr;grid-template-rows:1fr;gap:1rem;padding:1rem 1.5rem;overflow:hidden}.now-playing{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.85rem;grid-column:2;grid-row:1;overflow-y:auto;min-width:0}.np-top{display:flex;gap:1.25rem;align-items:center}.np-cover{width:80px;height:80px;border-radius:12px;background:linear-gradient(135deg,var(--purple),#1e1e3f);display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0;box-shadow:0 0 20px var(--purple-glow)}.np-cover.playing{animation:spin-slow 8s linear infinite}.np-info{flex:1;min-width:0}.np-title{font-size:1.3rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}.np-artist{color:var(--text-muted);font-size:.9rem;margin-top:.2rem}.np-meta{display:flex;gap:.75rem;margin-top:.5rem;flex-wrap:wrap}.np-tag{background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:.15rem .6rem;font-size:.72rem;color:var(--text-muted)}.progress-wrap{display:flex;align-items:center;gap:.75rem}.progress-time{font-size:.75rem;color:var(--text-muted);width:36px;text-align:center;flex-shrink:0}.progress-bar-bg{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(to right,var(--purple),var(--purple-light));border-radius:2px;transition:width .5s linear}.controls{display:flex;align-items:center;justify-content:center;gap:1rem}.btn-control{background:var(--bg3);border:1px solid var(--border);border-radius:50%;color:var(--text);width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;transition:all .2s}.btn-control:hover{border-color:var(--purple);background:#7c3aed26}.btn-control.primary{background:var(--purple);border-color:var(--purple);width:56px;height:56px;font-size:1.3rem;box-shadow:0 0 15px var(--purple-glow)}.btn-control.primary:hover{background:var(--purple-light)}.mood-control{display:flex;align-items:center;gap:.75rem}.mood-label{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.announcement{background:linear-gradient(135deg,#7c3aed1a,#f59e0b0d);border:1px solid rgba(124,58,237,.3);border-radius:12px;padding:.85rem 1rem;font-style:italic;color:var(--gold-light);font-size:.88rem;line-height:1.5;min-height:60px;display:flex;align-items:center;gap:.5rem}.announcement-icon{font-size:1.1rem;flex-shrink:0}.sidebar{display:flex;flex-direction:column;gap:1rem;overflow-y:auto;grid-column:1;grid-row:1}.sidebar-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;overflow:hidden}.sidebar-card-header{padding:.75rem 1rem;background:var(--bg3);border-bottom:1px solid var(--border);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);display:flex;align-items:center;gap:.4rem}.next-track{padding:1rem;display:flex;align-items:center;gap:.75rem}.next-cover{width:48px;height:48px;border-radius:8px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.next-info .next-title{font-weight:600;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.next-info .next-artist{font-size:.78rem;color:var(--text-muted)}.requests-list{max-height:200px;overflow-y:auto}.request-item{padding:.65rem 1rem;border-bottom:1px solid var(--border);font-size:.82rem}.request-item:last-child{border-bottom:none}.request-name{font-weight:600;color:var(--purple-light)}.request-text{color:var(--text-muted);margin-top:.1rem}.request-form{padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.request-form input{background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:.5rem .75rem;font-size:.83rem;outline:none;font-family:inherit}.request-form input:focus{border-color:var(--purple)}.btn-request{background:var(--purple);border:none;border-radius:8px;color:#fff;padding:.5rem;font-size:.83rem;font-weight:600;cursor:pointer}.btn-request:hover{background:var(--purple-light)}.queue-scroll{max-height:180px;overflow-y:auto}.queue-item{padding:.55rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.6rem;font-size:.82rem}.queue-item:last-child{border-bottom:none}.queue-num{width:20px;text-align:right;color:var(--text-muted);flex-shrink:0;font-size:.72rem}.queue-info{flex:1;min-width:0}.queue-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.queue-artist{font-size:.75rem;color:var(--text-muted)}.queue-dur{color:var(--text-muted);font-size:.72rem;flex-shrink:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}.loading-dots span{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--purple);margin:0 2px;animation:bounce 1.2s infinite}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.empty{padding:1.5rem;text-align:center;color:var(--text-muted);font-size:.85rem}.dj-effects{display:flex;flex-direction:column;gap:.6rem;padding-top:.5rem;border-top:1px solid var(--border)}.effect-row{display:flex;align-items:center;gap:.6rem}.effect-label{font-size:.75rem;color:var(--text-muted);width:90px;flex-shrink:0}.effect-val{font-size:.75rem;color:var(--text-muted);width:36px;text-align:right;flex-shrink:0}.fade-btn{background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);padding:.2rem .5rem;font-size:.75rem;cursor:pointer;transition:all .2s}.fade-btn:hover{border-color:var(--purple);color:var(--text)}.fade-btn.active{border-color:var(--purple);background:#7c3aed33;color:var(--purple-light)}.soundboard{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem;padding:.75rem .75rem .5rem}.fx-btn{background:var(--bg3);border:1px solid var(--border);border-radius:10px;color:var(--text-muted);padding:.55rem .25rem .45rem;cursor:pointer;transition:all .12s;display:flex;flex-direction:column;align-items:center;gap:.18rem;font-family:inherit;font-size:.68rem;font-weight:700;letter-spacing:.02em;line-height:1.2;-webkit-user-select:none;user-select:none}.fx-emoji{font-size:1.35rem;line-height:1;display:block}.fx-btn:hover{border-color:var(--purple-light);background:#7c3aed38;color:var(--text);transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed40}.fx-btn:active{border-color:var(--gold);background:#f59e0b2e;color:var(--gold-light);transform:scale(.95);box-shadow:0 0 14px #f59e0b66;transition:all .06s}.soundboard-hint{padding:0 .75rem .6rem;font-size:.68rem;color:var(--text-muted);text-align:center;opacity:.7}.mixer-view{margin-top:.75rem;background:linear-gradient(135deg,#0a0a14e6,#140a28d9);border:1px solid rgba(124,58,237,.25);border-radius:var(--radius);padding:.75rem;overflow:hidden}.mixer-decks{display:grid;grid-template-columns:1fr auto 1fr;gap:.75rem;align-items:start}.mixer-deck{display:flex;flex-direction:column;align-items:center;gap:.4rem;transition:opacity .3s ease}.deck-label{font-size:.65rem;font-weight:700;letter-spacing:.15em;color:var(--purple-light);text-transform:uppercase}.vinyl-wrap{position:relative;width:110px;height:110px}.vinyl{width:110px;height:110px;border-radius:50%;background:radial-gradient(circle at 50% 50%,#1a1a1a 18%,transparent 18%),repeating-radial-gradient(circle at 50% 50%,#111,#111 3px,#222 3px,#222 6px);box-shadow:0 0 18px #0009,inset 0 0 8px #0006;display:flex;align-items:center;justify-content:center;will-change:transform;border:2px solid rgba(80,40,140,.4)}.vinyl-center{width:32px;height:32px;border-radius:50%;background:#1e1e2e;display:flex;align-items:center;justify-content:center;font-size:14px;border:1px solid rgba(124,58,237,.5);box-shadow:0 0 8px #7c3aed66}.vinyl-gain-ring{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:3px solid transparent;border-top-color:rgba(124,58,237,calc(var(--gain, 0) * .9));border-right-color:rgba(168,85,247,calc(var(--gain, 0) * .7));box-shadow:0 0 calc(var(--gain, 0) * 16px) rgba(124,58,237,calc(var(--gain, 0) * .5));pointer-events:none;transition:box-shadow .2s ease,border-color .2s ease}.deck-track-info{width:100%;text-align:center}.deck-track-title{font-size:.8rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.deck-track-artist{font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.deck-bpm{font-size:.65rem;color:var(--gold);font-weight:600;letter-spacing:.05em}.deck-pitch{font-size:.6rem;color:var(--green);background:#10b9811f;padding:.1rem .4rem;border-radius:4px;border:1px solid rgba(16,185,129,.3)}.deck-progress-bar{width:100%;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden;position:relative}.deck-progress-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--purple-light));border-radius:2px;transition:width .4s linear;box-shadow:0 0 6px #7c3aed99}.deck-progress-fill.deck-b{background:linear-gradient(90deg,#f59e0b,#fcd34d);box-shadow:0 0 6px #f59e0b99}.deck-times{width:100%;display:flex;justify-content:space-between;font-size:.58rem;color:var(--text-muted);font-family:monospace}.deck-gain-label{font-size:.6rem;font-weight:700;color:#a855f7cc;letter-spacing:.05em}.mixer-center{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding-top:1rem}.bpm-match-indicator{font-size:.65rem;color:var(--text-muted);text-align:center;cursor:default}.crossfader-section{display:flex;align-items:center;gap:.4rem}.cf-label{font-size:.65rem;font-weight:700;color:var(--text-muted);letter-spacing:.1em;width:12px;text-align:center}.crossfader-track{position:relative;width:120px;height:12px;background:#ffffff0f;border-radius:5px;overflow:visible;border:1px solid rgba(255,255,255,.1)}.crossfader-fill-a{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--purple),rgba(124,58,237,.4));border-radius:5px 0 0 5px;transition:width .1s}.crossfader-fill-b{position:absolute;right:0;top:0;bottom:0;background:linear-gradient(270deg,var(--gold),rgba(245,158,11,.4));border-radius:0 5px 5px 0;transition:width .1s}.crossfader-thumb{position:absolute;top:-4px;width:18px;height:18px;background:linear-gradient(135deg,#a855f7,#7c3aed);border-radius:50%;border:2px solid rgba(255,255,255,.3);box-shadow:0 0 8px #7c3aedb3;transition:left .1s;z-index:2}.crossfade-active-badge{font-size:.6rem;font-weight:700;letter-spacing:.08em;color:var(--gold);background:#f59e0b1f;border:1px solid rgba(245,158,11,.4);border-radius:6px;padding:.15rem .5rem;animation:cfBlink 1s ease-in-out infinite}@keyframes cfBlink{0%,to{opacity:1}50%{opacity:.5}}.deck-waveform{display:flex;align-items:flex-end;gap:1px;height:36px;padding:2px 0;margin-top:4px;overflow:hidden}.deck-waveform-empty{height:36px;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--text-muted);opacity:.5}.wf-bar{flex:1;min-width:1px;border-radius:1px 1px 0 0;background:var(--border);transition:height .3s ease}.wf-bar.played{background:#7c3aed73}.wf-bar.current{background:var(--purple-light)!important;width:2px}.wf-bar.deck-b.played{background:#f59e0b73}.wf-bar.deck-b.current{background:var(--gold)!important}.key-compat-indicator{font-size:.65rem;text-align:center;padding:2px 4px;margin-top:2px;border-radius:4px;background:#ffffff0d}@media (max-width: 900px){.dj-body{grid-template-columns:1fr;grid-template-rows:auto auto}.sidebar{grid-column:1;grid-row:2}.now-playing{grid-column:1;grid-row:1}.event-grid{grid-template-columns:repeat(3,1fr)}.mixer-decks{grid-template-columns:1fr auto 1fr}.vinyl-wrap,.vinyl{width:80px;height:80px}}.qr-guest-card{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:.5rem 0}.qr-code-wrap{background:#09090f;border-radius:10px;padding:8px;border:1px solid var(--border)}.qr-instructions{font-size:.78rem;color:var(--text-muted);text-align:center}.qr-url{font-size:.68rem;color:var(--purple-light);word-break:break-all;text-align:center;background:var(--bg3);padding:.3rem .5rem;border-radius:6px;width:100%}.qr-copy-btn{background:transparent;border:1px solid var(--border);border-radius:7px;color:var(--text-muted);font-size:.78rem;padding:.35rem .8rem;cursor:pointer;transition:all .15s}.qr-copy-btn:hover{border-color:var(--purple);color:var(--purple-light)}.guest-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;background:radial-gradient(ellipse at 50% 0%,rgba(124,58,237,.15) 0%,transparent 70%)}.guest-logo{font-size:3rem;margin-bottom:.5rem}.guest-title{font-size:1.8rem;font-weight:700;color:var(--text);margin-bottom:.25rem}.guest-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem;text-align:center}.guest-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;width:100%;max-width:480px;display:flex;flex-direction:column;gap:1rem}.guest-label{font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.guest-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:.75rem 1rem;font-size:1rem;font-family:inherit;outline:none;transition:border-color .2s;box-sizing:border-box}.guest-input:focus{border-color:var(--purple)}.guest-results{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.guest-result-card{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:.1rem}.guest-result-card:hover,.guest-result-card.selected{border-color:var(--purple);background:#7c3aed1a}.guest-result-title{font-weight:600;font-size:.95rem}.guest-result-artist{color:var(--text-muted);font-size:.82rem}.guest-result-bpm{color:var(--purple-light);font-size:.75rem}.guest-not-found{color:var(--text-muted);font-size:.82rem;text-align:center;padding:.5rem}.guest-submit{width:100%;background:var(--purple);color:#fff;border:none;border-radius:8px;padding:.85rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.guest-submit:hover{background:var(--purple-light)}.guest-submit:disabled{opacity:.5;cursor:not-allowed}.guest-success{text-align:center;padding:2rem;font-size:1.1rem;color:var(--green)}.guest-error{text-align:center;padding:1rem;color:var(--red)}
