*{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;--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}.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}@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}.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}.room-view{padding-bottom:0;flex:1;display:flex;flex-direction:column;min-height:0}.room-header{position:fixed;top:0;left:var(--sidebar-width);right:0;z-index:var(--z-dropdown);background:#0f0f12f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:left .3s ease}.room-header__title{display:flex;align-items:center;gap:8px}.room-header__title h1{font-size:1.1rem;font-weight:600;margin:0}.room-content{display:flex;gap:24px;padding:24px;overflow:hidden;margin-top:var(--header-height);background:var(--bg-dark);height:calc(100vh - var(--header-height) - var(--player-height));min-height:calc(100vh - var(--header-height) - var(--player-height))}.room-main{flex:1;display:flex;flex-direction:column;gap:20px;min-width:0;min-height:0;overflow-y:auto;padding-right:8px}.room-main::-webkit-scrollbar{width:6px}.room-main::-webkit-scrollbar-track{background:transparent}.room-main::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px}.room-stream-panel{flex-shrink:0;height:auto;min-height:200px}.room-bottom-row{flex:1;display:flex;gap:20px;min-height:0;align-items:stretch}.room-left-column{flex:1;display:flex;flex-direction:column;gap:16px;min-width:0;height:100%}.room-search-row{flex-shrink:0}.room-queue-panel{flex:1;display:flex;flex-direction:column;min-height:500px;overflow:hidden}.room-queue-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:1px solid var(--glass-border-light)}.room-queue-header .tabs__list{border-bottom:none;padding:0}.radio-toggle{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-muted);font-size:13px;cursor:pointer;transition:var(--transition)}.radio-toggle:hover{background:var(--glass-bg);color:var(--text-primary)}.radio-toggle--active{background:rgba(var(--accent-rgb),.15);border-color:var(--accent);color:var(--accent)}.radio-toggle--active:hover{background:rgba(var(--accent-rgb),.25)}.radio-toggle .material-symbols-outlined{font-size:18px}.radio-toggle__label{font-weight:500}.radio-controls{display:flex;align-items:center;gap:4px}.radio-loading-indicator{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:radio-pulse 1s ease-in-out infinite}@keyframes radio-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.radio-panel{padding:10px 16px;background:rgba(var(--accent-rgb),.05);border-bottom:1px solid var(--glass-border)}.radio-mode-selector{display:flex;gap:8px;margin-bottom:10px}.radio-mode-btn{flex:1;padding:8px 12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition)}.radio-mode-btn:hover{background:var(--glass-bg-hover);border-color:var(--accent)}.radio-mode-btn--active{background:var(--accent-gradient);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(var(--accent-rgb),.3)}.radio-genres{display:flex;flex-wrap:wrap;gap:6px}.radio-genre-tag{padding:4px 10px;background:var(--glass-bg-strong);border:1px solid var(--glass-border);border-radius:12px;color:var(--text-muted);font-size:12px;cursor:pointer;transition:var(--transition)}.radio-genre-tag:hover{border-color:var(--primary);color:var(--text-primary)}.radio-genre-tag--active{background:#935af633;border-color:var(--primary);color:var(--primary)}@media(max-width:768px){.room-queue-header{flex-wrap:wrap;gap:8px;padding:8px 12px}.radio-toggle__label{display:none}}.room-chat-panel{flex:1.33;display:flex;flex-direction:column;min-height:530px;overflow:hidden;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)}.room-chat-header{padding:22px;border-bottom:none}.room-chat-header h3{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:10px}.room-chat-header h3:before{content:"";width:4px;height:20px;background:var(--accent-gradient);border-radius:2px}.room-chat-content{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.room-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:16px;height:fit-content;position:sticky;top:0}.room-sidebar__header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.room-sidebar__header h3{margin:0;font-size:1rem;font-weight:600}.room-sidebar__icon{font-size:1.2rem;color:var(--accent-primary)}.room{min-height:100vh;display:flex;flex-direction:column;padding-bottom:var(--player-height)}.room__header{background:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));-webkit-backdrop-filter:blur(var(--blur-amount));border-bottom:1px solid var(--glass-border);padding:18px 28px;display:flex;align-items:center;gap:28px;position:sticky;top:0;z-index:var(--z-dropdown)}.room__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:600;transition:var(--transition);display:flex;align-items:center;gap:8px}.room__back:hover{background:var(--glass-bg-strong);border-color:var(--accent-primary)}.room__main{flex:1;display:grid;grid-template-columns:1fr 1.3fr 1fr;gap:24px;padding:24px;max-height:calc(100vh - 140px - var(--player-height));overflow:hidden}.room__left,.room__center,.room__right{display:flex;flex-direction:column;gap:20px;overflow:hidden}.room-info{display:flex;align-items:center;gap:28px;flex:1}.room-info__header{display:flex;align-items:center;gap:14px}.room-info__name{font-size:1rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.room-info__owner-badge{background:var(--accent-gradient);padding:4px 10px;border-radius:var(--radius-full);font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff}.room-info__code{display:flex;align-items:center;gap:14px;color:var(--text-secondary);font-size:.95rem}.room-info__code-value{background:var(--glass-bg);border:1px solid var(--glass-border);padding:10px 20px;border-radius:var(--radius-md);font-family:SF Mono,Fira Code,monospace;font-size:1.1rem;letter-spacing:.15em;font-weight:700;color:var(--accent-primary)}.room-info__copy-btn{padding:10px 20px;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:.9rem;font-weight:600;transition:var(--transition)}.room-info__copy-btn:hover{background:var(--accent-gradient);border-color:transparent}.room-info__delete-btn{padding:8px 12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);cursor:pointer;font-size:1rem;transition:var(--transition)}.room-info__delete-btn:hover{background:#f43f5e26;border-color:var(--error)}.room-info__leave-btn{padding:8px 12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);cursor:pointer;font-size:1rem;transition:var(--transition)}.room-info__leave-btn:hover{background:#fb923c26;border-color:var(--warning)}.room-info__confirm-btn--leave{background:var(--warning);color:#000}.room-info__confirm-btn--leave:hover{background:#ea8c0a}.room-info__confirm-overlay{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)}.room-info__confirm{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);padding:28px;max-width:400px;text-align:center}.room-info__confirm p{font-size:1.1rem;margin-bottom:8px}.room-info__confirm-warning{color:var(--text-muted);font-size:.9rem!important;margin-bottom:24px!important}.room-info__confirm-actions{display:flex;gap:12px;justify-content:center}.room-info__confirm-btn{padding:12px 24px;border:none;border-radius:var(--radius-full);font-size:.95rem;font-weight:600;cursor:pointer;transition:var(--transition)}.room-info__confirm-btn--cancel{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary)}.room-info__confirm-btn--cancel:hover{background:var(--glass-bg-strong)}.room-info__confirm-btn--delete{background:var(--error);color:#fff}.room-info__confirm-btn--delete:hover{opacity:.9}.room-info__confirm-btn:disabled{opacity:.5;cursor:not-allowed}.user-list{padding:16px}.user-list__title{margin-bottom:12px;font-size:1rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px}.user-list__title:before{content:"";width:4px;height:20px;background:var(--accent-gradient);border-radius:2px}.user-list__list{list-style:none;overflow-y:auto;max-height:320px}.user-list__item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);transition:var(--transition);border:1px solid transparent}.user-list__item:hover{background:var(--glass-bg-light);border-color:var(--glass-border-light)}.user-list__avatar-wrap{position:relative;width:28px;height:28px;flex-shrink:0;cursor:pointer}.user-list__avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid var(--glass-border);transition:border-color .2s ease}.user-list__avatar-wrap:hover .user-list__avatar,.user-list__avatar-wrap:hover .user-list__avatar-fallback{border-color:var(--accent-primary)}.user-list__avatar-fallback{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);color:#fff;font-weight:700;font-size:.75rem;border:2px solid var(--glass-border);transition:border-color .2s ease}.user-list__status{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-radius:50%;background:var(--text-muted);border:2px solid var(--bg-primary)}.user-list__status--online{background:var(--success);box-shadow:0 0 8px #22c55e80}.user-list__name{display:flex;align-items:center;gap:6px;font-weight:500;font-size:.9rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-list__role-badge{font-size:.85rem;margin-left:2px;flex-shrink:0}.user-list__role-badge--owner{filter:drop-shadow(0 0 4px rgba(255,215,0,.5))}.user-list__role-badge--dj{filter:drop-shadow(0 0 4px rgba(168,85,247,.5))}.user-list__role-btn{padding:4px 10px;font-size:.7rem;font-weight:600;border-radius:var(--radius-full);border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;flex-shrink:0}.user-list__role-btn:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.user-list__role-btn--active{background:#a855f733;border-color:var(--accent-primary);color:var(--accent-primary)}.user-list__role-btn--active:hover{background:#ef444433;border-color:var(--danger);color:var(--danger)}.user-list__you-badge{font-size:.7rem;color:var(--accent-primary);font-weight:600;padding:1px 6px;background:#a855f726;border-radius:var(--radius-full);flex-shrink:0}.theme-selector{position:relative}.theme-selector__toggle{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);cursor:pointer;transition:var(--transition)}.theme-selector__toggle:hover{background:var(--glass-bg-strong);border-color:var(--accent-primary)}.theme-selector__current{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.3)}.theme-selector__icon{font-size:1rem}.theme-selector__dropdown{position:absolute;top:calc(100% + 8px);right:0;width:200px;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);box-shadow:var(--shadow-glass);z-index:var(--z-dropdown);overflow:hidden}.theme-selector__header{padding:12px 16px;font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--glass-border)}.theme-selector__list{padding:8px}.theme-selector__option{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);color:var(--text-primary);font-size:.9rem}.theme-selector__option:hover,.theme-selector__option--active{background:var(--glass-bg)}.theme-selector__color{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.2);flex-shrink:0}.theme-selector__name{flex:1;text-align:left}.theme-selector__check{color:var(--success);font-weight:700}.room--theme-ocean{--accent-primary: #0ea5e9;--accent-secondary: #0284c7;--accent-gradient: linear-gradient(135deg, #0ea5e9 0%, #0284c7 50%, #0369a1 100%);--accent-glow: rgba(14, 165, 233, .4);--gradient-1: #0c1929;--gradient-2: #0c4a6e;--gradient-3: #082f49}.room--theme-sunset{--accent-primary: #f97316;--accent-secondary: #ea580c;--accent-gradient: linear-gradient(135deg, #fbbf24 0%, #f97316 50%, #ea580c 100%);--accent-glow: rgba(249, 115, 22, .4);--gradient-1: #1c1917;--gradient-2: #431407;--gradient-3: #27241d}.room--theme-forest{--accent-primary: #22c55e;--accent-secondary: #16a34a;--accent-gradient: linear-gradient(135deg, #4ade80 0%, #22c55e 50%, #16a34a 100%);--accent-glow: rgba(34, 197, 94, .4);--gradient-1: #052e16;--gradient-2: #14532d;--gradient-3: #0f2417}.room--theme-neon{--accent-primary: #ec4899;--accent-secondary: #db2777;--accent-gradient: linear-gradient(135deg, #f472b6 0%, #ec4899 50%, #be185d 100%);--accent-glow: rgba(236, 72, 153, .4);--gradient-1: #18061a;--gradient-2: #4a1d5c;--gradient-3: #2d0e38}.room--theme-midnight{--accent-primary: #6366f1;--accent-secondary: #4f46e5;--accent-gradient: linear-gradient(135deg, #818cf8 0%, #6366f1 50%, #4f46e5 100%);--accent-glow: rgba(99, 102, 241, .4);--gradient-1: #0f0f23;--gradient-2: #1e1e3f;--gradient-3: #151530}.room-icon-selector{position:relative}.room-icon-selector__trigger{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.room-icon-selector__trigger:hover{background:var(--glass-bg-hover);color:var(--text-primary);border-color:var(--accent-primary)}.room-icon-selector__current{width:24px;height:24px;border-radius:4px;object-fit:cover}.room-icon-selector__placeholder{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:4px}.room-icon-selector__placeholder .material-symbols-outlined{font-size:16px}.room-icon-selector__label{font-size:.875rem}.room-icon-selector__dropdown{position:absolute;top:calc(100% + 8px);right:0;width:380px;background:#1a1a2e;border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000080;z-index:var(--z-dropdown);overflow:hidden}.room-icon-selector__tabs{display:flex;border-bottom:1px solid var(--glass-border)}.room-icon-selector__tab{flex:1;padding:12px;background:transparent;border:none;color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .2s ease}.room-icon-selector__tab:hover{color:var(--text-primary);background:var(--glass-bg-hover)}.room-icon-selector__tab--active{color:var(--accent-primary);border-bottom:2px solid var(--accent-primary)}.room-icon-selector__presets{padding:12px;max-height:300px;overflow-y:auto}.room-icon-selector__category{margin-bottom:16px}.room-icon-selector__category:last-child{margin-bottom:0}.room-icon-selector__category-label{display:block;font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.room-icon-selector__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.room-icon-selector__preset{aspect-ratio:2 / 1;padding:0;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;overflow:hidden;transition:all .2s ease}.room-icon-selector__preset img{width:100%;height:100%;object-fit:cover}.room-icon-selector__preset:hover{border-color:var(--accent-primary);transform:scale(1.05)}.room-icon-selector__preset--active{border-color:var(--accent-primary);box-shadow:0 0 0 2px #a855f74d}.room-icon-selector__upload{padding:16px}.room-icon-selector__upload--dragging .room-icon-selector__file-label{border-color:var(--accent);background:#a855f726;animation:pulse-border 1.5s ease-in-out infinite}.room-icon-selector__icon--bounce{animation:bounce .6s ease-in-out infinite}.room-icon-selector__progress{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.room-icon-selector__progress-bar{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.room-icon-selector__progress-fill{height:100%;background:var(--accent-gradient);border-radius:3px;transition:width .3s ease}.room-icon-selector__file-label{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;background:var(--bg-tertiary);border:2px dashed var(--glass-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;color:var(--text-secondary)}.room-icon-selector__file-label:hover{border-color:var(--accent-primary);color:var(--text-primary)}.room-icon-selector__file-label .material-symbols-outlined{font-size:32px}.room-icon-selector__file-hint{font-size:.75rem;color:var(--text-tertiary)}.room-icon-selector__preview{display:flex;flex-direction:column;align-items:center;gap:12px}.room-icon-selector__preview img{width:120px;height:120px;object-fit:cover;border-radius:var(--radius-md)}.room-icon-selector__preview-actions{display:flex;gap:8px}.room-icon-selector__btn{padding:8px 16px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .2s ease}.room-icon-selector__btn:hover{background:var(--glass-bg-hover);color:var(--text-primary)}.room-icon-selector__btn--primary{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.room-icon-selector__btn--primary:hover{background:var(--accent-secondary)}.room-icon-selector__reset{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:transparent;border:none;border-top:1px solid var(--glass-border);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .2s ease}.room-icon-selector__reset:hover{background:var(--glass-bg-hover);color:var(--text-primary)}.room-icon-selector__reset .material-symbols-outlined{font-size:18px}.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}.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)}.cinema-view{display:flex;flex-direction:column;height:100%;overflow:hidden;padding-bottom:0}.cinema-view .main-header{position:sticky;top:0;z-index:10;flex-shrink:0}.cinema-content{display:grid;grid-template-columns:1fr 380px;gap:20px;height:calc(100vh - var(--header-height) - 20px);max-height:calc(100vh - var(--header-height) - 20px);padding:20px;overflow:hidden}.cinema-main{display:flex;flex-direction:column;gap:16px;min-height:0;overflow:hidden}.cinema-sidebar{display:flex;flex-direction:column;gap:16px;min-height:0;overflow-y:auto;overflow-x:hidden}.cinema-player-card{flex:1;min-height:0;display:flex;flex-direction:column}.cinema-chat-panel{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.cinema-chat-content{flex:1;min-height:0;overflow:hidden}.cinema-url-input{flex-shrink:0}.cinema-url-input__row{display:flex;gap:12px}.cinema-url-input__row .input-wrapper{flex:1;position:relative;display:flex;align-items:center}.cinema-url-input__row .input-icon{position:absolute;left:14px;color:var(--text-muted);font-size:20px;pointer-events:none}.cinema-input{width:100%;padding:12px 16px 12px 46px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;outline:none;transition:all .2s ease}.cinema-input::placeholder{color:var(--text-muted)}.cinema-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.cinema-url-input__hint{margin-top:8px;font-size:.75rem;color:var(--text-muted)}.video-player{width:100%;height:100%;display:flex;flex-direction:column;background:#000;border-radius:var(--radius-lg);overflow:hidden}.video-player--empty{background:var(--bg-surface);min-height:400px}.video-player__placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary)}.video-player__placeholder .material-symbols-outlined{font-size:64px;opacity:.5}.video-player__placeholder p{font-size:1.125rem}.video-player__hint{font-size:.875rem;color:var(--text-muted)}.video-player__wrapper{flex:1;position:relative;min-height:0}.video-player__wrapper>div{position:absolute!important;inset:0}.video-player__controls{background:linear-gradient(transparent,#000000e6);padding:16px}.video-player__progress{height:4px;background:#fff3;border-radius:2px;cursor:pointer;margin-bottom:12px;overflow:hidden}.video-player__progress:hover{height:6px}.video-player__progress-fill{height:100%;background:var(--primary);border-radius:2px;transition:width .1s linear}.video-player__buttons{display:flex;align-items:center;justify-content:space-between}.video-player__left,.video-player__right{display:flex;align-items:center;gap:12px}.video-player__btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;color:#fff;cursor:pointer;border-radius:50%;transition:all .2s ease}.video-player__btn:hover:not(:disabled){background:#ffffff1a}.video-player__btn:disabled{opacity:.5;cursor:not-allowed}.video-player__btn--play{width:48px;height:48px}.video-player__btn--play .material-symbols-outlined{font-size:32px}.video-player__volume{display:flex;align-items:center;gap:8px}.video-player__volume-slider{width:80px;height:4px;background:#fff3;border-radius:2px;cursor:pointer;overflow:hidden}.video-player__volume-fill{height:100%;background:#fff;border-radius:2px}.video-player__time{font-size:.875rem;color:#fffc;font-variant-numeric:tabular-nums}.video-player__viewer-mode{display:flex;align-items:center;gap:6px;font-size:.75rem;color:#fff9;padding:6px 12px;background:#ffffff1a;border-radius:var(--radius-full)}.video-player__viewer-mode .material-symbols-outlined{font-size:16px}.video-player--iframe{display:flex;flex-direction:column;height:100%}.video-player--iframe .video-player__wrapper{flex:1;min-height:0}.video-player--iframe iframe{border:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.video-player__iframe-notice{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--glass-bg);border-radius:0 0 var(--radius-lg) var(--radius-lg);color:var(--text-secondary);font-size:.875rem}.video-player__iframe-notice .material-symbols-outlined{font-size:18px;color:var(--primary)}.cinema-card__cover{background:linear-gradient(135deg,#1a1a2e,#16213e)}.cinema-card__placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.cinema-card__placeholder .material-symbols-outlined{font-size:48px;color:var(--primary);opacity:.8}.create-cinema-modal__title{display:flex;align-items:center;gap:12px}.create-cinema-modal__title .material-symbols-outlined{font-size:28px;color:var(--primary)}.create-cinema-modal__hint{display:flex;gap:12px;padding:12px 16px;background:#935af61a;border:1px solid rgba(147,90,246,.2);border-radius:var(--radius-md);margin-top:8px}.create-cinema-modal__hint .material-symbols-outlined{font-size:20px;color:var(--primary);flex-shrink:0;margin-top:2px}.create-cinema-modal__hint p{font-size:.875rem;color:var(--text-secondary);line-height:1.5}@media(max-width:1200px){.cinema-content{grid-template-columns:1fr;grid-template-rows:1fr auto}.cinema-sidebar{flex-direction:row;overflow-x:auto}.cinema-sidebar>*{min-width:300px;flex:1}}@media(max-width:768px){.cinema-content{padding:12px;gap:12px}.cinema-sidebar{flex-direction:column}.cinema-sidebar>*{min-width:unset}.video-player__volume-slider{display:none}}.video-queue{display:flex;flex-direction:column;gap:12px;padding:16px}.video-queue__header{display:flex;align-items:center;justify-content:space-between}.video-queue__header h3{font-size:1rem;font-weight:600;margin:0}.video-queue__count{background:var(--glass-bg);padding:2px 8px;border-radius:var(--radius-full);font-size:.8rem;color:var(--text-muted)}.video-queue__actions{display:flex;gap:8px}.video-queue__action-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:none;border-radius:var(--radius-md);font-size:.85rem;cursor:pointer;transition:all .2s ease}.video-queue__action-btn--play{background:var(--accent);color:#000}.video-queue__action-btn--play:hover{filter:brightness(1.1)}.video-queue__action-btn--clear{background:var(--glass-bg);color:var(--text-secondary)}.video-queue__action-btn--clear:hover{background:#ef444433;color:var(--error)}.video-queue__action-btn .material-symbols-outlined{font-size:18px}.video-queue__list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.video-queue__empty{text-align:center;color:var(--text-muted);padding:24px;font-size:.9rem}.video-queue__item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--glass-bg);border-radius:var(--radius-md);transition:background .2s ease}.video-queue__item:hover{background:var(--glass-bg-strong)}.video-queue__item-index{font-size:.85rem;color:var(--text-muted);min-width:20px;text-align:center}.video-queue__item-icon{font-size:1.2rem}.video-queue__item-info{flex:1;min-width:0}.video-queue__item-title{font-size:.9rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.video-queue__item-added{font-size:.75rem;color:var(--text-muted)}.video-queue__item-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s ease}.video-queue__item:hover .video-queue__item-actions{opacity:1}.video-queue__item-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.video-queue__item-btn:hover{background:var(--glass-bg-strong);color:var(--text-primary)}.video-queue__item-btn--remove:hover{background:#ef444433;color:var(--error)}.video-queue__item-btn .material-symbols-outlined{font-size:18px}.video-queue__add-form{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--glass-bg);border-radius:var(--radius-md)}.video-queue__input{width:100%;padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem}.video-queue__input:focus{outline:none;border-color:var(--accent)}.video-queue__input::placeholder{color:var(--text-muted)}.video-queue__add-actions{display:flex;gap:8px;justify-content:flex-end}.video-queue__add-btn{padding:8px 16px;border:none;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.video-queue__add-btn--cancel{background:transparent;color:var(--text-secondary)}.video-queue__add-btn--cancel:hover{background:var(--glass-bg)}.video-queue__add-btn--submit{background:var(--accent);color:#000}.video-queue__add-btn--submit:hover:not(:disabled){filter:brightness(1.1)}.video-queue__add-btn--submit:disabled{opacity:.5;cursor:not-allowed}.video-queue__add-toggle{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border:2px dashed var(--glass-border);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s ease}.video-queue__add-toggle:hover{border-color:var(--accent);color:var(--accent);background:rgba(var(--accent-rgb),.1)}.video-queue__add-toggle .material-symbols-outlined{font-size:20px}.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--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}.queue{padding:22px;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:14px 16px;border-radius:var(--radius-md);gap:14px;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{color:var(--text-muted);font-size:14px;cursor:grab;padding:4px;margin-left:-8px;margin-right:-4px;opacity:.5;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:14px;flex:1;min-width:0}.queue__item-index{color:var(--text-muted);font-size:.9rem;min-width:28px;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-details{flex:1;min-width:0}.queue__item-title{display:block;font-size:.95rem;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:.8rem;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}.queue__item-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px;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:8px}.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:8px;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)}.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)}.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__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)}}@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)}.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:100%;padding:8px 16px;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-bottom:12px}.voice-chat__join-btn:hover{transform:scale(1.05);box-shadow:0 4px 15px var(--accent-glow)}.voice-chat__controls{display:flex;gap:8px;margin-bottom:12px;justify-content:center}.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;overflow-y:auto;max-height:150px}.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:visible}.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}.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-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-wrapper{display:flex;flex-direction:column;gap:6px}.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}.friends{padding:32px;max-width:800px;margin:0 auto}.friends__tabs{display:flex;gap:8px;margin-bottom:24px;padding:4px;background:var(--glass-bg-light);border-radius:var(--radius-md)}.friends__tab{flex:1;padding:12px 16px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:8px}.friends__tab:hover{background:var(--glass-bg);color:var(--text-primary)}.friends__tab--active{background:var(--accent-gradient);color:var(--text-primary)}.friends__badge{background:var(--error);color:#fff;font-size:11px;padding:2px 6px;border-radius:var(--radius-full);min-width:18px;text-align:center}.friends__content{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--blur-amount));backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px}.friends__content h4{color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}.friends__search{margin-bottom:24px}.friends__search-input{width:100%;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:14px}.friends__search-input::placeholder{color:var(--text-muted)}.friends__search-input:focus{outline:none;border-color:var(--accent-primary)}.friends__search-results{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--glass-border)}.friends__list,.friends__search-results{display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:400px}.friends__item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--glass-bg-light);border-radius:var(--radius-md);transition:var(--transition)}.friends__item:hover{background:var(--glass-bg)}.friends__avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;flex-shrink:0}.friends__avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.friends__info{flex:1;min-width:0}.friends__name{display:block;color:var(--text-primary);font-weight:500}.friends__username,.friends__subtitle{display:block;color:var(--text-muted);font-size:12px}.friends__actions{display:flex;gap:8px}.friends__btn{padding:8px 16px;border:none;border-radius:var(--radius-sm);font-size:13px;cursor:pointer;transition:var(--transition)}.friends__btn--add{background:var(--accent-gradient);color:#fff}.friends__btn--accept{background:var(--success);color:#fff}.friends__btn--decline,.friends__btn--remove{background:var(--glass-bg);color:var(--text-secondary)}.friends__btn--decline:hover,.friends__btn--remove:hover{background:var(--error);color:#fff}.friends__empty{color:var(--text-muted);text-align:center;padding:24px}.invite-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);padding:20px}.invite-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:400px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.invite-modal__header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--glass-border)}.invite-modal__header h3{color:var(--text-primary);font-size:18px}.invite-modal__close{background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:4px}.invite-modal__close:hover{color:var(--text-primary)}.invite-modal__body{padding:24px;overflow-y:auto}.invite-modal__empty{color:var(--text-muted);text-align:center}.invite-modal__list{display:flex;flex-direction:column;gap:8px}.invite-modal__item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--glass-bg-light);border-radius:var(--radius-md)}.invite-modal__avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;font-size:14px}.invite-modal__avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.invite-modal__info{flex:1}.invite-modal__name{color:var(--text-primary);font-weight:500}.invite-modal__btn{padding:8px 16px;background:var(--accent-gradient);border:none;border-radius:var(--radius-sm);color:#fff;font-size:13px;cursor:pointer;transition:var(--transition)}.invite-modal__btn:hover{opacity:.9}.invite-modal__sent{color:var(--success);font-size:13px}.room__invite-btn{padding:10px 20px;background:var(--accent-gradient);border:none;border-radius:var(--radius-md);color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition)}.room__invite-btn:hover{opacity:.9;transform:translateY(-1px)}.pm-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:20px}.pm-modal{width:100%;max-width:900px;height:80vh;max-height:700px;background:var(--glass-bg-strong);border:1px solid var(--glass-border);border-radius:var(--radius-xl);display:flex;flex-direction:column;overflow:hidden}.pm-modal__header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--glass-border)}.pm-modal__header h2{flex:1;margin:0;font-size:18px;font-weight:600}.pm-modal__badge{background:var(--accent);color:#fff;font-size:12px;font-weight:600;padding:2px 8px;border-radius:10px;min-width:20px;text-align:center}.pm-modal__close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;border-radius:var(--radius-sm);transition:var(--transition)}.pm-modal__close:hover{background:var(--glass-bg);color:var(--text-primary)}.pm-modal__content{flex:1;display:flex;overflow:hidden}.pm-conversations{width:300px;border-right:1px solid var(--glass-border);display:flex;flex-direction:column}.pm-conversations__header{padding:12px 16px;border-bottom:1px solid var(--glass-border)}.pm-conversations__header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-secondary)}.pm-conversations__list{flex:1;overflow-y:auto}.pm-conversations__empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:14px}.pm-conversation{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:var(--transition);border-bottom:1px solid var(--glass-border-light)}.pm-conversation:hover{background:var(--glass-bg)}.pm-conversation--active{background:var(--glass-bg-strong)}.pm-conversation__avatar{position:relative;width:44px;height:44px;border-radius:50%;background:var(--glass-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.pm-conversation__avatar img{width:100%;height:100%;object-fit:cover}.pm-conversation__avatar .material-symbols-outlined{font-size:24px;color:var(--text-muted)}.pm-conversation__online{position:absolute;bottom:2px;right:2px;width:10px;height:10px;background:var(--success);border-radius:50%;border:2px solid var(--glass-bg-strong)}.pm-conversation__info{flex:1;min-width:0}.pm-conversation__name{font-weight:500;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pm-conversation__last-message{font-size:13px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pm-conversation__meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.pm-conversation__time{font-size:11px;color:var(--text-muted)}.pm-conversation__unread{background:var(--accent);color:#fff;font-size:11px;font-weight:600;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.pm-chat{flex:1;display:flex;flex-direction:column;min-width:0}.pm-chat__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted)}.pm-chat__empty .material-symbols-outlined{font-size:64px;opacity:.5}.pm-chat__empty p{margin:0;font-size:14px}.pm-chat__header{padding:12px 16px;border-bottom:1px solid var(--glass-border)}.pm-chat__user{display:flex;align-items:center;gap:12px}.pm-chat__avatar{width:40px;height:40px;border-radius:50%;background:var(--glass-bg);display:flex;align-items:center;justify-content:center;overflow:hidden}.pm-chat__avatar img{width:100%;height:100%;object-fit:cover}.pm-chat__avatar .material-symbols-outlined{font-size:22px;color:var(--text-muted)}.pm-chat__user-info{display:flex;flex-direction:column}.pm-chat__name{font-weight:500;color:var(--text-primary)}.pm-chat__status{font-size:12px;color:var(--text-muted)}.pm-chat__status--online{color:var(--success)}.pm-chat__messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.pm-message{display:flex;max-width:70%}.pm-message--own{align-self:flex-end}.pm-message__content{background:var(--glass-bg);border-radius:var(--radius-lg);padding:10px 14px;border:1px solid var(--glass-border-light)}.pm-message--own .pm-message__content{background:var(--accent);border-color:transparent}.pm-message__text{color:var(--text-primary);font-size:14px;line-height:1.4;word-wrap:break-word;white-space:pre-wrap}.pm-message--own .pm-message__text{color:#fff}.pm-message__meta{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:4px}.pm-message__time{font-size:11px;color:var(--text-muted)}.pm-message--own .pm-message__time{color:#ffffffb3}.pm-message__status{display:flex}.pm-message__status .material-symbols-outlined{font-size:14px;color:#ffffff80}.pm-message__status--read .material-symbols-outlined{color:#ffffffe6}.pm-chat__input{display:flex;flex-direction:column;gap:0;padding:12px 16px;border-top:1px solid var(--glass-border)}.pm-chat__input textarea{flex:1;resize:none;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:10px 14px;color:var(--text-primary);font-size:14px;font-family:inherit;max-height:120px}.pm-chat__input textarea:focus{outline:none;border-color:var(--accent)}.pm-chat__send{background:var(--accent);border:none;border-radius:var(--radius-md);padding:10px 16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.pm-chat__send:hover:not(:disabled){background:var(--accent-hover)}.pm-chat__send:disabled{opacity:.5;cursor:not-allowed}.pm-chat__send .material-symbols-outlined{font-size:20px;color:#fff}@media(max-width:768px){.pm-modal{max-width:100%;height:100vh;max-height:100vh;border-radius:0}.pm-modal__content{flex-direction:column}.pm-conversations{width:100%;max-height:40%;border-right:none;border-bottom:1px solid var(--glass-border)}.pm-chat{flex:1}.pm-message{max-width:85%}}.messages-tab{display:flex;flex-direction:column;height:calc(100vh - 220px);max-height:calc(100vh - 220px)}.messages-tab__loading{display:flex;align-items:center;justify-content:center;flex:1;min-height:300px}.messages-tab__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.messages-tab__new-chat{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.messages-tab__new-chat:hover{background:var(--glass-bg-hover);border-color:var(--accent);color:var(--accent)}.messages-tab__new-chat .material-symbols-outlined{font-size:18px}.messages-tab__start-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:12px}.messages-tab__start-btn:hover{background:var(--glass-bg-hover);border-color:var(--accent);color:var(--accent)}.messages-tab__start-btn .material-symbols-outlined{font-size:18px}.messages-tab__content{display:flex;flex:1;gap:16px;min-height:0;background:var(--glass-bg);border-radius:var(--radius-lg);border:1px solid var(--glass-border);overflow:hidden}.messages-tab__sidebar{width:300px;min-width:260px;border-right:1px solid var(--glass-border);display:flex;flex-direction:column}.messages-tab__conversations{flex:1;overflow-y:auto;padding:8px}.messages-tab__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px;color:var(--text-muted);text-align:center}.messages-tab__empty .material-symbols-outlined{font-size:48px;opacity:.5}.messages-tab__empty p{margin:0;font-size:14px}.messages-tab__conversation{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition)}.messages-tab__conversation:hover{background:var(--glass-bg-hover)}.messages-tab__conversation--active{background:var(--accent-subtle)}.messages-tab__avatar{width:44px;height:44px;border-radius:50%;background:var(--glass-bg);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;flex-shrink:0}.messages-tab__avatar img{width:100%;height:100%;object-fit:cover}.messages-tab__avatar .material-symbols-outlined{font-size:24px;color:var(--text-muted)}.messages-tab__online{position:absolute;bottom:0;right:0;width:12px;height:12px;background:var(--success);border-radius:50%;border:2px solid var(--bg-primary)}.messages-tab__info{flex:1;min-width:0}.messages-tab__name{font-weight:500;color:var(--text-primary);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messages-tab__last-message{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messages-tab__meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.messages-tab__time{font-size:11px;color:var(--text-muted)}.messages-tab__unread{background:var(--accent);color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.messages-tab__chat{flex:1;display:flex;flex-direction:column;min-width:0}.messages-tab__chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-muted)}.messages-tab__chat-empty .material-symbols-outlined{font-size:64px;opacity:.5}.messages-tab__chat-empty p{margin:0;font-size:14px}.messages-tab__chat-header{padding:12px 16px;border-bottom:1px solid var(--glass-border)}.messages-tab__chat-user{display:flex;align-items:center;gap:12px}.messages-tab__chat-avatar{width:40px;height:40px;border-radius:50%;background:var(--glass-bg);display:flex;align-items:center;justify-content:center;overflow:hidden}.messages-tab__chat-avatar img{width:100%;height:100%;object-fit:cover}.messages-tab__chat-avatar .material-symbols-outlined{font-size:22px;color:var(--text-muted)}.messages-tab__chat-user-info{display:flex;flex-direction:column}.messages-tab__chat-name{font-weight:500;color:var(--text-primary)}.messages-tab__chat-status{font-size:12px;color:var(--text-muted)}.messages-tab__chat-status--online{color:var(--success)}.messages-tab__messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.messages-tab__message{display:flex;max-width:70%}.messages-tab__message--own{align-self:flex-end}.messages-tab__message-content{background:var(--glass-bg);border-radius:var(--radius-lg);padding:10px 14px;border:1px solid var(--glass-border-light)}.messages-tab__message--own .messages-tab__message-content{background:var(--accent);border-color:transparent}.messages-tab__message-text{color:var(--text-primary);font-size:14px;line-height:1.4;word-wrap:break-word;white-space:pre-wrap}.messages-tab__message--own .messages-tab__message-text{color:#fff}.messages-tab__message-meta{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:4px}.messages-tab__message-time{font-size:11px;color:var(--text-muted)}.messages-tab__message--own .messages-tab__message-time{color:#ffffffb3}.messages-tab__message-status{display:flex}.messages-tab__message-status .material-symbols-outlined{font-size:14px;color:#ffffff80}.messages-tab__message-status--read .material-symbols-outlined{color:#ffffffe6}.messages-tab__message-file{margin-bottom:8px}.messages-tab__message-image-link{display:block}.messages-tab__message-image{max-width:280px;max-height:280px;border-radius:var(--radius-md);object-fit:contain}.messages-tab__message--own .messages-tab__message-image{border:2px solid rgba(255,255,255,.2)}.messages-tab__message-file-download{display:flex;align-items:center;gap:12px;padding:12px;background:#0000001a;border-radius:var(--radius-md);color:inherit;text-decoration:none;transition:var(--transition)}.messages-tab__message-file-download:hover{background:#0003}.messages-tab__message--own .messages-tab__message-file-download{background:#ffffff1a}.messages-tab__message--own .messages-tab__message-file-download:hover{background:#fff3}.messages-tab__message-file-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.messages-tab__message-file-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messages-tab__message-file-size{font-size:11px;opacity:.7}.messages-tab__message-file-expires{font-size:10px;opacity:.6;margin-top:4px}.messages-tab__input{display:flex;flex-direction:column;border-top:1px solid var(--glass-border)}.messages-tab__upload-progress{display:flex;align-items:center;gap:10px;padding:10px 16px;margin:0 16px 8px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);font-size:13px;color:var(--text-primary)}.messages-tab__upload-progress .material-symbols-outlined{font-size:20px;color:var(--accent)}.messages-tab__upload-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.messages-tab__upload-bar{width:100px;height:6px;background:#8b5cf633;border-radius:3px;overflow:hidden}.messages-tab__upload-bar-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa);border-radius:3px;transition:width .15s ease;box-shadow:0 0 8px #8b5cf680}.messages-tab__upload-percent{font-size:12px;color:var(--text-muted);min-width:35px;text-align:right}.messages-tab__input-row{display:flex;align-items:flex-end;gap:8px;padding:12px 16px}.messages-tab__attach{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:10px;cursor:pointer;color:var(--text-muted);display:flex;transition:var(--transition)}.messages-tab__attach:hover:not(:disabled){background:var(--glass-bg-hover);color:var(--accent);border-color:var(--accent)}.messages-tab__attach:disabled{opacity:.5;cursor:not-allowed}.messages-tab__input-row textarea{flex:1;resize:none;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:10px 14px;color:var(--text-primary);font-size:14px;font-family:inherit;max-height:120px}.messages-tab__input-row textarea:focus{outline:none;border-color:var(--accent)}.messages-tab__send{background:var(--accent);border:none;border-radius:var(--radius-md);padding:10px 16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.messages-tab__send:hover:not(:disabled){background:var(--accent-hover)}.messages-tab__send:disabled{opacity:.5;cursor:not-allowed}.messages-tab__send .material-symbols-outlined{font-size:20px;color:#fff}.pm-message__file{margin-bottom:8px}.pm-message__image-link{display:block}.pm-message__image{max-width:300px;max-height:300px;border-radius:var(--radius-md);object-fit:contain}.pm-message--own .pm-message__image{border:2px solid rgba(255,255,255,.2)}.pm-message__file-download{display:flex;align-items:center;gap:12px;padding:12px;background:#0000001a;border-radius:var(--radius-md);color:inherit;text-decoration:none;transition:var(--transition)}.pm-message__file-download:hover{background:#0003}.pm-message--own .pm-message__file-download{background:#ffffff1a}.pm-message--own .pm-message__file-download:hover{background:#fff3}.pm-message__file-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.pm-message__file-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pm-message__file-size{font-size:11px;opacity:.7}.pm-message__file-expires{font-size:10px;opacity:.6;margin-top:4px}.pm-chat__file-preview{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;margin:8px 16px 0;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md)}.pm-chat__file-preview-info{display:flex;align-items:center;gap:8px;color:var(--text-primary);font-size:13px;min-width:0}.pm-chat__file-preview-info span:nth-child(2){white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pm-chat__file-preview-size{color:var(--text-muted);font-size:12px;flex-shrink:0}.pm-chat__file-remove{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;transition:var(--transition)}.pm-chat__file-remove:hover{color:var(--danger)}.pm-chat__upload-progress{display:flex;align-items:center;gap:12px;padding:8px 16px;margin:8px 16px 0;background:var(--glass-bg);border-radius:var(--radius-md);font-size:12px;color:var(--text-muted)}.pm-chat__upload-progress-bar{flex:1;height:4px;background:var(--accent);border-radius:2px;transition:width .3s ease}.pm-chat__input-row{display:flex;align-items:flex-end;gap:8px;padding:12px 16px}.pm-chat__attach{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:10px;cursor:pointer;color:var(--text-muted);display:flex;transition:var(--transition)}.pm-chat__attach:hover:not(:disabled){background:var(--glass-bg-hover);color:var(--accent);border-color:var(--accent)}.pm-chat__attach:disabled{opacity:.5;cursor:not-allowed}.pm-chat__input-row textarea{flex:1;resize:none;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:10px 14px;color:var(--text-primary);font-size:14px;font-family:inherit;max-height:120px}.pm-chat__input-row textarea:focus{outline:none;border-color:var(--accent)}.new-chat__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px;color:var(--text-muted);text-align:center}.new-chat__empty .material-symbols-outlined{font-size:48px;opacity:.5}.new-chat__empty p{margin:0;font-size:14px}.new-chat__hint{font-size:12px;opacity:.7}.new-chat__list{display:flex;flex-direction:column;gap:4px;max-height:400px;overflow-y:auto}.new-chat__friend{display:flex;align-items:center;gap:12px;padding:12px;background:var(--glass-bg);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition)}.new-chat__friend:hover{background:var(--glass-bg-hover);border-color:var(--accent)}.new-chat__friend>.material-symbols-outlined{color:var(--text-muted);opacity:0;transition:var(--transition)}.new-chat__friend:hover>.material-symbols-outlined{opacity:1;color:var(--accent)}.new-chat__avatar{width:44px;height:44px;border-radius:50%;background:var(--glass-bg);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.new-chat__avatar img{width:100%;height:100%;object-fit:cover}.new-chat__avatar .material-symbols-outlined{font-size:24px;color:var(--text-muted)}.new-chat__online{position:absolute;bottom:0;right:0;width:12px;height:12px;background:var(--success);border-radius:50%;border:2px solid var(--bg-primary)}.new-chat__info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.new-chat__name{font-weight:500;color:var(--text-primary);font-size:14px}.new-chat__username{font-size:12px;color:var(--text-muted)}@media(max-width:768px){.messages-tab,.messages-tab__content{flex-direction:column}.messages-tab__sidebar{width:100%;min-width:auto;max-height:35%;border-right:none;border-bottom:1px solid var(--glass-border)}.messages-tab__header{padding:12px 16px}.messages-tab__new-chat span:not(.material-symbols-outlined){display:none}.messages-tab__new-chat{padding:10px;min-width:auto}.messages-tab__chat{flex:1;min-height:0}.messages-tab__chat-header{padding:12px 16px}.messages-tab__input-area{padding:12px}.pm-message__image{max-width:200px;max-height:200px}.pm-message__file{padding:10px 12px;max-width:220px}}.settings-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:20px}.settings{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.settings__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--glass-border)}.settings__title{font-size:1.3rem;font-weight:700;color:var(--text-primary)}.settings__close{width:36px;height:36px;background:var(--glass-bg-light);border:1px solid var(--glass-border);border-radius:50%;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.settings__close:hover{background:var(--error);color:#fff;border-color:var(--error)}.settings__content{padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.settings__section{display:flex;flex-direction:column;gap:16px}.settings__section-title{font-size:1rem;font-weight:600;color:var(--text-primary);padding-bottom:8px;border-bottom:1px solid var(--glass-border)}.settings__field{display:flex;flex-direction:column;gap:8px}.settings__label{font-size:.9rem;color:var(--text-secondary)}.settings__hint{font-size:.75rem;color:var(--text-tertiary, #888);margin-top:4px;margin-bottom:0}.settings__avatar-upload{display:flex;align-items:center;gap:20px}.settings__avatar-preview{width:100px;height:100px;border-radius:50%;overflow:hidden;border:3px solid var(--glass-border);flex-shrink:0}.settings__avatar-preview img{width:100%;height:100%;object-fit:cover}.settings__avatar-placeholder{width:100%;height:100%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2.5rem;font-weight:700}.settings__avatar-actions{display:flex;flex-direction:column;gap:10px;flex:1}.settings__avatar-btn{padding:10px 20px;border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--glass-bg);color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);text-align:center}.settings__avatar-btn:hover{background:var(--glass-bg-strong);border-color:var(--accent-primary)}.settings__avatar-btn--primary{background:var(--accent-gradient);border:none;color:#fff}.settings__avatar-btn--primary:hover{transform:translateY(-2px);box-shadow:0 6px 25px var(--accent-glow)}.settings__avatar-btn--primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.settings__avatar-btn--secondary{background:transparent;color:var(--text-muted)}.settings__avatar-btn--secondary:hover{background:#f43f5e26;color:var(--error);border-color:var(--error)}.settings__input{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:1rem;transition:var(--transition)}.settings__input:focus{outline:none;border-color:var(--primary)}.settings__input-group{display:flex;gap:8px}.settings__input-group .settings__input{flex:1}.settings__save-btn{padding:12px 20px;background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap}.settings__save-btn:hover:not(:disabled){filter:brightness(1.1)}.settings__save-btn:disabled{opacity:.5;cursor:not-allowed}.settings__message{font-size:.85rem;color:var(--success)}.settings__radio-group{display:flex;flex-direction:column;gap:10px}.settings__radio{display:flex;align-items:center;gap:12px;cursor:pointer;color:var(--text-primary);font-size:.95rem}.settings__radio input{display:none}.settings__radio-mark{width:20px;height:20px;border:2px solid var(--glass-border);border-radius:50%;position:relative;transition:var(--transition)}.settings__radio input:checked+.settings__radio-mark{border-color:var(--primary)}.settings__radio input:checked+.settings__radio-mark:after{content:"";position:absolute;inset:4px;background:var(--primary);border-radius:50%}.settings__slider{width:100%;height:6px;background:var(--glass-bg-light);border-radius:3px;-webkit-appearance:none;appearance:none;cursor:pointer}.settings__slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:var(--primary);border-radius:50%;cursor:pointer}.settings__slider::-moz-range-thumb{width:18px;height:18px;background:var(--primary);border-radius:50%;border:none;cursor:pointer}.settings__toggle{display:flex;align-items:center;gap:12px;cursor:pointer;color:var(--text-primary);font-size:.95rem}.settings__toggle input{display:none}.settings__toggle-slider{width:44px;height:24px;background:var(--glass-bg-light);border:1px solid var(--glass-border);border-radius:12px;position:relative;transition:var(--transition);flex-shrink:0}.settings__toggle-slider:after{content:"";position:absolute;width:18px;height:18px;background:var(--text-secondary);border-radius:50%;top:2px;left:2px;transition:var(--transition)}.settings__toggle input:checked+.settings__toggle-slider{background:var(--primary);border-color:var(--primary)}.settings__toggle input:checked+.settings__toggle-slider:after{background:#fff;left:22px}.settings__theme-picker{display:flex;gap:10px}.settings__theme-btn{width:40px;height:40px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:var(--transition)}.settings__theme-btn--dark{background:linear-gradient(135deg,#1a1a2e,#16213e)}.settings__theme-btn--purple{background:linear-gradient(135deg,#667eea,#764ba2)}.settings__theme-btn--blue{background:linear-gradient(135deg,#4facfe,#00f2fe)}.settings__theme-btn--green{background:linear-gradient(135deg,#11998e,#38ef7d)}.settings__theme-btn:hover{transform:scale(1.1)}.settings__theme-btn--active{border-color:#fff}.settings__select{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:1rem;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23888' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.settings__select:focus{outline:none;border-color:var(--primary)}.settings__sound-select{display:flex;gap:8px;align-items:center}.settings__sound-select .settings__select{flex:1}.settings__sound-preview{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--glass-bg-light);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:var(--transition)}.settings__sound-preview:hover{background:var(--primary);border-color:var(--primary);color:#fff}.settings__sound-preview .material-symbols-outlined{font-size:20px}.settings__btn{padding:12px 20px;background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;font-size:.95rem;font-weight:500;cursor:pointer;transition:var(--transition)}.settings__btn:hover{filter:brightness(1.1)}.settings__reset-btn{padding:12px 20px;background:transparent;border:1px solid var(--error);border-radius:var(--radius-md);color:var(--error);font-size:.95rem;font-weight:500;cursor:pointer;transition:var(--transition)}.settings__reset-btn:hover{background:var(--error);color:#fff}@media(max-width:480px){.settings{max-height:100vh;border-radius:0}.settings__content{padding:16px}.settings__input-group{flex-direction:column}.settings__save-btn{width:100%}}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:20px}.create-room-modal{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);max-width:480px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.create-room-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--glass-border)}.create-room-modal__header h2{font-size:1.25rem;font-weight:600;margin:0}.create-room-modal__close{background:none;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:4px 8px;transition:var(--transition)}.create-room-modal__close:hover{color:var(--text-primary)}.create-room-modal__form{padding:24px;overflow-y:auto}.create-room-modal__field{margin-bottom:20px}.create-room-modal__field>label{display:block;font-size:.9rem;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.create-room-modal__field input[type=text],.create-room-modal__field textarea,.create-room-modal__field select{width:100%;padding:12px 16px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.95rem;outline:none;transition:var(--transition)}.create-room-modal__field input:focus,.create-room-modal__field textarea:focus,.create-room-modal__field select:focus{border-color:var(--accent-primary);background:var(--glass-bg-strong)}.create-room-modal__field textarea{resize:vertical;min-height:60px}.create-room-modal__radio-group{display:flex;flex-direction:column;gap:12px}.create-room-modal__radio{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);transition:var(--transition)}.create-room-modal__radio:hover{background:var(--glass-bg-strong)}.create-room-modal__radio input{display:none}.create-room-modal__radio-mark{width:20px;height:20px;border:2px solid var(--glass-border);border-radius:50%;flex-shrink:0;position:relative;margin-top:2px;transition:var(--transition)}.create-room-modal__radio input:checked+.create-room-modal__radio-mark{border-color:var(--accent-primary)}.create-room-modal__radio input:checked+.create-room-modal__radio-mark:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:var(--accent-primary);border-radius:50%}.create-room-modal__radio-title{display:block;font-weight:500;color:var(--text-primary)}.create-room-modal__radio-desc{display:block;font-size:.85rem;color:var(--text-muted);margin-top:2px}.create-room-modal__toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}.create-room-modal__toggle input{display:none}.create-room-modal__toggle-slider{width:44px;height:24px;background:var(--glass-bg-strong);border-radius:var(--radius-full);position:relative;transition:var(--transition);flex-shrink:0}.create-room-modal__toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:var(--text-secondary);border-radius:50%;transition:var(--transition)}.create-room-modal__toggle input:checked+.create-room-modal__toggle-slider{background:var(--accent-primary)}.create-room-modal__toggle input:checked+.create-room-modal__toggle-slider:after{left:23px;background:#fff}.create-room-modal__toggle-hint{display:block;font-size:12px;color:var(--text-secondary);margin-top:2px}.create-room-modal__toggle--disabled{opacity:.5;cursor:not-allowed}.create-room-modal__toggle--disabled .create-room-modal__toggle-slider{cursor:not-allowed}.create-room-modal__backgrounds{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:8px;max-height:280px;overflow-y:auto;padding:4px}.create-room-modal__bg-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:0;border:2px solid transparent;background:none;cursor:pointer;border-radius:12px;transition:var(--transition);position:relative}.create-room-modal__bg-btn:hover{border-color:var(--primary)}.create-room-modal__bg-btn--active{border-color:var(--primary);box-shadow:0 0 16px #a855f766}.create-room-modal__bg-preview{width:100%;aspect-ratio:2 / 1;border-radius:10px;object-fit:cover;display:block}.create-room-modal__bg-preview--waves{background:linear-gradient(135deg,#a855f74d,#6366f14d);display:flex;align-items:center;justify-content:center}.create-room-modal__bg-waves{display:flex;align-items:flex-end;justify-content:center;gap:4px;height:50%}.create-room-modal__bg-waves span{width:6px;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border-radius:3px;animation:wave 1s ease-in-out infinite}.create-room-modal__bg-waves span:nth-child(1){height:35%;animation-delay:0s}.create-room-modal__bg-waves span:nth-child(2){height:65%;animation-delay:.1s}.create-room-modal__bg-waves span:nth-child(3){height:50%;animation-delay:.2s}.create-room-modal__bg-waves span:nth-child(4){height:80%;animation-delay:.3s}.create-room-modal__bg-name{font-size:.75rem;color:var(--text-secondary);text-align:center}.create-room-modal__bg-preview--upload{background:var(--glass-bg);border:2px dashed var(--glass-border);display:flex;align-items:center;justify-content:center}.create-room-modal__bg-preview--upload .material-symbols-outlined{font-size:32px;color:var(--text-tertiary)}.create-room-modal__bg-btn--upload:hover .create-room-modal__bg-preview--upload{border-color:var(--primary)}.create-room-modal__bg-btn--upload:hover .material-symbols-outlined{color:var(--primary)}.create-room-modal__bg-btn--dragging .create-room-modal__bg-preview--upload{border-color:var(--accent);background:#a855f726;animation:pulse-border 1.5s ease-in-out infinite}.create-room-modal__bg-btn--dragging .material-symbols-outlined{color:var(--accent);animation:bounce .6s ease-in-out infinite}.create-room-modal__bg-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:#000000b3;border:none;color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.create-room-modal__bg-btn:hover .create-room-modal__bg-remove{opacity:1}.image-crop-editor{background:var(--glass-bg);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:500px}.image-crop-editor__header{margin-bottom:20px;text-align:center}.image-crop-editor__header h3{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.image-crop-editor__header p{font-size:.85rem;color:var(--text-secondary)}.image-crop-editor__preview{position:relative;width:100%;aspect-ratio:2 / 1;border-radius:var(--radius-md);overflow:hidden;cursor:grab;background:var(--bg-tertiary);border:2px solid var(--glass-border)}.image-crop-editor__preview:active{cursor:grabbing}.image-crop-editor__image{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;transform-origin:center center;margin-left:-50%;margin-top:-50%;-webkit-user-select:none;user-select:none;pointer-events:none}.image-crop-editor__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;opacity:0;transition:opacity .2s ease;pointer-events:none}.image-crop-editor__preview:hover .image-crop-editor__overlay{opacity:1}.image-crop-editor__overlay .material-symbols-outlined{font-size:48px;color:#fff;opacity:.8}.image-crop-editor__controls{display:flex;align-items:center;justify-content:space-between;margin-top:16px;gap:16px}.image-crop-editor__zoom{display:flex;align-items:center;gap:8px;flex:1}.image-crop-editor__zoom .material-symbols-outlined{font-size:20px;color:var(--text-secondary)}.image-crop-editor__slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--glass-border);border-radius:2px;outline:none}.image-crop-editor__slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary);cursor:pointer;transition:transform .2s ease}.image-crop-editor__slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.image-crop-editor__scale-value{font-size:.8rem;color:var(--text-secondary);min-width:45px;text-align:right}.image-crop-editor__reset{display:flex;align-items:center;gap:4px;padding:6px 12px;background:transparent;border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s ease}.image-crop-editor__reset:hover{border-color:var(--text-secondary);color:var(--text-primary)}.image-crop-editor__reset .material-symbols-outlined{font-size:16px}.image-crop-editor__actions{display:flex;gap:12px;margin-top:20px}.image-crop-editor__btn{flex:1;padding:12px 20px;border-radius:var(--radius-md);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.image-crop-editor__btn--cancel{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-secondary)}.image-crop-editor__btn--cancel:hover{background:var(--glass-bg-hover);color:var(--text-primary)}.image-crop-editor__btn--save{background:var(--accent-gradient);color:#fff}.image-crop-editor__btn--save:hover{opacity:.9;transform:translateY(-2px)}.image-crop-editor__modal{position:fixed;inset:0;width:100vw;height:100vh;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:var(--z-overlay);padding:20px;box-sizing:border-box}.avatar-crop-editor{background:var(--glass-bg-strong);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:360px}.avatar-crop-editor__header{margin-bottom:20px;text-align:center}.avatar-crop-editor__header h3{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.avatar-crop-editor__header p{font-size:.85rem;color:var(--text-secondary)}.avatar-crop-editor__preview{position:relative;width:280px;height:280px;margin:0 auto;border-radius:var(--radius-md);overflow:hidden;cursor:grab;background:var(--bg-darker)}.avatar-crop-editor__preview:active{cursor:grabbing}.avatar-crop-editor__image{position:absolute;top:0;left:0;-webkit-user-select:none;user-select:none;pointer-events:none}.avatar-crop-editor__mask{position:absolute;inset:0;background:radial-gradient(circle at center,transparent 45%,rgba(0,0,0,.7) 45%);pointer-events:none}.avatar-crop-editor__circle{position:absolute;top:50%;left:50%;width:250px;height:250px;transform:translate(-50%,-50%);border:2px dashed rgba(255,255,255,.5);border-radius:50%;pointer-events:none}.avatar-crop-editor__controls{display:flex;align-items:center;justify-content:space-between;margin-top:16px;gap:16px}.avatar-crop-editor__zoom{display:flex;align-items:center;gap:8px;flex:1}.avatar-crop-editor__zoom .material-symbols-outlined{font-size:20px;color:var(--text-secondary)}.avatar-crop-editor__slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--glass-border);border-radius:2px;outline:none}.avatar-crop-editor__slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary);cursor:pointer;transition:transform .2s ease}.avatar-crop-editor__slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.avatar-crop-editor__scale-value{font-size:.8rem;color:var(--text-secondary);min-width:45px;text-align:right}.avatar-crop-editor__reset{display:flex;align-items:center;gap:4px;padding:6px 12px;background:transparent;border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s ease}.avatar-crop-editor__reset:hover{border-color:var(--text-secondary);color:var(--text-primary)}.avatar-crop-editor__reset .material-symbols-outlined{font-size:16px}.avatar-crop-editor__actions{display:flex;gap:12px;margin-top:20px}.avatar-crop-editor__btn{flex:1;padding:12px 20px;border-radius:var(--radius-md);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.avatar-crop-editor__btn--cancel{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-secondary)}.avatar-crop-editor__btn--cancel:hover{background:var(--glass-bg-hover);color:var(--text-primary)}.avatar-crop-editor__btn--save{background:var(--accent-gradient);color:#fff}.avatar-crop-editor__btn--save:hover{opacity:.9;transform:translateY(-2px)}.avatar-crop-modal{position:fixed;inset:0;width:100vw;height:100vh;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:20px}.create-room-modal__bg-preview--custom{overflow:hidden;display:flex;align-items:center;justify-content:center}.create-room-modal__bg-preview--custom img{width:100%;height:100%;object-fit:cover;transform-origin:center center}.create-room-modal__bg-actions{position:absolute;top:4px;right:4px;display:flex;gap:4px;opacity:0;transition:opacity .2s ease}.create-room-modal__bg-btn:hover .create-room-modal__bg-actions{opacity:1}.create-room-modal__bg-edit,.create-room-modal__bg-remove{width:24px;height:24px;border-radius:50%;background:#000000b3;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:background .2s ease}.create-room-modal__bg-edit .material-symbols-outlined{font-size:14px}.create-room-modal__bg-edit:hover{background:var(--accent)}.create-room-modal__bg-remove:hover{background:var(--error)}.create-room-modal__error{color:var(--error);font-size:.9rem;margin-bottom:16px}.create-room-modal__actions{display:flex;gap:12px;margin-top:8px}.create-room-modal__btn{flex:1;padding:12px 24px;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;cursor:pointer;transition:var(--transition)}.create-room-modal__btn--cancel{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-secondary)}.create-room-modal__btn--cancel:hover{background:var(--glass-bg-strong);color:var(--text-primary)}.create-room-modal__btn--create{background:var(--accent-gradient);color:#fff}.create-room-modal__btn--create:hover{opacity:.9}.create-room-modal__btn:disabled{opacity:.5;cursor:not-allowed}.stream-player{overflow:hidden}.stream-player--theater{position:fixed;inset:0;z-index:var(--z-modal);margin:0;border-radius:0;display:flex;flex-direction:column;background:#0e0e10}.stream-player--theater .stream-player__container{flex:1;border-radius:0}.stream-player--theater .stream-player__video{height:100%;aspect-ratio:auto}.stream-player--theater .stream-player__owner-controls{background:#18181b;padding:16px 20px;margin:0}.stream-player__container{position:relative;background:#000;cursor:pointer}.stream-player__container--fullscreen{width:100vw;height:100vh}.stream-player__container--fullscreen .stream-player__video{height:100%;aspect-ratio:auto}.stream-player__video{width:100%;aspect-ratio:16/9;object-fit:contain;background:#000;display:block}.stream-player__play-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;animation:playOverlayFade .5s ease-out forwards}@keyframes playOverlayFade{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1.5)}}.stream-player__play-icon{width:80px;height:80px;background:#0009;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff}.stream-player__error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#dc3545e6;color:#fff;padding:12px 24px;border-radius:8px;font-size:.9rem;z-index:20}.stream-player__top-bar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:12px;padding:12px 16px;background:linear-gradient(rgba(0,0,0,.7),transparent);opacity:0;transition:opacity .3s ease;z-index:10}.stream-player__top-bar--visible,.stream-player__container:hover .stream-player__top-bar{opacity:1}.stream-player__live-badge{display:flex;align-items:center;gap:6px;background:#eb0400;color:#fff;font-size:.75rem;font-weight:700;padding:4px 8px;border-radius:4px;text-transform:uppercase}.stream-player__live-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:livePulse 1.5s ease-in-out infinite}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.5}}.stream-player__viewers{display:flex;align-items:center;gap:4px;color:#fff;font-size:.85rem;font-weight:500}.stream-player__duration{color:#ffffffe6;font-size:.75rem;background:#00000080;padding:2px 8px;border-radius:4px;font-variant-numeric:tabular-nums}.stream-player__latency{color:#ffffffb3;font-size:.75rem;background:#00000080;padding:2px 6px;border-radius:4px}.stream-player__controls{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:linear-gradient(transparent,#000000d9);opacity:0;transition:opacity .3s ease;z-index:10}.stream-player__controls--visible,.stream-player__container:hover .stream-player__controls{opacity:1}.stream-player__controls-left,.stream-player__controls-right{display:flex;align-items:center;gap:4px}.stream-player__btn{background:transparent;border:none;color:#fff;width:36px;height:36px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.stream-player__btn:hover{background:#ffffff26}.stream-player__btn svg{flex-shrink:0}.stream-player__volume{display:flex;align-items:center}.stream-player__volume-slider-container{width:0;overflow:hidden;transition:width .2s ease}.stream-player__volume-slider-container--visible{width:70px;margin-left:4px}.stream-player__volume-slider{width:70px;height:4px;-webkit-appearance:none;appearance:none;background:#ffffff4d;border-radius:2px;outline:none;cursor:pointer}.stream-player__volume-slider::-webkit-slider-runnable-track{height:4px;border-radius:2px}.stream-player__volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer;margin-top:-4px}.stream-player__volume-slider::-moz-range-thumb{width:12px;height:12px;background:#fff;border-radius:50%;border:none;cursor:pointer}.stream-player__live-text{color:#ffffffb3;font-size:.8rem;margin-left:8px}.stream-player__settings-wrapper{position:relative}.stream-player__settings-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:#18181b;border-radius:6px;min-width:180px;box-shadow:0 4px 20px #00000080;overflow:hidden;z-index:var(--z-dropdown)}.stream-player__settings-header{padding:10px 14px;font-size:.8rem;font-weight:600;color:#ffffffb3;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.1)}.stream-player__settings-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 14px;background:transparent;border:none;color:#fff;font-size:.9rem;cursor:pointer;text-align:left;transition:background .15s}.stream-player__settings-option:hover{background:#ffffff1a}.stream-player__settings-option--active{color:#9147ff}.stream-player__check{color:#9147ff;font-weight:700}.stream-player__offline{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted);text-align:center;background:#0e0e10}.stream-player__offline-icon{margin-bottom:16px;color:var(--text-muted)}.stream-player__offline p{font-size:1rem;color:#fff9}.stream-player__disconnected{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-muted);text-align:center;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,193,7,.3);border-radius:var(--radius-md)}.stream-player__disconnected-icon{margin-bottom:12px;color:#ffc107}.stream-player__disconnected p{font-size:.95rem;color:#ffffffb3;margin-bottom:16px}.stream-player__connect-btn{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.stream-player__connect-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.stream-player__connect-btn:active{transform:translateY(0)}.stream-player__owner-controls{padding:16px 20px;background:var(--glass-bg-light);border-top:1px solid var(--glass-border)}.stream-player__start-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,#9147ff,#772ce8);border:none;border-radius:var(--radius-md);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition)}.stream-player__start-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px #9147ff66}.stream-player__start-btn:disabled{opacity:.6;cursor:not-allowed}.stream-player__key-panel{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:18px}.stream-player__key-panel h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:16px}.stream-player__field{margin-bottom:14px}.stream-player__field label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.stream-player__copy-row{display:flex;align-items:center;gap:8px;background:#0000004d;border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:10px 14px}.stream-player__copy-row code{flex:1;font-size:.85rem;color:var(--text-primary);font-family:SF Mono,Fira Code,monospace;word-break:break-all}.stream-player__copy-row button{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:4px;transition:var(--transition)}.stream-player__copy-row button:hover{color:#9147ff}.stream-player__actions{display:flex;gap:10px;margin-top:16px}.stream-player__hide-btn{flex:1;padding:10px 20px;background:transparent;border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:var(--transition)}.stream-player__hide-btn:hover{background:#ffffff1a;border-color:#9147ff}.stream-player__stop-btn{flex:1;padding:10px 20px;background:#f43f5e26;border:1px solid rgba(244,63,94,.3);border-radius:var(--radius-md);color:var(--error);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}.stream-player__stop-btn:hover{background:var(--error);border-color:var(--error);color:#fff}.stream-player__hint{margin-top:14px;font-size:.8rem;color:var(--text-muted);text-align:center;font-style:italic}.stream-player__requests{margin-top:16px;padding:14px;background:#9147ff1a;border:1px solid rgba(145,71,255,.3);border-radius:var(--radius-md)}.stream-player__requests h4{font-size:.9rem;font-weight:600;color:#9147ff;margin-bottom:12px}.stream-player__request{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#0003;border-radius:var(--radius-sm);margin-bottom:8px}.stream-player__request:last-child{margin-bottom:0}.stream-player__request-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}.stream-player__request-actions{display:flex;gap:8px}.stream-player__request-approve,.stream-player__request-deny{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);font-size:1rem;cursor:pointer;transition:var(--transition)}.stream-player__request-approve{background:#22c55e33;color:#22c55e}.stream-player__request-approve:hover{background:#22c55e;color:#fff}.stream-player__request-deny{background:#f43f5e33;color:#f43f5e}.stream-player__request-deny:hover{background:#f43f5e;color:#fff}.stream-player__guest-controls{padding:16px 20px;background:var(--glass-bg-light);border-top:1px solid var(--glass-border)}.stream-player__request-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,#06b6d4,#0891b2);border:none;border-radius:var(--radius-md);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition)}.stream-player__request-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px #06b6d466}.stream-player__request-pending{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px;background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:var(--radius-md)}.stream-player__request-pending span{font-size:.9rem;color:#fbbf24}.stream-player__cancel-btn{padding:8px 20px;background:transparent;border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:var(--transition)}.stream-player__cancel-btn:hover{background:#ffffff1a;color:var(--text-primary)}.stream-player__request-denied{padding:16px;background:#f43f5e1a;border:1px solid rgba(244,63,94,.3);border-radius:var(--radius-md);color:#f43f5e;font-size:.9rem;text-align:center}@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__name{font-size:1.1rem}.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__name{font-size:1.2rem}.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,.room-bottom-row{gap:24px}.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}.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 12px 12px 56px}.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__name{display:none}.room-info{gap:4px;flex:0 0 auto}.room-info__delete-btn,.room-info__leave-btn{font-size:.85rem;padding:4px}.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{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,.voice-chat__join-btn{flex:1;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}}@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)}}.modal,.modal-overlay,.invite-modal,.settings-modal,.ui-modal{animation:modal-backdrop-in .2s ease-out forwards}.modal__content,.invite-modal__content,.settings-modal__content,.ui-modal__content{animation:modal-content-in .25s ease-out 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}}
