@import"https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;700;800;900&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{background:#121218e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:12px 20px;border-radius:12px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px #0000004d;border:1px solid var(--border);min-width:250px;pointer-events:auto;animation:toastSlideIn .3s cubic-bezier(.175,.885,.32,1.275)}.toast-success{border-color:#22c55e80;background:#141e19f2}.toast-error{border-color:#ef444480;background:#1e1414f2}.toast-info{border-color:var(--border)}.toast-msg{font-size:.9rem;font-weight:500}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.login-card{width:100%;max-width:420px;padding:48px 40px;text-align:center}.login-icon{font-size:3.5rem;margin-bottom:16px;animation:float 3s ease-in-out infinite}.login-title{font-size:1.8rem;font-weight:700;margin-bottom:8px;letter-spacing:-.02em}.gradient-text{background:var(--accent-gradient);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 4s ease infinite}.login-subtitle{color:var(--text-secondary);font-size:.95rem;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:16px}.input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:16px;font-size:1.1rem;z-index:1}.login-input{padding-left:48px!important;font-size:1.05rem;letter-spacing:.03em}.login-btn{width:100%;padding:16px;font-size:1rem;margin-top:8px}.login-footer{margin-top:24px;font-size:.75rem;color:var(--text-muted)}@media(max-width:480px){.login-card{padding:36px 24px}.login-title{font-size:1.5rem}.login-icon{font-size:2.8rem}}@media(max-width:360px){.login-card{padding:24px 16px}.login-title{font-size:1.35rem}.login-sub{font-size:.82rem;margin-bottom:24px}.login-icon{font-size:2.2rem}.login-footer p{font-size:.7rem}}.verify-card{width:100%;max-width:420px;padding:48px 40px;text-align:center;position:relative}.back-btn{position:absolute;top:20px;left:20px;background:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:color .2s}.back-btn:hover{color:var(--text-primary)}.verify-icon{font-size:3rem;margin-bottom:16px}.verify-title{font-size:1.6rem;font-weight:700;margin-bottom:8px}.verify-subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:32px}.verify-subtitle strong{color:var(--text-accent)}.otp-inputs{display:flex;justify-content:center;gap:12px;margin-bottom:24px}.otp-digit{width:60px;height:64px;text-align:center;font-size:1.6rem;font-weight:700;background:var(--bg-input);border:2px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);transition:all .25s ease;caret-color:var(--accent)}.otp-digit:focus{border-color:var(--accent);background:#7c5cfc0f;box-shadow:0 0 0 3px #7c5cfc26}.verify-error{color:var(--danger);font-size:.85rem;margin-bottom:16px}.verify-btn{width:100%;padding:16px;font-size:1rem}.verify-hint{margin-top:24px;font-size:.8rem;color:var(--text-muted)}@media(max-width:480px){.verify-card{padding:48px 20px 28px}.otp-digit{width:52px;height:58px;font-size:1.4rem}.otp-inputs{gap:8px}.verify-title{font-size:1.4rem}}.activate-card{width:100%;max-width:420px;padding:48px 40px;text-align:center}.activate-step{margin-bottom:20px}.step-badge{display:inline-block;padding:6px 16px;background:var(--accent-light);color:var(--accent);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.activate-title{font-size:1.6rem;font-weight:700;margin-bottom:8px}.activate-subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:32px}.activate-form{display:flex;flex-direction:column;align-items:center;gap:20px}.avatar-upload{width:120px;height:120px;border-radius:50%;overflow:hidden;cursor:pointer;position:relative;background:var(--bg-input);border:3px solid var(--border-light);transition:all .3s ease}.avatar-upload:hover{border-color:var(--accent);transform:scale(1.05)}.avatar-preview{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted)}.avatar-placeholder span{font-size:2rem;margin-bottom:4px}.avatar-placeholder small{font-size:.7rem}.avatar-overlay{position:absolute;bottom:0;left:0;right:0;background:#000000b3;color:#fff;font-size:.7rem;font-weight:600;padding:6px;text-align:center;opacity:0;transition:opacity .2s}.avatar-upload:hover .avatar-overlay{opacity:1}.activate-btn{width:100%;padding:16px;font-size:1rem}.error-message{color:#e74c3c;font-size:.9rem;margin-top:10px;text-align:center;background:#e74c3c1a;padding:8px;border-radius:8px;width:100%}@media(max-width:480px){.activate-card{padding:36px 20px}.activate-title{font-size:1.4rem}.avatar-upload{width:100px;height:100px}}@media(max-width:360px){.activate-card{padding:24px 16px}.activate-title{font-size:1.25rem}.activate-sub{font-size:.85rem;margin-bottom:24px}.avatar-upload{width:80px;height:80px}.avatar-icon{font-size:1.8rem}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1100;padding:20px;animation:fadeIn .2s ease;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-2xl);width:100%;max-width:460px;padding:32px;position:relative;max-height:88vh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}.modal-close{position:absolute;top:20px;right:20px;width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);color:var(--text-secondary);font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-title{font-size:1.45rem;font-weight:800;margin-bottom:4px;letter-spacing:-.02em}.modal-subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:28px;font-weight:500}.modal-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.85rem;font-weight:700;color:var(--text-secondary);letter-spacing:.02em}.room-type-options{display:flex;gap:12px}.room-type-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;background:transparent;border:1.5px solid var(--border-light);border-radius:var(--radius-xl);color:var(--text-secondary);transition:all .2s ease}.room-type-option:hover{border-color:var(--border);background:var(--bg-hover)}.room-type-option.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.room-type-icon{font-size:1.5rem}.room-type-label{font-size:.85rem;font-weight:700}.room-type-desc{font-size:.7rem;opacity:.8}.textarea.input{resize:vertical;min-height:80px;font-family:inherit;line-height:1.5}.schedule-group{padding:16px 0;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:600;color:var(--text-primary);position:relative;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:44px;height:24px;background:var(--bg-tertiary);border-radius:20px;position:relative;cursor:pointer;transition:background .3s;border:1px solid var(--border-light)}.checkbox-label input[type=checkbox]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--text-muted);border-radius:50%;transition:transform .3s,background .3s}.checkbox-label input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.checkbox-label input[type=checkbox]:checked:after{transform:translate(20px);background:#fff}.category-options{display:flex;flex-wrap:wrap;gap:8px}.category-pill{padding:8px 16px;border-radius:var(--radius-full);background:transparent;border:1px solid var(--border-light);color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.category-pill:hover{background:var(--bg-hover);border-color:var(--border);color:var(--text-primary)}.category-pill.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 10px #4f72ff4d}.modal-submit{width:100%;padding:16px;font-size:.95rem;margin-top:8px}@media(max-width:480px){.modal-overlay{padding:0;align-items:flex-end;overflow-y:auto}.modal-content{padding:24px 16px 36px;border-radius:24px 24px 0 0;max-height:calc(92vh - 65px - env(safe-area-inset-bottom,0px));border:none;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.modal-title{font-size:1.25rem}.room-type-options{gap:8px}.room-type-option{padding:12px 6px}.room-type-icon{font-size:1.25rem}.category-pill{padding:6px 12px;font-size:.78rem}}@media(max-width:360px){.modal-content{padding:20px 12px 30px}.form-group{gap:6px}.modal-title{font-size:1.15rem}.room-type-label{font-size:.75rem}}.friends-panel{display:flex;flex-direction:column;width:310px;height:calc(100vh - 84px);position:sticky;top:84px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;flex-shrink:0;box-shadow:var(--shadow-card)}.fp-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.fp-header-left{display:flex;align-items:center;gap:10px;font-weight:800;font-size:.95rem;color:var(--text-primary);letter-spacing:-.01em}.fp-close-btn{width:32px;height:32px;border-radius:50%;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.fp-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.fp-tabs{display:flex;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.fp-tab{flex:1;padding:8px 6px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}.fp-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.fp-tab.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #4f72ff40}.fp-tab-count{background:#fff3;font-size:.65rem;padding:2px 6px;border-radius:var(--radius-full);font-weight:700;line-height:1.2}.fp-tab:not(.active) .fp-tab-count{background:var(--bg-tertiary);color:var(--text-secondary)}.fp-content{flex:1;overflow-y:auto;min-height:0}.fp-list{padding:8px 0}.fp-search-wrap{display:flex;flex-direction:column;height:100%}.fp-search-input-wrap{display:flex;align-items:center;gap:8px;margin:12px 14px;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .2s}.fp-search-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #4f72ff1f}.fp-search-icon{color:var(--text-secondary);flex-shrink:0}.fp-search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:.88rem}.fp-search-input::placeholder{color:var(--text-secondary);opacity:.6}.fp-clear-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.8rem;padding:2px;line-height:1;transition:color .15s}.fp-clear-btn:hover{color:var(--text-primary)}.fp-person-row{display:flex;align-items:center;gap:12px;padding:12px 18px;cursor:pointer;transition:background .15s;border-radius:0}.fp-person-row:hover{background:var(--bg-hover)}.fp-avatar-wrap{position:relative;flex-shrink:0}.fp-avatar{width:44px;height:44px;border-radius:12px;object-fit:cover;background:var(--bg-secondary);display:block;border:1px solid var(--border-subtle)}.fp-status-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-card);position:absolute;bottom:-3px;right:-3px}.fp-dot-online{background:var(--success)}.fp-dot-in-room{background:var(--accent)}.fp-dot-offline{background:var(--text-muted)}.fp-person-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.fp-person-name{font-size:.92rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.fp-person-status{font-size:.75rem;color:var(--text-secondary);font-weight:500}.fp-person-status.in-room{color:var(--accent);font-weight:600}.fp-join-room{cursor:pointer;font-weight:700;color:var(--accent);display:inline-flex;align-items:center;gap:4px;text-decoration:underline;text-underline-offset:3px;transition:opacity .2s}.fp-join-room:hover{opacity:.75}.fp-follow-btn{flex-shrink:0;padding:6px 14px;border-radius:var(--radius-full);font-size:.75rem;font-weight:700;cursor:pointer;border:1px solid transparent;background:var(--bg-secondary);color:var(--text-primary);transition:all .2s;white-space:nowrap}.fp-follow-btn:hover{background:var(--text-primary);color:var(--bg-primary);transform:scale(1.02)}.fp-follow-btn.following{background:transparent;color:var(--text-secondary);border-color:var(--border)}.fp-follow-btn.following:hover{background:#ef444414;color:var(--danger);border-color:#ef44444d}.fp-status-msg{display:flex;align-items:center;gap:10px;padding:20px 16px;font-size:.82rem;color:var(--text-secondary);opacity:.6}.fp-spinner{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent, #6366f1);border-radius:50%;animation:fp-spin .7s linear infinite}@keyframes fp-spin{to{transform:rotate(360deg)}}.fp-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 20px;gap:6px}.fp-empty-icon{font-size:2.2rem;margin-bottom:6px}.fp-empty p{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0}.fp-empty span{font-size:.78rem;color:var(--text-secondary);opacity:.7;line-height:1.5}.friends-panel-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:299;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media(max-width:900px){.friends-panel{position:fixed;top:0;right:0;bottom:0;height:100dvh;border-radius:20px 0 0 20px;border-right:none;z-index:300;width:310px;box-shadow:-10px 0 30px #0000004d}.friends-panel-overlay{display:block}}@media(max-width:480px){.friends-panel{width:280px}.fp-header{padding:14px 16px}.fp-person-row{padding:10px 14px;gap:10px}.fp-avatar{width:40px;height:40px}}@media(max-width:360px){.friends-panel{width:250px}.fp-tab{font-size:.72rem;padding:6px 4px}.fp-person-name{font-size:.88rem}}.notification-dropdown{position:absolute;top:calc(var(--navbar-h) + 8px);right:0;width:380px;max-height:480px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;box-shadow:0 10px 40px #0006;z-index:3000;display:flex;flex-direction:column;overflow:hidden;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:notifFadeIn .18s ease both}@keyframes notifFadeIn{0%{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}body.light-mode .notification-dropdown{box-shadow:0 10px 40px #0000001a}.notification-header{padding:16px 20px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background:#ffffff08}.notification-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.mark-read-btn{background:transparent;border:none;color:var(--primary-color);font-size:.85rem;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:background .2s}.mark-read-btn:hover{background:#905bff1a}.notification-list-body{flex:1;overflow-y:auto;padding:8px 0}.notification-empty{padding:40px 20px;text-align:center;color:var(--text-muted)}.notification-empty .empty-icon{font-size:2.5rem;margin-bottom:12px;display:inline-block;opacity:.5}.notification-item{display:flex;align-items:flex-start;gap:12px;padding:12px 20px;text-decoration:none;cursor:pointer;transition:background .2s;position:relative;border-left:3px solid transparent}.notification-item:hover{background:var(--bg-hover)}.notification-item.unread{background:#905bff0d;border-left-color:var(--primary-color)}.notification-avatar{width:40px;height:40px;border-radius:var(--radius-full);object-fit:cover;flex-shrink:0}.notification-avatar-fallback{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-message{margin:0 0 4px;font-size:.95rem;color:var(--text-primary);line-height:1.4;word-break:break-word}.notification-time{margin:0;font-size:.8rem;color:var(--text-muted)}.unread-dot{width:8px;height:8px;border-radius:50%;background:var(--primary-color);position:absolute;right:20px;top:50%;transform:translateY(-50%)}.notification-list-body::-webkit-scrollbar{width:6px}.notification-list-body::-webkit-scrollbar-track{background:transparent}.notification-list-body::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.notification-list-body::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.notification-dropdown{position:fixed;bottom:65px;left:0;right:0;top:auto;width:100%;max-height:calc(100dvh - 65px);border-radius:24px 24px 0 0;border:1px solid var(--border);border-bottom:none;animation:slideInUp .3s cubic-bezier(.16,1,.3,1) forwards;z-index:3000;display:flex;flex-direction:column;overflow:hidden}.notification-header{padding:20px 20px 16px;flex-shrink:0;border-bottom:1px solid var(--border)}.notification-header:before{content:"";display:block;width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 16px}.close-mobile-btn{display:block!important;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0 8px;line-height:1}.notification-item{padding:14px 16px}.notification-list-body{overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:16px}}@media(max-width:480px){.notification-avatar,.notification-avatar-fallback{width:38px;height:38px;font-size:1rem}.notification-message{font-size:.88rem}.notification-time{font-size:.72rem}}.close-mobile-btn{display:none}.ptr-container{position:relative;overflow:hidden;touch-action:pan-y}.ptr-indicator{position:absolute;top:-40px;left:50%;margin-left:-15px;width:30px;height:30px;display:flex;justify-content:center;align-items:center;border-radius:50%;background:var(--bg-card);box-shadow:0 2px 10px #0003;z-index:50;transition:transform .2s ease,opacity .2s ease}.ptr-arrow{transition:transform .3s ease;font-size:1.2rem;color:var(--primary)}.ptr-spinner{width:20px;height:20px;border-width:2px;border-color:var(--primary);border-right-color:transparent}.ptr-content{transition:transform .2s ease}.end-of-list{display:flex;align-items:center;justify-content:center;padding:30px 20px;margin-top:10px;opacity:.6;animation:fadeIn .4s ease forwards}.end-of-list-divider{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}.end-of-list-content{display:flex;align-items:center;gap:8px;padding:0 15px;color:var(--text-muted)}.end-of-list-icon{font-size:1rem}.end-of-list-message{font-size:.9rem;font-weight:500}.rooms-page{min-height:100vh;min-height:100dvh;background:var(--bg-primary);width:100%;overflow-x:hidden}.rooms-layout{display:flex;align-items:flex-start;gap:24px;padding-top:36px;padding-bottom:80px}.rooms-main{flex:1;min-width:0;width:100%}.friends-nav-btn{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:6px 13px;border-radius:var(--radius-full);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .18s}.friends-nav-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent)}.friends-nav-btn.active{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.rooms-header{margin-bottom:32px;display:flex;flex-direction:column;gap:20px}.rooms-header-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.rooms-start-btn{display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0;padding:9px 18px;font-size:.9rem;font-weight:700;border-radius:var(--radius-full)}.rooms-start-btn-label{display:inline}.rooms-title{font-size:1.55rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary)}.rooms-subtitle{color:var(--text-secondary);font-size:.87rem;margin-top:3px;font-weight:400}.rooms-filters{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.search-wrap{flex:1;min-width:220px;display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--radius-full);background:var(--bg-input);border:1px solid var(--border);transition:all .2s;max-width:100%}.search-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #4f72ff1f}.search-icon{color:var(--text-muted);flex-shrink:0}.search-input{flex:1;background:none;border:none;color:var(--text-primary);font-size:.9rem;outline:none}.search-input::placeholder{color:var(--text-muted)}.filter-tabs{display:flex;gap:6px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;padding:2px 0;flex-wrap:nowrap;width:100%;min-width:0;-webkit-overflow-scrolling:touch}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{padding:6px 16px;border-radius:var(--radius-full);background:transparent;border:1px solid var(--border);color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .18s;flex-shrink:0}.filter-tab:hover{border-color:var(--accent);color:var(--text-primary);background:var(--bg-hover)}.filter-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 10px #4f72ff59}.rooms-section-label{display:flex;align-items:center;gap:10px;margin-bottom:16px;margin-top:32px}.rooms-section-label:first-child{margin-top:0}.rooms-section-label h3{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.rooms-section-label:after{content:"";flex:1;height:1px;background:var(--border)}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}.room-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;gap:16px;position:relative;overflow:hidden;box-shadow:0 4px 14px #0000000a}.room-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent-gradient-subtle);opacity:0;transition:opacity .3s ease;pointer-events:none}.room-card:hover:before{opacity:1}.room-card:hover{border-color:#4f72ff66;transform:translateY(-4px);box-shadow:0 12px 32px #00000014,0 0 0 1px #4f72ff1a;background:var(--bg-card-hover)}.room-card:hover .room-card-join{opacity:1;transform:translate(0)}.room-card.is-live:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent-gradient)}.room-card-header{display:flex;flex-direction:column;gap:6px}.room-card-status{display:flex;align-items:center;gap:8px}.live-dot{width:7px;height:7px;border-radius:50%;background:var(--success);animation:pulse 2s ease-in-out infinite;flex-shrink:0}.scheduled-dot{width:7px;height:7px;border-radius:50%;background:var(--warning);flex-shrink:0}.room-card-topic{font-size:1.05rem;font-weight:700;line-height:1.35;color:var(--text-primary);letter-spacing:-.01em}.room-card-page{display:flex;align-items:center;gap:7px;margin-top:2px}.room-card-page-logo{width:18px;height:18px;border-radius:4px;object-fit:cover;flex-shrink:0}.room-card-page-name{font-size:.78rem;font-weight:600;color:var(--primary-color, var(--accent));opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-card-speakers{display:flex;align-items:center;gap:0}.speaker-mini{width:34px;height:34px;border-radius:50%;border:2px solid var(--bg-card);margin-right:-10px;overflow:hidden;background:var(--bg-secondary);transition:border-color .2s;flex-shrink:0}.room-card:hover .speaker-mini{border-color:var(--bg-card-hover)}.speaker-mini-avatar{width:100%;height:100%;object-fit:cover}.speaker-mini-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:.78rem;font-weight:700;color:var(--text-secondary);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary))}.speaker-more{margin-left:18px;font-size:.75rem;color:var(--text-muted);font-weight:600}.room-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:14px;border-top:1px solid var(--border-subtle)}.room-card-count{display:flex;align-items:center;gap:5px;font-size:.8rem;color:var(--text-muted);font-weight:500}.room-card-join{font-size:.8rem;color:var(--accent);font-weight:700;opacity:0;transform:translate(-6px);transition:all .25s;display:flex;align-items:center;gap:4px}.scheduled-label{font-size:.72rem;font-weight:600;color:var(--warning);background:#f59e0b1a;padding:2px 8px;border-radius:var(--radius-full)}.rooms-empty{text-align:center;padding:64px 20px;animation:fadeIn .4s ease}.empty-icon{font-size:3.5rem;margin-bottom:20px;opacity:.4}.rooms-empty h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.rooms-empty p{font-size:.88rem;color:var(--text-secondary)}.rooms-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;gap:14px;color:var(--text-secondary);font-size:.88rem}@media(max-width:900px){.rooms-layout{flex-direction:column;gap:0}}@media(max-width:768px){.rooms-layout{padding-top:16px;padding-bottom:100px;gap:0}.rooms-title{font-size:1.3rem}.rooms-subtitle{font-size:.8rem}.rooms-header{margin-bottom:20px;gap:14px}.rooms-header-top{flex-wrap:wrap;gap:12px;align-items:center}.rooms-start-btn{margin-left:auto}.rooms-grid{grid-template-columns:1fr;gap:12px}.room-card{padding:18px;border-radius:18px}.room-card-join{opacity:1;transform:translate(0)}}@media(max-width:640px){.rooms-filters{flex-direction:column;align-items:stretch}.search-wrap{min-width:0}.mobile-hide{display:none}.filter-tabs{padding-bottom:4px}.filter-tab{padding:8px 14px;font-size:.82rem}}@media(max-width:480px){.rooms-layout{padding-top:12px;padding-bottom:110px}.rooms-title{font-size:1.15rem}.rooms-subtitle{font-size:.75rem}.rooms-header-top{flex-direction:column;align-items:center;text-align:center;gap:14px}.rooms-start-btn{width:100%;justify-content:center;margin-left:0;padding:12px 20px;border-radius:14px;font-size:1rem}.rooms-header-top .rooms-title{font-size:1.25rem}.rooms-header-top .rooms-subtitle{font-size:.85rem}.room-card{padding:14px;border-radius:16px;gap:12px}.room-card-topic{font-size:.95rem}.room-card-footer{padding-top:10px}.friends-nav-btn{padding:6px 8px;gap:2px}.speaker-mini{width:28px;height:28px}}@media(max-width:360px){.rooms-layout{padding-top:8px}.rooms-header{gap:12px;margin-bottom:14px}.room-card{padding:12px}.filter-tab{padding:6px 10px;font-size:.78rem}}.room-type-badge{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);letter-spacing:.04em}.social-badge{background:#f59e0b1f;color:#f59e0b;border:1px solid rgba(245,158,11,.25)}.closed-badge{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.25)}.rooms-fab{display:none}@media(max-width:480px){.rooms-fab{display:flex;align-items:center;justify-content:center;position:fixed;bottom:calc(81px + env(safe-area-inset-bottom,0px));right:20px;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#4f72ff,#7c3aed);color:#fff;border:none;cursor:pointer;box-shadow:0 6px 24px #4f72ff73,0 2px 8px #0003;z-index:950;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease;font-size:1.8rem;font-weight:300;line-height:1}.rooms-fab:hover,.rooms-fab:active{transform:scale(1.1);box-shadow:0 10px 32px #4f72ff8c}}@media(min-width:481px)and (max-width:768px){.rooms-start-btn{display:flex!important}}.user-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;justify-content:center;align-items:center}.user-modal-content{background:var(--bg-card);width:90%;max-width:400px;border-radius:24px;padding:24px;position:relative;box-shadow:0 20px 50px #00000080;border:1px solid var(--border)}.user-modal-header{display:flex;flex-direction:column;align-items:center;gap:16px;margin-bottom:24px;text-align:center;position:relative}.user-modal-close-btn{position:absolute;top:-10px;right:-10px;background:var(--bg-tertiary);border:none;color:var(--text-secondary);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:10}.user-modal-close-btn:hover{background:var(--bg-hover);color:var(--text-primary);transform:scale(1.1)}.user-modal-avatar{width:80px;height:80px;border-radius:40%;object-fit:cover;border:3px solid var(--bg-secondary);box-shadow:0 8px 16px #0003}.user-modal-name{font-size:1.4rem;font-weight:700;color:var(--text-primary);margin:0}.user-modal-handle{color:var(--text-secondary);font-size:.9rem;margin-top:4px}.user-modal-stats{display:flex;justify-content:center;gap:40px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.8rem;color:var(--text-secondary)}.user-modal-actions{display:flex;flex-direction:column;gap:12px}.modal-action-btn{padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .2s}.modal-action-btn:hover{background:var(--bg-input);border-color:var(--border-light)}.modal-action-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.modal-action-btn.primary:hover{filter:brightness(1.1)}.mod-actions-group{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.mod-actions-title{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.modal-action-btn.danger{color:#ef4444;border-color:#ef44444d;background:#ef44440d}.modal-action-btn.danger-filled{background:#ef4444;color:#fff;border-color:#ef4444}@media(max-width:600px){.user-modal-overlay{align-items:flex-end;padding:0}.user-modal-content{width:100%;max-width:100%;border-radius:24px 24px 0 0;padding:24px 16px 40px;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.modal-action-btn{padding:12px;font-size:.9rem}}@media(max-width:480px){.user-modal-content{padding:20px 14px 30px}.modal-user-name{font-size:1.15rem}.modal-user-username{font-size:.8rem}.modal-stats{gap:16px;margin-bottom:20px}.modal-bio{font-size:.85rem;margin-bottom:20px}.action-group-label{font-size:.7rem}}@media(max-width:360px){.user-modal-content{padding:16px 12px 24px}.modal-user-avatar{width:64px;height:64px;border-radius:20px}.modal-stats-item .count{font-size:1rem}.modal-stats-item .label{font-size:.65rem}}.modal-action-btn.secondary{background:var(--bg-secondary);border-color:var(--border);color:var(--text-primary)}.modal-action-btn.following-btn{background:transparent;border-color:var(--border);color:var(--text-secondary)}.modal-action-btn.following-btn:hover{background:#ef44440f;color:#ef4444;border-color:#ef44444d}.modal-action-btn.follow-back-btn{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:#fff;box-shadow:0 4px 14px #10b9814d}.modal-action-btn.follow-back-btn:hover{box-shadow:0 6px 20px #10b98173;filter:brightness(1.05)}.modal-relationship-badge{display:inline-flex;align-items:center;gap:4px;margin-top:5px;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:20px}.modal-relationship-badge.friends{background:#10b9811f;color:#10b981;border:1px solid rgba(16,185,129,.3)}.modal-relationship-badge.follows-you{background:#6366f11a;color:var(--accent, #6366f1);border:1px solid rgba(99,102,241,.25)}.modal-relationship-badge.you-follow{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border)}.user-modal-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:4px;margin-top:4px}.modal-role-badge{display:inline-flex;align-items:center;gap:3px;font-size:.68rem;font-weight:700;padding:2px 9px;border-radius:20px}.modal-role-badge.owner{background:#eab30826;color:#ca8a04;border:1px solid rgba(234,179,8,.3)}.modal-role-badge.mod{background:#6366f11f;color:var(--accent, #6366f1);border:1px solid rgba(99,102,241,.3)}.modal-action-btn.mute-btn{background:#f9731614;color:#f97316;border-color:#f973164d}.modal-action-btn.mute-btn:hover{background:#f973162e}.modal-action-btn.mod-give-btn{background:#6366f11a;color:var(--accent, #6366f1);border-color:#6366f14d}.modal-action-btn.mod-give-btn:hover{background:#6366f12e}.modal-action-btn.mod-revoke-btn{background:transparent;color:#ef4444;border-color:#ef44444d}.modal-action-btn.mod-revoke-btn:hover{background:#ef44440f}.invite-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.invite-modal-content{width:90%;max-width:450px;background:var(--card-bg);border-radius:24px;padding:24px;border:1px solid var(--border-color);box-shadow:0 25px 50px -12px #00000080;display:flex;flex-direction:column;max-height:80vh}.invite-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.invite-header h3{margin:0;font-size:1.25rem;font-weight:700}.invite-search{position:relative;margin-bottom:20px}.invite-search input{width:100%;padding:12px 12px 12px 40px;border-radius:12px;border:1px solid var(--border-color);background:#ffffff0d;color:var(--text-primary);font-size:1rem;outline:none;transition:all .2s}.invite-search input:focus{background:#ffffff1a;border-color:var(--primary-color)}.search-icon{opacity:.6;cursor:pointer}.invite-list{flex:1;overflow-y:auto;margin-bottom:20px;display:flex;flex-direction:column;gap:8px;min-height:200px}.user-row{display:flex;align-items:center;padding:10px;border-radius:12px;cursor:pointer;transition:background .2s;-webkit-user-select:none;user-select:none}.user-row:hover{background:#ffffff0d}.user-row.selected{background:rgba(var(--primary-rgb),.15)}.user-avatar{width:44px;height:44px;border-radius:16px;margin-right:12px;object-fit:cover}.user-info{flex:1;display:flex;flex-direction:column}.user-name{font-weight:600;font-size:1rem}.user-handle{font-size:.85rem;color:var(--text-secondary)}.selection-circle{width:24px;height:24px;border-radius:50%;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;transition:all .2s}.user-row.selected .selection-circle{background:var(--primary-color);border-color:var(--primary-color)}.invite-footer{display:flex;gap:12px;padding-top:20px;border-top:1px solid var(--border-color)}.invite-footer button{flex:1;padding:12px;border-radius:12px;font-weight:600;cursor:pointer;transition:transform .1s}.invite-footer button:active{transform:scale(.98)}.btn-secondary{background:#ffffff0d;border:1px solid var(--border-color);color:var(--text-primary)}.btn-primary{background:var(--primary-color);border:none;color:#fff}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.suggested-section{text-align:center;padding:40px 0;color:var(--text-secondary)}.section-label{font-weight:600;margin-bottom:8px;text-transform:uppercase;font-size:.75rem;letter-spacing:1px;opacity:.7;padding:0 4px}.avatar-wrap{position:relative;margin-right:12px;flex-shrink:0}.avatar-wrap .user-avatar{margin-right:0}.status-dot{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;border-radius:50%;border:2px solid var(--card-bg, #1a1a2e)}.status-dot.online{background:#22c55e}.status-dot.in-room{background:#a855f7}.status-dot.offline{background:#6b7280}.status-text{font-size:.75rem;margin-top:2px}.status-text.status-online{color:#22c55e}.status-text.status-in-room{color:#a855f7}.status-text.status-offline{color:#6b7280}.selection-circle.selected{background:var(--primary-color);border-color:var(--primary-color)}.invite-selected-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.chip{background:rgba(var(--primary-rgb, 99, 102, 241),.2);border:1px solid rgba(var(--primary-rgb, 99, 102, 241),.4);color:var(--text-primary);font-size:.8rem;padding:4px 10px;border-radius:999px;cursor:pointer;transition:background .15s}.chip:hover{background:rgba(var(--primary-rgb, 99, 102, 241),.35)}.empty-state{text-align:center;padding:32px 16px;color:var(--text-secondary);font-size:.9rem}.loading-state{display:flex;align-items:center;justify-content:center;padding:40px 0}@media(max-width:600px){.invite-modal-overlay{align-items:flex-end;padding:0}.invite-card{width:100%;max-width:100%;border-radius:24px 24px 0 0;max-height:85vh;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.invite-header{padding:20px 16px}.invite-body{padding:0 16px}.invite-footer{padding:16px;flex-direction:column-reverse;gap:10px}.invite-footer button{width:100%}}@media(max-width:480px){.invite-title{font-size:1.2rem}.invite-subtitle{font-size:.82rem}.search-input{font-size:.9rem;padding:10px 36px}.invite-person-row{padding:10px 4px}.person-name{font-size:.95rem}}@media(max-width:360px){.invite-card{max-height:90vh}.invite-title{font-size:1.1rem}.avatar-wrap{margin-right:8px}.user-avatar{width:38px;height:38px}.chip{padding:3px 8px;font-size:.75rem}}.room-page,.room-page *{box-sizing:border-box}.room-page{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:auto;z-index:1000;overflow-y:auto;overflow-x:hidden;background:var(--bg-primary);display:flex;flex-direction:column;padding-bottom:110px}.room-container{max-width:820px;margin:0 auto;width:100%;padding:16px 16px 24px}.room-container.playing-ludo{padding:8px 8px 16px;display:flex;flex-direction:column;gap:0}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideLeft{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes pop{0%{transform:translate(-50%) scale(.4);opacity:0}60%{transform:translate(-50%) scale(1.2)}to{transform:translate(-50%) scale(1);opacity:1}}@keyframes floatUp{0%{transform:translate(-50%) translateY(0);opacity:1}to{transform:translate(-50%) translateY(-40px);opacity:0}}@keyframes pulse-ring{0%{box-shadow:0 0 #22c55e66}70%{box-shadow:0 0 0 12px #22c55e00}to{box-shadow:0 0 #22c55e00}}@keyframes speaking-glow{0%,to{box-shadow:0 0 0 3px var(--speaking, #22c55e),0 4px 14px #22c55e40}50%{box-shadow:0 0 0 4px var(--speaking, #22c55e),0 8px 24px #22c55e66}}@keyframes liveDot{0%,to{opacity:1}50%{opacity:.2}}.animate-slideDown{animation:slideDown .35s cubic-bezier(.25,.8,.25,1) both}.animate-slideUp{animation:slideUp .35s cubic-bezier(.25,.8,.25,1) both}.animate-slideLeft{animation:slideLeft .3s cubic-bezier(.25,.8,.25,1) both}.animate-fadeIn{animation:fadeIn .3s ease both}.animate-pop{animation:pop .4s cubic-bezier(.34,1.56,.64,1) both}.room-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:28px}.header-left,.header-right{display:flex;align-items:center;gap:8px;min-width:80px}.header-right{justify-content:flex-end}.back-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-weight:600;font-size:.85rem;cursor:pointer;padding:6px 10px;border-radius:10px;transition:all .2s}.back-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.header-center{flex:1;text-align:center;min-width:0}.room-title{font-size:1.4rem;font-weight:800;line-height:1.3;margin:0 0 8px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 10px}.room-badges{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.room-badge{font-size:.7rem;background:var(--bg-secondary);color:var(--text-secondary);padding:3px 10px;border-radius:20px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;border:1px solid var(--border)}.live-badge{background:#ef44441f;color:#ef4444;border-color:#ef44444d;display:flex;align-items:center;gap:5px}.room-badge-page{background:#6366f11a;color:var(--accent, #6366f1);border-color:#6366f14d;text-transform:none;letter-spacing:0;font-size:.72rem;transition:all .2s}.room-badge-page:hover{background:#6366f133;border-color:#6366f180;transform:translateY(-1px)}.live-dot{width:6px;height:6px;background:#ef4444;border-radius:50%;animation:liveDot 1.2s ease-in-out infinite}.hdr-btn{width:36px;height:36px;border-radius:12px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.hdr-btn:hover{background:var(--bg-hover);color:var(--text-primary);transform:translateY(-1px)}.hdr-btn.danger-btn{color:#ef4444;border-color:#ef44444d}.hdr-btn.danger-btn:hover{background:#ef44441a}.room-stage{background:linear-gradient(145deg,var(--bg-card) 0%,var(--bg-secondary) 100%);border:1px solid var(--border);border-radius:28px;padding:24px 20px 28px;margin-bottom:24px;position:relative;overflow:hidden;box-shadow:0 4px 12px #00000008}.room-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 0%,rgba(99,102,241,.08) 0%,transparent 70%);pointer-events:none}.stage-label{display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:24px;opacity:.7}.stage-empty{text-align:center;padding:32px 0 16px;color:var(--text-secondary);opacity:.5}.stage-empty-icon{font-size:2rem;margin-bottom:8px}.stage-empty p{font-size:.85rem;margin:0}.stage-grid{display:flex;flex-wrap:wrap;gap:28px 20px;justify-content:center}.speaker-node{display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;position:relative;transition:transform .2s}.speaker-node:hover{transform:translateY(-3px)}.speaker-node.is-self{cursor:default}.speaker-node.is-self:hover{transform:none}.avatar-ring{width:90px;height:90px;border-radius:28px;position:relative;padding:3px;background:var(--bg-secondary);border:2px solid transparent;box-shadow:0 8px 20px #00000014,inset 0 2px 4px #ffffff0d;transition:all .3s cubic-bezier(.25,.8,.25,1)}.avatar-ring.speaking{border-color:#22c55e;background:linear-gradient(145deg,#22c55e0d,#22c55e26);animation:speaking-glow 2s ease-in-out infinite,pulse-ring 2.5s infinite}.speaker-avatar{width:100%;height:100%;border-radius:24px;object-fit:cover;display:block;background:var(--bg-secondary);box-shadow:inset 0 0 0 1px #0000000d}.spk-badge{position:absolute;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;box-shadow:0 4px 10px #0000004d;border:2px solid var(--bg-primary);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:5}.muted-badge{bottom:-4px;right:-4px;background:#ef4444e6;color:#fff}.host-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:.6rem;font-weight:800;letter-spacing:.05em;padding:3px 8px;border-radius:12px;box-shadow:0 4px 12px #f59e0b66,inset 0 1px #ffffff4d;border:1px solid rgba(245,158,11,.5);display:flex;align-items:center;gap:3px;z-index:10;white-space:nowrap}.mod-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#9ca3af,#4b5563);color:#fff;font-size:.6rem;font-weight:800;letter-spacing:.05em;padding:3px 8px;border-radius:12px;box-shadow:0 4px 12px #9ca3af66,inset 0 1px #ffffff4d;border:1px solid rgba(156,163,175,.5);display:flex;align-items:center;gap:3px;z-index:10;white-space:nowrap}.reaction-float{position:absolute;bottom:100%;left:50%;font-size:1.5rem;transform:translate(-50%);animation:floatUp 2.5s forwards;pointer-events:none;z-index:10}.speaker-name{font-size:.82rem;font-weight:600;text-align:center;color:var(--text-primary);max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.speaker-name em{font-size:.7rem;font-style:normal;color:var(--text-secondary);font-weight:400}.room-audience{padding:0 4px}.audience-header{margin-bottom:16px}.audience-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);opacity:.7}.audience-empty{font-size:.82rem;color:var(--text-secondary);opacity:.4;text-align:center;margin:20px 0}.audience-grid{display:flex;flex-wrap:wrap;gap:20px 16px}.listener-node{display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;transition:transform .2s}.listener-node:hover{transform:translateY(-2px)}.listener-avatar-wrap{width:66px;height:66px;border-radius:20px;position:relative;border:2px solid transparent}.listener-avatar-wrap.hand-raised{border-color:#f59e0b;animation:pulse-ring 1.5s cubic-bezier(.66,0,0,1) infinite}.listener-avatar{width:100%;height:100%;border-radius:18px;object-fit:cover;display:block;background:var(--bg-secondary)}.hand-indicator{position:absolute;top:-10px;right:-10px;font-size:.9rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));animation:pop .3s cubic-bezier(.34,1.56,.64,1)}.request-quick-actions{position:absolute;bottom:-14px;left:50%;transform:translate(-50%);display:flex;gap:4px;z-index:5}.rqa-btn{width:22px;height:22px;border-radius:50%;border:2px solid var(--bg-card);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.6rem;transition:transform .15s;box-shadow:0 2px 6px #0003}.rqa-btn:hover{transform:scale(1.15)}.rqa-btn.accept{background:#22c55e;color:#fff}.rqa-btn.deny{background:#ef4444;color:#fff}.listener-name{font-size:.75rem;color:var(--text-secondary);font-weight:500;max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.listener-name em{font-style:normal;font-size:.65rem;color:var(--text-secondary);opacity:.6}.listener-node.requesting .listener-avatar-wrap{border-color:#6366f1;animation:pulse-ring 1.5s cubic-bezier(.66,0,0,1) infinite}.room-controls-bar{position:fixed;bottom:0;left:0;right:0;height:100px;background:#ffffff08;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;padding:12px 20px 0;z-index:100;box-shadow:0 -8px 40px #00000014;-webkit-backdrop-filter:blur(24px) saturate(150%);backdrop-filter:blur(24px) saturate(150%)}.controls-center{display:flex;gap:16px;align-items:flex-start;transform:translateY(-18px)}.fab-wrap{display:flex;flex-direction:column;align-items:center;gap:5px}.fab-label{font-size:.65rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.ctrl-fab{width:60px;height:60px;border-radius:22px;border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 6px 20px #0000001a;transition:all .2s cubic-bezier(.34,1.56,.64,1);position:relative}.ctrl-fab:hover{transform:scale(1.1);box-shadow:0 10px 28px #00000026}.ctrl-fab.muted{background:#ef4444;color:#fff;border-color:#ef4444;box-shadow:0 6px 20px #ef444459}.ctrl-fab.active{background:var(--accent, #6366f1);color:#fff;border-color:var(--accent, #6366f1);box-shadow:0 6px 20px #6366f159}.ctrl-fab.request-fab{background:#6366f114;color:var(--accent, #6366f1);border-color:#6366f14d}.ctrl-fab.hand-fab.active{background:#f59e0b;border-color:#f59e0b;box-shadow:0 6px 20px #f59e0b59}.ctrl-fab.requests-fab{background:#6366f11a;color:var(--accent, #6366f1);border-color:#6366f140}.ctrl-fab.ludo-fab{background:#fbbf241a;color:#fbbf24;border-color:#fbbf2459;font-size:1.6rem}.ctrl-fab.ludo-fab:hover{background:#fbbf242e;box-shadow:0 8px 24px #fbbf2440}.fab-badge{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;font-size:.65rem;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg-card);line-height:1}.ctrl-side-btn{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:.72rem;font-weight:600;min-width:56px;transition:all .2s;padding-top:8px}.ctrl-side-btn:hover{color:var(--text-primary)}.leave-btn{color:#ef4444}.leave-btn:hover{color:#dc2626}.ctrl-side-btn span{font-size:.65rem;text-transform:uppercase;letter-spacing:.3px;margin-top:2px}.ctrl-side-btn svg{opacity:.9}.reactions-dock{position:fixed;bottom:115px;left:50%;transform:translate(-50%);background:var(--bg-card);border:1px solid var(--border);border-radius:24px;padding:12px 16px;display:flex;gap:8px;z-index:90;box-shadow:0 12px 40px #0003;animation:slideUp .25s ease both}.reaction-btn{font-size:1.7rem;background:none;border:none;cursor:pointer;transition:transform .15s cubic-bezier(.34,1.56,.64,1);padding:4px;line-height:1;border-radius:12px}.reaction-btn:hover{transform:scale(1.35)}.chat-panel{position:fixed;top:0;right:0;bottom:100px;width:320px;background:var(--bg-card);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:200;box-shadow:-12px 0 40px #0000001a}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:18px 16px;border-bottom:1px solid var(--border);font-weight:700;font-size:.95rem}.chat-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;padding:4px;border-radius:8px;transition:all .2s}.chat-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}.chat-empty{margin:auto;text-align:center;color:var(--text-secondary);opacity:.5;font-size:.85rem}.chat-row{display:flex;align-items:flex-end;gap:8px}.chat-row.mine{flex-direction:row-reverse}.chat-avatar{width:28px;height:28px;border-radius:10px;object-fit:cover;flex-shrink:0}.chat-bubble{max-width:78%;background:var(--bg-secondary);border-radius:16px 16px 16px 4px;padding:8px 12px}.chat-row.mine .chat-bubble{background:var(--accent, #6366f1);color:#fff;border-radius:16px 16px 4px}.chat-sender{display:block;font-size:.68rem;font-weight:700;color:var(--text-secondary);margin-bottom:3px}.chat-bubble p{margin:0;font-size:.88rem;line-height:1.4}.chat-input{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--border)}.chat-input input{flex:1;background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:20px;padding:9px 16px;outline:none;color:var(--text-primary);font-size:.88rem;transition:border-color .2s}.chat-input input:focus{border-color:var(--accent, #6366f1)}.chat-input button{width:38px;height:38px;border-radius:50%;background:var(--accent, #6366f1);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.chat-input button:hover{background:var(--accent-hover, #4f46e5);transform:scale(1.05)}.invite-banner{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:300;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-radius:20px;padding:14px 20px;display:flex;align-items:center;gap:14px;box-shadow:0 12px 40px #6366f173;max-width:90vw;width:420px;animation:slideDown .4s cubic-bezier(.25,.8,.25,1) both}.invite-banner-icon{font-size:1.8rem;flex-shrink:0}.invite-banner-text{flex:1;display:flex;flex-direction:column;gap:3px}.invite-banner-text strong{font-size:.95rem;font-weight:800}.invite-banner-text span{font-size:.8rem;opacity:.85}.invite-banner-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.invite-accept-btn,.invite-decline-btn{display:flex;align-items:center;gap:5px;padding:7px 14px;border-radius:12px;border:none;cursor:pointer;font-size:.82rem;font-weight:700;transition:all .2s}.invite-accept-btn{background:#ffffff40;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.invite-accept-btn:hover{background:#fff6}.invite-decline-btn{background:transparent;color:#ffffffb3;border:1px solid rgba(255,255,255,.3);font-size:.75rem;padding:5px 14px}.invite-decline-btn:hover{color:#fff;border-color:#fff9}.speak-panel{position:fixed;bottom:115px;right:20px;width:280px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:0 12px 40px #0003;z-index:150;overflow:hidden}.speak-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.speak-panel-title{display:flex;align-items:center;gap:7px;font-size:.85rem;font-weight:700;color:var(--text-primary)}.speak-panel-count{background:var(--accent, #6366f1);color:#fff;font-size:.65rem;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px}.speak-panel-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;padding:4px;border-radius:8px;transition:all .2s}.speak-panel-close:hover{background:var(--bg-hover);color:var(--text-primary)}.speak-panel-list{max-height:240px;overflow-y:auto;padding:8px 0}.speak-panel-row{display:flex;align-items:center;gap:10px;padding:10px 16px;transition:background .15s}.speak-panel-row:hover{background:var(--bg-secondary)}.speak-panel-avatar{width:36px;height:36px;border-radius:12px;object-fit:cover;background:var(--bg-secondary);flex-shrink:0}.speak-panel-name{flex:1;font-size:.85rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.speak-panel-btns{display:flex;gap:6px}.spb{width:30px;height:30px;border-radius:10px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;transition:all .2s;flex-shrink:0}.spb:hover{transform:scale(1.1)}.spb.accept{background:#22c55e26;color:#22c55e}.spb.accept:hover{background:#22c55e;color:#fff}.spb.reject{background:#ef44441a;color:#ef4444}.spb.reject:hover{background:#ef4444;color:#fff}@media(max-width:600px){.room-stage{padding:12px 10px 16px;margin-bottom:16px;border-radius:20px}.room-header{margin-bottom:16px}.avatar-ring{width:86px;height:86px}.room-controls-bar{height:90px;padding:8px 16px 0}.ctrl-fab{width:52px;height:52px;border-radius:18px;font-size:1.2rem}.controls-center{gap:10px;transform:translateY(-14px)}.chat-panel{width:100%;bottom:90px;border-left:none}.invite-banner{width:calc(100% - 32px);left:16px;transform:none;flex-wrap:wrap;gap:10px;top:auto;bottom:110px;animation:slideUp .35s cubic-bezier(.25,.8,.25,1) both}.invite-banner-actions{flex-direction:row}.speak-panel{right:10px;left:10px;width:auto;bottom:105px}.reactions-dock{padding:10px 12px;gap:6px}.reaction-btn{font-size:1.5rem}}.mod-badge{position:absolute;bottom:-2px;left:-2px;width:20px;height:20px;background:linear-gradient(135deg,#818cf8,#6366f1);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;border:2px solid var(--bg-primary);line-height:1}.mute-all-fab{background:#f973161f!important;color:#f97316!important;border:1px solid rgba(249,115,22,.35)!important}.mute-all-fab:hover{background:#f9731638!important}@media(max-width:480px){.room-container{padding:8px 8px 12px}.room-header{margin-bottom:10px;gap:8px}.room-title{font-size:.95rem}.room-topic{font-size:1rem}.room-stage{padding:10px 8px 12px;border-radius:16px;margin-bottom:14px}.stage-grid{gap:16px 10px}.avatar-ring{width:80px;height:80px;border-radius:20px}.speaker-avatar{border-radius:17px}.audience-grid{gap:14px 12px}.listener-avatar-wrap{width:64px;height:64px}.room-controls-bar{height:84px;padding:6px 8px 0;padding-bottom:max(6px,env(safe-area-inset-bottom));gap:6px}.ctrl-fab{width:42px;height:42px;border-radius:14px;font-size:1.05rem}.ctrl-side-btn{min-width:44px;padding-top:4px}.ctrl-side-btn span{font-size:.6rem}.controls-center{gap:6px;transform:translateY(-12px)}.chat-panel{width:100%;left:0;right:0;top:0;bottom:84px;border-radius:0}.reactions-dock{padding:8px 10px;gap:4px;border-radius:18px}.reaction-btn{font-size:1.3rem;padding:2px}}.room-minimized{position:fixed;bottom:20px;right:20px;left:20px;max-width:400px;margin:0 auto;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;z-index:1000;box-shadow:0 10px 40px #0003;cursor:pointer;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.room-minimized:hover{transform:translateY(-4px)}.minimized-info{display:flex;align-items:center;gap:12px;flex:1;overflow:hidden}.minimized-avatar{width:44px;height:44px;border-radius:14px;object-fit:cover}.minimized-text{display:flex;flex-direction:column;overflow:hidden}.minimized-text strong{font-size:.95rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.minimized-text span{font-size:.75rem;color:var(--text-secondary)}.minimized-actions{display:flex;gap:8px}.mini-fab{width:44px;height:44px;border-radius:14px;border:none;background:var(--bg-secondary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.mini-fab:hover{background:var(--bg-hover)}.mini-fab.muted{background:#ef444426;color:#ef4444}.mini-fab.danger{background:#ef44441a;color:#ef4444}.mini-fab.danger:hover{background:#ef4444;color:#fff}@media(max-width:600px){.room-minimized{bottom:80px;left:10px;right:auto;width:max-content;max-width:calc(100vw - 20px)}}@media(max-width:480px){.room-page{padding-bottom:max(96px,calc(88px + env(safe-area-inset-bottom)))}.room-container{padding:12px 12px 20px}.room-header{margin-bottom:18px;gap:8px}.room-title{font-size:1.1rem}.room-topic{font-size:1rem}.room-stage{padding:16px 12px 20px}.stage-label{margin-bottom:18px}.stage-grid{gap:20px 16px;display:grid;grid-template-columns:repeat(3,1fr);justify-items:center}.avatar-ring{width:80px;height:80px;border-radius:24px}.speaker-avatar{border-radius:20px}.speaker-name{font-size:.82rem;max-width:80px}.audience-grid{gap:16px 12px}.listener-avatar-wrap{width:58px;height:58px;border-radius:18px}.listener-avatar{border-radius:14px}.listener-name{font-size:.7rem;max-width:58px}.room-controls-bar{height:max(96px,calc(88px + env(safe-area-inset-bottom)));padding:8px 12px max(8px,env(safe-area-inset-bottom));gap:8px}.ctrl-fab{width:46px;height:46px;border-radius:15px;font-size:1.1rem}.ctrl-side-btn{min-width:44px}.ctrl-side-btn span{font-size:.6rem}.controls-center{gap:8px;transform:translateY(-12px)}.fab-label{font-size:.62rem}.mic-fab{width:56px;height:56px;font-size:1.3rem}.host-badge,.mod-badge{font-size:.62rem;padding:3px 9px}}@media(max-width:360px){.room-container{padding:6px 6px 10px}.room-header{margin-bottom:8px}.stage-grid{gap:10px 6px}.avatar-ring{width:68px;height:68px}.ctrl-fab{width:34px;height:34px;border-radius:10px;font-size:.9rem}.mic-fab{width:50px;height:50px;font-size:1.2rem}.room-controls-bar{gap:2px}.room-minimized{bottom:85px;left:6px;right:auto;max-width:calc(100vw - 12px);padding:10px 12px;border-radius:16px}.minimized-avatar{width:36px;height:36px}.mini-fab{width:38px;height:38px;border-radius:12px}}.room-container.playing-ludo{display:grid;grid-template-rows:auto auto 1fr;height:100%;max-height:100dvh}.playing-ludo .room-speakers{max-height:95px;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding:0 10px;margin-bottom:0}.playing-ludo .stage-grid{display:flex;gap:12px;flex-wrap:nowrap}.playing-ludo .speaker-node{width:60px}.playing-ludo .avatar-ring{width:50px;height:50px}.playing-ludo .speaker-avatar{width:44px;height:44px}.playing-ludo .speaker-name{font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60px}.playing-ludo .room-stage{padding:8px 10px;margin-bottom:0;border-radius:0 0 20px 20px}.playing-ludo .room-audience{display:none}.room-ludo-wrapper{flex:1;overflow-y:auto;display:flex;justify-content:center;align-items:flex-start}.profile-card{padding:40px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-2xl);text-align:center;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.profile-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,rgba(79,114,255,.03) 0%,transparent 100%)}.profile-title{font-size:2.2rem;font-weight:800;margin-bottom:32px;letter-spacing:-.02em;color:var(--text-primary)}.profile-header{display:flex;flex-direction:column;align-items:center;margin-bottom:32px}.profile-avatar-wrap{width:130px;height:130px;border-radius:50%;border:4px solid var(--bg-card);box-shadow:0 0 0 2px var(--accent-light);overflow:hidden;position:relative;cursor:pointer;margin-bottom:16px;transition:all .25s cubic-bezier(.4,0,.2,1);background:var(--bg-tertiary)}.profile-avatar-wrap:hover{transform:scale(1.05);box-shadow:0 0 0 4px var(--accent-light)}.profile-avatar-wrap:hover .avatar-overlay{opacity:1}.profile-avatar{width:100%;height:100%;object-fit:cover}.profile-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));color:var(--text-muted);font-size:3.5rem;font-weight:800}.avatar-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0e111899;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s}.avatar-overlay span{font-size:2rem;color:#fff}.profile-helper{font-size:.85rem;color:var(--text-secondary);font-weight:500}.profile-form{display:flex;flex-direction:column;gap:20px;text-align:left;position:relative}.save-btn{width:100%;margin-top:12px;padding:16px;font-size:1.05rem;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-xl)}.profile-stats{display:flex;justify-content:center;gap:40px;margin-bottom:32px;padding:20px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:6px}.stat-value{font-size:1.5rem;font-weight:800;color:var(--text-primary);line-height:1}.stat-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:700}.textarea.input{resize:vertical;min-height:100px;line-height:1.6}@media(max-width:768px){.profile-page{padding:calc(var(--navbar-h) + 16px) 16px 24px 16px}.profile-container{margin-top:12px}.profile-card{padding:28px 20px}.profile-title{font-size:1.7rem;margin-bottom:24px}.profile-stats{gap:20px;padding:16px}}@media(max-width:480px){.profile-card{padding:24px 16px}.profile-title{font-size:1.5rem}.profile-avatar-wrap{width:100px;height:100px}.profile-stats{gap:16px}.stat-value{font-size:1.25rem}}@media(max-width:360px){.profile-page{padding:calc(var(--navbar-h) + 12px) 12px 20px 12px}.profile-card{padding:20px 12px}.profile-title{font-size:1.35rem;margin-bottom:20px}.profile-avatar-wrap{width:80px;height:80px;border-radius:28px}.profile-stats{gap:12px;padding:12px}.stat-label{font-size:.65rem}.profile-form{gap:20px}}._modalOverlay_1qnms_1{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--bg-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:400;animation:_fadeIn_1qnms_1 .15s ease}._modalContent_1qnms_16{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-2xl);width:90%;max-width:420px;padding:24px 28px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:_slideUp_1qnms_1 .3s ease}._modalHeader_1qnms_30{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-subtle)}._modalHeader_1qnms_30 h2{font-size:1.35rem;font-weight:800;letter-spacing:-.01em;margin:0;color:var(--text-primary)}._closeBtn_1qnms_47{background:var(--bg-tertiary);border:none;width:32px;height:32px;border-radius:50%;font-size:1.2rem;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}._closeBtn_1qnms_47:hover{background:var(--bg-hover);color:var(--text-primary)}._modalBody_1qnms_67{overflow-y:auto;flex:1;padding-right:4px}._modalBody_1qnms_67::-webkit-scrollbar{width:4px}._userList_1qnms_77{display:flex;flex-direction:column;gap:12px}._userItem_1qnms_83{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:var(--radius-xl);background:var(--bg-card);border:1px solid transparent;cursor:pointer;transition:all .2s}._userItem_1qnms_83:hover{background:var(--bg-card-hover);border-color:var(--border-subtle);transform:translateY(-1px)}._userInfo_1qnms_101{display:flex;align-items:center;gap:14px}._avatar_1qnms_107{width:44px;height:44px;border-radius:12px;object-fit:cover;background:var(--bg-tertiary);border:1px solid var(--border-subtle)}._name_1qnms_116{font-weight:700;font-size:.95rem;color:var(--text-primary)}._actionBtn_1qnms_122{padding:6px 14px;border-radius:var(--radius-full);border:none;cursor:pointer;font-size:.75rem;font-weight:700;transition:all .2s}._primary_1qnms_132{background:var(--accent);color:#fff;box-shadow:0 2px 8px #4f72ff40}._primary_1qnms_132:hover{background:var(--accent-hover);transform:scale(1.02)}._secondary_1qnms_143{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}._secondary_1qnms_143:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-light)}._empty_1qnms_155,._error_1qnms_156{text-align:center;padding:30px 20px;color:var(--text-secondary);font-size:.9rem}.profile-page{min-height:100vh;background:var(--bg-primary);padding:calc(var(--navbar-h) + 32px) 24px 32px 24px;display:flex;justify-content:center;align-items:flex-start}.profile-container{width:100%;max-width:520px;margin-top:24px;display:flex;flex-direction:column}.profile-name{font-size:1.6rem;font-weight:800;margin-top:16px;margin-bottom:8px;color:var(--text-primary);letter-spacing:-.01em}.profile-bio{font-size:.95rem;color:var(--text-secondary);max-width:440px;line-height:1.6;margin-bottom:16px}.profile-dm-btn{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-full);padding:8px 18px;font-size:.85rem;font-weight:700;cursor:pointer;margin-bottom:20px;transition:all .2s}.profile-dm-btn:hover{background:var(--accent-light);transform:translateY(-1px)}.profile-interests{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:24px;max-width:500px}.interest-tag{background:transparent;color:var(--text-secondary);padding:6px 14px;border-radius:var(--radius-full);font-size:.82rem;font-weight:600;border:1px solid var(--border-light);transition:all .2s}.interest-tag:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border)}.profile-socials{display:flex;gap:12px;margin-bottom:24px}.social-link{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:1.2rem;color:#fff;transition:all .2s;font-weight:700;opacity:.9}.social-link:hover{transform:translateY(-3px);opacity:1;box-shadow:0 4px 12px #0000004d}.social-link.twitter{background-color:#000;border:1px solid #333}.social-link.linkedin{background-color:#0077b5}.social-link.instagram{background:radial-gradient(circle at 30% 107%,#fdf497,#fdf497 5%,#fd5949 45%,#d6249f 60%,#285aeb 90%)}.social-link.facebook{background-color:#1877f2}.profile-avatar-wrap.readonly{cursor:default;border-color:var(--bg-card);box-shadow:0 0 0 2px var(--border)}.profile-avatar-wrap.readonly:hover{transform:none;box-shadow:0 0 0 2px var(--border)}.stat-item.clickable{cursor:pointer;transition:all .2s;padding:8px 16px;border-radius:var(--radius-lg)}.stat-item.clickable:hover{background-color:var(--bg-hover);transform:translateY(-2px)}.profile-username{color:var(--text-muted);margin:-8px 0 12px;font-size:.9rem;font-weight:500}.profile-joined{font-size:.8rem;color:var(--text-muted);margin-top:8px;font-weight:500}.section-title{margin:32px 0 16px;font-size:.9rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:700}.profile-rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.mini-room-card{background:var(--bg-secondary);padding:18px;border-radius:var(--radius-xl);cursor:pointer;transition:all .2s;border:1px solid var(--border-subtle)}.mini-room-card:hover{transform:translateY(-2px);background:var(--bg-card-hover);border-color:var(--border)}.mini-room-topic{font-size:1.05rem;font-weight:700;margin-bottom:12px;color:var(--text-primary)}.mini-room-speakers{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--text-secondary);font-weight:500}.avatars{display:flex}.avatars img{width:26px;height:26px;border-radius:50%;border:2px solid var(--bg-secondary);margin-right:-10px;object-fit:cover}.profile-relationship{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:16px}.profile-actions{display:flex;justify-content:center}.action-btn{min-width:140px;border-radius:var(--radius-full)}.relationship-badge{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;padding:4px 12px;border-radius:var(--radius-full);letter-spacing:.02em}.relationship-badge.friends{background:#10b9811a;color:var(--success);border:1px solid rgba(16,185,129,.2)}.relationship-badge.follows-you{background:var(--accent-light);color:var(--accent);border:1px solid rgba(79,114,255,.2)}.follow-back-btn{background:var(--success)!important;border-color:var(--success)!important;box-shadow:0 2px 10px #10b98140;transition:all .2s;border-radius:var(--radius-full)!important}.follow-back-btn:hover{box-shadow:0 4px 14px #10b98166;transform:translateY(-1px);background:#0ea5e9!important}.profile-pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.mini-page-card{display:flex;align-items:center;gap:12px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:14px 16px;cursor:pointer;transition:all .2s}.mini-page-card:hover{transform:translateY(-2px);background:var(--bg-card-hover);border-color:var(--accent);box-shadow:0 4px 16px var(--shadow-color)}.mini-page-logo{width:44px;height:44px;border-radius:12px;object-fit:cover;flex-shrink:0;border:2px solid var(--border)}.mini-page-info{display:flex;flex-direction:column;min-width:0}.mini-page-name{font-size:.9rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-page-creator{font-size:.75rem;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-section{margin-top:16px}@media(max-width:768px){.profile-page{padding:calc(var(--navbar-h) + 16px) 16px 24px 16px}.profile-container{margin-top:12px}.profile-rooms-grid{grid-template-columns:1fr;gap:12px}.profile-pages-grid{grid-template-columns:1fr;gap:10px}.profile-name{font-size:1.35rem}.profile-bio{max-width:100%}}@media(max-width:480px){.profile-stats{gap:16px;padding:14px}.stat-value{font-size:1.25rem}.profile-interests{justify-content:flex-start}.mini-room-card{padding:14px}}@media(max-width:360px){.profile-page{padding:calc(var(--navbar-h) + 12px) 12px 20px 12px}.profile-name{font-size:1.2rem}.profile-handle{font-size:.82rem}.profile-stats{gap:12px;padding:10px}.stat-label{font-size:.65rem}.profile-interests{gap:6px}.interest-pill{padding:4px 10px;font-size:.72rem}}.search-page{padding-top:80px;padding-bottom:80px;min-height:100vh}.search-header{display:flex;align-items:center;gap:20px;margin-bottom:30px}.search-header h1{font-size:1.5rem;margin:0}.search-input-wrap{position:relative;margin-bottom:30px;max-width:600px;width:100%}.search-input{width:100%;padding:15px 15px 15px 45px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-size:1.1rem;outline:none;transition:box-shadow .2s}.search-input:focus{box-shadow:0 0 0 2px var(--accent)}.search-placeholder,.no-results{text-align:center;color:var(--text-secondary);margin-top:50px}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.user-card{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:15px;border-radius:15px;display:flex;align-items:center;gap:15px;cursor:pointer;transition:transform .2s,background .2s}.user-card:hover{transform:translateY(-2px);background:var(--bg-hover)}.user-card-avatar img{width:50px;height:50px;border-radius:50%;object-fit:cover;border:2px solid var(--accent)}.user-card-info h4{margin:0 0 5px;font-size:1rem;color:var(--text-primary)}.user-card-bio{margin:0;font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.create-page-modal{max-width:500px}.logo-dropzone{border:2px dashed var(--border-color);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:var(--bg-tertiary);min-height:110px;display:flex;align-items:center;justify-content:center}.logo-dropzone:hover,.logo-dropzone.drag-active{border-color:var(--primary-color);background:color-mix(in srgb,var(--primary-color) 8%,var(--bg-tertiary))}.logo-dropzone-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--text-secondary)}.logo-dropzone-placeholder .logo-icon{font-size:28px}.logo-dropzone-placeholder p{margin:0;font-size:.9rem}.logo-dropzone-placeholder small{font-size:.75rem;opacity:.6}.link-text{color:var(--primary-color);font-weight:600}.logo-preview-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}.logo-preview-img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--primary-color);box-shadow:0 4px 16px #0003}.logo-remove-btn{background:transparent;border:1px solid var(--error, #e74c3c);border-radius:6px;color:var(--error, #e74c3c);font-size:.75rem;padding:3px 10px;cursor:pointer;transition:background .15s}.logo-remove-btn:hover{background:color-mix(in srgb,var(--error, #e74c3c) 15%,transparent)}.form-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.875rem;font-weight:500;color:var(--text-primary)}.char-counter{font-size:.75rem;color:var(--text-muted);font-weight:400;transition:color .2s}.char-counter.near-limit{color:var(--warning, #f39c12);font-weight:600}.spinner-sm{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-right:6px;vertical-align:middle}.pages-page{min-height:100vh;background:var(--bg-primary)}.pages-layout{padding-top:0;padding-bottom:80px}.pages-hero{background:linear-gradient(135deg,#4f72ff26,#a855f71a);border-bottom:1px solid var(--border);padding:40px 24px 32px;margin-bottom:32px;text-align:center}.pages-hero-title{font-size:2rem;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.04em;margin-bottom:8px}.pages-hero-subtitle{color:var(--text-secondary);font-size:.95rem;max-width:480px;margin:0 auto 24px;line-height:1.6}.pages-hero-search{max-width:440px;margin:0 auto;display:flex;align-items:center;gap:10px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-full);padding:12px 20px;transition:all .2s}.pages-hero-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #4f72ff1f}.pages-hero-search .search-icon{color:var(--text-muted);flex-shrink:0}.pages-hero-search .search-input{flex:1;background:none;border:none;font-size:.95rem;color:var(--text-primary);outline:none}.pages-hero-search .search-input::placeholder{color:var(--text-muted)}.pages-tabs{display:flex;gap:8px;margin-bottom:24px;padding:0 4px}.pages-tab{background:none;border:1px solid var(--border);border-radius:var(--radius-full);padding:8px 20px;font-size:.85rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .18s}.pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.page-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);display:flex;flex-direction:column;cursor:pointer;overflow:hidden;transition:all .25s cubic-bezier(.34,1.56,.64,1);position:relative}.page-card:hover{border-color:#4f72ff66;transform:translateY(-4px);box-shadow:0 12px 32px #0000001a,0 0 0 1px #4f72ff1a}.page-card.is-member{border-color:#4f72ff4d}.page-card.is-member:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent-gradient)}.page-member-badge{position:absolute;top:12px;right:12px;font-size:.68rem;font-weight:700;color:var(--accent);background:var(--accent-light);border:1px solid rgba(79,114,255,.25);padding:2px 8px;border-radius:var(--radius-full);z-index:1}.page-card-logo-wrap{position:relative;width:100%;height:120px;overflow:hidden;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary))}.page-card-logo{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.page-card:hover .page-card-logo{transform:scale(1.06)}.page-card-logo-overlay{display:none;position:absolute;top:0;right:0;bottom:0;left:0;align-items:center;justify-content:center;font-size:3rem;opacity:.25}.page-card-body{padding:16px 18px 12px;flex:1}.page-card-title{font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;margin-bottom:6px}.page-card-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.5}.page-card-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 18px 14px;border-top:1px solid var(--border-subtle)}.page-card-creator{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-muted);font-weight:500}.creator-mini-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover}.creator-mini-fallback{width:20px;height:20px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}.page-card-join{font-size:.8rem;font-weight:700;color:var(--accent)}.pages-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;gap:14px;color:var(--text-secondary);font-size:.88rem}.pages-empty .empty-icon{font-size:4rem;margin-bottom:20px;opacity:.35}.pages-empty h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.pages-empty p{font-size:.88rem;color:var(--text-secondary)}@media(max-width:768px){.pages-hero{padding:28px 16px 24px;margin-bottom:20px}.pages-hero-title{font-size:1.5rem}.pages-hero-subtitle{font-size:.87rem}.pages-grid{grid-template-columns:1fr;gap:14px}}.page-detail-page{min-height:100vh;background:var(--bg-primary);padding-bottom:80px}.page-detail-spinner{display:flex;align-items:center;justify-content:center;min-height:100vh}.page-nav-actions{display:flex;align-items:center;gap:8px}.btn-danger{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444433;border-color:#ef4444}.page-detail-hero{position:relative;min-height:300px;display:flex;align-items:flex-end;overflow:hidden;margin-bottom:0}.page-hero-background{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;filter:blur(20px) saturate(1.5);transform:scale(1.1);background-color:var(--bg-secondary)}.page-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#00000026,#0009)}.page-hero-content{position:relative;z-index:2;display:flex;align-items:flex-end;gap:24px;padding-top:80px;padding-bottom:32px;width:100%}.page-hero-logo-wrap{position:relative;width:100px;height:100px;border-radius:24px;overflow:hidden;flex-shrink:0;border:3px solid rgba(255,255,255,.3);background:var(--bg-tertiary);box-shadow:0 8px 30px #0006}.page-hero-logo{width:100%;height:100%;object-fit:cover}.page-hero-logo-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:3rem;opacity:.4}.page-hero-info{flex:1;min-width:0}.page-hero-title{font-size:1.8rem;font-weight:900;color:#fff;letter-spacing:-.03em;text-shadow:0 2px 12px rgba(0,0,0,.4);margin-bottom:4px}.page-hero-by{font-size:.88rem;color:#ffffffbf;margin-bottom:12px}.page-hero-stats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.stat-chip{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:.78rem;font-weight:600;padding:4px 12px;border-radius:var(--radius-full)}.page-hero-actions{display:flex;gap:10px;flex-wrap:wrap}.page-section-tabs{display:flex;gap:8px;padding:20px 0 4px;border-bottom:1px solid var(--border);margin-bottom:24px;overflow-x:auto;scrollbar-width:none}.page-section-tabs::-webkit-scrollbar{display:none}.page-section-content{min-height:300px}.pages-tab{background:none;border:1px solid var(--border);border-radius:var(--radius-full);padding:8px 20px;font-size:.85rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .18s;flex-shrink:0}.pages-tab:hover{border-color:var(--accent);color:var(--text-primary)}.pages-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 3px 12px #4f72ff59}.page-rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.page-room-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:20px;display:flex;flex-direction:column;gap:14px;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.page-room-card:hover{border-color:#4f72ff66;transform:translateY(-3px);box-shadow:0 10px 28px #0000001a}.page-room-card.is-live:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#22c55e,#4ade80)}.page-room-card-top{display:flex;flex-direction:column;gap:6px}.room-card-status{display:flex;align-items:center;gap:6px}.page-room-title{font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;line-height:1.35}.page-room-speakers{display:flex;align-items:center}.page-room-speaker{width:32px;height:32px;border-radius:50%;overflow:hidden;border:2px solid var(--bg-card);margin-right:-8px;flex-shrink:0}.page-room-speaker img{width:100%;height:100%;object-fit:cover}.page-room-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border-subtle);padding-top:12px;margin-top:auto}.room-card-count{font-size:.8rem;color:var(--text-muted);font-weight:500}.room-card-join{font-size:.8rem;font-weight:700;color:var(--accent)}.page-about-section{display:flex;flex-direction:column;gap:16px}.content-section{padding:24px;display:flex;flex-direction:column;gap:12px}.content-section h3{font-size:.9rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.page-description{font-size:.95rem;color:var(--text-secondary);line-height:1.7}.creator-profile-row{display:flex;align-items:center;gap:14px;cursor:pointer;padding:12px;border-radius:12px;background:var(--bg-secondary);transition:background .2s}.creator-profile-row:hover{background:var(--bg-hover)}.creator-avatar-lg{width:48px;height:48px;border-radius:50%;object-fit:cover}.text-muted-sm{font-size:.78rem;color:var(--text-muted);margin:0}.page-members-header{margin-bottom:16px}.page-members-header h3{font-size:1rem;font-weight:700;color:var(--text-primary)}.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}.member-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.82rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s;text-align:center}.member-card:hover{border-color:#4f72ff4d;background:var(--bg-card-hover);transform:translateY(-2px)}.member-card img{width:48px;height:48px;border-radius:50%;object-fit:cover}.creator-badge{background:#6366f126;color:#818cf8;font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);border:1px solid rgba(99,102,241,.3)}.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.add-admin-form{display:flex;gap:8px;align-items:flex-start;margin-bottom:16px;flex-wrap:wrap}.admin-search-wrap{flex:1;min-width:220px;position:relative}.user-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;z-index:100;box-shadow:0 8px 24px #00000026}.user-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .15s}.user-dropdown-item:hover{background:var(--bg-hover)}.user-dropdown-item img{width:32px;height:32px;border-radius:50%;object-fit:cover}.dropdown-name{font-weight:600;font-size:.87rem;color:var(--text-primary);display:block}.dropdown-username{font-size:.75rem;color:var(--text-muted)}.user-dropdown.no-results{padding:12px 14px;color:var(--text-muted);font-size:.85rem}.admin-list{display:flex;flex-direction:column;gap:10px}.admin-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-secondary);border-radius:12px}.admin-info{display:flex;align-items:center;gap:10px;cursor:pointer;flex:1}.admin-info img{width:36px;height:36px;border-radius:50%;object-fit:cover}.btn-close{background:#ef444414;border:none;color:#ef4444;width:28px;height:28px;border-radius:8px;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-close:hover{background:#ef44442e}.page-section-empty{text-align:center;padding:60px 20px}.page-section-empty .empty-icon{font-size:3.5rem;margin-bottom:16px;opacity:.35}.page-section-empty h3{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.page-section-empty p{font-size:.88rem;color:var(--text-secondary)}.pages-empty{text-align:center;padding:80px 20px}.pages-empty .empty-icon{font-size:3.5rem;opacity:.35;margin-bottom:16px}.text-muted{color:var(--text-muted);font-size:.88rem}.spinner-sm{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@media(max-width:768px){.page-detail-hero{min-height:260px}.page-hero-content{flex-direction:column;align-items:flex-start;gap:16px;padding-bottom:24px}.page-hero-logo-wrap{width:76px;height:76px;border-radius:18px}.page-hero-title{font-size:1.4rem}.page-rooms-grid{grid-template-columns:1fr}.members-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}.page-nav-actions .btn-sm{padding:5px 10px;font-size:.75rem}}.dm-inbox{min-height:100vh;background:var(--bg-primary);max-width:600px;margin:0 auto;display:flex;flex-direction:column;border-left:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle)}.dm-inbox-header{display:flex;align-items:center;gap:14px;padding:20px;border-bottom:1px solid var(--border);background:var(--bg-secondary);position:sticky;top:0;z-index:10}.dm-inbox-title{font-size:1.25rem;font-weight:800;color:var(--text-primary);margin:0;letter-spacing:-.01em}.dm-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.dm-tab{flex:1;padding:14px;background:transparent;border:none;font-size:.95rem;font-weight:700;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.dm-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.dm-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:transparent}.dm-tab-badge{background:var(--accent);color:#fff;font-size:.75rem;font-weight:800;padding:2px 8px;border-radius:var(--radius-full);min-width:20px;text-align:center;box-shadow:0 2px 8px #4f72ff40}.dm-conversation-list{flex:1;overflow-y:auto;background:var(--bg-primary)}.dm-conv-item{display:flex;align-items:center;gap:16px;padding:16px 20px;cursor:pointer;transition:all .2s;border-bottom:1px solid var(--border-subtle)}.dm-conv-item:hover{background:var(--bg-card-hover)}.dm-conv-item.unread .dm-conv-name{font-weight:800;color:var(--text-primary)}.dm-conv-item.unread .dm-conv-preview{color:var(--text-primary);font-weight:600}.dm-conv-avatar-wrap{position:relative;flex-shrink:0}.dm-conv-avatar{width:52px;height:52px;border-radius:var(--radius-xl);object-fit:cover;background:var(--bg-tertiary);border:1px solid var(--border-subtle)}.dm-unread-dot{position:absolute;top:-4px;right:-4px;background:var(--accent);color:#fff;font-size:.7rem;font-weight:800;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;border:2px solid var(--bg-primary);box-shadow:0 2px 6px #0003}.dm-conv-info{flex:1;min-width:0}.dm-conv-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.dm-conv-name{font-size:1rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dm-conv-time{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;margin-left:8px;font-weight:500}.dm-conv-preview{font-size:.9rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.dm-you{font-weight:600;color:var(--text-muted)}.dm-empty{text-align:center;color:var(--text-secondary);padding:80px 20px;font-size:.95rem;display:flex;flex-direction:column;align-items:center;gap:12px}@media(max-width:480px){.dm-inbox{border-left:none;border-right:none}.dm-inbox-header{padding:14px 16px}.dm-inbox-title{font-size:1.1rem}.dm-conv-item{padding:14px 16px;gap:12px}.dm-conv-avatar{width:44px;height:44px}}@media(max-width:360px){.dm-inbox-header{padding:10px 12px}.dm-inbox-title{font-size:1rem}.dm-conv-item{padding:10px 12px;gap:10px}.dm-conv-avatar{width:38px;height:38px}.dm-conv-name{font-size:.88rem}.dm-conv-last-msg{font-size:.75rem}}.dm-chat{display:flex;flex-direction:column;height:100dvh;max-width:600px;margin:0 auto;background:var(--bg-primary);position:relative;border-left:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle)}.dm-chat-header{display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1px solid var(--border);background:#0e1118d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:10}.dm-back-btn{background:var(--bg-tertiary);border:none;color:var(--text-secondary);cursor:pointer;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.dm-back-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.dm-chat-avatar{width:44px;height:44px;border-radius:var(--radius-xl);object-fit:cover;background:var(--bg-tertiary);border:1px solid var(--border-subtle)}.dm-chat-info{display:flex;flex-direction:column}.dm-chat-name{font-size:1.05rem;font-weight:800;color:var(--text-primary);letter-spacing:-.01em}.dm-chat-handle{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.dm-msg-list{flex:1;overflow-y:auto;padding:24px 16px 16px;display:flex;flex-direction:column;gap:4px;background:var(--bg-primary)}.dm-chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary);text-align:center;padding:40px 20px}.dm-chat-empty-avatar{width:80px;height:80px;border-radius:var(--radius-2xl);object-fit:cover;opacity:.8}.dm-date-separator{display:flex;align-items:center;justify-content:center;margin:24px 0 16px;position:relative}.dm-date-separator:before,.dm-date-separator:after{content:"";flex:1;height:1px;background:var(--border-subtle);margin:0 16px}.dm-date-separator span{font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--bg-primary);padding:4px 12px;border-radius:var(--radius-full);border:1px solid var(--border-subtle);white-space:nowrap}.dm-msg-row{display:flex;align-items:flex-end;gap:10px;margin-bottom:6px}.dm-msg-row.from-me{flex-direction:row-reverse}.dm-msg-row.from-them{flex-direction:row}.dm-msg-avatar{width:32px;height:32px;border-radius:10px;object-fit:cover;flex-shrink:0;border:1px solid var(--border-subtle)}.dm-msg-col{display:flex;flex-direction:column;max-width:75%}.dm-msg-row.from-me .dm-msg-col{align-items:flex-end}.dm-msg-row.from-them .dm-msg-col{align-items:flex-start}.dm-bubble{padding:12px 16px;border-radius:20px;font-size:.95rem;line-height:1.5;word-break:break-word;white-space:pre-wrap;box-shadow:var(--shadow-sm)}.dm-bubble.mine{background:var(--accent);color:#fff;border-bottom-right-radius:6px;box-shadow:0 4px 12px #4f72ff26}.dm-bubble.theirs{background:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:6px;border:1px solid var(--border-subtle)}.dm-msg-meta{display:flex;align-items:center;gap:6px;margin-top:4px}.dm-msg-time{font-size:.72rem;color:var(--text-secondary);font-weight:500}.dm-seen-status{font-size:.72rem;color:var(--accent);font-weight:700}.dm-input-bar{display:flex;align-items:center;gap:12px;padding:16px 20px;border-top:1px solid var(--border);background:var(--bg-secondary);position:sticky;bottom:0}.dm-emoji-toggle{background:transparent;border:none;font-size:1.4rem;cursor:pointer;padding:6px;border-radius:10px;transition:all .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center}.dm-emoji-toggle:hover{background:var(--bg-tertiary);transform:scale(1.05)}.dm-text-input{flex:1;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-2xl);padding:12px 20px;color:var(--text-primary);font-size:.95rem;outline:none;transition:all .2s;resize:none;line-height:1.5}.dm-text-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4f72ff26}.dm-text-input::placeholder{color:var(--text-muted)}.dm-send-btn{background:var(--bg-tertiary);border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:all .2s}.dm-send-btn.active{background:var(--accent);color:#fff;box-shadow:0 4px 12px #4f72ff40}.dm-send-btn.active:hover{transform:translateY(-1px);background:var(--accent-hover)}.dm-send-btn:disabled{opacity:.4;cursor:not-allowed}.emoji-picker{position:absolute;bottom:80px;left:16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:12px;display:grid;grid-template-columns:repeat(8,1fr);gap:6px;box-shadow:var(--shadow-lg);z-index:100;max-width:320px;animation:slideUp .2s ease}.emoji-btn{background:transparent;border:none;font-size:1.4rem;cursor:pointer;padding:6px;border-radius:8px;transition:all .15s;line-height:1;display:flex;align-items:center;justify-content:center}.emoji-btn:hover{background:var(--bg-hover);transform:scale(1.15)}@media(max-width:480px){.dm-chat-header{padding:12px 16px;gap:12px}.dm-msg-list{padding:16px 12px 12px}.dm-input-bar{padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom));gap:8px}.dm-msg-col{max-width:88%}.emoji-picker{grid-template-columns:repeat(6,1fr);max-width:calc(100vw - 32px);left:8px}.dm-text-input{padding:10px 14px;font-size:.9rem}}@media(max-width:360px){.dm-chat-header{padding:8px 12px;gap:8px}.dm-chat-name{font-size:.95rem}.dm-input-bar{padding:8px 10px;gap:6px}.dm-text-input{padding:8px 12px;font-size:.85rem}.dm-chat-avatar{width:34px;height:34px}.dm-bubble{padding:8px 12px;font-size:.88rem}}body{margin:0;font-family:Inter,-apple-system,sans-serif;background-color:#0d0f1a;color:#e2e8f0}.landing-container{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;position:relative;background:radial-gradient(circle at top left,rgba(67,56,202,.15) 0%,transparent 40%),radial-gradient(circle at bottom right,rgba(217,70,239,.15) 0%,transparent 40%)}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:24px 8%;position:relative;z-index:10}.landing-logo{font-size:1.5rem;font-weight:800;color:#fff;display:flex;align-items:center;gap:8px;letter-spacing:-.02em}.landing-nav-actions{display:flex;gap:16px}.btn-login-outline{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.2);padding:10px 20px;border-radius:99px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-login-outline:hover{background:#ffffff1a;border-color:#fff6}.btn-signup-solid{background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border:none;padding:10px 24px;border-radius:99px;font-weight:600;cursor:pointer;box-shadow:0 4px 14px #6366f166;transition:transform .2s ease,box-shadow .2s ease}.btn-signup-solid:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f199}.landing-hero{flex:1;display:flex;align-items:center;justify-content:space-between;padding:0 8%;gap:60px;position:relative;z-index:2}.hero-content{flex:1;max-width:600px;animation:fadeUp .8s ease-out forwards}.hero-badge{display:inline-block;background:#6366f11a;color:#818cf8;border:1px solid rgba(99,102,241,.2);padding:6px 16px;border-radius:99px;font-size:.875rem;font-weight:600;margin-bottom:24px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hero-title{font-size:4.5rem;line-height:1.1;font-weight:800;margin:0 0 24px;color:#f8fafc;letter-spacing:-.03em}.gradient-text{background:linear-gradient(135deg,#818cf8,#d946ef);-webkit-background-clip:text;-webkit-text-fill-color:transparent;display:inline-block}.hero-subtitle{font-size:1.125rem;line-height:1.6;color:#94a3b8;margin-bottom:40px;max-width:500px}.hero-install-section{display:flex;flex-direction:column;gap:12px;align-items:flex-start}.install-main-btn{display:flex;flex-direction:column;align-items:flex-start;gap:4px;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border:none;padding:16px 32px;border-radius:14px;cursor:pointer;font-family:inherit;box-shadow:0 8px 24px #6366f173;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:220px;position:relative;overflow:hidden}.install-main-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);opacity:0;transition:opacity .3s}.install-main-btn:hover:before{opacity:1}.install-main-btn:hover{transform:translateY(-3px);box-shadow:0 12px 30px #6366f199}.install-main-btn:active{transform:translateY(0)}.install-main-btn.installed{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 8px 24px #10b98166}.install-main-btn.loading{opacity:.8;cursor:wait}.install-main-btn:disabled{cursor:not-allowed}.install-btn-label{font-size:1.05rem;font-weight:700;letter-spacing:-.01em}.install-btn-sub{font-size:.78rem;opacity:.75;font-weight:400}.install-alt-options{display:flex;gap:10px}.install-alt-btn{display:flex;align-items:center;gap:8px;background:#ffffff0d;color:#94a3b8;border:1px solid rgba(255,255,255,.1);padding:10px 18px;border-radius:10px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.install-alt-btn:hover{background:#ffffff1a;color:#e2e8f0;border-color:#fff3}.hero-browser-fallback{margin-top:20px;font-size:.95rem}.hero-browser-fallback span{color:#818cf8;cursor:pointer;font-weight:500;transition:color .2s}.hero-browser-fallback span:hover{color:#a855f7;text-decoration:underline}.hero-visual{flex:1;position:relative;height:500px;display:flex;align-items:center;justify-content:center;perspective:1000px}.visual-circle{position:absolute;border-radius:50%;border:1px solid rgba(99,102,241,.2);animation:pulse 4s cubic-bezier(.4,0,.6,1) infinite}.circle-1{width:300px;height:300px}.circle-2{width:450px;height:450px;animation-delay:1.2s;border-color:#d946ef1a}.circle-3{width:600px;height:600px;animation-delay:2.4s}.avatar-float{position:absolute;font-size:3rem;background:#ffffff1a;padding:16px;border-radius:50%;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #0003;border:1px solid rgba(255,255,255,.1);animation:float 6s ease-in-out infinite}.avatar-1{top:10%;right:20%;animation-delay:0s}.avatar-2{bottom:20%;right:10%;animation-delay:2s;font-size:4rem}.avatar-3{top:40%;left:10%;animation-delay:4s}.wave-container{display:flex;gap:8px;align-items:center;z-index:5;background:#0f172a99;padding:20px 30px;border-radius:99px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05)}.wave{width:6px;height:30px;background:linear-gradient(to top,#6366f1,#d946ef);border-radius:4px;animation:soundwave 1s ease-in-out infinite alternate}.wave:nth-child(1){height:20px;animation-delay:0s}.wave:nth-child(2){height:40px;animation-delay:.2s}.wave:nth-child(3){height:60px;animation-delay:.4s}.wave:nth-child(4){height:35px;animation-delay:.6s}.wave:nth-child(5){height:25px;animation-delay:.8s}.install-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .25s ease;padding:16px}.install-modal-content{background:#1e293b;border-radius:24px;padding:36px;width:100%;max-width:420px;position:relative;border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 60px #0009;animation:scaleIn .25s ease}.modal-icon{font-size:2.5rem;margin-bottom:12px}.install-modal-content h2{margin:0 0 8px;color:#f1f5f9;font-size:1.4rem;font-weight:700}.install-modal-content p{color:#94a3b8;line-height:1.5;margin-bottom:24px;font-size:.95rem}.modal-close-btn{position:absolute;top:20px;right:20px;background:#ffffff14;border:none;color:#94a3b8;font-size:1rem;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close-btn:hover{background:#ffffff26;color:#f1f5f9}.install-steps{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}.install-step{display:flex;align-items:flex-start;gap:14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);padding:14px 16px;border-radius:12px}.step-num{width:28px;height:28px;min-width:28px;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.step-body{font-size:.92rem;color:#cbd5e1;line-height:1.5;padding-top:2px}.step-icon{font-style:normal;background:#6366f126;padding:1px 6px;border-radius:4px;font-size:.8rem}.modal-cta-btn{width:100%;padding:14px;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.modal-cta-btn:hover{opacity:.9;transform:translateY(-1px)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.05)}}@keyframes soundwave{0%{transform:scaleY(.5)}to{transform:scaleY(1.2)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:900px){.landing-hero{flex-direction:column-reverse;padding:40px 6%;gap:40px;text-align:center}.hero-content{display:flex;flex-direction:column;align-items:center}.hero-install-section{align-items:center;width:100%}.install-main-btn{width:100%;max-width:320px;align-items:center}.install-alt-options{justify-content:center}.hero-title{font-size:3rem}.hero-visual{height:300px;width:100%}.circle-1{width:200px;height:200px}.circle-2{width:300px;height:300px}.circle-3{width:400px;height:400px}.avatar-float{font-size:2rem;padding:12px}}.install-prompt{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:1000;animation:slideUp .3s ease}.install-prompt-content{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:16px 20px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:16px;max-width:400px}.install-prompt-icon{font-size:2rem}.install-prompt-text h3{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary)}.install-prompt-text p{margin:4px 0 0;font-size:.85rem;color:var(--text-secondary)}.install-prompt-actions{display:flex;gap:12px;align-items:center}.install-btn{background:var(--accent);color:#fff;border:none;padding:8px 20px;border-radius:20px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.install-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.dismiss-btn{background:transparent;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.dismiss-btn:hover{background:var(--bg-secondary)}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:480px){.install-prompt{left:16px;right:16px;transform:none;bottom:90px}.install-prompt-content{max-width:100%}}.bottom-nav{display:none;position:fixed;bottom:0;left:0;width:100%;z-index:990;height:65px;padding-bottom:max(10px,env(safe-area-inset-bottom));flex-direction:row;align-items:center;justify-content:space-around;border-top:1px solid var(--border);background:var(--bg-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 -2px 10px #0000001a}.nav-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:transparent;color:var(--text-muted);flex:1;height:100%;padding-top:6px;transition:all .2s ease}.nav-icon{font-size:1.3rem;transition:transform .2s;filter:grayscale(100%) opacity(.6)}.nav-label{font-size:.7rem;font-weight:500}.nav-tab:active .nav-icon{transform:scale(.9)}.nav-tab.active{color:var(--accent)}.nav-tab.active .nav-icon{filter:grayscale(0%) opacity(1)}@media(max-width:480px){.bottom-nav{display:flex}}.nav-badge{position:absolute;top:-5px;right:-8px;background:#ef4444;color:#fff;font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:99px;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1;border:1.5px solid var(--bg-primary, #1a1a2e)}.ludo-container{position:relative;background:#fff;border-radius:20px;padding:14px 14px 10px;margin:0 auto;border:1px solid rgba(0,0,0,.08);box-shadow:0 10px 30px #00000014,0 1px 3px #0000000d;color:#1e293b;max-width:1000px;width:100%;box-sizing:border-box;display:flex;flex-direction:column;gap:10px;font-family:Inter,-apple-system,sans-serif}.ludo-header{display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid rgba(0,0,0,.06)}.ludo-header-left{display:flex;align-items:center;gap:6px;flex-shrink:0}.ludo-crown{font-size:1.2rem}.ludo-title{font-size:1.1rem;font-weight:800;color:#0f172a;letter-spacing:-.01em;white-space:nowrap}.ludo-status-msg{font-size:.85rem;color:#475569;flex:1;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 6px;font-weight:500}.ludo-header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.ludo-leave-btn,.ludo-end-btn{font-family:inherit;font-size:.8rem;font-weight:600;border:none;border-radius:8px;padding:6px 12px;cursor:pointer;transition:all .2s;white-space:nowrap}.ludo-leave-btn{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.ludo-leave-btn:hover{background:#e2e8f0;color:#0f172a}.ludo-end-btn{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.ludo-end-btn:hover{background:#fee2e2;color:#b91c1c}.ludo-auto-toast{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid;border-radius:10px;padding:8px 12px;cursor:pointer;animation:toastSlideIn .3s ease;font-size:.85rem;box-shadow:0 4px 15px #0000001a}.ludo-auto-toast-msg{flex:1;color:#1e293b;font-weight:600}.ludo-auto-toast-close{color:#94a3b8;font-size:1.1rem}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ludo-winners-bar{display:flex;gap:6px;flex-wrap:wrap;padding:6px 0;border-bottom:1px solid rgba(0,0,0,.06)}.winner-chip{display:inline-flex;align-items:center;gap:4px;font-size:.8rem;font-weight:700;padding:5px 12px;border-radius:20px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.ludo-lobby{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 0}.lobby-title{font-size:1.3rem;font-weight:800;color:#0f172a;letter-spacing:-.02em}.lobby-sub{font-size:.9rem;color:#64748b;margin:-8px 0 0;text-align:center}.ludo-color-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:100%;max-width:450px}.color-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 10px;border-radius:16px;border:2px solid #e2e8f0;background:#f8fafc;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.color-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--btn-color);opacity:.05;transition:opacity .2s}.color-btn:hover:not(:disabled):before{opacity:.1}.color-btn:hover:not(:disabled){border-color:var(--btn-color);transform:translateY(-2px);box-shadow:0 8px 15px #0000000d}.color-btn.selected{border-color:var(--btn-color);background:#fff;box-shadow:0 0 0 3px var(--btn-glow);transform:scale(1.02)}.color-btn.taken{opacity:.6;cursor:not-allowed;background:#e2e8f0}.color-btn:disabled{cursor:not-allowed}.color-btn-swatch{display:block;width:32px;height:32px;border-radius:50%;background:var(--btn-color);box-shadow:0 2px 8px var(--btn-glow)}.color-btn-label{font-size:.9rem;font-weight:700;color:#334155;text-transform:capitalize;position:relative;z-index:1}.color-btn-you,.color-btn-taken{display:block;font-size:.7rem;font-weight:800;padding:2px 8px;border-radius:6px;position:relative;z-index:1}.color-btn-you{background:var(--btn-color);color:#fff}.color-btn-taken{background:#cbd5e1;color:#475569}.start-game-btn{background:#0f172a;color:#fff;border:none;padding:16px 48px;border-radius:99px;font-size:1.1rem;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 4px 15px #00000026;transition:all .25s;letter-spacing:.02em;margin-top:10px}.start-game-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #0003}.start-game-btn:disabled{opacity:.4;cursor:not-allowed}.lobby-waiting{font-size:.9rem;color:#64748b;margin:0;text-align:center;font-weight:500}.ludo-requests-panel{width:100%;max-width:450px;background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:16px;padding:14px 16px;box-sizing:border-box}.ludo-requests-title{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:800;color:#166534;margin-bottom:12px}.ludo-requests-badge{background:#16a34a;color:#fff;font-size:.72rem;font-weight:800;padding:2px 8px;border-radius:99px;min-width:20px;text-align:center}.ludo-requests-list{display:flex;flex-direction:column;gap:8px}.ludo-req-card{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #d1fae5;border-radius:12px;padding:10px 12px;transition:box-shadow .2s}.ludo-req-card:hover{box-shadow:0 4px 12px #16a34a1f}.ludo-req-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid #d1fae5;flex-shrink:0}.ludo-req-info{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}.ludo-req-name{font-size:.9rem;font-weight:700;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ludo-req-color{display:inline-block;font-size:.68rem;font-weight:800;padding:2px 8px;border-radius:6px;color:#fff;text-transform:capitalize;letter-spacing:.04em;text-shadow:0 1px 2px rgba(0,0,0,.2);align-self:flex-start}.ludo-req-actions{display:flex;gap:6px;flex-shrink:0}.ludo-req-btn{font-family:inherit;font-size:1rem;font-weight:800;width:34px;height:34px;border-radius:10px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.ludo-req-btn.approve{background:#dcfce7;color:#16a34a;border:1.5px solid #86efac}.ludo-req-btn.approve:hover{background:#16a34a;color:#fff;transform:scale(1.1)}.ludo-req-btn.deny{background:#fef2f2;color:#dc2626;border:1.5px solid #fca5a5}.ludo-req-btn.deny:hover{background:#dc2626;color:#fff;transform:scale(1.1)}.ludo-active-board{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.ludo-controls{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:14px 20px;box-sizing:border-box;box-shadow:0 2px 8px #00000008}.turn-info{display:flex;align-items:center;gap:12px;min-width:0}.turn-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0;border:2px solid #ffffff;box-shadow:0 0 10px #0000001a;animation:pulseDot 1.2s ease-in-out infinite}@keyframes pulseDot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.9}}.turn-text{display:flex;flex-direction:column;gap:2px;min-width:0}.turn-label{font-size:.95rem;font-weight:800;color:#0f172a;white-space:nowrap}.sixes-badge{font-size:.75rem;color:#ea580c;font-weight:700}.ludo-timer-wrap{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;max-width:200px}.timer-secs{font-size:1.25rem;font-weight:800;color:#334155;letter-spacing:-.02em;transition:color .3s}.timer-secs.urgent{color:#dc2626;animation:timerBlink .5s infinite alternate}@keyframes timerBlink{0%{opacity:1}to{opacity:.6}}.ludo-timer-bar-track{width:100%;height:8px;background:#e2e8f0;border-radius:99px;overflow:hidden}.ludo-timer-bar-fill{height:100%;border-radius:99px;transition:width .9s linear}.ludo-timer-bar-fill.low{animation:timerPulse .5s infinite alternate}@keyframes timerPulse{0%{opacity:1}to{opacity:.7}}.dice-wrap{flex-shrink:0;cursor:default;-webkit-user-select:none;user-select:none}.dice-wrap.rollable{cursor:pointer}.dice-face{border-radius:14px;overflow:hidden;box-shadow:0 4px 15px #00000026;transition:transform .15s;background:#fff}.dice-face.rolled{animation:diceSettle .3s ease-out}.dice-wrap.rollable .dice-face:hover{transform:scale(1.08)}.dice-face.rolling{animation:spinDice .12s linear infinite}@keyframes spinDice{0%{transform:rotateX(0) rotateY(0) scale(1)}50%{transform:rotateX(180deg) rotateY(90deg) scale(.95)}to{transform:rotateX(360deg) rotateY(180deg) scale(1)}}@keyframes diceSettle{0%{transform:scale(1.2) rotate(-5deg)}60%{transform:scale(.92) rotate(3deg)}to{transform:scale(1) rotate(0)}}.dice-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;width:60px;height:60px;border-radius:14px;background:#f1f5f9;border:2px solid #cbd5e1;gap:2px;transition:all .2s}.dice-btn.ready{background:#0f172a;border-color:#0f172a;box-shadow:0 4px 15px #0003;cursor:pointer;animation:diceReady 1.5s ease-in-out infinite}@keyframes diceReady{0%,to{box-shadow:0 4px 15px #0003;transform:scale(1)}50%{box-shadow:0 8px 25px #0000004d;transform:scale(1.05)}}.dice-btn-icon{font-size:1.4rem}.dice-btn-text{font-size:.65rem;font-weight:800;color:#64748b;letter-spacing:.05em}.dice-btn.ready .dice-btn-text{color:#fff}.ludo-svg-wrapper{width:100%;max-width:900px;aspect-ratio:1 / 1;position:relative;border-radius:5px;box-shadow:0 10px 40px #00000014;overflow:hidden;background:#f8fafc}.ludo-svg{width:100%;height:100%;display:block}.ludo-token-svg{transition:transform .23s ease-out}.clickable-token{cursor:pointer}.pawn-glow{animation:pawnBounceGlow .7s ease-in-out infinite alternate}@keyframes pawnBounceGlow{0%{filter:drop-shadow(0 0 4px rgba(255,255,255,.4));transform:translateY(0)}to{filter:drop-shadow(0 0 10px rgba(255,255,255,.8));transform:translateY(-5px)}}.profile-glow{animation:profilePulse 1.2s ease-in-out infinite}@keyframes profilePulse{0%,to{r:44;opacity:.7;stroke-width:4}50%{r:48;opacity:1;stroke-width:7}}.player-strip{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;width:100%;padding:6px 0}.player-chip{display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:20px;padding:6px 14px 6px 10px;font-size:.85rem;transition:all .25s;box-shadow:0 2px 5px #00000005}.player-chip.active{background:#fff;border-width:2px;border-color:var(--chip-color);box-shadow:0 4px 15px var(--chip-glow);transform:translateY(-2px)}.player-chip.dq{opacity:.5;background:#e2e8f0}.player-chip.winner{background:#fffbeb;border-color:#fbbf24}.chip-dot{width:12px;height:12px;border-radius:50%;background:var(--chip-color);box-shadow:inset 0 0 0 2px #ffffff4d;flex-shrink:0}.chip-name{color:#1e293b;font-weight:700;white-space:nowrap}.chip-home{font-size:.75rem;color:#64748b;font-weight:600}.chip-badge{font-size:.7rem;font-weight:800;padding:2px 8px;border-radius:6px;margin-left:4px}.dq-badge{background:#fee2e2;color:#dc2626}.win-badge{background:#fef3c7;color:#d97706}.ludo-confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;border-radius:20px;animation:fadeIn .2s ease}.ludo-confirm-box{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:32px 24px;max-width:320px;width:90%;text-align:center;box-shadow:0 20px 40px #00000026;animation:scaleIn .2s cubic-bezier(.34,1.56,.64,1)}.ludo-confirm-icon{font-size:2.8rem;margin-bottom:12px}.ludo-confirm-box h3{margin:0 0 10px;color:#0f172a;font-size:1.2rem;font-weight:800}.ludo-confirm-box p{color:#475569;font-size:.95rem;line-height:1.5;margin-bottom:24px}.ludo-confirm-actions{display:flex;gap:12px;justify-content:center}.ludo-confirm-yes,.ludo-confirm-no{font-family:inherit;font-size:.95rem;font-weight:700;border:none;border-radius:10px;padding:12px 20px;cursor:pointer;flex:1;transition:all .2s}.ludo-confirm-yes{background:#dc2626;color:#fff;box-shadow:0 4px 12px #dc262633}.ludo-confirm-yes:hover{background:#b91c1c;transform:translateY(-1px)}.ludo-confirm-no{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.ludo-confirm-no:hover{background:#e2e8f0;color:#1e293b}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.room-container.playing-ludo{display:flex;flex-direction:column;gap:12px;max-width:1200px!important}@media(max-width:600px){.ludo-container{padding:12px 10px 10px;border-radius:16px;gap:8px}.ludo-title{font-size:1rem}.ludo-status-msg{display:none}.ludo-controls{padding:12px 14px;gap:8px}.turn-label{font-size:.85rem}.ludo-timer-wrap{max-width:120px}.timer-secs{font-size:1rem}.dice-btn{width:52px;height:52px;border-radius:12px}.dice-btn-icon{font-size:1.2rem}.dice-face svg{width:44px!important;height:44px!important}.ludo-svg-wrapper{border-radius:8px}.ludo-color-selector{grid-template-columns:repeat(2,1fr);max-width:320px}.color-btn{padding:12px 8px}.player-strip{gap:6px}.player-chip{padding:5px 10px 5px 8px;font-size:.8rem}.chip-dot{width:10px;height:10px}.ludo-confirm-box{padding:24px 20px}.ludo-leave-btn,.ludo-end-btn{padding:6px 10px;font-size:.75rem}}@media(max-width:380px){.ludo-controls{flex-wrap:wrap}.ludo-timer-wrap{order:3;max-width:100%;width:100%;margin-top:8px}.ludo-color-selector{grid-template-columns:repeat(2,1fr)}}.pawn-highlight-ring{animation:pawnRingPulse .9s ease-in-out infinite;transform-origin:center}@keyframes pawnRingPulse{0%{opacity:1;stroke-width:3}50%{opacity:.3;stroke-width:2}to{opacity:1;stroke-width:3}}.pawn-glow{filter:drop-shadow(0 0 6px currentColor)}.ludo-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;flex-direction:column;background:radial-gradient(ellipse at 20% 0%,#1a0533,#0d1117 60%,#0a0f1e);color:#f1f5f9;font-family:Outfit,sans-serif;overflow:hidden}.ludo-page-topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;padding-top:max(14px,env(safe-area-inset-top));background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.ludo-back-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#f1f5f9;padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:70px}.ludo-back-btn:active{transform:scale(.95);background:#ffffff24}.ludo-page-title{display:flex;align-items:center;gap:6px;font-size:1.2rem;font-weight:800;background:linear-gradient(135deg,#fbbf24,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.5px}.ludo-page-room{font-size:.78rem;color:#fff6;font-weight:600;min-width:70px;text-align:right}.ludo-page-toast{position:absolute;top:72px;left:50%;transform:translate(-50%);background:#1e293b;border:1px solid rgba(255,255,255,.12);color:#f1f5f9;padding:10px 20px;border-radius:30px;font-size:.9rem;font-weight:600;white-space:nowrap;z-index:100;animation:ludo-toast-in .3s ease both;box-shadow:0 8px 30px #0006;pointer-events:none}.ludo-page-toast.success{border-color:#22c55e;color:#86efac}.ludo-page-toast.error{border-color:#f43f5e;color:#fca5a5}.ludo-page-toast.info{border-color:#6366f1;color:#a5b4fc}@keyframes ludo-toast-in{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.ludo-no-game{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px;text-align:center}.ludo-no-game-icon{font-size:5rem;animation:ludo-bounce 2s ease-in-out infinite}@keyframes ludo-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.ludo-no-game h2{font-size:1.8rem;font-weight:800;margin:0}.ludo-no-game p{font-size:1rem;color:#ffffff80;margin:0;max-width:280px}.ludo-create-btn{margin-top:8px;padding:16px 36px;background:linear-gradient(135deg,#7c3aed,#a855f7);border:none;border-radius:50px;color:#fff;font-size:1.1rem;font-weight:700;cursor:pointer;box-shadow:0 8px 24px #7c3aed80;transition:all .2s}.ludo-create-btn:active{transform:scale(.96)}.ludo-board-wrap{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.ludo-board-wrap .ludo-container{flex:1;min-height:0;height:100%;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}.ludo-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:3100;display:flex;align-items:flex-end;justify-content:center;padding-bottom:env(safe-area-inset-bottom)}.ludo-modal{background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:28px 28px 0 0;padding:28px 24px 40px;width:100%;max-width:480px;animation:ludo-modal-up .35s cubic-bezier(.16,1,.3,1) both}.ludo-modal:before{content:"";display:block;width:40px;height:4px;background:#fff3;border-radius:2px;margin:0 auto 20px}@keyframes ludo-modal-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.ludo-modal-title{font-size:1.4rem;font-weight:800;text-align:center;margin:0 0 6px}.ludo-modal-sub{text-align:center;color:#ffffff80;font-size:.95rem;margin:0 0 20px}.ludo-player-btns{display:flex;gap:10px;justify-content:center;margin-bottom:16px}.ludo-count-btn{width:52px;height:52px;border-radius:50%;border:2px solid rgba(255,255,255,.15);background:#ffffff0f;color:#94a3b8;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:Outfit,sans-serif}.ludo-count-btn.active{background:#7c3aed;border-color:#a855f7;color:#fff;box-shadow:0 0 16px #7c3aed80;transform:scale(1.12)}.ludo-modal-info{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 16px;font-size:.88rem;color:#fff9;text-align:center;margin-bottom:24px}.ludo-modal-actions{display:flex;gap:12px}.ludo-modal-cancel{flex:1;padding:14px;border-radius:14px;border:1px solid rgba(255,255,255,.15);background:#ffffff0f;color:#94a3b8;font-size:1rem;font-weight:600;cursor:pointer;font-family:Outfit,sans-serif}.ludo-modal-create{flex:2;padding:14px;border-radius:14px;border:none;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 6px 20px #7c3aed66;transition:all .2s;font-family:Outfit,sans-serif}.ludo-modal-create:active{transform:scale(.97)}@media(max-width:480px){.ludo-page-topbar{padding:12px 14px;padding-top:max(12px,env(safe-area-inset-top))}.ludo-page-title{font-size:1.05rem}.ludo-modal{padding:20px 16px 32px}.ludo-count-btn{width:46px;height:46px;font-size:1.05rem}}:root{--bg-primary: #0e1118;--bg-secondary: #161b27;--bg-card: #1c2333;--bg-card-hover: #212b3c;--bg-input: #1a2030;--bg-glass: rgba(22, 27, 39, .85);--bg-glass-strong: rgba(22, 27, 39, .96);--bg-overlay: rgba(7, 9, 14, .7);--bg-hover: rgba(99, 130, 255, .08);--bg-tertiary: #232c3e;--accent: #4f72ff;--accent-hover: #6385ff;--accent-light: rgba(79, 114, 255, .14);--accent-gradient: linear-gradient(135deg, #4f72ff 0%, #7b9fff 100%);--accent-gradient-subtle: linear-gradient(135deg, rgba(79, 114, 255, .18), rgba(123, 159, 255, .1));--text-primary: #e8edf5;--text-secondary: #8892a4;--text-muted: #5a6475;--text-accent: #7b9fff;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--danger-hover: #dc2626;--online: #10b981;--border: rgba(255, 255, 255, .07);--border-light: rgba(255, 255, 255, .11);--border-subtle: rgba(255, 255, 255, .04);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--shadow-sm: 0 1px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .45);--shadow-glow: 0 0 24px rgba(79, 114, 255, .2);--shadow-card: 0 2px 12px rgba(0, 0, 0, .4);--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--navbar-h: 64px}body.light-mode{--bg-primary: #f4f6fb;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #f0f4ff;--bg-input: #ffffff;--bg-glass: rgba(255, 255, 255, .88);--bg-glass-strong: rgba(255, 255, 255, .97);--bg-overlay: rgba(0, 0, 0, .4);--bg-hover: rgba(79, 114, 255, .06);--bg-tertiary: #eef1f8;--text-primary: #0d1117;--text-secondary: #5a6475;--text-muted: #9aa3b0;--border: rgba(0, 0, 0, .08);--border-light: rgba(0, 0, 0, .12);--border-subtle: rgba(0, 0, 0, .04);--shadow-card: 0 1px 6px rgba(0, 0, 0, .08)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden;width:100%}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;width:100%;position:relative}#root{min-height:100dvh;width:100%;overflow-x:hidden}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;outline:none;font-family:var(--font)}input,textarea{border:none;outline:none;font-family:var(--font)}img{max-width:100%;display:block}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:var(--radius-full)}.glass{background:var(--bg-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:var(--radius-lg)}.glass-strong{background:var(--bg-glass-strong);backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);border:1px solid var(--border-light);border-radius:var(--radius-lg)}.gradient-text{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 24px;border-radius:var(--radius-full);font-size:.9rem;font-weight:600;transition:all .2s ease;letter-spacing:.01em;white-space:nowrap}.btn-sm{padding:7px 14px;font-size:.82rem}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 12px #4f72ff59}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 20px #4f72ff73}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--accent);color:var(--accent)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full);font-size:1.1rem}.back-btn{background:var(--bg-tertiary);color:var(--text-secondary);border:none;border-radius:var(--radius-full);padding:8px 18px;font-size:.9rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;margin-bottom:24px;transition:all .2s;align-self:flex-start}.back-btn:hover{background:var(--bg-hover);color:var(--text-primary);transform:translate(-3px)}.input{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;transition:all .2s ease}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4f72ff1f}.input::placeholder{color:var(--text-muted)}.page-center{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:20px;position:relative;z-index:1}.rooms-page{position:absolute;top:0;bottom:0;left:0;right:0;background:var(--bg-primary);width:100%;overflow-x:hidden}.container{width:100%;max-width:1240px;margin:0 auto;padding:0 24px}.navbar{position:sticky;top:0;z-index:200;height:var(--navbar-h);border-radius:0;border-left:none;border-right:none;border-top:none;border-bottom:1px solid var(--border)}.navbar-inner{height:100%;display:flex;align-items:center;justify-content:space-between;overflow:visible;gap:8px}.navbar-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}.brand-icon{font-size:1.4rem}.brand-name{font-size:1.25rem;font-weight:800;letter-spacing:-.02em}.navbar-user{display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:nowrap}.user-info{display:flex;flex-direction:column;line-height:1.2;margin-right:4px}.user-name{font-size:.85rem;font-weight:600;color:var(--text-primary)}.user-status{font-size:.72rem;color:var(--online);font-weight:500}.user-avatar-wrap{position:relative}.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--border-light);transition:border-color .2s}.user-avatar:hover{border-color:var(--accent)}.user-avatar-fallback{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--accent-light);border:2px solid var(--accent);font-size:.85rem;font-weight:700;color:var(--accent)}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:var(--radius-full);font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.badge-open{background:#10b9811f;color:var(--success)}.badge-social{background:#f59e0b1f;color:var(--warning)}.badge-closed{background:#ef44441f;color:var(--danger)}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.spinner-sm{width:14px;height:14px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes speakingRing{0%{box-shadow:0 0 #4f72ff80}70%{box-shadow:0 0 0 10px #4f72ff00}to{box-shadow:0 0 #4f72ff00}}.animate-fadeIn{animation:fadeIn .35s ease}.animate-slideUp{animation:slideUp .4s ease both}.animate-scaleIn{animation:scaleIn .25s ease}.auth-bg{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;z-index:0}.orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.28;animation:float 10s ease-in-out infinite}.orb-1{width:500px;height:500px;background:#4f72ff;top:-12%;left:-8%}.orb-2{width:400px;height:400px;background:#7b9fff;bottom:-10%;right:-6%;animation-delay:3s}.orb-3{width:280px;height:280px;background:#10b981;top:45%;left:55%;animation-delay:6s}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-card)}button,a{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.room-controls-bar,.dm-input-bar{padding-bottom:max(10px,env(safe-area-inset-bottom))}@media(max-width:768px){:root{--navbar-h: 56px}.container{padding:0 16px}.user-info{display:none}.brand-name{font-size:1.1rem}.brand-icon{font-size:1.2rem}}@media(max-width:480px){html{font-size:15px}body{padding-bottom:75px}.container{padding:0 12px}.card{padding:16px}.back-btn{min-height:40px;padding:8px 14px}.btn{padding:8px 14px;font-size:.85rem}.btn-sm{padding:6px 10px;font-size:.8rem}.navbar-user{gap:4px}.friends-nav-btn{display:none!important}.notification-nav-btn{display:inline-flex!important}}@media(max-width:360px){html{font-size:14px}.container{padding:0 10px}.navbar-user{gap:2px}.btn-sm{padding:5px 8px;font-size:.75rem}.brand-name{font-size:1rem}}
