.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:transparent}.login-left{padding:56px 64px;display:flex;align-items:center;justify-content:center}.login-right{padding:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffffff0a,#161b22b3 40%,#0f172a99);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.login-card{width:100%;max-width:360px;padding:32px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#ffffff0d,#161b2280,#0f172a66);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);position:relative;overflow:hidden}.login-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.08) 0%,transparent 45%,transparent 100%);border-radius:inherit;pointer-events:none}.login-title{margin:0 0 4px;font-size:24px;font-weight:600}.login-subtitle{margin:0 0 24px;color:var(--muted);font-size:14px;position:relative;z-index:1}.login-form{display:flex;flex-direction:column;gap:16px;position:relative;z-index:1}.login-field{display:flex;flex-direction:column;gap:8px}.login-label{font-size:14px;font-weight:500;color:var(--text)}.login-input{padding:10px 14px;font-size:14px;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);background:#0f172a66;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s}.login-input::placeholder{color:var(--muted)}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #58a6ff26}.login-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.login-check{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--muted);cursor:pointer}.login-link{font-size:14px;color:var(--accent);text-decoration:none}.login-link:hover{text-decoration:underline}.login-link--accent{font-weight:500}.login-btn{margin-top:4px;padding:10px 16px;font-size:14px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:var(--radius);cursor:pointer;transition:background .2s,transform .1s}.login-btn:hover{background:#4795ff}.login-btn:active{transform:scale(.99)}.login-switch{margin:24px 0 0;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:14px;color:var(--muted);text-align:center;position:relative;z-index:1}@media (max-width: 768px){.login-page{grid-template-columns:1fr}.login-left{display:none}.login-right{border-left:none}}.signup-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:transparent}.signup-left{padding:56px 64px;display:flex;align-items:center;justify-content:center}.auth-hero{display:flex;flex-direction:column;align-items:center;gap:28px;max-width:340px}.auth-logo-wrap{width:160px;height:160px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffffff26,#6366f126 40%,#6366f114);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.25);border-radius:28px;box-shadow:0 12px 40px #6366f133,inset 0 1px #ffffff4d;position:relative;overflow:hidden}.auth-logo-wrap:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.4) 0%,rgba(255,255,255,0) 50%,transparent 100%);border-radius:inherit;pointer-events:none}.auth-logo-icon{width:88px;height:88px;position:relative;z-index:1}.auth-brand{margin:0;font-size:38px;font-weight:800;letter-spacing:-1.2px;text-align:center;background:linear-gradient(135deg,#c7d2fe,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-tagline{margin:0;color:var(--muted);font-size:15px;text-align:center}.signup-right{padding:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffffff0a,#161b22b3 40%,#0f172a99);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.signup-card{width:100%;max-width:360px;padding:32px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#ffffff0d,#161b2280,#0f172a66);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);position:relative;overflow:hidden}.signup-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.08) 0%,transparent 45%,transparent 100%);border-radius:inherit;pointer-events:none}.signup-title{margin:0 0 4px;font-size:24px;font-weight:600;position:relative;z-index:1}.signup-subtitle{margin:0 0 24px;color:var(--muted);font-size:14px}.signup-form{display:flex;flex-direction:column;gap:14px;position:relative;z-index:1}.signup-field{display:flex;flex-direction:column;gap:8px}.signup-label{font-size:14px;font-weight:500;color:var(--text)}.signup-input{padding:10px 14px;font-size:14px;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);background:#0f172a66;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s}.signup-input::placeholder{color:var(--muted)}.signup-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #58a6ff26}.signup-btn{margin-top:4px;padding:10px 16px;font-size:14px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:var(--radius);cursor:pointer;transition:background .2s,transform .1s}.signup-btn:hover{background:#4795ff}.signup-btn:active{transform:scale(.99)}.signup-error{margin:12px 0 0;font-size:13px;color:#f85149;line-height:1.4}.signup-switch{margin:24px 0 0;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:14px;color:var(--muted);text-align:center;position:relative;z-index:1}.signup-link{color:var(--accent);text-decoration:none}.signup-link:hover{text-decoration:underline}@media (max-width: 768px){.signup-page{grid-template-columns:1fr}.signup-left{display:none}.signup-right{border-left:none}}.chat-page{position:relative;z-index:1;background:var(--bg);display:block;height:100vh;max-height:100vh;min-height:100vh;height:100dvh;max-height:100dvh;min-height:100dvh;overflow:hidden}.chat-page-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:25;margin:0;padding:0;border:none;background:#00000073;cursor:pointer;-webkit-tap-highlight-color:transparent}.chat-page--sidebar-open .chat-page-backdrop{display:block}.chat-page-sidebar-wrap{min-width:0;overflow:hidden;position:fixed;top:0;left:0;bottom:0;width:min(320px,88vw);max-width:100%;z-index:30;height:auto;background:var(--bg);box-shadow:8px 0 24px #0000001f;transform:translate(-102%);transition:transform .22s ease-out;padding-bottom:env(safe-area-inset-bottom,0px)}.chat-page--sidebar-open .chat-page-sidebar-wrap{transform:translate(0)}.chat-page-main-wrap{min-width:0;min-height:0;overflow:hidden;height:100%}.chat-page-divider{display:none}@media (min-width: 901px){.chat-page{display:grid;grid-template-columns:320px 1px 1fr;grid-template-rows:1fr}.chat-page-backdrop,.chat-page--sidebar-open .chat-page-backdrop{display:none!important}.chat-page-sidebar-wrap{position:relative;top:auto;left:auto;bottom:auto;width:auto;max-width:none;z-index:1;height:100%;transform:none!important;transition:none;box-shadow:none;background:transparent;padding-bottom:0}.chat-page--sidebar-open .chat-page-sidebar-wrap{transform:none!important}.chat-page-divider{display:block;width:1px;background:linear-gradient(180deg,transparent 0%,var(--border) 20%,var(--border) 80%,transparent 100%);opacity:.9}.chat-page-main-wrap{height:100%}}.chat-sidebar{width:100%;height:100%;max-width:320px;display:flex;flex-direction:column;background:var(--bg-elevated);border-right:1px solid var(--border);box-shadow:var(--shadow-lg);transition:box-shadow var(--duration-normal) var(--ease-out)}.chat-sidebar-header{padding:var(--space-5) var(--space-4);border-bottom:1px solid var(--border);flex-shrink:0}.chat-sidebar-search{display:flex;gap:var(--space-3);align-items:center}.chat-sidebar-search-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.chat-sidebar-input{flex:1;min-width:0;min-height:44px;padding:var(--space-3) var(--space-4);font-size:.9375rem;font-weight:500;border:1px solid var(--border);border-radius:var(--radius-2xl);background:var(--surface);color:var(--text);outline:none;transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.chat-sidebar-input::placeholder{color:var(--muted)}.chat-sidebar-input:focus,.chat-sidebar-input:focus-visible{border-color:var(--accent);box-shadow:var(--shadow-focus)}.chat-sidebar-search-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius-2xl);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast),border-color var(--duration-fast),background var(--duration-fast)}.chat-sidebar-search-btn:hover{color:var(--accent);border-color:var(--border-strong);background:var(--accent-soft)}.chat-sidebar-search-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.chat-sidebar-user{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-5);padding:var(--space-3) 0}.chat-sidebar-avatar-shell{position:relative;flex-shrink:0;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm),0 0 0 1px #ffffff0a inset;transition:box-shadow var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.chat-sidebar-avatar-shell:hover{box-shadow:var(--shadow-md),0 0 0 1px #6366f140,0 0 24px #6366f11f}.chat-sidebar-profile-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;opacity:0;pointer-events:none}.chat-sidebar-profile-upload{display:grid;place-items:center;cursor:pointer;border-radius:inherit;outline:none;margin:0}.chat-sidebar-profile-upload:focus-visible{outline:none}.chat-sidebar-profile-upload:focus-visible .chat-sidebar-avatar{box-shadow:0 0 0 3px var(--accent-soft),0 0 0 1px var(--accent)}.chat-sidebar-profile-upload .chat-sidebar-avatar{grid-area:1 / 1}.chat-sidebar-profile-veil{grid-area:1 / 1;z-index:1;border-radius:inherit;pointer-events:none;background:linear-gradient(165deg,#0d0f1400 35%,#0d0f1473 70%,#0d0f14b8);opacity:0;transition:opacity var(--duration-normal) var(--ease-out)}.chat-sidebar-profile-camera{grid-area:1 / 1;z-index:2;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);color:#fff;pointer-events:none;background:linear-gradient(145deg,#ffffff38,#ffffff0f);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 4px 14px #00000059,0 0 0 1px #0003 inset;opacity:0;transform:scale(.88) translateY(2px);transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-slow) var(--ease-spring)}.chat-sidebar-profile-upload:hover .chat-sidebar-profile-veil,.chat-sidebar-profile-upload:focus-visible .chat-sidebar-profile-veil{opacity:1}.chat-sidebar-profile-upload:hover .chat-sidebar-profile-camera,.chat-sidebar-profile-upload:focus-visible .chat-sidebar-profile-camera{opacity:1;transform:scale(1) translateY(0)}.chat-sidebar-profile-upload:active .chat-sidebar-profile-camera{transform:scale(.94) translateY(0);transition-duration:var(--duration-instant)}.chat-sidebar-avatar{--avatar-bg: var(--surface);--avatar-border: var(--border);width:48px;height:48px;border-radius:var(--radius-lg);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;flex-shrink:0;overflow:hidden;background:var(--avatar-bg);border:2px solid var(--avatar-border);transition:border-color var(--duration-fast) var(--ease-out)}.chat-sidebar-avatar--has-img{background:transparent}.chat-sidebar-avatar-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:auto;transform:translateZ(0);backface-visibility:hidden}.chat-sidebar-user-info{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.chat-sidebar-username{font-weight:600;font-size:.9375rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-sidebar-status{font-size:.8125rem;color:var(--accent-2);font-weight:500}.chat-sidebar-title{margin:var(--space-5) 0 var(--space-3);font-size:.6875rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.chat-sidebar-list{list-style:none;margin:0;padding:var(--space-2) var(--space-3) var(--space-6);overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;scroll-behavior:smooth}.chat-sidebar-list::-webkit-scrollbar{width:6px}.chat-sidebar-list::-webkit-scrollbar-track{background:transparent}.chat-sidebar-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}.chat-sidebar-list::-webkit-scrollbar-thumb:hover{background:var(--muted)}.chat-list-item{animation:sidebarItemIn var(--duration-slow) var(--ease-out) backwards}@keyframes sidebarItemIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.chat-sidebar-list .chat-list-item:nth-child(1){animation-delay:0ms}.chat-sidebar-list .chat-list-item:nth-child(2){animation-delay:30ms}.chat-sidebar-list .chat-list-item:nth-child(3){animation-delay:60ms}.chat-sidebar-list .chat-list-item:nth-child(4){animation-delay:90ms}.chat-sidebar-list .chat-list-item:nth-child(5){animation-delay:.12s}.chat-sidebar-list .chat-list-item:nth-child(6){animation-delay:.15s}.chat-sidebar-list .chat-list-item:nth-child(7){animation-delay:.18s}.chat-sidebar-list .chat-list-item:nth-child(8){animation-delay:.21s}.chat-sidebar-list .chat-list-item:nth-child(9){animation-delay:.24s}.chat-sidebar-list .chat-list-item:nth-child(10){animation-delay:.27s}.chat-sidebar-list .chat-list-item:nth-child(n+11){animation-delay:.3s}.chat-sidebar-empty{padding:var(--space-6) var(--space-4);margin:0 var(--space-3);font-size:.875rem;color:var(--text-secondary);text-align:center;line-height:1.5}.chat-list-item{margin:0 0 var(--space-2)}.chat-list-item-btn{width:100%;min-height:56px;display:flex;flex-direction:row;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:none;border-radius:var(--radius);background:transparent;color:var(--text);text-align:left;cursor:pointer;transition:background var(--duration-normal) var(--ease-out),transform var(--duration-fast) var(--ease-out),border-color var(--duration-fast),box-shadow var(--duration-fast),color var(--duration-fast);position:relative;border-left:3px solid transparent}.chat-list-item-btn:hover{background:var(--surface-hover)}.chat-list-item-btn:active{transform:scale(.99)}.chat-list-item-btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg-elevated),0 0 0 4px var(--accent)}.chat-list-item-btn--active{border-left-color:transparent;background:linear-gradient(135deg,color-mix(in srgb,var(--accent-soft) 78%,transparent),color-mix(in srgb,var(--accent) 16%,transparent));box-shadow:0 8px 20px color-mix(in srgb,var(--accent) 16%,transparent),inset 0 1px color-mix(in srgb,#ffffff 16%,transparent)}.chat-list-item-btn--active:hover{background:linear-gradient(135deg,color-mix(in srgb,var(--accent-soft) 84%,transparent),color-mix(in srgb,var(--accent) 22%,transparent))}.chat-list-item-avatar{--avatar-bg: var(--surface);--avatar-border: var(--border);width:48px;height:48px;min-width:48px;min-height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;border:2px solid var(--avatar-border);box-shadow:var(--shadow-sm),inset 0 1px #ffffff26;transition:box-shadow var(--duration-normal) var(--ease-out);overflow:hidden;background:var(--avatar-bg)}.chat-list-item-avatar--has-img{background:transparent}.chat-list-item-avatar-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:auto;transform:translateZ(0);backface-visibility:hidden}.chat-list-item-btn:hover .chat-list-item-avatar{box-shadow:var(--shadow-md),inset 0 1px #fff3}.chat-list-item-btn--active .chat-list-item-avatar{box-shadow:0 0 0 2px var(--bg-elevated),0 0 0 4px var(--accent),var(--shadow-sm),inset 0 1px #ffffff26}.chat-list-item-avatar-initials{font-size:17px;font-weight:700;color:#fffffffa;letter-spacing:-.5px;text-shadow:0 1px 2px rgba(0,0,0,.2)}.chat-list-item-avatar-status{display:none}.chat-list-item-avatar-status-dot{width:100%;height:100%;border-radius:50%;box-sizing:border-box}.chat-list-item-avatar--online .chat-list-item-avatar-status-dot{background:var(--accent-2);box-shadow:0 0 0 1px var(--bg-elevated),0 0 4px var(--accent-2);animation:status-pulse 2.5s ease-in-out infinite}.chat-list-item-avatar--offline .chat-list-item-avatar-status-dot{background:var(--muted)}@keyframes status-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.06)}}.chat-list-item-avatar--offline{filter:saturate(.8) brightness(.92)}.chat-list-item-btn--active .chat-list-item-avatar--offline{filter:saturate(.85) brightness(.95)}.chat-list-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.chat-list-item-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.chat-list-item-status{font-size:11px;font-weight:600;white-space:nowrap;line-height:1.2}.chat-list-item-status--online{color:var(--accent-2)}.chat-list-item-status--offline{color:var(--muted)}.chat-list-item-preview{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;margin-top:var(--space-1);transition:color var(--duration-fast)}.chat-list-item-preview--photo{display:inline-flex;align-items:center;gap:6px;min-width:0}.chat-list-item-preview-photo-icon{flex-shrink:0;opacity:.9;color:var(--text-secondary)}.chat-list-item-preview-photo-text{min-width:0;overflow:hidden;text-overflow:ellipsis}.chat-list-item-preview--typing{overflow:visible;text-overflow:clip}.typing{display:inline-flex;align-items:center;justify-content:flex-start;gap:6px;width:fit-content;max-width:100%;box-sizing:border-box;padding:3px 10px 3px 0;border-radius:999px;background:linear-gradient(135deg,color-mix(in srgb,var(--accent-soft) 75%,transparent),color-mix(in srgb,var(--accent) 22%,transparent));backdrop-filter:none;-webkit-backdrop-filter:none;font-size:11px;font-weight:600;letter-spacing:.01em;color:color-mix(in srgb,var(--text) 84%,var(--accent));white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:none}.typing:after{content:"";width:14px;height:4px;border-radius:999px;background:radial-gradient(circle,currentColor 58%,transparent 60%) 0 50% / 4px 4px no-repeat,radial-gradient(circle,currentColor 58%,transparent 60%) 5px 50% / 4px 4px no-repeat,radial-gradient(circle,currentColor 58%,transparent 60%) 10px 50% / 4px 4px no-repeat;opacity:.55;animation:typing-dots 1.2s ease-in-out infinite}@keyframes typing-dots{0%,to{opacity:.45;transform:translateY(0)}50%{opacity:1;transform:translateY(-.5px)}}.chat-area{width:100%;height:100%;min-width:0;min-height:0;display:flex;flex-direction:column;background:var(--bg)}.chat-area-menu-btn{display:flex;width:44px;height:44px;min-width:44px;min-height:44px;margin-right:var(--space-2);align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:color var(--duration-fast),border-color var(--duration-fast),background var(--duration-fast)}.chat-area-menu-btn:hover{color:var(--text);border-color:var(--text-tertiary);background:var(--bg-muted)}.chat-area-menu-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.chat-area-header{min-height:72px;padding:0 var(--space-6);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0;transition:background var(--duration-normal) var(--ease-out);box-shadow:0 1px 0 var(--border)}.chat-area-who{display:flex;align-items:center;gap:var(--space-3);min-width:0}.chat-area-avatar-wrap{position:relative;flex-shrink:0}.chat-area-avatar{--avatar-bg: var(--surface);--avatar-border: var(--border);width:46px;height:46px;border-radius:var(--radius-lg);border:2px solid var(--avatar-border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.0625rem;color:#fff;box-shadow:var(--shadow-sm);transition:box-shadow var(--duration-fast) var(--ease-out);overflow:hidden;background:var(--avatar-bg)}.chat-area-avatar--has-img{background:transparent}.chat-area-avatar-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:auto;transform:translateZ(0);backface-visibility:hidden}.chat-area-avatar-status{position:absolute;bottom:0;right:0;width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-elevated);box-sizing:border-box}.chat-area-avatar-status--online{background:var(--online)}.chat-area-avatar-status--offline{background:var(--muted)}.chat-area-info{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.chat-area-name{font-weight:600;font-size:1rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-area-status{font-size:.8125rem;font-weight:500;color:var(--text-tertiary)}.chat-area-status--online{color:var(--online)}.chat-area-status--offline{color:var(--text-tertiary)}.chat-area-logout{width:44px;height:44px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast),border-color var(--duration-fast),background var(--duration-fast),transform var(--duration-instant);flex-shrink:0}.chat-area-logout:active{transform:scale(.96)}.chat-area-logout:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-soft)}.chat-area-logout:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.chat-area-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}@media (min-width: 901px){.chat-area-menu-btn{display:none}}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-6);padding:var(--space-10) var(--space-6)}.chat-empty-icon{width:96px;height:96px;border-radius:50%;background:var(--surface);border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:border-color var(--duration-normal) var(--ease-out),background var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-xs)}.chat-empty-icon svg{opacity:.55}.chat-empty-title{margin:0;font-size:1.25rem;font-weight:700;color:var(--text);letter-spacing:-.02em;text-align:center}.chat-empty-text{margin:0;font-size:.9375rem;color:var(--text-secondary);text-align:center;line-height:1.6;max-width:280px}.chat-empty-btn{padding:var(--space-3) var(--space-6);font-size:.9375rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);border:none;border-radius:var(--radius-2xl);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-sm)}.chat-empty-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.chat-empty-btn:active{transform:translateY(0) scale(.98)}.chat-empty-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus),var(--shadow-glow)}.chat-conversation{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.chat-conversation-scroll{flex:1;min-height:0;overflow-y:auto;padding:var(--space-5) var(--space-6) var(--space-8);display:flex;flex-direction:column;gap:var(--space-1);scroll-behavior:smooth}.chat-conversation-date{display:flex;align-items:center;justify-content:center;padding:var(--space-4) 0 var(--space-3);margin:var(--space-2) 0 var(--space-1)}.chat-conversation-date span{font-size:.6875rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-2) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl)}.chat-conversation-scroll::-webkit-scrollbar{width:8px}.chat-conversation-scroll::-webkit-scrollbar-track{background:transparent}.chat-conversation-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-sm)}.chat-conversation-scroll::-webkit-scrollbar-thumb:hover{background:var(--muted)}.chat-conversation-typing{display:flex;gap:var(--space-3);align-items:center;max-width:78%;margin-top:var(--space-1);margin-bottom:var(--space-4);flex-shrink:0;animation:typingIn var(--duration-normal) var(--ease-out) backwards}.chat-conversation-typing-avatar{--avatar-bg: var(--surface-2);--avatar-border: var(--border);width:34px;height:34px;min-width:34px;border-radius:50%;border:1px solid var(--avatar-border);background:var(--avatar-bg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fffffff2;flex-shrink:0;overflow:hidden;box-shadow:var(--shadow-xs)}.chat-conversation-typing-avatar--has-img{background:transparent}.chat-conversation-typing-avatar-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:auto;transform:translateZ(0);backface-visibility:hidden}.chat-conversation-typing-bubble{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);width:fit-content;min-width:0;padding:var(--space-2) var(--space-3);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-xl);border-top-left-radius:6px;box-shadow:var(--shadow-xs)}.chat-conversation-typing-dots{display:inline-flex;align-items:center;gap:6.3px}.chat-conversation-typing-dot{width:6.3px;height:6.3px;border-radius:50%;background:var(--muted);animation:typingDot 1.2s var(--ease-in-out) infinite both}.chat-conversation-typing-dot:nth-child(1){animation-delay:0s}.chat-conversation-typing-dot:nth-child(2){animation-delay:.15s}.chat-conversation-typing-dot:nth-child(3){animation-delay:.3s}@keyframes typingIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes typingDot{0%,60%,to{opacity:.35;transform:scale(.9)}30%{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion: reduce){.chat-conversation-typing{animation:none}.chat-conversation-typing-dot{animation:none;opacity:.7}}.message-bubble{display:flex;gap:var(--space-3);align-items:flex-end;max-width:78%;animation:messageIn var(--duration-normal) var(--ease-out) backwards;margin-top:var(--space-1)}.message-bubble--consecutive{margin-top:-4px}.message-bubble--consecutive .message-bubble-body{border-radius:14px}.message-bubble--theirs.message-bubble--consecutive .message-bubble-body{border-top-left-radius:6px}.message-bubble-avatar-spacer{width:34px;min-width:34px;flex-shrink:0}@keyframes messageIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.message-bubble{animation:none}}.message-bubble--mine{align-self:flex-end;flex-direction:row-reverse}.message-bubble-avatar{width:34px;height:34px;min-width:34px;border-radius:50%;background:linear-gradient(135deg,var(--surface-2) 0%,var(--surface) 100%);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--text-secondary);flex-shrink:0;overflow:hidden}.message-bubble-avatar-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:auto;transform:translateZ(0);backface-visibility:hidden}.message-bubble-body{padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);transition:box-shadow var(--duration-fast) var(--ease-out)}.message-bubble-body:hover{box-shadow:var(--shadow-md)}.message-bubble-body--image-only{padding:var(--space-2)}.message-bubble--mine .message-bubble-body{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);border-color:var(--border-focus);box-shadow:var(--shadow-md),0 0 0 1px #ffffff0f inset}.message-bubble-sender{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:4px}.message-bubble-text{font-size:.9375rem;line-height:1.55;color:var(--text);word-wrap:break-word;overflow-wrap:break-word}.message-bubble--mine .message-bubble-text{color:#fffffffa}.message-bubble-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-1);margin-top:var(--space-2)}.message-bubble-time{font-size:.6875rem;color:var(--text-secondary);text-align:right;font-weight:500;letter-spacing:.02em;transition:color var(--duration-fast)}.message-bubble--mine .message-bubble-time{color:#fffc}.message-bubble-body:hover .message-bubble-time{color:var(--muted)}.message-bubble--mine .message-bubble-body:hover .message-bubble-time{color:#fffffff2}.message-bubble-sending{display:inline-flex;align-items:center;font-size:.625rem;font-weight:500;letter-spacing:.06em;color:#ffffffa6;margin-left:6px;font-style:italic}.message-bubble-seen{display:inline-flex;align-items:center;justify-content:center;gap:4px;color:#fff9;margin-left:6px;transition:color var(--duration-fast);flex-shrink:0;font-size:.625rem;font-weight:500;letter-spacing:.06em}.message-bubble-seen--read{color:#ffffffeb}.message-bubble-seen-icon{display:block;flex-shrink:0;opacity:.9}.message-bubble-seen-icon--single{width:12px;height:12px}.message-bubble-seen-icon--double{width:14px;height:14px}.message-bubble-seen-label{line-height:1}.message-bubble-body:hover .message-bubble-seen{color:#ffffffd9}.message-bubble-body:hover .message-bubble-seen--read{color:#fff}.message-bubble-image-wrap{display:flex;flex-direction:column;gap:var(--space-2);margin-top:-2px}.message-bubble-image{width:100%;max-width:280px;aspect-ratio:4 / 3;min-height:140px;border-radius:var(--radius-lg);background:var(--surface-2);border:1px solid var(--border);overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm),0 0 0 1px #00000014 inset;transition:box-shadow var(--duration-normal) var(--ease-out),border-color var(--duration-fast)}.message-bubble-image:hover{box-shadow:var(--shadow-md),0 0 0 1px #0000000f inset;border-color:var(--border-strong)}.message-bubble--mine .message-bubble-image{box-shadow:var(--shadow-sm),0 0 0 1px #ffffff0a inset}.message-bubble--mine .message-bubble-image:hover{box-shadow:var(--shadow-md),0 0 0 1px #ffffff0f inset}.message-bubble-image-btn{width:100%;height:100%;padding:0;border:none;background:none;cursor:pointer;display:block;position:relative;overflow:hidden;transition:transform var(--duration-normal) var(--ease-out)}.message-bubble-image-btn:hover{transform:scale(1.02)}.message-bubble-image-btn:active{transform:scale(.99)}.message-bubble-image-btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-soft)}.message-bubble-image-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;vertical-align:middle}.message-bubble-image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 50%);color:#fffffff2;opacity:0;transition:opacity var(--duration-fast) var(--ease-out);pointer-events:none}.message-bubble-image-btn:hover .message-bubble-image-overlay{opacity:1}.message-bubble-image-overlay svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.message-bubble-image-loading{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4)}.message-bubble-image-spinner{width:28px;height:28px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:var(--radius-full);animation:messageBubbleSpinner .7s linear infinite}@keyframes messageBubbleSpinner{to{transform:rotate(360deg)}}.message-bubble-image-loading-text{font-size:.8125rem;font-weight:500;color:var(--text-secondary);letter-spacing:.02em}.message-bubble-image-load{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-5);border:2px dashed var(--border-strong);border-radius:var(--radius-lg);background:linear-gradient(145deg,var(--surface-2) 0%,var(--surface-hover) 100%);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:border-color var(--duration-fast),background var(--duration-fast),color var(--duration-fast),transform var(--duration-fast)}.message-bubble-image-load:hover{border-color:var(--accent-strong);background:linear-gradient(145deg,var(--surface-hover) 0%,var(--accent-soft) 100%);color:var(--text)}.message-bubble-image-load:active{transform:scale(.98)}.message-bubble-image-load:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.message-bubble-image-load-icon{display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:color var(--duration-fast)}.message-bubble-image-load:hover .message-bubble-image-load-icon{color:var(--accent)}.message-bubble-image-load-label{text-align:center;letter-spacing:.02em}.message-bubble-image-caption{margin-top:0;padding-top:0;font-size:.875rem;line-height:1.5;color:var(--text-secondary)}.message-bubble--mine .message-bubble-image-caption{color:#ffffffd9}@media (prefers-reduced-motion: reduce){.message-bubble-image-btn:hover{transform:none}.message-bubble-image-spinner{animation:none;border-top-color:var(--text-tertiary)}}.chat-input-bar{flex-shrink:0;padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;align-items:stretch;gap:var(--space-3);border-top:1px solid var(--border);background:var(--bg-elevated)}.chat-input-bar-row{display:flex;align-items:center;gap:var(--space-3);min-width:0}.chat-input-bar-pending-image{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);overflow:hidden}.chat-input-bar-pending-image-inner{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);min-width:0}.chat-input-bar-pending-thumb{width:56px;height:56px;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0}.chat-input-bar-pending-meta{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.chat-input-bar-pending-label{font-size:.875rem;font-weight:600;color:var(--text)}.chat-input-bar-pending-hint{font-size:.75rem;color:var(--muted)}.chat-input-bar-pending-remove{margin-left:auto;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);background:transparent;color:var(--muted);font-size:1.5rem;line-height:1;cursor:pointer;transition:color var(--duration-fast),background var(--duration-fast)}.chat-input-bar-pending-remove:hover{color:var(--text);background:var(--accent-soft)}.chat-input-bar-input{flex:1;min-width:0;min-height:44px;padding:var(--space-3) var(--space-4);font-size:.9375rem;font-weight:500;border:1px solid var(--border);border-radius:var(--radius-2xl);background:var(--surface);color:var(--text);outline:none;transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.chat-input-bar-input::placeholder{color:var(--muted)}.chat-input-bar-input:focus,.chat-input-bar-input:focus-visible{border-color:var(--accent);box-shadow:var(--shadow-focus)}.chat-input-bar-btn{width:46px;height:46px;min-width:46px;min-height:46px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:transform var(--duration-instant) var(--ease-out),color var(--duration-fast),border-color var(--duration-fast),background var(--duration-fast),box-shadow var(--duration-fast);flex-shrink:0}.chat-input-bar-btn:hover{color:var(--accent);border-color:var(--border-strong);background:var(--accent-soft)}.chat-input-bar-btn:active{transform:scale(.96)}.chat-input-bar-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.chat-input-bar-btn--secondary:active{transform:scale(.96)}.chat-input-bar-btn--send{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);border-color:transparent;color:#fff}.chat-input-bar-btn--send:hover{filter:brightness(1.08);box-shadow:var(--shadow-glow)}.chat-input-bar-btn--send:active{transform:scale(.96);filter:brightness(1)}.chat-input-bar-btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.chat-input-bar-icon{width:22px;height:22px;pointer-events:none}.chat-input-bar-file-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.chat-input-bar-emoji-wrap{position:relative;flex-shrink:0}.chat-input-bar-emoji-popover{position:absolute;bottom:calc(100% + 8px);left:0;z-index:50;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg, 0 12px 40px rgba(0, 0, 0, .18));overflow:hidden}.chat-gallery-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:var(--space-6);animation:chatGalleryIn var(--duration-normal) var(--ease-out)}.chat-gallery-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.chat-gallery-modal{position:relative;width:100%;max-width:920px;max-height:88vh;display:flex;flex-direction:column;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),0 0 0 1px #ffffff08 inset;overflow:hidden}.chat-gallery-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);background:linear-gradient(180deg,var(--surface-2) 0%,var(--bg-elevated) 100%);border-bottom:1px solid var(--border);flex-shrink:0}.chat-gallery-title{margin:0;font-size:1.0625rem;font-weight:700;letter-spacing:-.02em;color:var(--text);display:flex;align-items:center;gap:var(--space-2)}.chat-gallery-title:before{content:"";width:4px;height:20px;border-radius:2px;background:linear-gradient(180deg,var(--accent) 0%,var(--accent-hover) 100%)}.chat-gallery-close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius);background:transparent;color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast),background var(--duration-fast)}.chat-gallery-close:hover{color:var(--text);background:var(--surface-hover)}.chat-gallery-close:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.chat-gallery-grid{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:var(--space-5);display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-auto-rows:180px;gap:var(--space-4);align-content:start}.chat-gallery-grid::-webkit-scrollbar{width:10px}.chat-gallery-grid::-webkit-scrollbar-track{background:var(--surface);border-radius:var(--radius-full);margin:var(--space-2) 0}.chat-gallery-grid::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full);border:3px solid var(--surface)}.chat-gallery-grid::-webkit-scrollbar-thumb:hover{background:var(--muted)}.chat-gallery-grid::-webkit-scrollbar-thumb:active{background:var(--text-tertiary)}.chat-gallery-grid{scrollbar-width:thin;scrollbar-color:var(--border-strong) var(--surface)}.chat-gallery-item{min-width:0;min-height:0;height:100%;max-height:180px;border-radius:var(--radius);overflow:hidden;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:box-shadow var(--duration-fast),border-color var(--duration-fast),transform var(--duration-fast);padding:0;margin:0;font:inherit;color:inherit;-moz-appearance:none;appearance:none;-webkit-appearance:none;display:block;position:relative}.chat-gallery-item:hover{box-shadow:var(--shadow-md),0 0 0 1px var(--accent-soft);border-color:var(--accent-strong);transform:scale(1.02)}.chat-gallery-item:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.chat-gallery-item-inner{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:inherit}.chat-gallery-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:auto;backface-visibility:hidden}.chat-gallery-loading,.chat-gallery-empty{grid-column:1 / -1;margin:var(--space-10) 0;text-align:center;font-size:.9375rem;font-weight:500;color:var(--text-secondary)}.chat-gallery-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:101;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:#000000e6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:chatGalleryIn var(--duration-normal) var(--ease-out)}.chat-gallery-lightbox-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;cursor:pointer}.chat-gallery-lightbox-content{position:relative;max-width:95vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.chat-gallery-lightbox-img{max-width:100%;max-height:90vh;width:auto;height:auto;object-fit:contain;object-position:center;border-radius:var(--radius);box-shadow:var(--shadow-lg),0 0 0 1px #ffffff0f;image-rendering:-webkit-optimize-contrast;image-rendering:auto;backface-visibility:hidden}.chat-gallery-lightbox-close{position:absolute;top:var(--space-2);right:var(--space-2);width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius);background:#0000008c;color:#fff;cursor:pointer;transition:background var(--duration-fast)}.chat-gallery-lightbox-close:hover{background:#000c}.chat-gallery-lightbox-close:focus-visible{outline:none;box-shadow:var(--shadow-focus)}@keyframes chatGalleryIn{0%{opacity:0}to{opacity:1}}.image-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:101;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:#000000e6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:imageLightboxIn var(--duration-normal) var(--ease-out)}.image-lightbox-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;cursor:pointer}.image-lightbox-content{position:relative;max-width:95vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.image-lightbox-img{max-width:100%;max-height:90vh;width:auto;height:auto;object-fit:contain;object-position:center;border-radius:var(--radius);box-shadow:var(--shadow-lg),0 0 0 1px #ffffff0f;image-rendering:-webkit-optimize-contrast;image-rendering:auto;backface-visibility:hidden}.image-lightbox-close{position:absolute;top:var(--space-2);right:var(--space-2);width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius);background:#0000008c;color:#fff;cursor:pointer;transition:background var(--duration-fast)}.image-lightbox-close:hover{background:#000c}.image-lightbox-close:focus-visible{outline:none;box-shadow:var(--shadow-focus)}@keyframes imageLightboxIn{0%{opacity:0}to{opacity:1}}.chat-toast{position:fixed;top:var(--space-6);left:50%;transform:translate(-50%);z-index:4000;max-width:min(420px,calc(100vw - var(--space-8)));pointer-events:none;animation:chat-toast-in var(--duration-normal) var(--ease-out) forwards}@media (prefers-reduced-motion: reduce){.chat-toast{animation:none}}@keyframes chat-toast-in{0%{opacity:0;transform:translate(-50%) translateY(-12px) scale(.98)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.chat-toast-inner{pointer-events:auto;display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-4) var(--space-4) var(--space-3);border-radius:var(--radius-lg);background:linear-gradient(145deg,#1a1e28eb,#13161df5);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-strong);box-shadow:var(--shadow-lg),0 0 0 1px #dc26261f;border-left:3px solid var(--danger)}.chat-toast-icon-wrap{flex-shrink:0;width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--danger-soft);color:#f87171}.chat-toast-icon-wrap svg{width:20px;height:20px}.chat-toast-body{flex:1;min-width:0;padding-top:2px}.chat-toast-title{margin:0 0 var(--space-1);font-size:.8125rem;font-weight:600;letter-spacing:.02em;color:var(--text)}.chat-toast-message{margin:0;font-size:.875rem;line-height:1.45;color:var(--text-secondary)}.chat-toast-dismiss{flex-shrink:0;margin:-4px -4px -4px 0;width:36px;height:36px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-tertiary);font-size:1.35rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.chat-toast-dismiss:hover{color:var(--text);background:var(--surface-hover)}.chat-toast-dismiss:focus-visible{outline:none;box-shadow:var(--shadow-focus)}*,*:before,*:after{box-sizing:border-box}:root{--bg: #0d0f14;--bg-elevated: #13161d;--bg-overlay: #181c24;--surface: #1a1e28;--surface-2: #1f242e;--surface-hover: #232934;--border: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .09);--border-focus: rgba(99, 102, 241, .4);--text: #eef1f5;--text-secondary: #8f97a6;--text-tertiary: #5c6370;--muted: #5c6370;--accent: #6366f1;--accent-hover: #7c7ff7;--accent-soft: rgba(99, 102, 241, .1);--accent-strong: rgba(99, 102, 241, .22);--online: #16a34a;--accent-2: #16a34a;--accent-2-soft: rgba(22, 163, 74, .12);--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .1);--success: #16a34a;--warning: #d97706;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .22), 0 0 1px rgba(0, 0, 0, .15);--shadow-md: 0 4px 16px rgba(0, 0, 0, .25), 0 0 1px rgba(0, 0, 0, .2);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .3);--shadow-glow: 0 0 0 1px var(--accent-strong), 0 0 20px rgba(99, 102, 241, .15);--shadow-focus: 0 0 0 3px var(--accent-soft);--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-instant: .1s;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .35s}@media (prefers-reduced-motion: reduce){:root{--duration-instant: 0s;--duration-fast: 0s;--duration-normal: .01s;--duration-slow: .01s}*,*:before,*:after{animation-duration:.01s!important;animation-iteration-count:1!important;transition-duration:.01s!important}}html{font-size:16px;-webkit-tap-highlight-color:transparent}html,body{width:100%;height:100%;margin:0;overflow:hidden}#root{width:100%;height:100%;display:block}.app-chat-wrapper{width:100%;height:100%;min-height:100vh;min-width:100%;display:block;overflow:hidden}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.9375rem;line-height:1.5;background:var(--bg);color:var(--text);min-height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.focus-ring:focus{outline:none}.focus-ring:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::selection{background:var(--accent-soft);color:var(--text)}.bg-dynamic{position:relative;min-height:100%}.bg-dynamic:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 70% 40% at 15% 15%,rgba(99,102,241,.06),transparent 45%),radial-gradient(ellipse 50% 60% at 88% 85%,rgba(34,197,94,.04),transparent 45%)}.app-chat-wrapper{position:relative;z-index:1}
