*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #935af6;--primary-hover: #a370ff;--primary-glow: rgba(147, 90, 246, .4);--bg-dark: #0f0f12;--bg-darker: #130c1c;--bg-surface: #171022;--bg-surface-light: #171023;--bg-elevated: #1e182d;--glass-bg: rgba(30, 24, 45, .65);--glass-bg-strong: rgba(30, 24, 45, .85);--glass-bg-light: rgba(23, 16, 35, .7);--glass-bg-hover: rgba(30, 24, 45, .85);--glass-border: rgba(255, 255, 255, .05);--glass-border-hover: rgba(255, 255, 255, .1);--glass-border-light: rgba(255, 255, 255, .08);--gradient-1: #0f0f12;--gradient-2: #171022;--gradient-3: #130c1c;--accent-primary: #935af6;--accent-secondary: #a690cb;--accent-gradient: linear-gradient(135deg, #935af6 0%, #7c3aed 100%);--accent-glow: rgba(147, 90, 246, .3);--text-primary: #ffffff;--text-secondary: #a690cb;--text-tertiary: #888888;--text-muted: rgba(255, 255, 255, .4);--text-gray: #9ca3af;--success: #22c55e;--error: #f43f5e;--warning: #f59e0b;--live: #ef4444;--premium-gold: #f59e0b;--blur-sm: 12px;--blur-md: 20px;--blur-lg: 40px;--blur-amount: 12px;--transition: .3s cubic-bezier(.4, 0, .2, 1);--transition-fast: .15s ease;--shadow-glass: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 40px var(--accent-glow);--shadow-lg: 0 25px 50px -12px rgba(0, 0, 0, .5);--accent: var(--accent-primary);--accent-rgb: 147, 90, 246;--accent-subtle: rgba(147, 90, 246, .1);--accent-hover: #a370ff;--danger: var(--error);--secondary: var(--accent-secondary);--bg-primary: var(--bg-dark);--bg-secondary: var(--bg-surface);--bg-tertiary: var(--bg-elevated);--surface-bg: var(--bg-surface);--border-color: var(--glass-border);--border: var(--glass-border);--hover-bg: var(--glass-bg);--sidebar-width: 256px;--player-height: 96px;--header-height: 50px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-2xl: 32px;--radius-full: 9999px;--z-base: 0;--z-dropdown: 100;--z-sidebar: 200;--z-player: 300;--z-overlay: 800;--z-modal: 1000;--z-tooltip: 2000;--z-notification: 3000}*,*:before,*:after{box-sizing:border-box}html{background:var(--bg-dark);overflow-x:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;margin:0;padding:0}#root{background:var(--bg-dark);min-height:100vh;overflow-x:hidden;max-width:100vw}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.ambient-bg{position:fixed;inset:0;z-index:var(--z-base);pointer-events:none;overflow:hidden}.ambient-bg:before{content:"";position:absolute;top:-20%;left:-10%;width:50%;height:50%;background:var(--primary);opacity:.15;border-radius:50%;filter:blur(120px);animation:ambient-float 25s ease-in-out infinite}.ambient-bg:after{content:"";position:absolute;bottom:-10%;right:-5%;width:40%;height:40%;background:#3b82f6;opacity:.1;border-radius:50%;filter:blur(100px);animation:ambient-float 20s ease-in-out infinite reverse}@keyframes ambient-float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}.app{min-height:100vh;display:flex;flex-direction:column;position:relative}.glass{background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);box-shadow:var(--shadow-glass)}.glass-panel{background:#1e182da6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-xl)}.glass-header{background:linear-gradient(180deg,#935af626,#0f0f1200)}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;text-align:center;min-height:120px;gap:8px}.error-boundary__icon{font-size:40px;color:var(--error);opacity:.7}.error-boundary__title{font-size:16px;font-weight:600;color:var(--text-primary)}.error-boundary__message{font-size:13px;color:var(--text-muted)}.error-boundary__btn{margin-top:8px;padding:8px 20px;background:var(--glass-bg);border:1px solid var(--glass-border-hover);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:13px;transition:var(--transition-fast)}.error-boundary__btn:hover{background:var(--glass-bg-strong);border-color:var(--primary)}.drop-zone{position:relative;display:flex;flex-direction:column;flex:1;min-height:0}.drop-zone__overlay{position:fixed;inset:0;background:#935af626;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:var(--z-overlay);border:3px dashed var(--primary);gap:12px;pointer-events:none}.drop-zone__overlay-icon{font-size:64px;color:var(--primary)}.drop-zone__overlay-text{font-size:20px;font-weight:600;color:var(--text-primary)}.drop-zone__overlay-hint{font-size:14px;color:var(--text-secondary)}.drop-zone__progress{position:fixed;bottom:120px;left:50%;transform:translate(-50%);background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));border:1px solid var(--glass-border-hover);border-radius:var(--radius-lg);padding:16px 24px;display:flex;align-items:center;gap:16px;z-index:var(--z-notification);min-width:300px;box-shadow:var(--shadow-lg)}.drop-zone__progress-info{flex:1;display:flex;flex-direction:column;gap:6px}.drop-zone__progress-name{font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px}.drop-zone__progress-bar{height:4px;background:var(--glass-bg);border-radius:2px;overflow:hidden}.drop-zone__progress-fill{height:100%;background:var(--accent-gradient);border-radius:2px;transition:width .2s ease}.drop-zone__progress-text{font-size:13px;color:var(--text-secondary);font-weight:600;min-width:36px;text-align:right}.user-profile-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.user-profile{background:var(--bg-surface);border:1px solid var(--glass-border-hover);border-radius:var(--radius-xl);padding:32px;min-width:340px;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:var(--shadow-lg)}.user-profile__avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;background:var(--glass-bg);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:var(--primary);border:3px solid var(--primary)}.user-profile__avatar img{width:100%;height:100%;object-fit:cover}.user-profile__name{font-size:20px;font-weight:700;color:var(--text-primary)}.user-profile__username{font-size:14px;color:var(--text-secondary);margin-top:-8px}.user-profile__date{font-size:12px;color:var(--text-muted)}.user-profile__stats{display:flex;gap:24px;padding:16px 0;border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border);width:100%;justify-content:center}.user-profile__stat{display:flex;flex-direction:column;align-items:center;gap:4px}.user-profile__stat-value{font-size:20px;font-weight:700;color:var(--primary)}.user-profile__stat-label{font-size:12px;color:var(--text-muted)}.user-profile__close{padding:8px 24px;background:var(--glass-bg);border:1px solid var(--glass-border-hover);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:14px;transition:var(--transition-fast)}.user-profile__close:hover{background:var(--glass-bg-strong)}.user-list__name--clickable{cursor:pointer;transition:color var(--transition-fast)}.user-list__name--clickable:hover{color:var(--primary)}.friends__name--clickable{cursor:pointer;transition:color var(--transition-fast)}.friends__name--clickable:hover{color:var(--primary)}.chat__reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.chat__reaction{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);font-size:13px;cursor:pointer;transition:var(--transition-fast);-webkit-user-select:none;user-select:none}.chat__reaction:hover{background:var(--glass-bg-strong);border-color:var(--glass-border-hover)}.chat__reaction--active{background:#935af633;border-color:var(--primary)}.chat__reaction-count{font-size:11px;color:var(--text-secondary)}.chat__reaction-add{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px dashed var(--glass-border);border-radius:var(--radius-full);cursor:pointer;opacity:0;transition:var(--transition-fast);position:relative}.chat__message:hover .chat__reaction-add{opacity:1}@media(hover:none){.chat__reaction-add{opacity:.6}}.chat__reaction-add:hover{background:var(--glass-bg);border-color:var(--glass-border-hover)}.chat__reaction-add .material-symbols-outlined{font-size:16px;color:var(--text-muted)}.chat__reaction-picker{position:absolute;bottom:100%;left:0;background:var(--bg-surface);border:1px solid var(--glass-border-hover);border-radius:var(--radius-md);padding:6px;display:flex;gap:2px;box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);margin-bottom:4px}.chat__reaction-picker-btn{background:transparent;border:none;font-size:18px;padding:4px 6px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast)}.chat__reaction-picker-btn:hover{background:var(--glass-bg)}.video-queue__item--dragging{opacity:.5}.video-queue__item--drag-over{border-top:2px solid var(--primary)}.video-queue__item-drag{cursor:grab;padding:4px;color:var(--text-muted);display:flex;align-items:center}.video-queue__item-drag:active{cursor:grabbing}.video-queue__item-drag .material-symbols-outlined{font-size:18px}[data-theme=light]{--bg-dark: #f5f5f7;--bg-darker: #eeeef0;--bg-surface: #ffffff;--bg-surface-light: #fafafa;--bg-elevated: #ffffff;--glass-bg: rgba(255, 255, 255, .75);--glass-bg-strong: rgba(255, 255, 255, .9);--glass-bg-light: rgba(245, 245, 247, .8);--glass-bg-hover: rgba(255, 255, 255, .9);--glass-border: rgba(0, 0, 0, .08);--glass-border-hover: rgba(0, 0, 0, .15);--glass-border-light: rgba(0, 0, 0, .06);--gradient-1: #f5f5f7;--gradient-2: #ffffff;--gradient-3: #eeeef0;--text-primary: #1a1a1a;--text-secondary: #6b6b80;--text-tertiary: #999999;--text-muted: rgba(0, 0, 0, .4);--text-gray: #6b7280;--shadow-glass: 0 8px 32px rgba(0, 0, 0, .08);--shadow-glow: 0 0 40px rgba(147, 90, 246, .15);--shadow-lg: 0 25px 50px -12px rgba(0, 0, 0, .1)}html[data-theme=light],html[data-theme=light] body,html[data-theme=light] #root{background:var(--bg-dark)}.settings__theme-mode{display:flex;gap:8px;align-items:center}.settings__theme-mode-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:13px;transition:var(--transition-fast)}.settings__theme-mode-btn:hover{border-color:var(--glass-border-hover)}.settings__theme-mode-btn--active{background:#935af626;border-color:var(--primary);color:var(--primary)}.settings__theme-mode-btn .material-symbols-outlined{font-size:18px}.app-layout{display:flex;flex-direction:column;min-height:100vh;width:100%;max-width:100%;position:relative;z-index:1;overflow-x:hidden}.app-layout__body{display:flex;flex:1;min-height:0;overflow:hidden;position:relative;max-width:100%}.sidebar{width:var(--sidebar-width);height:100vh;display:flex;flex-direction:column;background:var(--bg-darker);border-right:1px solid var(--glass-border);flex-shrink:0;overflow-y:auto;position:fixed;left:0;top:0;z-index:var(--z-sidebar);transition:width .3s ease}.sidebar--collapsed{width:72px}.sidebar--collapsed~.main-content{margin-left:72px}.sidebar--collapsed~.main-content .room-header{left:72px}.sidebar__toggle{position:absolute;top:28px;right:16px;width:28px;height:28px;border-radius:50%;background:#ffffff1a;border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:var(--transition)}.sidebar__toggle:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.sidebar__toggle .material-symbols-outlined{font-size:18px}.sidebar--collapsed .sidebar__toggle{top:75px;right:50%;transform:translate(50%)}.sidebar--collapsed .sidebar__nav{margin-top:20px}.sidebar__logo{padding:24px;display:flex;align-items:center;gap:12px}.sidebar__logo-icon{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,#7c3aed 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px var(--primary-glow)}.sidebar__logo-icon .material-symbols-outlined{color:#fff;font-size:24px}.sidebar__logo-text h1{font-size:1.125rem;font-weight:700;color:#fff;line-height:1.2}.sidebar__logo-text p{font-size:.75rem;color:var(--text-gray)}.sidebar__nav{flex:1;padding:0 16px;display:flex;flex-direction:column;gap:4px;margin-top:16px}.sidebar__nav-section{padding:8px 16px;font-size:.7rem;font-weight:600;color:var(--text-gray);text-transform:uppercase;letter-spacing:.1em}.sidebar__nav-item{display:flex;align-items:center;gap:16px;padding:12px 16px;border-radius:var(--radius-md);color:var(--text-gray);text-decoration:none;font-size:.875rem;font-weight:500;transition:var(--transition);cursor:pointer;border:none;background:transparent;width:100%;text-align:left}.sidebar__nav-item:hover{color:#fff;background:#ffffff0d}.sidebar__nav-item:hover .material-symbols-outlined{color:var(--primary)}.sidebar__nav-item.active{background:#935af61a;color:var(--primary);border:1px solid rgba(147,90,246,.2);box-shadow:0 2px 10px #935af61a}.sidebar__nav-item.active .material-symbols-outlined{color:var(--primary);font-variation-settings:"FILL" 1}.sidebar--collapsed .sidebar__logo{padding:24px 16px;justify-content:center}.sidebar--collapsed .sidebar__nav{padding:0 12px}.sidebar--collapsed .sidebar__nav-item{justify-content:center;padding:12px}.sidebar__notification-badge{min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-left:auto}@keyframes badge-pulse{0%,to{transform:scale(1);box-shadow:0 0 #ec489966}50%{transform:scale(1.05);box-shadow:0 0 8px 2px #ec48994d}}.sidebar--collapsed .sidebar__notification-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;font-size:.65rem;margin-left:0}.sidebar--collapsed .sidebar__nav-item{position:relative}.sidebar__friends{padding:24px;border-top:1px solid var(--glass-border)}.sidebar__friends-title{font-size:.7rem;font-weight:600;color:var(--text-gray);text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px;padding:0 8px}.sidebar__friends-empty{padding:20px 8px;text-align:center;color:var(--text-muted);font-size:.85rem}.sidebar__friend{display:flex;align-items:center;gap:12px;padding:8px;margin:0 -8px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.sidebar__friend:hover{background:#ffffff0d}.sidebar__friend-avatar{position:relative;width:32px;height:32px}.sidebar__friend-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;transition:var(--transition)}.sidebar__friend:hover .sidebar__friend-avatar img{box-shadow:0 0 0 2px #935af680}.sidebar__friend-status{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-darker)}.sidebar__friend-status.online{background:var(--success)}.sidebar__friend-status.offline{background:var(--text-gray)}.sidebar__friend-info{flex:1;min-width:0}.sidebar__friend-name{font-size:.875rem;font-weight:500;color:#e5e7eb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__friend-activity{font-size:.625rem;color:var(--primary)}.sidebar__friend-activity.idle{color:var(--text-gray)}.main-content{flex:1;min-height:0;display:flex;flex-direction:column;position:relative;background:var(--bg-dark);overflow:hidden;margin-left:var(--sidebar-width);transition:margin-left .3s ease}.main-header{position:sticky;top:0;z-index:30;padding:8px 16px;display:flex;justify-content:space-between;align-items:center;background:#0f0f124d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.05)}.main-header__nav{display:flex;align-items:center;gap:8px;min-width:0;overflow:hidden}.main-header__nav-btn{width:32px;height:32px;border-radius:50%;background:#0006;border:none;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:var(--transition)}.main-header__nav-btn:hover{background:#ffffff1a}.main-header__nav-btn:disabled{color:#ffffff4d;cursor:not-allowed}.main-header__actions{display:flex;align-items:center;gap:16px}.main-header__btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-full);background:#0006;border:1px solid rgba(255,255,255,.05);color:#d1d5db;font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition)}.main-header__btn:hover{background:#ffffff1a}.main-header__avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.1)}.page-content{flex:1;overflow-y:auto;padding:40px;background:var(--bg-dark);min-height:0}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.tab-content{animation:fadeSlideIn .25s ease-out forwards}@keyframes fadeSlideInStaggered{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-item{animation:fadeSlideInStaggered .3s ease-out forwards;opacity:0}.animate-item:nth-child(1){animation-delay:.02s}.animate-item:nth-child(2){animation-delay:.04s}.animate-item:nth-child(3){animation-delay:.06s}.animate-item:nth-child(4){animation-delay:.08s}.animate-item:nth-child(5){animation-delay:.1s}.animate-item:nth-child(6){animation-delay:.12s}.animate-item:nth-child(7){animation-delay:.14s}.animate-item:nth-child(8){animation-delay:.16s}.animate-item:nth-child(9){animation-delay:.18s}.animate-item:nth-child(10){animation-delay:.2s}@media(max-width:1200px)and (min-width:769px){.page-content{padding:28px}}@media(max-width:1024px)and (min-width:769px){.page-content{padding:20px}}.connection-status{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:#ef4444e6;color:#fff;font-size:.85rem;font-weight:500;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:slideDown .3s ease-out}.connection-status__dot{width:8px;height:8px;border-radius:50%;background:#fff;animation:blink 1.2s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.offline-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.offline-overlay__content{text-align:center;padding:2rem;max-width:360px}.offline-overlay__icon{font-size:3rem;margin-bottom:1rem}.offline-overlay__title{font-size:1.5rem;font-weight:600;color:#fff;margin-bottom:.5rem}.offline-overlay__text{font-size:.95rem;color:#ffffffb3;margin-bottom:1.5rem;line-height:1.5}.offline-overlay__btn{padding:.75rem 1.5rem;border-radius:8px;border:none;background:var(--primary, #6366f1);color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:opacity .2s}.offline-overlay__btn:hover:not(:disabled){opacity:.9}.offline-overlay__btn:disabled{opacity:.6;cursor:wait}.skeleton-message-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 0}.skeleton-message-item__content{flex:1;display:flex;flex-direction:column;gap:.4rem}.skeleton-playlist-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 0}.skeleton-playlist-item__info{flex:1;display:flex;flex-direction:column;gap:.35rem}.skeleton-user-profile{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem}.skeleton-user-profile__stats{display:flex;gap:1.5rem;margin-top:.5rem}@keyframes skeletonPulse{0%,to{opacity:.4}50%{opacity:.7}}@keyframes skeletonWave{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton--text{height:1em;border-radius:4px}.skeleton--circular{border-radius:50%}.skeleton--rectangular{border-radius:0}.skeleton--rounded{border-radius:var(--radius-md)}.skeleton--pulse{animation:skeletonPulse 1.5s ease-in-out infinite}.skeleton--wave:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);animation:skeletonWave 1.5s ease-in-out infinite}.skeleton--none{animation:none}.skeleton-room-card{background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden}.skeleton-room-card__cover{height:180px;background:var(--bg-elevated)}.skeleton-room-card__content{padding:20px;display:flex;flex-direction:column;gap:12px}.skeleton-track-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--glass-bg);border-radius:var(--radius-md)}.skeleton-track-item__info{flex:1;display:flex;flex-direction:column;gap:8px}.skeleton-track-list{display:flex;flex-direction:column;gap:8px}.skeleton-friend-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--glass-bg);border-radius:var(--radius-md)}.skeleton-friend-item__info{flex:1;display:flex;flex-direction:column;gap:6px}.page-welcome{margin-bottom:32px}.page-welcome__title{font-size:2.5rem;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.page-welcome__subtitle{color:var(--text-secondary);font-size:1.1rem}.page-section{margin-bottom:32px}.page-section__title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 20px;letter-spacing:-.02em}.rooms-tab{width:100%}.rooms-tab__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:28px;perspective:1000px}@media(min-width:1600px){.rooms-grid{grid-template-columns:repeat(auto-fill,minmax(420px,1fr))}}.rooms-grid__empty{grid-column:1 / -1;text-align:center;padding:80px 40px;background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.room-card{background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:transform .4s ease,box-shadow .4s ease,border-color .3s ease;box-shadow:var(--shadow-glass)}.room-card:hover{transform:translateY(-8px);border-color:var(--accent-primary);box-shadow:var(--shadow-glass),0 25px 50px #a855f740,0 0 30px #935af626}.room-card:active{transform:translateY(-4px) scale(.98)}.room-card__cover{height:200px;background:linear-gradient(135deg,#a855f74d,#6366f14d);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.room-card__cover:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(168,85,247,.4) 0%,transparent 50%)}.room-card__waves{display:flex;align-items:flex-end;gap:6px;height:50px;z-index:1}@keyframes wave{0%,to{transform:scaleY(1)}50%{transform:scaleY(.5)}}.room-card:hover .room-card__waves span{animation-duration:.5s}.room-card__icon{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;z-index:1}.room-card__icon--custom{inset:auto;object-fit:none}.room-card__badge{position:absolute;top:12px;right:12px;z-index:2}.room-card__content{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.3) 60%,transparent 100%);z-index:2}.room-card__title{font-size:1.1rem;font-weight:700;margin-bottom:4px;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.room-card__meta{font-size:.8rem;color:#fffc;text-shadow:0 1px 2px rgba(0,0,0,.5)}.room-card__play{position:absolute;bottom:50%;right:16px;transform:translateY(50%) translateY(10px);width:48px;height:48px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 30px var(--accent-glow);opacity:0;transition:all .3s ease;z-index:3}.room-card:hover .room-card__play{opacity:1;transform:translateY(50%)}.room-card__play .material-symbols-outlined{font-size:28px;color:#fff}.room-card--permanent .room-card__cover{background:linear-gradient(135deg,#10b9814d,#22c55e4d)}.room-card--permanent .room-card__cover:before{background:radial-gradient(circle at 30% 50%,rgba(16,185,129,.4) 0%,transparent 50%)}.room-card--permanent:hover{border-color:#10b981;box-shadow:var(--shadow-glass),0 20px 40px #10b98133}.room-card--permanent .room-card__waves span{background:linear-gradient(135deg,#10b981,#22c55e)}.rooms-grid--permanent{margin-bottom:32px}.home{min-height:100vh;display:flex;flex-direction:column}.home__header{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border-bottom:1px solid var(--glass-border);position:sticky;top:0;z-index:var(--z-dropdown)}.home__header h1{font-size:1.8rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home__user{display:flex;align-items:center;gap:20px}.home__user span{color:var(--text-secondary);font-weight:500;padding:8px 16px;background:var(--glass-bg-light);border-radius:var(--radius-full);border:1px solid var(--glass-border-light)}.home__user button{padding:10px 20px;border:1px solid var(--glass-border);border-radius:var(--radius-full);background:var(--glass-bg);color:var(--text-primary);cursor:pointer;font-weight:600;font-size:.9rem;transition:var(--transition);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.home__user button:hover{background:var(--glass-bg-strong);border-color:var(--accent-primary);box-shadow:0 0 20px #a855f733}.home__main{flex:1;padding:40px;max-width:1000px;margin:0 auto;width:100%}.home__section{background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:28px;margin-bottom:28px;box-shadow:var(--shadow-glass)}.home__section h2{margin-bottom:20px;font-size:1.3rem;font-weight:600;color:var(--text-primary)}.home__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.home__section-header h2{margin-bottom:0}.home__section-header button{padding:10px 24px;border:none;border-radius:var(--radius-full);background:var(--accent-gradient);color:#fff;cursor:pointer;font-weight:600;font-size:.9rem;transition:var(--transition)}.home__section-header button:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)}.home__join-form,.home__create-form{display:flex;gap:16px}.home__join-form input,.home__create-form input{flex:1;padding:14px 20px;border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--glass-bg-light);color:var(--text-primary);font-size:1rem;transition:var(--transition)}.home__join-form input:focus,.home__create-form input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 20px #a855f726}.home__join-form input::placeholder,.home__create-form input::placeholder{color:var(--text-muted)}.home__join-form button,.home__create-form button{padding:14px 32px;border:none;border-radius:var(--radius-full);background:var(--accent-gradient);color:#fff;cursor:pointer;font-weight:600;transition:var(--transition);white-space:nowrap}.home__join-form button:hover:not(:disabled),.home__create-form button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)}.home__join-form button:disabled,.home__create-form button:disabled{opacity:.5;cursor:not-allowed}.home__error{color:var(--error);margin-bottom:20px;padding:14px 18px;background:#f43f5e26;border:1px solid rgba(244,63,94,.3);border-radius:var(--radius-md);font-size:.9rem}.home__empty{color:var(--text-muted);text-align:center;padding:40px 20px;font-style:italic}.home__rooms{list-style:none}.home__room{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;background:var(--glass-bg-light);border:1px solid var(--glass-border-light);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);margin-bottom:12px}.home__room:last-child{margin-bottom:0}.home__room:hover{background:var(--glass-bg);border-color:var(--accent-primary);transform:translate(8px);box-shadow:0 4px 20px #a855f726}.home__room-name{font-weight:600;font-size:1.05rem}.home__room-code{color:var(--accent-primary);font-family:SF Mono,Fira Code,monospace;font-size:.9rem;background:#a855f726;padding:6px 14px;border-radius:var(--radius-sm);letter-spacing:.1em;font-weight:600}.home__room-members{color:var(--text-secondary);font-size:.9rem}.lobby{display:flex;min-height:100vh}.lobby__sidebar{width:280px;background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border-right:1px solid var(--glass-border);display:flex;flex-direction:column;padding:24px;position:fixed;top:0;left:0;bottom:0;z-index:100}.lobby__logo{display:flex;align-items:center;gap:14px;margin-bottom:40px}.lobby__logo-icon{width:48px;height:48px;background:var(--accent-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 4px 20px var(--accent-glow)}.lobby__logo span{font-size:1.4rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lobby__nav{display:flex;flex-direction:column;gap:8px;flex:1}.lobby__nav-item{display:flex;align-items:center;gap:14px;padding:14px 18px;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-size:1rem;font-weight:500;cursor:pointer;transition:var(--transition);text-align:left}.lobby__nav-item:hover{background:var(--glass-bg-light);color:var(--text-primary)}.lobby__nav-item--active{background:var(--glass-bg);border-color:var(--glass-border);color:var(--text-primary)}.lobby__nav-item--active .lobby__nav-icon{color:var(--accent-primary)}.lobby__nav-icon{font-size:1.2rem}.lobby__nav-badge{margin-left:auto;background:var(--accent-gradient);color:#fff;font-size:.75rem;font-weight:700;padding:2px 10px;border-radius:var(--radius-full)}.lobby__user{display:flex;align-items:center;gap:14px;padding:16px;background:var(--glass-bg-light);border:1px solid var(--glass-border-light);border-radius:var(--radius-md);margin-top:auto}.lobby__user-avatar{width:44px;height:44px;background:var(--accent-gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:#fff;flex-shrink:0}.lobby__user-info{flex:1;min-width:0}.lobby__user-name{display:block;font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lobby__user-actions{display:flex;align-items:center;gap:8px;margin-top:2px}.lobby__settings-btn{background:none;border:none;cursor:pointer;padding:2px;font-size:1rem;opacity:.6;transition:var(--transition)}.lobby__settings-btn:hover{opacity:1;transform:rotate(45deg)}.lobby__logout{display:block;background:none;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;padding:0;transition:var(--transition)}.lobby__logout:hover{color:var(--error)}.lobby__content{flex:1;margin-left:280px;padding:40px;min-height:100vh}.lobby__header{margin-bottom:32px}.lobby__title{font-size:2.5rem;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.lobby__subtitle{color:var(--text-secondary);font-size:1.1rem}.lobby__create{margin-bottom:32px}.lobby__create-room-btn{display:flex;align-items:center;gap:16px;width:100%;background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:20px 24px;box-shadow:var(--shadow-glass);cursor:pointer;transition:var(--transition);color:var(--text-primary);font-size:1.1rem;font-weight:500}.lobby__create-room-btn:hover{background:var(--glass-bg-strong);border-color:var(--accent-primary)}.lobby__create-icon{width:48px;height:48px;background:var(--accent-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.8rem;line-height:1;color:#fff;flex-shrink:0}.lobby__create-input::placeholder{color:var(--text-muted)}.lobby__create-btn{padding:14px 32px;background:var(--accent-gradient);border:none;border-radius:var(--radius-full);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition)}.lobby__create-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)}.lobby__create-btn:disabled{opacity:.5;cursor:not-allowed}.lobby__error{background:#f43f5e26;border:1px solid rgba(244,63,94,.3);color:var(--error);padding:16px 20px;border-radius:var(--radius-md);margin-bottom:24px}.lobby__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.lobby__empty{grid-column:1 / -1;text-align:center;padding:80px 40px;background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.lobby__empty-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.lobby__empty h3{font-size:1.5rem;margin-bottom:10px;color:var(--text-primary)}.lobby__empty p{color:var(--text-muted)}.room-card__visual{height:120px;background:linear-gradient(135deg,#a855f74d,#6366f14d);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.room-card__visual:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(168,85,247,.4) 0%,transparent 50%)}.room-card__waves{display:flex;align-items:flex-end;gap:6px;height:50px}.room-card__waves span{width:8px;background:var(--accent-gradient);border-radius:4px;animation:wave 1s ease-in-out infinite}.room-card__waves span:nth-child(1){height:20px;animation-delay:0s}.room-card__waves span:nth-child(2){height:35px;animation-delay:.1s}.room-card__waves span:nth-child(3){height:25px;animation-delay:.2s}.room-card__waves span:nth-child(4){height:40px;animation-delay:.3s}.room-card__content{padding:20px}.room-card__name{font-size:1.2rem;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.room-card__meta{display:flex;align-items:center;gap:12px}.room-card__owner{font-size:.85rem;color:var(--accent-primary);background:#a855f726;padding:4px 12px;border-radius:var(--radius-full)}.room-card__members{font-size:.85rem;color:var(--text-secondary)}.room-card__action{padding:16px 20px;border-top:1px solid var(--glass-border-light);display:flex;justify-content:flex-end}.room-card__enter{color:var(--text-muted);font-size:.9rem;font-weight:500;transition:var(--transition)}.room-card:hover .room-card__enter{color:var(--accent-primary)}::selection{background:var(--accent-primary);color:#fff}.player-bar{position:fixed;bottom:0;left:0;right:0;width:100%;height:var(--player-height);background:#130c1cfa;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border-top:1px solid var(--glass-border);flex-shrink:0;box-shadow:0 -10px 40px #0000004d;z-index:var(--z-player)}.player-bar__progress{height:4px;background:#27272a;cursor:pointer;position:relative;transition:height .15s ease}.player-bar__progress:hover{height:6px}.player-bar__progress-fill{height:100%;background:linear-gradient(90deg,#935af6,#7c3aed);position:relative;transition:width .1s linear;box-shadow:0 0 10px #935af680}.player-bar__progress:hover .player-bar__progress-fill:after{content:"";position:absolute;right:-7px;top:50%;transform:translateY(-50%) scale(1);width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000004d,0 0 15px #935af680;transition:transform .15s ease}.player-bar__progress:active .player-bar__progress-fill:after{transform:translateY(-50%) scale(1.2)}.player-bar__content{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:calc(100% - 4px)}.player-bar__track{display:flex;align-items:center;gap:16px;width:25%;min-width:200px}.player-bar__track-cover{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:cover;position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .3s ease,box-shadow .3s ease}.player-bar__track-cover--playing{animation:cover-pulse 2s ease-in-out infinite;box-shadow:0 0 20px #935af666}@keyframes cover-pulse{0%,to{box-shadow:0 0 15px #935af64d}50%{box-shadow:0 0 25px #935af680}}.player-bar__track-cover .now-playing-indicator{position:absolute;bottom:4px;right:4px;background:#0009;padding:3px 4px;border-radius:3px;height:14px}.player-bar__track-cover .now-playing-indicator__bar{width:2px;background:var(--primary)}.player-bar__track-info{display:flex;flex-direction:column;min-width:0}.player-bar__track-name{font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.875rem}.player-bar__track-artist{font-size:.75rem;color:var(--text-gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-bar__track-like{background:none;border:none;color:var(--primary);cursor:pointer;padding:4px;margin-left:8px}.player-bar__controls{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}.player-bar__buttons{display:flex;align-items:center;gap:24px}.player-bar__btn{background:none;border:none;color:var(--text-gray);cursor:pointer;padding:4px;transition:var(--transition)}.player-bar__btn:hover{color:#fff}.player-bar__btn--main{width:40px;height:40px;border-radius:50%;background:#fff;color:#000!important;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #ffffff1a;transition:var(--transition)}.player-bar__btn--main:hover{transform:scale(1.05)}.player-bar__time{font-size:.625rem;color:var(--text-gray);font-weight:500;letter-spacing:.05em}.player-bar__extras{display:flex;align-items:center;justify-content:flex-end;gap:12px;width:25%;min-width:200px}.player-bar__volume{display:flex;align-items:center;gap:8px}.player-bar__volume-slider{width:100px;height:6px;background:#3f3f46;border-radius:3px;cursor:pointer;position:relative;touch-action:none;-webkit-user-select:none;user-select:none}.player-bar__volume-fill{height:100%;background:var(--text-gray);border-radius:3px;transition:background .15s ease;pointer-events:none}.player-bar__volume-thumb{position:absolute;top:50%;width:10px;height:10px;background:var(--text-primary);border-radius:50%;transform:translate(-50%,-50%);opacity:0;transition:opacity .15s ease,transform .15s ease;pointer-events:none;box-shadow:0 1px 3px #0000004d}.player-bar__volume:hover .player-bar__volume-fill,.player-bar__volume-slider:active .player-bar__volume-fill{background:var(--primary)}.player-bar__volume:hover .player-bar__volume-thumb,.player-bar__volume-slider:active .player-bar__volume-thumb{opacity:1}.player-bar__volume-slider:active .player-bar__volume-thumb{transform:translate(-50%,-50%) scale(1.2)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-pulse{animation:pulse 1.5s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-fade-in{animation:fade-in .3s ease-out}.player{position:fixed;bottom:0;left:0;right:0;height:var(--player-height);background:var(--glass-bg-strong);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-top:1px solid var(--glass-border);display:grid;grid-template-columns:1fr 2fr 1fr;align-items:center;padding:0 32px;z-index:var(--z-sidebar)}.player--empty{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-style:italic}.player__info{display:flex;align-items:center;gap:18px;min-width:0}.player__cover{width:64px;height:64px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--accent-primary);font-size:1.8rem;flex-shrink:0;box-shadow:0 4px 20px #0000004d}.player__track{min-width:0}.player__title{display:block;font-size:.95rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.player__artist{display:block;font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player__center{display:flex;flex-direction:column;align-items:center;gap:10px}.player__controls{display:flex;justify-content:center;align-items:center;gap:20px}.player__btn{width:40px;height:40px;border-radius:50%;background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary);font-size:1.1rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.player__btn:hover:not(:disabled){background:var(--glass-bg-strong);border-color:var(--accent-primary);transform:scale(1.1);box-shadow:0 0 20px #a855f74d}.player__btn:disabled{opacity:.3;cursor:not-allowed}.player__btn--play{width:52px;height:52px;background:var(--accent-gradient);border:none;color:#fff;font-size:1.3rem;box-shadow:0 4px 20px var(--accent-glow)}.player__btn--play:hover:not(:disabled){transform:scale(1.08);box-shadow:0 6px 30px var(--accent-glow)}.player__progress{display:flex;align-items:center;gap:14px;width:100%;max-width:600px}.player__time{font-size:.75rem;color:var(--text-muted);min-width:45px;font-family:SF Mono,Fira Code,monospace}.player__time:last-child{text-align:right}.player__slider{flex:1;-webkit-appearance:none;height:5px;border-radius:3px;background:var(--glass-bg);cursor:pointer;transition:var(--transition)}.player__slider:hover{height:7px}.player__slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-gradient);cursor:pointer;box-shadow:0 2px 10px var(--accent-glow);opacity:0;transition:var(--transition)}.player__slider:hover::-webkit-slider-thumb{opacity:1}.player__slider:disabled{opacity:.3;cursor:not-allowed}.player__right{display:flex;align-items:center;justify-content:flex-end;gap:20px}.player__volume{display:flex;align-items:center;gap:10px;color:var(--text-secondary)}.player__volume-icon{font-size:1.1rem;cursor:pointer;transition:var(--transition)}.player__volume-icon:hover{color:var(--accent-primary)}.player__slider--volume{width:100px}.player__volume-value{font-size:.75rem;color:var(--text-muted);min-width:35px;text-align:right}.player__host-info{font-size:.8rem;color:var(--text-muted);background:var(--glass-bg);padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--glass-border-light)}.mini-player{position:fixed;bottom:20px;right:20px;background:var(--surface-bg);border:1px solid var(--border-color);border-radius:12px;padding:12px 16px;box-shadow:0 8px 24px #0000004d;z-index:var(--z-player);min-width:280px;max-width:320px;transition:all .3s ease}.mini-player--expanded{max-height:400px}.mini-player__content{display:flex;align-items:center;gap:12px}.mini-player__track-info{flex:1;min-width:0}.mini-player__track-title{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-player__track-artist{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-player__controls{display:flex;gap:8px;align-items:center}.mini-player__btn{background:transparent;border:none;color:var(--text-primary);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.mini-player__btn:hover{background:var(--hover-bg)}.mini-player__btn--play{background:var(--primary);color:#fff;width:40px;height:40px}.mini-player__btn--play:hover{opacity:.9;background:var(--primary)}.mini-player__btn .material-symbols-outlined{font-size:20px}.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap}.ui-btn--primary{background:var(--accent-gradient);color:#fff}.ui-btn--primary:hover{opacity:.9;transform:translateY(-1px)}.ui-btn--secondary{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary)}.ui-btn--secondary:hover{background:var(--glass-bg-strong);border-color:var(--accent-primary)}.ui-btn--ghost{background:transparent;color:var(--text-secondary)}.ui-btn--ghost:hover{background:var(--glass-bg);color:var(--text-primary)}.ui-btn--danger{background:var(--error);color:#fff}.ui-btn--danger:hover{opacity:.9}.ui-btn--sm{padding:6px 12px;font-size:.8rem}.ui-btn--md{padding:8px 16px;font-size:.875rem}.ui-btn--lg{padding:12px 24px;font-size:1rem}.ui-btn--icon-only{padding:10px}.ui-btn--loading{opacity:.7;pointer-events:none}.ui-btn__icon{font-size:1.1em}.ui-btn__spinner{width:16px;height:16px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.ui-select{position:relative;display:inline-block;min-width:160px}.ui-select__trigger{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:var(--transition)}.ui-select__trigger:hover,.ui-select--open .ui-select__trigger{border-color:var(--accent-primary);background:var(--glass-bg-hover)}.ui-select__icon{font-size:18px;color:var(--text-secondary)}.ui-select__value{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ui-select__chevron{font-size:20px;color:var(--text-secondary);transition:transform .2s ease}.ui-select--open .ui-select__chevron{color:var(--accent-primary)}.ui-select__dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:var(--z-dropdown);background:#1e1e2e;border:1px solid rgba(139,92,246,.3);border-radius:var(--radius-md);box-shadow:0 8px 32px #0009;overflow:hidden;animation:selectDropdownIn .15s ease-out}@keyframes selectDropdownIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ui-select__option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:var(--transition);text-align:left}.ui-select__option:hover{background:var(--glass-bg-hover)}.ui-select__option--selected{background:#8b5cf626;color:var(--accent-primary)}.ui-select__option--selected:hover{background:#8b5cf640}.ui-select__option-icon{font-size:18px;color:var(--text-secondary)}.ui-select__option--selected .ui-select__option-icon{color:var(--accent-primary)}.ui-select__option-check{margin-left:auto;font-size:18px;color:var(--accent-primary)}.ui-icon-btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);background:transparent;color:var(--text-primary)}.ui-icon-btn--sm{width:24px;height:24px;font-size:1.1rem}.ui-icon-btn--sm .material-symbols-outlined{font-size:1.1rem}.ui-icon-btn--md{width:32px;height:32px;font-size:1.3rem}.ui-icon-btn--md .material-symbols-outlined{font-size:1.3rem}.ui-icon-btn--lg{width:40px;height:40px;font-size:1.5rem}.ui-icon-btn--lg .material-symbols-outlined{font-size:1.5rem}.ui-icon-btn--ghost:hover{background:var(--glass-bg)}.ui-icon-btn--primary{background:var(--accent-gradient);color:#fff}.ui-icon-btn--primary:hover{opacity:.9}.ui-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.ui-badge--live{background:#eb0400;color:#fff}.ui-badge--online{background:var(--success);color:#fff}.ui-badge--dot{padding-left:6px}.ui-badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor}.ui-badge--pulse .ui-badge__dot{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.ui-tabs{display:flex;flex-direction:column;height:100%}.ui-tabs__list{display:flex;gap:4px;padding:12px 16px;background:#0003;border-bottom:1px solid var(--glass-border)}.ui-tabs__trigger{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}.ui-tabs__trigger:hover{background:var(--glass-bg);color:var(--text-primary)}.ui-tabs__trigger--active{background:var(--accent-gradient);border-color:transparent;color:#fff}.ui-tabs__trigger .material-symbols-outlined{font-size:1.1rem}.ui-tabs__content{flex:1;overflow:auto}.ui-card{background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-glass)}.ui-card--elevated{box-shadow:var(--shadow-glass),0 8px 32px #0000004d}.ui-card--interactive{cursor:pointer;transition:var(--transition)}.ui-card--interactive:hover{border-color:var(--glass-border-hover);transform:translateY(-2px)}.ui-card--hoverable{transition:var(--transition)}.ui-card--hoverable:hover{border-color:var(--glass-border-hover)}.ui-card--padding-sm{padding:12px}.ui-card--padding-md{padding:20px}.ui-card--padding-lg{padding:28px}.room-view .stream-player{border-radius:var(--radius-lg);overflow:hidden}.glass-panel{transition:var(--transition)}.glass-panel:hover{border-color:var(--glass-border-hover)}.room-card:hover .room-play-btn{opacity:1!important;transform:translateY(0)!important}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:400px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-md, 8px);background:var(--glass-bg, rgba(30, 30, 40, .95));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0000004d;color:var(--text-primary, #fff);font-size:14px;pointer-events:auto;cursor:pointer;min-width:280px;animation:toast-slide-in .3s ease-out}.toast__icon{font-size:20px;flex-shrink:0}.toast--success .toast__icon{color:#22c55e}.toast--error .toast__icon{color:#ef4444}.toast--info .toast__icon{color:#3b82f6}.toast--warning .toast__icon{color:#f59e0b}.toast--progress .toast__icon{color:var(--primary, #935af6)}.toast--success{border-left:3px solid #22c55e}.toast--error{border-left:3px solid #ef4444}.toast--info{border-left:3px solid #3b82f6}.toast--warning{border-left:3px solid #f59e0b}.toast--progress{border-left:3px solid var(--primary, #935af6);cursor:default}.toast__message{flex:1;line-height:1.4}.toast__close{background:none;border:none;color:var(--text-muted, rgba(255,255,255,.5));cursor:pointer;font-size:14px;padding:2px 4px;border-radius:4px;transition:color .2s,background .2s;flex-shrink:0}.toast__close:hover{color:var(--text-primary, #fff);background:#ffffff1a}.toast__progress-bar{width:100%;height:3px;background:#ffffff1a;border-radius:2px;overflow:hidden;margin-top:4px;position:absolute;bottom:0;left:0;right:0;border-radius:0 0 var(--radius-md, 8px) var(--radius-md, 8px)}.toast__progress-fill{height:100%;background:var(--primary, #935af6);border-radius:2px;transition:width .3s ease}.toast--progress{position:relative;overflow:hidden;padding-bottom:15px}@media(max-width:768px){.toast-container{right:16px;left:16px;max-width:none}}.confirm-overlay{position:fixed;inset:0;z-index:10001;display:flex;align-items:center;justify-content:center;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:modal-backdrop-in .2s ease-out forwards}.confirm-overlay--closing{animation:modal-backdrop-out .2s ease-in forwards}.confirm-dialog{background:var(--glass-bg, rgba(30, 30, 40, .95));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border, rgba(255, 255, 255, .1));border-radius:var(--radius-lg, 12px);box-shadow:0 16px 64px #00000080;padding:24px;min-width:320px;max-width:420px;animation:modal-content-in .25s ease-out forwards}.confirm-dialog--closing{animation:modal-content-out .2s ease-in forwards}.confirm-dialog__title{margin:0 0 8px;font-size:1.1rem;font-weight:600;color:var(--text-primary, #fff)}.confirm-dialog__message{margin:0 0 20px;font-size:.9rem;color:var(--text-secondary, rgba(255, 255, 255, .7));line-height:1.5}.confirm-dialog__actions{display:flex;gap:8px;justify-content:flex-end}.confirm-dialog__btn{padding:8px 20px;border:none;border-radius:var(--radius-md, 8px);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}.confirm-dialog__btn--cancel{background:var(--glass-bg, rgba(255, 255, 255, .05));border:1px solid var(--glass-border, rgba(255, 255, 255, .1));color:var(--text-secondary, rgba(255, 255, 255, .7))}.confirm-dialog__btn--cancel:hover{background:var(--glass-bg-hover, rgba(255, 255, 255, .1));color:var(--text-primary, #fff)}.confirm-dialog__btn--confirm{background:var(--accent-gradient, linear-gradient(135deg, #935af6, #7c3aed));color:#fff}.confirm-dialog__btn--confirm:hover{opacity:.9;transform:translateY(-1px)}.confirm-dialog__btn--danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.confirm-dialog__btn--danger:hover{opacity:.9;transform:translateY(-1px)}@media(max-width:768px){.confirm-dialog{min-width:auto;margin:0 16px}}.auth{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;position:relative;overflow-x:hidden;max-width:100%;width:100%}.auth__title{font-size:3.5rem;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;letter-spacing:-1px;text-shadow:0 0 60px var(--accent-glow)}.auth__subtitle{color:var(--text-secondary);margin-bottom:3rem;font-size:1.1rem;font-weight:300}.auth__form{background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-glass),var(--shadow-glow)}.auth__form h2{margin-bottom:2rem;font-size:1.5rem;font-weight:600;text-align:center;color:var(--text-primary)}.auth__input{width:100%;padding:16px 20px;margin-bottom:16px;border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--glass-bg-light);color:var(--text-primary);font-size:1rem;transition:var(--transition);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.auth__input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 20px #a855f733;background:var(--glass-bg)}.auth__input::placeholder{color:var(--text-muted)}.auth__error{color:var(--error);margin-bottom:16px;padding:14px 18px;background:#f43f5e26;border:1px solid rgba(244,63,94,.3);border-radius:var(--radius-md);font-size:.9rem;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.auth__btn{width:100%;padding:16px 28px;font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-full);background:var(--accent-gradient);color:#fff;cursor:pointer;transition:var(--transition);margin-top:8px;position:relative;overflow:hidden}.auth__btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 50%);opacity:0;transition:var(--transition)}.auth__btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 40px var(--accent-glow)}.auth__btn:hover:not(:disabled):before{opacity:1}.auth__btn:active:not(:disabled){transform:translateY(0)}.auth__btn:disabled{opacity:.5;cursor:not-allowed}.auth__switch{margin-top:2rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.auth__switch button{background:none;border:none;color:var(--accent-primary);cursor:pointer;font-weight:600;transition:var(--transition)}.auth__switch button:hover{color:var(--text-primary);text-shadow:0 0 20px var(--accent-glow)}.chat{padding:22px;flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.chat__title{margin-bottom:18px;font-size:1.1rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:10px}.chat__title:before{content:"";width:4px;height:20px;background:var(--accent-gradient);border-radius:2px}.chat__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.chat__header .chat__title{margin-bottom:0}.chat__notify-btn{width:32px;height:32px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:50%;font-size:1rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.chat__notify-btn:hover{transform:scale(1.1);background:var(--glass-bg-light)}.chat__notify-btn--active{background:var(--success);border-color:var(--success)}.chat__messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px;min-height:0;margin-bottom:16px}.chat__messages::-webkit-scrollbar{width:6px}.chat__messages::-webkit-scrollbar-track{background:transparent}.chat__messages::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px}.chat__empty{color:var(--text-muted);text-align:center;padding:30px;font-style:italic}.chat__message{margin-bottom:10px;display:flex;flex-direction:column;align-items:flex-start;max-width:75%}.chat__message--own{align-items:flex-end;align-self:flex-end}.chat__message-author{font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:4px;padding:0 4px}.chat__message--own .chat__message-author{color:var(--accent-primary)}.chat__message-bubble{padding:10px 14px;border-radius:16px;background:var(--glass-bg-light);border:none;box-shadow:0 2px 8px #00000026;transition:var(--transition)}.chat__message:hover .chat__message-bubble{box-shadow:0 4px 12px #00000040}.chat__message--own .chat__message-bubble{background:var(--accent-gradient);border-radius:16px 16px 4px}.chat__message:not(.chat__message--own) .chat__message-bubble{border-radius:16px 16px 16px 4px}.chat__message-text{font-size:.875rem;word-wrap:break-word;line-height:1.4;color:var(--text-primary);margin:0}.chat__message-link{color:var(--accent-primary);text-decoration:underline;text-underline-offset:2px}.chat__message-link:hover{color:var(--accent-secondary)}.chat__message--own .chat__message-text{color:#fff}.chat__message-time{font-size:.65rem;color:var(--text-muted);margin-top:4px;opacity:.7}.chat__message--own .chat__message-time{color:#fffc}.chat__form{display:flex;gap:12px;flex-shrink:0;margin-top:auto}.chat__input-wrapper{flex:1;position:relative;display:flex;align-items:center;gap:8px;padding:0 14px;border:1px solid var(--glass-border);border-radius:var(--radius-full);background:var(--glass-bg-light);transition:var(--transition)}.chat__input-wrapper:focus-within{border-color:var(--accent-primary);box-shadow:0 0 20px #a855f726}.chat__emoji-toggle{background:none;border:none;font-size:1.3rem;cursor:pointer;padding:4px;line-height:1;transition:var(--transition);flex-shrink:0}.chat__emoji-toggle:hover{transform:scale(1.1)}.chat__emoji-picker{position:absolute;bottom:calc(100% + 8px);left:0;background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:12px;display:grid;grid-template-columns:repeat(6,1fr);gap:8px;box-shadow:0 8px 32px #0006;z-index:10}.chat__emoji-btn{background:transparent;border:none;font-size:1.5rem;cursor:pointer;padding:8px;border-radius:var(--radius-sm);transition:var(--transition);line-height:1}.chat__emoji-btn:hover{background:var(--glass-bg);transform:scale(1.2)}.chat__input{flex:1;padding:14px 6px;border:none;background:transparent;color:var(--text-primary);font-size:.9rem;outline:none}.chat__input::placeholder{color:var(--text-muted)}.chat__send{width:36px;height:36px;min-width:36px;padding:0;border:none;border-radius:50%;background:var(--accent-gradient);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0}.chat__send .material-symbols-outlined{font-size:20px}.chat__send:hover:not(:disabled){transform:scale(1.1);box-shadow:0 4px 15px var(--accent-glow)}.chat__send:disabled{opacity:.4;cursor:not-allowed;background:var(--glass-bg)}.chat__typing-indicator{display:flex;align-items:center;gap:6px;padding:4px 12px;font-size:.75rem;color:#ffffff80;flex-shrink:0;min-height:20px}.chat__typing-dots{display:inline-flex;align-items:center;gap:3px}.chat__typing-dot{width:4px;height:4px;border-radius:50%;background:#ffffff80;animation:chat-typing-bounce 1.4s ease-in-out infinite}.chat__typing-dot:nth-child(2){animation-delay:.2s}.chat__typing-dot:nth-child(3){animation-delay:.4s}@keyframes chat-typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.chat__typing-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.emoji-picker{position:absolute;bottom:calc(100% + 8px);right:0;width:340px;background:var(--glass-bg, rgba(30, 30, 40, .95));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border, rgba(255, 255, 255, .1));border-radius:var(--radius-lg, 12px);box-shadow:0 12px 40px #0006;z-index:100;overflow:hidden;animation:modal-content-in .2s ease-out}.emoji-picker__search{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.06)}.emoji-picker__search-input{width:100%;padding:6px 10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm, 6px);color:var(--text-primary, #fff);font-size:.85rem;outline:none;transition:border-color .2s}.emoji-picker__search-input:focus{border-color:var(--primary, #935af6)}.emoji-picker__search-input::placeholder{color:var(--text-muted, rgba(255, 255, 255, .3))}.emoji-picker__tabs{display:flex;gap:2px;padding:6px 8px;border-bottom:1px solid rgba(255,255,255,.06);overflow-x:auto;scrollbar-width:none}.emoji-picker__tabs::-webkit-scrollbar{display:none}.emoji-picker__tab{flex-shrink:0;padding:4px 6px;background:none;border:none;border-radius:var(--radius-sm, 6px);font-size:1.1rem;cursor:pointer;opacity:.5;transition:opacity .2s,background .2s}.emoji-picker__tab:hover{opacity:.8;background:#ffffff0d}.emoji-picker__tab--active{opacity:1;background:#ffffff1a}.emoji-picker__category-label{padding:4px 12px;font-size:.75rem;color:var(--text-muted, rgba(255, 255, 255, .4));text-transform:uppercase;letter-spacing:.5px}.emoji-picker__grid-container{height:250px;overflow-y:auto;padding:0 8px 8px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.emoji-picker__grid-container::-webkit-scrollbar{width:4px}.emoji-picker__grid-container::-webkit-scrollbar-track{background:transparent}.emoji-picker__grid-container::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.emoji-picker__grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px}.emoji-picker__emoji{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;border-radius:var(--radius-sm, 6px);font-size:1.3rem;cursor:pointer;transition:background .15s,transform .15s}.emoji-picker__emoji:hover{background:#ffffff1a;transform:scale(1.2)}.emoji-picker__empty{display:flex;align-items:center;justify-content:center;height:100px;color:var(--text-muted, rgba(255, 255, 255, .4));font-size:.85rem}@media(max-width:768px){.emoji-picker{width:300px;right:-20px}}.sticker-picker{position:absolute;bottom:calc(100% + 8px);right:0;width:280px;background:var(--glass-bg, rgba(30, 30, 40, .95));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border, rgba(255, 255, 255, .1));border-radius:var(--radius-lg, 12px);box-shadow:0 12px 40px #0006;z-index:100;overflow:hidden;animation:modal-content-in .2s ease-out}.sticker-picker__header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.06);font-size:.85rem;color:var(--text-secondary)}.sticker-picker__close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:0;line-height:1}.sticker-picker__close:hover{color:var(--text-primary)}.sticker-picker__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:8px;max-height:200px;overflow-y:auto}.sticker-picker__sticker{background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;padding:4px;transition:background .15s,transform .15s}.sticker-picker__sticker:hover{background:#ffffff1a;transform:scale(1.1)}.sticker-picker__sticker img{width:100%;aspect-ratio:1;object-fit:contain}@media(max-width:768px){.sticker-picker{width:250px;right:-10px}}.chat__message--deleted .chat__message-bubble{opacity:.5}.chat__message-text--deleted{font-style:italic;color:var(--text-muted);font-size:.8rem}.chat__message--own .chat__message-text--deleted{color:#fff9}.chat__message-meta{display:flex;align-items:center;gap:4px;margin-top:4px}.chat__message-edited{font-size:.6rem;color:var(--text-muted);opacity:.7}.chat__message--own .chat__message-edited{color:#fff9}.chat__message-actions-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;padding:0;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.chat__message-actions-btn .material-symbols-outlined{font-size:16px;color:var(--text-secondary)}.chat__message{position:relative}.chat__message:hover .chat__message-actions-btn{opacity:1}.chat__message--own .chat__message-actions-btn{right:auto;left:4px}.chat__context-menu{position:absolute;top:0;right:0;min-width:160px;background:var(--glass-bg-strong, rgba(30, 30, 40, .95));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-md, 8px);padding:4px;box-shadow:0 8px 32px #0006;z-index:20;animation:modal-content-in .15s ease-out}.chat__message--own .chat__context-menu{right:auto;left:0}.chat__context-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;border-radius:var(--radius-sm, 6px);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:background .15s}.chat__context-menu-item .material-symbols-outlined{font-size:18px}.chat__context-menu-item:hover{background:#ffffff14}.chat__context-menu-item--danger{color:var(--danger, #ef4444)}.chat__context-menu-item--danger:hover{background:#ef44441a}.chat__edit-bar{display:flex;align-items:center;gap:8px;padding:6px 14px;background:#935af61a;border-left:3px solid var(--primary, #935af6);border-radius:0 var(--radius-sm, 6px) var(--radius-sm, 6px) 0;margin-bottom:8px;flex-shrink:0}.chat__edit-bar .material-symbols-outlined{font-size:16px;color:var(--primary, #935af6)}.chat__edit-bar-text{flex:1;font-size:.8rem;color:var(--primary, #935af6);font-weight:500}.chat__edit-bar-cancel{width:22px;height:22px;padding:0;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.chat__edit-bar-cancel .material-symbols-outlined{font-size:16px;color:var(--text-muted)}.chat__edit-bar-cancel:hover{background:#ffffff1a}.chat__image-btn{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition);opacity:.6}.chat__image-btn .material-symbols-outlined{font-size:20px;color:var(--text-secondary)}.chat__image-btn:hover{opacity:1;transform:scale(1.1)}.chat__image-preview{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--glass-bg-light);border:1px solid var(--glass-border);border-radius:var(--radius-md, 8px);margin-bottom:8px;flex-shrink:0}.chat__image-preview-thumb{width:48px;height:48px;border-radius:var(--radius-sm, 6px);object-fit:cover;flex-shrink:0}.chat__image-preview-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.chat__image-preview-name{font-size:.8rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat__image-preview-size{font-size:.7rem;color:var(--text-muted)}.chat__image-preview-cancel{width:24px;height:24px;padding:0;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.chat__image-preview-cancel .material-symbols-outlined{font-size:18px;color:var(--text-muted)}.chat__image-preview-cancel:hover{background:#ffffff1a}.chat__message-image-link{display:block;margin-bottom:6px;padding:0;background:none;border:none;cursor:pointer}.chat__message-image{max-width:280px;max-height:280px;border-radius:var(--radius-sm, 6px);object-fit:contain;cursor:pointer;transition:opacity .15s}.chat__message-image:hover{opacity:.9}.chat__message-sticker{max-width:150px;max-height:150px;border-radius:var(--radius-sm, 6px);object-fit:contain;margin-bottom:4px}.chat__messages--drag-over{position:relative}.chat__messages--drag-over:after{content:"Перетащите изображение сюда";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#935af626;border:2px dashed var(--accent-primary, #935af6);border-radius:var(--radius-md, 8px);color:var(--accent-primary, #935af6);font-size:.9rem;font-weight:500;pointer-events:none;z-index:5}.chat__upload-progress{height:3px;background:var(--glass-bg);border-radius:2px;overflow:hidden;margin-bottom:6px;flex-shrink:0}.chat__upload-progress-bar{height:100%;background:var(--accent-gradient);border-radius:2px;transition:width .2s ease}.chat__lightbox{position:fixed;inset:0;z-index:1000;background:#000000d9;display:flex;align-items:center;justify-content:center;animation:chat-lightbox-in .2s ease-out;cursor:pointer}@keyframes chat-lightbox-in{0%{opacity:0}to{opacity:1}}.chat__lightbox-image{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-md, 8px);box-shadow:0 8px 40px #0009;cursor:default}.chat__lightbox-close{position:absolute;top:16px;right:16px;width:40px;height:40px;padding:0;background:#ffffff26;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.chat__lightbox-close .material-symbols-outlined{font-size:24px;color:#fff}.chat__lightbox-close:hover{background:#ffffff40}@media(max-width:768px){.chat__message-actions-btn{display:none}.chat__context-menu{position:fixed;inset:auto 16px 80px;width:auto;border-radius:var(--radius-lg, 12px)}.chat__message--own .chat__context-menu{left:16px;right:16px}.chat__message-image{max-width:200px;max-height:200px}.chat__image-preview-thumb{width:40px;height:40px}}.queue{padding:14px;flex:1;overflow:hidden;display:flex;flex-direction:column}.queue__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.queue__title{font-size:1.1rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:10px}.queue__header-actions{display:flex;gap:8px}.queue__save-btn{padding:6px 12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);cursor:pointer;font-size:.9rem;transition:var(--transition)}.queue__save-btn:hover{background:var(--accent-gradient);border-color:transparent}.queue__save-btn--danger{color:var(--error)}.queue__save-btn--danger:hover{background:var(--error);color:#fff}.queue__save-form{display:flex;gap:8px;margin-bottom:14px;padding:12px;background:var(--glass-bg-light);border-radius:var(--radius-md)}.queue__save-input{flex:1;padding:8px 12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem}.queue__save-input:focus{outline:none;border-color:var(--accent-primary)}.queue__save-input::placeholder{color:var(--text-muted)}.queue__save-submit{padding:8px 16px;background:var(--accent-gradient);border:none;border-radius:var(--radius-sm);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap}.queue__save-submit:disabled{opacity:.5;cursor:not-allowed}.queue__title:before{content:"";width:4px;height:20px;background:var(--accent-gradient);border-radius:2px}.queue__empty{color:var(--text-muted);text-align:center;padding:50px 20px;font-style:italic}.queue__list{list-style:none;flex:1}.queue__list::-webkit-scrollbar{width:6px}.queue__list::-webkit-scrollbar-track{background:transparent}.queue__list::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px}.queue__item{display:flex;align-items:center;padding:8px 10px;border-radius:var(--radius-md);gap:10px;transition:var(--transition);border:1px solid transparent}.queue__item:hover{background:var(--glass-bg-light);border-color:var(--glass-border-light)}.queue__item--playing{background:#a855f726;border-color:#a855f74d}.queue__item--playing:hover{background:#a855f733}.queue__item[draggable=true]{cursor:grab}.queue__item--dragging{opacity:.5;cursor:grabbing}.queue__item--drag-over{border-color:var(--accent-primary)!important;background:#935af61a}.queue__item-drag-handle{display:flex;align-items:center;justify-content:center;width:14px;flex-shrink:0;color:var(--text-muted);font-size:14px;cursor:grab;opacity:.4;transition:opacity .2s ease;-webkit-user-select:none;user-select:none}.queue__item:hover .queue__item-drag-handle{opacity:1}.queue__item--dragging .queue__item-drag-handle{cursor:grabbing}.queue__item-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.queue__item-index{color:var(--text-muted);font-size:.82rem;min-width:18px;text-align:center;flex-shrink:0;font-family:SF Mono,Fira Code,monospace}.queue__item--playing .queue__item-index{color:var(--accent-primary);text-shadow:0 0 10px var(--accent-glow)}.queue__item-cover{width:32px;height:32px;min-width:32px;border-radius:6px;background-size:cover;background-position:center;background-color:#ffffff0d}.queue__item-details{flex:1;min-width:0}.queue__item-title{display:block;font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue__item--playing .queue__item-title{color:var(--accent-primary)}.queue__item-artist{display:block;font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue__item-duration{color:var(--text-muted);font-size:.8rem;font-family:SF Mono,Fira Code,monospace;flex-shrink:0}.queue__item-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:50%;transition:var(--transition);opacity:0}.queue__item:hover .queue__item-remove{opacity:1}.queue__item-remove:hover{color:var(--error);background:#f43f5e26}.queue__item-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.queue__item-details--clickable{cursor:pointer;transition:var(--transition)}.queue__item-details--clickable:hover{color:var(--accent-primary)}.queue__item-play{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:50%;transition:var(--transition);opacity:0;font-size:.85rem}.queue__item:hover .queue__item-play{opacity:1}.queue__item-play:hover{color:var(--success);background:#22c55e26}.playlist-modal{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.playlist-modal__content{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(var(--blur-amount));backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);width:100%;max-width:360px;max-height:400px;overflow:hidden}.playlist-modal__header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--glass-border)}.playlist-modal__header h3{font-size:1.1rem;font-weight:600}.playlist-modal__close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.2rem;padding:4px 8px}.playlist-modal__close:hover{color:var(--text-primary)}.playlist-modal__body{padding:16px;overflow-y:auto;max-height:300px}.playlist-modal__empty{color:var(--text-muted);text-align:center;padding:20px;font-size:.9rem}.playlist-modal__list{list-style:none}.playlist-modal__item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--glass-bg-light);border-radius:var(--radius-md);margin-bottom:8px;transition:var(--transition)}.playlist-modal__item:last-child{margin-bottom:0}.playlist-modal__item:hover{background:var(--glass-bg)}.playlist-modal__name{font-weight:500}.playlist-modal__add-btn{width:32px;height:32px;background:var(--accent-gradient);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.1rem;transition:var(--transition)}.playlist-modal__add-btn:hover{transform:scale(1.1)}.playlist-modal__add-btn:disabled{opacity:.5;cursor:not-allowed}.room-playlists{background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-glass);max-height:350px;overflow:hidden;display:flex;flex-direction:column}.room-playlists__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.room-playlists__title{font-size:1rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:10px}.room-playlists__title:before{content:"";width:4px;height:18px;background:var(--accent-gradient);border-radius:2px}.room-playlists__save-btn{padding:6px 10px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);cursor:pointer;font-size:.9rem;transition:var(--transition)}.room-playlists__save-btn:hover{background:var(--accent-gradient);border-color:transparent}.room-playlists__save-form{display:flex;gap:8px;margin-bottom:14px;padding:12px;background:var(--glass-bg-light);border-radius:var(--radius-md)}.room-playlists__save-input{flex:1;padding:8px 12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem}.room-playlists__save-input:focus{outline:none;border-color:var(--accent-primary)}.room-playlists__save-input::placeholder{color:var(--text-muted)}.room-playlists__save-submit{padding:8px 14px;background:var(--accent-gradient);border:none;border-radius:var(--radius-sm);color:#fff;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap}.room-playlists__save-submit:disabled{opacity:.5;cursor:not-allowed}.room-playlists__empty{color:var(--text-muted);font-size:.85rem;text-align:center;padding:16px}.room-playlists__list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.room-playlists__item-btn{padding:8px 14px;background:var(--glass-bg-light);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:6px;transition:var(--transition)}.room-playlists__item-btn:hover{background:var(--glass-bg);color:var(--text-primary);border-color:var(--accent-primary)}.room-playlists__item-btn--active{background:var(--accent-gradient);border-color:transparent;color:#fff}.room-playlists__item-icon{font-size:.9rem}.room-playlists__tracks{flex:1;overflow:hidden;display:flex;flex-direction:column;background:var(--glass-bg-light);border-radius:var(--radius-md);padding:12px}.room-playlists__tracks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.9rem;font-weight:600}.room-playlists__add-all{padding:6px 12px;background:var(--accent-gradient);border:none;border-radius:var(--radius-full);color:#fff;font-size:.75rem;font-weight:600;cursor:pointer;transition:var(--transition)}.room-playlists__add-all:hover{transform:scale(1.05)}.room-playlists__loading,.room-playlists__tracks-empty{color:var(--text-muted);font-size:.85rem;text-align:center;padding:12px}.room-playlists__track-list{list-style:none;flex:1}.room-playlists__track-list::-webkit-scrollbar{width:4px}.room-playlists__track-list::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:2px}.room-playlists__track{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);transition:var(--transition)}.room-playlists__track:hover{background:var(--glass-bg)}.room-playlists__track-info{flex:1;min-width:0}.room-playlists__track-title{display:block;font-size:.85rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-playlists__track-artist{display:block;font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-playlists__track-duration{font-size:.75rem;color:var(--text-muted);font-family:SF Mono,Fira Code,monospace}.room-playlists__track-add{width:26px;height:26px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:50%;color:var(--text-primary);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition)}.room-playlists__track:hover .room-playlists__track-add{opacity:1}.room-playlists__track-add:hover{background:var(--accent-gradient);border-color:transparent}.queue__item-playing-icon{color:var(--accent-primary);font-size:.9rem;animation:pulse 2s ease-in-out infinite}.track-search{background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-glass)}.track-search__title{margin-bottom:18px;font-size:1.1rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:10px}.track-search__title:before{content:"";width:4px;height:20px;background:var(--accent-gradient);border-radius:2px}.track-search__form{display:flex;gap:12px;margin-bottom:18px}.track-search__input{flex:1;padding:14px 18px;border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--glass-bg-light);color:var(--text-primary);font-size:.9rem;transition:var(--transition)}.track-search__input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 20px #a855f726}.track-search__input::placeholder{color:var(--text-muted)}.track-search__btn{padding:14px 28px;border:none;border-radius:var(--radius-full);background:var(--accent-gradient);color:#fff;cursor:pointer;font-weight:600;font-size:.9rem;transition:var(--transition);flex-shrink:0;white-space:nowrap}.track-search__btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px var(--accent-glow)}.track-search__btn:disabled{opacity:.5;cursor:not-allowed}.track-search__tabs{display:flex;gap:8px;margin-bottom:14px}.track-search__tab{flex:1;padding:10px 14px;border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--glass-bg-light);color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:500;transition:var(--transition);white-space:nowrap}.track-search__tab:hover{background:var(--glass-bg);color:var(--text-primary)}.track-search__tab--active{background:var(--accent-gradient);border-color:transparent;color:#fff}.track-search__upload{margin-bottom:14px}.track-search__upload--dragging .track-search__upload-label{border-color:var(--accent);background:#a855f71a;animation:pulse-border 1.5s ease-in-out infinite}@keyframes pulse-border{0%,to{border-color:var(--accent);box-shadow:0 0 #a855f766}50%{border-color:var(--accent-secondary);box-shadow:0 0 20px 5px #a855f733}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.track-search__upload-icon--bounce{animation:bounce .6s ease-in-out infinite}.track-search__upload-progress{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.track-search__progress-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.track-search__progress-fill{height:100%;background:var(--accent-gradient);border-radius:4px;transition:width .3s ease}.track-search__progress-text{font-size:.9rem;color:var(--text-secondary)}.track-search__download-progress{display:flex;align-items:center;gap:8px;margin-top:4px}.track-search__download-bar{flex:1;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.track-search__download-fill{height:100%;background:var(--accent-gradient);border-radius:2px;transition:width .3s ease}.track-search__download-text{font-size:.75rem;color:var(--accent);font-weight:500;white-space:nowrap;min-width:30px}.track-search__spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:track-spinner .6s linear infinite}@keyframes track-spinner{to{transform:rotate(360deg)}}.track-search__file-input{display:none}.track-search__upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:28px 20px;border:2px dashed var(--glass-border);border-radius:var(--radius-md);background:var(--glass-bg-light);cursor:pointer;transition:var(--transition);text-align:center}.track-search__upload-label:hover{border-color:var(--accent-primary);background:var(--glass-bg)}.track-search__upload-icon{font-size:2rem}.track-search__upload-hint{font-size:.75rem;color:var(--text-muted)}.track-search__error{color:var(--error);font-size:.9rem;margin-bottom:14px;padding:14px 18px;background:#f43f5e26;border:1px solid rgba(244,63,94,.3);border-radius:var(--radius-md)}.track-search__library-btn{width:100%;padding:12px;border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--glass-bg-light);color:var(--text-secondary);cursor:pointer;font-size:.9rem;font-weight:500;transition:var(--transition)}.track-search__library-btn:hover{background:var(--glass-bg);color:var(--text-primary);border-color:var(--accent-primary)}.track-search__library{margin-top:18px;padding-top:18px;border-top:1px solid var(--glass-border)}.track-search__library-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.track-search__library h4{font-size:.95rem;font-weight:600;color:var(--text-secondary);margin:0}.track-search__library-search{flex:1;max-width:150px;padding:6px 12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;outline:none;transition:var(--transition)}.track-search__library-search:focus{border-color:var(--accent-primary);background:var(--glass-bg-strong)}.track-search__library-search::placeholder{color:var(--text-muted)}.track-search__library-filters{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.track-search__library-filters .track-search__library-search{max-width:100%}.track-search__duration-filter{display:flex;gap:16px}.track-search__duration-filter label{flex:1;display:flex;flex-direction:column;gap:4px}.track-search__duration-filter label span{font-size:.75rem;color:var(--text-muted)}.track-search__duration-filter input[type=range]{width:100%;height:4px;background:var(--glass-border);border-radius:2px;-webkit-appearance:none;appearance:none;cursor:pointer}.track-search__duration-filter input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--accent-primary);border-radius:50%;cursor:pointer;transition:var(--transition)}.track-search__duration-filter input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--accent-primary);border-radius:50%;border:none;cursor:pointer}.track-search__duration-filter input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.track-search__list--youtube{margin-top:12px}.track-search__empty{color:var(--text-muted);font-size:.9rem;text-align:center;padding:20px 0}.track-search__list{list-style:none;max-height:220px;overflow-y:auto}.track-search__list::-webkit-scrollbar{width:5px}.track-search__list::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px}.track-search__item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:var(--radius-md);transition:var(--transition);border:1px solid transparent}.track-search__item:hover{background:var(--glass-bg-light);border-color:var(--glass-border-light)}.track-search__item-info{flex:1;min-width:0}.track-search__item-title{display:block;font-size:.9rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-search__item-artist{display:block;font-size:.8rem;color:var(--text-muted)}.track-search__item-add{padding:8px 18px;border:none;border-radius:var(--radius-full);background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary);cursor:pointer;font-size:.8rem;font-weight:600;transition:var(--transition)}.track-search__item-add:hover{background:var(--accent-gradient);border-color:transparent;transform:scale(1.05)}.playlists{padding:32px;max-width:800px;margin:0 auto}.playlists__header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.playlists__header h3{font-size:1.8rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex:1}.playlists__back{padding:10px 20px;border:1px solid var(--glass-border);border-radius:var(--radius-full);background:var(--glass-bg);color:var(--text-primary);cursor:pointer;font-size:.9rem;font-weight:500;transition:var(--transition)}.playlists__back:hover{background:var(--glass-bg-strong);border-color:var(--accent-primary)}.playlists__name{font-size:1.5rem;font-weight:700;color:var(--text-primary);flex:1}.playlists__count{color:var(--text-muted);font-size:.9rem}.playlists__create-btn{padding:10px 20px;background:var(--accent-gradient);border:none;border-radius:var(--radius-full);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition)}.playlists__create-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px var(--accent-glow)}.playlists__form{display:flex;gap:12px;margin-bottom:24px;padding:20px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md)}.playlists__input{flex:1;padding:12px 16px;background:var(--glass-bg-light);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem}.playlists__input:focus{outline:none;border-color:var(--accent-primary)}.playlists__input::placeholder{color:var(--text-muted)}.playlists__submit-btn{padding:12px 24px;background:var(--accent-gradient);border:none;border-radius:var(--radius-md);color:#fff;font-weight:600;cursor:pointer;transition:var(--transition)}.playlists__submit-btn:disabled{opacity:.5;cursor:not-allowed}.playlists__list{display:flex;flex-direction:column;gap:12px;overflow-y:auto;max-height:400px}.playlists__empty{color:var(--text-muted);text-align:center;padding:40px 20px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md)}.playlists__item{display:flex;align-items:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);overflow:hidden;transition:var(--transition)}.playlists__item:hover{border-color:var(--accent-primary)}.playlists__item-content{display:flex;align-items:center;gap:16px;padding:16px 20px;flex:1;cursor:pointer}.playlists__item-icon{width:48px;height:48px;background:var(--accent-gradient);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;flex-shrink:0}.playlists__item-info{flex:1}.playlists__item-name{display:block;font-size:1.05rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.playlists__item-date{display:block;font-size:.8rem;color:var(--text-muted)}.playlists__item-delete{padding:16px 20px;background:transparent;border:none;border-left:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;font-size:1rem;transition:var(--transition)}.playlists__item-delete:hover{background:#f43f5e26;color:var(--error)}.playlists__tracks{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);overflow:hidden}.playlists__track-list{list-style:none}.playlists__track{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--glass-border-light);transition:var(--transition)}.playlists__track:last-child{border-bottom:none}.playlists__track:hover{background:var(--glass-bg-light)}.playlists__track-index{color:var(--text-muted);font-size:.9rem;min-width:28px;font-family:SF Mono,Fira Code,monospace}.playlists__track-info{flex:1;min-width:0}.playlists__track-title{display:block;font-size:.95rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlists__track-artist{display:block;font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlists__track-duration{color:var(--text-muted);font-size:.8rem;font-family:SF Mono,Fira Code,monospace}.playlists__track-actions{display:flex;gap:8px;opacity:0;transition:var(--transition)}.playlists__track:hover .playlists__track-actions{opacity:1}.playlists__track-btn{width:32px;height:32px;border:none;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.playlists__track-btn--add{background:var(--accent-gradient);color:#fff}.playlists__track-btn--add:hover{transform:scale(1.1)}.playlists__track-btn--remove{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-muted)}.playlists__track-btn--remove:hover{background:#f43f5e26;color:var(--error)}.track-library{width:100%}.track-library__tabs-header{margin-bottom:20px}.track-library__tabs-header .tabs__list{background:var(--glass-bg);padding:4px;border-radius:12px}.track-library__header{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.track-library__search-wrapper{position:relative;display:flex;align-items:center}.track-library__search-icon{position:absolute;left:16px;color:var(--text-muted);font-size:20px;pointer-events:none}.track-library__search{width:100%;padding:14px 44px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--text-primary);font-size:1rem;transition:var(--transition)}.track-library__search:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.track-library__search::placeholder{color:var(--text-muted)}.track-library__search-clear{position:absolute;right:12px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.track-library__search-clear:hover{color:var(--text-primary)}.track-library__search-clear .material-symbols-outlined{font-size:18px}.track-library__controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.track-library__count{color:var(--text-secondary);font-size:.9rem;white-space:nowrap}.track-library__loading{text-align:center;color:var(--text-secondary);padding:40px}.track-library__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.track-library__card{display:flex;flex-direction:column;padding:16px!important;cursor:default;min-height:180px}.track-library__card-icon{width:64px;height:64px;background:var(--accent-gradient);border:none;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;position:relative;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.track-library__card-icon:hover{transform:scale(1.05);box-shadow:0 4px 20px #8b5cf666}.track-library__card-icon:active{transform:scale(.98)}.track-library__icon-note,.track-library__icon-play{font-size:28px;color:#fff;position:absolute;transition:opacity .2s ease,transform .2s ease}.track-library__icon-note{opacity:1}.track-library__icon-play,.track-library__card-icon:hover .track-library__icon-note{opacity:0;transform:scale(.8)}.track-library__card-icon:hover .track-library__icon-play{opacity:1;transform:scale(1)}.track-library__equalizer{display:flex;align-items:flex-end;justify-content:center;gap:3px;height:24px}.track-library__equalizer span{width:4px;background:#fff;border-radius:2px;animation:equalizerBar .8s ease-in-out infinite}.track-library__equalizer span:nth-child(1){animation-delay:0s;height:8px}.track-library__equalizer span:nth-child(2){animation-delay:.2s;height:16px}.track-library__equalizer span:nth-child(3){animation-delay:.4s;height:12px}.track-library__equalizer span:nth-child(4){animation-delay:.6s;height:20px}@keyframes equalizerBar{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.track-library__card--playing{border-color:var(--accent-primary);box-shadow:0 0 20px #8b5cf633}.track-library__card--playing .track-library__card-icon{box-shadow:0 4px 20px #8b5cf680}.track-library__card-info{flex:1;min-width:0;text-align:center;margin-bottom:12px}.track-library__card-title{font-weight:600;font-size:.95rem;color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;line-height:1.3}.track-library__card-artist{font-size:.85rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-library__card-meta{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;margin-top:auto}.track-library__card-duration{font-size:.85rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.track-library__card-source{font-size:.7rem;padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.track-library__card-source--soundcloud{background:#f503;color:#f50}.track-library__card-source--upload{background:#22c55e33;color:var(--success)}.track-library__card{position:relative}.track-library__card-actions{position:absolute;top:8px;left:8px;display:flex;gap:4px;z-index:2}.track-library__card-delete{width:32px;height:32px;border:none;border-radius:var(--radius-md);background:#64748be6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--transition-fast);box-shadow:0 2px 8px #0003}.track-library__card-delete--admin{background:#ef4444e6}.track-library__card:hover .track-library__card-delete{opacity:1}.track-library__card-delete:hover:not(:disabled){background:#475569;transform:scale(1.1)}.track-library__card-delete--admin:hover:not(:disabled){background:#dc2626}.track-library__card-delete:disabled{opacity:.6;cursor:not-allowed}.track-library__card-delete .material-symbols-outlined{font-size:18px}@media(max-width:1024px){.track-library__grid{grid-template-columns:repeat(2,1fr)}.track-search__tab{flex:0 1 auto;padding:8px 10px;font-size:.8rem}.track-search__tabs{gap:6px}}@media(max-width:640px){.track-library__grid{grid-template-columns:repeat(2,1fr);gap:12px}.track-library__card{min-height:160px;padding:12px!important}.track-library__card-icon{width:52px;height:52px;margin-bottom:10px}.track-library__card-title{font-size:.85rem}.track-library__card-artist{font-size:.8rem}.track-library__controls{flex-direction:column;align-items:stretch;width:100%}.track-library__controls .ui-select{width:100%}.track-library__card-delete{opacity:1}.track-library__icon-note,.track-library__icon-play{font-size:24px}.track-library__equalizer{height:20px}.track-library__equalizer span{width:3px}}@media(max-width:400px){.track-library__grid{grid-template-columns:1fr}}.library{display:flex;flex-direction:column;gap:24px}.library__header{display:flex;align-items:center;justify-content:space-between;gap:16px}.library__tabs{display:flex;gap:8px;background:var(--glass-bg);padding:4px;border-radius:var(--radius-lg);border:1px solid var(--glass-border)}.library__tab{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;background:transparent;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.library__tab .material-symbols-outlined{font-size:20px}.library__tab:hover{background:#ffffff0d;color:var(--text-primary)}.library__tab--active{background:var(--accent);color:#fff}.library__tab--active:hover{background:var(--accent-hover)}.library__content{flex:1}@media(max-width:640px){.library__header{flex-direction:column;align-items:stretch}.library__tabs{width:100%}.library__tab{flex:1;justify-content:center}}.voice-chat{background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-glass);width:100%;box-sizing:border-box}.voice-chat__header{margin-bottom:12px}.voice-chat__title{font-size:1rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px;margin:0}.voice-chat__title:before{content:"🎙️"}.voice-chat__join-btn{width:85%;padding:8px 24px;background:var(--accent-gradient);border:none;border-radius:var(--radius-full);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition);margin:8px auto 12px}.voice-chat__join-btn:hover{transform:scale(1.05);box-shadow:0 4px 15px var(--accent-glow)}.voice-chat__controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;margin-top:8px}.voice-chat__control-group{display:flex;gap:8px;margin-left:8px}.voice-chat__leave-btn{margin-right:8px}.voice-chat__mute-btn{width:36px;height:36px;background:var(--success);border:none;border-radius:50%;color:#fff;font-size:1rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.voice-chat__mute-btn:hover{transform:scale(1.1)}.voice-chat__mute-btn--muted{background:var(--error)}.voice-chat__deafen-btn{width:36px;height:36px;background:var(--primary);border:none;border-radius:50%;color:#fff;font-size:1rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.voice-chat__deafen-btn:hover{transform:scale(1.1)}.voice-chat__deafen-btn--deafened{background:var(--error)}.voice-chat__ptt-mode-btn{width:36px;height:36px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:50%;color:#fff;font-size:1rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.voice-chat__ptt-mode-btn:hover{transform:scale(1.1)}.voice-chat__ptt-mode-btn--active{background:var(--warning);border-color:var(--warning)}.voice-chat__ptt-btn{width:36px;height:36px;background:var(--warning);border:none;border-radius:50%;color:#fff;font-size:1rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.voice-chat__ptt-btn:hover{transform:scale(1.1)}.voice-chat__ptt-btn--active{background:var(--success);animation:ptt-pulse .5s ease-in-out infinite}@keyframes ptt-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.voice-chat__leave-btn{padding:8px 14px;background:#f43f5e26;border:1px solid rgba(244,63,94,.3);border-radius:var(--radius-full);color:var(--error);font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--transition)}.voice-chat__leave-btn:hover{background:var(--error);color:#fff}.voice-chat__users{display:flex;flex-direction:column;gap:8px}.voice-chat__user-wrapper{display:flex;flex-direction:column;gap:6px}.voice-chat__user{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--glass-bg-light);border:2px solid transparent;border-radius:var(--radius-md);transition:var(--transition);position:relative;overflow:hidden}.voice-chat__user--premium{min-height:80px}.voice-chat__user[class*=voice-chat__user--bg-]{background-size:cover;background-position:center;background-repeat:no-repeat}.voice-chat__user[class*=voice-chat__user--bg-]:before{content:"";position:absolute;inset:0;border-radius:inherit;background:#00000059;z-index:0;pointer-events:none}.voice-chat__user[class*=voice-chat__user--bg-]>*{position:relative;z-index:1}.voice-chat__user[class*=voice-chat__user--bg-] .voice-chat__user-name{text-shadow:0 1px 3px rgba(0,0,0,.5)}.voice-chat__user--bg-aurora{background-image:url(/backgrounds/aurora.jpg);border-color:#0f86}.voice-chat__user--bg-ocean{background-image:url(/backgrounds/ocean.jpg);border-color:#0077b666}.voice-chat__user--bg-sunset{background-image:url(/backgrounds/sunset.jpg);border-color:#ff6b3566}.voice-chat__user--bg-forest{background-image:url(/backgrounds/forest.jpg);border-color:#228b2266}.voice-chat__user--bg-storm{background-image:url(/backgrounds/storm.jpg);border-color:#6495ed66}.voice-chat__user--bg-northern-sky{background-image:url(/backgrounds/northern-sky.jpg);border-color:#6478c866}.voice-chat__user--bg-lightning{background-image:url(/backgrounds/lightning.jpg);border-color:#c8c8ff66}.voice-chat__user--bg-nebula{background-image:url(/backgrounds/nebula.jpg);border-color:#b400ff66}.voice-chat__user--bg-galaxy{background-image:url(/backgrounds/galaxy.jpg);border-color:#5856d666}.voice-chat__user--bg-supernova{background-image:url(/backgrounds/supernova.jpg);border-color:#ffa50066}.voice-chat__user--bg-blackhole{background-image:url(/backgrounds/blackhole.jpg);border-color:#ff783266}.voice-chat__user--bg-matrix{background-image:url(/backgrounds/matrix.jpg);border-color:#00ff4166}.voice-chat__user--bg-cyberpunk{background-image:url(/backgrounds/cyberpunk.jpg);border-color:#ff008066}.voice-chat__user--bg-synthwave{background-image:url(/backgrounds/synthwave.jpg);border-color:#c832c866}.voice-chat__user--bg-laser{background-image:url(/backgrounds/laser.jpg);border-color:#00ffc866}.voice-chat__user--bg-neon-city{background-image:url(/backgrounds/neon-city.jpg);border-color:#ff00c866}.voice-chat__user--bg-neon-tunnel{background-image:url(/backgrounds/neon-tunnel.jpg);border-color:#9632ff66}.voice-chat__user--bg-glitch{background-image:url(/backgrounds/glitch.jpg);border-color:#ff329666}.voice-chat__user--bg-enchanted{background-image:url(/backgrounds/enchanted.jpg);border-color:#c8b43266}.voice-chat__user--bg-dragonfire{background-image:url(/backgrounds/dragonfire.jpg);border-color:#ff3c0066}.voice-chat__user--bg-ice{background-image:url(/backgrounds/ice.jpg);border-color:#96dcff66}.voice-chat__user--bg-ethereal{background-image:url(/backgrounds/ethereal.jpg);border-color:#c8b4ff66}.voice-chat__user--bg-fantasy-realm{background-image:url(/backgrounds/fantasy-realm.jpg);border-color:#b482ff66}.voice-chat__user--bg-meepo{background-image:url(/backgrounds/meepo.webp);border-color:#0f86}.voice-chat__user--bg-tinker{background-image:url(/backgrounds/tinker2.jpg);border-color:#ff963266}.voice-chat__user[class*=voice-chat__user--bg-custom-]{border-color:#ffffff4d}.voice-chat__user--speaking.voice-chat__user--bg-aurora .voice-chat__user-avatar{box-shadow:0 0 0 2px #0f8}.voice-chat__user--speaking.voice-chat__user--bg-aurora .voice-chat__user-avatar:before{border-color:#0f8}.voice-chat__user--speaking.voice-chat__user--bg-ocean .voice-chat__user-avatar{box-shadow:0 0 0 2px #00b4d8}.voice-chat__user--speaking.voice-chat__user--bg-ocean .voice-chat__user-avatar:before{border-color:#00b4d8}.voice-chat__user--speaking.voice-chat__user--bg-sunset .voice-chat__user-avatar{box-shadow:0 0 0 2px #ff6b35}.voice-chat__user--speaking.voice-chat__user--bg-sunset .voice-chat__user-avatar:before{border-color:#ff6b35}.voice-chat__user--speaking.voice-chat__user--bg-nebula .voice-chat__user-avatar{box-shadow:0 0 0 2px #b400ff}.voice-chat__user--speaking.voice-chat__user--bg-nebula .voice-chat__user-avatar:before{border-color:#b400ff}.voice-chat__user--speaking.voice-chat__user--bg-matrix .voice-chat__user-avatar{box-shadow:0 0 0 2px #00ff41}.voice-chat__user--speaking.voice-chat__user--bg-matrix .voice-chat__user-avatar:before{border-color:#00ff41}.voice-chat__user--speaking.voice-chat__user--bg-forest .voice-chat__user-avatar{box-shadow:0 0 0 2px #228b22}.voice-chat__user--speaking.voice-chat__user--bg-forest .voice-chat__user-avatar:before{border-color:#228b22}.voice-chat__user--speaking.voice-chat__user--bg-storm .voice-chat__user-avatar{box-shadow:0 0 0 2px #6495ed}.voice-chat__user--speaking.voice-chat__user--bg-storm .voice-chat__user-avatar:before{border-color:#6495ed}.voice-chat__user--speaking.voice-chat__user--bg-galaxy .voice-chat__user-avatar{box-shadow:0 0 0 2px #5856d6}.voice-chat__user--speaking.voice-chat__user--bg-galaxy .voice-chat__user-avatar:before{border-color:#5856d6}.voice-chat__user--speaking.voice-chat__user--bg-supernova .voice-chat__user-avatar{box-shadow:0 0 0 2px orange}.voice-chat__user--speaking.voice-chat__user--bg-supernova .voice-chat__user-avatar:before{border-color:orange}.voice-chat__user--speaking.voice-chat__user--bg-blackhole .voice-chat__user-avatar{box-shadow:0 0 0 2px #ff7832}.voice-chat__user--speaking.voice-chat__user--bg-blackhole .voice-chat__user-avatar:before{border-color:#ff7832}.voice-chat__user--speaking.voice-chat__user--bg-cyberpunk .voice-chat__user-avatar{box-shadow:0 0 0 2px #ff0080}.voice-chat__user--speaking.voice-chat__user--bg-cyberpunk .voice-chat__user-avatar:before{border-color:#ff0080}.voice-chat__user--speaking.voice-chat__user--bg-synthwave .voice-chat__user-avatar{box-shadow:0 0 0 2px #c832c8}.voice-chat__user--speaking.voice-chat__user--bg-synthwave .voice-chat__user-avatar:before{border-color:#c832c8}.voice-chat__user--speaking.voice-chat__user--bg-laser .voice-chat__user-avatar{box-shadow:0 0 0 2px #00ffc8}.voice-chat__user--speaking.voice-chat__user--bg-laser .voice-chat__user-avatar:before{border-color:#00ffc8}.voice-chat__user--speaking.voice-chat__user--bg-enchanted .voice-chat__user-avatar{box-shadow:0 0 0 2px #c8b432}.voice-chat__user--speaking.voice-chat__user--bg-enchanted .voice-chat__user-avatar:before{border-color:#c8b432}.voice-chat__user--speaking.voice-chat__user--bg-dragonfire .voice-chat__user-avatar{box-shadow:0 0 0 2px #ff3c00}.voice-chat__user--speaking.voice-chat__user--bg-dragonfire .voice-chat__user-avatar:before{border-color:#ff3c00}.voice-chat__user--speaking.voice-chat__user--bg-ice .voice-chat__user-avatar{box-shadow:0 0 0 2px #96dcff}.voice-chat__user--speaking.voice-chat__user--bg-ice .voice-chat__user-avatar:before{border-color:#96dcff}.voice-chat__user--speaking.voice-chat__user--bg-ethereal .voice-chat__user-avatar{box-shadow:0 0 0 2px #c8b4ff}.voice-chat__user--speaking.voice-chat__user--bg-ethereal .voice-chat__user-avatar:before{border-color:#c8b4ff}.voice-chat__user--speaking.voice-chat__user--bg-fantasy-realm .voice-chat__user-avatar{box-shadow:0 0 0 2px #b482ff}.voice-chat__user--speaking.voice-chat__user--bg-fantasy-realm .voice-chat__user-avatar:before{border-color:#b482ff}.voice-chat__user--speaking.voice-chat__user--bg-northern-sky .voice-chat__user-avatar{box-shadow:0 0 0 2px #6478c8}.voice-chat__user--speaking.voice-chat__user--bg-northern-sky .voice-chat__user-avatar:before{border-color:#6478c8}.voice-chat__user--speaking.voice-chat__user--bg-lightning .voice-chat__user-avatar{box-shadow:0 0 0 2px #c8c8ff}.voice-chat__user--speaking.voice-chat__user--bg-lightning .voice-chat__user-avatar:before{border-color:#c8c8ff}.voice-chat__user--speaking.voice-chat__user--bg-neon-city .voice-chat__user-avatar{box-shadow:0 0 0 2px #ff00c8}.voice-chat__user--speaking.voice-chat__user--bg-neon-city .voice-chat__user-avatar:before{border-color:#ff00c8}.voice-chat__user--speaking.voice-chat__user--bg-neon-tunnel .voice-chat__user-avatar{box-shadow:0 0 0 2px #9632ff}.voice-chat__user--speaking.voice-chat__user--bg-neon-tunnel .voice-chat__user-avatar:before{border-color:#9632ff}.voice-chat__user--speaking.voice-chat__user--bg-meepo .voice-chat__user-avatar{box-shadow:0 0 0 2px #0f8}.voice-chat__user--speaking.voice-chat__user--bg-meepo .voice-chat__user-avatar:before{border-color:#0f8}.voice-chat__user--speaking.voice-chat__user--bg-tinker .voice-chat__user-avatar{box-shadow:0 0 0 2px orange}.voice-chat__user--speaking.voice-chat__user--bg-tinker .voice-chat__user-avatar:before{border-color:orange}.voice-chat__user--speaking.voice-chat__user--bg-glitch .voice-chat__user-avatar{box-shadow:0 0 0 2px #ff3296}.voice-chat__user--speaking.voice-chat__user--bg-glitch .voice-chat__user-avatar:before{border-color:#ff3296}@keyframes premium-flash{0%{background-color:var(--glass-bg-light)}50%{background-color:#ff646499}to{background-color:var(--glass-bg-light)}}.voice-chat__user--premium-just-gained{animation:premium-flash 1s ease-in-out 0s 2}.voice-chat__user-avatar{width:32px;height:32px;background:var(--accent-gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;color:#fff;flex-shrink:0;position:relative;overflow:hidden}.voice-chat__user-avatar--premium{border:2px solid rgba(135,206,235,.5)}.voice-chat__user-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.voice-chat__user--speaking .voice-chat__user-avatar{box-shadow:0 0 0 2px var(--success)}.voice-chat__user--speaking .voice-chat__user-avatar:before{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--success);animation:speaking-pulse 1.2s ease-out infinite}@keyframes speaking-pulse{0%{transform:scale(.9);opacity:.8}to{transform:scale(1.4);opacity:0}}.voice-chat__user--speaking.voice-chat__user--premium .voice-chat__user-avatar{box-shadow:0 0 0 2px #f44}.voice-chat__user--speaking.voice-chat__user--premium .voice-chat__user-avatar:before{border-color:#f44}.voice-chat__user-name{flex:1;font-size:.9rem;font-weight:500;color:var(--text-primary)}.voice-chat__user-status{font-size:.9rem;opacity:.7}.voice-chat__user-badge{display:flex;align-items:center;margin-left:auto}.voice-chat__premium-badge{font-size:.85rem;margin-left:4px}.voice-chat__volume-btn{background:none;border:none;padding:4px;cursor:pointer;font-size:.85rem;opacity:.6;transition:var(--transition);margin-left:auto}.voice-chat__volume-btn:hover{opacity:1}.voice-chat__volume-btn--modified{opacity:1;color:var(--accent)}.voice-chat__volume-control{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--glass-bg);border-radius:var(--radius-sm);margin-top:2px}.voice-chat__volume-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:var(--border);border-radius:3px;cursor:pointer}.voice-chat__volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--accent);border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0003;transition:transform .15s ease}.voice-chat__volume-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.voice-chat__volume-slider::-moz-range-thumb{width:16px;height:16px;background:var(--accent);border-radius:50%;border:none;cursor:pointer;box-shadow:0 2px 4px #0003}.voice-chat__volume-value{font-size:.8rem;color:var(--text-muted);min-width:40px;text-align:right}.voice-chat__mic-label{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.voice-chat__volume-reset{background:none;border:none;padding:4px;cursor:pointer;font-size:.85rem;color:var(--text-muted);transition:var(--transition)}.voice-chat__volume-reset:hover{color:var(--accent)}.voice-chat__preview{text-align:center;color:var(--text-muted);font-size:.85rem;padding:8px}.voice-chat__warning{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:var(--radius-md);padding:12px;margin-top:12px;text-align:center}.voice-chat__warning p{color:var(--warning);font-size:.9rem;margin:0 0 8px;font-weight:500}.voice-chat__unblock-btn{padding:8px 16px;background:var(--warning);border:none;border-radius:var(--radius-md);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition)}.voice-chat__unblock-btn:hover{transform:scale(1.05);opacity:.9}.voice-chat__unblock-btn:active{transform:scale(.98)}.voice-chat__retry-btn{padding:8px 16px;background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition)}.voice-chat__retry-btn:hover{transform:scale(1.05);opacity:.9}@media(max-width:1200px){.room__main{grid-template-columns:1fr 1fr}.room__right{grid-column:span 2;flex-direction:row;gap:20px}.room__right>*{flex:1}}@media(max-width:900px){.room__main{grid-template-columns:1fr;max-height:none;overflow:visible}.room__right{grid-column:span 1;flex-direction:column}.player{grid-template-columns:1fr;height:auto;padding:20px;gap:16px}.player__info{justify-content:center}.player__right{display:none}}@media(max-width:900px){.lobby__sidebar{width:100%;position:fixed;inset:auto 0 0;height:auto;flex-direction:row;padding:12px 20px;border-right:none;border-top:1px solid var(--glass-border);z-index:var(--z-sidebar)}.lobby__logo{display:none}.lobby__nav{flex-direction:row;flex:1;justify-content:center;gap:16px}.lobby__nav-item{padding:12px 20px;font-size:.9rem}.lobby__nav-icon{display:none}.lobby__user{margin-top:0;padding:10px 14px}.lobby__user-info{display:none}.lobby__content{margin-left:0;padding:24px 24px 100px}.lobby__title{font-size:2rem}.lobby__grid{grid-template-columns:1fr}}@media(max-width:768px){.room__header{padding:16px 20px;flex-wrap:wrap}.room__main{padding:20px}.room-info{flex-direction:column;align-items:flex-start;gap:14px}.auth__title{font-size:2.5rem}.auth__form{padding:28px 24px}.lobby__create-form{flex-direction:column;gap:12px}.lobby__create-icon{display:none}.lobby__create-input{padding:16px;background:var(--glass-bg-light);border:1px solid var(--glass-border);border-radius:var(--radius-md)}.lobby__create-btn{width:100%}body:before,body:after{opacity:.3}}@media(max-width:480px){.auth{padding:20px}.auth__title{font-size:2rem}.auth__subtitle{font-size:1rem}.auth__form{padding:20px 16px}.auth__input{padding:14px;font-size:16px}.auth__btn{padding:14px 24px;font-size:1rem}.room__header{padding:12px 16px;gap:8px}.room__back,.room__invite-btn{padding:8px 12px;font-size:.85rem}.room__main{padding:12px;gap:12px}.voice-chat{padding:16px}.voice-chat__controls{gap:8px}.voice-chat__mute-btn,.voice-chat__deafen-btn,.voice-chat__ptt-mode-btn,.voice-chat__ptt-btn{width:44px;height:44px;font-size:1.2rem}.voice-chat__leave-btn{padding:10px 12px;font-size:.8rem}.chat{padding:16px}.chat__input{padding:12px;font-size:16px}.chat__send{width:32px;height:32px;min-width:32px}.chat__send .material-symbols-outlined{font-size:18px}.queue,.user-list{padding:16px}.player{padding:16px;gap:12px}.player__cover{width:50px;height:50px}.player__title{font-size:1rem}.player__artist{font-size:.8rem}.player__btn{width:40px;height:40px;font-size:1.1rem}.player__btn--main{width:52px;height:52px;font-size:1.3rem}.track-search{padding:16px}.track-search__input{font-size:16px;padding:12px}.lobby__nav-item{padding:10px 14px;font-size:.8rem}.lobby__content{padding:16px 16px 90px}.lobby__title{font-size:1.5rem}.lobby__subtitle{font-size:.9rem}.lobby__create,.room-card{padding:16px}.room-card__name{font-size:1rem}.friends{padding:16px}.friends__tab{padding:10px 12px;font-size:.85rem}.room-info__theme-btn{padding:8px 12px;font-size:.85rem}}@media(min-width:481px)and (max-width:1024px){.ui-btn--sm{padding:10px 16px;font-size:.9rem}.ui-btn--md{padding:12px 18px;font-size:.95rem}.ui-btn--lg{padding:14px 28px;font-size:1.1rem}.ui-icon-btn--sm{width:32px;height:32px}.ui-icon-btn--md{width:40px;height:40px}.ui-icon-btn--lg{width:48px;height:48px}.room-header__title h1{font-size:1.3rem}.room-info__code-value{font-size:.85rem;padding:6px 14px}.room-info__copy-btn{padding:8px 14px;font-size:.8rem}.sidebar{width:280px}.sidebar--collapsed{width:80px}.main-content{margin-left:280px}.sidebar--collapsed~.main-content{margin-left:80px}.room-header{left:280px}.sidebar--collapsed~.main-content .room-header{left:80px}.chat{padding:24px}.chat__message-author{font-size:.85rem}.chat__message-text{font-size:1rem}.chat__input{padding:14px;font-size:1rem}.chat__send{width:38px;height:38px;min-width:38px}.chat__emoji-btn{font-size:1.4rem;width:36px;height:36px}.queue__track-title{font-size:1rem}.queue__track-artist{font-size:.9rem}.player{padding:18px 24px}.player__btn{width:42px;height:42px}.player__btn--main{width:56px;height:56px}.track-search__input{padding:14px;font-size:1rem}.track-search__result-title{font-size:1rem}.track-search__result-artist{font-size:.9rem}.voice-chat__mute-btn,.voice-chat__deafen-btn,.voice-chat__ptt-btn{width:48px;height:48px;font-size:1.4rem}.voice-chat__leave-btn,.voice-chat__join-btn{padding:12px 18px;font-size:.95rem}.stream-player__btn{width:40px;height:40px}.room-main{gap:24px}.room-bottom-row{gap:16px}.room-sidebar{width:220px}.room-chat-panel{flex:1}.ui-btn,.ui-icon-btn,.voice-chat__mute-btn,.voice-chat__deafen-btn,.voice-chat__ptt-btn,.voice-chat__leave-btn,.voice-chat__join-btn{min-height:44px}.modal,.invite-modal,.settings-modal,.ui-modal{padding:24px;display:flex;align-items:center;justify-content:center}.modal__content,.invite-modal__content,.settings-modal__content,.ui-modal__content{max-width:600px;width:100%;max-height:85vh;margin:0;border-radius:var(--radius-xl);box-shadow:0 20px 60px #00000080}.modal__header,.invite-modal__header,.settings-modal__header,.ui-modal__header{padding:20px 24px}.modal__title,.invite-modal__title,.settings-modal__title,.ui-modal__title{font-size:1.3rem}.modal__body,.invite-modal__body,.settings-modal__body,.ui-modal__body{padding:24px;max-height:calc(85vh - 140px)}.settings-content{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.settings-section{padding:20px}.settings-section__title{font-size:1.1rem}.create-room-form{padding:20px}.create-room-form__input,.create-cinema-form__input{padding:14px;font-size:1rem}.create-room-form__color-grid,.create-cinema-form__color-grid{grid-template-columns:repeat(6,1fr);gap:10px}.friends__content{padding:20px}.friends__item{padding:14px}.friends__avatar{width:44px;height:44px}.friends__name{font-size:1rem}.messages{max-height:80vh}.messages__conversation-item{padding:14px}.messages__avatar{width:44px;height:44px}}@media(hover:none)and (pointer:coarse){.voice-chat__mute-btn,.voice-chat__deafen-btn,.voice-chat__ptt-mode-btn,.voice-chat__ptt-btn,.chat__notify-btn{min-width:44px;min-height:44px}.room-card:hover{transform:none}.room-card:active{transform:scale(.98)}.chat__messages,.queue__list,.user-list__list{-webkit-overflow-scrolling:touch}.voice-chat__ptt-btn:active{transform:scale(1.1)}}@media(max-height:500px)and (orientation:landscape){.room__main{grid-template-columns:1fr 1fr 1fr;max-height:calc(100vh - 160px)}.room__right{grid-column:span 1;flex-direction:column}.player{padding:10px 20px}}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(var(--blur-amount));backdrop-filter:blur(var(--blur-amount));border-top:1px solid var(--glass-border);z-index:var(--z-modal);padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0)}.mobile-nav__list{display:flex;justify-content:space-around;align-items:center;height:100%;margin:0;padding:0;list-style:none}.mobile-nav__list-item{flex:1;display:flex}.mobile-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 4px;background:transparent;border:none;color:var(--text-muted);font-size:10px;cursor:pointer;transition:var(--transition);text-decoration:none;min-height:56px}.mobile-nav__item .material-symbols-outlined{font-size:24px;transition:var(--transition)}.mobile-nav__item.active{color:var(--primary)}.mobile-nav__item.active .material-symbols-outlined{font-variation-settings:"FILL" 1}.mobile-menu-btn{display:none;position:fixed;top:12px;left:12px;width:44px;height:44px;background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(var(--blur-amount));backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);z-index:calc(var(--z-modal) + 1);cursor:pointer;align-items:center;justify-content:center}.sidebar-overlay{display:none;position:fixed;inset:0;background:#000000bf;z-index:var(--z-overlay);opacity:0;transition:opacity .3s ease}.sidebar-overlay.visible{opacity:1}.pull-to-refresh-indicator{display:flex;align-items:center;justify-content:center;color:var(--primary);transition:height .2s ease,opacity .2s ease;overflow:hidden}.pull-to-refresh-indicator .material-symbols-outlined{font-size:28px;animation:refresh-spin 1s linear infinite}@keyframes refresh-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.mobile-nav{display:block}.radio-genres{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.radio-genres::-webkit-scrollbar{height:4px}.radio-genres::-webkit-scrollbar-track{background:transparent}.radio-genres::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:2px}.radio-genre-tag{white-space:nowrap;min-width:60px}.mobile-menu-btn{display:flex}.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px!important;transform:translate(-100%);transition:transform .3s ease;z-index:var(--z-modal)}.sidebar.sidebar--mobile-open{transform:translate(0)}.sidebar--collapsed{width:280px!important}.sidebar__toggle{display:none!important}.sidebar-overlay{display:block;pointer-events:none}.sidebar-overlay.visible{pointer-events:auto}.main-content{margin-left:0!important;padding-bottom:80px}.page-content{padding:20px 16px 20px 60px}.settings-overlay{z-index:calc(var(--z-modal) + 2);padding:0}.settings{max-height:100vh;max-height:100dvh;border-radius:0}.settings__content{padding-bottom:80px}.app-layout__body{flex-direction:column}.main-header{padding:12px 16px 12px 64px}.main-header__nav{gap:8px;min-width:0;flex:1;overflow:hidden}.main-header__nav h1{font-size:1.1rem}.main-header__actions{gap:4px;flex-shrink:0}.main-header__actions .ui-btn{padding:6px 8px;font-size:.85rem}.main-header__actions .ui-btn span:not(.material-symbols-outlined){display:none}.main-header__actions .ui-btn .material-symbols-outlined{margin-right:0}.room-header{left:0!important;padding:12px 8px 12px 56px!important}.room-header__title h1{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-header__title{min-width:0;overflow:hidden}.room-info{gap:4px;flex:0 0 auto}.room-info__delete-btn,.room-info__leave-btn{font-size:.85rem;padding:4px 6px;border-color:transparent}.home-content{padding:16px 16px 100px}.home-content__header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px}.home-content__header h1{font-size:1.5rem}.rooms-grid{grid-template-columns:1fr!important;gap:12px}.room-card{padding:16px}.room-card__name{font-size:1rem}.room-card__meta{font-size:.8rem}.create-room-card{padding:24px 16px}.create-room-card__title{font-size:1rem}.room-layout{flex-direction:column;height:auto;min-height:calc(100vh - 64px)}.room-content{flex-direction:column;height:auto;max-height:none;overflow:visible;padding:12px 12px 100px;margin-top:80px}.room-main{width:100%;padding:0;overflow:visible}.room-sidebar{width:100%;position:static;flex-direction:column;gap:12px}.room-bottom-row{flex-direction:column;gap:12px}.room-left-column{width:100%}.room-chat-panel{width:100%;max-height:350px}.room-sidebar-panel{width:100%;max-height:none;border-left:none;border-top:1px solid var(--glass-border)}.player-bar,.mini-player{display:none!important}.player-bar__track{width:auto;min-width:0;flex:1;max-width:40%}.player-bar__track-cover{width:40px;height:40px}.player-bar__track-info{max-width:calc(100% - 56px)}.player-bar__content{padding:0 12px;gap:8px}.player-bar__controls{flex:0 0 auto}.player-bar__buttons{gap:12px}.player-bar__btn--shuffle,.player-bar__btn--repeat,.player-bar__time{display:none}.player-bar__extras{width:auto;min-width:0;gap:8px}.player-bar__volume{display:none}.room-player-bar{position:fixed;bottom:64px;left:0;right:0;padding:12px;z-index:var(--z-dropdown)}.player{grid-template-columns:1fr;gap:12px;padding:12px 16px}.player__info{flex-direction:row;justify-content:flex-start;gap:12px}.player__cover{width:48px;height:48px}.player__details{text-align:left}.player__title{font-size:.9rem}.player__artist{font-size:.75rem}.player__center{order:1}.player__controls{justify-content:center}.player__btn{width:40px;height:40px}.player__btn--main{width:48px;height:48px}.player__progress{margin-top:8px}.player__right{display:none}.queue{max-height:300px}.queue__track{padding:12px}.queue__track-cover{width:40px;height:40px}.voice-chat{padding:12px}.voice-chat__header{flex-wrap:wrap;gap:8px}.voice-chat__title{font-size:.9rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-chat__controls{flex-wrap:wrap;justify-content:center;gap:8px}.voice-chat__mute-btn,.voice-chat__deafen-btn,.voice-chat__ptt-mode-btn,.voice-chat__ptt-btn{width:48px;height:48px}.voice-chat__leave-btn{flex:1;min-width:120px}.voice-chat__join-btn{min-width:120px}.chat{height:auto;max-height:min(60vh,500px);padding:12px}.room-chat-content{max-height:300px}.chat__messages{max-height:250px}.chat__form{padding:8px;gap:8px}.chat__input{padding:10px 12px;font-size:16px}.chat__emoji-picker{bottom:100%;left:0;right:0;padding:12px}.track-search{padding:12px}.track-search__input{padding:12px;font-size:16px}.track-search__results{max-height:350px}.user-list{padding:12px}.user-list__item{padding:10px}.cinema-view .main-header{padding-left:64px}.cinema-content{display:flex;flex-direction:column;height:auto;max-height:none;gap:12px;padding:12px 12px 100px}.cinema-main{width:100%;flex:none}.cinema-player-card{aspect-ratio:16/9;min-height:220px;max-height:350px}.cinema-url-input{padding:12px}.cinema-url-input__row{flex-direction:column;gap:8px}.cinema-url-input__row .ui-btn{width:100%}.cinema-sidebar{width:100%;flex-direction:column;gap:12px}.cinema-sidebar>.ui-card{width:100%;min-width:unset}.cinema-chat-panel{max-height:350px}.cinema-chat-content{max-height:250px}.video-player__controls,.video-player__buttons{padding:8px}.video-player__btn{width:44px;height:44px}.video-player__btn--play{width:56px;height:56px}.video-player__time{font-size:.75rem}.video-player__viewer-mode{font-size:.7rem;padding:4px 8px}.modal,.invite-modal,.settings-modal,.modal-overlay{padding:12px}.modal__content,.invite-modal__content,.settings-modal__content,.ui-modal__content{max-width:100%;max-height:90vh;margin:auto}.modal__header,.invite-modal__header,.settings-modal__header,.ui-modal__header,.modal__body,.invite-modal__body,.settings-modal__body,.ui-modal__body{padding:16px}.friends{padding:16px 16px 100px}.friends__tabs{flex-wrap:wrap}.friends__tab{flex:1 1 45%;padding:10px;font-size:.8rem}.friends__content{padding:16px}.friends__item{flex-wrap:wrap;gap:8px}.friends__actions{width:100%;justify-content:flex-end}.settings-content,.settings-section{padding:16px}.ui-card{padding:12px}.room-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.room-tabs::-webkit-scrollbar{display:none}.room-tabs__btn{padding:10px 16px;white-space:nowrap;font-size:.85rem}input,textarea,select{font-size:16px!important}.ui-btn,button{min-height:44px}.ui-icon-btn{min-width:44px;min-height:44px}}@media(max-width:480px){.mobile-nav{height:56px}.mobile-nav__item{font-size:9px;padding:6px 2px}.mobile-nav__item .material-symbols-outlined{font-size:22px}.main-header{padding:10px 12px 10px 56px}.main-header__nav h1{font-size:1rem}.home-content{padding:12px 12px 80px}.home-content__header h1{font-size:1.25rem}.home-content__header p{font-size:.85rem}.rooms-grid .room-card__cover{height:140px}.room-card--compact{padding:12px}.room-card--compact .room-card__header{gap:10px}.room-card--compact .room-card__cover{width:48px;height:48px}.room-card--compact .room-card__name{font-size:.95rem}.room-card--compact .room-card__desc{font-size:.8rem;-webkit-line-clamp:1}.player{padding:10px 12px}.player__cover{width:40px;height:40px}.player__title{font-size:.85rem}.player__artist{font-size:.7rem}.player__btn{width:36px;height:36px}.player__btn--main{width:44px;height:44px}.cinema-player-card{min-height:180px;max-height:250px}.cinema-url-input__hint{font-size:.7rem}.chat__message-bubble{max-width:85%}.chat__message-author{font-size:.75rem}.chat__message-text{font-size:.9rem}.queue__track-title{font-size:.85rem}.queue__track-artist{font-size:.75rem}.friends__tab{flex:1 1 100%}.friends__avatar{width:36px;height:36px}.friends__name{font-size:.9rem}.friends__btn{padding:6px 12px;font-size:.8rem}.ui-badge{font-size:.65rem;padding:2px 6px}}@media(max-height:500px)and (orientation:landscape){.mobile-nav{height:48px}.mobile-nav__item{flex-direction:row;gap:6px;font-size:9px}.mobile-nav__item .material-symbols-outlined{font-size:20px}.main-content{padding-bottom:56px}.room-content{margin-top:60px;padding-bottom:60px}.room-bottom-row{flex-direction:row;gap:16px}.room-left-column{flex:1.5}.room-chat-panel{flex:1;max-height:none;height:calc(100vh - 180px)}.chat{max-height:none}.chat__messages{max-height:calc(100vh - 260px)}.chat__message-bubble{max-width:90%;padding:6px 10px}.chat__message-author{font-size:.7rem}.chat__message-text{font-size:.85rem}.chat__typing{padding:4px 8px;font-size:.75rem}.queue__item{padding:8px}.queue__item-title{font-size:.85rem}.queue__item-artist{font-size:.75rem}.cinema-content{flex-direction:row;height:calc(100vh - 104px);padding:8px;gap:8px}.cinema-main{flex:2}.cinema-sidebar{flex:1;max-width:280px;flex-direction:column;overflow-y:auto}.cinema-player-card{max-height:none;aspect-ratio:auto;flex:1;min-height:auto}.cinema-chat-panel{max-height:none;flex:1}.cinema-chat-content{max-height:none}.video-player__controls{padding:6px}.video-player__btn{width:40px;height:40px}.video-player__btn--play{width:48px;height:48px}.video-player__time{font-size:.7rem}.room-player-bar{bottom:48px}.player,.player-bar{padding:6px 12px}.player__cover,.player-bar__track-cover{width:36px;height:36px}.player__title,.player-bar__track-name{font-size:.85rem}.player__artist,.player-bar__track-artist{font-size:.7rem}.player__btn,.player-bar__btn{width:32px;height:32px}.player__btn--main,.player-bar__btn--main{width:40px;height:40px}.main-header,.room-header{padding:8px 12px 8px 56px}.main-header__nav h1,.room-header__title h1{font-size:.95rem}.rooms-grid{grid-template-columns:repeat(2,1fr)!important;gap:8px}.room-card__cover{height:100px}.room-stream-panel{min-height:150px}.voice-chat{padding:8px}.voice-chat__controls{gap:6px}.voice-chat__mute-btn,.voice-chat__deafen-btn,.voice-chat__ptt-btn{width:40px;height:40px}}@supports (padding: env(safe-area-inset-bottom)){.mobile-nav{padding-bottom:env(safe-area-inset-bottom);height:calc(64px + env(safe-area-inset-bottom))}@media(max-width:480px){.mobile-nav{height:calc(56px + env(safe-area-inset-bottom))}}.main-content{padding-bottom:calc(80px + env(safe-area-inset-bottom))}.room-player-bar{bottom:calc(64px + env(safe-area-inset-bottom))}}@media print{.mobile-nav,.sidebar,.mobile-menu-btn,.sidebar-overlay{display:none!important}.main-content{margin-left:0!important;padding:0!important}}.mobile-player{position:fixed;bottom:64px;left:0;right:0;background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(var(--blur-amount));backdrop-filter:blur(var(--blur-amount));border-top:1px solid var(--glass-border);z-index:calc(var(--z-modal) - 1);transition:transform .3s cubic-bezier(.4,0,.2,1),height .3s ease;transform:translateY(0);height:auto}.mobile-player--expanded{position:fixed;top:0;bottom:0;height:100vh;z-index:var(--z-modal);transform:translateY(0)}.mobile-player-overlay{position:fixed;inset:0;background:#000c;z-index:calc(var(--z-modal) - 1);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-player__handle{display:flex;justify-content:center;padding:8px;cursor:grab}.mobile-player__handle-bar{width:40px;height:4px;background:var(--text-muted);border-radius:2px;opacity:.5}.mobile-player__mini{cursor:pointer}.mobile-player__progress{height:3px;background:#ffffff1a;position:relative;cursor:pointer}.mobile-player__progress-fill{height:100%;background:var(--primary);transition:width .1s linear}.mobile-player__mini-content{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;gap:12px}.mobile-player__track-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.mobile-player__cover{width:48px;height:48px;border-radius:var(--radius-md);background-size:cover;background-position:center;flex-shrink:0;box-shadow:0 2px 8px #0000004d}.mobile-player__meta{flex:1;min-width:0}.mobile-player__title{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-player__artist{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-player__mini-controls{display:flex;align-items:center;gap:8px}.mobile-player__btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:none;color:var(--text-primary);cursor:pointer;transition:var(--transition);border-radius:50%}.mobile-player__btn:active{transform:scale(.95);background:#ffffff1a}.mobile-player__btn .material-symbols-outlined{font-size:24px}.mobile-player__full{display:flex;flex-direction:column;align-items:center;padding:32px 24px 24px;gap:24px;height:calc(100vh - 80px);overflow-y:auto}.mobile-player__full-cover{width:280px;height:280px;border-radius:var(--radius-xl);background-size:cover;background-position:center;box-shadow:0 20px 60px #00000080;animation:slideInUp .4s ease}@keyframes slideInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.mobile-player__full-info{text-align:center;width:100%;padding:0 16px}.mobile-player__full-title{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.mobile-player__full-artist{font-size:1rem;color:var(--text-muted)}.mobile-player__seekbar{display:flex;align-items:center;gap:12px;width:100%}.mobile-player__time{font-size:.75rem;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:40px}.mobile-player__seekbar-track{flex:1;height:4px;background:#ffffff1a;border-radius:2px;position:relative;cursor:pointer}.mobile-player__seekbar-fill{height:100%;background:var(--primary);border-radius:2px;transition:width .1s linear}.mobile-player__seekbar-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000004d;transition:left .1s linear}.mobile-player__full-controls{display:flex;align-items:center;justify-content:center;gap:16px;width:100%}.mobile-player__btn--play{width:64px;height:64px;background:var(--primary);color:#fff}.mobile-player__btn--play .material-symbols-outlined{font-size:32px}.mobile-player__btn--play:active{background:var(--accent-hover)}.mobile-player__volume{display:flex;align-items:center;gap:12px;width:100%}.mobile-player__volume-slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:#ffffff1a;border-radius:2px;outline:none}.mobile-player__volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0000004d}.mobile-player__volume-slider::-moz-range-thumb{width:14px;height:14px;background:#fff;border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 4px #0000004d}.mobile-player__volume-value{font-size:.85rem;color:var(--text-muted);min-width:38px;text-align:right}@supports (padding: env(safe-area-inset-bottom)){.mobile-player{bottom:calc(64px + env(safe-area-inset-bottom))}@media(max-width:480px){.mobile-player{bottom:calc(56px + env(safe-area-inset-bottom))}}}@media(min-width:769px){.mobile-player,.mobile-player-overlay{display:none}}.premium-banner{position:relative;border-radius:var(--radius-lg);padding:1px;margin-bottom:24px;cursor:pointer;overflow:hidden;background:linear-gradient(135deg,#f59e0b,#f97316,#ef4444,#a855f7);background-size:300% 300%;animation:premium-gradient 6s ease infinite;transition:transform .2s ease,box-shadow .2s ease}.premium-banner:hover{transform:translateY(-2px);box-shadow:0 8px 30px #f59e0b4d}.premium-banner__glow{position:absolute;inset:0;background:linear-gradient(135deg,#f59e0b26,#a855f726);border-radius:inherit;pointer-events:none}.premium-banner__content{position:relative;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;border-radius:calc(var(--radius-lg) - 1px);background:var(--bg-surface)}.premium-banner__left{display:flex;align-items:center;gap:14px;min-width:0}.premium-banner__icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff}.premium-banner__text{min-width:0}.premium-banner__title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.premium-banner__description{font-size:.85rem;color:var(--text-secondary);margin:2px 0 0}.premium-banner__description strong{color:#f59e0b;font-weight:700}.premium-banner__btn{flex-shrink:0;padding:8px 20px;border-radius:var(--radius-full);border:none;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;font-weight:700;font-size:.85rem;cursor:pointer;transition:opacity .2s ease}.premium-banner__btn:hover{opacity:.9}.premium-modal{position:relative;width:100%;max-width:420px;border-radius:var(--radius-xl);background:var(--bg-surface);border:1px solid var(--glass-border);overflow:hidden;animation:modal-content-in .3s ease forwards}.premium-modal--closing{animation:modal-content-out .2s ease forwards}.premium-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.premium-modal__badge{padding:4px 14px;border-radius:var(--radius-full);background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;font-size:.7rem;font-weight:800;letter-spacing:1.5px}.premium-modal__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);border:none;background:var(--glass-bg);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.premium-modal__close:hover{background:var(--glass-bg-hover, rgba(255, 255, 255, .1));color:var(--text-primary)}.premium-modal__hero{text-align:center;padding:24px 24px 16px}.premium-modal__icon-wrap{width:80px;height:80px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#f59e0b33,#f9731633);color:#f59e0b;animation:premium-pulse 3s ease infinite}.premium-modal__title{font-size:1.4rem;font-weight:800;color:var(--text-primary);margin:0}.premium-modal__subtitle{font-size:.9rem;color:var(--text-secondary);margin:6px 0 0}.premium-modal__features{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 24px}.premium-modal__feature{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);background:var(--glass-bg);border:1px solid var(--glass-border)}.premium-modal__feature-icon{font-size:20px;color:#f59e0b}.premium-modal__feature-title{font-size:.8rem;color:var(--text-primary);font-weight:600}.premium-modal__feature-desc{font-size:.7rem;color:var(--text-secondary);margin-top:1px}.premium-modal__price-section{text-align:center;padding:20px 24px 8px}.premium-modal__price{display:inline-flex;align-items:baseline;gap:2px}.premium-modal__price-amount{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#f59e0b,#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.premium-modal__price-period{font-size:1rem;color:var(--text-secondary);font-weight:500}.premium-modal__cta{display:flex;align-items:center;justify-content:center;gap:8px;width:calc(100% - 48px);margin:8px 24px;padding:14px;border-radius:var(--radius-lg);border:none;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease}.premium-modal__cta:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 20px #f59e0b66}.premium-modal__cta--secondary{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary)}.premium-modal__cta--secondary:hover{background:var(--glass-bg-hover, rgba(255, 255, 255, .1));box-shadow:none}.premium-modal__disclaimer{text-align:center;font-size:.75rem;color:var(--text-tertiary);padding:8px 24px 20px;margin:0}.premium-modal__error{text-align:center;font-size:.8rem;color:var(--error);padding:0 24px;margin:0}.premium-modal__spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.premium-modal__cta:disabled{opacity:.7;cursor:not-allowed;transform:none}.premium-modal__success{text-align:center;padding:48px 24px}.premium-modal__success-icon{width:88px;height:88px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#22c55e33,#10b98133);color:var(--success);animation:premium-success-pop .5s ease}@keyframes premium-success-pop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.premium-modal__success-title{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin:0 0 8px}.premium-modal__success-text{font-size:.9rem;color:var(--text-secondary);margin:0 0 24px;line-height:1.5}@keyframes premium-gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes premium-pulse{0%,to{box-shadow:0 0 #f59e0b4d}50%{box-shadow:0 0 24px 4px #f59e0b26}}@media(max-width:768px){.premium-banner__content{flex-direction:column;text-align:center;padding:14px 16px}.premium-banner__left{flex-direction:column}.premium-banner__btn{width:100%}.premium-modal{max-width:calc(100vw - 32px);margin:16px}.premium-modal__features{grid-template-columns:1fr}}@keyframes stagger-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-stagger>*{opacity:0;animation:stagger-fade-in .4s ease-out forwards}.animate-stagger>*:nth-child(1){animation-delay:0ms}.animate-stagger>*:nth-child(2){animation-delay:50ms}.animate-stagger>*:nth-child(3){animation-delay:.1s}.animate-stagger>*:nth-child(4){animation-delay:.15s}.animate-stagger>*:nth-child(5){animation-delay:.2s}.animate-stagger>*:nth-child(6){animation-delay:.25s}.animate-stagger>*:nth-child(7){animation-delay:.3s}.animate-stagger>*:nth-child(8){animation-delay:.35s}.animate-stagger>*:nth-child(9){animation-delay:.4s}.animate-stagger>*:nth-child(10){animation-delay:.45s}.animate-stagger>*:nth-child(n+11){animation-delay:.5s}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,#ffffff08 25%,#ffffff14,#ffffff08 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-text{height:1em;margin-bottom:.5em;border-radius:var(--radius-sm)}.skeleton-text--short{width:60%}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-card{height:120px;border-radius:var(--radius-lg)}.hover-glow{transition:var(--transition),box-shadow .3s ease}.hover-glow:hover{box-shadow:0 0 20px #935af64d,0 0 40px #935af61a}.room-card,.cinema-room-card,.permanent-room-card{transition:var(--transition),transform .3s ease,box-shadow .3s ease}.room-card:hover,.cinema-room-card:hover,.permanent-room-card:hover{transform:translateY(-8px);box-shadow:0 12px 40px #0000004d,0 0 20px #935af626}.ui-button--primary:hover,.btn-primary:hover{box-shadow:0 4px 20px #935af666,0 0 30px #935af633}@keyframes modal-backdrop-in{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}@keyframes modal-content-in{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes modal-backdrop-out{0%{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}to{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}}@keyframes modal-content-out{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.95) translateY(-10px)}}.modal,.modal-overlay,.invite-modal,.settings-modal,.settings-overlay,.playlist-modal,.ui-modal{animation:modal-backdrop-in .2s ease-out forwards}.modal__content,.invite-modal__content,.settings-modal__content,.settings,.create-room-modal,.playlist-modal__content,.ui-modal__content{animation:modal-content-in .25s ease-out forwards}.settings-overlay--closing,.modal-overlay--closing,.playlist-modal--closing{animation:modal-backdrop-out .2s ease-in forwards}.settings--closing,.create-room-modal--closing,.playlist-modal__content--closing{animation:modal-content-out .2s ease-in forwards}@keyframes track-add{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.queue__item{animation:track-add .3s ease-out}@keyframes playing-glow{0%,to{box-shadow:0 0 #935af666}50%{box-shadow:0 0 15px 3px #935af633}}.queue__item--playing{animation:playing-glow 2s ease-in-out infinite}@keyframes page-enter{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.page-section{animation:page-enter .4s ease-out}@keyframes fab-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.fab-button{position:fixed;bottom:100px;right:24px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,#7c3aed 100%);border:none;color:#fff;font-size:24px;cursor:pointer;box-shadow:0 4px 20px #935af666;transition:var(--transition);z-index:var(--z-dropdown);display:flex;align-items:center;justify-content:center}.fab-button:hover{transform:scale(1.1);box-shadow:0 6px 30px #935af680;animation:fab-bounce .6s ease-in-out infinite}@keyframes equalizer-bar{0%,to{height:4px}50%{height:16px}}.now-playing-indicator{display:flex;align-items:flex-end;gap:2px;height:16px}.now-playing-indicator__bar{width:3px;background:var(--primary);border-radius:2px;animation:equalizer-bar .8s ease-in-out infinite}.now-playing-indicator__bar:nth-child(1){animation-delay:0s}.now-playing-indicator__bar:nth-child(2){animation-delay:.2s}.now-playing-indicator__bar:nth-child(3){animation-delay:.4s}.now-playing-indicator__bar:nth-child(4){animation-delay:.1s}.sidebar__friend-avatar,.friends__avatar{transition:transform .2s ease,box-shadow .2s ease}.sidebar__friend-avatar:hover,.friends__avatar:hover{transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.ripple{position:relative;overflow:hidden}.ripple:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%);opacity:0}.ripple:active:after{width:200px;height:200px;opacity:0;transition:width .4s ease,height .4s ease,opacity .4s ease}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toast-slide-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.toast{animation:toast-slide-in .3s ease-out}.toast--exiting{animation:toast-slide-out .3s ease-in forwards}@keyframes gradient-border{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.gradient-border{position:relative;background:var(--glass-bg);border-radius:var(--radius-lg)}.gradient-border:before{content:"";position:absolute;inset:-2px;border-radius:inherit;background:linear-gradient(45deg,var(--primary),var(--accent),var(--primary),var(--accent));background-size:300% 300%;animation:gradient-border 4s ease infinite;z-index:-1;opacity:0;transition:opacity .3s ease}.gradient-border:hover:before{opacity:1}@keyframes message-slide-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes message-slide-in-own{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.chat__message{animation:message-slide-in .25s ease-out}.chat__message--own{animation:message-slide-in-own .25s ease-out}@keyframes badge-bounce{0%,to{transform:scale(1)}20%{transform:scale(1.3)}40%{transform:scale(.9)}60%{transform:scale(1.15)}80%{transform:scale(.95)}}.sidebar__notification-badge:not(:empty),.mobile-nav__badge:not(:empty){animation:badge-pop-in .3s ease-out,badge-pulse 2s ease-in-out .3s infinite}@keyframes badge-pop-in{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes sidebar-slide-in{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes sidebar-slide-out{0%{transform:translate(0);opacity:1}to{transform:translate(-100%);opacity:0}}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.sidebar--mobile-open{animation:sidebar-slide-in .3s ease-out forwards}.sidebar-overlay{animation:overlay-fade-in .3s ease-out}@keyframes online-pulse{0%,to{box-shadow:0 0 #22c55eb3}50%{box-shadow:0 0 0 4px #22c55e00}}.sidebar__friend-status--online,.friends__status-dot--online,.user-list__status--online,.ui-avatar__status--online{animation:online-pulse 2s ease-in-out infinite}@keyframes focus-glow{0%,to{box-shadow:0 0 0 2px #935af64d}50%{box-shadow:0 0 0 4px #935af633}}.input:focus,.textarea:focus{animation:focus-glow 1.5s ease-in-out infinite;border-color:var(--primary);outline:none}@keyframes button-press{0%{transform:scale(1)}50%{transform:scale(.95)}to{transform:scale(1)}}.btn:active,.button:active,.ui-button:active{animation:button-press .15s ease-out}@keyframes progress-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.player-bar__progress-fill,.video-player__progress-fill{position:relative;overflow:hidden}.player-bar__progress-fill:after,.video-player__progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);background-size:200% 100%;animation:progress-shimmer 2s linear infinite}@keyframes loading-dots{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}.loading-dots{display:flex;gap:4px;align-items:center;justify-content:center}.loading-dots__dot{width:8px;height:8px;background:var(--primary);border-radius:50%;animation:loading-dots 1.4s ease-in-out infinite}.loading-dots__dot:nth-child(1){animation-delay:0s}.loading-dots__dot:nth-child(2){animation-delay:.16s}.loading-dots__dot:nth-child(3){animation-delay:.32s}@keyframes checkmark-draw{0%{stroke-dashoffset:50}to{stroke-dashoffset:0}}@keyframes success-scale{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.success-icon{animation:success-scale .4s ease-out}.success-icon path{stroke-dasharray:50;stroke-dashoffset:50;animation:checkmark-draw .3s ease-out .2s forwards}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.input--error,.shake{animation:shake .5s ease-out}@keyframes typing-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.typing-indicator{display:flex;gap:3px;padding:8px 12px}.typing-indicator__dot{width:6px;height:6px;background:var(--text-muted);border-radius:50%;animation:typing-bounce 1.2s ease-in-out infinite}.typing-indicator__dot:nth-child(1){animation-delay:0s}.typing-indicator__dot:nth-child(2){animation-delay:.15s}.typing-indicator__dot:nth-child(3){animation-delay:.3s}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
