.notification-bell-wrapper{position:relative}.notification-bell-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:transparent;border:none;border-radius:8px;color:var(--text);font-size:14px;cursor:pointer;transition:background-color .15s ease;text-align:left;position:relative}.notification-bell-btn:hover{background:var(--panel-2)}.notification-bell-btn .material-icons{font-size:22px;color:var(--muted);transition:color .15s ease}.notification-bell-btn.has-unread .material-icons{color:var(--accent)}.notification-bell-label{font-weight:500}.notification-badge{position:absolute;top:4px;left:26px;min-width:18px;height:18px;padding:0 5px;background:#ef4444;color:#fff;font-size:11px;font-weight:600;border-radius:9px;display:flex;align-items:center;justify-content:center;line-height:1;animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.notif-dropdown{width:400px;max-height:520px;background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:0 16px 48px #0000002e,0 2px 8px #0000000f;z-index:99999;overflow:hidden;display:flex;flex-direction:column;animation:notifAppear .22s cubic-bezier(.16,1,.3,1)}@keyframes notifAppear{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px}.notif-header-title{font-weight:700;font-size:16px;color:var(--text);letter-spacing:-.02em}.notif-mark-all{display:inline-flex;align-items:center;gap:4px;background:transparent;border:none;color:var(--accent);font-size:12px;font-weight:500;cursor:pointer;padding:4px 10px;border-radius:6px;transition:background-color .15s}.notif-mark-all:hover{background:rgba(var(--accent-rgb),.1)}.notif-tabs{display:flex;gap:4px;padding:0 18px 10px}.notif-tab{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:7px 0;border:none;border-radius:8px;background:transparent;color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;transition:background-color .15s,color .15s}.notif-tab:hover{background:var(--panel-2);color:var(--text)}.notif-tab.active{background:var(--chip-active);color:var(--chip-active-text, #fff)}.notif-tab-badge{min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1}.notif-tab.active .notif-tab-badge{background:#ffffff40}.notif-list{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--muted) 25%,transparent) transparent}.notif-list::-webkit-scrollbar{width:4px}.notif-list::-webkit-scrollbar-track{background:transparent}.notif-list::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--muted) 25%,transparent);border-radius:10px}.notif-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 24px;color:var(--muted);font-size:13px}.notif-empty .material-icons{font-size:36px;opacity:.35}.notif-group-label{padding:8px 18px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.notif-item{display:flex;align-items:flex-start;gap:12px;padding:10px 18px;cursor:pointer;transition:background-color .12s;position:relative}.notif-item:hover{background:var(--panel-2)}.notif-item.unread{background:rgba(var(--accent-rgb),.04)}.notif-item.unread:hover{background:rgba(var(--accent-rgb),.08)}.notif-avatar{width:42px;height:42px;border-radius:12px;overflow:visible;background:var(--panel-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.notif-avatar img{width:42px;height:42px;border-radius:12px;object-fit:cover;display:block}.notif-avatar>.material-icons{font-size:22px}.notif-type-badge{position:absolute;bottom:-3px;right:-3px;width:18px;height:18px;border-radius:6px;display:flex;align-items:center;justify-content:center;border:2px solid var(--panel)}.notif-type-badge .material-icons{font-size:10px;color:#fff}.notif-item-body{flex:1;min-width:0}.notif-item-main{font-size:13.5px;line-height:1.4;color:var(--text)}.notif-from{font-weight:600;color:var(--accent)}.notif-action{color:var(--text);margin-left:4px}.notif-preview{margin-top:3px;padding:5px 8px;border-radius:6px;background:var(--panel-2);font-size:12.5px;color:var(--muted);line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px;font-style:italic}.notif-item-footer{display:flex;align-items:center;gap:10px;margin-top:4px}.notif-time{font-size:11.5px;color:var(--muted)}.notif-dest{display:inline-flex;align-items:center;gap:2px;font-size:11px;color:var(--accent);opacity:.7;transition:opacity .15s}.notif-item:hover .notif-dest{opacity:1}.notif-dest .material-icons{font-size:12px}.notif-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;flex-shrink:0;margin-top:8px;box-shadow:0 0 0 3px rgba(var(--accent-rgb),.15)}.notif-reply-zone{margin-top:6px}.notif-reply-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:background-color .15s,border-color .15s}.notif-reply-btn .material-icons{font-size:14px;color:var(--muted)}.notif-reply-btn:hover{background:var(--panel-2);border-color:var(--accent)}.notif-reply-form{display:flex;flex-direction:column;gap:6px}.notif-reply-input{width:100%;min-height:48px;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-size:13px;font-family:inherit;resize:vertical;box-sizing:border-box;transition:border-color .15s}.notif-reply-input:focus{outline:none;border-color:var(--accent)}.notif-reply-actions{display:flex;gap:6px;justify-content:flex-end}.notif-reply-cancel{padding:5px 10px;border-radius:8px;border:none;background:transparent;color:var(--muted);font-size:12px;cursor:pointer}.notif-reply-cancel:hover{color:var(--text)}.notif-reply-send{width:32px;height:32px;border-radius:8px;border:none;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .15s}.notif-reply-send .material-icons{font-size:16px}.notif-reply-send:hover{opacity:.85}.notif-reply-send:disabled{opacity:.35;cursor:default}@keyframes notifSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.notif-spin{animation:notifSpin .8s linear infinite}@media (max-width: 768px){.notif-dropdown{width:calc(100vw - 24px)!important;left:12px!important;right:12px!important;max-height:calc(100vh - 120px)}.notification-bell-btn{padding:8px 12px}.notification-badge{top:2px;left:22px}.notif-preview{max-width:200px}}.sidebar{width:220px;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:0;flex-shrink:0;position:sticky;top:20px;height:fit-content;max-height:calc(100vh - 40px);overflow-y:auto;overflow:hidden;margin:20px 0 20px 20px;opacity:1;-webkit-overflow-scrolling:touch;display:block;visibility:visible}@media (min-width: 769px) and (max-width: 1600px){.container.room-layout .sidebar{position:fixed!important;top:20px!important;left:20px!important;right:auto!important;margin:0!important;z-index:2200;align-self:flex-start;transform:none!important;width:220px!important}}@media (min-width: 1601px){.container.room-layout .sidebar{position:fixed!important;top:20px!important;left:calc((100vw - 1600px)/2 + 20px)!important;right:auto!important;margin:0!important;z-index:2200;align-self:flex-start;transform:none!important;width:220px!important}}body.loaded .sidebar{transition:background-color .3s ease,border-color .3s ease}.sidebar-menu{padding:12px;display:flex;flex-direction:column;gap:6px}.sidebar-menu-item{width:100%;text-align:left;padding:10px 14px;border:1px solid transparent;border-radius:14px;font-weight:600;cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease;white-space:nowrap;font-size:13px;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;background:var(--panel-2);color:var(--text);text-decoration:none;display:flex;align-items:center;position:relative;touch-action:manipulation;-webkit-tap-highlight-color:transparent}@media (hover: hover) and (pointer: fine){.sidebar-menu-item:hover{background:var(--chip-active);border-color:transparent;color:var(--chip-active-text, white)}}.sidebar-menu-item:not(.active):active{background:var(--panel-2);color:var(--text);opacity:.85}.sidebar-menu-item.active{background:var(--chip-active)!important;border-color:transparent!important;color:var(--chip-active-text, white)!important}.sidebar-menu-item .material-icons{vertical-align:middle;margin-right:4px;font-size:18px;display:inline-block}.friends-badge{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#f44;color:#fff;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:700;min-width:18px;text-align:center;line-height:14px}.sidebar-menu-item.active .friends-badge{background:#ffffff4d;color:#fff}.mobile-menu-button{position:fixed!important;top:20px!important;left:20px!important;z-index:2300!important;min-width:96px!important;height:40px!important;border-radius:8px!important;border:1px solid var(--border)!important;background:var(--panel)!important;color:var(--text)!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;transition:background .14s ease,transform .14s ease!important;box-shadow:0 8px 24px #00000059!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important;margin:0!important;padding:0 16px!important;box-sizing:border-box!important;font-size:14px!important;font-weight:600!important;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial!important}@media (min-width: 769px){.mobile-menu-button{display:none!important}}@media (max-width: 768px){.mobile-menu-button{display:none!important}}.mobile-menu-button:hover{background:var(--chip-active);color:var(--chip-active-text, white);border-color:transparent}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:2199;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;transition:opacity .3s cubic-bezier(.4,0,.2,1);pointer-events:none;will-change:opacity;backface-visibility:hidden;-webkit-backface-visibility:hidden}.mobile-menu-overlay.active{opacity:1;pointer-events:auto}@media (max-width: 768px){.sidebar:not(.mobile-sidebar){width:100%;height:auto;position:relative;border-radius:18px;padding:0;margin:0;top:0;max-height:none}.sidebar:not(.mobile-sidebar) .sidebar-menu{flex-direction:row;flex-wrap:wrap;gap:8px}.sidebar:not(.mobile-sidebar) .sidebar-menu-item{flex:1;min-width:120px;justify-content:center}.sidebar.mobile-sidebar{display:none!important;visibility:hidden!important;opacity:0!important;pointer-events:none!important;-webkit-backface-visibility:hidden!important}.sidebar.mobile-sidebar.mobile-sidebar-open{display:none!important;visibility:hidden!important;opacity:0!important;pointer-events:none!important}.container.room-layout .sidebar.mobile-sidebar .sidebar-menu,.sidebar.mobile-sidebar .sidebar-menu{flex-direction:column!important;flex-wrap:nowrap!important;padding:16px!important;gap:12px!important}.container.room-layout .sidebar.mobile-sidebar .sidebar-menu-item,.sidebar.mobile-sidebar .sidebar-menu-item{flex:none!important;min-width:auto!important;width:100%!important;justify-content:flex-start!important;text-align:left!important;padding:16px 20px!important;font-size:16px!important;min-height:56px!important}.container.room-layout .sidebar.mobile-sidebar .sidebar-menu-item .material-icons,.sidebar.mobile-sidebar .sidebar-menu-item .material-icons{font-size:24px!important;margin-right:12px!important}}@media (max-width: 480px){.sidebar-menu{gap:10px}.sidebar.mobile-sidebar .sidebar-menu{gap:12px!important}.sidebar-menu-item{padding:8px 10px;font-size:12px;border-width:.5px}.sidebar.mobile-sidebar .sidebar-menu-item{padding:16px 20px!important;font-size:16px!important;min-height:56px!important}.sidebar.mobile-sidebar .sidebar-menu-item .material-icons{font-size:24px!important;margin-right:12px!important}}.chat-tabs-wrapper{display:flex;flex-direction:column;width:220px;min-width:220px;flex-shrink:0;overflow:hidden;transition:transform .3s ease;position:relative;pointer-events:all}.chat-tabs-sidebar{display:flex;flex-direction:column;width:100%;height:100%;background:var(--panel);overflow:hidden}.chat-tabs-overlay{display:none;position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;z-index:998;opacity:0;transition:opacity .3s ease;pointer-events:none;touch-action:none}.chat-tabs-overlay.open{opacity:1;pointer-events:all}.chat-tabs-overlay.open~.chat-tabs-wrapper{pointer-events:all}.chat-tabs-header{display:flex;align-items:center;gap:8px;padding:14px 16px;background:var(--panel-2);color:var(--text);font-weight:700;font-size:15px;flex-shrink:0;border-bottom:1px solid var(--border)}.chat-tabs-header .material-icons{font-size:20px;color:var(--accent)}.chat-tabs-title{font-weight:700}.chat-tabs-list{display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain;will-change:scroll-position;padding:6px 0}.chat-tab{display:flex;align-items:flex-start;gap:0;padding:10px 16px;background:transparent;border:none;color:var(--text);cursor:pointer;transition:background .12s ease;text-align:left;width:100%;min-height:56px;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;box-sizing:border-box;position:relative;white-space:normal;flex-shrink:0}.chat-tab:after{content:"";position:absolute;bottom:0;left:72px;right:16px;height:1px;background:var(--border);opacity:.5}.chat-tab:last-child:after{display:none}.chat-tab:hover{background:var(--panel-2)}.chat-tab:active{background:var(--panel-2);opacity:.85}.chat-tab.active{background:var(--chip-active);color:#fff}.chat-tab.active:after{display:none}.chat-tab.chat-tab-room{margin:6px 10px 4px;width:calc(100% - 20px);padding:12px 16px;border-radius:22px;background:var(--panel-2);border:1px solid var(--border);min-height:auto}.chat-tab.chat-tab-room:after{display:none}.chat-tab.chat-tab-room:hover{background:var(--panel-2);border-color:var(--accent)}.chat-tab.chat-tab-room.active{background:var(--chip-active);border-color:transparent}.chat-tab-room-messages{display:flex;flex-direction:column;gap:2px;margin-top:2px}.chat-tab-room-msg{font-size:12px;line-height:1.35;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-tab-room-msg-text{font-weight:400}.chat-tab.active .chat-tab-room-msg{color:#fff9}.chat-tab.active .chat-tab-room-messages .chat-tab-preview-sender{color:#ffffffd9}.chat-tab-content{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.chat-tab-avatar{width:48px;height:48px;min-width:48px;min-height:48px;border-radius:50%;flex-shrink:0;background:var(--panel-2);display:flex;align-items:center;justify-content:center;overflow:hidden}.chat-tab-avatar img{width:100%;height:100%;object-fit:cover}.chat-tab-avatar .material-icons{font-size:26px;color:var(--muted)}.chat-tab.active .chat-tab-avatar{background:#ffffff26}.chat-tab.active .chat-tab-avatar .material-icons{color:#ffffffd9}.chat-tab-name-wrapper{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0;padding-top:2px}.chat-tab-top-row{display:flex;align-items:baseline;justify-content:space-between;gap:8px;min-width:0}.chat-tab-name{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text);line-height:1.3}.chat-tab.active .chat-tab-name{color:#fff}.chat-tab-room-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.chat-tab.active .chat-tab-room-name{color:#fff}.chat-tab-time{font-size:12px;font-weight:400;color:var(--muted);white-space:nowrap;flex-shrink:0;line-height:1.3}.chat-tab.active .chat-tab-time{color:#fff9}.chat-tab-preview{font-size:13px;font-weight:400;color:var(--muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-break:break-word;white-space:normal}.chat-tab-preview--empty{font-style:italic;opacity:.45}.chat-tab-preview-sender{font-weight:600;color:var(--accent)}.chat-tab.active .chat-tab-preview{color:#fff9}.chat-tab.active .chat-tab-preview-sender{color:#ffffffd9}.chat-tab-label{font-size:12px;font-weight:500;color:var(--muted);line-height:1.2}.chat-tab.active .chat-tab-label{color:#ffffffb3}.chat-tab-actions{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0;padding-top:2px;margin-left:8px}.chat-tab-unread-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;background:var(--accent);color:#fff;border-radius:11px;font-size:12px;font-weight:600;line-height:1;flex-shrink:0}.chat-tab.active .chat-tab-unread-count{background:#ffffff40}.chat-tab-close{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;padding:2px;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;transition:all .15s ease;-webkit-user-select:none;user-select:none;opacity:0}.chat-tab:hover .chat-tab-close{opacity:.6}.chat-tab:hover .chat-tab-close:hover{opacity:1;background:#00000014}.chat-tab.active .chat-tab-close{color:#fffc}.chat-tab.active:hover .chat-tab-close:hover{background:#ffffff26}.users-count-btn{background:#0000000a;border:none;color:var(--accent);font-size:11px;font-weight:600;cursor:pointer;padding:3px 8px;border-radius:12px;transition:all .15s ease;display:flex;align-items:center;gap:3px}.users-count-btn:hover{background:#00000014}.chat-tab.active .users-count-btn{background:#ffffff26;color:#fff}.chat-tab.active .users-count-btn:hover{background:#ffffff40}.users-count-btn .material-icons{font-size:14px}.chat-tabs-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--muted);font-size:13px;text-align:center;gap:10px}.chat-tabs-empty .material-icons{font-size:36px;opacity:.35}.chat-tab-icon{font-size:20px;flex-shrink:0;color:var(--muted)}.chat-tab.active .chat-tab-icon{color:#fff}@media (min-width: 769px){.chat-tabs-overlay{display:block;position:absolute}.chat-tabs-wrapper{position:absolute;left:0;top:0;bottom:0;width:300px;max-width:85vw;min-width:0;z-index:999;transform:translate(-100%);background:var(--panel);border-right:1px solid var(--border);border-radius:22px 0 0 22px}.chat-tabs-wrapper.open{transform:translate(0)}.chat-container{position:relative;overflow:hidden}.chat-tabs-sidebar{border-right:none;border-radius:22px 0 0 22px;overflow:hidden}}@media (max-width: 768px){.chat-tabs-overlay{display:block;position:absolute;top:0;right:0;bottom:0;left:0;z-index:998;touch-action:none}.chat-tabs-wrapper{position:absolute;left:0;top:0;bottom:0;width:100%;max-width:100%;min-width:0;z-index:999;transform:translate(-100%);background:var(--panel);box-shadow:2px 0 10px #0000004d;touch-action:none}.chat-tabs-wrapper.open{transform:translate(0)}.chat-tabs-sidebar{width:100%;height:100%;border-right:none;touch-action:none}.chat-tabs-sidebar .chat-tabs-list{touch-action:pan-y!important;will-change:scroll-position;overscroll-behavior:contain}.chat-tabs-list{overflow-y:auto!important;touch-action:pan-y!important;overscroll-behavior:contain;position:relative;z-index:1}.chat-tab-avatar{width:44px;height:44px}.chat-tab-avatar .material-icons{font-size:24px}}.chat-messages-container{position:relative;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;width:100%}.chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.chat-messages--hidden{visibility:hidden}.chat-messages.bottom-up{flex-direction:column-reverse}.chat-messages-spacer{flex:1 1 auto}.chat-loading-more{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;color:var(--muted);font-size:14px;flex-shrink:0}.chat-loading-more .material-icons{font-size:18px;animation:spin 1s linear infinite}.chat-date-separator{display:flex;justify-content:center;padding:6px 0;flex-shrink:0}.chat-date-separator span{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;background:var(--panel);border:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:700}.chat-message-wrapper{display:flex;flex-direction:column;gap:4px;max-width:80%;width:fit-content;flex-shrink:0}.chat-message-wrapper.own{align-self:flex-end}.chat-message{display:flex;flex-direction:column;gap:4px;padding:10px 14px;background:var(--panel-2);border-radius:30px;word-wrap:break-word;overflow-wrap:break-word}.chat-message-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.chat-message-wrapper:not(.own) .chat-message{border-radius:8px 30px 30px}.chat-message-wrapper.own .chat-message{background:var(--accent);color:#fff;border-radius:30px 8px 30px 30px}.chat-message-username{font-size:12px;font-weight:600;color:var(--muted)}.chat-message-wrapper.own .chat-message-username{color:#fffc}.chat-message-action{border:none;background:var(--chip, rgba(255,255,255,.06));color:var(--muted, #888);opacity:0;cursor:pointer;padding:0;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;transition:background .18s ease,opacity .18s ease,color .18s ease,transform .12s ease;flex-shrink:0}.chat-message-action .material-icons{font-size:16px}.chat-message-wrapper:hover .chat-message-action{opacity:.7}.chat-message-action:hover{opacity:1!important;background:var(--accent, #3b82f6);color:#fff;transform:scale(1.1)}.chat-message-action:active{transform:scale(.92)}@media (max-width: 768px){.chat-message-action{opacity:.5}}.chat-message-text{font-size:14px;word-wrap:break-word;overflow-wrap:break-word;white-space:pre-wrap}.chat-link{color:#60a5fa;text-decoration:underline;text-underline-offset:2px;transition:color .15s}.chat-link:hover{color:#93bbfd}[data-theme=light] .chat-link{color:#2563eb}[data-theme=light] .chat-link:hover{color:#1d4ed8}.chat-message-image{margin-top:6px;border-radius:22px;overflow:hidden}.chat-message-image img{display:block;max-width:280px;width:100%;height:auto;border-radius:22px}.chat-message-meta{display:flex;align-items:center;justify-content:flex-end;gap:4px}.chat-message-time{font-size:11px;color:var(--muted)}.chat-message-wrapper.own .chat-message-time{color:#ffffffb3}.chat-message-read-status{display:flex;flex-direction:column;align-items:flex-end;gap:2px;padding:0 4px;margin-top:2px}.chat-message-read-text{font-size:11px;color:var(--muted);font-weight:500;display:inline-flex;align-items:center}.chat-message-read-text .material-icons{font-size:14px!important;margin-right:3px}.chat-message-read-date{font-size:10px;color:var(--muted);opacity:.8}.chat-reply-block{border-left:3px solid var(--accent);padding:6px 10px;margin:2px 0 4px;background:#0000000a;border-radius:4px 10px 10px 4px;max-width:100%;overflow:hidden}.chat-message-wrapper.own .chat-reply-block{background:#ffffff26;border-left-color:#fff9}.chat-reply-author{font-size:12px;font-weight:600;color:var(--accent);line-height:1.3}.chat-message-wrapper.own .chat-reply-author{color:#ffffffe6}.chat-reply-text{font-size:13px;line-height:1.35;color:var(--text);opacity:.75;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.chat-message-wrapper.own .chat-reply-text{color:#fff;opacity:.7}.chat-reply-image img{max-width:160px;width:100%;border-radius:6px;margin-top:4px}.chat-input-container{padding:10px 16px;background:transparent;flex-shrink:0;position:relative;box-sizing:border-box}.chat-drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:20px 16px;background:rgba(var(--accent-rgb, 66, 133, 244),.08);border:2px dashed var(--accent);border-radius:12px;color:var(--accent);font-size:13px;font-weight:500;cursor:pointer;margin-bottom:8px;transition:background .2s,border-color .2s;animation:chatDropIn .2s ease}.chat-drop-zone:hover{background:rgba(var(--accent-rgb, 66, 133, 244),.15)}.chat-drop-zone .material-icons{font-size:28px}.chat-drop-zone .drop-zone-formats{font-size:11px;font-weight:400;opacity:.55;letter-spacing:.5px}@keyframes chatDropIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.chat-input-icon-btn--active{color:var(--accent)!important;background:rgba(var(--accent-rgb, 66, 133, 244),.12)!important}.chat-gif-btn-label{font-size:11px;font-weight:700;line-height:1;letter-spacing:.5px;border:1.5px solid currentColor;border-radius:4px;padding:2px 3px 1px}.chat-input-wrapper{display:flex;gap:8px;align-items:center}.chat-input-field-row{flex:1;min-width:0;display:flex;align-items:center;gap:2px;background:var(--panel);border:1px solid var(--border);border-radius:22px;padding:4px 6px;transition:border-color .2s}.chat-input-field-row:focus-within{border-color:var(--accent)}.chat-input-icon-btn{flex-shrink:0;width:36px;height:36px;border:none;background:none;color:var(--text-secondary, #999);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:color .15s,background .15s}.chat-input-icon-btn:hover{color:var(--text);background:var(--hover, rgba(255,255,255,.06))}.chat-input-icon-btn:disabled{opacity:.4;cursor:not-allowed}.chat-input-icon-btn .material-icons{font-size:22px}.chat-input{flex:1;min-width:0;padding:8px 6px;background:transparent;border:none;color:var(--text);font-size:15px;outline:none;line-height:1.3}.chat-input::placeholder{color:var(--text-secondary, #999)}.chat-input:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn{flex-shrink:0;width:44px;height:44px;border:none;border-radius:50%;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,transform .1s}.chat-send-btn:hover:not(:disabled){background:var(--accent-2)}.chat-send-btn:active:not(:disabled){transform:scale(.92)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-send-btn .material-icons{font-size:22px;margin-left:2px}.chat-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--muted);text-align:center;flex:1}.chat-empty-state .material-icons{font-size:48px;margin-bottom:12px;opacity:.5}.chat-empty-state p{margin:0;font-size:14px}.chat-reply-bar{display:flex;align-items:center;justify-content:space-between;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:8px 14px;margin-bottom:8px;gap:8px}.chat-reply-bar-title{font-weight:600;font-size:13px}.chat-reply-bar-snippet{font-size:13px;color:var(--muted);margin-top:2px}.chat-reply-bar-close{background:transparent;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:50%;transition:background .15s ease,color .15s}.chat-reply-bar-close:hover{background:var(--panel-2);color:var(--text)}.chat-attachment-preview{position:relative;display:inline-block;margin-bottom:8px;align-self:flex-start}.chat-attachment-preview img{max-height:120px;max-width:200px;border-radius:10px;display:block}.chat-attachment-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#0000008c;border:none;border-radius:50%;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.chat-attachment-remove .material-icons{font-size:15px}.chat-attachment-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000059;border-radius:10px;pointer-events:none}.chat-attachment-ring{width:44px;height:44px;animation:chatRingSpin 1.5s linear infinite}.chat-attachment-ring circle:nth-child(2){transition:stroke-dasharray .25s ease}@keyframes chatRingSpin{to{transform:rotate(360deg)}}.chat-attachment-pct{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff}.chat-attachment-done{position:absolute;bottom:6px;right:6px;color:#4caf50;font-size:20px!important;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));animation:chatDoneIn .3s ease}@keyframes chatDoneIn{0%{transform:scale(0)}to{transform:scale(1)}}.chat-send-status{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:13px;color:var(--muted)}.chat-send-status .material-icons{font-size:16px;animation:none}.chat-send-status.spinning .material-icons{animation:spin 1s linear infinite}.chat-scroll-bottom{position:absolute;bottom:80px;right:14px;z-index:20;width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:var(--panel);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000002e;transition:transform .2s,box-shadow .2s,background .2s;animation:chatScrollBtnIn .25s cubic-bezier(.34,1.56,.64,1)}.chat-scroll-bottom:hover{background:var(--chip);box-shadow:0 4px 14px #00000038;transform:scale(1.1)}.chat-scroll-bottom:active{transform:scale(.93)}.chat-scroll-bottom .material-icons{font-size:22px}.chat-scroll-bottom-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;animation:chatBadgePop .3s cubic-bezier(.34,1.56,.64,1)}@keyframes chatScrollBtnIn{0%{opacity:0;transform:translateY(8px) scale(.6)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes chatBadgePop{0%{transform:scale(0)}to{transform:scale(1)}}.chat-message-wrapper.msg-appear{animation:chatMsgAppear .35s cubic-bezier(.34,1.56,.64,1) both}.chat-message-wrapper.msg-appear.own{animation-name:chatMsgAppearOwn}@keyframes chatMsgAppear{0%{opacity:0;transform:translateY(14px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes chatMsgAppearOwn{0%{opacity:0;transform:translateY(14px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.chat-messages{padding:12px;gap:10px}.chat-input-container{padding:8px 10px 14px}.chat-input-wrapper{gap:6px}.chat-input{font-size:16px}.chat-send-btn{width:40px;height:40px}.chat-send-btn .material-icons{font-size:20px}.chat-input-icon-btn{width:32px;height:32px}.chat-input-icon-btn .material-icons{font-size:20px}.chat-message-wrapper{max-width:85%}}.chat-message-reactions-row{display:flex;align-items:center;margin-top:2px;min-height:20px}.chat-reaction-wrap{position:relative;display:inline-flex;align-items:center;gap:4px}.chat-reaction-trigger{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:var(--chip, rgba(255,255,255,.06));cursor:pointer;padding:0;opacity:0;border-radius:50%;transition:opacity .18s,background .18s,color .18s,transform .12s;color:var(--muted, #888)}.chat-reaction-trigger .material-icons{font-size:16px}.chat-message-wrapper:hover .chat-reaction-trigger,.new-chat-message-item:hover .chat-reaction-trigger,.chat-reaction-trigger:focus-visible{opacity:.7}.chat-reaction-trigger:hover{opacity:1!important;background:var(--accent, #3b82f6);color:#fff;transform:scale(1.1)}.chat-reaction-trigger:active{transform:scale(.92)}@media (max-width: 768px){.chat-reaction-trigger{opacity:.5}}.chat-reaction-popup{display:flex;gap:2px;padding:4px 6px;background:var(--panel, #1e1e23);border:1px solid var(--border, rgba(255,255,255,.1));border-radius:20px;box-shadow:0 4px 16px #00000059;animation:chatReactionIn .15s ease;pointer-events:auto}@keyframes chatReactionIn{0%{opacity:0;transform:translateY(4px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-reaction-option{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;cursor:pointer;border-radius:50%;font-size:18px;transition:transform .12s,background .12s;padding:0}.chat-reaction-option:hover{transform:scale(1.25);background:var(--border, rgba(255,255,255,.08))}.chat-reaction-option.active{background:#3b82f633}.chat-reaction-badges{display:flex;flex-wrap:wrap;gap:4px}.chat-reaction-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:10px;border:1px solid var(--border, rgba(255,255,255,.1));background:var(--chip, rgba(255,255,255,.05));cursor:pointer;transition:background .15s,border-color .15s;font-size:12px;line-height:1}.chat-reaction-badge:hover{background:var(--border, rgba(255,255,255,.1))}.chat-reaction-badge.active{border-color:var(--accent, #3b82f6);background:#3b82f626}.chat-reaction-emoji{font-size:14px;line-height:1}.chat-reaction-count{color:var(--text, #fff);font-size:11px;font-weight:600}.users-modal{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:2000;align-items:center;justify-content:center}.users-modal.active{display:flex}.users-modal-content{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:24px;max-width:800px;width:90%;max-height:80vh;display:flex;flex-direction:column}.users-modal-title{font-size:20px;font-weight:700;margin-bottom:20px}.users-modal-loading{text-align:center;padding:40px;color:var(--muted)}.users-modal-error{text-align:center;padding:40px;color:var(--error)}.users-modal-empty{text-align:center;padding:40px;color:var(--muted)}.users-modal-list{overflow-y:auto;flex:1;min-height:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;padding:4px}.user-card-modal{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:12px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .2s ease;text-align:center}.user-card-modal:hover{background:var(--panel);border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 8px #0003}.user-card-avatar{width:64px;height:64px;border-radius:12px;background:var(--panel);border:2px solid var(--border);overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-card-avatar img{width:100%;height:100%;object-fit:cover}.user-card-avatar .material-icons{font-size:32px;color:var(--muted)}.user-card-name{font-size:13px;font-weight:600;color:var(--text);word-break:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:100%}.users-modal-close{margin-top:20px;align-self:flex-end}@media (max-width: 768px){.users-modal-content{max-width:100%;padding:16px}.users-modal-list{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px}.user-card-modal{padding:10px}.user-card-avatar{width:56px;height:56px}.user-card-name{font-size:12px}}.room-chat-overlay{position:fixed;bottom:140px;left:20px;right:80px;z-index:999;display:flex;flex-direction:column;justify-content:flex-end;pointer-events:none;max-height:40vh;overflow:hidden}@media (min-width: 769px){.room-chat-overlay{bottom:80px;left:auto;right:80px;width:min(420px,40vw)}}.room-chat-overlay-msg{display:flex;align-items:flex-end;gap:4px;margin-bottom:3px;max-width:100%;width:fit-content;pointer-events:auto;animation:overlayMsgIn .3s ease-out,overlayMsgOut .6s ease-in forwards;animation-delay:0s,8.4s}.room-chat-overlay-msg--mine{align-self:flex-end;flex-direction:row-reverse}.room-chat-overlay-msg-content{padding:5px 10px;border-radius:12px;background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.2),rgba(var(--accent-rgb, 59, 130, 246),.05)),#00000073;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);line-height:1.4;font-size:13px;word-break:break-word;max-width:100%}.room-chat-overlay-msg--img-only .room-chat-overlay-msg-content{padding:5px 6px}.room-chat-overlay-msg--mine .room-chat-overlay-msg-content{background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.35),rgba(var(--accent-rgb, 59, 130, 246),.15)),#00000059}.room-chat-overlay-name{font-weight:700;color:var(--accent, #4fc3f7);margin-right:6px;text-shadow:0 1px 3px rgba(0,0,0,.6)}.room-chat-overlay-msg--mine .room-chat-overlay-name{color:#93c5fd}.room-chat-overlay-text{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.7)}.room-chat-overlay-img{display:block;max-width:140px;max-height:100px;border-radius:8px;object-fit:cover;margin-top:4px}.room-chat-overlay-reply{pointer-events:auto;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:none;border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#ffffffb3;flex-shrink:0;opacity:0;transition:opacity .15s,background .15s,color .15s;padding:0}.room-chat-overlay-reply .material-icons{font-size:15px}.room-chat-overlay-msg:hover .room-chat-overlay-reply{opacity:1}@media (max-width: 768px){.room-chat-overlay-reply{opacity:1;width:24px;height:24px}.room-chat-overlay-reply .material-icons{font-size:14px}}.room-chat-overlay-reply:hover{background:#fff3;color:#fff}.room-chat-overlay-reply:active{transform:scale(.9)}@keyframes overlayMsgIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes overlayMsgOut{0%{opacity:1}to{opacity:0}}.chat-panel{background:var(--panel);border-top:1px solid var(--border);border-radius:22px;display:flex;flex-direction:column;width:800px;height:400px;min-height:50px;min-width:380px;max-height:80vh;max-width:90vw;position:fixed;left:50%;bottom:40px;transform:translate(-50%);z-index:1000;box-shadow:0 4px 24px #0000001f,0 1px 4px #00000014;overflow:visible;box-sizing:border-box;opacity:0;transition:opacity .3s ease,background-color .3s ease,border-color .3s ease}.chat-panel.dice-open{overflow:hidden}.chat-container{display:flex;flex-direction:row;flex:1;overflow:hidden;min-height:0;position:relative}.chat-content-wrapper{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.room-games-section{flex-shrink:0;max-height:400px;overflow-y:auto;border-top:1px solid var(--border);padding:12px 16px;background:var(--bg);display:block!important;visibility:visible!important;opacity:1!important}.chat-chats-list-view{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.chat-panel.ready{opacity:1}.chat-panel.resizing,.chat-panel.dragging{transition:none}.chat-panel:not(.resizing):not(.dragging){transition:height .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1),left .3s cubic-bezier(.4,0,.2,1),top .3s cubic-bezier(.4,0,.2,1),bottom .3s cubic-bezier(.4,0,.2,1),opacity .3s ease,background-color .3s ease,border-color .3s ease}@media (max-width: 768px){.chat-panel{width:100%;max-width:100%;left:0;bottom:-100%;transform:none;border-radius:12px 12px 0 0}.chat-panel.ready:not(.collapsed){bottom:0}.chat-panel:not(.resizing):not(.dragging){transition:height .15s ease-out,bottom .3s cubic-bezier(.4,0,.2,1),opacity .3s ease,background-color .3s ease,border-color .3s ease}.chat-panel .chat-container,.chat-panel .chat-messages{touch-action:pan-y;-webkit-overflow-scrolling:touch}.chat-container{flex-direction:column}}.chat-drag-handle{position:absolute;top:0;left:0;right:0;height:100%;cursor:move;z-index:11;pointer-events:none}@media (max-width: 768px){.chat-drag-handle{display:none}}.chat-resize-handle{position:absolute;top:0;left:50%;transform:translate(-50%);width:200px;height:24px;background:transparent;cursor:move;z-index:10;border-radius:12px;transition:all .2s ease}@media (max-width: 768px){.chat-resize-handle{cursor:ns-resize}}.chat-resize-handle:hover{background:#3b82f61a}.chat-resize-handle:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:4px;background:var(--border);border-radius:2px}.chat-resize-corner{position:absolute;top:6px;right:6px;width:16px;height:16px;background:transparent;cursor:nwse-resize;z-index:12;opacity:.35;transition:opacity .2s}.chat-resize-corner:hover{opacity:.7}.chat-resize-corner:before,.chat-resize-corner:after{content:"";position:absolute;border-radius:50%;background:var(--muted)}.chat-resize-corner:before{width:3px;height:3px;bottom:0;right:0}.chat-resize-corner:after{width:3px;height:3px;bottom:0;right:6px;box-shadow:6px -6px 0 var(--muted)}@media (max-width: 768px){.chat-resize-corner{display:none}}.chat-panel-header{padding:12px 16px;border-bottom:none}.chat-header-top{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;cursor:move}.chat-header-left{display:flex;align-items:center;gap:8px;justify-content:flex-start}.chat-header-right{display:flex;align-items:center;gap:8px;justify-content:flex-end}.chat-panel-title{display:flex;align-items:center;justify-content:center;gap:8px;font-size:16px;font-weight:600;color:var(--text);grid-column:2;text-align:center}.chat-panel-title .material-icons{font-size:20px;color:var(--accent)}.chat-minimize-btn,.chat-exit-btn-inner,.chat-users-btn,.chat-tabs-toggle-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;padding:7px 16px;position:relative;min-width:0;height:34px;box-sizing:border-box;justify-content:center;border-radius:17px!important}.chat-tabs-toggle-text{display:inline}.chat-tabs-toggle-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--accent);color:var(--chip-active-text, white);border-radius:10px;font-size:11px;font-weight:600;line-height:1;margin-left:4px}@media (max-width: 768px){.chat-tabs-toggle-btn{padding:8px;min-width:44px}.chat-tabs-toggle-text{display:none}.chat-tabs-toggle-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;font-size:10px;margin-left:0}}.chat-panel.collapsed{height:56px;width:min(460px,90vw);left:auto;right:16px;transform:none;bottom:0;top:auto;border-radius:28px 28px 0 0;padding:6px 18px;box-shadow:0 -2px 10px #0000001f,0 -1px 4px #00000014;border:1px solid var(--border);border-bottom:none;background:var(--panel);display:flex;align-items:center;justify-content:center}@media (min-width: 769px){.chat-panel.collapsed .chat-collapsed-content{padding:0 12px!important}.chat-panel.collapsed.room-quick .chat-collapsed-content{padding:6px!important}.chat-panel.collapsed{left:auto!important;right:12px!important;padding:0!important;border-radius:28px!important;bottom:12px!important}}@media (max-width: 768px){.chat-panel.collapsed{left:0;right:0}}.chat-collapsed-content{display:none;width:100%;height:100%}.chat-panel.collapsed .chat-collapsed-content{display:flex;align-items:center;justify-content:center;gap:8px;padding:0;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:relative;overflow:visible}.chat-panel.collapsed.room-quick{height:auto!important;min-height:0!important;padding:0!important;width:min(420px,40vw)!important;right:80px!important}.chat-panel.collapsed.room-quick .chat-collapsed-content{flex-direction:column;align-items:stretch;justify-content:center;padding:6px!important;gap:0;box-sizing:border-box;height:auto!important}.chat-panel.collapsed.room-quick .chat-collapsed-actions{display:flex;gap:8px;justify-content:center}.chat-quick-reply-floating{position:fixed;left:8px;right:8px;bottom:calc(112px + env(safe-area-inset-bottom,0px));z-index:1002;display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.2),rgba(var(--accent-rgb, 59, 130, 246),.05)),#00000073;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:.5px solid rgba(var(--accent-rgb, 59, 130, 246),.25);border-radius:22px;padding:5px 8px 5px 12px;gap:6px;box-shadow:0 2px 12px #00000040}.chat-quick-reply-floating--desktop{position:absolute;left:0;right:0;bottom:100%;margin-bottom:4px;border-radius:22px}.chat-quick-reply-info{display:flex;align-items:center;min-width:0;flex:1;gap:6px;overflow:hidden}.chat-quick-reply-icon{font-size:16px;color:var(--accent, #4fc3f7);flex-shrink:0}.chat-quick-reply-body{display:flex;flex-direction:column;min-width:0;flex:1;gap:1px}.chat-quick-reply-author{font-size:12px;font-weight:600;color:var(--accent, #4fc3f7);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 2px rgba(0,0,0,.5)}.chat-quick-reply-text{font-size:12px;color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 2px rgba(0,0,0,.4)}.chat-quick-reply-thumb{width:36px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0}.chat-quick-reply-close{background:none;border:none;cursor:pointer;padding:2px;color:#ffffff80;flex-shrink:0;display:flex;align-items:center;transition:color .15s}.chat-quick-reply-close:hover{color:#fff}.chat-quick-room-form{display:flex;gap:8px;width:100%;align-items:center;box-sizing:border-box}.chat-quick-capsule{flex:1;min-width:0;display:flex;align-items:center;gap:2px;background:var(--panel-2);border:1px solid var(--border);border-radius:22px;padding:4px 6px;transition:border-color .2s}.chat-quick-capsule:focus-within{border-color:var(--accent)}.chat-quick-actions{display:flex;align-items:center;gap:0;flex-shrink:0}.chat-quick-attach{flex:0 0 auto;width:34px;height:34px;padding:0;border-radius:50%;border:none;background:transparent;color:var(--text-secondary, #999);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:color .15s,background .15s;transition:background .2s ease,border-color .2s ease,color .2s ease}.chat-quick-attach:hover{color:var(--accent);background:rgba(var(--accent-rgb, 66, 133, 244),.1)}.chat-quick-attachment-preview{position:absolute;bottom:100%;left:8px;margin-bottom:8px;display:inline-block;width:fit-content}.chat-quick-attachment-preview img{max-width:140px;max-height:100px;border-radius:10px;object-fit:cover;display:block}.chat-quick-attachment-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;border:none;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}.chat-quick-attachment-remove .material-icons{font-size:14px}.chat-quick-attachment-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000059;border-radius:10px;pointer-events:none}.chat-quick-attachment-ring{width:36px;height:36px;animation:qaSpin 1.5s linear infinite}.chat-quick-attachment-ring circle:nth-child(2){transition:stroke-dasharray .25s ease}@keyframes qaSpin{to{transform:rotate(360deg)}}.chat-quick-attachment-pct{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff}.chat-quick-attachment-done{position:absolute;bottom:4px;right:4px;color:#4caf50;font-size:18px!important;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));animation:qaDoneIn .3s ease}@keyframes qaDoneIn{0%{transform:scale(0)}to{transform:scale(1)}}.chat-quick-drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:18px 14px;background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.2),rgba(var(--accent-rgb, 59, 130, 246),.05)),#00000073;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:2px dashed rgba(var(--accent-rgb, 59, 130, 246),.4);border-radius:22px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s;animation:qaDropIn .2s ease;position:absolute;bottom:100%;left:0;right:0;margin-bottom:8px;text-shadow:0 1px 3px rgba(0,0,0,.5)}.chat-quick-drop-zone:hover{background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.3),rgba(var(--accent-rgb, 59, 130, 246),.1)),#00000080;border-color:rgba(var(--accent-rgb, 59, 130, 246),.6)}.chat-quick-drop-zone .material-icons{font-size:26px}.chat-quick-drop-zone .drop-zone-formats{font-size:11px;font-weight:400;opacity:.55;letter-spacing:.5px}@keyframes qaDropIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.chat-quick-attach--active{color:var(--accent)!important;background:rgba(var(--accent-rgb, 66, 133, 244),.12)!important;border-radius:50%}.chat-quick-attach .chat-gif-btn-label{font-size:10px;font-weight:700;line-height:1;letter-spacing:.3px;border:1.5px solid currentColor;border-radius:3px;padding:1.5px 2.5px .5px}.chat-quick-gif-popup{position:absolute;bottom:100%;left:0;right:0;margin-bottom:8px;z-index:120}.chat-quick-gif-popup .gif-picker{width:100%!important;max-width:100%!important;border-radius:22px!important;box-sizing:border-box!important}.chat-quick-room-input{flex:1;min-width:0;height:34px;border-radius:0;border:none;background:transparent;color:var(--text);padding:0 8px;font-size:13px;outline:none;box-sizing:border-box}.chat-quick-room-input::placeholder{color:var(--text-secondary, #999)}.chat-quick-room-send{flex:0 0 auto;width:38px;height:38px;padding:0;border-radius:50%;border:none;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,transform .1s}.chat-quick-room-send:hover:not(:disabled){background:var(--accent-2)}.chat-quick-room-send:active:not(:disabled){transform:scale(.92)}.chat-quick-room-send:disabled{opacity:.4;cursor:default}.chat-quick-room-send .material-icons{font-size:18px;margin-left:1px}.chat-collapsed-main{position:absolute;left:50%;transform:translate(-50%);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:color .2s ease;color:var(--text)}.chat-panel.collapsed .chat-collapsed-main:hover{color:var(--accent)}.chat-panel.collapsed .chat-collapsed-main:focus-visible{outline:none;color:var(--accent)}.chat-panel.collapsed .chat-collapsed-main .material-icons{font-size:20px;color:var(--accent)}.chat-panel.collapsed .chat-collapsed-content .btn.chat-collapsed-exit-btn,.chat-panel.collapsed .chat-collapsed-content .chat-collapsed-exit-btn.btn,.chat-panel.collapsed .chat-collapsed-exit-btn{position:absolute!important;right:0!important;top:50%!important;transform:translateY(-50%)!important;display:inline-flex!important;align-items:center!important;gap:6px!important;padding:8px 14px!important;font-size:14px!important;font-weight:600!important;min-width:80px!important;height:36px!important;box-sizing:border-box!important;justify-content:center!important;flex-shrink:0!important;border-radius:8px!important;margin:0!important}.chat-panel.collapsed .chat-collapsed-content .btn.chat-collapsed-exit-btn:hover,.chat-panel.collapsed .chat-collapsed-content .chat-collapsed-exit-btn.btn:hover,.chat-panel.collapsed .chat-collapsed-exit-btn:hover{background:var(--chip-active)!important;border-color:transparent!important;color:var(--chip-active-text, white)!important}.chat-collapsed-exit-btn .material-icons{font-size:18px}@media (min-width: 769px){.chat-panel.collapsed .chat-collapsed-content{padding:8px!important;gap:8px!important}.chat-panel.collapsed .chat-collapsed-content .btn.chat-collapsed-btn{display:inline-flex!important;align-items:center!important;gap:6px!important;padding:7px 20px!important;font-size:13px!important;font-weight:500!important;flex:1!important;height:38px!important;border-radius:22px!important;box-sizing:border-box!important;justify-content:center!important;margin:0!important;position:static!important;transform:none!important}.chat-panel.collapsed .chat-collapsed-content .btn.chat-collapsed-btn:hover{background:var(--chip-active)!important;border-color:transparent!important;color:var(--chip-active-text, white)!important}.chat-panel.collapsed .chat-collapsed-content .btn.chat-collapsed-btn .material-icons{font-size:18px}}.chat-collapsed-label{font-weight:600;letter-spacing:.02em;font-size:14px}.chat-collapsed-buttons,.chat-collapsed-users-count{display:flex;align-items:center;gap:8px}@media (max-width: 768px){.chat-panel.collapsed .chat-collapsed-content{display:none!important}}.chat-panel.collapsed .chat-container,.chat-panel.collapsed .chat-tabs,.chat-panel.collapsed .chat-panel-header,.chat-panel.collapsed .chat-resize-corner,.chat-panel.collapsed .chat-drag-handle{display:none}@media (min-width: 769px){.chat-panel.collapsed .chat-resize-handle{display:none!important}}@media (max-width: 768px){.chat-panel-header{padding:12px}.chat-minimize-btn,.chat-exit-btn-inner,.chat-users-btn{padding:6px 10px;font-size:12px}.chat-panel.collapsed{width:100%!important;left:0!important;right:0!important;transform:none!important;bottom:-100%!important;border-radius:0!important;padding:0!important;height:0!important;min-height:0!important;overflow:hidden!important;opacity:0!important;pointer-events:none!important}.chat-collapsed-label{font-size:13px}}.dice-modal{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:1100;display:flex;align-items:center;justify-content:center;padding:20px}.dice-modal-content{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:24px;width:min(420px,100%);box-shadow:0 20px 50px #0006}.dice-modal-title{font-size:20px;font-weight:700;margin-bottom:20px;text-align:center}.dice-result-area{display:none;text-align:center;margin-bottom:20px}.dice-result-area.rolling{display:block}.dice-result-display{font-size:48px;font-weight:900;color:var(--accent);min-height:60px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.dice-result-display.dice-spinning{animation:diceSpin .2s infinite linear}.dice-result-display.numbers-rolling{animation:numbersRoll .1s infinite}.dice-result-display.final{animation:diceFinal .6s ease-out}@keyframes diceSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes numbersRoll{0%{opacity:.4}to{opacity:1}}@keyframes diceFinal{0%{transform:scale(.9)}70%{transform:scale(1.05)}to{transform:scale(1)}}.dice-result-label{font-size:14px;color:var(--muted)}.dice-range-inputs{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}.dice-input-group{display:flex;flex-direction:column;gap:6px}.dice-input-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase}.dice-input{padding:10px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px}.dice-presets{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:20px}.dice-preset-btn{padding:10px;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-weight:600;cursor:pointer;transition:all .2s ease}.dice-preset-btn:hover:not(:disabled){background:var(--panel);border-color:var(--accent)}.dice-preset-btn:disabled{opacity:.5;cursor:not-allowed}.dice-modal-actions{display:flex;justify-content:flex-end;gap:12px}.dice-modal-actions.rolling{opacity:.7;pointer-events:none}.btn-accent{background:var(--accent);color:var(--chip-active-text, white);border:none;border-radius:8px;padding:10px 20px;font-weight:600;cursor:pointer;transition:background .2s ease}.btn-accent:disabled{opacity:.6;cursor:not-allowed}.btn-accent:not(:disabled):hover{background:var(--accent-2, #2563eb)}.chat-input-actions{display:inline-flex;align-items:center;gap:8px;margin-right:8px}.btn-dice{background:var(--panel-2);color:var(--text);padding:8px 12px;border:1px solid var(--border);border-radius:8px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,border-color .2s ease}.btn-dice .material-icons{font-size:20px}.btn-dice:hover{background:var(--panel);border-color:var(--accent)}.btn-voice-livekit{background:var(--panel-2);color:var(--text);padding:8px 12px;border:1px solid var(--border);border-radius:999px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}.btn-voice-livekit .material-icons{font-size:20px}.btn-voice-livekit.recording{background:#ef4444;color:#fff;border-color:#dc2626;animation:voicePulse 1s ease-in-out infinite}.btn-voice-livekit:disabled{opacity:.45;cursor:not-allowed}@media (max-width: 768px){.chat-input-actions{gap:2px;margin-right:6px;flex-shrink:0;display:flex;align-items:center}.btn-dice{padding:6px 8px;min-width:36px;min-height:40px;width:36px;display:flex;align-items:center;justify-content:center}.btn-dice .material-icons{font-size:18px}.btn-voice-livekit{padding:6px 8px;min-width:36px;min-height:40px;width:36px;display:flex;align-items:center;justify-content:center}.btn-voice-livekit .material-icons{font-size:18px}}@keyframes voicePulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.chat-toggle-btn{position:fixed;bottom:0;left:0;right:0;width:100%;height:56px;background:var(--panel);border-top:1px solid var(--border);border-radius:20px 20px 0 0;display:flex;align-items:center;justify-content:center;gap:0;cursor:pointer;z-index:1001;box-shadow:0 -4px 20px #00000026,0 -2px 8px #0000001a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.4,0,.2,1);font-size:16px;font-weight:600;color:var(--text);border:none;outline:none;padding:0;padding-bottom:env(safe-area-inset-bottom,0)}.chat-toggle-btn-room{height:auto;min-height:calc(56px + env(safe-area-inset-bottom));display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;padding-top:6px;padding-bottom:env(safe-area-inset-bottom,0)}.chat-toggle-btn-room:before{top:4px}.room-quick-actions{position:fixed;right:10px;bottom:calc(150px + env(safe-area-inset-bottom,0px));z-index:1002;display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;background:#00000059;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:28px;box-shadow:0 2px 12px #0003}.room-quick-actions>button,.room-quick-actions>.gesture-btn-wrap>button{width:42px;height:42px;border-radius:50%;border:none;background:#ffffff26;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,transform .15s ease;padding:0}.room-quick-actions>button:hover,.room-quick-actions>.gesture-btn-wrap>button:hover{background:#ffffff47}.room-quick-actions>button:active,.room-quick-actions>.gesture-btn-wrap>button:active{transform:scale(.92);background:#ffffff59}.room-quick-actions>button .material-icons,.room-quick-actions>.gesture-btn-wrap>button .material-icons{font-size:22px}.room-quick-actions-chat-btn{position:relative}.room-quick-actions-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;background:#ff3b30;color:#fff;font-size:11px;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 2px 6px #ff3b3066;pointer-events:none}.gesture-btn-wrap{position:relative;flex:0 0 42px;width:42px;height:42px}@media (min-width: 769px){.room-quick-actions{right:12px;bottom:130px}}.chat-toggle-btn-actions{display:flex;flex:0 0 56px;width:100%;height:56px}.chat-toggle-btn-room .chat-quick-room-form{flex:0 0 auto;padding:10px 12px 8px;width:100%;box-sizing:border-box}.chat-toggle-btn-room .chat-quick-capsule{padding:4px 8px}.chat-toggle-btn-room .chat-quick-room-input{flex:1;height:36px;font-size:14px}.chat-toggle-btn-room .chat-quick-room-send{width:42px;height:42px}.chat-toggle-btn-room .chat-quick-attach{width:36px;height:36px}.chat-toggle-btn:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:36px;height:4px;background:var(--border);border-radius:2px;opacity:.6}.chat-toggle-btn-actions button{flex:1;height:100%;background:transparent;border:none;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;transition:all .2s cubic-bezier(.4,0,.2,1);border-right:1px solid var(--border);position:relative;padding:8px 4px}.chat-toggle-btn-actions button:last-child{border-right:none}.chat-toggle-btn-actions button:hover{background:var(--panel-2);color:var(--accent)}.chat-toggle-btn-actions button:active{background:var(--chip);transform:scale(.98)}.chat-toggle-btn-actions button .material-icons{font-size:22px;transition:transform .2s ease}.chat-toggle-btn-actions button:hover .material-icons{transform:scale(1.1)}.chat-toggle-btn-actions button .chat-toggle-btn-text{font-size:11px;letter-spacing:.3px;opacity:.9;line-height:1.2}.chat-toggle-btn-actions button:not(.chat-toggle-chat-btn){font-size:12px}.chat-toggle-btn:hover{box-shadow:0 -6px 24px #0003,0 -2px 8px #00000026}.chat-toggle-btn:focus{background:var(--panel);outline:none}.chat-toggle-btn:active{background:var(--panel-2)}@media (min-width: 769px){.chat-toggle-btn{display:none!important}}@media (max-width: 768px){.chat-toggle-btn{display:none!important}}@media (min-width: 769px){.room-exit-button{display:none!important}}@media (max-width: 768px){.container.room-layout .room-exit-button{display:none!important}.room-exit-button{top:12px!important;right:12px!important;min-width:96px!important;height:40px!important;padding:0 16px!important}}:root{--mobile-panel-h: 64px;--mobile-panel-bottom: 20px;--mobile-panel-space: calc(var(--mobile-panel-h) + var(--mobile-panel-bottom))}.mobile-bottom-panel{position:fixed;bottom:20px;left:20px;right:20px;width:auto;height:64px;min-height:64px;background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.35),rgba(var(--accent-rgb, 59, 130, 246),.15),rgba(var(--accent-rgb, 59, 130, 246),.25)),#0f0f14a6;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border:.5px solid rgba(var(--accent-rgb, 59, 130, 246),.35);border-radius:28px;display:flex;align-items:center;justify-content:center;gap:0;z-index:1000;box-shadow:0 10px 40px #0000004d,0 4px 16px rgba(var(--accent-rgb, 59, 130, 246),.2);padding-bottom:env(safe-area-inset-bottom,0);overflow:hidden;transform:translateZ(0);-webkit-transform:translateZ(0)}[data-theme=light] .mobile-bottom-panel{background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.25),rgba(var(--accent-rgb, 59, 130, 246),.1),rgba(var(--accent-rgb, 59, 130, 246),.18)),#ffffffbf;border:.5px solid rgba(var(--accent-rgb, 59, 130, 246),.25);box-shadow:0 10px 40px #00000014,0 4px 16px rgba(var(--accent-rgb, 59, 130, 246),.12)}@supports not (backdrop-filter: blur(20px)){.mobile-bottom-panel{background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.4),rgba(var(--accent-rgb, 59, 130, 246),.25)),#0f0f14eb;backdrop-filter:none;-webkit-backdrop-filter:none}[data-theme=light] .mobile-bottom-panel{background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.3),rgba(var(--accent-rgb, 59, 130, 246),.18)),#ffffffeb}}.mobile-panel-btn{flex:1;height:100%;min-height:60px;background:transparent;border:none;color:#ffffffd9;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;padding:8px 12px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border-radius:12px;margin:4px}[data-theme=light] .mobile-panel-btn{color:#000000bf}.mobile-panel-btn:focus-visible{outline:none}.mobile-panel-btn:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:0;height:3px;background:var(--accent);border-radius:0 0 3px 3px;transition:width .2s cubic-bezier(.4,0,.2,1);opacity:0}.mobile-panel-btn:hover:before,.mobile-panel-btn:active:before{width:40px;opacity:1}@media (hover: hover) and (pointer: fine){.mobile-panel-btn:hover{background:#ffffff1a;color:#fff}[data-theme=light] .mobile-panel-btn:hover{background:#0000000f;color:#000}}.mobile-panel-btn:active{background:#ffffff26;transform:scale(.96)}[data-theme=light] .mobile-panel-btn:active{background:#0000001a}@media (hover: none){.mobile-panel-btn:hover,[data-theme=light] .mobile-panel-btn:hover{background:transparent}}.mobile-panel-btn.active{background:rgba(var(--accent-rgb, 59, 130, 246),.25);color:var(--accent)}.mobile-panel-btn.active:before{width:40px;opacity:1}.mobile-panel-btn.active .mobile-panel-btn-text{opacity:1;color:var(--accent)}[data-theme=light] .mobile-panel-btn.active{background:rgba(var(--accent-rgb, 59, 130, 246),.15)}.mobile-panel-btn .material-icons{font-size:24px;transition:all .2s cubic-bezier(.4,0,.2,1);line-height:1}.mobile-panel-btn:hover .material-icons{transform:scale(1.1)}.mobile-panel-btn:active .material-icons{transform:scale(.95)}.mobile-panel-btn-text{font-size:11px;font-weight:500;letter-spacing:.3px;opacity:.7;line-height:1.2;transition:opacity .2s ease}.mobile-panel-btn:hover .mobile-panel-btn-text{opacity:1}.mobile-panel-exit-btn{color:#ef4444}.mobile-panel-exit-btn:before{background:#ef4444}.mobile-panel-exit-btn:hover{background:#ef44441a;color:#dc2626}.mobile-panel-exit-btn:active{background:#ef444426}@media (min-width: 769px){.mobile-bottom-panel{display:none!important}}@media (max-width: 768px){.mobile-bottom-panel{position:fixed!important;bottom:20px!important;left:20px!important;right:20px!important}.mobile-bottom-panel-room{flex-direction:column;height:auto;min-height:auto;padding:0!important;gap:0;overflow:hidden}.mobile-quick-room-form{display:flex;gap:6px;width:100%;align-items:center;padding:4px 8px;box-sizing:border-box;border-bottom:.5px solid rgba(255,255,255,.1);transition:padding .15s ease}[data-theme=light] .mobile-quick-room-form{border-bottom-color:#0000000f}.mobile-quick-room-form-focused{border-bottom:none;padding:4px 8px}.mobile-bottom-panel-keyboard{bottom:0!important;left:0!important;right:0!important;border-radius:20px 20px 0 0!important}.mobile-quick-capsule{flex:1;min-width:0;display:flex;align-items:center;gap:2px;background:#ffffff14;border:1px solid var(--border);border-radius:22px;padding:2px 6px;transition:border-color .2s}[data-theme=light] .mobile-quick-capsule{background:#0000000a}.mobile-quick-capsule:focus-within{border-color:var(--accent)}.mobile-quick-capsule-btn{flex:0 0 auto;width:34px;height:34px;padding:0;border-radius:50%;border:none;background:none;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:color .15s,background .15s}.mobile-quick-capsule-btn:hover,.mobile-quick-capsule-btn:active{color:var(--accent);background:rgba(var(--accent-rgb, 66, 133, 244),.1)}.mobile-quick-capsule-btn--active{color:var(--accent)!important;background:rgba(var(--accent-rgb, 66, 133, 244),.12)!important}.mobile-quick-capsule-btn .material-icons{font-size:20px}.mobile-quick-gif-label{font-size:10px;font-weight:700;line-height:1;letter-spacing:.3px;border:1.5px solid currentColor;border-radius:4px;padding:2px 3px 1px}.mobile-quick-room-input{flex:1;min-width:0;height:34px;border-radius:0;border:none;background:transparent;color:var(--text);padding:0 8px;font-size:14px;outline:none;box-sizing:border-box}.mobile-quick-room-input::placeholder{color:#ffffff80}[data-theme=light] .mobile-quick-room-input::placeholder{color:#0006}.mobile-quick-attachment-preview{position:absolute;bottom:100%;left:12px;right:12px;margin-bottom:8px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:8px;display:flex;align-items:center;gap:8px}.mobile-quick-attachment-preview img{max-width:80px;max-height:60px;border-radius:8px;object-fit:cover}.mobile-quick-attachment-remove{width:24px;height:24px;border-radius:50%;border:none;background:var(--danger, #ef4444);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-left:auto}.mobile-quick-attachment-remove .material-icons{font-size:16px}.mobile-quick-room-send{flex:0 0 auto;width:40px;height:40px;padding:0;border-radius:50%;border:none;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.mobile-quick-room-send:hover:not(:disabled){filter:brightness(1.1);transform:scale(1.05)}.mobile-quick-room-send:active:not(:disabled){transform:scale(.95)}.mobile-quick-room-send:disabled{opacity:.4;cursor:default}.mobile-quick-room-send .material-icons{font-size:20px}.mobile-panel-actions{display:flex;width:100%;height:56px;min-height:56px;flex-shrink:0}.mobile-panel-actions .mobile-panel-btn{margin:0;border-radius:0;min-height:56px;height:56px;padding:4px 8px;gap:2px}.mobile-panel-actions .mobile-panel-btn:first-child{border-bottom-left-radius:28px}.mobile-panel-actions .mobile-panel-btn:last-child{border-bottom-right-radius:28px}.mobile-panel-actions .mobile-panel-btn .material-icons{font-size:22px}.mobile-panel-actions .mobile-panel-btn-text{font-size:10px}}.mobile-sheet-overlay{position:fixed!important;width:100%!important;height:100%!important;background:#00000080!important;z-index:2198!important;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);will-change:opacity;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:translateZ(0);-webkit-transform:translateZ(0);margin:0!important;padding:0!important;border:none!important;top:0!important;right:0!important;bottom:0!important;left:0!important;pointer-events:none}.mobile-sheet-overlay[data-state=open]{pointer-events:auto}.mobile-sheet-overlay[data-state=closed]{pointer-events:none}@supports (-webkit-touch-callout: none){.mobile-sheet-overlay{backdrop-filter:none;-webkit-backdrop-filter:none}}.mobile-menu-sheet,.mobile-chat-sheet{position:fixed;bottom:0;left:0;right:0;width:100%;max-height:90vh;background:var(--panel);border-radius:24px 24px 0 0;border:1px solid var(--border);border-bottom:none;z-index:2199;box-shadow:0 -4px 20px #00000026;overflow:hidden;display:flex;flex-direction:column}[vaul-drawer]{background:var(--panel)!important;border-radius:24px 24px 0 0!important;border:1px solid var(--border)!important;border-bottom:none!important}[vaul-overlay]{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100%!important;height:100%!important;background:#00000080!important;z-index:2198!important;pointer-events:none}[vaul-overlay][data-state=open]{pointer-events:auto}[vaul-overlay][data-state=closed]{pointer-events:none}[vaul-drawer][data-state=closed]{visibility:hidden!important;pointer-events:none!important}[vaul-handle]{background:var(--border)!important;opacity:.4!important;width:40px!important;height:4px!important;border-radius:2px!important;margin-top:10px!important;transform:translateZ(0)!important;-webkit-transform:translateZ(0)!important}@supports (-webkit-touch-callout: none){.mobile-menu-sheet,.mobile-chat-sheet{box-shadow:0 -2px 10px #0000001a;-webkit-box-shadow:0 -2px 10px rgba(0,0,0,.1)}[vaul-overlay]{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}}.mobile-sheet-header{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:8px 0 12px;background:var(--panel);border-bottom:none}.mobile-sheet-resize-handle{position:relative;width:100%;height:24px;cursor:ns-resize;touch-action:none;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:10;background:var(--panel);border-bottom:1px solid var(--border)}.mobile-sheet-resize-handle:active{background:var(--hover)}.mobile-sheet-drag-handle{width:36px;height:4px;background:var(--border);border-radius:2px;opacity:.6;flex-shrink:0;pointer-events:none}.mobile-chat-sheet.resizing,.mobile-chat-sheet.resizing *{transition:none!important}.mobile-sheet-title{padding:0 20px;font-size:18px;font-weight:800;color:var(--text);text-align:center}.mobile-sheet-title--logo{display:flex;align-items:center;justify-content:center}.mobile-menu-logo{height:44px;width:auto;max-width:78vw;object-fit:contain;display:block}.mobile-sheet-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:0;height:100%;transform:translateZ(0);-webkit-transform:translateZ(0);will-change:scroll-position;position:relative}@supports (-webkit-touch-callout: none){.mobile-sheet-content{-webkit-overflow-scrolling:touch}}.mobile-chat-content{display:flex;flex-direction:column;height:100%}.mobile-chat-wrapper{display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.mobile-chat-wrapper .chat-panel-header{flex-shrink:0;border-bottom:1px solid var(--border);background:var(--panel)}.mobile-chat-wrapper .chat-header-top{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;gap:8px;min-height:48px}.mobile-chat-wrapper .chat-header-left,.mobile-chat-wrapper .chat-header-right{flex-shrink:0;display:flex;align-items:center}.mobile-chat-wrapper .chat-panel-title{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;font-size:15px;font-weight:600;color:var(--text);min-width:0;padding:0 8px}.mobile-chat-wrapper .chat-panel-title .material-icons{font-size:18px;flex-shrink:0;opacity:.8}.mobile-chat-wrapper .chat-panel-title span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.mobile-chat-wrapper .chat-tabs-toggle-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;font-size:13px;min-height:32px;border-radius:6px}.mobile-chat-wrapper .chat-tabs-toggle-btn .material-icons{font-size:18px}.mobile-chat-wrapper .chat-tabs-toggle-text{display:none}@media (min-width: 360px){.mobile-chat-wrapper .chat-tabs-toggle-text{display:inline}}.mobile-chat-wrapper .chat-tabs-toggle-badge{background:var(--accent);color:#fff;border-radius:10px;padding:2px 6px;font-size:10px;font-weight:600;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;line-height:1}.mobile-chat-wrapper .chat-minimize-btn{padding:6px 12px;font-size:13px;min-height:32px;border-radius:6px}.mobile-chat-wrapper .chat-container{flex:1;display:flex;flex-direction:row;position:relative;overflow:hidden;min-height:0}.mobile-chat-wrapper .chat-tabs-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:10;opacity:0;pointer-events:none;transition:opacity .3s ease}.mobile-chat-wrapper .chat-tabs-overlay.open{opacity:1;pointer-events:all}.mobile-chat-wrapper .chat-tabs-wrapper{position:absolute;top:0;left:0;bottom:0;width:280px;max-width:85vw;background:var(--panel);border-right:1px solid var(--border);z-index:11;transform:translate(-100%);transition:transform .3s ease;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.mobile-chat-wrapper .chat-tabs-wrapper.open{transform:translate(0)}.mobile-chat-wrapper .chat-messages{flex:1;min-width:0;display:flex;flex-direction:column}.mobile-menu-content{padding:0}.mobile-menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px 4px;padding:12px 16px 20px}.mobile-menu-grid-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 4px;background:none;border:none;cursor:pointer;color:var(--text);font-family:inherit;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;outline:none;transition:transform .15s ease}.mobile-menu-grid-item:active{transform:scale(.92)}.mobile-menu-grid-circle{position:relative;width:68px;height:68px;border-radius:22px;background:var(--panel-2);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all .2s ease}.mobile-menu-grid-circle .material-icons{font-size:26px;color:var(--muted);transition:color .2s ease}.mobile-menu-grid-circle.has-thumb{overflow:hidden;padding:0;border-color:transparent}.mobile-menu-grid-thumb{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}.mobile-menu-grid-item.active .mobile-menu-grid-circle{background:var(--accent);border-color:var(--accent);box-shadow:0 2px 12px rgba(var(--accent-rgb, 59,130,246),.35)}.mobile-menu-grid-item.active .mobile-menu-grid-circle .material-icons{color:var(--chip-active-text, #fff)}.mobile-menu-grid-label{font-size:11px;font-weight:500;text-align:center;line-height:1.25;color:var(--muted);max-width:80px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;transition:color .2s ease}.mobile-menu-grid-item.active .mobile-menu-grid-label{color:var(--accent);font-weight:600}.mobile-menu-grid-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}@media (hover: none){.mobile-menu-grid-item:not(.active):hover .mobile-menu-grid-circle,.mobile-menu-grid-item:not(.active):focus .mobile-menu-grid-circle{background:var(--panel-2);border-color:var(--border)}}@supports (-webkit-touch-callout: none){.mobile-menu-grid-item{outline:none!important}.mobile-menu-grid-item:not(.active):hover .mobile-menu-grid-circle,.mobile-menu-grid-item:not(.active):active .mobile-menu-grid-circle,.mobile-menu-grid-item:not(.active):focus .mobile-menu-grid-circle{background:var(--panel-2);border-color:var(--border)}}.mobile-menu-sheet>div,.mobile-chat-sheet>div{background:var(--panel)!important}.mobile-menu-sheet~div[style*="position: fixed"],.mobile-chat-sheet~div[style*="position: fixed"]{backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);pointer-events:none!important}@media (prefers-reduced-motion: reduce){.mobile-menu-sheet,.mobile-chat-sheet{transition:transform .2s ease!important}.mobile-sheet-overlay{transition:opacity .15s ease!important}}@media (min-resolution: 120dpi){.mobile-menu-sheet,.mobile-chat-sheet{will-change:transform,height}}@supports (padding: max(0px)){.mobile-bottom-panel,.mobile-menu-sheet,.mobile-chat-sheet{padding-bottom:max(env(safe-area-inset-bottom,0px),0px)}}.mobile-panel-notifications-btn{position:relative}.mobile-panel-badge{position:absolute;top:4px;right:50%;transform:translate(16px);min-width:18px;height:18px;padding:0 5px;background:#ff3b30;color:#fff;font-size:11px;font-weight:600;border-radius:9px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #ff3b3066;line-height:1;animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:translate(14px) scale(1)}50%{transform:translate(14px) scale(1.1)}}.mobile-notifications-sheet{max-height:85vh!important}.mobile-notifications-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px}.mobile-notifications-title{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;color:var(--text);margin:0}.mobile-notifications-title .material-icons{font-size:24px;color:var(--accent)}.mobile-notifications-mark-all{display:inline-flex;align-items:center;background:transparent;border:none;color:var(--accent);font-size:12px;font-weight:500;cursor:pointer;padding:6px 12px;border-radius:6px;transition:background-color .15s ease}.mobile-notifications-mark-all:hover{background:rgba(var(--accent-rgb, 255, 204, 0),.1)}.mob-notif-tabs{display:flex;gap:4px;padding:0 20px 10px}.mob-notif-tab{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:8px 0;border:none;border-radius:8px;background:transparent;color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;transition:background-color .15s,color .15s}.mob-notif-tab:active{background:var(--panel-2)}.mob-notif-tab.active{background:var(--chip-active);color:var(--chip-active-text, #fff)}.mob-notif-tab-badge{min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1}.mob-notif-tab.active .mob-notif-tab-badge{background:#ffffff40}.mob-notif-group-label{padding:10px 20px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.mobile-notifications-list{flex:1;overflow-y:auto;padding:4px 0}.mobile-notifications-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 20px;text-align:center;color:var(--muted);font-size:14px}.mobile-notification-item{display:flex;align-items:flex-start;gap:12px;width:100%;padding:12px 20px;background:transparent;border:none;cursor:pointer;transition:background-color .12s ease;text-align:left;position:relative}.mobile-notification-item:active{background:var(--panel-2)}.mobile-notification-item.unread{background:rgba(var(--accent-rgb, 255, 204, 0),.04)}.mobile-notification-item.unread:active{background:rgba(var(--accent-rgb, 255, 204, 0),.08)}.mobile-notification-avatar{width:44px;height:44px;border-radius:12px;overflow:visible;background:var(--panel-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.mobile-notification-avatar img{width:44px;height:44px;border-radius:12px;object-fit:cover;display:block}.mobile-notification-avatar>.material-icons{font-size:22px}.mob-notif-type-badge{position:absolute;bottom:-3px;right:-3px;width:18px;height:18px;border-radius:6px;display:flex;align-items:center;justify-content:center;border:2px solid var(--panel)}.mob-notif-type-badge .material-icons{font-size:10px;color:#fff}.mobile-notification-content{flex:1;min-width:0}.mobile-notification-text{font-size:14px;color:var(--text);line-height:1.4}.mobile-notification-from{font-weight:600;color:var(--accent)}.mob-notif-preview{margin-top:3px;padding:5px 8px;border-radius:6px;background:var(--panel-2);font-size:12.5px;color:var(--muted);line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:italic}.mobile-notification-time{font-size:12px;color:var(--muted);margin-top:4px}.mobile-notification-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;flex-shrink:0;margin-top:8px;box-shadow:0 0 0 3px rgba(var(--accent-rgb, 255, 204, 0),.15)}.mobile-notification-reply-block{margin-top:6px}.mobile-notification-reply-btn{display:inline-flex;align-items:center;padding:5px 14px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text);font-size:12.5px;font-weight:500;cursor:pointer}.mobile-notification-reply-btn:active{background:var(--panel-2)}.mobile-notification-reply-input{width:100%;min-height:52px;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-size:13px;font-family:inherit;resize:vertical;box-sizing:border-box}.mobile-notification-reply-input:focus{outline:none;border-color:var(--accent)}.mobile-notification-reply-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:6px}.mobile-notification-reply-cancel,.mobile-notification-reply-send{padding:7px 12px;border-radius:8px;border:none;font-size:13px;font-weight:500;cursor:pointer}.mobile-notification-reply-cancel{background:transparent;color:var(--muted)}.mobile-notification-reply-send{background:var(--accent);color:var(--chip-active-text, #fff)}.mobile-notification-reply-send:disabled{opacity:.4;cursor:default}.mobile-quick-gif-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:#0006;display:flex;align-items:flex-end;padding:0 20px calc(20px + var(--mobile-panel-h, 64px) + 8px) 20px;animation:mobileGifOverlayIn .15s ease}.mobile-quick-gif-popup{width:100%;max-width:100%;box-sizing:border-box;animation:mobileGifFadeIn .2s cubic-bezier(.34,1.4,.64,1)}.mobile-quick-gif-popup .gif-picker{width:100%!important;max-width:100%!important;max-height:50vh;min-height:0;border-radius:28px!important;border:.5px solid rgba(var(--accent-rgb, 59, 130, 246),.35)!important;box-shadow:0 10px 40px #0000004d,0 4px 16px rgba(var(--accent-rgb, 59, 130, 246),.2)!important;overflow:hidden!important;box-sizing:border-box!important}@keyframes mobileGifOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes mobileGifFadeIn{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.room-canvas{width:100%;height:100%;position:absolute;top:0;left:0;overflow:hidden;touch-action:none}.room-canvas-root{position:relative;isolation:isolate}.room-canvas-backdrop{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;z-index:0;background-size:cover;background-position:center;background-repeat:no-repeat;filter:blur(2px);pointer-events:none;transform:translateZ(0)}.room-canvas-root>canvas{position:relative;z-index:1;display:block;width:100%;height:100%;touch-action:none}.room-canvas canvas{display:block;width:100%;height:100%;touch-action:none}.game-window-container{position:relative;border-radius:16px;border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 40px #00000080,0 0 0 1px #ffffff0d inset;overflow:hidden;display:flex;flex-direction:column;max-height:500px;z-index:1}.game-window-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#14141ceb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:-1;border-radius:inherit}.game-creation-window .game-window-container{min-height:300px}.game-window-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.06);cursor:grab}.game-window-header:active{cursor:grabbing}.game-window-title{margin:0;font-size:15px;font-weight:700;color:#fff;letter-spacing:.2px}.game-window-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ff464626;border:1px solid rgba(255,70,70,.3);border-radius:8px;color:#ff6b6b;font-size:20px;font-weight:600;cursor:pointer;transition:all .15s ease;line-height:1}.game-window-close:hover{background:#ff464640;border-color:#ff464680;transform:scale(1.05)}.game-window-close:active{transform:scale(.95)}.game-window-content{padding:16px;overflow-y:auto;flex:1;min-height:0}.game-content-area{cursor:default}.game-window-error{padding:10px 14px;margin-bottom:12px;background:#ff464626;border:1px solid rgba(255,70,70,.3);border-radius:8px;color:#ff8a8a;font-size:13px}.game-form-group{margin-bottom:16px}.game-form-label{display:block;margin-bottom:8px;font-size:13px;font-weight:600;color:#ffffffe6}.game-form-hint{font-weight:400;color:#ffffff80;margin-left:8px}.game-form-textarea,.game-form-input{width:100%;padding:12px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:14px;font-family:inherit;resize:vertical;transition:all .15s ease}.game-form-textarea:focus,.game-form-input:focus{outline:none;border-color:var(--accent, #6c5ce7);background:#ffffff14;box-shadow:0 0 0 3px #6c5ce726}.game-form-textarea::placeholder,.game-form-input::placeholder{color:#ffffff59}.game-options-list{display:flex;flex-direction:column;gap:10px}.game-option-row{display:flex;align-items:center;gap:10px}.game-option-radio{width:18px;height:18px;cursor:pointer;accent-color:var(--accent, #6c5ce7)}.game-option-input{flex:1;padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:14px;font-family:inherit;transition:all .15s ease}.game-option-input.full{flex:1}.game-option-input:focus{outline:none;border-color:var(--accent, #6c5ce7);background:#ffffff14}.game-option-input::placeholder{color:#ffffff59}.game-option-remove{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ff46461a;border:1px solid rgba(255,70,70,.2);border-radius:6px;color:#ff6b6b;font-size:18px;cursor:pointer;transition:all .15s ease;flex-shrink:0}.game-option-remove:hover{background:#ff464633;border-color:#ff464666}.game-option-add{padding:8px 14px;margin-top:8px;background:#6c5ce726;border:1px solid rgba(108,92,231,.3);border-radius:8px;color:var(--accent, #6c5ce7);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease;align-self:flex-start}.game-option-add:hover{background:#6c5ce740;border-color:#6c5ce780}.game-rps-info{text-align:center;padding:20px}.game-rps-icons{display:flex;justify-content:center;gap:20px;font-size:36px;margin-bottom:16px}.game-rps-info p{margin:8px 0;color:#ffffffb3;font-size:14px;line-height:1.5}.game-window-actions{display:flex;gap:10px;padding:14px 16px;background:#0003;border-top:1px solid rgba(255,255,255,.06)}.game-btn{flex:1;padding:12px 16px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease;border:none}.game-btn:disabled{opacity:.5;cursor:not-allowed}.game-btn-primary{background:var(--accent, #6c5ce7);color:#fff}.game-btn-primary:hover:not(:disabled){background:var(--accent-hover, #5b4cdb);transform:translateY(-1px)}.game-btn-primary:active:not(:disabled){transform:translateY(0)}.game-btn-secondary{background:#ffffff14;color:#ffffffe6;border:1px solid rgba(255,255,255,.1)}.game-btn-secondary:hover:not(:disabled){background:#ffffff1f;border-color:#fff3}.room-game-card{background:transparent;padding:0}.room-game-card .room-game-header{display:none}.room-game-content{color:#ffffffe6}.room-game-question{font-size:15px;font-weight:500;margin-bottom:16px;color:#fff;line-height:1.4}.room-game-participants{font-size:13px;color:#fff9;margin-bottom:14px}.room-game-options{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.room-game-option{padding:12px 16px;background:#ffffff0d;border:2px solid transparent;border-radius:10px;color:#ffffffe6;font-size:14px;cursor:pointer;transition:all .15s ease;text-align:left}.room-game-option:hover:not(:disabled){background:#ffffff1a;border-color:#6c5ce74d}.room-game-option.selected{background:var(--accent, #6c5ce7);color:#fff;border-color:var(--accent, #6c5ce7)}.room-game-option:disabled{opacity:.6;cursor:not-allowed}.room-game-result{padding:16px;background:#ffffff0d;border-radius:10px;margin-bottom:16px;text-align:center}.room-game-result .correct{color:#4ade80;font-weight:600}.room-game-result .incorrect{color:#f87171;font-weight:600}.room-game-results{margin-top:16px}.room-game-winners{margin-bottom:16px}.room-game-winners h4{margin:0 0 10px;font-size:14px;color:#fffc}.room-game-winner{padding:10px 14px;background:var(--accent, #6c5ce7);color:#fff;border-radius:8px;margin-bottom:6px;font-weight:500}.room-game-my-result{padding:12px;background:#ffffff0d;border-radius:8px;margin-bottom:16px}.room-game-participants-list{margin-top:16px}.room-game-participants-list h4{margin:0 0 10px;font-size:13px;color:#fff9}.room-game-participant-result{padding:8px 0;font-size:13px;color:#fffc;display:flex;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.05)}.room-game-participant-result:last-child{border-bottom:none}.room-game-poll-results{margin-bottom:16px}.room-game-poll-option-result{margin-bottom:14px}.room-game-poll-option-label{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px;color:#ffffffe6}.room-game-poll-bar{height:24px;background:#ffffff0d;border-radius:12px;overflow:hidden;position:relative}.room-game-poll-bar-fill{height:100%;background:var(--accent, #6c5ce7);transition:width .3s ease;border-radius:12px}.room-game-total-votes{font-size:13px;color:#ffffff80;text-align:center;margin-top:10px}.room-game-rps-options{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.room-game-rps-option{padding:14px 16px;background:#ffffff0d;border:2px solid transparent;border-radius:10px;color:#ffffffe6;font-size:15px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:14px}.room-game-rps-option:hover:not(:disabled){background:#ffffff1a;border-color:#6c5ce74d}.room-game-rps-option.selected{background:var(--accent, #6c5ce7);color:#fff;border-color:var(--accent, #6c5ce7)}.room-game-rps-option:disabled{opacity:.6;cursor:not-allowed}.room-game-rps-emoji{font-size:26px}.room-game-rps-results{margin-bottom:16px}.room-game-rps-result-item{padding:10px 14px;background:#ffffff0d;border-radius:8px;margin-bottom:6px;display:flex;justify-content:space-between;align-items:center;font-size:14px}.room-game-card .btn{padding:12px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease;border:none;display:inline-block;text-align:center}.room-game-card .btn-accent{background:var(--accent, #6c5ce7);color:#fff}.room-game-card .btn-accent:hover:not(:disabled){background:var(--accent-hover, #5b4cdb)}.room-game-card .btn-primary{background:#ffffff1a;color:#fff;margin-top:10px}.room-game-card .btn-primary:hover:not(:disabled){background:#ffffff26}.room-game-card .btn:disabled{opacity:.5;cursor:not-allowed}.game-unknown{text-align:center;padding:20px;color:#fff9}.game-window-content::-webkit-scrollbar{width:6px}.game-window-content::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.game-window-content::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.game-window-content::-webkit-scrollbar-thumb:hover{background:#ffffff40}.room-game-quiz-result{display:flex;flex-direction:column;gap:12px}.room-game-result-badge{padding:12px 16px;border-radius:10px;font-weight:700;font-size:16px;text-align:center}.room-game-result-badge.correct{background:#2ed57326;color:#2ed573;border:1px solid rgba(46,213,115,.3)}.room-game-result-badge.incorrect{background:#ff6b6b26;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.room-game-options.answered{pointer-events:none}.room-game-option.disabled{pointer-events:none;opacity:.8}.room-game-option.correct{background:#2ed57333!important;border-color:#2ed57380!important;color:#2ed573!important}.room-game-option.wrong{background:#ff6b6b33!important;border-color:#ff6b6b80!important;color:#ff6b6b!important}.room-game-answers-count{font-size:13px;color:#ffffff80;text-align:center}.room-game-poll-option-result.my-choice .room-game-poll-option-label{color:var(--accent, #6c5ce7);font-weight:600}.room-game-poll-option-result.my-choice .room-game-poll-bar-fill{background:var(--accent, #6c5ce7)}.room-game-status-badge{margin-top:12px;padding:8px 12px;background:#ffffff14;border-radius:8px;font-size:13px;color:#fff9;text-align:center}.room-top-buttons{position:fixed;top:20px;right:20px;z-index:2300;display:flex;align-items:center;gap:8px;flex-direction:row-reverse}.room-games-toggle-btn,.room-env-settings-btn{display:flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 14px;border-radius:10px;border:1px solid var(--border);background:#0009;color:#fff;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 8px 24px #00000059;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:transform .2s ease,box-shadow .2s ease,background .2s ease;min-width:44px;min-height:40px}.room-games-toggle-btn:hover,.room-env-settings-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px #00000073;background:#0f0f14bf}.room-games-toggle-btn .material-icons,.room-env-settings-btn .material-icons{font-size:22px}.room-games-toggle-text{display:inline}.room-games-panel-container{position:fixed;top:80px;right:20px;width:380px;max-height:calc(100vh - 120px);overflow-y:auto;z-index:2300;background:var(--panel);border-radius:12px;box-shadow:0 8px 24px #00000040;border:1px solid var(--border)}.room-game-placing-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:3000;cursor:crosshair;background:#0000001a;pointer-events:auto}.room-game-type-dropdown{position:fixed;top:68px;right:20px;background:#1a1a20d9;border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 12px 40px #00000080,0 0 0 1px #ffffff0d inset;z-index:2400;min-width:200px;overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.room-game-type-dropdown button{display:block;width:100%;padding:12px 16px;background:transparent;border:none;text-align:left;color:#fff;cursor:pointer;font-size:14px;transition:background .2s}.room-game-type-dropdown button:hover{background:#ffffff1a}.room-game-type-dropdown button:not(:last-child){border-bottom:1px solid var(--border)}@media (max-width: 768px){.room-top-buttons{top:12px;right:12px;gap:6px}.room-games-toggle-btn,.room-env-settings-btn{padding:0 12px;font-size:14px;min-width:44px;min-height:40px}.room-games-toggle-btn .material-icons,.room-env-settings-btn .material-icons{font-size:20px}.room-game-type-dropdown{top:56px;right:12px;min-width:160px}.room-games-panel-container{top:56px;right:10px;left:10px;width:auto;max-height:50vh}}.room-page{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;overflow:visible;background:var(--bg);color:var(--text);position:relative}@media (max-width: 768px){.room-page{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100%!important;height:100%!important;overflow:hidden!important}}.room-loading,.room-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;color:var(--muted)}.room-loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:var(--text);font-size:16px;text-align:center;padding:20px}.room-content{flex:1;min-height:0;position:relative;display:flex;flex-direction:column;overflow:hidden}.room-exit-button{position:fixed!important;top:20px!important;right:20px!important;left:auto!important;bottom:auto!important;z-index:2300!important;min-width:96px!important;height:40px!important;justify-content:center!important;box-shadow:0 8px 24px #00000059!important;padding:0 16px!important;font-size:14px!important;font-weight:600!important;margin:0!important;transform:none!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important;cursor:pointer!important;box-sizing:border-box!important}.room-exit-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.canvas-panel{background:var(--character-panel-bg, radial-gradient(60% 80% at 50% 65%, #18202c 0%, #0f1115 80%));position:relative;flex:1;min-height:0;width:100%;height:100%;opacity:0;transition:opacity .3s ease,background .3s ease}.room-perspective-guides{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;touch-action:none;z-index:1200;overflow:hidden}.room-perspective-band{position:absolute;left:0;right:0;background:linear-gradient(to bottom,#4da0ff1a,#4da0ff0a 60%,#ffd24d0f);mix-blend-mode:screen;pointer-events:none}.room-perspective-line{position:absolute;left:0;right:0;height:0;pointer-events:auto;cursor:ns-resize;touch-action:none}.room-perspective-line:before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:#ffffffd9;box-shadow:0 0 0 1px #00000059,0 8px 18px #00000040;opacity:.85}.room-perspective-line:after{content:"";position:absolute;left:0;right:0;top:-1px;height:3px;background-image:repeating-linear-gradient(to right,#0000 0,#0000 10px,#00000059 10px,#00000059 16px);opacity:.55;mix-blend-mode:overlay}.room-perspective-line.horizon:before{background:#4da0fff2}.room-perspective-line.ground:before{background:#ffd24df2}.room-perspective-label{position:absolute;left:12px;top:-20px;padding:6px 10px;border-radius:10px;font-size:14px;font-weight:800;letter-spacing:.2px;color:#ffffffeb;background:#00000073;border:1px solid rgba(255,255,255,.12);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.room-perspective-line.horizon .room-perspective-label{border-color:#4da0ff59}.room-perspective-line.ground .room-perspective-label{border-color:#ffd24d59}.room-hidden-counter{position:absolute;top:calc(50% + 42px);transform:translateY(-50%);background:#0009;border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:0 10px 26px #00000073;padding:6px 10px;display:inline-flex;align-items:center;gap:6px;color:#fff;font-weight:800;font-size:13px;letter-spacing:.1px;pointer-events:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1250}.room-hidden-counter.left{left:8px}.room-hidden-counter.right{right:8px}.room-hidden-counter .material-icons{font-size:18px;line-height:1}.room-hidden-me{position:absolute;top:50%;transform:translateY(-50%);background:#000000b3;border:1px solid rgba(255,255,255,.16);border-radius:14px;box-shadow:0 10px 26px #00000073;padding:7px 11px;display:inline-flex;align-items:center;gap:6px;color:#ffd54f;font-weight:900;font-size:13px;letter-spacing:.1px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1260;cursor:pointer;pointer-events:auto}.room-hidden-me.left{left:8px}.room-hidden-me.right{right:8px}.room-hidden-me .material-icons{font-size:18px;line-height:1}.room-hidden-counter-me{font-weight:900;color:#ffd54f}.canvas-panel.ready{opacity:1}.zoom-hint{position:absolute;top:16px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;pointer-events:none;opacity:0;transition:opacity .3s ease;z-index:1000}.zoom-hint.show{opacity:1}.character-context-menu{display:none;position:fixed;background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0006;z-index:2000;min-width:180px;overflow:hidden}.character-context-menu.visible{display:block}.context-menu-item{padding:12px 16px;color:var(--text);font-size:14px;cursor:pointer;transition:background .2s ease;border:none;background:transparent;width:100%;text-align:left;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}.context-menu-item:last-child{border-bottom:none}.context-menu-item:hover{background:var(--panel-2)}.context-menu-item:active{background:var(--border)}.context-menu-item .material-icons{font-size:18px}.room-page .zoom-hint{top:72px}.room-env-settings-panel{position:fixed;top:68px;left:auto;right:20px;z-index:2300;width:min(300px,calc(100vw - 32px));background:#1a1a20d9;border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 12px 40px #00000080,0 0 0 1px #ffffff0d inset;padding:16px;animation:room-env-slide-down .18s ease;transform-origin:top right;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff}@keyframes room-env-slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.room-env-settings-title{font-weight:800;margin-bottom:10px;color:#fff}.room-env-settings-error{margin:8px 0 10px;color:#ffb3b3;font-size:13px}.room-env-settings-row{display:grid;grid-template-columns:1fr;gap:6px;margin:10px 0;font-size:13px;color:#fff}.room-env-settings-row input[type=range]{width:100%}.room-env-settings-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.room-env-settings-primary,.room-env-settings-secondary{height:36px;padding:0 12px;border-radius:10px;border:1px solid var(--border);cursor:pointer;font-weight:700;display:inline-flex;align-items:center;gap:6px}.room-env-settings-primary{background:var(--accent);color:#fff;border-color:#00000026}.room-env-settings-secondary{background:var(--panel-2);color:var(--text)}.room-env-settings-primary:disabled,.room-env-settings-secondary:disabled{opacity:.7;cursor:default}@media (max-width: 768px){.room-exit-button{top:12px!important;right:12px!important;min-width:96px!important;height:40px!important;padding:0 16px!important}.mobile-menu-button{top:12px!important;left:12px!important}.room-env-settings-panel{top:56px;left:auto;right:12px;width:min(200px,calc(100vw - 16px));padding:8px;border-radius:10px;box-shadow:0 10px 32px #00000073;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.room-page .zoom-hint{top:64px}.room-env-settings-title{font-size:14px;margin-bottom:6px}.room-env-settings-row{gap:4px;margin:6px 0;font-size:11px}.room-env-settings-actions{gap:6px;margin-top:8px;justify-content:space-between}.room-env-settings-primary,.room-env-settings-secondary{height:32px;padding:0 8px;font-size:12px}.room-env-settings-btn-label{display:none}.room-hidden-counter{padding:5px 8px;font-size:12px;border-radius:10px;gap:5px;box-shadow:0 8px 20px #0006}.room-hidden-counter.left{left:6px}.room-hidden-counter.right{right:6px}.room-hidden-me{padding:6px 9px;font-size:12px;border-radius:12px;gap:5px;box-shadow:0 8px 20px #0006}.room-content{overflow:hidden;padding-bottom:0}.canvas-panel{min-height:100vh;min-height:100dvh;height:100vh;height:100dvh}}.room-close-eyes-button{position:absolute;bottom:80px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 24px;background:#0009;color:#fff;border:1px solid var(--border);border-radius:24px;font-size:16px;font-weight:500;cursor:pointer;box-shadow:0 4px 12px #0003;transition:all .2s ease;z-index:100;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.room-close-eyes-button:hover{background:#000000bf;transform:translate(-50%) translateY(-2px);box-shadow:0 6px 16px #0000004d}.room-close-eyes-button:active{transform:translate(-50%) translateY(0);box-shadow:0 2px 8px #0003}.room-close-eyes-button--active{background:#3b82f64d;border-color:var(--accent)}.room-close-eyes-button .material-icons{font-size:24px}.room-close-eyes-lock{position:absolute;bottom:80px;left:calc(50% + 120px);transform:translate(-50%);display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#0009;color:#fff;border:1px solid var(--border);border-radius:50%;cursor:pointer;box-shadow:0 4px 12px #0003;transition:all .2s ease;z-index:101;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:room-lock-pulse 2s ease-in-out infinite}@keyframes room-lock-pulse{0%,to{transform:translate(-50%) scale(1);box-shadow:0 4px 12px #0003}50%{transform:translate(-50%) scale(1.05);box-shadow:0 6px 16px #3b82f666}}.room-close-eyes-lock:hover{background:#3b82f64d;border-color:var(--accent);transform:translate(-50%) scale(1.1);box-shadow:0 8px 20px #3b82f680;animation:none}.room-close-eyes-lock--active{background:#3b82f680;border-color:var(--accent);box-shadow:0 8px 20px #3b82f699;animation:none}.room-close-eyes-lock .material-icons{font-size:24px}.room-wave-button{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 24px;background:var(--accent);color:#fff;border:none;border-radius:24px;font-size:16px;font-weight:500;cursor:pointer;box-shadow:0 4px 12px #0003;transition:all .2s ease;z-index:100}.room-wave-button:hover{background:var(--accent-hover, var(--accent));transform:translate(-50%) translateY(-2px);box-shadow:0 6px 16px #0000004d}.room-wave-button:active{transform:translate(-50%) translateY(0);box-shadow:0 2px 8px #0003}.room-wave-button .material-icons{font-size:24px}.room-wave-button:disabled,.room-wave-button--disabled{opacity:.6;cursor:not-allowed;pointer-events:none}@media (max-width: 768px){.room-close-eyes-button{position:fixed;bottom:250px;left:auto;right:16px;transform:none;padding:14px;border-radius:50%;font-size:14px;z-index:100}.room-close-eyes-button:hover{transform:translateY(-2px)}.room-close-eyes-button:active{transform:translateY(0)}.room-close-eyes-button .material-icons{font-size:24px}.room-close-eyes-button .room-close-eyes-text{display:none}.room-close-eyes-lock{position:fixed;bottom:250px;left:auto;right:80px;transform:none;width:48px;height:48px;animation:room-lock-pulse-mobile 2s ease-in-out infinite}@keyframes room-lock-pulse-mobile{0%,to{transform:scale(1);box-shadow:0 4px 12px #0003}50%{transform:scale(1.05);box-shadow:0 6px 16px #3b82f666}}.room-close-eyes-lock:hover{transform:scale(1.1)}.room-close-eyes-lock--active{animation:none}.room-wave-button{position:fixed;bottom:180px;left:auto;right:16px;transform:none;padding:14px;border-radius:50%;font-size:14px;z-index:100}.room-wave-button:hover{transform:translateY(-2px)}.room-wave-button:active{transform:translateY(0)}.room-wave-button .material-icons{font-size:24px}.room-wave-button .room-wave-text{display:none}}.room-games-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1500;overflow:hidden}.room-games-layer>*{pointer-events:auto}.room-wave-button.locked,.room-close-eyes-button.locked{position:relative;opacity:.7;cursor:not-allowed}.room-wave-button.locked:after,.room-close-eyes-button.locked:after{content:"🔒";position:absolute;top:4px;right:4px;font-size:14px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.room-wave-button.locked:hover,.room-close-eyes-button.locked:hover{transform:translate(-50%);opacity:.8}@media (max-width: 768px){.room-wave-button.locked:hover,.room-close-eyes-button.locked:hover{transform:none}}.room-actions-container{position:fixed;right:24px;bottom:196px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.room-actions-buttons{display:flex;flex-direction:column;gap:6px;animation:slideInAction .2s ease-out forwards}.room-actions-buttons--floating{position:fixed;z-index:1003;align-items:center}.room-bar-dropdown{position:fixed;right:72px;left:auto;transform:none;display:flex;flex-direction:row-reverse;flex-wrap:wrap-reverse;justify-content:flex-start;gap:6px;align-items:flex-start;z-index:2300;max-width:calc(100vw - 90px);animation:dropdownSlideLeft .2s ease-out forwards}@media (min-width: 769px){.room-bar-dropdown{right:74px}}.room-dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--panel);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:14px;color:var(--text);font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s ease;box-shadow:0 2px 8px #00000026}.room-dropdown-item:hover{background:var(--chip)}.room-dropdown-item:active{transform:scale(.96)}.room-dropdown-item .material-icons{font-size:20px;opacity:.8}.room-env-settings-portal{position:fixed!important;top:auto!important;left:auto!important;right:72px!important;bottom:calc(180px + env(safe-area-inset-bottom,0px))!important;transform:none!important;width:min(270px,85vw)!important;z-index:2300;animation:dropdownSlideLeft .2s ease-out forwards;padding:16px!important;background:var(--panel)!important;backdrop-filter:blur(20px)!important;-webkit-backdrop-filter:blur(20px)!important;border:1px solid var(--border)!important;border-radius:20px!important;box-shadow:0 8px 32px #00000040,0 2px 8px #0000001a!important;box-sizing:border-box!important}.room-env-settings-portal .room-env-settings-title{font-size:14px!important;font-weight:700!important;color:var(--text)!important;margin-bottom:12px!important}.room-env-settings-portal .room-env-settings-row{margin-bottom:8px!important;gap:4px!important;display:flex!important;flex-direction:column!important}.room-env-settings-portal .room-env-settings-row span{font-size:12px!important;color:var(--muted)!important;font-weight:500!important}.room-env-settings-portal input[type=range]{-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;width:100%!important;height:6px!important;background:var(--border)!important;border-radius:3px!important;outline:none!important}.room-env-settings-portal input[type=range]::-webkit-slider-thumb{-webkit-appearance:none!important;width:18px!important;height:18px!important;background:var(--panel)!important;border:2px solid var(--accent)!important;border-radius:50%!important;cursor:pointer!important;box-shadow:0 1px 4px #0000004d!important}.room-env-settings-portal .room-env-settings-divider{margin:8px 0!important;padding-top:8px!important;border-top-color:var(--border)!important}.room-env-settings-portal .room-env-settings-divider span{font-size:12px!important;color:var(--muted)!important;font-weight:600!important}.room-env-settings-portal .room-env-settings-error{color:#ef4444!important;font-size:12px!important}.room-env-settings-portal .room-env-settings-actions{margin-top:12px!important;gap:8px!important;display:flex!important}.room-env-settings-portal .room-env-settings-actions button{height:36px!important;font-size:13px!important;padding:0 14px!important;border-radius:12px!important;border:none!important;font-weight:600!important;cursor:pointer!important;display:flex!important;align-items:center!important;gap:4px!important;transition:all .15s ease!important}.room-env-settings-portal .room-env-settings-secondary{background:var(--chip)!important;color:var(--text)!important}.room-env-settings-portal .room-env-settings-secondary:hover{background:var(--border)!important}.room-env-settings-portal .room-env-settings-primary{background:var(--accent)!important;color:#fff!important}.room-env-settings-portal .room-env-settings-primary:hover{opacity:.9!important}.room-env-settings-portal .room-env-settings-actions .material-icons{font-size:16px!important}.room-env-settings-portal .room-env-settings-btn-label{font-size:13px!important}@media (min-width: 769px){.room-env-settings-portal{right:74px!important;bottom:120px!important}}.room-add-dropdown{gap:4px}@keyframes dropdownSlideUp{0%{opacity:0;transform:translate(12px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes dropdownSlideUpDesktop{0%{opacity:0;transform:translate(12px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes dropdownSlideLeft{0%{opacity:0;transform:translate(12px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes slideInAction{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.room-action-button{width:48px;height:48px;border-radius:50%;border:1px solid var(--border);background:var(--panel);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s;position:relative;box-shadow:0 2px 8px #00000026}.room-action-button--owned:hover:not(:disabled){background:var(--accent);color:#fff;transform:scale(1.05)}.room-action-button--locked{opacity:.7;cursor:not-allowed}.room-action-button-lock{position:absolute;top:2px;right:2px;font-size:14px;color:#ff6b6b}.room-camera-dropdown{display:flex;flex-direction:column;gap:4px;min-width:160px}.room-camera-option{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--panel);border:1px solid var(--border);border-radius:12px;color:var(--text);cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,border-color .15s;box-shadow:0 2px 8px #0000001f;animation:slideInAction .2s ease backwards}.room-camera-option:nth-child(2){animation-delay:.05s}.room-camera-option:nth-child(3){animation-delay:.1s}.room-camera-option:hover{background:var(--hover-bg, rgba(128,128,128,.08))}.room-camera-option.active{background:var(--accent);border-color:var(--accent);color:#fff}.room-camera-option.active .material-icons{color:#fff}.room-camera-option .material-icons{font-size:20px;color:var(--muted)}.room-camera-option-label{flex:1}.room-actions-button{width:56px;height:56px;border-radius:50%;border:none;background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d;transition:transform .2s,background .2s}.room-actions-button:hover{transform:scale(1.05)}.room-actions-button--active{background:linear-gradient(135deg,#5aa0e9,#4a90d9)}@media (max-width: 768px){.room-actions-container{right:16px;bottom:180px;z-index:1000}}.room-portal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.room-portal-panel{background:var(--card-bg, #1e1e2e);border-radius:20px;width:min(420px,92vw);max-height:80vh;overflow-y:auto;padding:24px;position:relative;box-shadow:0 16px 48px #0006}.room-portal-close{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px}.room-portal-close:hover{color:var(--text-primary)}.room-portal-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.room-portal-title{font-size:18px;font-weight:600;color:var(--text-primary)}.room-portal-content{display:flex;flex-direction:column;gap:14px}.room-portal-preview{border-radius:14px;overflow:hidden;aspect-ratio:16/9;background:var(--bg-secondary, #2a2a3e)}.room-portal-preview img{width:100%;height:100%;object-fit:cover}.room-portal-info{display:flex;flex-direction:column;gap:8px}.room-portal-room-name{font-size:16px;font-weight:600;color:var(--text-primary)}.room-portal-users-count{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.room-portal-users-list{display:flex;flex-wrap:wrap;gap:6px}.room-portal-user-chip{padding:4px 10px;border-radius:12px;background:var(--bg-secondary, #2a2a3e);font-size:12px;color:var(--text-secondary)}.room-portal-go-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:none;border-radius:14px;background:linear-gradient(135deg,#7c4dff,#651fff);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s}.room-portal-go-btn:hover{opacity:.9}.room-env-settings-active{background:var(--primary, #7c4dff)!important;color:#fff!important}.portal-map-inline{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;pointer-events:auto;cursor:grab;animation:portalMapFadeIn .4s ease-out;overflow:hidden}.portal-map-inline:active{cursor:grabbing}@keyframes portalMapFadeIn{0%{opacity:0}to{opacity:1}}.portal-map-inline svg{pointer-events:none!important}.portal-map-me-title{display:flex;align-items:center;gap:6px;background:#7c4dffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:13px;font-weight:700;padding:5px 14px;border-radius:12px;white-space:nowrap;box-shadow:0 2px 16px #7c4dff66;pointer-events:none;letter-spacing:.3px}.portal-map-env-wrap{pointer-events:auto}.portal-map-env-title{position:absolute;top:-4px;left:50%;transform:translate(-50%,-100%);display:flex;align-items:center;gap:6px;padding:5px 14px;background:#1e1e28e0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:13px;font-weight:700;border-radius:12px;white-space:nowrap;letter-spacing:.3px;box-shadow:0 2px 16px #0006;pointer-events:none;z-index:3}.portal-map-env{position:relative;border-radius:6px;overflow:hidden;border:2px solid rgba(255,255,255,.12);background:#111;transition:border-color .2s,box-shadow .2s;box-shadow:0 4px 24px #00000080}.portal-map-env:hover{border-color:#7c4dff99;box-shadow:0 4px 32px #7c4dff40}.portal-map-env-bg{width:100%;height:100%;object-fit:cover;display:block}.portal-map-env-char{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;pointer-events:none;z-index:2}.portal-map-env-char-img{height:100%;width:auto;object-fit:contain;filter:drop-shadow(0 1px 3px rgba(0,0,0,.5));image-rendering:auto}.portal-map-env-char-fallback{border-radius:50%;background:#7c4dffb3;display:flex;align-items:center;justify-content:center;color:#fff;border:2px solid rgba(255,255,255,.5);box-shadow:0 1px 6px #0006}.portal-map-env-char-name{font-size:8px;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);white-space:nowrap;font-weight:600;margin-top:1px;max-width:60px;overflow:hidden;text-overflow:ellipsis}.portal-map-env-users{display:flex;align-items:center;gap:3px;font-weight:600;opacity:.7;font-size:11px}.portal-map-inline-hint{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff9;font-size:11px;padding:6px 16px;border-radius:12px;white-space:nowrap;z-index:5;pointer-events:none}@media (max-width: 768px){.portal-map-card{width:130px}.portal-map-card-thumb{height:72px}}.container:has(.character-page) .content-wrapper .main-content:has(.character-page),.container:has(.character-page) .main-content:has(.character-page),.main-content:has(.character-page){padding:0!important;margin:0!important;gap:0!important;overflow:hidden!important;height:100vh!important;max-height:100vh!important;min-height:100vh!important}.container{max-width:1600px;margin:0 auto;padding:0;display:flex;flex-direction:column;min-height:100vh;width:100%;position:relative;z-index:1;overflow:visible;touch-action:auto}.container-row{display:flex;flex:1;min-width:0}.app-shell{position:relative;min-height:100vh;overflow:visible;touch-action:auto}.room-background{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;z-index:0}.room-background.background{pointer-events:none}.room-background.interactive{pointer-events:auto!important;touch-action:none!important;z-index:0}.app-shell:has(.room-background) .character-new-page,.app-shell:has(.room-background) .character-new-loading{background:transparent!important}.room-glass-scrim{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;z-index:0;pointer-events:none;background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.15),#0f0f14a6 45%,#0f0f148c);border:1px solid rgba(255,255,255,.1);box-shadow:0 18px 60px #00000059;transform:translateZ(0);-webkit-transform:translateZ(0);-webkit-backdrop-filter:blur(10px) saturate(150%);backdrop-filter:blur(10px) saturate(150%)}@media (min-width: 769px){.room-glass-scrim{background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.18),#0f0f148c 45%,#0f0f146b);-webkit-backdrop-filter:blur(12px) saturate(150%);backdrop-filter:blur(12px) saturate(150%)}}[data-theme=light] .room-glass-scrim{background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.1),#ffffffbf,#ffffffa6);border:1px solid rgba(0,0,0,.08);box-shadow:0 18px 60px #00000024}@media (min-width: 769px){[data-theme=light] .room-glass-scrim{background:linear-gradient(135deg,rgba(var(--accent-rgb, 59, 130, 246),.12),#fff9,#ffffff85);-webkit-backdrop-filter:blur(12px) saturate(150%);backdrop-filter:blur(12px) saturate(150%)}}.container.room-layout{max-width:100%;padding:0;position:relative;z-index:1}.container.room-layout .content-wrapper{gap:0}.container.room-layout .main-content{padding:0;gap:0;min-height:100vh;overflow:hidden}.container.room-layout .page-transition{flex:1;gap:0;min-height:100vh}.room-keep-alive{flex:1;display:flex;flex-direction:column;width:100%;height:100%;min-height:100vh}.room-keep-alive.visible{position:relative;z-index:1;pointer-events:auto;visibility:visible;opacity:1}.room-keep-alive.hidden{position:absolute;top:0;left:0;z-index:-1;pointer-events:none;visibility:hidden;opacity:0}.container.room-interactive,.container.room-interactive .container-row,.container.room-interactive .content-wrapper,.container.room-interactive .main-content,.container.room-interactive .page-transition{pointer-events:none!important}.container.room-interactive .sidebar,.container.room-interactive .chat-panel,.container.room-interactive .chat-panel-placeholder,.container.room-interactive .chat-toggle-btn,.container.room-interactive .room-exit-button,.container.room-interactive .mobile-menu-overlay,.container.room-interactive .mobile-bottom-panel,.container.room-interactive .mobile-bottom-panel *{pointer-events:auto!important}.container.chat-layout{max-width:100%;padding:0}.container.chat-layout .content-wrapper{gap:0}.container.chat-layout .main-content{padding:0;gap:0;overflow:hidden}.container.chat-layout .page-transition{flex:1;gap:0;height:100vh}.page-logo-wrap{display:flex;justify-content:center;align-items:center;height:150px;flex-shrink:0;will-change:height;pointer-events:none;overflow:visible}.page-logo-img{width:300px;height:165px;flex-shrink:0;will-change:width,height,opacity;mask-image:url(/logo.svg);mask-size:contain;mask-repeat:no-repeat;mask-position:center;-webkit-mask-image:url(/logo.svg);-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;background-color:var(--logo-color);background-image:url(/logo.svg);background-size:contain;background-repeat:no-repeat;background-position:center}.content-wrapper{flex:1;display:flex;min-width:0;gap:12px;overflow:visible;touch-action:auto}.main-content{flex:1;display:flex;flex-direction:column;gap:20px;order:1;min-width:0;-webkit-overflow-scrolling:touch;touch-action:auto}.main-content:has(.character-page),.main-content:has(.users-page){padding:0!important;margin:0!important;gap:0!important;overflow:hidden!important;height:100vh!important;max-height:100vh!important;min-height:100vh!important}.main-content:not(:has(.character-page)):not(:has(.users-page)){padding:20px}.page-transition:has(.character-page),.content-wrapper:has(.character-page),.page-transition:has(.users-page),.content-wrapper:has(.users-page){padding:0!important;margin:0!important;gap:0!important;overflow:hidden!important;height:100vh!important;max-height:100vh!important;min-height:100vh!important;flex:1!important;display:flex!important;flex-direction:column!important}.page-transition{width:100%;min-height:100%;display:flex;flex-direction:column;overflow:visible;gap:20px;touch-action:auto}.page-transition.fade-in{animation:pageFadeIn .15s ease both}.page-transition.fade-out{animation:pageFadeOut .12s ease forwards}@keyframes pageFadeIn{0%{opacity:0}to{opacity:1}}@keyframes pageFadeOut{0%{opacity:1}to{opacity:0}}@media (prefers-reduced-motion: reduce){.page-transition{animation:none!important}}@media (max-width: 768px){.page-logo-wrap{display:none}.container{flex-direction:column;max-width:100%;padding:0;min-height:100vh}.container-row{flex-direction:column;flex:1}.content-wrapper{flex-direction:column;gap:0}.main-content:not(:has(.character-page)):not(:has(.users-page)){padding:12px;padding-bottom:calc(76px + env(safe-area-inset-bottom,0px));order:1;gap:16px;overflow-y:auto!important;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:auto;height:auto;min-height:calc(100vh - 64px - env(safe-area-inset-bottom,0px));touch-action:auto}.main-content:has(.users-page){padding:0!important;margin:0!important;overflow:hidden!important;overflow-y:hidden!important;height:100vh!important;max-height:100vh!important;min-height:auto!important}.container.room-layout .main-content{padding-bottom:calc(132px + env(safe-area-inset-bottom,0px))}.container.room-interactive{visibility:hidden}.container.room-interactive .sidebar{visibility:visible}.page-transition{gap:16px}.main-content:has(.character-page),.main-content:has(.users-page){padding:0!important;margin:0!important;overflow-y:hidden!important;height:100vh!important;max-height:100vh!important}.container:has(.character-page),.container:has(.character-page) .content-wrapper,.container:has(.users-page),.container:has(.users-page) .content-wrapper{padding:0!important;margin:0!important}.page-transition:has(.character-page),.content-wrapper:has(.character-page),.page-transition:has(.users-page),.content-wrapper:has(.users-page){padding:0!important;margin:0!important;gap:0!important}}@media (max-width: 768px){.container:has(.character-page) .content-wrapper .main-content:has(.character-page),.container:has(.character-page) .main-content:has(.character-page),.main-content:has(.character-page),.container:has(.users-page) .content-wrapper .main-content:has(.users-page),.container:has(.users-page) .main-content:has(.users-page),.main-content:has(.users-page){padding:0!important;margin:0!important}.container:has(.character-page) .content-wrapper .page-transition:has(.character-page),.container:has(.character-page) .page-transition:has(.character-page),.page-transition:has(.character-page),.container:has(.users-page) .content-wrapper .page-transition:has(.users-page),.container:has(.users-page) .page-transition:has(.users-page),.page-transition:has(.users-page){padding:0!important;margin:0!important;gap:0!important}.container:has(.character-page) .content-wrapper:has(.character-page),.container:has(.character-page) .content-wrapper,.container:has(.users-page) .content-wrapper:has(.users-page),.container:has(.users-page) .content-wrapper{padding:0!important;margin:0!important;gap:0!important}.container:has(.character-page),.container:has(.users-page){padding:0!important;margin:0!important}}@media (max-width: 768px){.main-content:has(.users-page),.page-transition:has(.users-page),.content-wrapper:has(.users-page){min-height:0!important;overflow:hidden!important}}[data-gesture-handler-root]{width:100%;height:100%;min-height:100vh}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.random-composite-character{width:100%;height:300px;background:var(--panel-2);border-radius:8px;border:1px solid var(--border);position:relative;overflow:hidden;margin-bottom:30px;transition:background-color .3s ease,border-color .3s ease;display:flex;align-items:center;justify-content:center}.random-composite-character-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--muted);font-size:14px}@media (max-width: 768px){.random-composite-character{height:250px;margin-bottom:20px}}@media (max-width: 480px){.random-composite-character{height:200px;margin-bottom:16px}}.auth-page{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;padding:24px;box-sizing:border-box;background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(var(--accent-rgb),.08) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(var(--accent-rgb),.04) 0%,transparent 50%),var(--bg);overflow:hidden;z-index:9999}body.auth-no-scroll{overflow:hidden!important;overscroll-behavior:none}.auth-page input,.auth-page textarea{-webkit-user-select:text;user-select:text}.auth-card{display:flex;flex-direction:column;max-width:400px;width:100%;max-height:95%;background:var(--panel);border:1px solid var(--border);border-radius:24px;overflow:hidden;box-shadow:0 12px 48px #0000001f,0 2px 8px #0000000f}.auth-character-section{position:relative;flex-shrink:0;background:var(--panel-2);overflow:hidden;height:300px}.auth-character-section .random-composite-character{width:100%;height:100%;margin:0;border-radius:0;border:none;min-height:0;max-height:none}.auth-character-section .random-composite-character canvas{transform:scale(1.08) translateY(4%);transform-origin:center center}.auth-logo-overlay{position:absolute;top:8px;left:50%;transform:translate(-50%);width:120px;height:40px;background-image:url(/logo.svg);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.45;filter:drop-shadow(0 1px 3px rgba(0,0,0,.15));pointer-events:none;z-index:1}.auth-character-section:after{content:"";position:absolute;bottom:0;left:0;right:0;height:40px;background:linear-gradient(to top,var(--panel),transparent);pointer-events:none}.auth-form-section{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}.auth-form-inner{flex:1;display:flex;flex-direction:column;justify-content:center;padding:24px 30px 28px}.auth-form-section form{display:flex;flex-direction:column}.form-header{text-align:center;margin-bottom:16px}.form-title{font-size:19px;font-weight:700;margin:0 0 3px;color:var(--text);letter-spacing:-.02em}.form-subtitle{margin:0;font-size:12.5px;color:var(--muted);font-weight:400}.auth-telegram-badge{padding:10px 14px;margin-bottom:14px;background-color:rgba(var(--accent-rgb),.08);color:var(--accent);border-radius:12px;font-size:13px;font-weight:500;text-align:center;border:1px solid rgba(var(--accent-rgb),.12)}.form-group{margin-bottom:12px}.form-group.hidden-field{position:absolute;opacity:0;pointer-events:none;height:0;overflow:hidden}.form-label{display:block;margin-bottom:5px;font-weight:600;color:var(--muted);font-size:11px;letter-spacing:.04em;text-transform:uppercase}.input-wrapper{position:relative}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:18px;color:var(--muted);opacity:.5;pointer-events:none;transition:color .2s ease,opacity .2s ease}.input-wrapper:focus-within .input-icon{color:var(--accent);opacity:.8}.form-input{width:100%;padding:12px 14px;background:var(--panel-2);border:1.5px solid var(--border);border-radius:12px;color:var(--text);font-size:15px;font-family:inherit;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.form-input.has-icon{padding-left:40px}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(var(--accent-rgb),.1);background:var(--panel)}.form-input:disabled{opacity:.55}.form-input::placeholder{color:var(--muted);opacity:.4}.btn{padding:13px 20px;border:none;border-radius:14px;font-weight:600;cursor:pointer;font-family:inherit;font-size:14px;width:100%;margin-top:4px;transition:opacity .15s ease,transform .1s ease,box-shadow .2s ease}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 16px rgba(var(--accent-rgb),.25)}.btn-primary:hover:not(:disabled){opacity:.92;box-shadow:0 6px 20px rgba(var(--accent-rgb),.3)}.btn-primary:active:not(:disabled){transform:scale(.98);box-shadow:0 2px 8px rgba(var(--accent-rgb),.2)}.btn-primary:disabled{opacity:.5;cursor:default;box-shadow:none}.form-divider{display:flex;align-items:center;margin:14px 0;gap:12px}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:var(--border)}.form-divider span{font-size:12px;color:var(--muted);opacity:.6;text-transform:lowercase;font-weight:500}.form-switch{text-align:center}.form-switch-btn{display:block;width:100%;padding:11px 18px;border:1.5px solid var(--border);border-radius:12px;background:transparent;color:var(--text);font-size:13px;font-weight:500;font-family:inherit;text-decoration:none;text-align:center;transition:background-color .15s ease,border-color .15s ease}.form-switch-btn:hover{background:var(--panel-2);border-color:var(--accent)}.error-message{background:#ef444414;border:1px solid rgba(239,68,68,.2);color:#f87171;padding:10px 14px;border-radius:12px;margin-bottom:14px;display:none;font-size:13px;font-weight:500;line-height:1.4}.error-message.show{display:block;animation:errorShake .35s ease}@keyframes errorShake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}.form-step-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:10px 12px;background:var(--panel-2);border-radius:12px}.btn-back{background:none;border:none;color:var(--muted);cursor:pointer;width:30px;height:30px;border-radius:8px;transition:background-color .15s ease,color .15s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-back .material-icons{font-size:20px}.btn-back:hover{background:var(--panel);color:var(--text)}.step-email{color:var(--text);font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.auth-page{padding:0;align-items:stretch;background:radial-gradient(ellipse 100% 40% at 50% 0%,rgba(var(--accent-rgb),.06) 0%,transparent 50%),var(--bg)}.auth-card{max-width:100%;max-height:100%;border-radius:0;border:none;box-shadow:none;flex:1}.auth-character-section{height:270px}.auth-character-section .random-composite-character canvas{transform:scale(1.12) translateY(5%);transform-origin:center center}.auth-logo-overlay{width:100px;height:32px;top:6px;opacity:.4}.auth-form-inner{padding:14px 22px 20px;justify-content:flex-start}.form-header{margin-bottom:12px}.form-title{font-size:17px}.form-subtitle{font-size:11.5px}.form-group{margin-bottom:10px}.form-label{font-size:10.5px;margin-bottom:4px}.form-input{padding:11px 12px;font-size:15px}.form-input.has-icon{padding-left:38px}.input-icon{font-size:16px;left:12px}.btn{padding:12px 18px;font-size:14px}.form-divider{margin:10px 0}.form-switch-btn{padding:10px 16px;font-size:12.5px}}@media (max-width: 480px){.auth-character-section{height:250px}.auth-form-inner{padding:12px 18px 18px}}@media (max-height: 700px){.auth-character-section{height:210px}.auth-character-section .random-composite-character canvas{transform:scale(1.1) translateY(4%)}}@media (max-height: 600px){.auth-character-section{height:170px}}.card{background:var(--panel);border:1px solid var(--border);border-radius:20px;overflow:hidden;width:100%;max-width:100%;box-sizing:border-box;min-width:0;contain:layout paint;touch-action:auto}.users-page .card,.users-page .card-content{overflow:visible}.card.clothing-grid-card{overflow:hidden!important;display:flex!important;flex-direction:column!important}body.loaded .card{transition:background-color .3s ease,border-color .3s ease}.panel-title{padding:4px 16px;font-weight:800;letter-spacing:.02em;border-bottom:1px solid var(--border);background:var(--panel-title-tinted, var(--panel-2));font-size:14px;color:var(--panel-title-text, white);min-height:48px;max-height:48px;box-sizing:border-box;display:flex;align-items:center}@media (max-width: 768px){.panel-title,.card .panel-title,.clothing-grid-card .panel-title,.card-categories .panel-title{font-size:14px!important;padding:4px 16px!important}}@media (max-width: 480px){.panel-title,.card .panel-title,.clothing-grid-card .panel-title,.card-categories .panel-title{font-size:13px!important;padding:4px 14px!important}}.card-content{padding:16px;display:flex;flex-direction:column;gap:16px}@media (max-width: 768px){.card-content{padding:12px;gap:12px}}.new-chat-window-card{display:flex!important;flex-direction:column!important;max-height:calc(100vh - 120px)!important;height:calc(100vh - 120px)!important}.new-chat-window-card .card-content{padding:0!important;flex:1!important;min-height:0!important;overflow:hidden!important;gap:0!important;display:flex!important;flex-direction:column!important}.new-chat-list-card{display:flex!important;flex-direction:column!important}.new-chat-list-card .card-content{padding:16px!important;flex:1!important;min-height:0!important;overflow:hidden!important;display:flex!important;flex-direction:column!important;gap:0!important}.card.collapsible .panel-title.collapsible-title{-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.card.collapsible .panel-title.collapsible-title:hover{background:var(--panel-title-hover, var(--panel-2))}.card.collapsible .panel-title.collapsible-title .collapse-icon{display:inline-flex;align-items:center;justify-content:center}.card.collapsible .card-content{max-height:5000px;transition:max-height .3s ease,opacity .3s ease,padding-top .3s ease,padding-bottom .3s ease;overflow:hidden}.card.collapsible .card-content.collapsed{max-height:0;padding-top:0;padding-bottom:0;opacity:0}.btn{padding:10px 16px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .14s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent;font-size:13px;font-family:inherit}.btn-primary{background:var(--accent);color:var(--chip-active-text, white)}.btn-primary:hover:not(:disabled){background:var(--accent-2)}.btn-secondary{background:var(--chip);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--chip-active);border-color:transparent;color:var(--chip-active-text, white)}.btn-danger{background:var(--btn-danger-bg, rgba(239, 68, 68, .2));color:var(--btn-danger-text, #fca5a5);border:1px solid var(--btn-danger-border, rgba(239, 68, 68, .3));transition:background-color .3s ease,color .3s ease,border-color .3s ease}.btn-danger:hover:not(:disabled){background:var(--btn-danger-hover-bg, rgba(239, 68, 68, .3))}.btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.btn{padding:10px 16px;font-size:13px}}.card-categories{overflow:hidden;display:flex;flex-direction:column;flex-shrink:0;border-radius:12px;min-height:0;flex:1}.card-categories .panel-title{min-height:48px;max-height:48px;display:flex;align-items:center;justify-content:center;text-align:center}.categories{display:flex;flex-direction:column;gap:8px;padding:10px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;flex:1;min-height:0}.cat-btn{background:var(--chip);color:var(--text);padding:12px 16px;border:1px solid var(--border);border-radius:10px;cursor:pointer;text-align:left;transition:.14s ease;font-weight:600;font-size:15px;min-height:46px;line-height:1.4}.cat-btn:hover{transform:translate(2px)}.cat-btn.active{background:var(--chip-active);border-color:transparent;color:var(--chip-active-text, white)}@media (max-width: 768px){.card-categories .panel-title{min-height:44px;max-height:44px;font-size:14px}.categories{padding:12px;gap:10px}.cat-btn{padding:14px 18px;font-size:16px;min-height:50px;line-height:1.4;font-weight:600}}@media (max-width: 480px){.card-categories .panel-title{min-height:42px;max-height:42px;font-size:13px}.categories{padding:12px;gap:10px}.cat-btn{padding:14px 18px;font-size:16px;min-height:50px;line-height:1.4;font-weight:600}}.clothing-grid-card{min-height:0;flex:1;display:flex;flex-direction:column;overflow:hidden}.clothing-grid-card .panel-title{flex-shrink:0}.grid-panel-title{display:flex;align-items:center;justify-content:flex-start;gap:0;padding:12px 16px;min-height:48px;max-height:none;box-sizing:border-box}.grid-panel-title:has(.color-bar-inline){padding:12px 16px;min-height:48px;max-height:none;align-items:center}.grid-placeholder{color:var(--muted);font-size:13px;font-weight:600}.color-bar-inline{display:flex;gap:8px;align-items:center;flex-shrink:0;overflow-x:auto;overflow-y:hidden;padding:4px;flex:1}.color-bar-inline .color-dot{width:30px;height:30px;border-radius:50%;border:2px solid var(--color-dot-border, rgba(255,255,255,.8));cursor:pointer;transition:transform .12s ease,border-color .3s ease;flex-shrink:0}.color-bar-inline .color-dot:hover{transform:scale(1.05)}.color-bar-inline .color-dot.selected{outline:3px solid var(--color-dot-selected, rgba(255,255,255,.9));transition:outline-color .3s ease}.clothing-grid-card .grid-scroll-wrapper{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;max-height:100%}.grid-scroll-wrapper .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:12px;width:100%;box-sizing:border-box}.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:12px;max-width:100%;box-sizing:border-box;width:100%}.grid-load-more{padding:10px 12px 18px;display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0}.grid-load-more .btn{min-width:190px;padding:10px 16px;border-radius:10px}.grid-load-info{color:var(--muted);font-size:12px}.grid-item{background:var(--grid-item-bg, #121827);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .14s ease,background-color .3s ease;display:flex;flex-direction:column;width:100%;aspect-ratio:1 / 1;position:relative;box-sizing:border-box}.grid-item:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--grid-thumb-bg, #0b0f17);transition:opacity .25s ease;opacity:1;pointer-events:none;z-index:2}.grid-item-loaded:after{opacity:0}.grid-item:hover{transform:translateY(-2px)}.grid-item.selected{box-shadow:0 0 0 3px var(--accent);border-color:var(--accent)}.grid-thumb{width:100%;flex:1;object-fit:contain;background:var(--grid-thumb-bg, #0b0f17);display:block;min-height:0;padding:8px;transition:opacity .25s ease,background-color .3s ease;position:relative;z-index:3}.grid-item-loading .grid-thumb{opacity:0}.grid-item-loaded .grid-thumb{opacity:1;transition:opacity .25s ease}.grid-caption{padding:8px 10px;color:var(--muted);font-size:12px;border-top:1px solid var(--border);flex-shrink:0;text-align:center}@media (max-width: 768px){.grid-scroll-wrapper .grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:8px}.grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:8px;max-width:100%}.grid-item{max-width:100%}.grid-panel-title{padding:12px 16px;min-height:48px;max-height:none}.grid-panel-title:has(.color-bar-inline){padding:12px 16px!important;min-height:48px!important;max-height:none!important}.grid-placeholder{font-size:11px}.color-bar-inline{gap:6px;padding:3px}.color-bar-inline .color-dot{width:28px;height:28px;border-width:2px}.grid-load-more{padding:8px 8px 16px}.grid-load-more .btn{min-width:150px}}@media (max-width: 480px){.grid-scroll-wrapper .grid,.grid{gap:8px;padding:8px}.grid-panel-title{padding:12px 14px;min-height:48px;max-height:none}.grid-panel-title:has(.color-bar-inline){padding:12px 14px!important;min-height:48px!important;max-height:none!important}.grid-placeholder{font-size:10px}.color-bar-inline{gap:6px;padding:3px}.color-bar-inline .color-dot{width:26px;height:26px;border-width:2px}.grid-load-more{padding:6px 6px 12px}.grid-load-more .btn{min-width:120px}}.character-canvas-container{width:100%;height:100%;position:relative}.character-canvas{opacity:0;transition:opacity .3s ease-in-out;image-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.character-canvas.visible{opacity:1}.register-page{min-height:100vh;width:100%;touch-action:manipulation;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;overflow-x:hidden}.register-page input,.register-page textarea{-webkit-user-select:text;user-select:text;touch-action:auto}.register-container{display:flex;min-height:100vh;padding:0;max-width:1400px;margin:0 auto}@media (max-width: 768px){.register-container{flex-direction:column}}.character-panel{background:var(--character-panel-bg, radial-gradient(60% 80% at 50% 65%, #18202c 0%, #0f1115 80%));position:relative;min-height:calc(100vh - 32px);border-radius:12px;overflow:hidden;transition:background .3s ease;width:100%;margin:16px}@media (max-width: 768px){.character-panel{margin:8px}}.layout{display:grid;grid-template-rows:auto 1fr;height:100%}.mobile-registration-block{display:none}.desktop-registration-block{display:flex}.mobile-username-form{display:none}.stage-panel{position:relative;min-height:320px;max-height:320px;overflow:hidden}.ui-panel{display:grid;grid-template-columns:14% 1fr minmax(240px,280px);grid-template-rows:auto 1fr;gap:12px;padding:8px 12px;background:transparent;overflow-x:visible;opacity:0;transition:opacity .3s ease;min-height:0;height:100%}.ui-panel.ready{opacity:1;transition:opacity .3s ease}.register-info-card{flex-shrink:0;grid-column:1 / -1}.register-panel-title{display:flex;align-items:center;justify-content:space-between;gap:12px}.register-panel-title .action-buttons{display:flex;gap:8px;padding:0;margin:0 0 0 auto;align-items:center;flex-shrink:0}.register-panel-title .action-buttons .btn-icon{height:40px;width:40px;padding:0;display:flex;align-items:center;justify-content:center;font-size:20px;border-radius:8px;flex-shrink:0}.register-form-content{padding:10px;display:flex;flex-direction:column;gap:0}.registration-form-inline{display:flex;flex-direction:column;gap:0}.character-form-row{display:flex;gap:12px;margin-bottom:0}.character-form-row .form-group{flex:1;min-width:0;margin-bottom:0}.left-col{display:flex;flex-direction:column;gap:12px;align-items:stretch}.right-col{display:flex;flex-direction:column;gap:12px;min-width:0;min-height:0;flex:1}.right-col-sidebar{display:flex;flex-direction:column;gap:12px;min-width:0;width:100%;overflow:visible}.registration-form{display:flex;flex-direction:column;gap:clamp(8px,1.2vw,12px);padding:clamp(8px,1vw,10px)}.registration-form .form-group{margin-bottom:0}.registration-form .form-label{font-size:clamp(11px,1.2vw,12px);margin-bottom:clamp(4px,.5vw,6px);color:var(--muted);font-weight:600}.registration-form .form-input{padding:clamp(6px,.8vw,8px) clamp(10px,1.2vw,12px);font-size:clamp(11px,1.3vw,13px);width:100%;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:inherit;box-sizing:border-box}.registration-form .form-input:focus{outline:none;border-color:var(--accent)}.registration-form .form-input:disabled{opacity:.6;cursor:not-allowed}.action-buttons{display:flex;gap:clamp(6px,.8vw,8px);margin-top:4px}.action-buttons button{font-size:clamp(11px,1.2vw,13px);padding:clamp(8px,1vw,10px) clamp(12px,1.5vw,16px)}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:12px;border-radius:8px;margin-bottom:20px;display:none;font-size:clamp(11px,1.3vw,13px)}.error-message.show{display:block}@media (max-width: 1200px){.layout{grid-template-rows:auto auto}.stage-panel{min-height:280px;max-height:280px}.ui-panel{grid-template-columns:20% 1fr minmax(220px,260px);padding:6px 8px;gap:10px}.right-col{display:flex;flex-direction:column;gap:12px}}@media (max-width: 768px){.register-container{flex-direction:column;padding:0}.character-panel{min-height:calc(100vh - 16px);margin:8px;border-radius:12px}.layout{grid-template-rows:auto auto 1fr;display:grid}.mobile-registration-block{display:flex;order:-1;margin-bottom:8px}.stage-panel{order:0;min-height:280px;max-height:280px;margin-bottom:0;border-radius:0;overflow:hidden}.mobile-username-form{display:block;padding:12px 16px;background:var(--panel);border-top:1px solid var(--border);border-radius:0 0 12px 12px;margin-top:0;width:100%;box-sizing:border-box}.mobile-username-form .form-group{margin-bottom:0}.mobile-username-form .form-input{padding:10px 12px;font-size:14px;width:100%}.desktop-username-field{display:none}.ui-panel{grid-template-columns:30% 70%;grid-template-rows:auto 1fr;padding:6px 8px;gap:8px;align-items:start;height:100%;min-height:0;order:1}.left-col{display:flex;flex-direction:column}.right-col{display:flex;flex-direction:column;gap:12px;min-height:0;flex:1}.desktop-registration-block{display:none!important}.register-panel-title .action-buttons{padding:0;gap:10px;margin-left:auto}.register-panel-title .action-buttons .btn-icon{flex:0 0 auto;width:52px;height:32px;min-width:52px;font-size:20px;display:flex;align-items:center;justify-content:center}.register-message{top:10px;padding:10px;font-size:13px}.registration-form{padding:clamp(6px,1vw,8px)}.registration-form .form-group{margin-bottom:16px}.action-buttons{flex-direction:row;gap:clamp(6px,.8vw,8px)}.action-buttons button{flex:1}.grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:clamp(6px,.8vw,8px);padding:clamp(6px,.8vw,8px);max-width:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.grid-item{max-width:100%}.color-bar{min-height:clamp(44px,6vw,48px);max-height:clamp(44px,6vw,48px);padding:clamp(6px,.8vw,8px);gap:clamp(6px,.8vw,8px)}.color-dot{width:clamp(28px,4vw,32px);height:clamp(28px,4vw,32px);border-width:2.5px}}@media (max-width: 640px){.ui-panel{grid-template-columns:minmax(60px,24%) 1fr!important;gap:clamp(3px,.6vw,5px)}.right-col{grid-template-columns:1fr minmax(140px,180px)!important;gap:clamp(3px,.6vw,5px)}}@media (max-width: 480px){.register-container{padding:0}.character-panel{margin:0;border-radius:0;min-height:100vh}.stage-panel{min-height:280px;max-height:280px}.ui-panel{grid-template-columns:28% 72%;grid-template-rows:auto 1fr;padding:4px 6px;gap:6px}.right-col{grid-template-columns:1fr minmax(130px,160px);gap:6px}.register-form-content{padding:8px;gap:6px}.register-panel-title .action-buttons{gap:8px}.register-panel-title .action-buttons .btn-icon{width:48px;height:28px;min-width:48px}.register-panel-title .action-buttons .btn-icon .material-icons{font-size:18px!important}.categories{padding:clamp(6px,.8vw,8px);gap:clamp(4px,.6vw,6px)}.cat-btn{padding:clamp(6px,.8vw,8px) clamp(8px,1vw,10px);font-size:clamp(11px,1.2vw,12px)}.registration-form{padding:clamp(6px,.8vw,8px);gap:clamp(6px,.8vw,8px)}.registration-form .form-input{padding:clamp(6px,.7vw,7px) clamp(8px,1vw,10px);font-size:clamp(11px,1.2vw,12px)}.registration-form .form-label{font-size:clamp(10px,1.1vw,11px);margin-bottom:clamp(3px,.4vw,4px)}.action-buttons{gap:clamp(5px,.7vw,7px)}.action-buttons button{padding:clamp(6px,.8vw,8px) clamp(8px,1vw,10px);font-size:clamp(10px,1.1vw,11px)}.grid{gap:clamp(5px,.7vw,7px);padding:clamp(5px,.7vw,7px)}}@media (max-width: 360px){.ui-panel{grid-template-columns:minmax(50px,20%) 1fr!important;gap:clamp(2px,.5vw,3px)}.right-col{grid-template-columns:1fr minmax(110px,140px)!important;gap:clamp(2px,.5vw,3px)}.registration-form{padding:clamp(5px,.7vw,7px)}.registration-form .form-input{font-size:clamp(10px,1.1vw,11px);padding:clamp(5px,.6vw,6px) clamp(7px,.9vw,9px)}.registration-form .form-label{font-size:clamp(9px,1vw,10px)}.action-buttons button{font-size:clamp(9px,1vw,10px);padding:clamp(5px,.7vw,7px) clamp(7px,.9vw,9px)}}:root{--bg: #0f1115;--panel: #161a22;--panel-2: #1c2230;--text: #e5e7eb;--muted: #9aa3af;--accent: #3b82f6;--accent-2: #60a5fa;--border: #263041;--chip: #2a3345;--chip-active: #3b82f6;--character-panel-bg: radial-gradient(60% 80% at 50% 65%, #18202c 0%, #0f1115 80%);--card-shadow: 0 1px 3px rgba(0, 0, 0, .12);--card-shadow-hover: 0 4px 12px rgba(0, 0, 0, .15);--status-active-bg: rgba(34, 197, 94, .2);--status-active-text: #86efac;--status-used-bg: rgba(156, 163, 175, .2);--copy-btn-bg: #2a3345;--grid-item-bg: #121827;--grid-thumb-bg: #0b0f17;--color-dot-border: rgba(255,255,255,.8);--color-dot-selected: rgba(255,255,255,.9);--btn-danger-bg: rgba(239, 68, 68, .2);--btn-danger-text: #fca5a5;--btn-danger-border: rgba(239, 68, 68, .3);--btn-danger-hover-bg: rgba(239, 68, 68, .3)}[data-theme=light]{--bg: #ffffff;--panel: #f8f9fa;--panel-2: #ffffff;--text: #212529;--muted: #6c757d;--accent: #3b82f6;--accent-2: #2563eb;--border: #e0e0e0;--chip: #e9ecef;--chip-active: #3b82f6;--character-panel-bg: radial-gradient(60% 80% at 50% 65%, #f1f3f5 0%, #ffffff 80%);--card-shadow: 0 2px 8px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--card-shadow-hover: 0 8px 24px rgba(0, 0, 0, .12), 0 4px 8px rgba(0, 0, 0, .08);--status-active-bg: rgba(34, 197, 94, .15);--status-active-text: #16a34a;--status-used-bg: rgba(156, 163, 175, .2);--copy-btn-bg: #d1d5db;--grid-item-bg: #f8f9fa;--grid-thumb-bg: #ffffff;--color-dot-border: rgba(0,0,0,.2);--color-dot-selected: #3b82f6;--btn-danger-bg: rgba(239, 68, 68, .1);--btn-danger-text: #dc2626;--btn-danger-border: rgba(239, 68, 68, .3);--btn-danger-hover-bg: rgba(239, 68, 68, .2)}*{box-sizing:border-box}html,body{min-height:100%;margin:0;padding:0;background:var(--bg);color:var(--text);font:14px/1.4 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;overflow-x:clip;-webkit-overflow-scrolling:touch;touch-action:pan-y pinch-zoom;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}@media (max-width: 768px){html,body{height:100%;width:100%}#root{height:100vh;position:relative}}input,textarea,[contenteditable=true]{-webkit-user-select:text;user-select:text;touch-action:auto}body.loaded{transition:background-color .3s ease,color .3s ease}#root{min-height:100vh;width:100%;position:relative}.panel-title{background:var(--panel-title-tinted, var(--panel-2))!important;color:var(--panel-title-text, white)!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
