:root{--text:#e0e0e0;--text-h:#fff;--bg:#0f0f1a;--border:#ffffff1a;--code-bg:#1a1a2e;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/145% var(--sans);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{width:100%;height:var(--app-height,100dvh);-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;overscroll-behavior:none;overflow:hidden}body{width:100%;height:var(--app-height,100dvh);overscroll-behavior:none;touch-action:manipulation;margin:0;position:fixed;inset:0;overflow:hidden}#root{width:100%;height:var(--app-height,100dvh);overflow:hidden}:root{--bg:#eef2f7;--surface:#fff;--surface-soft:#f6f8fb;--ink:#111827;--muted:#667085;--muted-2:#98a2b3;--line:#11182717;--primary:#2563eb;--primary-dark:#1d4ed8;--accent:#14b8a6;--danger:#ef4444;--bubble-in:#f2f4f7;--shadow:0 24px 70px #0f172a2e}*{box-sizing:border-box}body{color:var(--ink);letter-spacing:0;background:radial-gradient(circle at 18% 12%,#2563eb29,#0000 28%),radial-gradient(circle at 82% 20%,#14b8a624,#0000 25%),linear-gradient(#f8fafc 0%,#e5eaf2 100%);margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,ui-sans-serif,sans-serif;overflow:hidden}button,input{font:inherit;letter-spacing:0}button{-webkit-tap-highlight-color:transparent}.login-container,.chat-layout{width:100%;max-width:100%;height:100dvh;height:var(--app-height,100dvh);justify-content:center;align-items:center;min-height:0;padding:18px;display:flex;overflow:hidden}.login-card,.chat-main{width:min(100%,430px);max-width:100%;height:min(100%,884px);max-height:calc(100dvh - 36px);max-height:calc(var(--app-height,100dvh) - 36px);background:var(--surface);min-width:0;box-shadow:var(--shadow);border:1px solid #ffffffbf;border-radius:28px;overflow:hidden}.login-card{padding:max(24px, env(safe-area-inset-top)) 22px max(22px, env(safe-area-inset-bottom));flex-direction:column;gap:8px;display:flex}.login-hero{flex:none;padding:42px 2px 22px}.login-app-icon{background:linear-gradient(135deg, var(--primary), #7c3aed);color:#fff;border-radius:20px;place-items:center;width:64px;height:64px;font-size:27px;font-weight:800;display:grid;box-shadow:0 18px 35px #2563eb52}.login-kicker{color:var(--primary);text-transform:uppercase;margin-top:30px;font-size:12px;font-weight:800;display:inline-flex}.login-card h1{max-width:320px;color:var(--ink);margin:12px 0 0;font-size:40px;font-weight:800;line-height:1.02}.login-card p{max-width:300px;color:var(--muted);margin:12px 0 0;font-size:15px;line-height:1.5}.login-preview{flex-direction:column;flex:auto;justify-content:center;gap:12px;min-height:110px;padding:10px 0 18px;display:flex}.preview-row{align-items:flex-end;gap:9px;display:flex}.preview-row.reverse{justify-content:flex-end}.preview-avatar,.header-avatar,.empty-avatar{color:#fff;background:linear-gradient(135deg,#64748b,#94a3b8);border-radius:50%;place-items:center;font-weight:800;display:grid}.preview-avatar{flex:none;width:34px;height:34px;font-size:13px}.preview-row.reverse .preview-avatar,.header-avatar{background:linear-gradient(135deg, var(--primary), #06b6d4)}.preview-bubble{border-radius:18px;max-width:68%;padding:11px 14px;font-size:15px;line-height:1.36;box-shadow:0 10px 26px #0f172a14}.preview-bubble.sent{background:var(--bubble-in);color:var(--ink);border-bottom-left-radius:6px}.preview-bubble.received{background:var(--primary);color:#fff;border-bottom-right-radius:6px}.login-form{flex:none;padding-top:8px}.login-card input{border:1px solid var(--line);background:var(--surface-soft);width:100%;height:54px;color:var(--ink);text-align:center;text-transform:lowercase;border-radius:16px;outline:none;font-size:18px;font-weight:700;transition:background .16s,border-color .16s,box-shadow .16s}.login-card input:focus{background:#fff;border-color:#2563eb75;box-shadow:0 0 0 4px #2563eb1a}.login-card input::placeholder{color:var(--muted-2);font-weight:600}.login-error{min-height:22px;color:var(--danger);text-align:center;padding-top:8px;font-size:13px}.invite-panel{border:1px solid var(--line);background:var(--surface-soft);border-radius:18px;padding:12px}.invite-title{color:var(--ink);font-size:15px;font-weight:850}.invite-note{color:var(--muted);margin-top:9px;font-size:13px;line-height:1.45}.invite-link-field{margin-top:10px;padding:0 12px;text-align:left!important;text-transform:none!important;font-size:12px!important;font-weight:650!important}.login-card button{background:var(--primary);color:#fff;cursor:pointer;border:0;border-radius:16px;width:100%;min-height:54px;margin-top:8px;font-size:16px;font-weight:800;transition:transform .16s,opacity .16s,background .16s;box-shadow:0 14px 30px #2563eb42}.login-card button.secondary-action{border:1px solid var(--line);color:var(--ink);box-shadow:none;background:#fff}.login-card button.danger-action{color:var(--danger)}.login-card button:active:not(:disabled),.send-btn:active:not(:disabled),.attach-btn:active:not(:disabled),.sticker-toggle-btn:active:not(:disabled),.sticker-btn:active{transform:scale(.96)}.login-card button:disabled,.send-btn:disabled,.attach-btn:disabled,.sticker-toggle-btn:disabled{opacity:.42;cursor:not-allowed;box-shadow:none}.login-footnote{color:var(--muted);text-align:center;margin-top:13px;font-size:12px}.home-guide-overlay{z-index:30;padding:16px;padding-bottom:max(16px, env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172a5c;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.home-guide-card{width:min(100%,390px);max-height:calc(100dvh - 32px);max-height:calc(var(--app-height,100dvh) - 32px);background:#fffffff5;border:1px solid #ffffffb8;border-radius:24px;padding:16px;animation:.18s both trayIn;overflow:auto;box-shadow:0 24px 70px #0f172a47}.home-guide-topline{justify-content:space-between;align-items:center;gap:12px;display:flex}.home-guide-badge{min-height:28px;color:var(--primary);background:#2563eb1a;border-radius:999px;align-items:center;padding:0 10px;font-size:12px;font-weight:850;display:inline-flex}.home-guide-close{border:1px solid var(--line);min-height:32px;color:var(--muted);background:#fff;border-radius:999px;padding:0 10px;font-size:12px;font-weight:800}.home-guide-title{color:var(--ink);margin-top:14px;font-size:24px;font-weight:900;line-height:1.12}.home-guide-copy{color:var(--muted);margin-top:9px;font-size:14px;line-height:1.5}.home-guide-steps{gap:8px;margin-top:14px;display:grid}.home-guide-step{border:1px solid var(--line);background:var(--surface-soft);min-height:44px;color:var(--ink);border-radius:16px;align-items:center;gap:10px;padding:9px 11px;font-size:14px;font-weight:750;display:flex}.home-guide-step span{background:var(--primary);color:#fff;border-radius:999px;flex:none;place-items:center;width:24px;height:24px;font-size:12px;font-weight:900;display:grid}.home-guide-primary{background:var(--primary);color:#fff;border:0;border-radius:16px;width:100%;min-height:48px;margin-top:14px;font-size:15px;font-weight:850;box-shadow:0 14px 30px #2563eb38}.chat-sidebar{display:none}.chat-main{background:var(--surface);isolation:isolate;flex-direction:column;display:flex}.chat-main-header{padding:max(14px, env(safe-area-inset-top)) 14px 12px;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffe0;flex:none;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;display:grid;position:relative}.chat-main-header:after{content:"";background:linear-gradient(90deg,#0000,#2563eb38,#0000);height:1px;position:absolute;bottom:-1px;left:16px;right:16px}.header-contact{align-items:center;gap:10px;min-width:0;display:flex}.header-avatar{flex:none;width:42px;height:42px;font-size:16px}.header-name{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:17px;font-weight:800;line-height:1.1;overflow:hidden}.header-status{color:var(--muted);align-items:center;gap:6px;margin-top:4px;font-size:12px;font-weight:650;display:flex}.header-actions{align-items:center;gap:8px;display:inline-flex}.status-dot{background:var(--muted-2);border-radius:999px;width:7px;height:7px}.status-dot.online{background:var(--accent);animation:1.8s ease-in-out infinite onlinePulse;box-shadow:0 0 0 4px #14b8a621}.secure-pill{background:var(--surface-soft);min-height:34px;color:var(--muted);border-radius:999px;justify-content:center;align-items:center;gap:7px;padding:0 11px;font-size:12px;font-weight:800;display:inline-flex}.secure-pill.ready{color:#0f766e;background:#14b8a61f}.secure-dot{opacity:.72;background:currentColor;border-radius:999px;width:6px;height:6px}.logout-btn{border:1px solid var(--line);width:auto;min-width:44px;height:34px;color:var(--muted);cursor:pointer;box-shadow:none;background:#fff;border-radius:999px;padding:0 10px;font-size:12px;font-weight:800;line-height:1}.logout-btn:active{transform:scale(.96)}.message-area{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:radial-gradient(circle at 12% 8%,#2563eb0d,#0000 24%),linear-gradient(#f8fafc 0%,#f1f5f9 100%);flex-direction:column;flex:1;gap:7px;width:100%;min-width:0;min-height:0;padding:14px 12px 18px;display:flex;overflow-y:auto}.message-area::-webkit-scrollbar{width:0}.message-day,.history-status{color:var(--muted);background:#ffffffd1;border-radius:999px;align-self:center;padding:6px 10px;font-size:12px;font-weight:700;box-shadow:0 8px 18px #0f172a0a}.history-status-error{color:var(--danger)}.empty-thread{color:var(--muted);justify-items:center;gap:8px;margin:auto 0;display:grid}.empty-avatar{width:66px;height:66px;font-size:24px}.empty-name{font-size:15px;font-weight:800}.message{word-break:break-word;flex-direction:column;gap:3px;min-width:0;max-width:84%;animation:.18s both bubbleIn;display:flex}.message.sent{align-self:flex-end;align-items:flex-end}.message.received{align-self:flex-start;align-items:flex-start}.message-content,.message-file{border-radius:18px;padding:10px 13px;font-size:16px;line-height:1.38;box-shadow:0 8px 20px #0f172a0f}.message-content{white-space:pre-wrap}.message.sent .message-content,.message.sent .message-file{background:var(--primary);color:#fff;border-bottom-right-radius:6px}.message.received .message-content,.message.received .message-file{color:var(--ink);background:#fff;border-bottom-left-radius:6px}.message-sticker{filter:drop-shadow(0 6px 12px #0f172a1f);padding:2px 4px;font-size:56px;line-height:1}.message-media{background:#fff;border-radius:18px;max-width:min(292px,74vw);overflow:hidden;box-shadow:0 12px 28px #0f172a24}.message-media img,.message-media video{width:100%;height:auto;display:block}.message-media-placeholder{width:min(292px,74vw);min-height:132px;color:var(--ink);cursor:pointer;text-align:center;background:linear-gradient(135deg,#eef5ff,#f8fafc);border:0;border-radius:18px;align-content:center;justify-items:center;gap:5px;padding:18px;display:grid;box-shadow:0 12px 28px #0f172a1f}.message-media-placeholder span{color:var(--muted);font-size:12px;font-weight:800}.message-media-placeholder strong{color:var(--primary);font-size:16px}.message-media-placeholder small{max-width:100%;color:var(--muted-2);text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:650;overflow:hidden}.message-media-placeholder:disabled{cursor:wait;opacity:.75}.video-placeholder{background:linear-gradient(135deg,#101827,#263247);min-height:164px}.video-placeholder span,.video-placeholder small{color:#ffffffb8}.video-placeholder strong{color:#fff}.message-file{grid-template-columns:36px minmax(0,1fr) 36px;align-items:center;gap:10px;min-width:min(250px,74vw);display:grid}.file-icon{background:#ffffff2e;border-radius:12px;place-items:center;width:36px;height:36px;font-size:18px;display:grid}.message.received .file-icon{background:var(--surface-soft)}.file-info{min-width:0}.file-name{color:inherit;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:800;overflow:hidden}.file-size{color:#ffffffbf;margin-top:2px;font-size:11px;font-weight:650}.message.received .file-size{color:var(--muted)}.file-download{width:36px;height:36px;color:inherit;cursor:pointer;background:#ffffff2e;border:0;border-radius:12px;place-items:center;font-size:18px;font-weight:900;text-decoration:none;display:grid}.file-download:disabled{cursor:wait;opacity:.72}.message.received .file-download{color:var(--primary);background:#2563eb1a}.message-meta{max-width:100%;min-height:15px;color:var(--muted-2);font-variant-numeric:tabular-nums;white-space:nowrap;align-items:center;gap:4px;padding:0 5px;font-size:10px;font-weight:650;line-height:1.2;display:flex}.message.sent .message-meta{justify-content:flex-end}.read-receipt{color:var(--muted-2);align-items:center;gap:4px;margin-left:1px;transition:color .16s,opacity .16s;display:inline-flex;position:relative}.read-receipt:before{content:"";opacity:.72;background:currentColor;border-radius:999px;width:3px;height:3px}.read-receipt.read{color:var(--primary);font-weight:800}.read-receipt.read:before{opacity:1;box-shadow:0 0 0 3px #2563eb17}.lock{display:none}.pending-file-bar,.sticker-picker,.input-area{border-top:1px solid var(--line);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffe6;flex:none}.pending-file-bar{color:var(--ink);justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;font-size:13px;font-weight:650;display:flex}.pending-file-meta{align-items:center;gap:8px;min-width:0;display:flex}.pending-file-meta span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.pending-file-icon{width:32px;height:32px;color:var(--primary);background:#2563eb1a;border-radius:12px;flex:none;place-items:center;display:grid}.pending-actions{flex:none;gap:8px;display:flex}.pending-actions button{cursor:pointer;border:0;border-radius:12px;min-height:34px;padding:0 12px;font-size:13px;font-weight:800}.pending-actions button:disabled{cursor:not-allowed;opacity:.62}.pending-actions button:first-child{background:var(--primary);color:#fff}.pending-actions button:last-child{background:var(--surface-soft);color:var(--ink)}.sticker-picker{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:12px 14px 14px;animation:.16s both trayIn;display:grid}.sticker-picker-handle{background:#11182724;border-radius:999px;grid-column:1/-1;justify-self:center;width:38px;height:5px;margin-bottom:2px}.sticker-btn{background:var(--surface-soft);cursor:pointer;border:0;border-radius:16px;min-width:0;min-height:58px;font-size:28px;transition:transform .16s,background .16s;box-shadow:0 8px 18px #0f172a0f}.input-area{z-index:2;padding:10px 10px max(10px, env(safe-area-inset-bottom));grid-template-columns:42px 42px minmax(0,1fr) auto;align-items:center;gap:7px;display:grid;position:relative;box-shadow:0 -12px 32px #0f172a0f}.attach-btn,.sticker-toggle-btn,.send-btn{appearance:none;cursor:pointer;border:0;border-radius:14px;align-self:center;place-items:center;width:42px;height:42px;padding:0;line-height:1;transition:transform .16s,opacity .16s,background .16s;display:grid}.attach-btn,.sticker-toggle-btn{background:var(--surface-soft);color:var(--primary);font-size:28px}.sticker-toggle-btn{font-size:23px}.message-input{border:1px solid var(--line);background:var(--surface-soft);width:100%;height:42px;min-height:42px;color:var(--ink);border-radius:14px;outline:none;padding:10px 13px;font-size:16px}.message-input:focus{background:#fff;border-color:#2563eb6b;box-shadow:0 0 0 4px #2563eb14}.message-input::placeholder{color:var(--muted-2)}.send-btn{background:var(--primary);color:#fff;width:auto;min-width:58px;padding:0 14px;font-size:14px;font-weight:850;box-shadow:0 10px 22px #2563eb3d}.send-btn:not(:disabled){background:linear-gradient(135deg, var(--primary), var(--primary-dark))}@keyframes bubbleIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@keyframes trayIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes onlinePulse{0%,to{box-shadow:0 0 0 4px #14b8a621}50%{box-shadow:0 0 0 7px #14b8a60a}}@media (width<=520px){.login-container,.chat-layout{background:var(--surface);padding:0}.login-card,.chat-main{width:100%;height:100dvh;height:var(--app-height,100dvh);max-height:none;box-shadow:none;border:none;border-radius:0}.login-card{padding-left:18px;padding-right:18px;padding-bottom:max(14px, env(safe-area-inset-bottom));justify-content:space-between;gap:10px}.login-hero{padding-top:max(24px, calc(env(safe-area-inset-top) + 18px));padding-bottom:10px}.login-app-icon{border-radius:18px;width:58px;height:58px;font-size:25px}.login-kicker{margin-top:20px}.login-card h1{font-size:38px}.login-card p{font-size:14px;line-height:1.45}.login-preview{gap:9px;min-height:98px;padding:4px 0 8px}.login-card button,.login-card input{height:52px;min-height:52px}.login-footnote{margin-top:10px}.home-guide-overlay{padding:10px;padding-bottom:max(10px, env(safe-area-inset-bottom))}.home-guide-card{border-radius:22px;width:100%}}@media (width<=520px) and (height<=720px){.login-card{padding-top:max(14px, env(safe-area-inset-top));padding-bottom:max(10px, env(safe-area-inset-bottom));gap:8px}.login-hero{padding-top:8px;padding-bottom:6px}.login-app-icon{border-radius:16px;width:50px;height:50px;font-size:22px}.login-kicker{margin-top:14px;font-size:11px}.login-card h1{margin-top:8px;font-size:34px}.login-card p{margin-top:8px;font-size:13px;line-height:1.4}.login-preview{gap:7px;min-height:72px;padding:0 0 4px}.preview-avatar{width:30px;height:30px;font-size:12px}.preview-bubble{padding:9px 12px;font-size:14px}.invite-panel{padding:10px}.invite-note{margin-top:7px;font-size:12px;line-height:1.35}.login-card button,.login-card input{border-radius:15px;height:48px;min-height:48px;font-size:15px}.login-footnote{margin-top:8px;font-size:11px}.home-guide-card{padding:13px}.home-guide-title{margin-top:10px;font-size:21px}.home-guide-copy{margin-top:7px;font-size:13px;line-height:1.42}.home-guide-steps{gap:7px;margin-top:10px}.home-guide-step{min-height:40px;padding:8px 10px;font-size:13px}.home-guide-primary{min-height:44px;margin-top:10px}}@media (width<=520px) and (height<=620px){.login-preview{display:none}.login-card{justify-content:center}}@media (width<=370px){.login-card h1{font-size:35px}.input-area{grid-template-columns:38px 38px minmax(0,1fr) auto;gap:6px}.attach-btn,.sticker-toggle-btn{width:38px;height:38px}.send-btn{min-width:52px;height:38px;padding:0 11px;font-size:13px}.message-content,.message-file{font-size:15px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important}}
