:root{--c-bg-1: #f5efe4;--c-bg-2: #e7efe9;--c-surface: #fffcf6;--c-surface-2: #f7f2e9;--c-border: rgba(39, 93, 90, .12);--c-border-strong: rgba(39, 93, 90, .22);--c-text: #14302f;--c-text-muted: #5a7475;--c-text-subtle: #82979a;--c-accent: #1f7a75;--c-accent-strong: #185f5b;--c-accent-soft: rgba(31, 122, 117, .12);--c-own: #d8ebe4;--c-own-border: rgba(31, 122, 117, .22);--c-danger: #b13838;--c-danger-soft: rgba(177, 56, 56, .1);--c-warn: #b07023;--c-warn-soft: rgba(176, 112, 35, .14);--c-ok: #1f7a75;--c-ok-soft: rgba(31, 122, 117, .14);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;--fs-xs: .75rem;--fs-sm: .85rem;--fs-base: .95rem;--fs-md: 1.05rem;--fs-lg: 1.25rem;--fs-xl: clamp(1.5rem, 3.5vw, 2rem);--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--r-sm: 10px;--r-md: 14px;--r-lg: 20px;--r-xl: 26px;--r-pill: 999px;--sh-1: 0 1px 2px rgba(20, 48, 47, .06), 0 2px 6px rgba(20, 48, 47, .04);--sh-2: 0 6px 18px rgba(20, 48, 47, .08);--sh-3: 0 12px 30px rgba(20, 48, 47, .12);color:var(--c-text);background:radial-gradient(1200px 600px at 50% -10%,rgba(255,255,255,.7),transparent 60%),linear-gradient(180deg,var(--c-bg-1) 0%,var(--c-bg-2) 100%);background-attachment:fixed;font-family:var(--font-sans);font-size:var(--fs-base);line-height:1.5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light}*{box-sizing:border-box}html,body{height:100%}body{margin:0;min-width:320px;min-height:100dvh}#root{min-height:100dvh;display:flex;flex-direction:column}button,input,textarea{font:inherit;color:inherit}button{border:0;cursor:pointer;background:none}button:disabled,input:disabled,textarea:disabled{cursor:not-allowed}input,textarea{width:100%;border:1px solid var(--c-border-strong);border-radius:var(--r-md);padding:.75rem .9rem;background:var(--c-surface);color:inherit;transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease}input:focus,textarea:focus{outline:none;border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-soft)}textarea{resize:none;min-height:44px;line-height:1.45}::selection{background:var(--c-accent-soft)}@media(hover:hover)and (pointer:fine){.timeline{scrollbar-width:thin;scrollbar-color:rgba(39,93,90,.25) transparent}.timeline::-webkit-scrollbar{width:8px}.timeline::-webkit-scrollbar-thumb{background:#275d5a38;border-radius:999px}.timeline::-webkit-scrollbar-track{background:transparent}}.splash-screen,.auth-shell{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--sp-5)}.splash-card,.auth-card{width:min(100%,28rem);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-xl);box-shadow:var(--sh-3);padding:1.75rem;display:grid;gap:1.1rem}.brand-block{display:grid;gap:.5rem;text-align:center;justify-items:center}.brand-emblem{width:56px;height:56px;display:grid;place-items:center;border-radius:18px;background:linear-gradient(135deg,var(--c-accent),var(--c-accent-strong));color:#fff;box-shadow:var(--sh-2);margin-bottom:.25rem}.brand-emblem svg{width:28px;height:28px}.brand-block h1,.splash-card h1{margin:0;font-size:var(--fs-xl);line-height:1.2;letter-spacing:-.01em;font-weight:700}.support-copy{margin:0;color:var(--c-text-muted);font-size:var(--fs-sm)}.eyebrow{margin:0;color:var(--c-accent);font-size:var(--fs-xs);font-weight:700;letter-spacing:.16em;text-transform:uppercase}.auth-toggle{display:grid;grid-template-columns:repeat(2,1fr);gap:.25rem;background:var(--c-bg-2);border-radius:var(--r-pill);padding:.25rem}.toggle-button{border-radius:var(--r-pill);background:transparent;color:var(--c-text-muted);padding:.6rem .9rem;font-weight:600;font-size:var(--fs-sm);transition:background-color .16s ease,color .16s ease,box-shadow .16s ease}.toggle-button.active{background:var(--c-surface);color:var(--c-text);box-shadow:var(--sh-1)}.field{display:grid;gap:.35rem}.field span{font-size:var(--fs-sm);font-weight:600;color:var(--c-text-muted)}.auth-form{display:grid;gap:.85rem}.primary-button,.secondary-button{border-radius:var(--r-md);padding:.8rem 1.05rem;font-weight:600;font-size:var(--fs-base);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;transition:transform .12s ease,background-color .16s ease,box-shadow .16s ease,color .16s ease,opacity .16s ease}.primary-button{background:linear-gradient(135deg,var(--c-accent),var(--c-accent-strong));color:#fff;box-shadow:var(--sh-1)}.primary-button:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--sh-2)}.primary-button:not(:disabled):active{transform:translateY(0)}.secondary-button{background:var(--c-accent-soft);color:var(--c-accent-strong)}.secondary-button:not(:disabled):hover{background:#1f7a752e}.primary-button:disabled,.secondary-button:disabled,.toggle-button:disabled{opacity:.55;transform:none;box-shadow:none}.inline-button{padding:.6rem .85rem;font-size:var(--fs-sm)}.text-button{background:transparent;color:var(--c-accent);font-weight:600;padding:0;font-size:var(--fs-sm)}.text-button:hover{color:var(--c-accent-strong);text-decoration:underline}.icon-button{width:40px;height:40px;display:inline-grid;place-items:center;border-radius:var(--r-md);background:var(--c-accent-soft);color:var(--c-accent-strong);transition:background-color .16s ease,transform .12s ease}.icon-button:not(:disabled):hover{background:#1f7a752e}.icon-button:disabled{opacity:.55}.icon-button svg{width:20px;height:20px}.icon-button.send{background:linear-gradient(135deg,var(--c-accent),var(--c-accent-strong));color:#fff;box-shadow:var(--sh-1)}.icon-button.send:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--sh-2)}.notice-banner,.error-banner{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin:0;border-radius:var(--r-md);padding:.7rem .9rem;font-size:var(--fs-sm);line-height:1.4;flex-wrap:wrap}.notice-banner{background:var(--c-accent-soft);color:var(--c-accent-strong)}.error-banner{background:var(--c-danger-soft);color:var(--c-danger)}.chat-shell{display:grid;grid-template-rows:auto 1fr auto;height:100dvh;width:100%;max-width:56rem;margin:0 auto;padding:var(--sp-3) var(--sp-3) 0;padding-bottom:env(safe-area-inset-bottom);gap:var(--sp-3);overflow:hidden}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);padding:.5rem .25rem;border-bottom:1px solid var(--c-border);min-height:56px}.chat-header-info{display:flex;align-items:center;gap:.65rem;min-width:0}.chat-header-info .brand-emblem{width:40px;height:40px;border-radius:12px;margin:0;flex-shrink:0}.chat-header-info .brand-emblem svg{width:22px;height:22px}.chat-header-titles{display:grid;min-width:0}.chat-header-titles .eyebrow{font-size:.65rem;letter-spacing:.14em}.chat-header h1{margin:0;font-size:var(--fs-md);font-weight:600;line-height:1.3;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.chat-header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.connection-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .7rem;border-radius:var(--r-pill);font-size:var(--fs-xs);font-weight:600;white-space:nowrap;background:var(--c-bg-2);color:var(--c-text-muted)}.connection-dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0}.connection-pill.connecting,.connection-pill.reconnecting{background:var(--c-warn-soft);color:var(--c-warn)}.connection-pill.connecting .connection-dot,.connection-pill.reconnecting .connection-dot{animation:pulse 1.4s ease-in-out infinite}.connection-pill.connected{background:var(--c-ok-soft);color:var(--c-ok)}.connection-pill.disconnected{background:var(--c-danger-soft);color:var(--c-danger)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.85)}}.timeline{display:flex;flex-direction:column;gap:.35rem;align-content:start;min-height:0;overflow-y:auto;overflow-x:hidden;padding:.5rem .25rem 1rem;scroll-behavior:smooth;overscroll-behavior:contain}.timeline-state{flex:1;display:grid;place-content:center;gap:.5rem;min-height:14rem;color:var(--c-text-muted);text-align:center;padding:2rem}.timeline-state .empty-illustration{margin:0 auto .5rem;width:88px;height:88px;display:grid;place-items:center;border-radius:28px;background:var(--c-accent-soft);color:var(--c-accent)}.timeline-state .empty-illustration svg{width:44px;height:44px}.timeline-state strong{display:block;font-size:var(--fs-md);color:var(--c-text);font-weight:600}.older-button{align-self:center;margin:.25rem 0 .5rem}.message-card{display:grid;gap:.4rem;max-width:min(75%,32rem);padding:.55rem .8rem .5rem;border-radius:18px 18px 18px 6px;background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--sh-1);align-self:flex-start;animation:bubble-in .18s ease}.message-card.own-message{align-self:flex-end;background:var(--c-own);border-color:var(--c-own-border);border-radius:18px 18px 6px}.message-card[data-grouped=true]{border-radius:18px 18px 18px 14px;margin-top:-.15rem}.message-card.own-message[data-grouped=true]{border-radius:18px 18px 14px}.message-card:not([data-grouped=true]){margin-top:.5rem}.message-card:first-child{margin-top:0}.sender-name{font-size:var(--fs-xs);font-weight:600;color:var(--c-accent-strong);letter-spacing:.01em}.message-text{margin:0;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;font-size:var(--fs-base);line-height:1.45}.message-meta{display:flex;align-items:center;justify-content:flex-end;gap:.35rem;font-size:var(--fs-xs);color:var(--c-text-subtle);font-feature-settings:"tnum" 1;margin-top:.05rem}@keyframes bubble-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.attachment-grid{display:grid;gap:.5rem}.attachment-card{display:grid;border-radius:var(--r-md);overflow:hidden;background:#fff9;border:1px solid var(--c-border);max-width:100%}.attachment-image-wrap{display:block;border:0;padding:0;width:100%;cursor:zoom-in;background:var(--c-bg-2)}.attachment-preview{display:block;width:100%;max-height:280px;object-fit:cover}.attachment-placeholder{display:grid;grid-template-columns:40px 1fr;align-items:center;gap:.6rem;padding:.6rem .75rem;background:#ffffff8c;color:var(--c-text-muted);font-size:var(--fs-sm)}.attachment-placeholder.loading,.attachment-placeholder.failed{display:grid;place-items:center;min-height:7rem;text-align:center}.attachment-icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:var(--c-accent-soft);color:var(--c-accent-strong)}.attachment-icon svg{width:22px;height:22px}.attachment-foot{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .65rem;border-top:1px solid var(--c-border);background:#ffffff80}.attachment-meta{display:grid;gap:.05rem;min-width:0}.attachment-meta strong{font-size:var(--fs-sm);font-weight:600;line-height:1.25;color:var(--c-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-meta span{font-size:var(--fs-xs);color:var(--c-text-subtle)}.attachment-download{flex-shrink:0}.lightbox-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a1919d9;display:grid;place-items:center;padding:1rem;z-index:50;animation:fade-in .16s ease}.lightbox-image{max-width:100%;max-height:90dvh;border-radius:12px;box-shadow:0 20px 50px #00000080}.lightbox-close{position:fixed;top:max(1rem,env(safe-area-inset-top));right:1rem;width:44px;height:44px;border-radius:50%;background:#ffffff26;color:#fff;display:grid;place-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lightbox-close:hover{background:#ffffff40}.lightbox-close svg{width:22px;height:22px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.composer-wrap{position:sticky;bottom:0;padding-bottom:max(var(--sp-3),env(safe-area-inset-bottom));padding-top:.5rem;background:linear-gradient(180deg,rgba(245,239,228,0) 0%,var(--c-bg-1) 30%)}.composer{display:grid;gap:.5rem;padding:.65rem .75rem;border-radius:var(--r-lg);background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--sh-2)}.composer-row{display:grid;grid-template-columns:auto 1fr auto;align-items:end;gap:.5rem}.composer-field{display:block;min-width:0}.composer-field textarea{border:0;background:transparent;padding:.55rem .4rem;border-radius:0;min-height:2.6rem;max-height:40dvh;overflow-y:auto}.composer-field textarea:focus{box-shadow:none}.selected-file{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.6rem;padding:.4rem .5rem;border-radius:var(--r-md);background:var(--c-surface-2);border:1px solid var(--c-border)}.selected-file-thumb{width:40px;height:40px;border-radius:8px;object-fit:cover;background:var(--c-bg-2)}.selected-file-thumb.placeholder{display:grid;place-items:center;color:var(--c-accent-strong)}.selected-file-thumb.placeholder svg{width:20px;height:20px}.selected-file-info{display:grid;min-width:0}.selected-file-info strong{font-size:var(--fs-sm);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-file-info span{font-size:var(--fs-xs);color:var(--c-text-subtle)}.composer-error{margin:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media(min-width:768px){.auth-card{padding:2rem}.chat-shell{padding:var(--sp-5) var(--sp-5) 0;gap:var(--sp-4)}.attachment-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.message-card{max-width:30rem}}@media(min-width:1024px){.chat-shell{max-width:60rem}}@media(max-width:480px){:root{font-size:.95rem}.chat-shell{padding:var(--sp-2) var(--sp-2) 0;gap:var(--sp-2)}.chat-header{min-height:52px;padding:.25rem .1rem}.message-card{max-width:88%}.composer{padding:.5rem .55rem;border-radius:var(--r-md)}}@media(max-width:380px){.chat-header-info .brand-emblem{width:36px;height:36px;border-radius:10px}.chat-header-info .brand-emblem svg{width:20px;height:20px}.chat-header h1{font-size:var(--fs-base)}.chat-header-titles .eyebrow,.connection-pill .connection-text{display:none}.connection-pill{padding:.4rem;width:28px;height:28px;justify-content:center}.connection-dot{width:10px;height:10px}.chat-header-actions .logout-text{display:none}.icon-button{width:36px;height:36px}.message-card{max-width:92%;padding:.5rem .7rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}.timeline{scroll-behavior:auto}}
