@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{font-family:Inter,system-ui,sans-serif;color-scheme:dark;--cyan: #00f3ff;--violet: #7b00ff;--bg: #07070b;--surface: rgba(255,255,255,.04);--border: rgba(255,255,255,.08);--glass: rgba(255,255,255,.03)}body,html{background:var(--bg);color:#fff;overscroll-behavior-y:none;-webkit-tap-highlight-color:transparent;min-height:100vh;width:100%;overflow-x:hidden}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:radial-gradient(circle at top right,rgba(123,0,255,.15),transparent),radial-gradient(circle at bottom left,rgba(0,243,255,.1),transparent)}.client-screen{min-height:100vh;display:flex;flex-direction:column;padding:1.25rem;gap:1.5rem;background:radial-gradient(circle at 0% 0%,rgba(0,243,255,.05),transparent 40%),radial-gradient(circle at 100% 100%,rgba(123,0,255,.05),transparent 40%);background-attachment:fixed}.login-card{width:100%;max-width:400px;background:var(--surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:24px;padding:2.5rem 2rem;text-align:center;box-shadow:0 20px 40px #0006}.login-title{font-size:2rem;font-weight:800;margin-bottom:.5rem;background:linear-gradient(to right,#fff,var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.form-group{margin-bottom:1.25rem;text-align:left}.form-label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#666;margin-bottom:.5rem;padding-left:4px}.input-glass{width:100%;padding:1.1rem;background:var(--glass);border:1px solid var(--border);border-radius:14px;color:#fff;font-size:1rem;outline:none;transition:all .2s}.input-glass:focus{background:#ffffff0f;border-color:#00f3ff80;box-shadow:0 0 0 3px #00f3ff1a}.btn-join{width:100%;padding:1.1rem;border:none;border-radius:14px;background:linear-gradient(135deg,var(--violet),var(--cyan));color:#fff;font-weight:700;font-size:1rem;cursor:pointer;transition:transform .2s,opacity .2s;margin-top:1rem}.btn-join:active{transform:scale(.98)}.btn-join:disabled{opacity:.5;filter:grayscale(1);cursor:not-allowed}.client-header{display:flex;justify-content:space-between;align-items:flex-end}.header-info h2{font-size:1.4rem;font-weight:800}.accent{color:var(--cyan)}.btn-queue-toggle{background:var(--surface);border:1px solid var(--border);padding:8px 16px;border-radius:50px;color:#fff;display:flex;align-items:center;gap:8px;font-weight:700;font-size:.85rem;cursor:pointer}.search-bar{display:flex;align-items:center;gap:12px;background:var(--surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:18px;padding:6px 6px 6px 16px;width:100%;transition:all .3s ease}.search-bar:focus-within{border-color:#00f3ff66;box-shadow:0 0 20px #00f3ff1a;background:#ffffff0f}.search-icon{color:#666;flex-shrink:0}.search-bar input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:1rem;padding:12px 0;min-width:0}.search-bar input::placeholder{color:#555}.btn-mic,.btn-send{width:46px;height:46px;border-radius:12px;border:1px solid var(--border);background:var(--glass);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-mic:hover,.btn-send:hover{background:#ffffff14;border-color:var(--cyan)}.btn-mic.listening{background:var(--violet);border-color:var(--cyan);box-shadow:0 0 15px #00f3ff66;animation:pulse 1.5s infinite}.btn-send{background:var(--cyan);color:#000;border:none}.btn-send:hover{filter:brightness(1.1);transform:translateY(-1px)}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}to{transform:scale(1);opacity:1}}.results-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding-bottom:2rem}.result-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:10px;display:flex;align-items:center;gap:12px}.result-number{min-width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#00f3ff1f;color:var(--cyan);font-weight:800;font-size:.8rem;border-radius:8px;flex-shrink:0}.result-card img{width:60px;height:60px;border-radius:10px;object-fit:cover}.result-info{flex:1;min-width:0}.result-info strong{display:block;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-info span{font-size:.8rem;color:#888}.btn-add{background:var(--cyan);color:#000;border:none;padding:8px 12px;border-radius:10px;font-weight:800;font-size:.75rem;display:flex;align-items:center;gap:4px;cursor:pointer}.btn-add--disabled{opacity:.5;cursor:not-allowed}.result-card--validating{opacity:.6;pointer-events:none}.spin{animation:spin-icon 1s linear infinite}@keyframes spin-icon{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.my-songs-section{background:#ff4b4b0d;border:1px solid rgba(255,75,75,.15);border-radius:16px;padding:12px}.my-songs-title{font-size:.8rem;font-weight:700;color:#aaa;margin-bottom:8px}.my-song-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.my-song-row:last-child{border-bottom:none}.my-song-info strong{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;display:block}.playing-badge{font-size:.65rem;font-weight:700;color:#4ade80;margin-top:2px;display:block}.my-song-row--playing{opacity:.6;border-color:#4ade8033!important}.btn-remove{background:#ff4b4b26;color:#ff4b4b;border:1px solid rgba(255,75,75,.3);padding:6px 12px;border-radius:8px;font-weight:700;font-size:.7rem;display:flex;align-items:center;gap:4px;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-remove:hover{background:#ff4b4b4d}.queue-row--mine{border-color:#00f3ff33!important;background:#00f3ff08}.btn-remove-sm{background:#ff4b4b26;color:#ff4b4b;border:1px solid rgba(255,75,75,.25);width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .2s}.btn-remove-sm:hover{background:#ff4b4b4d}.queue-drawer{position:fixed;bottom:0;left:0;right:0;height:70vh;background:#0f0f15;border-top:1px solid var(--border);border-top-left-radius:30px;border-top-right-radius:30px;z-index:100;padding:1.5rem;display:flex;flex-direction:column;box-shadow:0 -20px 40px #00000080}.drawer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.queue-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.queue-item-sm{background:#ffffff05;border-radius:12px;padding:8px 12px;display:flex;align-items:center;gap:10px}.queue-item-sm .q-index{color:var(--cyan);font-weight:800;font-size:.8rem}.queue-item-sm .q-title{flex:1;font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-item-sm .q-user{font-size:.7rem;color:#666}.toast-container{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:1000;display:flex;flex-direction:column;gap:8px;width:90%;max-width:400px}.toast{background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 20px;border-radius:12px;border:1px solid var(--border);color:#fff;font-size:.9rem;font-weight:600;text-align:center}.toast-success{border-color:var(--cyan);color:var(--cyan)}.toast-error{border-color:#ff4b4b;color:#ff4b4b}@media screen and (max-width: 768px){.input-glass{font-size:16px!important}}.client-screen{padding-top:max(1.25rem,env(safe-area-inset-top));padding-bottom:max(1.25rem,env(safe-area-inset-bottom));padding-left:max(1.25rem,env(safe-area-inset-left));padding-right:max(1.25rem,env(safe-area-inset-right))}.queue-drawer{padding-bottom:env(safe-area-inset-bottom)}@media (max-width: 380px){.login-card{padding:1.5rem 1rem}.login-title{font-size:1.5rem}.client-header{flex-direction:column;align-items:flex-start;gap:10px}.btn-queue-toggle{width:100%;justify-content:center}.result-card img{width:50px;height:50px}.result-info strong{font-size:.85rem}.btn-add span{display:none}}.btn-mic,.btn-send,.btn-add,.btn-queue-toggle,.btn-join{min-height:44px}.results-list,.queue-scroll{-webkit-overflow-scrolling:touch}.blocked-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 24px;max-width:340px;margin:auto}.blocked-icon{font-size:4rem;margin-bottom:16px;filter:grayscale(.2)}.blocked-title{font-size:1.5rem;font-weight:800;color:#fff;margin-bottom:12px}.blocked-msg{font-size:1rem;color:#ffffffbf;line-height:1.5;margin-bottom:8px;background:#ff505014;border:1px solid rgba(255,80,80,.25);border-radius:12px;padding:14px 16px}.blocked-sub{font-size:.82rem;color:#fff6;line-height:1.5}
