:root{--bg: #0f1219;--surface: #171b26;--surface2: #1e2433;--border: #2a3142;--text: #e8eaef;--muted: #8b93a7;--accent: #6c8cff;--accent-dim: #4a5fbf;--danger: #f07178;--ok: #7fd99a;--radius: 12px;--bg-glow: #1a2240;--top-bar-bg: rgba(15, 18, 25, .85);--shadow-card: 0 24px 48px rgba(0, 0, 0, .35);--avatar-accent-2: #9b7fd9;--bubble-mine-bg: rgba(108, 140, 255, .2);--bubble-mine-border: rgba(108, 140, 255, .35);--composer-attach-hover-bg: rgba(108, 140, 255, .12);--file-attachment-bg: rgba(0, 0, 0, .2);--user-row-active-bg: rgba(108, 140, 255, .15);--user-row-active-outline: rgba(108, 140, 255, .35);--unread-fg: #0f1219;font-family:DM Sans,system-ui,sans-serif;line-height:1.5;color:var(--text);background:var(--bg)}html[data-theme=light]{--bg: #eef0f5;--surface: #ffffff;--surface2: #e8ebf2;--border: #c5ccd8;--text: #141820;--muted: #5c6578;--accent: #4661e6;--accent-dim: #3548b8;--danger: #c42d3e;--ok: #1d7a4a;--bg-glow: #c5d4f7;--top-bar-bg: rgba(255, 255, 255, .88);--shadow-card: 0 24px 48px rgba(15, 22, 40, .1);--avatar-accent-2: #7c6ae6;--bubble-mine-bg: rgba(70, 97, 230, .2);--bubble-mine-border: rgba(70, 97, 230, .38);--composer-attach-hover-bg: rgba(70, 97, 230, .14);--file-attachment-bg: rgba(0, 0, 0, .06);--user-row-active-bg: rgba(70, 97, 230, .14);--user-row-active-outline: rgba(70, 97, 230, .4);--unread-fg: #f8f9fc}html[data-theme=ocean]{--bg: #061018;--surface: #0c1822;--surface2: #122530;--border: #1e3a4a;--text: #e4eef2;--muted: #7a9bab;--accent: #2dd4bf;--accent-dim: #0d9488;--danger: #fb7185;--ok: #4ade80;--bg-glow: #0d3d4d;--top-bar-bg: rgba(6, 16, 24, .9);--shadow-card: 0 24px 48px rgba(0, 0, 0, .45);--avatar-accent-2: #38bdf8;--bubble-mine-bg: rgba(45, 212, 191, .18);--bubble-mine-border: rgba(45, 212, 191, .38);--composer-attach-hover-bg: rgba(45, 212, 191, .14);--file-attachment-bg: rgba(0, 0, 0, .28);--user-row-active-bg: rgba(45, 212, 191, .14);--user-row-active-outline: rgba(45, 212, 191, .4);--unread-fg: #061018}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;min-height:100dvh;background:radial-gradient(1200px 600px at 10% -10%,var(--bg-glow) 0%,transparent 50%),var(--bg)}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.auth-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:max(24px,env(safe-area-inset-top,0px)) max(24px,env(safe-area-inset-right,0px)) max(24px,env(safe-area-inset-bottom,0px)) max(24px,env(safe-area-inset-left,0px))}.auth-card,.profile-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 28px 24px;box-shadow:var(--shadow-card)}.profile-card{max-width:520px;margin:24px auto}h1{margin:0 0 8px;font-size:1.5rem;font-weight:700}h2{margin:0;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.muted{color:var(--muted)}.muted.small{font-size:.875rem}.form{display:flex;flex-direction:column;gap:14px;margin-top:20px}.form label{display:flex;flex-direction:column;gap:6px;font-size:.875rem;font-weight:500;min-width:0}.profile-page-scroll .form input:not([type=file]){min-width:0;width:100%;max-width:100%}input:not([type=file]){padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font:inherit}input:focus{outline:2px solid var(--accent);outline-offset:0}.btn{font:inherit;cursor:pointer;border-radius:8px;border:1px solid var(--border);padding:10px 16px;background:var(--surface2);color:var(--text)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-dim));border-color:transparent;font-weight:600}.btn.secondary{display:inline-flex;align-items:center;justify-content:center;width:fit-content}.btn.ghost{background:transparent;border-color:transparent;color:var(--muted)}.btn.ghost:hover{color:var(--text)}.alert{padding:10px 12px;border-radius:8px;font-size:.875rem}.alert.error{background:#f071781f;color:var(--danger);border:1px solid rgba(240,113,120,.35)}.alert.ok{background:#7fd99a1f;color:var(--ok);border:1px solid rgba(127,217,154,.35)}.alert.tight{margin-bottom:8px}.app-shell{flex:1;min-height:0;height:100vh;max-height:100vh;height:100dvh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.app-shell.narrow{flex:1;min-height:0;height:100vh;max-height:100vh;height:100dvh;max-height:100dvh;overflow:hidden;width:100%;max-width:100%;box-sizing:border-box}.app-shell.narrow .top-bar{max-width:640px;margin:0 auto;width:100%}.app-shell.narrow .top-bar.profile-top-bar{display:grid;grid-template-columns:minmax(44px,auto) 1fr minmax(44px,auto);align-items:center;gap:8px;max-width:none;width:100%;margin:0;flex-shrink:0;padding-left:max(12px,env(safe-area-inset-left,0px));padding-right:max(12px,env(safe-area-inset-right,0px));padding-top:max(12px,env(safe-area-inset-top,0px))}.profile-top-bar .brand{justify-self:center;text-align:center;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-top-bar .top-bar-icon-btn{justify-self:end}.top-bar-back-link{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:44px;min-height:44px;padding:8px 10px;margin:-6px 0 -6px -8px;text-decoration:none;color:var(--muted)}.top-bar-back-link:hover{color:var(--text);text-decoration:none}.profile-page-scroll{flex:1 1 0;min-height:0;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;padding:16px max(16px,env(safe-area-inset-left,0px)) max(24px,env(safe-area-inset-bottom,0px)) max(16px,env(safe-area-inset-right,0px))}.profile-page-scroll .profile-card{margin:0 auto 24px;width:100%;max-width:520px;overflow-wrap:anywhere}.top-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--top-bar-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;z-index:100}.top-bar-start{display:flex;align-items:center;gap:4px;min-width:0}.hamburger-btn{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:8px;margin:-6px 0 -6px -8px;color:var(--text)}.top-bar-icon-btn{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:8px;margin:-6px 0;color:var(--muted);text-decoration:none}.top-bar-icon-btn:hover{color:var(--text);text-decoration:none}.brand{font-weight:700;letter-spacing:-.02em}.top-actions{display:flex;align-items:center;gap:12px}.socket-banner{padding:10px 20px;font-size:.85rem;color:#f0d9a8;background:#f0b4501f;border-bottom:1px solid rgba(240,180,80,.35);position:relative;z-index:100}.chat-layout{flex:1;min-height:0;display:grid;grid-template-columns:280px 1fr;overflow:hidden}.sidebar{border-right:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;min-height:0;overflow:hidden}.sidebar-title{padding:16px 16px 8px}.sidebar-drawer-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 8px 0 12px;flex-shrink:0}.sidebar-drawer-head .sidebar-title{padding:8px 0;margin:0}.drawer-close-btn{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:8px;flex-shrink:0;color:var(--muted)}.drawer-close-btn:hover{color:var(--text)}.pad{padding:16px}.user-list{list-style:none;margin:0;padding:8px;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.user-row{width:100%;display:flex;align-items:center;gap:10px;padding:10px;border:none;border-radius:10px;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer}.user-row:hover{background:var(--surface2)}.user-row.active{background:var(--user-row-active-bg);outline:1px solid var(--user-row-active-outline)}.unread-badge{flex-shrink:0;min-width:1.35rem;height:1.35rem;padding:0 6px;border-radius:999px;background:var(--accent);color:var(--unread-fg);font-size:.7rem;font-weight:700;line-height:1.35rem;text-align:center}.msg-block{display:flex;flex-direction:column;gap:6px}.msg-day-sep{text-align:center;font-size:.75rem;font-weight:600;color:var(--muted);padding:14px 12px 6px}.user-meta{display:flex;flex-direction:column;min-width:0}.user-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.avatar-fallback{border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--avatar-accent-2));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.avatar-fallback.large{width:96px;height:96px;font-size:2rem}.thread{display:flex;flex-direction:column;min-height:0;overflow:hidden;background:var(--bg)}.thread-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.empty-thread{flex:1;display:flex;align-items:center;justify-content:center;color:var(--muted);padding:24px}.empty-thread-msg{margin:0;text-align:center;max-width:18rem;line-height:1.45}.thread-header{flex-shrink:0;display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);background:var(--surface);min-width:0}.thread-header-text{min-width:0;flex:1}.thread-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.messages{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:12px 20px 20px;overscroll-behavior:contain}.messages-stack{display:flex;flex-direction:column;gap:10px;min-height:min-content}.load-older-wrap{display:flex;justify-content:center;padding:8px 0 16px;flex-shrink:0}.btn.load-older{font-size:.8rem;padding:8px 16px;border-radius:999px;background:var(--surface2);border:1px solid var(--border);color:var(--accent);cursor:pointer}.btn.load-older:disabled{opacity:.5;cursor:not-allowed}.bubble-row{display:flex;justify-content:flex-start}.bubble-row.mine{justify-content:flex-end}.bubble{max-width:min(72%,420px);padding:10px 14px;border-radius:14px;background:var(--surface);border:1px solid var(--border)}.bubble-row.mine .bubble{background:var(--bubble-mine-bg);border-color:var(--bubble-mine-border)}.bubble p{margin:0 0 6px;white-space:pre-wrap;word-break:break-word}.msg-image{max-width:100%;border-radius:8px;display:block;margin-top:4px}.msg-time{font-size:.7rem;color:var(--muted)}.composer{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:14px 20px;border-top:1px solid var(--border);background:var(--surface)}.composer-input{flex:1}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.composer-attach{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;flex-shrink:0;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--accent);cursor:pointer;transition:background .15s ease,color .15s ease}.composer-attach:hover{background:var(--composer-attach-hover-bg);color:var(--text)}.composer-attach:has(input:disabled){opacity:.45;cursor:not-allowed}.composer-attach-inner{display:flex;align-items:center;justify-content:center;line-height:1}.composer-attach-spin{font-size:1.25rem;color:var(--muted);animation:pulse .8s ease-in-out infinite}@keyframes pulse{50%{opacity:.35}}.file-attachment{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:6px;padding:8px 10px;border-radius:10px;background:var(--file-attachment-bg);border:1px solid var(--border);max-width:100%}.file-attachment-name{font-size:.875rem;font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn.file-attach-btn{padding:6px 12px;font-size:.8rem}.profile-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.avatar-preview-row{display:flex;align-items:center;gap:16px;margin-bottom:8px;min-width:0}.row{display:flex;gap:10px;flex-wrap:wrap}.theme-picker{border:none;margin:0;padding:0}.theme-picker legend{margin-bottom:8px;font-size:.875rem;font-weight:500;color:var(--text)}.theme-options{display:flex;flex-wrap:wrap;gap:10px}.theme-option{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);cursor:pointer;font-size:.875rem;font-weight:500;-webkit-user-select:none;user-select:none;color:var(--text)}.theme-option:has(input:focus-visible){outline:2px solid var(--accent);outline-offset:2px}.theme-option:has(input:checked){border-color:var(--accent);background:var(--user-row-active-bg)}.theme-option input{margin:0;accent-color:var(--accent)}.mobile-people-backdrop{display:none}@media (max-width: 720px){.chat-layout{display:flex;flex-direction:column;grid-template-columns:unset;grid-template-rows:unset;position:relative}.chat-layout.mobile .thread{flex:1;min-height:0}.mobile-people-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#0000007a;animation:backdrop-in .2s ease}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.chat-layout.mobile .sidebar{position:fixed;left:0;top:0;bottom:0;width:min(300px,88vw);max-width:320px;z-index:90;border-right:1px solid var(--border);box-shadow:8px 0 36px #00000073;transform:translate(-100%);transition:transform .22s ease;padding-top:max(env(safe-area-inset-top,0px),8px);padding-bottom:env(safe-area-inset-bottom,0px);pointer-events:none}.chat-layout.mobile.drawer-open .sidebar{transform:translate(0);pointer-events:auto}.top-bar{padding-top:max(12px,env(safe-area-inset-top,0px));padding-left:max(12px,env(safe-area-inset-left,0px));padding-right:max(16px,env(safe-area-inset-right,0px))}.socket-banner{padding-left:max(20px,env(safe-area-inset-left,0px));padding-right:max(20px,env(safe-area-inset-right,0px))}.sidebar{border-right:none}.thread-header{padding-left:max(14px,env(safe-area-inset-left,0px));padding-right:max(14px,env(safe-area-inset-right,0px));padding-top:12px}.messages{padding-left:max(12px,env(safe-area-inset-left,0px));padding-right:max(12px,env(safe-area-inset-right,0px))}.composer{padding-left:max(14px,env(safe-area-inset-left,0px));padding-right:max(14px,env(safe-area-inset-right,0px));padding-bottom:max(14px,env(safe-area-inset-bottom,0px));gap:8px}.bubble{max-width:min(88%,100%)}.user-row{min-height:44px}input:not([type=file]),textarea{font-size:16px}.avatar-preview-row{flex-direction:column;align-items:flex-start;gap:12px}}@media (max-width: 520px){.top-bar-me,.thread-header-email{display:none}.auth-card,.profile-card{padding:22px 18px 20px}.top-bar-back-label{display:none}.top-bar-back-link{margin-left:-8px}}
