@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Manrope:wght@500;600;700;800&display=swap";.reactEasyCrop_Container{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:none;cursor:move;display:flex;justify-content:center;align-items:center}.reactEasyCrop_Image,.reactEasyCrop_Video{will-change:transform}.reactEasyCrop_Contain{max-width:100%;max-height:100%;margin:auto;position:absolute;top:0;bottom:0;left:0;right:0}.reactEasyCrop_Cover_Horizontal{width:100%;height:auto}.reactEasyCrop_Cover_Vertical{width:auto;height:100%}.reactEasyCrop_CropArea{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border:1px solid rgba(255,255,255,.5);box-sizing:border-box;box-shadow:0 0 0 9999em;color:#00000080;overflow:hidden}.reactEasyCrop_CropAreaRound{border-radius:50%}.reactEasyCrop_CropAreaGrid:before{content:" ";box-sizing:border-box;position:absolute;border:1px solid rgba(255,255,255,.5);top:0;bottom:0;left:33.33%;right:33.33%;border-top:0;border-bottom:0}.reactEasyCrop_CropAreaGrid:after{content:" ";box-sizing:border-box;position:absolute;border:1px solid rgba(255,255,255,.5);top:33.33%;bottom:33.33%;left:0;right:0;border-left:0;border-right:0}.admin-shell{height:var(--app-shell-height);display:grid;grid-template-columns:260px 1fr;gap:0}.admin-sidebar{border-right:var(--border-thin);background:#ffffffeb;padding:var(--space-4);display:grid;grid-template-rows:auto 1fr auto;gap:var(--space-4)}.admin-brand{display:grid;gap:6px}.admin-brand-title{font-family:var(--font-brand);font-weight:800;letter-spacing:-.02em;margin:0}.admin-brand-subtitle{margin:0;color:var(--color-text-muted);font-size:var(--text-sm)}.admin-nav{display:grid;gap:6px}.admin-nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid transparent;color:var(--color-text-secondary);background:transparent}.admin-nav a:hover{background:#f7fcff;border-color:var(--color-border)}.admin-nav a.admin-nav-active{color:var(--color-text-primary);background:#30bbc01a;border-color:#30bbc040}.admin-main{min-width:0;overflow:auto;padding:var(--space-6)}.admin-page{max-width:1100px;margin:0 auto;display:grid;gap:var(--space-4)}.admin-page-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3)}.admin-page-title{margin:0}.admin-card{background:#ffffffeb;border:var(--border-thin);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:var(--space-4)}.admin-grid{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.admin-metric-title{margin:0;color:var(--color-text-muted);font-size:var(--text-sm);font-weight:600}.admin-metric-value{margin:6px 0 0;font-family:var(--font-brand);font-size:var(--text-2xl);font-weight:800;letter-spacing:-.02em}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{text-align:left;padding:10px 12px;border-bottom:var(--border-thin);vertical-align:top;font-size:var(--text-sm)}.admin-table th{color:var(--color-text-muted);font-weight:700}.admin-row-clickable{cursor:pointer}.admin-row-clickable:hover td{background:#f7fcff}@media(max-width:980px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{border-right:none;border-bottom:var(--border-thin);grid-template-rows:auto auto auto}.admin-main{padding:var(--space-4)}}:root{--hampo-mint-100: #cff6ec;--hampo-aqua-200: #8fe4d8;--hampo-teal-500: #30bbc0;--hampo-teal-600: #1faab9;--hampo-blue-600: #1070ab;--hampo-ocean-800: #195166;--hampo-surface-50: #f7fbfc;--hampo-night-950: #0c1b24;--hampo-theme-canvas: #f3f9fb;--hampo-theme-surface: #ffffff;--hampo-theme-surface-soft: #edf6f9;--hampo-theme-surface-elevated: #ffffff;--hampo-theme-surface-brand: #e5f7f3;--hampo-theme-text-primary: #163745;--hampo-theme-text-secondary: #3a606f;--hampo-theme-text-muted: #64818d;--hampo-theme-text-on-primary: #ffffff;--hampo-theme-border: #cfe1e8;--hampo-theme-border-strong: #b9d1da;--hampo-theme-primary: var(--hampo-teal-500);--hampo-theme-primary-hover: var(--hampo-teal-600);--hampo-theme-secondary: var(--hampo-blue-600);--hampo-theme-secondary-hover: #0d6297;--hampo-theme-ghost: #eff6fa;--hampo-theme-ghost-hover: #e6f1f6;--hampo-theme-success: #1f8f66;--hampo-theme-warning: #936d28;--hampo-theme-danger: #c85369;--hampo-theme-info: #2d7eaa;--hampo-theme-overlay-scrim: rgba(7, 20, 27, .3);--hampo-theme-overlay-panel: rgba(255, 255, 255, .94);--color-bg: var(--hampo-theme-canvas);--color-canvas: var(--color-bg);--color-surface: var(--hampo-theme-surface);--color-surface-soft: var(--hampo-theme-surface-soft);--color-surface-elevated: var(--hampo-theme-surface-elevated);--color-surface-brand: var(--hampo-theme-surface-brand);--color-text-primary: var(--hampo-theme-text-primary);--color-text-secondary: var(--hampo-theme-text-secondary);--color-text-muted: var(--hampo-theme-text-muted);--color-text-on-primary: var(--hampo-theme-text-on-primary);--color-border: var(--hampo-theme-border);--color-border-strong: var(--hampo-theme-border-strong);--color-primary: var(--hampo-theme-primary);--color-primary-hover: var(--hampo-theme-primary-hover);--color-secondary: var(--hampo-theme-secondary);--color-secondary-hover: var(--hampo-theme-secondary-hover);--color-ghost: var(--hampo-theme-ghost);--color-ghost-hover: var(--hampo-theme-ghost-hover);--color-success: var(--hampo-theme-success);--color-warning: var(--hampo-theme-warning);--color-danger: var(--hampo-theme-danger);--color-info: var(--hampo-theme-info);--color-success-surface: #eef9f4;--color-success-border: #9edbc5;--color-warning-surface: #fff8ec;--color-warning-border: #e8d09d;--color-danger-surface: #fff4f6;--color-danger-border: #e9b8c3;--color-info-surface: #eef6fb;--color-info-border: #abcce2;--color-overlay-scrim: var(--hampo-theme-overlay-scrim);--color-overlay-panel: var(--hampo-theme-overlay-panel);--message-incoming-surface: rgba(255, 255, 255, .94);--message-incoming-border: rgba(188, 214, 223, .92);--message-incoming-text: #143646;--message-incoming-meta: rgba(20, 54, 70, .62);--message-outgoing-surface: linear-gradient( 180deg, rgba(213, 246, 238, .96), rgba(244, 251, 252, .95) );--message-outgoing-border: rgba(122, 193, 192, .9);--message-outgoing-text: #103746;--message-outgoing-meta: rgba(16, 55, 70, .64);--reaction-pill-surface: rgba(255, 255, 255, .96);--reaction-pill-border: rgba(196, 216, 225, .92);--reaction-pill-text: rgba(16, 55, 70, .84);--reaction-pill-mine-surface: rgba(231, 249, 247, .98);--reaction-pill-mine-border: rgba(73, 183, 187, .44);--sheet-surface: rgba(255, 255, 255, .98);--menu-surface: rgba(255, 255, 255, .97);--toast-surface: rgba(255, 255, 255, .96);--app-bg-radial-a: rgba(143, 228, 216, .2);--app-bg-radial-b: rgba(48, 187, 192, .12);--app-bg-gradient-start: #fcfeff}html[data-theme=dark]{--hampo-theme-canvas: #0c1b24;--hampo-theme-surface: #122734;--hampo-theme-surface-soft: #182d3a;--hampo-theme-surface-elevated: #1a3240;--hampo-theme-surface-brand: #1c3942;--hampo-theme-text-primary: #e3f0f4;--hampo-theme-text-secondary: #b6cad1;--hampo-theme-text-muted: #8da7b1;--hampo-theme-text-on-primary: #062028;--hampo-theme-border: #2b4755;--hampo-theme-border-strong: #3a5f6f;--hampo-theme-primary: #45c4c9;--hampo-theme-primary-hover: #57cfd4;--hampo-theme-secondary: #6aaecf;--hampo-theme-secondary-hover: #7bc1de;--hampo-theme-ghost: #1b3441;--hampo-theme-ghost-hover: #244250;--hampo-theme-success: #63d3a9;--hampo-theme-warning: #d6b06b;--hampo-theme-danger: #e48d9a;--hampo-theme-info: #69b7dd;--hampo-theme-overlay-scrim: rgba(2, 8, 11, .62);--hampo-theme-overlay-panel: rgba(20, 42, 53, .95);--color-bg: var(--hampo-theme-canvas);--color-canvas: var(--color-bg);--color-surface: var(--hampo-theme-surface);--color-surface-soft: var(--hampo-theme-surface-soft);--color-surface-elevated: var(--hampo-theme-surface-elevated);--color-surface-brand: var(--hampo-theme-surface-brand);--color-text-primary: var(--hampo-theme-text-primary);--color-text-secondary: var(--hampo-theme-text-secondary);--color-text-muted: var(--hampo-theme-text-muted);--color-text-on-primary: var(--hampo-theme-text-on-primary);--color-border: var(--hampo-theme-border);--color-border-strong: var(--hampo-theme-border-strong);--color-primary: var(--hampo-theme-primary);--color-primary-hover: var(--hampo-theme-primary-hover);--color-secondary: var(--hampo-theme-secondary);--color-secondary-hover: var(--hampo-theme-secondary-hover);--color-ghost: var(--hampo-theme-ghost);--color-ghost-hover: var(--hampo-theme-ghost-hover);--color-success: var(--hampo-theme-success);--color-warning: var(--hampo-theme-warning);--color-danger: var(--hampo-theme-danger);--color-info: var(--hampo-theme-info);--color-success-surface: rgba(28, 66, 55, .7);--color-success-border: rgba(80, 163, 133, .74);--color-warning-surface: rgba(74, 58, 31, .72);--color-warning-border: rgba(158, 126, 70, .78);--color-danger-surface: rgba(74, 39, 49, .74);--color-danger-border: rgba(166, 98, 112, .82);--color-info-surface: rgba(29, 54, 69, .74);--color-info-border: rgba(89, 138, 167, .8);--color-overlay-scrim: var(--hampo-theme-overlay-scrim);--color-overlay-panel: var(--hampo-theme-overlay-panel);--message-incoming-surface: rgba(22, 42, 54, .96);--message-incoming-border: rgba(58, 90, 106, .92);--message-incoming-text: #ddebf1;--message-incoming-meta: rgba(190, 208, 218, .72);--message-outgoing-surface: linear-gradient( 180deg, rgba(33, 70, 82, .97), rgba(27, 54, 66, .97) );--message-outgoing-border: rgba(67, 138, 149, .92);--message-outgoing-text: #e7f6fa;--message-outgoing-meta: rgba(191, 214, 222, .78);--reaction-pill-surface: rgba(22, 41, 53, .98);--reaction-pill-border: rgba(62, 97, 113, .92);--reaction-pill-text: rgba(214, 230, 237, .88);--reaction-pill-mine-surface: rgba(31, 74, 82, .96);--reaction-pill-mine-border: rgba(73, 151, 156, .76);--sheet-surface: rgba(20, 43, 54, .98);--menu-surface: rgba(19, 40, 51, .97);--toast-surface: rgba(20, 44, 56, .97);--app-bg-radial-a: rgba(56, 133, 145, .28);--app-bg-radial-b: rgba(39, 122, 157, .18);--app-bg-gradient-start: #0f212c}:root{--font-brand: "Manrope", "Onest", "Inter", "Segoe UI", sans-serif;--font-ui: "Inter", "Onest", "Segoe UI", sans-serif;--text-xs: 12px;--text-sm: 13px;--text-md: 14px;--text-base: 15px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 28px;--leading-tight: 1.2;--leading-normal: 1.45;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--radius-xs: 8px;--radius-sm: 12px;--radius-md: 16px;--radius-lg: 20px;--radius-xl: 24px;--radius-pill: 999px;--border-thin: 1px solid var(--color-border);--border-strong: 1px solid var(--color-border-strong);--shadow-xs: 0 2px 10px rgba(11, 34, 45, .08);--shadow-sm: 0 10px 26px rgba(11, 34, 45, .12);--shadow-md: 0 18px 36px rgba(11, 34, 45, .16);--state-disabled-opacity: .55;--focus-ring: 0 0 0 3px rgba(48, 187, 192, .24);--transition-fast: .12s ease;--transition-normal: .18s ease;--app-shell-surface: rgba(255, 255, 255, .78);--app-shell-surface-strong: rgba(255, 255, 255, .9);--input-disabled-bg: #f0f7f9;--button-primary-start: #35c8cb;--button-primary-end: var(--color-primary);--button-primary-hover-start: #2fc3c8;--button-primary-hover-end: var(--color-primary-hover);--button-primary-shadow: 0 8px 16px rgba(48, 187, 192, .24);--button-secondary-bg: var(--color-surface-elevated);--button-secondary-hover-bg: var(--color-ghost);--button-secondary-hover-border: var(--color-border-strong);--search-clear-bg: #eaf5f8;--search-clear-hover-bg: #dff0f5;--search-clear-hover-color: var(--color-secondary-hover);--list-item-bg: rgba(255, 255, 255, .82);--list-item-hover-bg: rgba(255, 255, 255, .96);--list-item-active-bg: #f4fbfd;--list-item-border: rgba(200, 223, 231, .78);--list-item-border-hover: rgba(163, 204, 218, .9);--list-item-selected-bg: linear-gradient( 180deg, rgba(219, 248, 241, .74), rgba(248, 252, 253, .96) );--panel-neutral-bg: rgba(247, 252, 253, .9);--panel-neutral-strong-bg: rgba(255, 255, 255, .96);--chat-scrollbar-thumb: rgba(25, 81, 102, .22);--status-connected-bg: var(--color-success-surface);--status-connected-border: var(--color-success-border);--status-connected-text: #0f7552;--status-warning-bg: var(--color-warning-surface);--status-warning-border: var(--color-warning-border);--status-warning-text: #7f6532;--status-danger-bg: var(--color-danger-surface);--status-danger-border: var(--color-danger-border);--status-danger-text: #9a4452}html[data-theme=dark]{--shadow-xs: 0 2px 10px rgba(2, 8, 11, .26);--shadow-sm: 0 12px 30px rgba(2, 8, 11, .34);--shadow-md: 0 20px 40px rgba(2, 8, 11, .46);--focus-ring: 0 0 0 3px rgba(69, 196, 201, .34);--app-shell-surface: rgba(18, 39, 52, .78);--app-shell-surface-strong: rgba(22, 45, 58, .9);--input-disabled-bg: rgba(23, 45, 58, .9);--button-primary-start: #46c6cb;--button-primary-end: var(--color-primary);--button-primary-hover-start: #5ad2d6;--button-primary-hover-end: var(--color-primary-hover);--button-primary-shadow: 0 10px 22px rgba(39, 154, 170, .34);--button-secondary-bg: var(--color-surface-soft);--button-secondary-hover-bg: var(--color-ghost-hover);--button-secondary-hover-border: var(--color-border-strong);--search-clear-bg: rgba(35, 66, 80, .86);--search-clear-hover-bg: rgba(44, 79, 95, .9);--search-clear-hover-color: #96cee7;--list-item-bg: rgba(21, 45, 58, .82);--list-item-hover-bg: rgba(25, 52, 66, .94);--list-item-active-bg: rgba(28, 58, 72, .92);--list-item-border: rgba(53, 83, 99, .86);--list-item-border-hover: rgba(78, 116, 134, .9);--list-item-selected-bg: linear-gradient( 180deg, rgba(30, 75, 87, .95), rgba(24, 54, 68, .96) );--panel-neutral-bg: rgba(24, 47, 59, .92);--panel-neutral-strong-bg: rgba(20, 44, 56, .97);--chat-scrollbar-thumb: rgba(120, 164, 183, .28);--status-connected-bg: rgba(26, 70, 57, .72);--status-connected-border: rgba(81, 161, 133, .78);--status-connected-text: #7ce0bd;--status-warning-bg: rgba(78, 60, 32, .74);--status-warning-border: rgba(166, 132, 73, .82);--status-warning-text: #e6c17c;--status-danger-bg: rgba(77, 40, 50, .76);--status-danger-border: rgba(169, 99, 115, .84);--status-danger-text: #f0a9b7}html,body{font-family:var(--font-ui);font-size:var(--text-base);line-height:var(--leading-normal)}h1,h2,h3,.brand-text{font-family:var(--font-brand);letter-spacing:-.015em}strong{font-weight:600}input,button,textarea{font-family:var(--font-ui)}*{box-sizing:border-box}:root{--app-shell-height: 100vh}@supports (height: 100svh){:root{--app-shell-height: 100svh}}@supports (height: 100dvh){:root{--app-shell-height: 100dvh}}html,body,#root{width:100%;height:100%;max-width:100%}html.messenger-shell-lock,body.messenger-shell-lock{overflow:hidden;overscroll-behavior:none}body{margin:0;color:var(--color-text-primary);overflow-x:hidden;background:radial-gradient(1200px 520px at -10% -10%,var(--app-bg-radial-a),transparent 66%),radial-gradient(980px 420px at 110% 0%,var(--app-bg-radial-b),transparent 62%),linear-gradient(180deg,var(--app-bg-gradient-start) 0%,var(--color-bg) 100%)}#root{min-width:0}a{color:var(--color-secondary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-secondary-hover)}button,input,textarea{font:inherit}input:not([type=checkbox]):not([type=radio]):not([type=range]),textarea{width:100%;border:var(--border-thin);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-primary);padding:11px 13px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}input:not([type=checkbox]):not([type=radio]):not([type=range])::placeholder,textarea::placeholder{color:var(--color-text-muted)}input:not([type=checkbox]):not([type=radio]):not([type=range]):focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--focus-ring)}input:not([type=checkbox]):not([type=radio]):not([type=range]):disabled,textarea:disabled{background:var(--input-disabled-bg);color:var(--color-text-muted)}.primary-button,.secondary-button{border-radius:var(--radius-sm);border:1px solid transparent;padding:10px 13px;font-weight:600;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.primary-button:hover,.secondary-button:hover{transform:translateY(-1px)}.primary-button:focus-visible,.secondary-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.primary-button:disabled,.secondary-button:disabled{opacity:var(--state-disabled-opacity);cursor:not-allowed;transform:none;box-shadow:none}.primary-button{color:var(--color-text-on-primary);background:linear-gradient(180deg,var(--button-primary-start) 0%,var(--button-primary-end) 100%);box-shadow:var(--button-primary-shadow)}.primary-button:hover{background:linear-gradient(180deg,var(--button-primary-hover-start) 0%,var(--button-primary-hover-end) 100%)}.secondary-button{color:var(--color-secondary);background:var(--button-secondary-bg);border-color:var(--color-border)}.secondary-button:hover{border-color:var(--button-secondary-hover-border);background:var(--button-secondary-hover-bg)}.small-button{padding:6px 10px;font-size:var(--text-xs);border-radius:var(--radius-xs)}.user-avatar{border-radius:var(--radius-sm);border:var(--border-thin);display:inline-grid;place-items:center;overflow:hidden;flex-shrink:0;-webkit-user-select:none;user-select:none}.user-avatar-image{width:100%;height:100%;object-fit:cover;display:block}.user-avatar-fallback{font-family:var(--font-brand);font-size:inherit;font-weight:700;letter-spacing:.01em}.stack-md{display:grid;gap:var(--space-3)}.muted{margin:0;color:var(--color-text-muted);font-size:var(--text-md)}.error-text{margin:0;color:var(--color-danger);font-size:var(--text-md)}.success-text{margin:0;color:var(--color-success);font-size:var(--text-md)}.field-label{margin:0;color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:600}.auth-shell,.page-state{min-height:100vh;display:grid;place-items:center;padding:var(--space-6)}.auth-card,.page-state-card{width:min(480px,100%);background:var(--app-shell-surface-strong);border:var(--border-thin);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-6);animation:rise-in .3s ease}.page-state-card.is-brand-loading{width:min(340px,100%);text-align:center;display:grid;justify-items:center;gap:var(--space-2);padding:var(--space-5)}.page-state-brand-loader{width:100%;display:grid;place-items:center;margin-bottom:var(--space-1)}.page-state-brand-loader-mark{width:68px;height:68px;border-radius:20px;border:1px solid var(--color-border-strong);background:linear-gradient(160deg,var(--color-surface-elevated),var(--color-surface-soft));box-shadow:inset 0 0 0 1px #ffffff42,0 10px 22px #0f4c5f38;display:grid;place-items:center;position:relative;animation:page-state-brand-loader-breathe 1.8s ease-in-out infinite}.page-state-brand-loader-mark:before{content:"";position:absolute;top:-5px;right:-5px;bottom:-5px;left:-5px;border-radius:inherit;border:1px solid rgba(97,171,184,.42);opacity:0;animation:page-state-brand-loader-ring 1.8s ease-out infinite}.page-state-brand-loader-logo{width:36px;height:36px;object-fit:contain}.page-state-card.is-brand-loading h2{margin:0;font-size:var(--text-xl);font-family:var(--font-brand)}.page-state-card.is-brand-loading p{margin:0;font-size:var(--text-sm);color:var(--color-text-muted)}.page-state-card.is-conversation-loading{width:min(560px,100%);display:grid;gap:var(--space-3);text-align:left;padding:var(--space-5)}.page-state-conversation-skeleton{display:grid;gap:8px}.page-state-conversation-line{height:10px;border-radius:var(--radius-pill);background:linear-gradient(90deg,#9dbbc63d,#c1dae370,#9dbbc63d);background-size:200% 100%;animation:sidebar-skeleton-shimmer 1.6s linear infinite}.page-state-conversation-line.long{width:min(92%,420px)}.page-state-conversation-line.medium{width:min(76%,340px)}.page-state-conversation-line.short{width:min(64%,280px)}.page-state-conversation-bubbles{margin-top:4px;display:grid;gap:8px}.page-state-conversation-bubble{height:40px;border-radius:14px;background:linear-gradient(90deg,#98b7c440,#bcd6e16b,#98b7c440);background-size:200% 100%;animation:sidebar-skeleton-shimmer 1.6s linear infinite}.page-state-conversation-bubble.incoming{width:min(72%,360px)}.page-state-conversation-bubble.outgoing{justify-self:end;width:min(58%,292px)}.page-state-conversation-bubble.incoming.short{width:min(44%,210px)}.page-state-card.is-conversation-loading h2{margin:0;font-size:var(--text-lg)}.page-state-card.is-conversation-loading p{margin:0;font-size:var(--text-sm);color:var(--color-text-muted)}@keyframes page-state-brand-loader-breathe{0%,to{transform:scale(1)}50%{transform:scale(.975)}}@keyframes page-state-brand-loader-ring{0%{opacity:0;transform:scale(.98)}30%{opacity:.45}to{opacity:0;transform:scale(1.08)}}.auth-brand{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.auth-brand-mark{width:48px;height:48px;border-radius:var(--radius-md);background:linear-gradient(135deg,#cff6ece6,#8fe4d8b3);border:var(--border-thin);display:grid;place-items:center;box-shadow:var(--shadow-xs)}.auth-logo{width:28px;height:28px;object-fit:contain}.auth-brand-kicker{margin:0;color:var(--color-secondary);font-family:var(--font-brand);font-size:var(--text-sm);font-weight:700;line-height:1.2}.auth-brand-note{margin:0;color:var(--color-text-muted);font-size:var(--text-sm)}.auth-title,.page-state-card h2{margin:0;color:var(--color-text-primary);font-size:var(--text-2xl);line-height:var(--leading-tight)}.auth-subtitle,.page-state-card p{margin:var(--space-2) 0 var(--space-4);color:var(--color-text-secondary)}.row-actions{display:flex;gap:var(--space-2);flex-wrap:wrap}.messenger-layout{--sidebar-layout-width: 340px;height:var(--app-shell-height);min-height:var(--app-shell-height);max-height:var(--app-shell-height);width:100%;min-width:0;position:relative;isolation:isolate;display:grid;grid-template-columns:var(--sidebar-layout-width) minmax(0,1fr);overflow:hidden;overflow:clip}.messenger-layout>*{min-width:0}.sidebar{border-right:var(--border-thin);background:var(--app-shell-surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;display:flex;flex-direction:column;min-height:0;overflow:hidden}.sidebar-top{padding:var(--space-4);border-bottom:var(--border-thin);display:grid;gap:var(--space-3);min-width:0;overflow-x:hidden;overflow-x:clip}.sidebar-brand-row{display:flex;align-items:center;justify-content:flex-start;gap:var(--space-3)}.sidebar-brand{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.sidebar-brand-copy{min-width:0;display:grid;gap:2px}.sidebar-brand-mark{width:40px;height:40px;border-radius:var(--radius-md);border:var(--border-thin);background:linear-gradient(135deg,#cff6eceb,#8fe4d8bd);display:grid;place-items:center}.sidebar-logo{width:24px;height:24px;object-fit:contain}.sidebar-kicker{margin:0;color:var(--color-secondary);font-family:var(--font-brand);font-size:11px;letter-spacing:.04em;text-transform:uppercase;font-weight:700;line-height:1.2;display:inline-flex;align-items:center;gap:7px}.sidebar-kicker-beta{display:inline-flex;align-items:center;justify-content:center;padding:1px 6px;border-radius:999px;border:1px solid rgba(76,172,183,.44);background:#53b6be29;color:var(--color-secondary);font-size:9px;font-family:var(--font-primary);font-weight:700;letter-spacing:.01em;line-height:1.25;text-transform:none}.sidebar-title{margin:0;font-family:var(--font-brand);color:var(--color-text-primary);font-size:17px;line-height:var(--leading-tight)}.sidebar-mode-note{margin:0;color:var(--color-text-muted);font-size:var(--text-xs);line-height:1.3}.sidebar-profile-button{width:40px;height:40px;border-radius:var(--radius-sm);border:var(--border-thin);background:var(--button-secondary-bg);display:inline-grid;place-items:center;padding:0;cursor:pointer;flex-shrink:0;transition:background-color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.sidebar-profile-button:hover{background:var(--button-secondary-hover-bg);border-color:var(--color-border-strong)}.sidebar-profile-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.sidebar-profile-avatar{width:100%;height:100%;border:none;border-radius:inherit}.sidebar-menu-toggle{width:40px;height:40px;border-radius:var(--radius-sm);border:var(--border-thin);background:var(--button-secondary-bg);color:var(--color-text-secondary);display:inline-grid;place-items:center;cursor:pointer;flex-shrink:0;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.sidebar-menu-toggle:hover{background:var(--button-secondary-hover-bg);border-color:var(--color-border-strong)}.sidebar-menu-toggle:focus-visible{outline:none;box-shadow:var(--focus-ring)}.sidebar-menu-toggle.is-active{background:#4dbdc429;border-color:#499fb78a;color:var(--color-secondary)}.sidebar-menu-toggle-lines{width:16px;display:grid;gap:3px}.sidebar-menu-toggle-lines span{display:block;height:2px;border-radius:var(--radius-pill);background:currentColor;transition:transform var(--transition-fast),opacity var(--transition-fast)}.sidebar-menu-toggle.is-active .sidebar-menu-toggle-lines span:nth-child(1){transform:translateY(5px) rotate(45deg)}.sidebar-menu-toggle.is-active .sidebar-menu-toggle-lines span:nth-child(2){opacity:0}.sidebar-menu-toggle.is-active .sidebar-menu-toggle-lines span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}.wellness-card{--wellness-pull-offset: 0px;border:none;border-radius:var(--radius-sm);background:#6fb2bd1a;padding:6px 8px 4px;display:grid;gap:4px}.wellness-card-chevron{width:16px;height:16px;border-radius:var(--radius-pill);border:none;display:inline-grid;place-items:center;color:var(--color-text-muted);flex-shrink:0;transform:translateY(calc(var(--wellness-pull-offset) * .35));transition:transform var(--transition-normal),color var(--transition-fast)}.wellness-card-chevron svg{width:13px;height:13px}.wellness-card.is-expanded .wellness-card-chevron{transform:rotate(180deg) translateY(calc(var(--wellness-pull-offset) * .35));color:var(--color-text-secondary)}.wellness-card.is-pulling .wellness-card-chevron{transition-duration:80ms}.wellness-metric-grid{min-width:0;display:flex;align-items:center;justify-content:space-between;gap:9px;overflow-x:hidden;scrollbar-width:none}.wellness-metric-grid::-webkit-scrollbar{display:none}.wellness-metric-item{display:inline-flex;align-items:center;gap:6px;min-width:0}.wellness-metric-icon{width:20px;height:20px;color:#3d6f82;display:inline-grid;place-items:center;flex-shrink:0}.wellness-metric-icon svg{width:16px;height:16px}.wellness-metric-item.is-time .wellness-metric-icon{color:#2e648e}.wellness-metric-item.is-steps .wellness-metric-icon{color:#2f6b4f}.wellness-metric-item.is-weight .wellness-metric-icon{color:#6d4c8f}.wellness-metric-item.is-heart-rate .wellness-metric-icon{color:#8f3b50}.wellness-metric-item.is-sleep .wellness-metric-icon{color:#425a9f}.wellness-metric-item.is-water .wellness-metric-icon{color:#3d768e}.wellness-metric-copy{min-width:0;display:flex;align-items:baseline;gap:4px}.wellness-metric-label{margin:0;color:var(--color-text-muted);font-size:10px;letter-spacing:.02em;line-height:1.2;white-space:nowrap}.wellness-metric-value{margin:0;color:var(--color-text-primary);font-size:12px;font-weight:700;line-height:1.2;font-variant-numeric:tabular-nums;white-space:nowrap}.wellness-card-details{border-top:1px solid rgba(123,165,180,.44);padding:5px 2px 1px;display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px}.wellness-card-details[hidden]{display:none}.wellness-card-handle{border:none;background:transparent;width:100%;padding:2px 0 3px;margin:0;border-radius:var(--radius-pill);display:grid;justify-items:center;gap:1px;cursor:pointer;color:var(--color-text-muted)}.wellness-card-handle:hover{color:var(--color-text-secondary)}.wellness-card-handle:focus-visible{outline:none;box-shadow:var(--focus-ring)}.wellness-card-pull-line{width:34px;height:3px;border-radius:var(--radius-pill);background:#7fa5b38a;transform:translateY(calc(var(--wellness-pull-offset) * .2));transition:transform .1s ease}.wellness-card.is-pulling .wellness-card-pull-line{transition-duration:80ms}.search-input{background:var(--color-surface-elevated);min-height:40px;padding-top:9px;padding-bottom:9px}.search-input-wrap{position:relative;min-width:0}.search-input-wrap .search-input{padding-right:74px}.search-clear-button{position:absolute;right:6px;top:50%;transform:translateY(-50%);border:none;border-radius:var(--radius-pill);background:var(--search-clear-bg);color:var(--color-secondary);padding:5px 10px;font-size:var(--text-xs);font-weight:700;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.search-clear-button:hover{background:var(--search-clear-hover-bg);color:var(--search-clear-hover-color)}.search-clear-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.search-meta{margin:0;color:var(--color-text-muted);font-size:var(--text-xs)}.search-meta.is-error{color:var(--color-danger)}.small-state{margin:0;padding:14px 16px;color:var(--color-text-muted);display:grid;gap:10px}.search-results{display:grid;gap:var(--space-2);border:var(--border-thin);border-radius:var(--radius-sm);background:var(--panel-neutral-bg);padding:var(--space-2)}.search-results-state{padding:var(--space-3)}.search-results-error{border-color:var(--color-danger-border);background:var(--color-danger-surface)}.search-results-title{margin:0;color:var(--color-text-secondary);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.search-results-message{margin:0;color:var(--color-text-muted);font-size:var(--text-sm)}.user-results{display:grid;gap:6px}.user-result-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:var(--space-3);width:100%;border:var(--border-thin);text-align:left;cursor:pointer;min-height:46px;padding:9px 10px;border-radius:var(--radius-sm);background:var(--list-item-bg);transition:border-color var(--transition-fast),background-color var(--transition-fast)}.user-result-avatar{width:36px;height:36px}.user-result-row:hover{border-color:var(--list-item-border-hover);background:var(--list-item-hover-bg)}.user-result-row:focus-visible{outline:none;border-color:#30bbc08c;box-shadow:var(--focus-ring)}.user-result-row:active{background:var(--list-item-active-bg)}.user-result-main{display:grid;gap:1px;min-width:0}.user-result-name{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-primary);font-size:var(--text-md);font-weight:600}.user-result-handle{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-muted);font-size:var(--text-sm)}.user-result-action{color:var(--color-secondary);font-size:var(--text-xs);font-weight:700;white-space:nowrap}.sidebar-inline-hint{margin:0;border:1px solid var(--color-warning-border);border-radius:var(--radius-xs);background:var(--color-warning-surface);color:var(--status-warning-text);font-size:var(--text-xs);padding:8px 10px}.notification-first-run-card{border:1px solid rgba(73,159,183,.46);border-radius:var(--radius-sm);background:#59b4c124;padding:var(--space-3);display:grid;gap:var(--space-2)}.notification-first-run-title{margin:0;color:var(--color-text-primary);font-size:var(--text-sm);font-weight:700}.notification-first-run-description{margin:0;color:var(--color-text-secondary);font-size:var(--text-xs);line-height:var(--leading-normal)}.notification-first-run-actions{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.notification-first-run-dismiss{border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;font-size:var(--text-xs);padding:4px 0}.notification-first-run-dismiss:hover{color:var(--color-secondary)}.notification-first-run-dismiss:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:var(--radius-xs)}.sidebar-state-card{margin:var(--space-2);border:var(--border-thin);border-radius:var(--radius-sm);background:var(--panel-neutral-strong-bg);padding:var(--space-3);display:grid;gap:var(--space-2)}.sidebar-state-error{border-color:var(--color-danger-border);background:var(--color-danger-surface)}.sidebar-state-title{margin:0;color:var(--color-text-primary);font-size:var(--text-md);font-weight:700}.sidebar-state-description{margin:0;color:var(--color-text-secondary);font-size:var(--text-sm)}.sidebar-state-skeleton{display:grid;gap:var(--space-2)}.sidebar-state-skeleton-line{height:10px;border-radius:var(--radius-pill);background:linear-gradient(90deg,#9dbbc63d,#c1dae370,#9dbbc63d);background-size:200% 100%;animation:sidebar-skeleton-shimmer 1.6s linear infinite}.sidebar-state-skeleton-line.short{width:62%}.sidebar-list-block{flex:1;min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr);position:relative}.sidebar-menu-panel{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:var(--space-3) var(--space-2) var(--space-3);display:grid;align-content:start;gap:10px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.sidebar-menu-panel-head{display:grid;gap:2px;padding:0 4px}.sidebar-menu-panel-title{margin:0;color:var(--color-text-muted);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.sidebar-menu-panel-description{margin:0;color:var(--color-text-secondary);font-size:var(--text-xs);line-height:1.35}.sidebar-menu-list{display:grid;gap:8px}.sidebar-menu-item{width:100%;border:1px solid var(--list-item-border);border-radius:var(--radius-sm);background:var(--list-item-bg);padding:9px 10px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:var(--space-2);text-align:left;cursor:pointer;min-height:52px;transition:border-color var(--transition-fast),background-color var(--transition-fast),transform var(--transition-fast)}.sidebar-menu-item:hover{border-color:var(--list-item-border-hover);background:var(--list-item-hover-bg)}.sidebar-menu-item:focus-visible{outline:none;box-shadow:var(--focus-ring)}.sidebar-menu-item:active{transform:translateY(1px)}.sidebar-menu-item:disabled{cursor:default;opacity:var(--state-disabled-opacity);background:var(--panel-neutral-bg)}.sidebar-menu-item.is-danger{border-color:var(--color-danger-border);background:var(--color-danger-surface)}.sidebar-menu-item.is-danger .sidebar-menu-item-label{color:var(--color-danger)}.sidebar-menu-item-icon{width:28px;height:28px;border-radius:var(--radius-pill);border:1px solid var(--color-border);color:var(--color-text-secondary);background:var(--color-surface-soft);display:inline-grid;place-items:center}.sidebar-menu-item-icon svg{width:16px;height:16px}.sidebar-menu-item-copy{min-width:0;display:grid;gap:2px}.sidebar-menu-item-label{color:var(--color-text-primary);font-size:var(--text-sm);font-weight:700}.sidebar-menu-item-description{color:var(--color-text-secondary);font-size:var(--text-xs);line-height:1.35}.sidebar-menu-item-badge{border-radius:var(--radius-pill);border:1px solid var(--color-border);background:var(--color-surface-soft);color:var(--color-text-secondary);font-size:10px;font-weight:700;padding:3px 7px}.sidebar-section-label{margin:var(--space-2) var(--space-2) 0;color:var(--color-text-muted);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.conversation-list{flex:1;min-height:0;display:flex;flex-direction:column;gap:5px;padding:var(--space-2) var(--space-2) calc(var(--space-3) + 126px);overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.sidebar-center-logo-wrap{position:absolute;left:50%;bottom:calc(clamp(16px,2.2vh,26px) + env(safe-area-inset-bottom,0px));transform:translate(-50%);z-index:3;pointer-events:none}.sidebar-center-logo{width:clamp(132px,12.5vw,168px);aspect-ratio:1;border:none;border-radius:36px;background:transparent;padding:0;margin:0;position:relative;display:inline-grid;place-items:center;cursor:pointer;opacity:.065;pointer-events:auto;transition:opacity var(--transition-fast),transform var(--transition-fast)}.sidebar-center-logo:hover,.sidebar-center-logo:focus-visible{opacity:.12}.sidebar-center-logo:active{transform:scale(.985)}.sidebar-center-logo:focus-visible{outline:none;box-shadow:var(--focus-ring)}.sidebar-center-logo-image{width:100%;height:100%;object-fit:contain}.sidebar-center-logo-ring,.sidebar-center-logo-glint{position:absolute;pointer-events:none}.sidebar-center-logo-ring{top:6px;right:6px;bottom:6px;left:6px;border-radius:32px}.sidebar-center-logo-ring:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:1.5px;background:conic-gradient(from 0deg,transparent 0deg 282deg,rgba(191,248,244,.92) 306deg,rgba(243,255,255,.98) 328deg,rgba(165,232,236,.88) 345deg,transparent 360deg);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0}.sidebar-center-logo-glint{top:22%;right:22%;bottom:22%;left:22%;border-radius:999px;background:radial-gradient(circle,#dcfcfa75,#dcfcfa00 72%);opacity:0}.sidebar-center-logo.is-sparking .sidebar-center-logo-ring:before{animation:sidebar-logo-spark-ring 1.3s ease-out both}.sidebar-center-logo.is-sparking .sidebar-center-logo-glint{animation:sidebar-logo-spark-glint 1.3s ease-out both}.sidebar-bottom-meta{margin-top:auto;padding:0 var(--space-2) calc(var(--space-2) + env(safe-area-inset-bottom,0px));position:relative;z-index:4}.conversation-row{display:grid;grid-template-columns:72px minmax(0,1fr);align-items:stretch;column-gap:10px;width:100%;border:1px solid var(--list-item-border);border-radius:14px;background:var(--list-item-bg);text-align:left;padding:0 10px 0 0;min-height:72px;overflow:hidden;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.conversation-row:hover{border-color:var(--list-item-border-hover);background:var(--list-item-hover-bg)}.conversation-row:focus-visible{outline:none;border-color:#30bbc094;box-shadow:var(--focus-ring)}.conversation-row:active{transform:translateY(1px)}.conversation-row.active{border-color:#49a9b5ad;background:var(--list-item-selected-bg);box-shadow:var(--shadow-xs)}.conversation-row.has-unread .conversation-name{font-weight:700}.conversation-content{min-width:0;display:grid;gap:2px;align-content:center;padding:8px 0}.conversation-row-main{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:8px}.conversation-avatar{width:72px;height:72px;border:none;border-radius:0;align-self:stretch}.conversation-identity{min-width:0;display:grid;gap:1px}.conversation-name{margin:0;color:var(--color-text-primary);font-size:14px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-meta-right{display:grid;justify-items:end;align-content:start;gap:5px;flex-shrink:0}.conversation-time{min-height:15px;font-size:11px;line-height:1.2;color:var(--color-text-muted);font-variant-numeric:tabular-nums;white-space:nowrap}.conversation-username{margin:0;color:var(--color-text-muted);font-size:11px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-time.is-empty{opacity:0}.conversation-preview{margin:1px 0 0;color:var(--color-text-secondary);font-size:var(--text-sm);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unread-badge{min-width:20px;height:20px;border-radius:var(--radius-pill);display:inline-grid;place-items:center;padding:0 7px;font-size:var(--text-xs);font-weight:700;letter-spacing:.01em;color:var(--color-text-on-primary);background:linear-gradient(180deg,var(--button-primary-start),var(--button-primary-end))}.conversation-empty{margin:var(--space-2);text-align:left;display:grid;gap:6px}.conversation-empty-title{margin:0;color:var(--color-text-primary);font-size:var(--text-md);font-weight:700}.conversation-empty-description{margin:0;color:var(--color-text-secondary);font-size:var(--text-sm)}.chat-panel{min-height:0;min-width:0;display:grid;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden;position:relative;background:transparent}.chat-header{border-bottom:var(--border-thin);padding:12px 18px;display:flex;align-items:center;justify-content:space-between;background:var(--app-shell-surface);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.chat-header-main{min-width:0;display:flex;align-items:center;gap:var(--space-3)}.chat-back-button{width:36px;height:36px;border-radius:var(--radius-pill);border:var(--border-thin);background:var(--button-secondary-bg);color:var(--color-text-primary);display:inline-grid;place-items:center;cursor:pointer;flex-shrink:0}.chat-back-button:hover{background:var(--button-secondary-hover-bg)}.chat-back-button span{font-size:18px;line-height:1}.chat-person{min-width:0;display:flex;align-items:center;gap:10px}.chat-avatar{width:48px;height:48px;border-radius:13px;border-color:var(--color-border-strong)}.chat-person-copy{min-width:0}.chat-person-name{display:block;color:var(--color-text-primary);font-size:15px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-presence{margin-top:1px;display:flex;align-items:center;gap:6px;color:var(--color-text-muted);font-size:13px}.status-dot{width:8px;height:8px;border-radius:999px;background:var(--color-text-muted);display:inline-block}.status-dot.online{background:var(--color-success)}.connection-pill{border-radius:var(--radius-pill);padding:6px 10px;font-size:var(--text-xs);font-weight:600;border:var(--border-thin);background:var(--button-secondary-bg);color:var(--color-text-muted)}.sidebar-connection-pill{display:none;margin:0 0 10px}@media(max-width:980px){.sidebar-connection-pill{display:inline-flex;width:fit-content;align-items:center;justify-content:center;margin-left:var(--space-2)}}.connection-pill.connected{color:var(--status-connected-text);border-color:var(--status-connected-border);background:var(--status-connected-bg)}.connection-pill.disconnected,.connection-pill.connecting,.connection-pill.reconnecting{color:var(--status-warning-text);border-color:var(--status-warning-border);background:var(--status-warning-bg)}.connection-pill.offline{color:var(--status-danger-text);border-color:var(--status-danger-border);background:var(--status-danger-bg)}.chat-scroll{min-height:0;overflow-y:auto;overflow-x:hidden;padding:var(--space-4) var(--space-4) calc(var(--space-4) + 6px);display:grid;align-content:start;gap:var(--space-3);overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.chat-panel>.page-state{min-height:0;height:100%;padding:var(--space-6)}.chat-scroll::-webkit-scrollbar,.conversation-list::-webkit-scrollbar,.sidebar-menu-panel::-webkit-scrollbar{width:8px}.chat-scroll::-webkit-scrollbar-thumb,.conversation-list::-webkit-scrollbar-thumb,.sidebar-menu-panel::-webkit-scrollbar-thumb{background:var(--chat-scrollbar-thumb);border-radius:var(--radius-pill)}.chat-error{margin-bottom:var(--space-4);color:var(--color-danger);display:inline-grid;gap:var(--space-2);justify-items:start;background:var(--color-danger-surface);border:1px solid var(--color-danger-border);border-radius:var(--radius-sm);padding:10px 12px;font-size:var(--text-sm)}.chat-state-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);border:var(--border-thin);border-radius:var(--radius-sm);padding:8px 10px;background:var(--panel-neutral-bg);color:var(--color-text-secondary);font-size:var(--text-sm)}.chat-state-banner.is-reconnecting{border-color:var(--status-warning-border);background:var(--status-warning-bg);color:var(--status-warning-text)}.chat-state-banner.is-offline,.chat-state-banner.is-error{border-color:var(--status-danger-border);background:var(--status-danger-bg);color:var(--status-danger-text)}.message-system-banner{margin-bottom:var(--space-3);border:1px solid var(--status-warning-border);background:var(--status-warning-bg);color:var(--status-warning-text);border-radius:var(--radius-sm);padding:8px 12px;font-size:var(--text-sm)}.chat-state-card{color:var(--color-text-muted);border:1px dashed var(--color-border-strong);border-radius:var(--radius-sm);padding:var(--space-4);text-align:center;background:var(--panel-neutral-bg)}.message-list{display:grid;gap:var(--space-3)}.history-loader{display:grid;place-items:center;margin-bottom:var(--space-1)}.message-separator{display:flex;align-items:center;gap:var(--space-2);margin:2px 0}.message-separator:before,.message-separator:after{content:"";flex:1;height:1px;background:#6b8e9d57}.message-separator span{border-radius:var(--radius-pill);border:1px solid var(--color-border);background:var(--panel-neutral-strong-bg);color:var(--color-text-muted);font-size:var(--text-xs);font-weight:600;letter-spacing:.01em;padding:4px 10px}.message-separator.unread span{border-color:#499fb794;color:var(--color-secondary);background:#52bbc22e}.message-divider{width:max-content;max-width:100%;margin:var(--space-1) auto var(--space-1);padding:4px 10px;border-radius:var(--radius-pill);font-size:var(--text-xs);color:var(--color-text-muted);background:var(--panel-neutral-bg);border:1px solid var(--color-border)}.message-divider.unread{background:#52bbc22e;border-color:#499fb794;color:var(--color-secondary)}.message-row{display:flex}.message-row.has-reactions{padding-bottom:0}.message-row.mine{justify-content:flex-end}.message-stack{position:relative;display:inline-flex;flex-direction:column;flex:0 1 auto;min-width:0;max-width:min(76%,680px);overflow:visible}.message-stack.is-single-emoji{max-width:min(62%,520px);margin-top:4px}.message-stack.is-selected .message-bubble{box-shadow:0 0 0 2px #2a9ca738,var(--shadow-xs)}.message-stack.is-flash .message-bubble{animation:message-target-flash 1.1s ease}@keyframes message-target-flash{0%{box-shadow:0 0 0 2px #2a9ca759,var(--shadow-xs)}to{box-shadow:var(--shadow-xs)}}.message-bubble-wrap{position:relative;display:block;max-width:100%;min-width:0;overflow:visible}.message-bubble-wrap.is-single-emoji{padding-bottom:12px}.message-row.mine .message-bubble-wrap{--outgoing-anchor-reserve: 12px;padding-right:var(--outgoing-anchor-reserve)}.message-row:not(.mine) .message-bubble-wrap{--incoming-anchor-reserve: 12px;padding-left:var(--incoming-anchor-reserve)}.message-bubble{display:block;width:fit-content;max-width:100%;min-width:0;position:relative;background:var(--message-incoming-surface);border:var(--border-thin);border-radius:var(--radius-md);padding:10px 12px 9px;box-shadow:var(--shadow-xs)}.message-bubble.is-single-emoji{padding:0;border-radius:0;box-shadow:none;background:transparent;border:none}.message-row.mine .message-bubble.is-single-emoji{background:transparent;border:none;box-shadow:none}.message-bubble.pending{opacity:.88}.message-row.mine .message-bubble{background:var(--message-outgoing-surface);border-color:var(--message-outgoing-border)}.message-row.mine .message-bubble.tone-read{border-color:var(--message-outgoing-border)}.message-row.mine .message-bubble.tone-sent{border-color:#54a3ffb8;box-shadow:0 0 0 1px #54a3ff1f,var(--shadow-xs)}.message-row.mine .message-bubble.tone-delivered{border-color:#26c2a7b8;box-shadow:0 0 0 1px #26c2a71f,var(--shadow-xs)}.message-row.mine .message-bubble.tone-pending{border-color:#e77b4d94;box-shadow:0 0 0 1px #e77b4d1a,var(--shadow-xs)}.message-row.mine .message-bubble.tone-failed{border-color:#db4a4ad1;box-shadow:0 0 0 1px #db4a4a24,var(--shadow-xs)}.message-row.mine .message-bubble.is-single-emoji.tone-read,.message-row.mine .message-bubble.is-single-emoji.tone-sent,.message-row.mine .message-bubble.is-single-emoji.tone-delivered,.message-row.mine .message-bubble.is-single-emoji.tone-pending{border-color:#9cd9d89e;box-shadow:none}.message-row.mine .message-bubble.is-single-emoji.tone-failed{box-shadow:none}.message-body{margin:0;min-width:0;color:var(--message-incoming-text);line-height:1.42;white-space:pre-wrap;word-break:normal;overflow-wrap:break-word;-webkit-hyphens:manual;hyphens:manual}.message-row.mine .message-body{color:var(--message-outgoing-text)}.message-reply-quote{width:100%;min-width:0;display:grid;gap:2px;margin:0 0 7px;padding:7px 8px;border-radius:10px;border:1px solid var(--color-border-strong);background:var(--color-surface-soft);color:var(--color-text-primary);text-align:left}.message-row.mine .message-reply-quote{border-color:#60abadb8;background:#54b5bd1f}.message-reply-quote.is-clickable{cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.message-reply-quote.is-clickable:hover{border-color:#35adb1bd;background:#54b5bd2e}.message-reply-quote:disabled{cursor:default}.message-reply-quote-label{font-size:11px;font-weight:700;line-height:1.2;color:var(--color-secondary)}.message-reply-quote-text{font-size:12px;line-height:1.25;color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.message-body.is-single-emoji{font-size:72px;line-height:1;letter-spacing:-.02em;text-align:center}.message-body.is-emoji-only.emoji-count-2,.message-body.is-emoji-only.emoji-count-3{font-size:0}.single-emoji-glyph{display:inline-block;vertical-align:middle;filter:drop-shadow(0 10px 18px rgba(15,46,58,.12))}.message-emoji-only-row{display:inline-flex;align-items:center;justify-content:center;gap:6px;filter:drop-shadow(0 10px 18px rgba(15,46,58,.12))}.message-emoji-only-row.count-3{gap:5px}.message-emoji-only-glyph{display:inline-block;vertical-align:middle}.message-footer{display:flex;flex-direction:column;align-items:flex-end;width:auto;min-width:0}.message-meta{margin-top:6px;font-size:11px;color:var(--message-incoming-meta);display:flex;align-items:center;justify-content:flex-end;gap:4px;white-space:nowrap;-webkit-user-select:none;user-select:none;max-width:100%}.message-row.mine .message-meta{color:var(--message-outgoing-meta)}.message-time{font-variant-numeric:tabular-nums;font-weight:600}.message-meta.is-single-emoji{margin-top:10px;margin-bottom:2px;justify-content:flex-end}.message-status{display:inline-flex;align-items:center;gap:4px;padding:0;border:none;background:transparent;color:var(--message-incoming-meta)}.message-status.is-compact{padding:0}.message-row.mine .message-status{color:var(--message-outgoing-meta)}.message-status-icon{flex:0 0 auto;opacity:.76;transform-origin:50% 50%}.message-status--sent,.message-status--delivered,.message-status--read{color:var(--message-incoming-meta)}.message-status--failed{color:#ca4c61eb}.message-status--sending,.message-status--queued{color:var(--message-incoming-meta)}.message-status--sending .message-status-icon{animation:message-status-spin .95s linear infinite}@keyframes message-status-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.message-status--sending .message-status-icon{animation:none}}.message-actions{margin-top:6px;display:flex;justify-content:flex-end}.message-reactions-anchor{position:absolute;bottom:0;width:auto;height:auto;display:inline-flex;align-items:center;transform:translateY(50%);z-index:4;pointer-events:none}.message-reactions-anchor>*{pointer-events:auto}.message-reactions-anchor.is-incoming{left:var(--incoming-anchor-reserve, 0px);justify-content:flex-start}.message-row.mine .message-reactions-anchor.is-outgoing{right:var(--outgoing-anchor-reserve, 0px);justify-content:flex-end}.message-reactions-rail{position:absolute;bottom:0;display:inline-flex;align-items:center;gap:8px;padding:0;background:transparent;border:none;box-shadow:none;white-space:nowrap;transform:translateY(50%);animation:reaction-lane-enter .18s cubic-bezier(.22,.78,.22,1) 1}.message-reactions-rail.expand-right{left:0;right:auto}.message-reactions-rail.expand-left{right:0;left:auto}.reaction-hover-heart{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;border:1px solid var(--reaction-pill-border);background:var(--reaction-pill-surface);color:#e23b3bf5;box-shadow:0 1px 4px #0f2e3a1f;padding:0;border-radius:10px;cursor:pointer;touch-action:manipulation;transition:transform .14s ease,opacity .14s ease;animation:reaction-heart-enter .17s cubic-bezier(.22,.78,.22,1) 1;will-change:transform,opacity}.message-row.mine .reaction-hover-heart.is-outgoing{border-color:var(--reaction-pill-border)}.reaction-hover-heart-emoji{display:block}.reaction-hover-heart:hover:not(:disabled){color:#e23b3b;background:var(--color-danger-surface);border-color:var(--color-danger-border);transform:translateY(-1px) scale(1.02)}.message-row.mine .reaction-hover-heart.is-outgoing:hover:not(:disabled){transform:translateY(-1px) scale(1.02)}.reaction-hover-heart:disabled{opacity:.6;cursor:not-allowed}@keyframes reaction-lane-enter{0%{opacity:0;transform:translateY(3px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes reaction-heart-enter{0%{opacity:0;transform:translateY(2px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes reaction-pill-attach{0%{opacity:0;transform:translateY(2px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.reaction-chip{display:inline-flex;align-items:center;gap:5px;padding:2px 7px 2px 6px;border:1px solid var(--reaction-pill-border);background:var(--reaction-pill-surface);color:var(--reaction-pill-text);font-size:var(--text-xs);line-height:1;font-variant-numeric:tabular-nums;border-radius:var(--radius-pill);box-shadow:none}.message-row.mine .reaction-chip{background:var(--reaction-pill-mine-surface);border-color:var(--reaction-pill-mine-border)}.reaction-chip:hover:not(:disabled){border-color:#499fb794;background:#499fb729}.reaction-chip:disabled{opacity:.7;cursor:not-allowed}.reaction-chip.is-mine{background:var(--reaction-pill-mine-surface);border-color:var(--reaction-pill-mine-border);color:var(--reaction-pill-text);box-shadow:0 0 0 1px #499fb733 inset}.reaction-chip-emoji{display:block}.reaction-chip-count{font-weight:650;color:var(--reaction-pill-text)}.message-reaction-pill-rail{display:inline-flex;align-items:center;justify-content:flex-end;flex-direction:row-reverse;gap:3px;padding:0;min-height:20px;white-space:nowrap;animation:reaction-lane-enter .18s cubic-bezier(.22,.78,.22,1) 1;will-change:transform,opacity}.message-reaction-pill-rail.is-incoming{justify-content:flex-start;flex-direction:row}.message-reaction-pill-rail.is-incoming.expand-left{position:relative;right:100%}.message-reaction-pill-lane{display:inline-flex;align-items:center;gap:4px}.message-reaction-pill-lane.is-outgoing{flex-direction:row}.message-reaction-pill-lane.is-incoming{flex-direction:row-reverse}.message-reaction-pill-lane.is-incoming.expand-left{position:relative;right:100%}.message-reaction-heart-slot{width:20px;min-width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 20px}.reaction-hover-heart.is-lane-heart{margin:0}.message-reaction-pill{display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;gap:3px;height:20px;padding:0 7px 0 6px;border-radius:10px;border:1px solid var(--reaction-pill-border);background:var(--reaction-pill-surface);color:var(--reaction-pill-text);box-shadow:0 1px 4px #0f2e3a1f;white-space:nowrap;font-size:11px;line-height:1;font-variant-numeric:tabular-nums;cursor:pointer;touch-action:manipulation;animation:reaction-pill-attach .17s cubic-bezier(.22,.78,.22,1) 1;transition:transform .15s ease,opacity .15s ease;will-change:transform,opacity}.message-reaction-pill:hover:not(:disabled){border-color:#499fb79e;background:#499fb729}.message-reaction-pill:disabled{opacity:.7;cursor:not-allowed}.message-reaction-pill.is-mine{border-color:var(--reaction-pill-mine-border);background:var(--reaction-pill-mine-surface)}.message-reaction-pill-emoji{display:block}.message-reaction-pill-count{font-weight:650;line-height:1;color:var(--reaction-pill-text)}.message-reaction-expanded-rail{position:relative;display:inline-flex;align-items:center;gap:3px;padding:3px 5px;min-height:26px;height:auto;border-radius:999px;border:1px solid var(--reaction-pill-border);background:var(--reaction-pill-surface);box-shadow:0 1px 4px #0f2e3a1f;white-space:nowrap;animation:reaction-lane-enter .19s cubic-bezier(.22,.78,.22,1) 1;will-change:transform,opacity}.message-reaction-expanded-rail.is-incoming.expand-left{right:100%}.reaction-rail-emoji{width:22px;height:22px;border:none;border-radius:9px;background:transparent;display:inline-flex;align-items:center;justify-content:center;padding:0}.reaction-rail-emoji:hover:not(:disabled){background:#499fb72e}.reaction-rail-emoji:disabled{opacity:.72;cursor:not-allowed}.reaction-rail-emoji-icon{display:block}.reaction-picker{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30}.reaction-picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;border:none;background:var(--color-overlay-scrim);padding:0}.reaction-picker-panel{position:absolute;display:flex;gap:6px;padding:10px;border-radius:16px;border:none;background:var(--sheet-surface);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.reaction-picker-panel.is-start{left:0}.reaction-picker-panel.is-end{right:0}.reaction-picker-panel.is-top{bottom:calc(100% + 12px)}.reaction-picker-panel.is-bottom{top:calc(100% + 12px)}.reaction-picker-emoji{width:38px;height:38px;border-radius:12px;border:none;background:transparent;font-size:18px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.reaction-picker-emoji:hover{background:#499fb729}.reaction-picker-emoji-icon{display:block}.message-action-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:82}.message-action-sheet-overlay.mobile{background:var(--color-overlay-scrim)}.message-action-sheet-menu{border:1px solid var(--color-border-strong);background:var(--menu-surface);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.message-action-sheet-menu.desktop{position:absolute;display:grid;min-width:190px;border-radius:12px;padding:6px}.message-action-sheet-menu.mobile{position:absolute;left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom,0px));display:grid;gap:6px;border-radius:16px;padding:10px}.message-action-sheet-title{margin:0;padding:0 4px 2px;font-size:12px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--color-text-muted)}.message-action-sheet-item{width:100%;border:none;border-radius:10px;background:transparent;color:var(--color-text-primary);padding:10px 12px;text-align:left;font-size:14px;font-weight:600}.message-action-sheet-item:hover{background:#499fb729}.message-action-sheet-item.is-destructive{color:var(--color-danger)}.message-action-sheet-item.is-cancel{border:1px solid var(--color-border)}.composer{border-top:var(--border-thin);padding:var(--space-3) var(--space-4) calc(var(--space-3) + env(safe-area-inset-bottom,0px));display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:var(--space-2);background:var(--app-shell-surface);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);position:relative}.composer-reply-preview{grid-column:1 / -1;min-width:0;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:1px;padding:8px 10px;border-radius:11px;border:1px solid var(--color-border-strong);background:var(--panel-neutral-bg)}.composer-reply-preview-copy{min-width:0;display:grid;gap:2px}.composer-reply-preview-label{margin:0;font-size:11px;font-weight:700;color:var(--color-secondary)}.composer-reply-preview-body{margin:0;font-size:12px;line-height:1.3;color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.composer-reply-preview-close{border:none;border-radius:9px;background:transparent;color:var(--color-text-muted);font-size:12px;font-weight:600;line-height:1;padding:6px 8px}.composer-reply-preview-close:hover{background:#499fb724}.composer-field{min-width:0;display:block}.composer-input-shell{position:relative;min-width:0;display:flex;align-items:flex-end}.composer-input{border-radius:var(--radius-md);padding:10px 52px 10px 14px;min-height:44px;max-height:180px;resize:none;overflow-y:auto;line-height:1.4;width:100%}.composer-submit{min-width:88px;height:44px;align-self:end}.composer-emoji{position:absolute;right:8px;bottom:6px;z-index:3;display:inline-flex;align-items:flex-end}.composer-emoji-button{width:32px;height:32px;padding:0;border:none;border-radius:10px;background:transparent;display:inline-flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:color var(--transition-fast),transform var(--transition-fast)}.composer-emoji-icon{display:block;width:20px;height:20px;transform:none}.composer-emoji-button:hover:not(:disabled){color:var(--color-secondary);transform:translateY(-1px)}.composer-emoji-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.composer-emoji-button:disabled{opacity:.6;cursor:not-allowed}.emoji-picker,.emoji-picker-layer{--emoji-picker-open-opacity-duration: 112ms;--emoji-picker-open-transform-duration: .12s;--emoji-picker-close-opacity-duration: 90ms;--emoji-picker-close-transform-duration: 104ms;--emoji-picker-open-ease: cubic-bezier(.2, .8, .2, 1);--emoji-picker-close-ease: cubic-bezier(.3, 0, 1, 1)}.emoji-picker{position:relative;z-index:20}.emoji-picker.is-closed{pointer-events:none}.emoji-picker.is-open{pointer-events:auto}.emoji-picker-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;pointer-events:none}.emoji-picker-layer .emoji-picker-backdrop,.emoji-picker-layer .emoji-picker-panel{pointer-events:auto}.emoji-picker-layer.is-closed .emoji-picker-backdrop,.emoji-picker-layer.is-closed .emoji-picker-panel{pointer-events:none}.emoji-picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-scrim);border:none;opacity:1;visibility:visible;transition:opacity var(--emoji-picker-open-opacity-duration) var(--emoji-picker-open-ease),visibility var(--emoji-picker-open-opacity-duration) linear}.emoji-picker-panel{width:min(408px,calc(100vw - 24px));padding:0;border-radius:var(--radius-md);border:1px solid var(--color-border-strong);background:linear-gradient(180deg,rgba(73,159,183,.06),transparent 22%),var(--sheet-surface);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;flex-direction:column;overflow:hidden;isolation:isolate;opacity:1;visibility:visible;transform:translateY(0) scale(1);transform-origin:100% 100%;backface-visibility:hidden;will-change:opacity,transform;transition:opacity var(--emoji-picker-open-opacity-duration) var(--emoji-picker-open-ease),transform var(--emoji-picker-open-transform-duration) var(--emoji-picker-open-ease),visibility var(--emoji-picker-open-opacity-duration) linear}.emoji-picker.is-closed .emoji-picker-panel{opacity:0;visibility:hidden;transform:translateY(4px) scale(.992);transition:opacity var(--emoji-picker-close-opacity-duration) var(--emoji-picker-close-ease),transform var(--emoji-picker-close-transform-duration) var(--emoji-picker-close-ease),visibility var(--emoji-picker-close-opacity-duration) linear}.emoji-picker-layer.is-closed .emoji-picker-backdrop{opacity:0;visibility:hidden;transition:opacity var(--emoji-picker-close-opacity-duration) var(--emoji-picker-close-ease),visibility var(--emoji-picker-close-opacity-duration) linear}.emoji-picker-layer.is-closed .emoji-picker-panel{opacity:0;visibility:hidden;transform:translateY(5px) scale(.992);transition:opacity var(--emoji-picker-close-opacity-duration) var(--emoji-picker-close-ease),transform var(--emoji-picker-close-transform-duration) var(--emoji-picker-close-ease),visibility var(--emoji-picker-close-opacity-duration) linear}.emoji-picker-panel.is-desktop{position:absolute;right:0;bottom:42px;height:min(66vh,520px);max-height:min(66vh,520px);min-height:360px;transform-origin:100% 100%}.emoji-picker-panel.is-mobile{position:fixed;left:8px;right:8px;width:auto;bottom:var(--emoji-picker-mobile-bottom, 6px);border-radius:18px;height:min(58svh,460px);max-height:calc(100svh - var(--emoji-picker-mobile-bottom, 6px) - 12px);min-height:260px;transform-origin:50% 100%;box-shadow:0 14px 32px #091e2829,0 -6px 18px #091e281f}.emoji-picker-header{flex:0 0 auto;position:relative;z-index:1;contain:paint;transform:translateZ(0);backface-visibility:hidden;padding:12px 12px 10px;background:linear-gradient(180deg,#499fb70d,#499fb705),var(--sheet-surface);box-shadow:0 1px #499fb71a}.emoji-picker-search-shell{display:flex;align-items:center;gap:10px;min-height:40px;padding:0 12px;border-radius:12px;border:1px solid transparent;background:#499fb714}.emoji-picker-search-shell:focus-within{border-color:#499fb73d;background:#499fb71c;box-shadow:inset 0 0 0 1px #499fb714}.emoji-picker-search-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--color-text-muted);flex:0 0 auto}.emoji-picker-search-icon-svg{width:16px;height:16px}.emoji-picker-search-input{width:100%;min-width:0;border:none;background:transparent;color:var(--color-text-primary);padding:0;min-height:40px;font:inherit;line-height:1.2}.emoji-picker-search-input::placeholder{color:var(--color-text-muted)}.emoji-picker-search-input:focus-visible{outline:none}.emoji-picker-body{flex:1 1 auto;min-height:0;display:flex}.emoji-picker-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;display:grid;gap:16px;align-content:start;padding:10px 12px 8px;scroll-padding-block:12px}.emoji-picker-bottom-rail{flex:0 0 auto;position:relative;z-index:1;contain:paint;transform:translateZ(0);backface-visibility:hidden;display:grid;grid-template-columns:repeat(9,minmax(0,1fr));gap:4px;padding:8px 10px calc(10px + env(safe-area-inset-bottom,0px));border-top:1px solid rgba(73,159,183,.12);background:linear-gradient(180deg,#499fb70a,#499fb714),var(--sheet-surface);transition:opacity .13s ease,border-color .14s ease,box-shadow .14s ease}.emoji-picker-bottom-rail.is-searching{opacity:.93}.emoji-picker-rail-button{width:100%;min-width:0;height:34px;border:none;border-radius:11px;background:transparent;color:var(--color-text-muted);position:relative;isolation:isolate;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transform:translateY(0);transition:background-color .11s ease,color .11s ease,opacity 90ms ease,transform .13s cubic-bezier(.2,.8,.2,1)}.emoji-picker-rail-button:after{content:"";position:absolute;left:8px;right:8px;bottom:4px;height:2px;border-radius:999px;background:#499fb78a;opacity:0;transform:scaleX(.6);transition:opacity .11s ease,transform .14s cubic-bezier(.2,.8,.2,1);pointer-events:none}.emoji-picker-rail-button:hover{background:#499fb71c;color:var(--color-text-primary);transform:translateY(-.5px)}.emoji-picker-rail-button.is-active{background:#499fb726;color:var(--color-text-primary);transform:translateY(-1px)}.emoji-picker-rail-button.is-active:after{opacity:.95;transform:scaleX(1)}.emoji-picker-rail-button:active{transform:scale(.96)}.emoji-picker-bottom-rail.is-searching .emoji-picker-rail-button:after{opacity:0}.emoji-picker-bottom-rail.is-searching .emoji-picker-rail-button{opacity:.74}.emoji-picker-rail-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.emoji-picker-rail-button-svg{width:18px;height:18px}.emoji-picker-section{display:grid;gap:10px;scroll-margin-top:10px}.emoji-picker-title{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin:0;padding-left:2px}.emoji-picker-recent-empty{min-height:34px;display:flex;align-items:center;padding:0 2px;color:var(--color-text-muted);font-size:12px}.emoji-picker-grid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:6px;justify-items:center}.emoji-picker-emoji{border:none;background:transparent;width:34px;height:34px;border-radius:11px;display:inline-grid;place-items:center;cursor:pointer;touch-action:manipulation;transform:translateY(0) scale(1);transition:background-color 96ms ease,transform .11s cubic-bezier(.2,.8,.2,1),box-shadow .13s ease}.emoji-picker-emoji:hover{background:#499fb72e;transform:translateY(-1px)}.emoji-picker-emoji:active{background:#499fb73d;transform:translateY(0) scale(.93)}.emoji-picker-emoji:focus-visible{outline:none;box-shadow:var(--focus-ring)}.emoji-picker-emoji-icon{display:inline-flex;align-items:center;justify-content:center;font-size:21px;line-height:1}.emoji-picker-emoji-icon-image{display:block;width:100%;height:auto;object-fit:contain}.emoji-picker-emoji-fallback{display:inline-flex;align-items:center;justify-content:center}.emoji-picker-section-placeholder{width:100%;border-radius:14px;background:transparent}.emoji-glyph{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle}.emoji-glyph--fallback{position:relative;border-radius:6px;border:1px dashed rgba(73,159,183,.58);background:#499fb729}.emoji-glyph-fallback-char{line-height:1}.emoji-glyph-fallback-badge{position:absolute;right:-4px;bottom:-4px;min-width:10px;height:10px;border-radius:999px;border:1px solid rgba(73,159,183,.54);background:var(--color-surface-elevated);color:var(--color-secondary);display:inline-flex;align-items:center;justify-content:center;font-size:6px;font-weight:700;line-height:1}.emoji-picker-empty{border:1px dashed rgba(73,159,183,.28);border-radius:14px;padding:16px 14px;text-align:center;color:var(--color-text-muted);background:#499fb70f;margin:0}@media(max-width:640px){.emoji-picker-panel.is-mobile{height:min(62svh,500px);min-height:280px}.emoji-picker-header{padding:12px 12px 8px}.emoji-picker-search-shell{min-height:42px}.emoji-picker-scroll{padding-top:8px}.emoji-picker-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.emoji-picker-emoji{width:40px;height:40px;border-radius:12px}.emoji-picker-emoji-icon{font-size:22px}.emoji-picker-bottom-rail{gap:3px;padding:8px 8px calc(10px + env(safe-area-inset-bottom,0px))}.emoji-picker-rail-button{height:32px;border-radius:10px}}@media(prefers-reduced-motion:reduce){.emoji-picker-backdrop,.emoji-picker-panel,.emoji-picker-bottom-rail,.emoji-picker-rail-button{transition-duration:1ms!important;transition-delay:0ms!important}.emoji-picker.is-closed .emoji-picker-panel,.emoji-picker-layer.is-closed .emoji-picker-panel,.emoji-picker.is-open .emoji-picker-panel,.emoji-picker-layer.is-open .emoji-picker-panel{transform:none}}.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}.empty-block{color:var(--color-text-muted);border:1px dashed var(--color-border-strong);border-radius:var(--radius-sm);padding:var(--space-4);text-align:center;background:var(--panel-neutral-bg)}.chat-empty-state{border:1px dashed var(--color-border-strong);border-radius:var(--radius-md);padding:var(--space-4);text-align:center;background:var(--panel-neutral-bg)}.chat-empty-title{margin:0;font-family:var(--font-brand);font-size:var(--text-lg);color:var(--color-text-primary)}.chat-empty-description{margin:var(--space-2) 0 0;color:var(--color-text-secondary);font-size:var(--text-sm)}.profile-shell{min-height:var(--app-shell-height);display:flex;justify-content:center;align-items:flex-start;padding:var(--space-7) var(--space-6) var(--space-6);overflow-x:hidden;overflow-x:clip}.profile-page{width:min(780px,100%);min-width:0;display:grid;gap:var(--space-4)}.profile-page-header{border:var(--border-thin);border-radius:var(--radius-lg);background:var(--panel-neutral-strong-bg);box-shadow:var(--shadow-sm);padding:var(--space-5);display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4)}.profile-page-header-main{display:grid;gap:var(--space-2);min-width:0}.profile-page-kicker{margin:0;color:var(--color-secondary);font-size:var(--text-xs);font-weight:700;letter-spacing:.07em;text-transform:uppercase}.profile-page-title{margin:0;font-family:var(--font-brand);font-size:var(--text-2xl);line-height:var(--leading-tight)}.profile-page-subtitle{margin:0;color:var(--color-text-secondary);font-size:var(--text-md);line-height:1.5}.profile-back-button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.profile-page-header-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:var(--space-2)}.profile-page-header-actions .secondary-button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.profile-sections{display:grid;gap:var(--space-4)}.profile-section-card{border:var(--border-thin);border-radius:var(--radius-lg);background:var(--panel-neutral-strong-bg);box-shadow:var(--shadow-sm);padding:var(--space-5);display:grid;gap:var(--space-4);min-width:0}.profile-section-header{display:grid;gap:var(--space-1)}.profile-section-title{margin:0;color:var(--color-text-primary);font-size:var(--text-lg);font-family:var(--font-brand);line-height:var(--leading-tight)}.profile-section-description{margin:0;color:var(--color-text-secondary);font-size:var(--text-sm)}.profile-section-body{display:grid;gap:var(--space-4)}.profile-form-grid{display:grid;gap:var(--space-3)}.profile-field{display:grid;gap:var(--space-1)}.profile-field-hint{margin:0;color:var(--color-text-muted);font-size:var(--text-xs)}.profile-avatar-block{border:var(--border-thin);border-radius:var(--radius-md);background:var(--panel-neutral-bg);padding:var(--space-3);display:grid;gap:var(--space-3)}.profile-avatar-preview-row{display:flex;align-items:flex-start;gap:var(--space-3)}.profile-avatar-trigger{position:relative;border:none;background:transparent;padding:0;margin:0;border-radius:var(--radius-md);cursor:pointer;flex-shrink:0;min-width:88px;min-height:88px}.profile-avatar-trigger:focus-visible{outline:none;box-shadow:var(--focus-ring)}.profile-avatar-trigger:disabled{cursor:not-allowed}.profile-avatar-preview{width:88px;height:88px;border-radius:var(--radius-md);border-color:#bdd7dff5}.profile-avatar-trigger-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;display:grid;place-items:center;gap:4px;color:#f8fdff;background:linear-gradient(180deg,#12313e05,#12313e99);opacity:0;transition:opacity var(--transition-fast);pointer-events:none}.profile-avatar-trigger:hover .profile-avatar-trigger-overlay,.profile-avatar-trigger:focus-visible .profile-avatar-trigger-overlay{opacity:1}.profile-avatar-trigger:disabled .profile-avatar-trigger-overlay{opacity:.72}.profile-avatar-trigger-chip{position:absolute;right:-4px;bottom:-4px;width:28px;height:28px;border-radius:var(--radius-pill);border:1px solid var(--color-border-strong);background:var(--color-surface-elevated);color:var(--color-text-secondary);display:inline-grid;place-items:center;box-shadow:var(--shadow-xs)}.profile-avatar-trigger-chip svg{width:16px;height:16px}.profile-avatar-trigger:disabled .profile-avatar-trigger-chip{opacity:.75}.profile-avatar-trigger-icon{width:22px;height:22px;display:inline-grid;place-items:center}.profile-avatar-trigger-icon svg{width:100%;height:100%}.profile-avatar-trigger-label{font-size:var(--text-xs);font-weight:700;letter-spacing:.02em}.profile-avatar-copy{min-width:0;display:grid;gap:4px}.profile-avatar-title{margin:0;color:var(--color-text-primary);font-size:var(--text-md);font-weight:700}.profile-avatar-description{margin:0;color:var(--color-text-secondary);font-size:var(--text-sm);line-height:1.4}.profile-avatar-hint{margin:2px 0 0;color:var(--color-text-muted);font-size:var(--text-xs)}.profile-avatar-file-input{position:absolute;width:1px;height:1px;border:0;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);clip-path:inset(50%);white-space:nowrap}.profile-avatar-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.profile-avatar-crop-card{border:var(--border-thin);border-radius:var(--radius-sm);background:var(--panel-neutral-bg);padding:var(--space-3);display:grid;gap:var(--space-3);min-width:0;overflow:hidden}.profile-avatar-crop-title{margin:0;color:var(--color-text-primary);font-size:var(--text-sm);font-weight:700}.profile-avatar-crop-shell{position:relative;width:100%;height:280px;border-radius:var(--radius-sm);overflow:hidden;background:#102733}.profile-avatar-zoom-control{display:grid;gap:8px}.profile-avatar-zoom-control input[type=range]{width:100%;margin:0;accent-color:var(--color-primary)}.profile-avatar-crop-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.profile-avatar-progress{width:100%;height:8px;border-radius:var(--radius-pill);background:#7ba7b757;overflow:hidden}.profile-avatar-progress-bar{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--button-primary-start),var(--button-primary-end));transition:width .2s ease}.profile-form-actions{display:flex;align-items:center;gap:var(--space-2);padding-top:var(--space-1)}.profile-form-actions .primary-button{min-height:44px}.profile-feedback{margin:0}.profile-notification-permission{border-radius:var(--radius-sm);border:var(--border-thin);background:var(--panel-neutral-bg);padding:var(--space-3);display:grid;gap:var(--space-2)}.profile-notification-permission.is-neutral{border-color:#bdd7dfe6}.profile-notification-permission.is-warning{border-color:var(--color-warning-border);background:var(--color-warning-surface)}.profile-notification-permission.is-success{border-color:var(--color-success-border);background:var(--color-success-surface)}.profile-notification-permission.is-danger{border-color:var(--color-danger-border);background:var(--color-danger-surface)}.profile-notification-permission-title{margin:0;color:var(--color-text-primary);font-weight:700;font-size:var(--text-sm)}.profile-notification-permission-description{margin:0;color:var(--color-text-secondary);font-size:var(--text-sm)}.profile-notification-cta{display:grid;gap:var(--space-2)}.profile-inline-note{margin:0;color:var(--color-text-muted);font-size:var(--text-xs)}.profile-toggle-list{display:grid;gap:var(--space-2)}.profile-toggle-field{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:flex-start;gap:var(--space-2);border:var(--border-thin);border-radius:var(--radius-sm);background:var(--panel-neutral-bg);padding:11px 12px}.profile-toggle-field input{margin:3px 0 0;width:16px;height:16px;flex-shrink:0}.profile-toggle-title{display:block;color:var(--color-text-primary);font-size:var(--text-sm);font-weight:600;line-height:1.35}.profile-toggle-description{display:block;margin-top:2px;color:var(--color-text-muted);font-size:var(--text-xs);line-height:1.4}.profile-theme-options{display:grid;gap:var(--space-2)}.profile-theme-option{width:100%;border:var(--border-thin);border-radius:var(--radius-sm);background:var(--panel-neutral-bg);text-align:left;padding:11px 12px;display:grid;gap:3px;cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),transform var(--transition-fast)}.profile-theme-option:hover{border-color:var(--color-border-strong);background:var(--panel-neutral-strong-bg)}.profile-theme-option:focus-visible{outline:none;box-shadow:var(--focus-ring)}.profile-theme-option.is-active{border-color:#499fb79e;background:#499fb724}.profile-theme-option-title{font-size:var(--text-sm);color:var(--color-text-primary);font-weight:700}.profile-theme-option-description{font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.4}.profile-meta-list{margin:0;display:grid;gap:var(--space-2)}.profile-meta-item{margin:0;display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3)}.profile-meta-label,.profile-meta-value{margin:0}.profile-meta-label{color:var(--color-text-muted);font-size:var(--text-sm)}.profile-meta-value{color:var(--color-text-primary);font-size:var(--text-sm);font-weight:600;text-align:right;word-break:break-word}.profile-session-actions{display:flex;gap:var(--space-2)}.profile-danger-button{border-radius:var(--radius-sm);border:1px solid var(--color-danger-border);background:var(--color-danger-surface);color:var(--color-danger);font-weight:700;padding:10px 13px;min-height:44px;cursor:pointer;transition:transform var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast)}.profile-danger-button:hover{transform:translateY(-1px);border-color:#ca4c61b8;background:#e8647f2e}.profile-danger-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.profile-danger-button:disabled{opacity:var(--state-disabled-opacity);cursor:not-allowed;transform:none}.inapp-toast-center{position:fixed;right:20px;bottom:20px;z-index:1300;width:min(380px,calc(100% - 24px));display:grid;gap:10px}.inapp-toast{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;border:var(--border-thin);border-color:#6fb2bdb3;border-radius:var(--radius-md);background:var(--toast-surface);box-shadow:var(--shadow-md);overflow:hidden}.inapp-toast-main{border:none;background:transparent;text-align:left;display:grid;gap:4px;padding:12px;cursor:pointer}.inapp-toast-main:hover{background:#499fb729}.inapp-toast-title{color:var(--color-text-primary);font-size:var(--text-sm)}.inapp-toast-body{color:var(--color-text-secondary);font-size:var(--text-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inapp-toast-dismiss{border:none;border-left:var(--border-thin);background:transparent;color:var(--color-text-muted);width:36px;cursor:pointer;font-size:13px;line-height:1}.inapp-toast-dismiss:hover{background:#499fb729}.desktop-build-badge{width:100%;pointer-events:none;display:grid;gap:1px;border:1px solid rgba(95,140,160,.24);border-radius:var(--radius-xs);background:#fbfeffa8;box-shadow:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:5px 8px;opacity:.74}.desktop-build-badge.channel-lan{border-color:#8f6a1f42;background:#fffbf29e}.desktop-build-badge.channel-beta{border-color:#30bbc040}.desktop-build-badge.channel-local{border-color:#4c74843d}.desktop-build-badge strong{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:#3d5a6ae6}.desktop-build-badge span{font-size:10px;line-height:1.3;color:#293e4bc7;word-break:break-word}@keyframes rise-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes sidebar-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes sidebar-logo-spark-ring{0%{opacity:0;transform:rotate(-28deg)}14%{opacity:.96}82%{opacity:.84}to{opacity:0;transform:rotate(336deg)}}@keyframes sidebar-logo-spark-glint{0%{opacity:0;transform:scale(.76)}34%{opacity:.65}to{opacity:0;transform:scale(1.26)}}@media(prefers-reduced-motion:reduce){.sidebar-center-logo,.sidebar-center-logo-ring:before,.sidebar-center-logo-glint{animation:none!important;transition:none!important}}@media(max-width:980px){.messenger-layout{grid-template-columns:1fr}.sidebar-center-logo-wrap,.sidebar-bottom-meta{display:none}.sidebar-top{padding:calc(var(--space-3) + env(safe-area-inset-top,0px)) var(--space-3) var(--space-3)}.sidebar-brand-mark{width:36px;height:36px}.sidebar-logo{width:22px;height:22px}.sidebar-menu-toggle{width:40px;height:40px}.wellness-card{padding:6px 6px 3px}.wellness-metric-grid{justify-content:flex-start;gap:7px}.wellness-metric-value{font-size:11px}.wellness-card-details{padding-top:4px}.wellness-card-handle{padding-bottom:2px}.sidebar{height:100%;min-height:0;border-right:none;border-bottom:none}.chat-panel{height:100%;min-height:0}.chat-header{padding:calc(var(--space-2) + env(safe-area-inset-top,0px)) var(--space-3) var(--space-2)}.connection-pill{display:none}.chat-scroll{padding:var(--space-3) var(--space-3) calc(var(--space-3) + 6px);gap:var(--space-2)}.conversation-list,.sidebar-menu-panel{padding:var(--space-2) var(--space-2) calc(var(--space-3) + env(safe-area-inset-bottom,0px))}.sidebar-menu-item{min-height:56px}.conversation-row{min-height:72px}.search-results{padding:var(--space-2)}.notification-first-run-actions .secondary-button{width:100%}.user-result-row{min-height:50px}.composer{padding:var(--space-2) var(--space-3) calc(var(--space-2) + env(safe-area-inset-bottom,0px))}.composer-reply-preview{padding:7px 9px}.message-action-sheet-menu.mobile{left:8px;right:8px;bottom:calc(8px + env(safe-area-inset-bottom,0px))}.message-stack{max-width:min(88%,560px)}.message-stack.is-single-emoji{max-width:min(68%,400px)}.message-bubble{max-width:100%}.profile-shell{padding:calc(var(--space-4) + env(safe-area-inset-top,0px)) var(--space-3) calc(var(--space-5) + env(safe-area-inset-bottom,0px))}.profile-page,.profile-section-body{gap:var(--space-3)}.profile-page-header{padding:var(--space-4);flex-direction:column;align-items:stretch}.profile-page-title{font-size:var(--text-xl)}.profile-page-subtitle{font-size:var(--text-sm)}.profile-back-button{width:100%}.profile-page-header-actions{display:grid}.profile-page-header-actions .secondary-button{width:100%}.profile-section-card{padding:var(--space-4);gap:var(--space-3)}.profile-form-actions .primary-button{width:100%}.profile-avatar-preview-row{align-items:flex-start}.profile-avatar-preview{width:74px;height:74px}.profile-avatar-trigger{min-width:74px;min-height:74px}.profile-avatar-trigger-chip{width:26px;height:26px}.profile-avatar-actions{display:grid}.profile-avatar-actions .secondary-button,.profile-avatar-actions .profile-danger-button{width:100%}.profile-avatar-crop-shell{height:240px}.profile-avatar-crop-actions,.profile-session-actions{display:grid}.profile-danger-button{width:100%}.profile-meta-item{display:grid;gap:2px;justify-content:start}.profile-meta-value{text-align:left}.inapp-toast-center{right:12px;left:12px;bottom:calc(12px + env(safe-area-inset-bottom,0px));width:auto}}
