*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Inter,Helvetica Neue,Arial,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.\!visible{visibility:visible!important}.visible{visibility:visible}.fixed{position:fixed}.relative{position:relative}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.block{display:block}.inline{display:inline}.table{display:table}.grid{display:grid}.hidden{display:none}.grow{flex-grow:1}.resize{resize:both}.list-disc{list-style-type:disc}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pl-5{padding-left:1.25rem}.text-\[15px\]{font-size:15px}.text-sm{font-size:.875rem;line-height:1.25rem}.leading-relaxed{line-height:1.625}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--bg-base: #000000;--bg-elev-1: #0b0b0c;--bg-elev-2: #141416;--bg-elev-3: #1c1c1f;--bg-elev-4: #26262a;--bg-overlay: rgba(8, 8, 9, .72);--bg-vibrancy: rgba(22, 22, 24, .62);--scrim: rgba(0, 0, 0, .48);--hairline: rgba(255, 255, 255, .07);--hairline-strong: rgba(255, 255, 255, .14);--hairline-vivid: rgba(255, 255, 255, .22);--ink: #ffffff;--ink-2: #c4c4c8;--ink-3: #8a8a8f;--ink-4: #5a5a5e;--ink-5: #3a3a3e;--primary-bg: #ffffff;--primary-fg: #000000;--primary-hover: #f0f0f2;--primary-press: #d9d9dd;--success: #30d158;--warning: #ffd60a;--danger: #ff453a;--info: #64d2ff;--shadow-1: 0 1px 2px rgba(0, 0, 0, .32), 0 1px 1px rgba(0, 0, 0, .18);--shadow-2: 0 8px 24px rgba(0, 0, 0, .42), 0 2px 6px rgba(0, 0, 0, .24);--shadow-3: 0 28px 70px rgba(0, 0, 0, .58), 0 10px 20px rgba(0, 0, 0, .34);--ring-focus: 0 0 0 4px rgba(255, 255, 255, .18);--r-xs: 6px;--r-sm: 10px;--r-md: 14px;--r-lg: 20px;--r-xl: 28px;--r-2xl: 36px;--r-full: 999px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-soft: cubic-bezier(.32, .72, 0, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--topbar-h: 64px;--control-h: 64px}html.theme-light{--bg-base: #ffffff;--bg-elev-1: #ffffff;--bg-elev-2: #f5f5f7;--bg-elev-3: #ebebef;--bg-elev-4: #dcdce0;--bg-overlay: rgba(255, 255, 255, .72);--bg-vibrancy: rgba(248, 248, 250, .62);--scrim: rgba(0, 0, 0, .32);--hairline: rgba(0, 0, 0, .08);--hairline-strong: rgba(0, 0, 0, .16);--hairline-vivid: rgba(0, 0, 0, .26);--ink: #000000;--ink-2: #3a3a3e;--ink-3: #6a6a6e;--ink-4: #9a9a9e;--ink-5: #c4c4c8;--primary-bg: #000000;--primary-fg: #ffffff;--primary-hover: #1a1a1a;--primary-press: #2a2a2a;--shadow-1: 0 1px 2px rgba(0, 0, 0, .06);--shadow-2: 0 10px 28px rgba(0, 0, 0, .08), 0 2px 6px rgba(0, 0, 0, .04);--shadow-3: 0 28px 70px rgba(0, 0, 0, .14), 0 10px 20px rgba(0, 0, 0, .08);--ring-focus: 0 0 0 4px rgba(0, 0, 0, .14)}:root{--text-primary: var(--ink);--text-secondary: var(--ink-2);--text-muted: var(--ink-3);--border: var(--hairline);--border-strong: var(--hairline-strong);--accent: var(--ink);--accent-soft: var(--bg-elev-2);--accent-fg: var(--primary-fg);--accent-gradient: var(--primary-bg);--accent-glow: var(--shadow-2)}html{color-scheme:dark}html.theme-light{color-scheme:light}*{box-sizing:border-box}body{margin:0;min-height:100svh;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Inter,Segoe UI Variable,Segoe UI,Helvetica Neue,Arial,sans-serif;font-feature-settings:"cv11","ss01","ss03";font-variant-ligatures:contextual;font-size:15px;line-height:1.5;letter-spacing:-.011em;background:var(--bg-base);color:var(--ink);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;-webkit-tap-highlight-color:transparent;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);overflow-x:hidden}button,input,select,textarea{font:inherit}button{color:inherit}::-moz-selection{background:var(--ink);color:var(--bg-base)}::selection{background:var(--ink);color:var(--bg-base)}body:before{content:"";position:fixed;inset:-260px;background:radial-gradient(680px circle at 14% 8%,rgba(255,255,255,.05),transparent 55%),radial-gradient(620px circle at 86% 92%,rgba(255,255,255,.04),transparent 60%);pointer-events:none;z-index:0;transition:opacity .48s var(--ease-out)}html.theme-light body:before{background:radial-gradient(680px circle at 14% 8%,rgba(0,0,0,.04),transparent 55%),radial-gradient(620px circle at 86% 92%,rgba(0,0,0,.03),transparent 60%)}#app{position:relative;z-index:1}#modal-root{position:relative;z-index:250}#toast-root{position:relative;position:fixed;top:max(20px,env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:260;display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:none;width:min(420px,calc(100% - 24px))}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:14.5px;padding:11px 22px;min-height:44px;border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;letter-spacing:-.012em;transition:transform .18s var(--ease-soft),background-color .2s var(--ease-soft),box-shadow .24s var(--ease-soft),opacity .16s var(--ease-soft),color .2s var(--ease-soft),border-color .2s var(--ease-soft);will-change:transform}.btn:active{transform:scale(.96);transition-duration:80ms}.btn:disabled{opacity:.4;pointer-events:none}.btn:focus-visible{outline:none;box-shadow:var(--ring-focus)}.btn-primary{background:var(--primary-bg);color:var(--primary-fg);box-shadow:var(--shadow-1)}.btn-primary:hover{background:var(--primary-hover);box-shadow:var(--shadow-2)}.btn-primary:active{background:var(--primary-press)}.btn-secondary{background:var(--bg-elev-2);color:var(--ink);border-color:var(--hairline)}.btn-secondary:hover{background:var(--bg-elev-3);border-color:var(--hairline-strong)}.btn-ghost{background:transparent;color:var(--ink-2)}.btn-ghost:hover{background:var(--bg-elev-2);color:var(--ink)}.btn-danger{background:var(--danger);color:#fff;box-shadow:var(--shadow-1)}.btn-danger:hover{filter:brightness(1.08)}.btn-with-icon{display:inline-flex;align-items:center;gap:8px}.btn-with-icon svg{width:16px;height:16px}.btn-icon{width:44px;height:44px;padding:0;border-radius:var(--r-md);background:transparent;border:0;cursor:pointer;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;transition:transform .18s var(--ease-soft),background-color .2s var(--ease-soft),color .2s var(--ease-soft),opacity .16s var(--ease-soft)}.btn-icon:active{transform:scale(.92)}.btn-icon.btn-round{border-radius:50%}.btn-icon.large{width:56px;height:56px}.btn-icon svg{width:20px;height:20px;pointer-events:none}.btn-icon.disabled{opacity:.35;pointer-events:none}.btn-icon.busy{opacity:.6;pointer-events:none}.btn.compact{min-height:36px;padding:8px 14px;font-size:13px;border-radius:var(--r-sm)}.btn-pill{padding:18px 36px;min-height:60px;border-radius:var(--r-full);font-size:16px;font-weight:650;letter-spacing:-.014em}.surface{background:var(--bg-elev-1);border:1px solid var(--hairline);border-radius:var(--r-lg)}.surface-elev{background:var(--bg-elev-2);border:1px solid var(--hairline);border-radius:var(--r-lg);box-shadow:var(--shadow-2)}.glass{background:var(--bg-vibrancy);backdrop-filter:blur(32px) saturate(180%);border:1px solid var(--hairline-strong)}.topbar{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:14px 22px;padding-top:calc(14px + env(safe-area-inset-top));background:var(--bg-overlay);backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid var(--hairline);z-index:40;animation:slideDown .48s var(--ease-out)}.topbar .brand{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:17px;letter-spacing:-.024em}.topbar .brand-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;padding:0;cursor:pointer}.topbar .brand-button:focus-visible{outline:none;box-shadow:var(--ring-focus);border-radius:var(--r-sm)}.topbar .brand .logo{width:32px;height:32px;border-radius:9px;background:var(--ink);color:var(--bg-base);display:grid;place-items:center;font-size:15px;font-weight:800;box-shadow:var(--shadow-1);transition:transform .32s var(--ease-spring)}.topbar .brand:hover .logo{transform:rotate(-6deg) scale(1.06)}.topbar .actions{display:flex;align-items:center;gap:8px}.user-pill{display:inline-flex;align-items:center;min-height:36px;max-width:160px;padding:0 14px;border-radius:var(--r-full);background:var(--bg-elev-2);border:1px solid var(--hairline);color:var(--ink);font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.theme-btn{position:relative;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--bg-elev-2);border:1px solid var(--hairline);color:var(--ink);cursor:pointer;transition:transform .26s var(--ease-spring),background-color .2s var(--ease-soft),border-color .2s var(--ease-soft)}.theme-btn:hover{background:var(--bg-elev-3);border-color:var(--hairline-strong);transform:scale(1.06)}.theme-btn:active{transform:scale(.92)}.theme-btn svg{width:18px;height:18px}.settings-wrap{position:relative}.settings-menu{position:absolute;top:calc(100% + 12px);right:0;min-width:240px;max-width:280px;background:var(--bg-elev-1);border:1px solid var(--hairline-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-3);padding:8px;z-index:60;transform-origin:top right;transform:scale(.92) translateY(-4px);opacity:0;pointer-events:none;transition:transform .22s var(--ease-spring),opacity .2s var(--ease-soft)}.settings-menu.open{transform:scale(1) translateY(0);opacity:1;pointer-events:auto}.settings-user{display:grid;grid-template-columns:40px 1fr;gap:12px;padding:10px 12px;align-items:center}.settings-user-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-elev-3);color:var(--ink);display:grid;place-items:center;font-weight:800;font-size:16px}.settings-user strong{display:block;font-size:14px;font-weight:700;letter-spacing:-.015em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-user span{display:block;font-size:12px;color:var(--ink-3)}.settings-divider{height:1px;background:var(--hairline);margin:4px 0}.settings-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:0;background:transparent;color:var(--ink);font:inherit;font-size:14px;font-weight:500;text-align:left;border-radius:var(--r-sm);cursor:pointer;transition:background .16s var(--ease-soft)}.settings-item:hover{background:var(--bg-elev-2)}.settings-item.danger{color:var(--danger)}.settings-item.danger:hover{background:color-mix(in srgb,var(--danger) 12%,var(--bg-elev-2))}.settings-item svg{flex:0 0 auto}.profile-body{display:flex;flex-direction:column;gap:8px}.profile-avatar{width:84px;height:84px;border-radius:50%;background:var(--ink);color:var(--bg-base);display:grid;place-items:center;font-weight:800;font-size:32px;margin:0 auto 4px;overflow:visible;border:0;padding:0;position:relative}.profile-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;border-radius:50%}.profile-avatar-edit{cursor:pointer;transition:transform .2s var(--ease-soft)}.profile-avatar-edit:hover{transform:scale(1.04)}.profile-avatar-edit.busy{opacity:.6;pointer-events:none}.profile-avatar-edit:after{content:"";position:absolute;right:2px;bottom:2px;width:26px;height:26px;border-radius:50%;background:var(--primary, #5b8cff);border:2px solid var(--bg-elev-1);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M23 19a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h4l2-3h6l2 3h4a2 2 0 0 1 2 2z'/><circle cx='12' cy='13' r='4'/></svg>");background-size:14px 14px;background-repeat:no-repeat;background-position:center;box-shadow:0 2px 6px #00000040}.profile-avatar-hint{display:block;text-align:center;font-size:11.5px;color:var(--ink-3);margin:2px 0 6px;letter-spacing:-.005em}.avatar-file-input{display:none}.profile-remove-avatar{align-self:center;margin-bottom:4px}.profile-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:10px 12px;background:var(--bg-elev-2);border-radius:var(--r-sm)}.profile-label{font-size:12px;color:var(--ink-3);font-weight:600}.profile-value{font-size:14px;font-weight:600;letter-spacing:-.012em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%}.notif-wrap,.notif-btn{position:relative}.notif-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;border-radius:999px;background:var(--danger);color:#fff;font-size:10px;font-weight:800;display:grid;place-items:center;padding:0 5px;letter-spacing:0;border:2px solid var(--bg-base);transform-origin:center;animation:badgePop .38s var(--ease-spring)}.notif-drawer{position:absolute;top:calc(100% + 12px);right:0;width:min(360px,calc(100vw - 24px));max-height:480px;overflow:hidden;display:flex;flex-direction:column;background:var(--bg-elev-1);border:1px solid var(--hairline-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-3);z-index:50;transform-origin:top right;transform:scale(.94) translateY(-6px);opacity:0;pointer-events:none;transition:transform .24s var(--ease-spring),opacity .2s var(--ease-soft)}.notif-drawer.open{transform:scale(1) translateY(0);opacity:1;pointer-events:auto}.notif-drawer.hidden{display:none}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--hairline)}.notif-header strong{font-size:15px;letter-spacing:-.015em}.notif-list{overflow-y:auto;padding:8px}.notif-empty{padding:36px 20px;text-align:center;color:var(--ink-3);font-size:14px}.notif-row{display:grid;grid-template-columns:36px 1fr;gap:12px;padding:10px;border-radius:var(--r-md);align-items:start;transition:background .16s var(--ease-soft);animation:rise .32s var(--ease-out)}.notif-row:hover{background:var(--bg-elev-2)}.notif-row.busy{opacity:.5;pointer-events:none}.notif-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-elev-3);color:var(--ink);display:grid;place-items:center;font-weight:700;font-size:14px}.notif-body{min-width:0}.notif-text{font-size:13.5px;color:var(--ink-2);letter-spacing:-.005em}.notif-text strong{color:var(--ink);font-weight:600}.notif-actions{margin-top:8px;display:flex;gap:6px}.notif-actions .btn{min-height:32px;padding:6px 12px;font-size:12.5px}.friends-backdrop{position:fixed;inset:0;background:var(--scrim);backdrop-filter:blur(8px);z-index:80;opacity:0;transition:opacity .32s var(--ease-out)}.friends-backdrop.visible{opacity:1}.dm-backdrop{position:fixed;inset:0;background:transparent;z-index:94;opacity:0;transition:opacity .22s var(--ease-out)}.dm-backdrop.visible{opacity:1}.ctx-menu{position:fixed;z-index:200;min-width:180px;padding:6px;border-radius:var(--r-md);background:var(--bg-vibrancy);border:1px solid var(--hairline-strong);backdrop-filter:blur(20px) saturate(180%);box-shadow:var(--shadow-2);display:flex;flex-direction:column;gap:2px;opacity:0;transform:translateY(-4px) scale(.98);transform-origin:top left;transition:opacity .14s var(--ease-soft),transform .14s var(--ease-soft)}.ctx-menu.open{opacity:1;transform:translateY(0) scale(1)}.ctx-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border:0;background:transparent;color:var(--ink);font-size:13.5px;font-weight:500;text-align:left;cursor:pointer;border-radius:var(--r-sm);transition:background .12s var(--ease-soft)}.ctx-item:hover{background:var(--bg-elev-2)}.ctx-item.danger{color:var(--danger)}.ctx-item.danger:hover{background:#ef44441a}.ctx-item.disabled{opacity:.4;pointer-events:none}.ctx-item svg{width:16px;height:16px;flex-shrink:0}.ctx-divider{height:1px;background:var(--hairline);margin:4px 2px}.ctx-slider{display:flex;flex-direction:column;gap:6px;padding:8px 10px}.ctx-slider-label{font-size:12px;color:var(--ink-3);font-weight:600}.ctx-slider-row{display:flex;align-items:center;gap:8px}.ctx-slider-input{flex:1;accent-color:var(--accent, #0a84ff);cursor:pointer}.ctx-slider-val{font-size:12px;color:var(--ink-2);min-width:34px;text-align:right}.friends-panel{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:460px;display:flex;flex-direction:column;background:var(--bg-elev-1);border-left:1px solid var(--hairline-strong);box-shadow:var(--shadow-3);transform:translate(100%);transition:transform .38s var(--ease-out);z-index:85;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.friends-panel.open{transform:translate(0)}.friends-panel.busy{opacity:.75;pointer-events:none}.friends-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:1px solid var(--hairline)}.friends-title{display:block;font-size:20px;font-weight:700;letter-spacing:-.024em}.friends-count{display:block;font-size:12px;color:var(--ink-3);margin-top:2px;font-weight:600}.friends-header-actions{display:flex;gap:4px}.friends-header-actions .btn-icon{width:38px;height:38px;border-radius:50%;color:var(--ink)}.friends-header-actions .btn-icon:hover{background:var(--bg-elev-2)}.friends-close{background:var(--danger)!important;color:#fff;display:grid;place-items:center;padding:0;line-height:0}.friends-close svg{width:16px;height:16px;display:block}.friends-close:hover{filter:brightness(1.08);background:var(--danger)!important;color:#fff}.friends-body{flex:1;overflow-y:auto;display:flex;flex-direction:column}.friends-section{display:flex;flex-direction:column;padding:6px 12px}.friends-section+.friends-section{border-top:1px solid var(--hairline);margin-top:6px;padding-top:12px}.friends-section h3{margin:8px 4px;font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--ink-3);text-transform:uppercase;display:flex;align-items:center;justify-content:space-between}.section-count{background:var(--ink);color:var(--bg-base);font-size:10.5px;font-weight:800;padding:1px 7px;border-radius:var(--r-full);letter-spacing:0}.add-section .friends-add-row{display:flex;gap:8px;margin-bottom:4px}.add-section .input{flex:1}.friend-request-row{display:grid;grid-template-columns:36px 1fr auto;gap:12px;padding:10px 8px;border-radius:var(--r-md);align-items:center;animation:rise .32s var(--ease-out)}.friend-request-row.busy{opacity:.55;pointer-events:none}.friend-request-row:hover{background:var(--bg-elev-2)}.request-actions{display:flex;gap:6px}.request-actions .btn{min-height:32px;padding:6px 12px;font-size:12.5px}.requests-view-all{align-self:stretch;margin:8px 4px 4px;font-size:12.5px}.requests-back-row{display:flex;align-items:center;gap:10px;margin:4px 4px 12px}.requests-back-btn{padding:6px 10px!important;font-size:13px!important;min-height:30px!important}.requests-back-title{font-size:14px;letter-spacing:-.012em}.friends-section.hidden,.add-section.hidden{display:none}.friends-list{display:flex;flex-direction:column;gap:2px}.friends-list.hidden{display:none}.friend-row{display:grid;grid-template-columns:44px 1fr auto;gap:12px;align-items:center;padding:10px 12px;border-radius:var(--r-md);transition:background .2s var(--ease-soft);animation:rise .32s var(--ease-out)}.friend-row:hover{background:var(--bg-elev-2)}.friend-avatar{width:44px;height:44px;border-radius:50%;background:var(--bg-elev-3);color:var(--ink);display:grid;place-items:center;font-weight:700;font-size:17px;letter-spacing:-.01em}.friend-meta{min-width:0}.friend-name-row{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.friend-meta strong{display:block;font-size:15px;font-weight:600;letter-spacing:-.012em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-time{flex:0 0 auto;font-size:11.5px;color:var(--ink-3);font-variant-numeric:tabular-nums}.friend-status{display:block;font-size:12.5px;color:var(--ink-3);margin-top:2px;letter-spacing:-.005em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-status.has-message{color:var(--ink-2)}.friend-row.has-unread .friend-meta strong,.friend-row.has-unread .friend-status{color:var(--ink);font-weight:650}.friend-row.has-unread .friend-time{color:var(--ink);font-weight:600}.friend-trailing{display:flex;align-items:center;gap:6px}.unread-badge{background:var(--danger);color:#fff;font-size:11px;font-weight:800;min-width:20px;height:20px;padding:0 6px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;letter-spacing:0;animation:badgePop .38s var(--ease-spring)}.friend-action{width:36px;height:36px;border-radius:50%;background:transparent;border:0;color:var(--ink-3);cursor:pointer;display:grid;place-items:center;transition:background .2s var(--ease-soft),color .2s var(--ease-soft),transform .18s var(--ease-soft)}.friend-action:hover{background:var(--bg-elev-3);color:var(--danger)}.friend-action:active{transform:scale(.9)}.friends-empty{flex:1;display:grid;place-items:center;align-content:center;gap:8px;padding:48px 24px;text-align:center;color:var(--ink-3)}.friends-empty.hidden{display:none}.friends-empty-illus{font-size:44px;margin-bottom:8px;animation:breathe 3.6s var(--ease-out) infinite}.friends-empty strong{display:block;font-size:17px;color:var(--ink);letter-spacing:-.018em;font-weight:700}.friends-empty span{display:block;font-size:14px;max-width:280px;margin:0 auto;line-height:1.45}@media (max-width: 520px){.friends-panel{max-width:none}}.dm-panel{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:460px;display:flex;flex-direction:column;background:var(--bg-elev-1);border-left:1px solid var(--hairline-strong);box-shadow:var(--shadow-3);transform:translate(100%);transition:transform .38s var(--ease-out);z-index:95;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.dm-panel.open{transform:translate(0)}.dm-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--hairline)}.dm-back{width:38px;height:38px;border-radius:50%;color:var(--ink)}.dm-back:hover{background:var(--bg-elev-2)}.dm-remove{width:38px;height:38px;border-radius:50%;color:var(--danger);margin-left:auto}.dm-remove:hover{background:#ef44441f}.dm-remove svg{width:18px;height:18px}.dm-friend-avatar{width:38px;height:38px;border-radius:50%;background:var(--bg-elev-3);color:var(--ink);display:grid;place-items:center;font-weight:700;font-size:14px}.dm-friend-meta{min-width:0;flex:1}.dm-friend-meta strong{display:block;font-size:15px;font-weight:700;letter-spacing:-.014em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dm-friend-presence{display:block;font-size:12px;color:var(--ink-3);margin-top:1px}.dm-messages{flex:1;overflow-y:auto;padding:18px 16px 8px;display:flex;flex-direction:column;gap:6px;scroll-behavior:smooth}.dm-messages.hidden{display:none}.dm-day-sep{align-self:center;margin:14px 0 8px;padding:4px 12px;border-radius:var(--r-full);background:var(--bg-elev-2);color:var(--ink-3);font-size:11px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.dm-bubble{position:relative;max-width:78%;min-width:96px;padding:9px 14px 22px;border-radius:18px;font-size:14.5px;line-height:1.4;letter-spacing:-.005em;word-break:break-word;animation:msgIn .24s var(--ease-out)}.dm-bubble.own{align-self:flex-end;background:var(--ink);color:var(--bg-base);border-bottom-right-radius:6px}.dm-bubble.peer{align-self:flex-start;background:var(--bg-elev-3);color:var(--ink);border-bottom-left-radius:6px}.dm-bubble.pending{opacity:.6}.dm-bubble-text{display:inline}.dm-bubble-time{position:absolute;bottom:6px;right:12px;font-size:10.5px;opacity:.6;font-variant-numeric:tabular-nums}.dm-bubble.peer .dm-bubble-time{right:auto;left:12px}.dm-empty{flex:1;display:grid;place-items:center;align-content:center;gap:8px;padding:48px 24px;text-align:center;color:var(--ink-3)}.dm-empty.hidden{display:none}.dm-empty-illus{font-size:44px;margin-bottom:8px}.dm-empty strong{display:block;font-size:17px;color:var(--ink);font-weight:700;letter-spacing:-.018em}.dm-empty span{display:block;font-size:14px;max-width:280px;margin:0 auto;line-height:1.45}.dm-composer{display:flex;gap:8px;padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--hairline);background:var(--bg-elev-1)}.dm-composer.hidden{display:none}.dm-input{flex:1}.dm-lock-banner{display:flex;align-items:center;gap:12px;padding:14px 16px;padding-bottom:calc(14px + env(safe-area-inset-bottom));border-top:1px solid var(--hairline);background:var(--bg-elev-2)}.dm-lock-banner.hidden{display:none}.dm-lock-text{flex:1;font-size:13px;line-height:1.4;color:var(--ink-2);letter-spacing:-.005em}.dm-lock-banner .btn{flex-shrink:0}@media (max-width: 520px){.dm-panel{max-width:none}}.landing{min-height:100svh;display:flex;align-items:center;justify-content:center;padding:calc(var(--topbar-h) + 32px) 20px 40px}.landing-inner{width:100%;max-width:540px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:28px;animation:heroIn .72s var(--ease-out)}.landing-copy{display:flex;flex-direction:column;align-items:center;gap:12px}.landing-title{margin:0;font-size:clamp(32px,5.4vw,52px);font-weight:700;letter-spacing:-.042em;line-height:1;white-space:nowrap;background:linear-gradient(180deg,var(--ink) 0%,color-mix(in srgb,var(--ink) 50%,transparent) 110%);-webkit-background-clip:text;background-clip:text;color:transparent}@media (max-width: 380px){.landing-title{font-size:28px}}.landing-subtitle{margin:0;font-size:16px;color:var(--ink-2);max-width:440px;letter-spacing:-.006em;line-height:1.45}.cam-card{width:100%;position:relative;background:var(--bg-elev-1);border:1px solid var(--hairline);border-radius:var(--r-xl);overflow:hidden;aspect-ratio:4 / 3;box-shadow:var(--shadow-2);transition:transform .32s var(--ease-out),box-shadow .32s var(--ease-out)}.cam-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-3)}.cam-card video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transform:scaleX(-1);background:var(--bg-elev-2);display:block}.landing-video.hidden{display:none}.cam-card .cam-overlay{position:absolute;inset:0;display:grid;place-items:center;background:var(--bg-elev-1);color:var(--ink-2);animation:fadeIn .32s var(--ease-out)}.cam-card .cam-overlay-stack{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;padding:24px}.cam-card .cam-overlay-stack strong{font-size:17px;color:var(--ink);letter-spacing:-.018em}.cam-card .cam-overlay-stack span{font-size:14px;color:var(--ink-3)}.cam-card .cam-toggle-row{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:6px;padding:6px;background:var(--bg-vibrancy);border-radius:var(--r-full);border:1px solid var(--hairline-strong);backdrop-filter:blur(24px) saturate(180%);box-shadow:var(--shadow-2)}.cam-card .cam-toggle-row .btn-icon{width:42px;height:42px;background:transparent;color:var(--ink);border-radius:50%}.cam-card .cam-toggle-row .btn-icon.off{color:var(--danger)}.cam-card .cam-toggle-row .btn-icon:hover{background:var(--bg-elev-3)}.cam-card .cam-flip-btn{position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;background:var(--bg-vibrancy);color:var(--ink);border:1px solid var(--hairline-strong);backdrop-filter:blur(20px) saturate(180%);display:none;place-items:center;cursor:pointer;z-index:5}.cam-card .cam-flip-btn svg{width:18px;height:18px}.cam-card .cam-flip-btn:active{transform:scale(.92)}.tile-actions.self-actions{display:none}@media (max-width: 768px){.cam-card .cam-flip-btn{display:grid}.tile-actions.self-actions{display:flex}}.start-button{min-width:min(100%,320px)}.chip-row{display:inline-flex;padding:4px;border-radius:var(--r-full);background:var(--bg-elev-2);border:1px solid var(--hairline)}.chip{padding:10px 20px;border-radius:var(--r-full);background:transparent;border:0;color:var(--ink-2);font-size:13.5px;font-weight:600;cursor:pointer;transition:all .24s var(--ease-soft);letter-spacing:-.005em}.chip:hover{color:var(--ink)}.chip.active{background:var(--bg-elev-1);color:var(--ink);box-shadow:var(--shadow-1)}html.theme-light .chip.active{background:#fff;box-shadow:0 1px 2px #00000014,0 .5px .5px #0000000a}.searching-tile{background:linear-gradient(160deg,var(--bg-elev-1),var(--bg-elev-2))}.searching-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center}.searching-orb{width:116px;height:116px;border-radius:50%;margin:0 auto 24px;display:grid;place-items:center;position:relative;background:radial-gradient(circle,var(--bg-elev-3),var(--bg-elev-2));animation:breathe 3.4s var(--ease-out) infinite}.searching-orb:before,.searching-orb:after{content:"";position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--hairline-strong);animation:pulse-ring 2.6s ease-out infinite}.searching-orb:after{animation-delay:1.3s}.searching-orb-inner{width:64px;height:64px;border-radius:50%;background:var(--ink);color:var(--bg-base);display:grid;place-items:center;font-size:28px;font-weight:800;letter-spacing:-.02em;box-shadow:var(--shadow-1)}.searching-title{margin:0 0 12px;font-size:clamp(22px,2.6vw,28px);font-weight:700;letter-spacing:-.026em}.searching-meta{margin:0 0 4px;color:var(--ink-2);font-size:14px}.searching-timer{margin:0 0 6px;color:var(--ink-3);font-size:13px;font-variant-numeric:tabular-nums}.searching-hint{margin:0;color:var(--ink-3);font-size:12.5px;min-height:18px;letter-spacing:-.005em}.searching-actions{margin-top:24px}@media (max-width: 768px){.searching-overlay{padding:20px}.searching-orb{width:88px;height:88px;margin-bottom:18px}.searching-orb-inner{width:48px;height:48px;font-size:22px}.searching-title{font-size:19px;margin-bottom:8px}}.stage{position:relative;width:100%;min-height:100svh;background:var(--bg-base);animation:fadeIn .32s var(--ease-out);display:flex;align-items:center;justify-content:center;padding:calc(var(--topbar-h) + 28px) 24px calc(var(--control-h) + 32px + env(safe-area-inset-bottom))}.stage-grid{width:100%;max-width:1380px;display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:stretch;animation:heroIn .54s var(--ease-out)}.stage-grid>.video-tile{aspect-ratio:4 / 3;height:auto;max-height:none}.video-tile{position:relative;width:100%;height:100%;border-radius:var(--r-xl);overflow:hidden;background:linear-gradient(160deg,var(--bg-elev-1),var(--bg-elev-2));border:1px solid var(--hairline);box-shadow:var(--shadow-2);min-height:0;animation:tileIn .48s var(--ease-out)}.video-tile.peer{animation-delay:80ms;animation-fill-mode:both}.video-tile video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.video-tile.self video{transform:scaleX(-1)}.video-tile.self.is-off video{opacity:0}.tile-label{position:absolute;left:14px;bottom:14px;padding:7px 14px;border-radius:var(--r-full);background:var(--bg-vibrancy);border:1px solid var(--hairline-strong);backdrop-filter:blur(20px) saturate(180%);color:var(--ink);font-size:12px;font-weight:600;letter-spacing:-.005em;display:inline-flex;align-items:center;gap:8px}.tile-label .dot{width:6px;height:6px;border-radius:50%;background:var(--success);box-shadow:0 0 0 3px color-mix(in srgb,var(--success) 24%,transparent);animation:pulseDot 2.4s ease-in-out infinite}.tile-label-avatar{width:22px;height:22px;border-radius:50%;background:var(--bg-elev-3);color:var(--ink);display:grid;place-items:center;font-weight:700;font-size:11px;overflow:hidden;flex-shrink:0}.tile-label-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.tile-label-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-label.is-admin{border-color:#ffd60a;box-shadow:0 0 0 1px #ffd60a,0 0 12px #ffd60a59}.tile-actions{position:absolute;top:14px;right:14px;display:flex;gap:6px;z-index:5}.tile-action{width:38px;height:38px;border-radius:50%;background:var(--bg-vibrancy);color:var(--ink);border:1px solid var(--hairline-strong);backdrop-filter:blur(20px) saturate(180%);display:grid;place-items:center;cursor:pointer;transition:transform .2s var(--ease-soft),background .2s var(--ease-soft)}.tile-action:hover{background:var(--bg-elev-3);transform:scale(1.06)}.tile-action:active{transform:scale(.92)}.tile-action svg{width:16px;height:16px}.tile-action.disabled{opacity:.45;pointer-events:none}.tile-action.busy{opacity:.55;pointer-events:none}.tile-action.danger{color:var(--danger)}.tile-action.danger:hover{background:color-mix(in srgb,var(--danger) 16%,var(--bg-vibrancy))}.control-bar.searching-controls .btn-icon{width:48px;height:48px}.tile-empty{position:absolute;inset:0;display:grid;place-items:center;color:var(--ink-3);font-size:14px;letter-spacing:-.005em;background:linear-gradient(160deg,var(--bg-elev-1),var(--bg-elev-2))}.tile-empty .avatar-circle{width:84px;height:84px;border-radius:50%;background:var(--bg-elev-3);display:grid;place-items:center;font-size:36px;font-weight:800;color:var(--ink-2);margin-bottom:14px;animation:breathe 3s var(--ease-out) infinite}.tile-empty.hidden{display:none}.control-bar{position:fixed;bottom:calc(20px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);display:inline-flex;align-items:center;gap:6px;padding:8px;border-radius:var(--r-full);background:var(--bg-vibrancy);border:1px solid var(--hairline-strong);box-shadow:var(--shadow-3);backdrop-filter:blur(32px) saturate(180%);z-index:20;animation:floatIn .52s var(--ease-spring);max-width:calc(100% - 24px);width:auto}@media (min-width: 769px){body.body--in-call .stage,body.body--searching .stage{flex-direction:column;gap:16px;padding-bottom:calc(24px + env(safe-area-inset-bottom))}body.body--in-call .control-bar,body.body--searching .control-bar{position:relative;bottom:auto;left:auto;transform:none;animation:rise .36s var(--ease-out)}}.control-bar .next-btn.disabled,.control-bar .next-btn[aria-disabled=true]{opacity:.4;pointer-events:none;cursor:default;filter:grayscale(.4)}.control-bar .btn-icon{background:transparent;color:var(--ink);border-radius:50%;width:48px;height:48px;transition:transform .18s var(--ease-soft),background-color .2s var(--ease-soft),color .2s var(--ease-soft)}.control-bar .btn-icon:hover{background:var(--bg-elev-3)}.control-bar .btn-icon:active{transform:scale(.88)}.control-bar .btn-icon.danger{background:var(--danger);color:#fff}.control-bar .btn-icon.danger:hover{filter:brightness(1.1);background:var(--danger)}.control-bar .btn-icon.off,.control-bar .btn-icon.report-btn{color:var(--danger)}.control-bar .btn-icon.report-btn:hover{background:color-mix(in srgb,var(--danger) 16%,transparent);color:var(--danger)}.guest-id{width:36px;height:36px;border-radius:50%;background:var(--bg-elev-2);border:1px solid var(--hairline);color:var(--ink-2);display:grid;place-items:center;transition:background .2s var(--ease-soft)}.guest-id:hover{background:var(--bg-elev-3)}.guest-id svg{width:16px;height:16px}.control-bar .next-btn{height:48px;padding:0 24px;border-radius:var(--r-full);font-size:14.5px;min-width:132px;background:var(--ink);color:var(--bg-base);border:0;cursor:pointer;font-weight:650;display:inline-flex;align-items:center;justify-content:center;gap:8px;letter-spacing:-.012em;transition:transform .18s var(--ease-soft),background .2s var(--ease-soft),box-shadow .24s var(--ease-soft)}.control-bar .next-btn svg{width:16px;height:16px}.control-bar .next-btn:hover{background:var(--primary-hover);box-shadow:var(--shadow-2)}.control-bar .next-btn:active{transform:scale(.96)}.quality-indicator{position:absolute;top:16px;left:16px;display:inline-flex;align-items:end;gap:3px;padding:9px 12px;border-radius:var(--r-md);background:var(--bg-vibrancy);border:1px solid var(--hairline-strong);backdrop-filter:blur(20px) saturate(180%);z-index:20;animation:rise .48s var(--ease-out)}.quality-indicator .bar{width:4px;border-radius:2px;background:var(--ink-4);opacity:.55;transition:background .2s var(--ease-soft)}.quality-indicator .bar:nth-child(1){height:8px}.quality-indicator .bar:nth-child(2){height:12px}.quality-indicator .bar:nth-child(3){height:16px}.quality-indicator.good .bar{background:var(--success);opacity:1}.quality-indicator.medium .bar:nth-child(1),.quality-indicator.medium .bar:nth-child(2){background:var(--warning);opacity:1}.quality-indicator.poor .bar:nth-child(1){background:var(--danger);opacity:1}@media (max-width: 768px){.stage{padding:0;align-items:stretch;height:100svh;min-height:100svh}.stage-grid{grid-template-columns:1fr;grid-template-rows:1fr 1fr;gap:8px;padding:8px;padding-top:calc(var(--topbar-h) + 8px + env(safe-area-inset-top));padding-bottom:calc(var(--control-h) + 20px + env(safe-area-inset-bottom));height:100%;max-width:none}.stage-grid>.video-tile{aspect-ratio:auto;height:auto}.video-tile{border-radius:var(--r-lg)}.control-bar{gap:4px;padding:6px}.control-bar .btn-icon{width:44px;height:44px}.control-bar .btn-icon svg{width:19px;height:19px}.control-bar .next-btn{height:44px;min-width:124px;padding:0 20px;font-size:14px}.topbar{padding:8px 14px;padding-top:calc(8px + env(safe-area-inset-top))}.topbar .brand .logo{width:28px;height:28px;font-size:14px}.topbar .brand span:last-child{font-size:15px}}@media (max-width: 420px){.control-bar .btn-icon{width:42px;height:42px}.control-bar .next-btn{min-width:100px;padding:0 16px}.tile-label{padding:6px 10px;font-size:11px}}.chat-panel{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:460px;display:flex;flex-direction:column;background:var(--bg-vibrancy);backdrop-filter:blur(32px) saturate(180%);border-left:1px solid var(--hairline);transform:translate(100%);transition:transform .38s var(--ease-out);z-index:50;box-shadow:var(--shadow-3)}.chat-panel.open{transform:translate(0)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;padding-top:calc(14px + env(safe-area-inset-top));border-bottom:1px solid var(--hairline)}.chat-title{font-weight:700;font-size:16px;letter-spacing:-.018em}.chat-header .btn-icon{font-size:22px;line-height:1;width:36px;height:36px;border-radius:50%}@media (max-width: 768px){.chat-header .btn-icon{background:var(--danger);color:#fff;width:40px;height:40px;font-size:26px;font-weight:600}.chat-header .btn-icon:hover{filter:brightness(1.08);background:var(--danger)}}.chat-messages{flex:1;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:4px;scroll-behavior:smooth}.chat-msg{max-width:78%;padding:9px 14px;border-radius:18px;font-size:14.5px;line-height:1.4;word-break:break-word;animation:msgIn .28s var(--ease-out);letter-spacing:-.005em}.chat-msg.own{align-self:flex-end;background:var(--ink);color:var(--bg-base);border-bottom-right-radius:6px}.chat-msg.peer{align-self:flex-start;background:var(--bg-elev-3);color:var(--ink);border-bottom-left-radius:6px}.chat-input-row{padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--hairline);display:flex;gap:8px}.input{flex:1;background:var(--bg-elev-2);border:1px solid var(--hairline);border-radius:var(--r-md);padding:11px 14px;min-height:44px;color:var(--ink);font-size:14.5px;outline:none;transition:border-color .2s var(--ease-soft),box-shadow .24s var(--ease-soft),background .2s var(--ease-soft);letter-spacing:-.005em}select.input{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.input::-moz-placeholder{color:var(--ink-3)}.input::placeholder{color:var(--ink-3)}.input:focus{border-color:var(--hairline-vivid);box-shadow:var(--ring-focus);background:var(--bg-elev-1)}textarea.input{resize:vertical;min-height:76px}@media (min-width: 769px){body.body--in-call #toast-root{top:auto;bottom:calc(100px + env(safe-area-inset-bottom))}}.toast{pointer-events:auto;padding:12px 20px;border-radius:var(--r-md);font-size:14px;font-weight:500;background:var(--bg-vibrancy);color:var(--ink);border:1px solid var(--hairline-strong);box-shadow:var(--shadow-2);backdrop-filter:blur(24px) saturate(180%);animation:toastIn .32s var(--ease-spring);letter-spacing:-.005em}.toast.success{border-color:color-mix(in srgb,var(--success) 50%,transparent)}.toast.error{border-color:color-mix(in srgb,var(--danger) 50%,transparent)}.toast.warn{border-color:color-mix(in srgb,var(--warning) 50%,transparent)}.toast.info{border-color:color-mix(in srgb,var(--info) 40%,transparent)}.modal-backdrop{position:fixed;inset:0;background:var(--scrim);backdrop-filter:blur(18px);display:grid;place-items:center;padding:20px;z-index:200;animation:fadeIn .28s var(--ease-out)}.modal-card{width:100%;max-width:460px;background:var(--bg-elev-1);border:1px solid var(--hairline);border-radius:var(--r-xl);box-shadow:var(--shadow-3);padding:28px;animation:modalIn .38s var(--ease-spring)}.modal-title{font-size:24px;font-weight:700;letter-spacing:-.028em;margin:0 0 6px}.modal-subtitle{font-size:14.5px;color:var(--ink-2);margin:0 0 18px;letter-spacing:-.005em}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;flex-wrap:wrap}.auth-body{margin-top:14px}.tab-row{display:flex;background:var(--bg-elev-2);border-radius:var(--r-md);padding:4px;margin-bottom:18px;border:1px solid var(--hairline)}.tab{flex:1;padding:9px 12px;border-radius:10px;font-size:13.5px;font-weight:600;cursor:pointer;text-align:center;color:var(--ink-2);transition:all .2s var(--ease-soft);background:transparent;border:0;letter-spacing:-.005em}.tab.active{background:var(--bg-elev-1);color:var(--ink);box-shadow:var(--shadow-1)}.tab:not(.active):hover{color:var(--ink)}.field-stack{display:flex;flex-direction:column;gap:14px}.field-stack label{font-size:12px;color:var(--ink-2);font-weight:600;letter-spacing:-.005em}.field-stack .field{display:flex;flex-direction:column;gap:6px}.field-stack .btn[type=submit]{margin-top:4px}.admin-shell{min-height:100svh;padding:16px}.admin-layout{width:min(1440px,100%);min-height:calc(100svh - 32px);margin:0 auto;display:grid;grid-template-columns:264px minmax(0,1fr);gap:16px}.admin-sidebar,.admin-main{background:var(--bg-elev-1);border:1px solid var(--hairline);border-radius:var(--r-xl);box-shadow:var(--shadow-1)}.admin-panel,.admin-filter-bar,.admin-stat,.admin-gate-card{background:var(--bg-elev-1);border:1px solid var(--hairline);border-radius:var(--r-lg)}.admin-sidebar{position:sticky;top:16px;height:calc(100svh - 32px);padding:22px 18px;display:flex;flex-direction:column;gap:22px}.admin-brand{display:flex;align-items:center;gap:12px}.admin-brand.center{justify-content:center}.admin-brand .logo{width:40px;height:40px;border-radius:12px;background:var(--ink);color:var(--bg-base);display:grid;place-items:center;font-size:18px;font-weight:850;box-shadow:var(--shadow-1)}.admin-brand strong{display:block;font-size:15.5px;letter-spacing:-.018em}.admin-brand span:not(.logo){display:block;color:var(--ink-2);font-size:12px}.admin-nav{display:flex;flex-direction:column;gap:4px}.admin-nav-item{width:100%;min-height:42px;padding:0 14px;border:0;border-radius:var(--r-md);background:transparent;color:var(--ink-2);font:inherit;font-weight:600;text-align:left;cursor:pointer;letter-spacing:-.005em;transition:background .2s var(--ease-soft),color .2s var(--ease-soft)}.admin-nav-item:hover{background:var(--bg-elev-2);color:var(--ink)}.admin-nav-item.active{background:var(--bg-elev-3);color:var(--ink)}.admin-sidebar-actions{margin-top:auto;display:grid;gap:8px}.admin-main{min-width:0;padding:26px}.admin-topline{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid var(--hairline)}.admin-topline h1{margin:0;font-size:clamp(24px,2.6vw,34px);line-height:1.1;letter-spacing:-.03em;font-weight:700}.admin-topline p{margin:6px 0 0;color:var(--ink-2);font-size:14.5px}.admin-user{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--r-full);background:var(--bg-elev-2);border:1px solid var(--hairline);white-space:nowrap;font-size:13px;font-weight:600}.badge{display:inline-flex;align-items:center;min-height:22px;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--hairline);background:var(--bg-elev-2);color:var(--ink-2);font-size:11px;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.badge.status-pending,.badge.status-banned{color:var(--warning);border-color:color-mix(in srgb,var(--warning) 45%,transparent);background:color-mix(in srgb,var(--warning) 10%,transparent)}.badge.status-actioned,.badge.status-active,.badge.role-admin{color:var(--success);border-color:color-mix(in srgb,var(--success) 45%,transparent);background:color-mix(in srgb,var(--success) 10%,transparent)}.badge.status-dismissed,.badge.status-deleted{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 45%,transparent);background:color-mix(in srgb,var(--danger) 10%,transparent)}.badge.status-reviewed,.badge.role-moderator{color:var(--ink);border-color:var(--hairline-strong);background:var(--bg-elev-3)}.admin-stack{display:flex;flex-direction:column;gap:16px}.admin-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}.admin-stat{padding:18px}.admin-stat span,.admin-stat small{display:block;color:var(--ink-2)}.admin-stat span{font-size:12.5px;font-weight:600;letter-spacing:-.005em}.admin-stat strong{display:block;margin:6px 0 2px;font-size:34px;line-height:1;letter-spacing:-.034em;font-weight:700;color:var(--ink)}.admin-stat small{font-size:12px}.admin-stat-live{position:relative;border-color:color-mix(in srgb,var(--success) 40%,var(--hairline));background:linear-gradient(180deg,color-mix(in srgb,var(--success) 6%,var(--bg-elev-1)),var(--bg-elev-1))}.admin-stat-live:before{content:"";position:absolute;top:14px;right:14px;width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 0 4px color-mix(in srgb,var(--success) 22%,transparent);animation:pulseDot 2.4s ease-in-out infinite}.admin-live-header{display:flex;align-items:center;justify-content:space-between;margin:4px 2px 8px}.admin-table-wrap{overflow-x:auto;margin:0 -4px}.admin-table{width:100%;border-collapse:collapse;font-size:13px;letter-spacing:-.005em}.admin-table th,.admin-table td{padding:10px 12px;text-align:right;border-bottom:1px solid var(--hairline);white-space:nowrap}.admin-table th:first-child,.admin-table td:first-child{text-align:left;font-variant-numeric:tabular-nums}.admin-table th{font-size:11.5px;font-weight:700;letter-spacing:.04em;color:var(--ink-3);text-transform:uppercase;background:var(--bg-elev-2)}.admin-table tbody td{color:var(--ink);font-variant-numeric:tabular-nums}.admin-table tbody tr:hover{background:var(--bg-elev-2)}.admin-live-header strong{font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);font-weight:700}.admin-panel{padding:18px}.admin-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.admin-panel-header h2{margin:0;font-size:17px;letter-spacing:-.02em;font-weight:700}.admin-panel-header span{color:var(--ink-2);font-size:13px}.admin-filter-bar{padding:14px;display:flex;align-items:end;gap:10px;flex-wrap:wrap}.admin-field{display:flex;flex-direction:column;gap:6px;min-width:170px}.admin-field.grow{flex:1 1 260px}.admin-field span{color:var(--ink-2);font-size:12px;font-weight:600}.admin-record-list{display:flex;flex-direction:column;gap:10px}.admin-record-list.compact{gap:8px}.admin-record{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;padding:16px;border:1px solid var(--hairline);border-radius:var(--r-md);background:var(--bg-elev-2);transition:border-color .18s var(--ease-soft),background .18s var(--ease-soft),transform .2s var(--ease-soft)}.admin-record:hover{border-color:var(--hairline-strong);transform:translateY(-1px)}.admin-record-list.compact .admin-record{grid-template-columns:minmax(0,1fr);padding:12px}.admin-record-main{min-width:0}.admin-record-title{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-record-title strong{font-size:15px;letter-spacing:-.014em}.admin-meta{margin-top:6px;color:var(--ink-2);font-size:12.5px;word-break:break-word}.admin-description{margin:10px 0 0;color:var(--ink-2);font-size:13px}.admin-two-col{margin-top:10px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.admin-user-line{min-width:0;padding:10px 12px;border-radius:var(--r-sm);background:var(--bg-elev-1);border:1px solid var(--hairline)}.admin-user-line span,.admin-user-line small{display:block;color:var(--ink-2);font-size:11px}.admin-user-line strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13.5px}.admin-user-line small{overflow-wrap:anywhere}.admin-actions-row{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap}.admin-metric-row{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.mini-metric{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--r-sm);background:var(--bg-elev-1);border:1px solid var(--hairline);color:var(--ink-2);font-size:12px}.mini-metric small{color:var(--ink-3)}.mini-metric strong{color:var(--ink);font-weight:700}.admin-pager{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:16px}.admin-pager span{color:var(--ink-2);font-size:13px}.admin-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.admin-detail-block{min-width:0;padding:14px;border-radius:var(--r-md);border:1px solid var(--hairline);background:var(--bg-elev-2)}.admin-detail-block h3{margin:0 0 10px;font-size:14px;letter-spacing:-.014em}.admin-loading,.admin-empty{min-height:140px;display:grid;place-items:center;gap:10px;color:var(--ink-2);font-size:14px}.admin-loading{grid-auto-flow:column;justify-content:center}.admin-gate{min-height:calc(100svh - 32px);display:grid;place-items:center}.admin-gate-card{width:min(440px,100%);padding:32px;text-align:center}.admin-gate-card h1{margin:20px 0 6px;font-size:28px;letter-spacing:-.028em}.admin-gate-card p{margin:0 0 20px;color:var(--ink-2);font-size:14.5px}.spinner{width:28px;height:28px;border:3px solid var(--hairline-strong);border-top-color:var(--ink);border-radius:50%;animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes modalIn{0%{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes heroIn{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes tileIn{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes floatIn{0%{opacity:0;transform:translate(-50%) translateY(20px) scale(.92)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes msgIn{0%{opacity:0;transform:translateY(6px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastIn{0%{opacity:0;transform:translateY(-16px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-ring{0%{transform:scale(1);opacity:.55}to{transform:scale(2.4);opacity:0}}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}@keyframes pulseDot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}@keyframes badgePop{0%{transform:scale(0)}60%{transform:scale(1.18)}to{transform:scale(1)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important}}@media (max-width: 980px){.admin-layout{grid-template-columns:1fr}.admin-sidebar{position:static;height:auto;padding:16px}.admin-nav{flex-direction:row;overflow-x:auto;gap:6px;padding-bottom:4px}.admin-nav-item{white-space:nowrap;text-align:center;flex:0 0 auto}.admin-sidebar-actions,.admin-stat-grid,.admin-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 720px){.admin-shell{padding:10px}.admin-layout{min-height:calc(100svh - 20px)}.admin-main,.admin-sidebar,.admin-panel,.admin-filter-bar{padding:14px}.admin-topline{flex-direction:column}.admin-user{width:100%;justify-content:space-between}.admin-stat-grid,.admin-detail-grid,.admin-two-col,.admin-record{grid-template-columns:1fr}.admin-actions-row{justify-content:flex-start}.admin-field{min-width:100%}}@media (max-width: 520px){.topbar{padding-left:14px;padding-right:14px}.topbar .actions{gap:4px}.topbar .brand .brand-name{display:none}.topbar .user-pill{max-width:110px;padding:0 10px}.landing{padding-left:16px;padding-right:16px}.chat-panel{max-width:none}.settings-menu{width:calc(100vw - 24px);right:-8px}.notif-drawer{position:fixed;top:calc(var(--topbar-h, 56px) + env(safe-area-inset-top) + 6px);right:8px;left:8px;width:auto;max-height:calc(100svh - var(--topbar-h, 56px) - env(safe-area-inset-top) - 24px);transform-origin:top right}}.hidden{display:none!important}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.w-full{width:100%}.text-center{text-align:center}.text-sm{font-size:13px}.text-secondary{color:var(--ink-2)}.muted{color:var(--ink-3)}.rooms-create-btn{width:100%}.rooms-list{display:flex;flex-direction:column;gap:2px}.room-row{grid-template-columns:40px 1fr auto;align-items:center;width:100%;box-sizing:border-box;text-align:left}.room-row-icon{font-size:20px;display:flex;align-items:center;justify-content:center}.room-row-count{font-size:12px;color:var(--ink-3);font-weight:600;margin-left:8px}.room-row-badges{display:flex;gap:4px;align-items:center}.room-badge{font-size:13px;opacity:.85}.room-row.banned{background:#ff453a1a;border:1px solid rgba(255,69,58,.35);border-radius:12px}.room-row.banned strong,.room-row.banned .friend-status{color:var(--danger)}.room-form{display:flex;flex-direction:column;gap:12px;text-align:left}.room-form-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.room-form-label{font-size:13px;color:var(--ink-2);font-weight:600}.room-form-row .input{max-width:220px}.room-form-row input[type=checkbox]{width:20px;height:20px}.room-toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer;flex:0 0 auto}.room-toggle-input{position:absolute;opacity:0;width:0;height:0;margin:0}.room-toggle-track{width:46px;height:28px;border-radius:999px;background:var(--bg-elev-3);border:1px solid var(--hairline);display:flex;align-items:center;padding:3px;transition:background .18s var(--ease-out),border-color .18s var(--ease-out)}.room-toggle-thumb{width:20px;height:20px;border-radius:50%;background:var(--ink-2);transition:transform .18s var(--ease-out),background .18s var(--ease-out)}.room-toggle-input:checked+.room-toggle-track{background:var(--ink);border-color:transparent}.room-toggle-input:checked+.room-toggle-track .room-toggle-thumb{transform:translate(18px);background:var(--bg-base)}.room-toggle-input:focus-visible+.room-toggle-track{box-shadow:var(--ring-focus)}.room-toggle.disabled{opacity:.45;cursor:not-allowed}.room-invite-list{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto}.room-invite-friend{text-align:left;padding:10px 12px;border-radius:10px;background:var(--bg-elev-2);border:1px solid var(--hairline);color:var(--ink)}.room-invite-friend:hover{background:var(--bg-elev-3)}.room-view{display:flex;flex-direction:column;height:100dvh;background:var(--bg-base);padding-top:calc(var(--topbar-h) + env(safe-area-inset-top));box-sizing:border-box}.room-main{flex:1;display:flex;min-height:0;gap:0}.room-tiles{position:relative;flex:1;display:flex;flex-direction:column;min-width:0;padding:16px;gap:12px;overflow:hidden}.room-stage{flex:0 0 auto;display:none;align-items:center;justify-content:center;min-height:0}.room-stage.hidden{display:none}.room-view.has-stage .room-stage{display:flex;flex:1}.room-stage .room-tile{width:100%;height:100%;max-width:none;max-height:100%;aspect-ratio:16 / 9}.room-grid{flex:1;min-height:0;overflow-y:auto;display:grid;gap:12px;align-content:center;justify-content:center;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr))}.room-view.has-stage .room-grid{flex:0 0 auto;max-height:132px;align-content:start;justify-content:start;grid-template-columns:none;grid-auto-flow:column;grid-auto-columns:156px;overflow-x:auto;overflow-y:hidden}.room-tile{position:relative;width:100%;max-width:560px;justify-self:center;min-width:0;min-height:0;aspect-ratio:16 / 9;border-radius:16px;overflow:hidden;background:var(--bg-elev-2);border:1px solid var(--hairline);display:flex;align-items:center;justify-content:center;cursor:pointer}.room-tile.spotlighted{box-shadow:0 0 0 2px var(--accent, #fff)}.room-tile:after{content:"";position:absolute;inset:0;border-radius:inherit;border:2px solid transparent;pointer-events:none;z-index:4;transition:border-color .14s var(--ease-out)}.room-tile.speaking:after{border-color:#30d158}.room-tile.locally-muted:before{content:"🔇";position:absolute;top:8px;right:8px;z-index:5;font-size:13px;line-height:1;padding:3px 5px;border-radius:8px;background:#0000008c}.room-fs-btn{position:absolute;right:18px;bottom:14px;z-index:6;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#00000080;color:#fff;border:1px solid var(--hairline);backdrop-filter:blur(6px)}.room-fs-btn:hover{background:#000000b3}.room-video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;background:#000}.room-tile.cam-off .room-video{opacity:0}.room-tile-avatar{position:absolute;inset:0;display:none;align-items:center;justify-content:center;font-size:34px;font-weight:700;color:var(--ink-2);background:var(--bg-elev-3)}.room-tile.cam-off .room-tile-avatar{display:flex}.room-tile-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.room-tile-label{position:absolute;left:8px;bottom:8px;right:8px;display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;background:#0000008c;backdrop-filter:blur(6px);font-size:12.5px;color:#fff;max-width:-moz-max-content;max-width:max-content}.room-tile-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-tile-label.is-admin{border:1px solid #ffd60a;box-shadow:0 0 0 1px #ffd60a,0 0 12px #ffd60a59}.room-owner-badge{color:#ffd60a}.room-mic-dot{width:8px;height:8px;border-radius:50%;background:#30d158;flex:0 0 auto}.room-mic-dot.off{background:var(--danger)}.room-screen-badge{position:absolute;top:8px;left:8px;padding:2px 8px;border-radius:999px;background:#0a84ffd9;color:#fff;font-size:11px;font-weight:600}.room-chat{flex:0 0 340px;max-width:340px;display:flex;flex-direction:column;border-left:1px solid var(--hairline);background:var(--bg-elev-1);min-height:0}.room-view.chat-collapsed .room-chat{display:none}.room-chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--hairline)}.room-chat-count{font-size:12px;color:var(--ink-3);font-weight:600}.room-chat-header-right{display:flex;align-items:center;gap:8px}.room-delete-btn{width:34px;height:34px;border-radius:50%;color:var(--danger)}.room-delete-btn:hover{background:#ff453a1f}.room-chat-msgs{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.room-msg{display:flex;flex-direction:column;gap:2px}.room-msg-author{font-size:11.5px;color:var(--ink-3);font-weight:600}.room-msg.mine .room-msg-author{color:var(--ink-2)}.room-msg-text{font-size:14px;color:var(--ink);word-break:break-word}.room-msg-link{color:var(--info);text-decoration:underline;word-break:break-all}.room-msg-link:hover{opacity:.85}.room-chat-input{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--hairline)}.room-chat-field{flex:1}.room-dock{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px;border-top:1px solid var(--hairline);background:var(--bg-elev-1)}.room-dock-btn{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-elev-3);border:1px solid var(--hairline);color:var(--ink);transition:transform .14s var(--ease-out),background .14s var(--ease-out)}.room-dock-btn:hover{background:var(--bg-elev-4);transform:scale(1.06)}.room-dock-btn.active{background:var(--ink);color:var(--bg-base)}.room-dock-btn.danger{background:var(--danger);color:#fff;border-color:transparent}.room-kick-banner{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;padding:10px 16px;background:#ff453a1f;border-bottom:1px solid rgba(255,69,58,.3);color:var(--ink);font-size:13.5px}.room-kick-banner.final{background:#ff453a38;font-weight:600}.room-kick-actions{display:flex;gap:8px}@media (max-width: 768px){.room-main{display:contents}.room-tiles{order:2}.room-dock{order:3}.room-chat{order:4;flex:0 0 38%;max-width:none;border-left:none;border-top:1px solid var(--hairline)}.room-grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,150px),1fr));grid-auto-rows:max-content;align-content:start}.room-tile{max-width:none}.room-view.chat-collapsed .room-tiles{flex:1}.room-view.has-stage .room-grid{grid-auto-columns:120px;max-height:96px}.room-dock-btn{width:48px;height:48px}.room-form-row .input{max-width:150px}}
