:root,[data-theme=deep-space]{--bg-primary: #0b0e14;--bg-secondary: #111620;--bg-tertiary: #171d28;--bg-surface: #1c2333;--bg-hover: #222a3a;--bg-active: rgba(13, 190, 140, .08);--border-subtle: rgba(255, 255, 255, .06);--border-medium: rgba(255, 255, 255, .1);--border-focus: #0dbe8c;--text-primary: #f0f4f8;--text-secondary: #94a3b8;--text-muted: #64748b;--text-inverse: #0b0e14;--accent: #0dbe8c;--accent-hover: #0ba87a;--accent-subtle: rgba(13, 190, 140, .12);--accent-glow: rgba(13, 190, 140, .25);--accent-secondary: #06b6d4;--danger: #ef4444;--danger-hover: #dc2626;--danger-subtle: rgba(239, 68, 68, .1);--warning: #f59e0b;--success: #22c55e;--bubble-outgoing: rgba(13, 190, 140, .1);--bubble-outgoing-border: rgba(13, 190, 140, .18);--bubble-incoming: rgba(255, 255, 255, .04);--bubble-incoming-border: rgba(255, 255, 255, .06);--glass-bg: rgba(17, 22, 32, .8);--glass-border: rgba(255, 255, 255, .06);--glass-blur: 20px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--accent-glow);--gradient-bg: radial-gradient(ellipse at 20% 0%, rgba(13, 190, 140, .06) 0%, transparent 50%), radial-gradient(ellipse at 80% 100%, rgba(6, 182, 212, .04) 0%, transparent 50%);--sidebar-width: 320px;--nav-rail-width: 64px;--header-height: 64px;--composer-min-height: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-spring: .35s cubic-bezier(.34, 1.56, .64, 1);color-scheme:dark}[data-theme=aurora]{--bg-primary: #0a0f1a;--bg-secondary: #10162a;--bg-tertiary: #161d36;--bg-surface: #1c2444;--bg-hover: #232d50;--bg-active: rgba(124, 58, 237, .1);--border-subtle: rgba(139, 92, 246, .08);--border-medium: rgba(139, 92, 246, .15);--border-focus: #8b5cf6;--accent: #8b5cf6;--accent-hover: #7c3aed;--accent-subtle: rgba(139, 92, 246, .12);--accent-glow: rgba(139, 92, 246, .3);--accent-secondary: #ec4899;--bubble-outgoing: rgba(139, 92, 246, .1);--bubble-outgoing-border: rgba(139, 92, 246, .2);--bubble-incoming: rgba(255, 255, 255, .04);--bubble-incoming-border: rgba(255, 255, 255, .06);--glass-bg: rgba(16, 22, 42, .85);--shadow-glow: 0 0 20px rgba(139, 92, 246, .2);--gradient-bg: radial-gradient(ellipse at 10% 10%, rgba(139, 92, 246, .08) 0%, transparent 50%), radial-gradient(ellipse at 90% 80%, rgba(236, 72, 153, .05) 0%, transparent 50%)}[data-theme=ocean]{--bg-primary: #0c1222;--bg-secondary: #111b30;--bg-tertiary: #17243e;--bg-surface: #1d2d4c;--bg-hover: #243658;--bg-active: rgba(6, 182, 212, .1);--border-subtle: rgba(6, 182, 212, .08);--border-medium: rgba(6, 182, 212, .15);--border-focus: #06b6d4;--accent: #06b6d4;--accent-hover: #0891b2;--accent-subtle: rgba(6, 182, 212, .12);--accent-glow: rgba(6, 182, 212, .3);--accent-secondary: #3b82f6;--bubble-outgoing: rgba(6, 182, 212, .1);--bubble-outgoing-border: rgba(6, 182, 212, .2);--bubble-incoming: rgba(255, 255, 255, .04);--bubble-incoming-border: rgba(255, 255, 255, .06);--glass-bg: rgba(17, 27, 48, .85);--shadow-glow: 0 0 20px rgba(6, 182, 212, .2);--gradient-bg: radial-gradient(ellipse at 30% 0%, rgba(6, 182, 212, .08) 0%, transparent 50%), radial-gradient(ellipse at 70% 100%, rgba(59, 130, 246, .05) 0%, transparent 50%)}[data-theme=sunset]{--bg-primary: #1a110a;--bg-secondary: #221810;--bg-tertiary: #2d1f16;--bg-surface: #38271c;--bg-hover: #443022;--bg-active: rgba(245, 158, 11, .1);--border-subtle: rgba(245, 158, 11, .08);--border-medium: rgba(245, 158, 11, .15);--border-focus: #f59e0b;--accent: #f59e0b;--accent-hover: #d97706;--accent-subtle: rgba(245, 158, 11, .12);--accent-glow: rgba(245, 158, 11, .25);--accent-secondary: #ef4444;--text-primary: #fef3c7;--text-secondary: #a89070;--bubble-outgoing: rgba(245, 158, 11, .1);--bubble-outgoing-border: rgba(245, 158, 11, .2);--bubble-incoming: rgba(255, 255, 255, .04);--bubble-incoming-border: rgba(255, 255, 255, .06);--glass-bg: rgba(34, 24, 16, .85);--shadow-glow: 0 0 20px rgba(245, 158, 11, .2);--gradient-bg: radial-gradient(ellipse at 20% 20%, rgba(245, 158, 11, .06) 0%, transparent 50%), radial-gradient(ellipse at 80% 80%, rgba(239, 68, 68, .04) 0%, transparent 50%)}[data-theme=forest]{--bg-primary: #0a1410;--bg-secondary: #101e18;--bg-tertiary: #162820;--bg-surface: #1c3228;--bg-hover: #223c30;--bg-active: rgba(34, 197, 94, .1);--border-subtle: rgba(34, 197, 94, .08);--border-medium: rgba(34, 197, 94, .15);--border-focus: #22c55e;--accent: #22c55e;--accent-hover: #16a34a;--accent-subtle: rgba(34, 197, 94, .12);--accent-glow: rgba(34, 197, 94, .25);--accent-secondary: #a3e635;--bubble-outgoing: rgba(34, 197, 94, .1);--bubble-outgoing-border: rgba(34, 197, 94, .2);--bubble-incoming: rgba(255, 255, 255, .04);--bubble-incoming-border: rgba(255, 255, 255, .06);--glass-bg: rgba(16, 30, 24, .85);--shadow-glow: 0 0 20px rgba(34, 197, 94, .2);--gradient-bg: radial-gradient(ellipse at 20% 0%, rgba(34, 197, 94, .06) 0%, transparent 50%), radial-gradient(ellipse at 80% 100%, rgba(163, 230, 53, .04) 0%, transparent 50%)}[data-theme=rose]{--bg-primary: #140a0f;--bg-secondary: #1d0f16;--bg-tertiary: #28151e;--bg-surface: #331a26;--bg-hover: #3e2030;--bg-active: rgba(244, 63, 94, .1);--border-subtle: rgba(244, 63, 94, .08);--border-medium: rgba(244, 63, 94, .16);--border-focus: #f43f5e;--text-primary: #ffe4e6;--text-secondary: #c79ba6;--text-muted: #8c6470;--accent: #f43f5e;--accent-hover: #e11d48;--accent-subtle: rgba(244, 63, 94, .12);--accent-glow: rgba(244, 63, 94, .3);--accent-secondary: #fb7185;--bubble-outgoing: rgba(244, 63, 94, .1);--bubble-outgoing-border: rgba(244, 63, 94, .22);--bubble-incoming: rgba(255, 255, 255, .04);--bubble-incoming-border: rgba(255, 255, 255, .06);--glass-bg: rgba(29, 15, 22, .85);--shadow-glow: 0 0 20px rgba(244, 63, 94, .22);--gradient-bg: radial-gradient(ellipse at 15% 0%, rgba(244, 63, 94, .08) 0%, transparent 50%), radial-gradient(ellipse at 85% 100%, rgba(251, 113, 133, .05) 0%, transparent 50%)}[data-theme=graphite]{--bg-primary: #18181b;--bg-secondary: #1f1f23;--bg-tertiary: #27272a;--bg-surface: #2e2e33;--bg-hover: #34343a;--bg-active: rgba(161, 161, 170, .1);--border-subtle: rgba(255, 255, 255, .06);--border-medium: rgba(255, 255, 255, .12);--border-focus: #a1a1aa;--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-muted: #71717a;--accent: #d4d4d8;--accent-hover: #e4e4e7;--accent-subtle: rgba(212, 212, 216, .12);--accent-glow: rgba(212, 212, 216, .2);--accent-secondary: #818cf8;--text-inverse: #18181b;--bubble-outgoing: rgba(129, 140, 248, .14);--bubble-outgoing-border: rgba(129, 140, 248, .24);--bubble-incoming: rgba(255, 255, 255, .05);--bubble-incoming-border: rgba(255, 255, 255, .07);--glass-bg: rgba(31, 31, 35, .85);--shadow-glow: 0 0 20px rgba(212, 212, 216, .12);--gradient-bg: radial-gradient(ellipse at 20% 0%, rgba(129, 140, 248, .05) 0%, transparent 50%)}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-surface: #e2e8f0;--bg-hover: #e2e8f0;--bg-active: rgba(59, 130, 246, .08);--border-subtle: rgba(0, 0, 0, .06);--border-medium: rgba(0, 0, 0, .1);--border-focus: #3b82f6;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--text-inverse: #f8fafc;--accent: #3b82f6;--accent-hover: #2563eb;--accent-subtle: rgba(59, 130, 246, .08);--accent-glow: rgba(59, 130, 246, .15);--accent-secondary: #8b5cf6;--danger: #ef4444;--danger-hover: #dc2626;--danger-subtle: rgba(239, 68, 68, .08);--bubble-outgoing: rgba(59, 130, 246, .08);--bubble-outgoing-border: rgba(59, 130, 246, .15);--bubble-incoming: #ffffff;--bubble-incoming-border: rgba(0, 0, 0, .06);--glass-bg: rgba(255, 255, 255, .9);--glass-border: rgba(0, 0, 0, .06);--glass-blur: 20px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(59, 130, 246, .1);--gradient-bg: radial-gradient(ellipse at 20% 0%, rgba(59, 130, 246, .04) 0%, transparent 50%), radial-gradient(ellipse at 80% 100%, rgba(139, 92, 246, .03) 0%, transparent 50%);color-scheme:light}html[data-font-size=small]{font-size:14.5px}html[data-font-size=medium]{font-size:16px}html[data-font-size=large]{font-size:17.5px}[data-density=compact] .timeline{padding:8px 18px;gap:0}[data-density=compact] .msg-group{margin-top:1px}[data-density=compact] .msg-bubble{padding:7px 11px}[data-density=compact] .room-item{padding:7px 10px}[data-density=compact] .sidebar__profile{padding:14px 16px}[data-bubble=sharp] .msg-bubble{border-radius:8px}[data-bubble=sharp] .msg-bubble--in{border-bottom-left-radius:2px}[data-bubble=sharp] .msg-bubble--out{border-bottom-right-radius:2px}[data-bubble=sharp] .composer__form{border-radius:12px}[data-motion=reduced] *,[data-motion=reduced] *:before,[data-motion=reduced] *:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}@media(prefers-reduced-motion:reduce){html:not([data-motion=full]) *,html:not([data-motion=full]) *:before,html:not([data-motion=full]) *:after{animation-duration:.001ms!important;transition-duration:.001ms!important}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes pulseGlow{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 8px transparent}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes typingDot{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}@keyframes messageSend{0%{transform:translateY(8px) scale(.97);opacity:.5}to{transform:translateY(0) scale(1);opacity:1}}@keyframes ripple{to{transform:scale(4);opacity:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}@keyframes checkmark{0%{stroke-dashoffset:100}to{stroke-dashoffset:0}}@keyframes expandWidth{0%{width:0}to{width:100%}}.animate-fade-in{animation:fadeIn .3s ease forwards}.animate-fade-in-up{animation:fadeInUp .4s ease forwards}.animate-fade-in-down{animation:fadeInDown .4s ease forwards}.animate-fade-in-scale{animation:fadeInScale .3s ease forwards}.animate-slide-in-left{animation:slideInLeft .3s ease forwards}.animate-slide-in-right{animation:slideInRight .3s ease forwards}.animate-scale-in{animation:scaleIn .3s var(--transition-spring) forwards}.animate-bounce{animation:bounce .5s ease}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-pulse-glow{animation:pulseGlow 2s ease-in-out infinite}.animate-shake{animation:shake .5s ease}.animate-float{animation:float 3s ease-in-out infinite}.animate-message-send{animation:messageSend .3s ease forwards}@keyframes popIn{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.08);opacity:1}to{transform:scale(1);opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes glowPulse{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 14px 2px var(--accent-glow)}}@keyframes breathe{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.04);opacity:1}}@keyframes drawIn{0%{stroke-dashoffset:var(--len, 48)}to{stroke-dashoffset:0}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}@keyframes auroraDrift{0%{transform:translateZ(0) scale(1)}50%{transform:translate3d(2%,-2%,0) scale(1.06)}to{transform:translateZ(0) scale(1)}}.animate-pop-in{animation:popIn .32s var(--transition-spring) forwards}.animate-slide-in-up{animation:slideInUp .4s cubic-bezier(.22,1,.36,1) forwards}.animate-glow-pulse{animation:glowPulse 2.4s ease-in-out infinite}.animate-breathe{animation:breathe 3.5s ease-in-out infinite}.animate-wiggle{animation:wiggle .4s ease}.lift{transition:transform var(--transition-normal),box-shadow var(--transition-normal),background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.lift:hover{transform:translateY(-2px)}.lift:active{transform:translateY(0) scale(.98)}.press{transition:transform var(--transition-fast)}.press:active{transform:scale(.92)}button{transition:transform var(--transition-fast),background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}button:active{transform:scale(.97)}.stagger-children>*{animation:fadeInUp .3s ease forwards;opacity:0}.stagger-children>*:nth-child(1){animation-delay:.02s}.stagger-children>*:nth-child(2){animation-delay:.04s}.stagger-children>*:nth-child(3){animation-delay:.06s}.stagger-children>*:nth-child(4){animation-delay:.08s}.stagger-children>*:nth-child(5){animation-delay:.1s}.stagger-children>*:nth-child(6){animation-delay:.12s}.stagger-children>*:nth-child(7){animation-delay:.14s}.stagger-children>*:nth-child(8){animation-delay:.16s}.stagger-children>*:nth-child(9){animation-delay:.18s}.stagger-children>*:nth-child(10){animation-delay:.2s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);overflow:hidden;height:100vh;width:100vw;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}#root{height:100vh;width:100vw}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.glass-card{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.spinner-sm{width:16px;height:16px;border:2px solid var(--border-medium);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spinner-md{width:32px;height:32px;border:3px solid var(--border-medium);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.spinner-lg{width:48px;height:48px;border:3px solid var(--accent-subtle);border-top-color:var(--accent);border-radius:50%;animation:spin 1s cubic-bezier(.4,0,.2,1) infinite}.avatar{border-radius:50%;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-weight:700;color:var(--accent);background:var(--bg-tertiary);border:1.5px solid var(--border-subtle);position:relative}.avatar img{width:100%;height:100%;object-fit:cover}.avatar--sm{width:32px;height:32px;font-size:.85rem}.avatar--md{width:40px;height:40px;font-size:1rem}.avatar--lg{width:48px;height:48px;font-size:1.2rem}.avatar--xl{width:72px;height:72px;font-size:1.8rem}.avatar__status{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-secondary);background-color:var(--success)}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100vw;background:var(--bg-primary);position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-bg);pointer-events:none}.auth-particles{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.auth-particles span{position:absolute;width:2px;height:2px;background:var(--accent);border-radius:50%;opacity:0;animation:float 6s ease-in-out infinite}.auth-particles span:nth-child(1){top:20%;left:10%;animation-delay:0s;animation-duration:7s;opacity:.3}.auth-particles span:nth-child(2){top:60%;left:80%;animation-delay:1s;animation-duration:5s;opacity:.2}.auth-particles span:nth-child(3){top:40%;left:30%;animation-delay:2s;animation-duration:8s;opacity:.4}.auth-particles span:nth-child(4){top:80%;left:50%;animation-delay:.5s;animation-duration:6s;opacity:.2}.auth-particles span:nth-child(5){top:10%;left:70%;animation-delay:3s;animation-duration:9s;opacity:.3}.auth-particles span:nth-child(6){top:50%;left:90%;animation-delay:1.5s;animation-duration:7s;opacity:.15}.auth-card{width:440px;max-width:90vw;padding:48px 40px;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;z-index:1;animation:fadeInScale .5s ease forwards}.auth-logo{position:relative;margin-bottom:8px}.auth-logo__glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100px;height:100px;background:var(--accent);filter:blur(50px);opacity:.25;border-radius:50%;animation:pulse 4s ease-in-out infinite}.auth-logo__text{font-family:Outfit,sans-serif;font-size:2.5rem;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,var(--text-primary) 30%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;z-index:1}.auth-tagline{color:var(--text-secondary);font-size:.95rem;margin-bottom:40px;line-height:1.6}.auth-btn-sso{width:100%;padding:14px 24px;background:var(--bg-tertiary);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all var(--transition-normal);position:relative;overflow:hidden}.auth-btn-sso:hover{background:var(--bg-hover);border-color:var(--accent);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.auth-btn-sso:active{transform:translateY(0) scale(.99)}.auth-btn-sso .sso-icon{width:20px;height:20px;flex-shrink:0}.auth-footer{margin-top:32px;color:var(--text-muted);font-size:.75rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;gap:6px}.auth-footer svg{width:14px;height:14px;color:var(--accent)}.auth-status{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px 0}.auth-status h2{font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:600}.auth-status p{color:var(--text-secondary);font-size:.9rem}.auth-steps{display:flex;gap:8px;margin-top:16px}.auth-step{width:48px;height:4px;border-radius:var(--radius-full);background:var(--border-subtle);transition:background .5s ease}.auth-step.active{background:var(--accent);animation:expandWidth 1s ease forwards}.auth-step.done{background:var(--accent)}.auth-btn-retry{margin-top:20px;padding:10px 24px;background:var(--accent);color:var(--text-inverse);border:none;border-radius:var(--radius-md);font-weight:600;font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.auth-btn-retry:hover{background:var(--accent-hover);transform:translateY(-1px)}.auth-error-msg{color:var(--danger);font-size:.85rem;background:var(--danger-subtle);padding:12px 16px;border-radius:var(--radius-md);border:1px solid rgba(239,68,68,.15);max-width:100%;word-break:break-word;margin-top:8px}.app-shell{display:grid;grid-template-columns:var(--nav-rail-width) var(--sidebar-width) 1fr;height:100vh;width:100vw;background:var(--bg-primary)}.nav-rail{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;padding:16px 0;gap:4px}.nav-rail__logo{font-family:Outfit,sans-serif;font-weight:800;font-size:1.4rem;background:linear-gradient(135deg,var(--accent),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:20px;cursor:default;-webkit-user-select:none;user-select:none}.nav-rail__btn{width:44px;height:44px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);position:relative}.nav-rail__btn:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-rail__btn.active{background:var(--accent-subtle);color:var(--accent)}.nav-rail__btn.active:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.nav-rail__spacer{flex:1}.nav-rail__btn svg{width:22px;height:22px}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;height:100vh;overflow:hidden}.sidebar__profile{padding:20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-subtle)}.sidebar__profile-info{flex:1;min-width:0}.sidebar__profile-name{font-weight:600;font-size:.95rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__profile-status{font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.sidebar__profile-status:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--success)}.sidebar__search{padding:12px 16px}.sidebar__search-input{width:100%;padding:10px 14px 10px 38px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:.85rem;outline:none;transition:all var(--transition-fast)}.sidebar__search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.sidebar__search-input::placeholder{color:var(--text-muted)}.sidebar__search-wrapper{position:relative}.sidebar__search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);width:16px;height:16px;pointer-events:none}.sidebar__section-label{padding:12px 20px 6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.room-list{flex:1;overflow-y:auto;padding:4px 8px}.room-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);position:relative}.room-item:hover{background:var(--bg-hover)}.room-item.active{background:var(--bg-active)}.room-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.room-item__info{flex:1;min-width:0}.room-item__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.room-item__name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-item.unread .room-item__name{font-weight:700}.room-item__time{font-size:.72rem;color:var(--text-muted);flex-shrink:0;margin-left:8px}.room-item__bottom{display:flex;justify-content:space-between;align-items:center}.room-item__preview{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.room-item__preview strong{color:var(--text-primary);font-weight:600;margin-right:4px}.unread-badge{background:var(--accent);color:var(--text-inverse);font-size:.68rem;font-weight:700;min-width:20px;height:20px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0;animation:scaleIn .3s var(--transition-spring) forwards}.room-item__lock{color:var(--accent);width:12px;height:12px;flex-shrink:0;margin-left:4px}.chat-area{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary);position:relative}.chat-header{height:var(--header-height);padding:0 24px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary);flex-shrink:0}.chat-header__left{display:flex;align-items:center;gap:12px;min-width:0}.chat-header__name{font-family:Outfit,sans-serif;font-weight:700;font-size:1.05rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header__lock{color:var(--accent);display:flex;align-items:center}.chat-header__actions{display:flex;gap:8px}.btn-icon{width:38px;height:38px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent)}.btn-icon svg{width:18px;height:18px}.timeline{flex:1;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:2px;position:relative}.timeline__date-sep{display:flex;align-items:center;justify-content:center;padding:12px 0}.timeline__date-label{background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 14px;border-radius:var(--radius-full);font-size:.75rem;color:var(--text-secondary);font-weight:500;border:1px solid var(--glass-border)}.timeline__system{text-align:center;padding:6px 0;font-size:.78rem;color:var(--text-muted);animation:fadeIn .3s ease}.timeline__scroll-btn{position:absolute;bottom:16px;right:24px;width:40px;height:40px;border-radius:50%;background:var(--accent);color:var(--text-inverse);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:all var(--transition-fast);animation:fadeInUp .3s ease forwards;z-index:10}.timeline__scroll-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.timeline__scroll-btn svg{width:20px;height:20px}.msg-group{display:flex;gap:10px;max-width:75%;animation:messageSend .25s ease forwards}.msg-group--out{align-self:flex-end;flex-direction:row-reverse}.msg-group--in{align-self:flex-start}.msg__avatar{flex-shrink:0;align-self:flex-end}.msg__stack{display:flex;flex-direction:column;gap:2px}.msg__sender{font-size:.78rem;font-weight:600;color:var(--accent);margin-bottom:2px;margin-left:2px}.msg-bubble{padding:10px 14px;border-radius:var(--radius-lg);position:relative;min-width:60px;transition:background .15s ease}.msg-bubble--in{background:var(--bubble-incoming);border:1px solid var(--bubble-incoming-border);border-bottom-left-radius:4px}.msg-bubble--out{background:var(--bubble-outgoing);border:1px solid var(--bubble-outgoing-border);border-bottom-right-radius:4px}.msg-bubble:hover{filter:brightness(1.05)}.msg__body{font-size:.92rem;line-height:1.5;color:var(--text-primary);word-break:break-word}.msg__body--emoji-only{font-size:2.2rem;line-height:1.2;background:transparent!important;border:none!important;padding:4px 0!important}.msg__image{max-width:100%;max-height:280px;border-radius:var(--radius-md);cursor:pointer;transition:transform .2s ease;display:block;margin-top:4px}.msg__image:hover{transform:scale(1.02)}.msg__file{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-primary);text-decoration:none;transition:background .15s ease;margin-top:4px}.msg__file:hover{background:var(--bg-hover);text-decoration:none}.msg__file-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--accent-subtle);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.msg__file-info{flex:1;min-width:0}.msg__file-name{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg__file-size{font-size:.72rem;color:var(--text-muted)}.msg__meta{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:4px}.msg__time{font-size:.68rem;color:var(--text-muted)}.msg__decrypt-error{color:var(--warning);font-size:.85rem;font-style:italic;display:flex;align-items:center;gap:6px}.msg__hover-actions{position:absolute;top:-14px;right:8px;display:none;background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:2px;gap:2px;z-index:5}.msg-bubble:hover .msg__hover-actions{display:flex}.msg__hover-btn{width:28px;height:28px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all var(--transition-fast)}.msg__hover-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.msg__reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.msg__reaction{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-subtle);font-size:.78rem;cursor:pointer;transition:all var(--transition-fast)}.msg__reaction:hover,.msg__reaction--mine{border-color:var(--accent);background:var(--accent-subtle)}.msg__reaction-count{font-size:.72rem;color:var(--text-secondary)}.msg__reply-preview{padding:6px 10px;margin-bottom:6px;border-left:3px solid var(--accent);background:var(--bg-tertiary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.78rem;color:var(--text-secondary)}.msg__reply-sender{color:var(--accent);font-weight:600}.composer{padding:12px 24px 16px;background:var(--bg-secondary);border-top:1px solid var(--border-subtle);flex-shrink:0}.composer__reply-banner{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;margin-bottom:8px;background:var(--bg-tertiary);border-radius:var(--radius-md);border-left:3px solid var(--accent);animation:fadeInDown .2s ease}.composer__reply-text{font-size:.8rem;color:var(--text-secondary);flex:1;min-width:0}.composer__reply-text strong{color:var(--accent);margin-right:6px}.composer__reply-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.composer__reply-close:hover{color:var(--text-primary)}.composer__uploads{display:flex;gap:8px;padding:8px 0;overflow-x:auto;animation:fadeInUp .2s ease}.composer__upload-thumb{position:relative;width:64px;height:64px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-medium);flex-shrink:0}.composer__upload-thumb img{width:100%;height:100%;object-fit:cover}.composer__upload-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;background:#000000b3;color:#fff;border:none;cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center}.composer__form{display:flex;align-items:flex-end;gap:8px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:6px 8px;transition:border-color var(--transition-fast)}.composer__form:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.composer__input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-family:inherit;font-size:.9rem;min-height:24px;max-height:120px;resize:none;padding:6px 4px;line-height:1.4}.composer__input::placeholder{color:var(--text-muted)}.composer__btn{width:36px;height:36px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.composer__btn:hover{color:var(--accent);background:var(--accent-subtle)}.composer__btn--send{background:var(--accent);color:var(--text-inverse);border-radius:var(--radius-full)}.composer__btn--send:hover{background:var(--accent-hover);color:var(--text-inverse);transform:scale(1.05)}.composer__btn--send:disabled{opacity:.4;cursor:not-allowed;transform:none}.composer__btn svg{width:20px;height:20px}.composer__progress{height:3px;background:var(--border-subtle);border-radius:var(--radius-full);overflow:hidden;margin-top:8px}.composer__progress-bar{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width .3s ease}.emoji-picker{position:absolute;bottom:calc(100% + 8px);left:0;width:340px;height:380px;background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;z-index:50;animation:fadeInUp .2s ease forwards}.emoji-picker__search{padding:10px 12px;border-bottom:1px solid var(--border-subtle)}.emoji-picker__search input{width:100%;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:.85rem;outline:none}.emoji-picker__search input:focus{border-color:var(--accent)}.emoji-picker__tabs{display:flex;border-bottom:1px solid var(--border-subtle);padding:0 4px;overflow-x:auto}.emoji-picker__tab{padding:8px 10px;font-size:1.1rem;cursor:pointer;border:none;background:transparent;border-bottom:2px solid transparent;transition:all var(--transition-fast);flex-shrink:0}.emoji-picker__tab.active{border-bottom-color:var(--accent)}.emoji-picker__tab:hover{background:var(--bg-hover)}.emoji-picker__grid{flex:1;overflow-y:auto;padding:8px;display:grid;grid-template-columns:repeat(8,1fr);gap:2px;align-content:start}.emoji-picker__category-label{grid-column:1 / -1;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:8px 4px 4px}.emoji-picker__item{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:1.5rem;cursor:pointer;border:none;background:transparent;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.emoji-picker__item:hover{background:var(--bg-hover);transform:scale(1.15)}.sticker-picker{position:absolute;bottom:calc(100% + 8px);left:0;width:340px;height:380px;background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;z-index:50;animation:fadeInUp .2s ease forwards}.sticker-picker__grid{flex:1;overflow-y:auto;padding:12px;display:grid;grid-template-columns:repeat(4,1fr);gap:8px;align-content:start}.sticker-picker__item{aspect-ratio:1;cursor:pointer;border:none;background:var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-fast);font-size:2.5rem;display:flex;align-items:center;justify-content:center}.sticker-picker__item:hover{transform:scale(1.08);box-shadow:var(--shadow-sm)}.call-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000e6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;flex-direction:column;z-index:100;animation:fadeIn .3s ease}.call-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;padding:20px;overflow-y:auto}.video-tile{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);position:relative;overflow:hidden;aspect-ratio:16/9}.video-tile video{width:100%;height:100%;object-fit:cover}.video-tile__label{position:absolute;bottom:10px;left:10px;background:#0009;padding:4px 10px;border-radius:var(--radius-sm);font-size:.78rem;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.call-controls{height:80px;display:flex;align-items:center;justify-content:center;gap:16px;background:var(--bg-secondary);border-top:1px solid var(--border-subtle)}.call-control-btn{width:48px;height:48px;border-radius:50%;border:none;background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.call-control-btn:hover{background:var(--bg-hover)}.call-control-btn.active{background:var(--accent);color:var(--text-inverse)}.call-control-btn.hangup{background:var(--danger);color:#fff}.call-control-btn.hangup:hover{background:var(--danger-hover)}.call-control-btn svg{width:22px;height:22px}.call-status{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);gap:16px}.call-status__icon{font-size:3rem}.call-status h2{font-family:Outfit,sans-serif}.verify-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.verify-card{width:440px;max-width:90vw;background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:32px;text-align:center;animation:fadeInScale .3s ease forwards}.verify-card h2{font-family:Outfit,sans-serif;font-size:1.3rem;margin-bottom:8px}.verify-card p{color:var(--text-secondary);font-size:.9rem;margin-bottom:24px}.verify-emoji-grid{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:28px}.verify-emoji{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:var(--bg-tertiary);border-radius:var(--radius-md);min-width:72px;animation:fadeInUp .3s ease forwards}.verify-emoji__icon{font-size:2rem}.verify-emoji__label{font-size:.68rem;color:var(--text-muted);text-transform:capitalize}.verify-actions{display:flex;gap:12px;justify-content:center}.verify-btn{padding:10px 24px;border-radius:var(--radius-md);border:none;font-weight:600;font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.verify-btn--confirm{background:var(--accent);color:var(--text-inverse)}.verify-btn--confirm:hover{background:var(--accent-hover)}.verify-btn--cancel{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-medium)}.verify-btn--cancel:hover{background:var(--bg-hover)}.verify-success{font-size:3rem;margin-bottom:16px;animation:scaleIn .4s var(--transition-spring) forwards}.settings{height:100vh;overflow-y:auto;padding:32px;animation:fadeIn .3s ease}.settings h1{font-family:Outfit,sans-serif;font-size:1.6rem;margin-bottom:24px}.settings__section{margin-bottom:32px}.settings__section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:12px}.settings__card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px}.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.theme-card{padding:16px;border-radius:var(--radius-md);border:2px solid var(--border-subtle);background:var(--bg-tertiary);cursor:pointer;transition:all var(--transition-fast);text-align:center}.theme-card:hover{border-color:var(--text-muted)}.theme-card.active{border-color:var(--accent);box-shadow:var(--shadow-glow)}.theme-card__preview{display:flex;gap:6px;justify-content:center;margin-bottom:8px}.theme-card__dot{width:20px;height:20px;border-radius:50%;border:1px solid rgba(255,255,255,.1)}.theme-card__name{font-size:.8rem;font-weight:600;color:var(--text-primary)}.theme-card__emoji{font-size:1.2rem;margin-bottom:4px}.wallpaper-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.wallpaper-thumb{aspect-ratio:3/4;border-radius:var(--radius-md);border:2px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-fast);overflow:hidden}.wallpaper-thumb:hover{border-color:var(--text-muted)}.wallpaper-thumb.active{border-color:var(--accent);box-shadow:var(--shadow-glow)}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary);padding:40px}.empty-state__icon{width:80px;height:80px;border-radius:var(--radius-xl);background:var(--accent-subtle);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:8px}.empty-state__icon svg{width:36px;height:36px}.empty-state h2{font-family:Outfit,sans-serif;font-size:1.3rem;color:var(--text-primary)}.empty-state p{color:var(--text-muted);font-size:.9rem;max-width:320px;text-align:center}.typing-indicator{display:flex;align-items:center;gap:6px;padding:4px 12px;font-size:.78rem;color:var(--text-muted);min-height:24px}.typing-dots{display:flex;gap:3px}.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--text-muted);animation:typingDot 1.4s ease-in-out infinite}.typing-dots span:nth-child(1){animation-delay:0s}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:300;cursor:zoom-out;animation:fadeIn .2s ease}.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-md);animation:fadeInScale .3s ease forwards}.lightbox__close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:#ffffff1a;color:#fff;border:none;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.app-shell{grid-template-columns:1fr}.nav-rail{display:none}.sidebar{position:absolute;left:0;top:0;width:300px;height:100vh;z-index:50;transform:translate(-100%);transition:transform .3s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.chat-header__menu-btn{display:flex!important}.emoji-picker,.sticker-picker{width:100%;left:0;border-radius:var(--radius-lg) var(--radius-lg) 0 0}}@media(min-width:769px){.chat-header__menu-btn{display:none!important}}.toast-container{position:fixed;top:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:var(--text-primary);font-size:.85rem;animation:slideInRight .3s ease forwards;max-width:360px}.toast--error{border-left:3px solid var(--danger)}.toast--success{border-left:3px solid var(--success)}.toast--info{border-left:3px solid var(--accent)}.nav-rail__logo{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent),var(--accent-secondary));-webkit-background-clip:initial;background-clip:initial;-webkit-text-fill-color:var(--text-inverse);color:var(--text-inverse);box-shadow:var(--shadow-glow)}.nav-rail__btn{transition:all var(--transition-normal)}.nav-rail__btn:hover{transform:translateY(-1px)}.nav-rail__btn.active:before{animation:scaleIn .25s var(--transition-spring) forwards}.room-item{animation:fadeInUp .32s ease backwards;will-change:transform}.room-list .room-item:nth-child(1){animation-delay:.02s}.room-list .room-item:nth-child(2){animation-delay:.05s}.room-list .room-item:nth-child(3){animation-delay:.08s}.room-list .room-item:nth-child(4){animation-delay:.11s}.room-list .room-item:nth-child(5){animation-delay:.14s}.room-item:hover{transform:translate(2px)}.room-item:active{transform:translate(2px) scale(.99)}.chat-area{animation:fadeIn .3s ease}.composer__btn--active{color:var(--accent);background:var(--accent-subtle)}.msg__sent-check{color:var(--accent);opacity:.7}.msg__hover-actions{gap:1px;padding:3px;border-radius:var(--radius-md)}.msg-bubble:hover .msg__hover-actions,.msg__hover-actions--pinned{display:flex}.msg__hover-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center}.msg__hover-btn--danger:hover{color:var(--danger);background:var(--danger-subtle)}.react-picker{position:absolute;bottom:calc(100% + 6px);right:0;display:flex;gap:2px;padding:6px;background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);z-index:20;animation:popIn .22s var(--transition-spring) forwards}.react-picker__item{width:34px;height:34px;border:none;background:transparent;border-radius:50%;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform var(--transition-fast),background var(--transition-fast)}.react-picker__item:hover{transform:scale(1.3);background:var(--bg-hover)}.msg__reactions{margin-top:6px}.msg__reactions--out{justify-content:flex-end}.msg__reaction{animation:popIn .25s var(--transition-spring) forwards;gap:5px}.msg__reaction--mine{border-color:var(--accent);background:var(--accent-subtle);color:var(--accent)}.msg__reaction:active{transform:scale(.9)}.settings{max-width:760px}.settings__section-title{display:flex;align-items:center;gap:7px}.settings__section-title svg{color:var(--accent)}.settings__section{animation:fadeInUp .4s ease backwards}.settings__section:nth-child(2){animation-delay:.04s}.settings__section:nth-child(3){animation-delay:.08s}.settings__section:nth-child(4){animation-delay:.12s}.settings__section:nth-child(5){animation-delay:.16s}.settings__card-title{font-size:.9rem;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.btn-danger{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:var(--danger-subtle);color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius-md);font-weight:600;font-size:.9rem;cursor:pointer;font-family:inherit}.btn-danger:hover{background:var(--danger);color:#fff}.theme-card{border:2px solid var(--border-subtle);background:var(--bg-tertiary);padding:0;overflow:hidden;font-family:inherit}.theme-card__swatch{position:relative;height:64px;display:flex;align-items:center;justify-content:center;gap:8px}.theme-card__chip{width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,.18);box-shadow:var(--shadow-sm)}.theme-card__chip--sm{width:14px;height:14px;opacity:.85}.theme-card__check{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;animation:popIn .25s var(--transition-spring) forwards}.theme-card__name{padding:8px;font-size:.78rem}.pref-list{display:flex;flex-direction:column;gap:4px}.pref-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--border-subtle)}.pref-row:last-child{border-bottom:none}.pref-row__label{font-size:.88rem;font-weight:500;color:var(--text-primary)}.pref-row__hint{font-size:.76rem;color:var(--text-muted);margin-top:2px}.pref-row__control{flex-shrink:0}.segmented{display:inline-flex;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:3px;gap:2px}.segmented__btn{border:none;background:transparent;color:var(--text-secondary);font-family:inherit;font-size:.8rem;font-weight:600;padding:6px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.segmented__btn:hover{color:var(--text-primary)}.segmented__btn.active{background:var(--accent);color:var(--text-inverse);box-shadow:var(--shadow-sm)}.accent-swatches{display:flex;flex-wrap:wrap;gap:8px;max-width:280px;justify-content:flex-end}.accent-swatch{width:28px;height:28px;border-radius:50%;border:2px solid var(--border-medium);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.accent-swatch:hover{transform:scale(1.15)}.accent-swatch.active{box-shadow:0 0 0 2px var(--bg-secondary),0 0 0 4px currentColor}.accent-swatch--theme{background:conic-gradient(from 0deg,#0dbe8c,#8b5cf6,#06b6d4,#f59e0b,#f43f5e,#0dbe8c);color:var(--text-primary)}[data-motion=reduced] .room-item,[data-motion=reduced] .settings__section,[data-motion=reduced] .chat-area{animation:none!important}.verify-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px}.verify-status-icon{width:72px;height:72px;margin:0 auto 16px;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:popIn .4s var(--transition-spring) forwards}.verify-status-icon--success{background:var(--accent-subtle);color:var(--accent)}.verify-status-icon--error{background:var(--danger-subtle);color:var(--danger)}.verify-status-icon--muted{background:var(--bg-tertiary);color:var(--text-muted)}.call-control-btn{transition:all var(--transition-normal)}.call-control-btn:hover{transform:translateY(-2px)}.chat-area-wrap{display:flex;height:100vh;min-width:0;overflow:hidden}.chat-area{flex:1;min-width:0}.chat-area-wrap>.settings,.chat-area-wrap>.empty-state{flex:1;min-width:0}.msg__body a{color:var(--accent);text-decoration:underline;word-break:break-all}.md-code{font-family:SF Mono,ui-monospace,Menlo,Consolas,monospace;font-size:.85em;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:5px;padding:1px 5px}.md-pre{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:10px 12px;margin:6px 0;overflow-x:auto}.md-pre code{font-family:SF Mono,ui-monospace,Menlo,Consolas,monospace;font-size:.82em;background:none;border:none;padding:0;white-space:pre}.md-quote{border-left:3px solid var(--accent);padding:2px 0 2px 10px;margin:4px 0;color:var(--text-secondary)}.msg__reply-quote{display:flex;flex-direction:column;gap:1px;padding:5px 10px;margin-bottom:6px;border-left:3px solid var(--accent);background:color-mix(in srgb,var(--accent) 7%,transparent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;max-width:100%;overflow:hidden}.msg__reply-quote-sender{font-size:.74rem;font-weight:700;color:var(--accent)}.msg__reply-quote-body{font-size:.78rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg__edited{font-size:.64rem;color:var(--text-muted);font-style:italic;margin-right:2px}.composer__edit-banner{border-left-color:var(--warning)}.composer__edit-banner .composer__reply-text{display:flex;align-items:center;gap:6px}.composer__reply-text strong{display:inline-flex;align-items:center}.typing-indicator--empty{min-height:0;padding:0;height:6px}.sidebar__list-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px 4px}.sidebar__new-btn{width:26px;height:26px;border-radius:var(--radius-sm);border:none;background:var(--accent-subtle);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center}.sidebar__new-btn:hover{background:var(--accent);color:var(--text-inverse)}.btn-icon--active{background:var(--accent-subtle);color:var(--accent);border-color:var(--accent)}.btn-icon--ghost{border:none;background:transparent;width:28px;height:28px}.room-info{width:300px;flex-shrink:0;height:100vh;background:var(--bg-secondary);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;animation:slideInRight .28s cubic-bezier(.22,1,.36,1) forwards}.room-info__header{height:var(--header-height);flex-shrink:0;padding:0 16px 0 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-subtle);font-weight:700;font-family:Outfit,sans-serif}.room-info__scroll{flex:1;overflow-y:auto;padding:20px}.room-info__hero{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding-bottom:20px;border-bottom:1px solid var(--border-subtle)}.room-info__name{display:flex;align-items:center;gap:6px;font-size:1.1rem;font-weight:700}.room-info__name svg{color:var(--accent)}.room-info__topic{font-size:.82rem;color:var(--text-secondary);line-height:1.5}.room-info__section{padding:18px 0;border-bottom:1px solid var(--border-subtle)}.room-info__section:last-child{border-bottom:none}.room-info__section-title{display:flex;align-items:center;justify-content:space-between;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:12px}.room-info__add{width:24px;height:24px;border:none;cursor:pointer;border-radius:var(--radius-sm);background:var(--accent-subtle);color:var(--accent);display:flex;align-items:center;justify-content:center}.room-info__add:hover{background:var(--accent);color:var(--text-inverse)}.room-info__members{display:flex;flex-direction:column;gap:4px}.room-info__member{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:var(--radius-md);transition:background var(--transition-fast);animation:fadeInUp .3s ease backwards}.room-info__member:hover{background:var(--bg-hover)}.room-info__member-info{flex:1;min-width:0}.room-info__member-name{font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-info__member-id{font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-info__badge{font-size:.62rem;font-weight:700;text-transform:uppercase;color:var(--accent);background:var(--accent-subtle);padding:2px 7px;border-radius:var(--radius-full)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:250;animation:fadeIn .2s ease}.modal-card{width:440px;max-width:92vw;background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;animation:fadeInScale .28s var(--transition-spring) forwards}.modal-card__header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border-subtle)}.modal-card__header h2{font-family:Outfit,sans-serif;font-size:1.15rem}.modal-tabs{display:flex;gap:4px;padding:12px 16px 0}.modal-tab{display:flex;align-items:center;gap:6px;padding:9px 14px;border:none;background:transparent;color:var(--text-secondary);font-family:inherit;font-size:.85rem;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.modal-tab:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.modal-tab.active{background:var(--accent-subtle);color:var(--accent)}.modal-tab:disabled{opacity:.4;cursor:not-allowed}.modal-body{padding:16px 20px 24px}.modal-label{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:8px}.modal-input{width:100%;padding:11px 14px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:.9rem;outline:none;transition:all var(--transition-fast)}.modal-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.modal-submit{width:100%;margin-top:14px;padding:12px;background:var(--accent);color:var(--text-inverse);border:none;border-radius:var(--radius-md);font-family:inherit;font-weight:700;font-size:.92rem;cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:44px}.modal-submit:hover{background:var(--accent-hover)}.modal-submit:disabled{opacity:.6;cursor:not-allowed}.modal-error{margin-top:12px;padding:10px 14px;background:var(--danger-subtle);color:var(--danger);border-radius:var(--radius-md);font-size:.82rem}.profile-avatar{position:relative;border:none;background:none;padding:0;cursor:pointer;border-radius:50%}.profile-avatar__overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.profile-avatar:hover .profile-avatar__overlay{opacity:1}.profile-name-edit{display:flex;align-items:center;gap:8px}.profile-name-edit .modal-input{flex:1}@media(max-width:768px){.room-info{position:absolute;right:0;top:0;z-index:60;box-shadow:var(--shadow-lg)}}.nav-rail__avatar{position:relative;border:none;background:transparent;padding:0;margin-bottom:18px;cursor:pointer;border-radius:50%}.nav-rail__avatar .avatar{border:2px solid var(--border-medium);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.nav-rail__avatar:hover .avatar{border-color:var(--accent);box-shadow:var(--shadow-glow)}.nav-rail__avatar-caret{position:absolute;bottom:-3px;right:-3px;width:16px;height:16px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border-medium);color:var(--text-secondary);display:flex;align-items:center;justify-content:center}.user-menu__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:290}.user-menu{position:fixed;left:calc(var(--nav-rail-width) + 10px);top:12px;width:280px;z-index:300;background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:8px;animation:fadeInScale .18s var(--transition-spring) forwards;transform-origin:top left}.user-menu__head{display:flex;align-items:center;gap:12px;padding:10px 8px}.user-menu__identity{min-width:0;flex:1}.user-menu__name{font-weight:700;font-size:.98rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu__id{display:flex;align-items:center;gap:6px;max-width:100%;margin-top:2px;padding:0;border:none;background:transparent;color:var(--text-muted);font-size:.74rem;font-family:inherit;cursor:pointer}.user-menu__id span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu__id:hover{color:var(--accent)}.user-menu__id svg{flex-shrink:0;opacity:.7}.user-menu__divider{height:1px;background:var(--border-subtle);margin:6px 4px}.user-menu__item{display:flex;align-items:center;gap:12px;width:100%;padding:10px;border:none;background:transparent;color:var(--text-primary);font-family:inherit;font-size:.9rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.user-menu__item svg{color:var(--text-secondary)}.user-menu__item:hover{background:var(--bg-hover)}.user-menu__item:hover svg{color:var(--accent)}.user-menu__item--danger{color:var(--danger)}.user-menu__item--danger svg{color:var(--danger)}.user-menu__item--danger:hover{background:var(--danger-subtle)}.user-menu__item--danger:hover svg{color:var(--danger)}.chat-header__left--btn{border:none;background:transparent;cursor:pointer;font-family:inherit;padding:6px 10px;margin:0 -10px;border-radius:var(--radius-md);text-align:left;color:inherit;transition:background var(--transition-fast)}.chat-header__left--btn:hover{background:var(--bg-hover)}.chat-header__caret{color:var(--text-muted);display:flex;align-items:center;margin-left:2px}
