@font-face{font-family:DM Sans;font-style:normal;font-weight:100 1000;font-display:swap;src:url(../media/c3cb240f9c892514-s.d8e4bce2.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:100 1000;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.a62025f2.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans Fallback;src:local(Arial);ascent-override:94.9%;descent-override:29.66%;line-gap-override:0.0%;size-adjust:104.53%}.dm_sans_fd62f040-module__0jgVUW__className{font-family:DM Sans,DM Sans Fallback;font-style:normal}.dm_sans_fd62f040-module__0jgVUW__variable{--font-body:"DM Sans","DM Sans Fallback"}
@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/0b1dc8ddaa74ba49-s.8624a701.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/e629b5bc06499d58-s.8e66b869.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/1a099d89ee94ee96-s.f6ed4c33.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/fba5a26ea33df6a3-s.p.1bbdebe6.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Plus Jakarta Sans Fallback;src:local(Arial);ascent-override:98.88%;descent-override:21.15%;line-gap-override:0.0%;size-adjust:104.98%}.plus_jakarta_sans_2db2a51f-module__MR2Onq__className{font-family:Plus Jakarta Sans,Plus Jakarta Sans Fallback;font-style:normal}.plus_jakarta_sans_2db2a51f-module__MR2Onq__variable{--font-display:"Plus Jakarta Sans","Plus Jakarta Sans Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/13bf9871fe164e7f-s.f2220059.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/cc545e633e20c56d-s.f6f1950f.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/71b036adf157cdcf-s.bd5f4d11.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/89b21bb081cb7469-s.51c18f09.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/3fe682a82f50d426-s.23358719.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/70bc3e132a0a741e-s.15008bfb.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_f0e1cf5b-module__w1ICmG__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_f0e1cf5b-module__w1ICmG__variable{--font-mono:"JetBrains Mono","JetBrains Mono Fallback"}
*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0a;--card:#1a1a1a;--text:#ededed;--text-secondary:#9ca3af;--text-tertiary:#6b7280;--border:#333}html,body{max-width:100vw;font-family:var(--font-body,"DM Sans"),-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}.container{max-width:1200px;margin:0 auto;padding:2rem}.card{background:var(--card);border-radius:8px;margin-bottom:1rem;padding:1.5rem;overflow:hidden}.btn{cursor:pointer;border:none;border-radius:6px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:background .2s;display:inline-block}.btn-primary{color:#fff;background:#3b82f6}.btn-primary:hover{background:#2563eb}.btn-success{color:#fff;background:#22c55e}.btn-success:hover{background:#16a34a}.btn-warning{color:#fff;background:#f59e0b}.btn-warning:hover{background:#d97706}.btn-danger{color:#fff;background:#ef4444}.btn-danger:hover{background:#dc2626}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:6px;padding:.75rem;font-size:1rem}.input:focus{border-color:#3b82f6;outline:none}.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.5rem;font-weight:500;display:block}.badge{text-transform:uppercase;border-radius:9999px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-new{color:#fff;background:#3b82f6}.badge-accepted{color:#fff;background:#8b5cf6}.badge-playing{color:#fff;background:#22c55e;animation:2s ease-in-out infinite badge-pulse-glow}@keyframes badge-pulse-glow{0%,to{box-shadow:0 0 4px #22c55e66}50%{box-shadow:0 0 14px #22c55ecc}}.badge-played{color:#fff;background:#6b7280}.badge-rejected{color:#fff;background:#ef4444}.header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.header h1{font-size:1.5rem}.request-list{flex-direction:column;gap:1rem;display:flex}.request-item{background:var(--card);color:inherit;border-radius:8px;justify-content:space-between;align-items:flex-start;padding:1rem;display:flex}.request-info{flex:1;min-width:0}.request-info h3{white-space:nowrap;text-overflow:ellipsis;min-width:0;margin-bottom:.25rem;font-size:1.125rem;overflow:hidden}.request-info p{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;overflow:hidden}.request-info .note{background:var(--bg);border-radius:4px;margin-top:.5rem;padding:.5rem;font-style:italic}.request-actions{flex-wrap:wrap;gap:.5rem;display:flex}.event-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.event-card{background:var(--card);border-radius:8px;padding:1.5rem}.event-card h3{margin-bottom:.5rem;font-size:1.25rem}.event-card .code{color:#3b82f6;margin-bottom:1rem;font-family:monospace;font-size:1.5rem}.qr-container{background:#fff;border-radius:8px;margin:1rem 0;padding:1rem;display:inline-block}.tabs{gap:.5rem;margin-bottom:1rem;display:flex}.tab{cursor:pointer;border:1px solid var(--border);color:var(--text-secondary);background:0 0;border-radius:6px;padding:.5rem 1rem}.tab.active{color:#fff;background:#3b82f6;border-color:#3b82f6}.loading{height:200px;color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.scrollable-list{scrollbar-width:thin;scrollbar-color:#444 transparent;max-height:680px;overflow-y:auto}.scrollable-list::-webkit-scrollbar{width:6px}.scrollable-list::-webkit-scrollbar-track{background:0 0}.scrollable-list::-webkit-scrollbar-thumb{background:#444;border-radius:3px}.scrollable-list::-webkit-scrollbar-thumb:hover{background:#555}@keyframes fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.fade-out{animation:.5s ease-out forwards fade-out}.join-page-wrapper{max-width:100vw;min-height:100dvh;position:relative;overflow-x:clip}.join-banner-bg{z-index:0;width:100%;height:30vh;min-height:150px;max-height:250px;position:absolute;top:0;left:0;overflow:hidden}.join-banner-bg img{object-fit:cover;filter:blur(2px)brightness(.65);width:100%;height:100%;display:block;-webkit-mask-image:linear-gradient(#000 0% 30%,#0000 100%);mask-image:linear-gradient(#000 0% 30%,#0000 100%)}.guest-request-list-container{flex-direction:column;max-width:100vw;min-height:100dvh;padding-bottom:5rem;display:flex;position:relative;overflow-x:clip}.guest-request-list{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:.5rem;display:flex;overflow-y:auto}.guest-request-item{background:var(--card);border-radius:8px;align-items:center;gap:.75rem;padding:.75rem;display:flex}.guest-request-item-art{object-fit:cover;border-radius:6px;flex-shrink:0;width:48px;height:48px}.guest-request-item-info{flex:1;min-width:0}.guest-request-item-title{white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.guest-request-item-artist{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;overflow:hidden}.guest-request-item-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.25rem;display:flex}.guest-vote-badge{color:#60a5fa;white-space:nowrap;background:#3b82f633;border-radius:1rem;padding:.2rem .5rem;font-size:.75rem}.badge-pending{color:#60a5fa;background:#3b82f626}.badge-accepted-guest{color:#a78bfa;background:#8b5cf626}.sticky-bottom-button{padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px));background:linear-gradient(transparent,var(--bg)30%);z-index:10;position:fixed;bottom:0;left:0;right:0}@keyframes btn-glow{0%,to{box-shadow:0 0 15px #3b82f666,0 0 30px #3b82f633}50%{box-shadow:0 0 20px #3b82f6b3,0 0 40px #3b82f659}}@keyframes generate-pulse{0%,to{opacity:.9;box-shadow:0 0 8px #3b82f680,0 0 16px #3b82f640}50%{opacity:1;box-shadow:0 0 14px #3b82f6cc,0 0 28px #3b82f666}}.btn-generating{animation:1.2s ease-in-out infinite generate-pulse}.btn-complete{transition:background 1.5s,box-shadow 1.5s;background:#10b981!important}.btn-complete-fade{transition:background 1.5s,box-shadow 1.5s}.sticky-bottom-button .btn{width:100%;max-width:500px;margin:0 auto;padding:1rem 1.5rem;font-size:1.125rem;font-weight:600;animation:2s ease-in-out infinite btn-glow;display:block}.admin-layout{min-height:100vh;display:flex}.admin-sidebar{border-right:1px solid var(--border);background:#111;flex-direction:column;flex-shrink:0;width:220px;display:flex}.admin-sidebar-header{border-bottom:1px solid var(--border);padding:1.5rem}.admin-sidebar-header h2{color:#3b82f6;font-size:1.25rem}.admin-sidebar-nav{flex-direction:column;flex:1;padding:1rem 0;display:flex}.admin-sidebar-link{color:var(--text-secondary);padding:.75rem 1.5rem;text-decoration:none;transition:background .2s,color .2s;display:block}.admin-sidebar-link:hover{color:var(--text);background:#222}.admin-sidebar-link.active{background:var(--card);color:#3b82f6;border-left:3px solid #3b82f6}.admin-sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;padding:1rem 1.5rem;display:flex}.admin-main{flex:1;overflow-x:auto}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.stat-card{background:var(--card);text-align:center;border-radius:8px;padding:1.5rem}.stat-value{color:var(--text);font-size:2rem;font-weight:700}.stat-label{color:var(--text-secondary);margin-top:.25rem;font-size:.875rem}.admin-table{border-collapse:collapse;width:100%}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);padding:.75rem 1rem}.admin-table th{color:var(--text-secondary);text-transform:uppercase;font-size:.875rem;font-weight:600}.admin-table tbody tr:hover{background:var(--card)}.badge-role-admin{color:#fff;background:#6b21a8}.badge-role-dj{color:#fff;background:#3b82f6}.badge-role-pending{color:#0a0a0a;background:#f59e0b}.modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--card);border-radius:8px;width:100%;max-width:450px;max-height:90vh;padding:2rem;overflow-y:auto}.pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;display:flex}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.7}}@keyframes now-playing-spectrum{0%{height:20%}to{height:100%}}.now-playing-live-badge{color:#fff;letter-spacing:.05em;background:#ef4444;border-radius:.25rem;flex-shrink:0;padding:.1rem .375rem;font-size:.625rem;font-weight:700;animation:2s ease-in-out infinite pulse-live;display:inline-block}.now-playing-spectrum-bars{flex-shrink:0;align-items:flex-end;gap:3px;height:24px;display:flex}.now-playing-spectrum-bar{background:linear-gradient(#4ade80,#22c55e);border-radius:2px;width:3px;animation:.5s ease-in-out infinite alternate now-playing-spectrum}.badge-status{letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;border-radius:4px;padding:.2rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.badge-status.yes{color:#fff;background:#22c55e}.badge-status.no{color:#fff;background:#ef4444}.badge-status.configured{color:#0a0a0a;background:#f59e0b}.badge-status.not-configured{color:var(--text-secondary);background:#374151}.badge-status.not-implemented{color:#6b7280;background:#1f2937}.integration-table{border-collapse:collapse;width:100%}.integration-table th,.integration-table td{text-align:center;border-bottom:1px solid var(--border);padding:.75rem 1rem}.integration-table th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.integration-table td:first-child,.integration-table th:first-child{text-align:left}.integration-table tbody tr:hover{background:var(--card)}.toggle-switch{cursor:pointer;background:#374151;border:none;border-radius:12px;flex-shrink:0;width:44px;height:24px;transition:background .2s;position:relative}.toggle-switch.active{background:#22c55e}.toggle-switch:after{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:2px;left:2px}.toggle-switch.active:after{transform:translate(20px)}.toggle-switch:disabled{opacity:.5;cursor:not-allowed}.btn-check{color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #444;border-radius:4px;padding:.375rem .75rem;font-size:.75rem;transition:background .2s,color .2s}.btn-check:hover{color:var(--text);background:#333}.btn-check:disabled{opacity:.5;cursor:not-allowed}.event-tabs{gap:.75rem;margin-bottom:1.5rem;display:flex}.event-tab{border:2px solid var(--border);background:var(--card);color:var(--text-secondary);cursor:pointer;border-radius:8px;flex:1;padding:1rem;font-size:1rem;font-weight:600;transition:background .2s,border-color .2s,color .2s}.event-tab:hover{color:var(--text);border-color:#555}.event-tab.active{color:var(--text);background:#1e3a5f;border-color:#3b82f6}.activity-log{max-height:400px;overflow-y:auto}.log-entry{border-bottom:1px solid #222;align-items:flex-start;gap:.75rem;padding:.5rem 0;font-size:.875rem;display:flex}.log-entry:last-child{border-bottom:none}.log-level-info{color:#60a5fa;white-space:nowrap;background:#1e3a5f;border-radius:4px;padding:.125rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.log-level-warning{color:#fbbf24;white-space:nowrap;background:#78350f;border-radius:4px;padding:.125rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.log-level-error{color:#f87171;white-space:nowrap;background:#7f1d1d;border-radius:4px;padding:.125rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.log-source{color:var(--text-secondary);white-space:nowrap;background:#333;border-radius:4px;padding:.125rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}@media (max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%}.admin-sidebar-nav{flex-direction:row;padding:0;overflow-x:auto}.admin-sidebar-link{white-space:nowrap;padding:.75rem 1rem}.admin-sidebar-link.active{border-bottom:3px solid #3b82f6;border-left:none}.admin-sidebar-footer{flex-direction:row;justify-content:space-between}}.help-btn-container{z-index:1200;align-items:center;gap:.5rem;display:flex;position:fixed;top:1rem;right:1rem}.help-btn-container-inline{align-items:center;gap:.5rem;display:flex}.help-btn{background:var(--card);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border:2px solid #444;border-radius:50%;justify-content:center;align-items:center;font-size:1.125rem;font-weight:700;transition:background .2s,border-color .2s,color .2s;display:flex}.help-btn:hover{color:var(--text);border-color:#3b82f6}.help-btn-active{color:#fff;background:#3b82f6;border-color:#3b82f6}.help-tour-btn{color:#3b82f6;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #3b82f6;border-radius:6px;padding:.375rem .75rem;font-size:.8125rem;font-weight:500;transition:background .2s}.help-tour-btn:hover{background:#3b82f61a}.help-spot-highlight{outline-offset:4px;border-radius:6px;outline:2px solid #3b82f680}.help-tooltip{z-index:1100;background:var(--card);border:1px solid var(--border);pointer-events:none;border-radius:8px;min-width:200px;max-width:min(320px,100vw - 32px);padding:.75rem 1rem;position:absolute;top:calc(100% + 8px);left:0;box-shadow:0 4px 16px #0006}.help-tooltip-title{color:var(--text);margin-bottom:.25rem;font-size:.875rem;font-weight:600}.help-tooltip-desc{color:var(--text-secondary);font-size:.8125rem;line-height:1.4}.onboarding-card{background:var(--card);border:1px solid var(--border);border-radius:12px;width:320px;max-width:calc(100vw - 32px);max-height:calc(100vh - 64px);padding:1.25rem 1.5rem;overflow-y:auto;box-shadow:0 8px 32px #00000080}.onboarding-step-counter{color:#60a5fa;letter-spacing:.03em;margin-bottom:.5rem;font-size:.75rem;font-weight:600}.onboarding-card-title{color:var(--text);margin-bottom:.375rem;font-size:1rem;font-weight:600}.onboarding-card-desc{color:var(--text-secondary);margin-bottom:1rem;font-size:.875rem;line-height:1.5}.onboarding-nav{justify-content:space-between;align-items:center;display:flex}.theme-toggle{border:1px solid var(--border);background:var(--card);color:var(--text-secondary);cursor:pointer;border-radius:6px;align-items:center;gap:.375rem;padding:.375rem .625rem;font-size:.75rem;font-weight:500;transition:border-color .2s,color .2s;display:flex}.theme-toggle:hover{color:var(--text);border-color:#3b82f6}.theme-toggle-icon{border:2px solid;border-radius:50%;width:14px;height:14px;transition:background .2s}.theme-toggle-icon--dark{background:linear-gradient(135deg,currentColor 50%,#0000 50%)}.theme-toggle-icon--high-contrast{background:currentColor}.theme-toggle-icon--daylight{background:0 0}h1,.display-heading{font-family:var(--font-display,"Plus Jakarta Sans"),-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}.code,code{font-family:var(--font-mono,"JetBrains Mono"),"SF Mono","Fira Code",monospace}.compact .request-list{gap:.5rem}.compact .request-item{padding:.5rem .75rem}.compact .request-info h3{margin-bottom:.125rem;font-size:.95rem}.compact .request-info p{font-size:.8rem}.compact .request-actions{gap:.25rem}.compact .btn-sm{padding:.375rem .625rem;font-size:.8rem}.compact .badge{padding:.2rem .5rem;font-size:.675rem}.compact .scrollable-list{max-height:900px}
