:root{--bg: #000000;--surface: #0a0a0a;--border: #495057;--text: #f8f9fa;--muted: rgba(222, 226, 230, .72);--accent: #1077aa;--accent-dim: #0d5f85;--danger: #dc3545;--tab-active-bg: #ffffff;--tab-active-fg: #000000;--radius: 0;--font: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;--mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;--link: #ffffff;--hover-bg: rgba(255, 255, 255, .06);--btn-fg: #ffffff;--tab-close-active: #555555;--tab-close-border-active: rgba(0, 0, 0, .15);--ok: #75b798;--ok-bg: rgba(117, 183, 152, .12);--ok-border: rgba(117, 183, 152, .35);--err-bg: rgba(232, 93, 106, .12);--err-fg: #f0909a;--err-border: rgba(232, 93, 106, .3);--accent-tint-bg: rgba(16, 119, 170, .08);--accent-tint-border: rgba(16, 119, 170, .45);--accent-strong-border: rgba(16, 119, 170, .5);--accent-tint-tag-bg: rgba(16, 119, 170, .12);--accent-tag-fg: #7ec8e8;--danger-tint-bg: rgba(232, 93, 106, .06);--danger-tint-border: rgba(232, 93, 106, .4);--danger-tag-bg: rgba(232, 93, 106, .3);--danger-tag-fg: #ffb8bf;--accent-line: rgba(16, 119, 170, .22);--chat-out-bg: rgba(16, 119, 170, .2);--chat-out-border: rgba(16, 119, 170, .4);--focus-shadow: rgba(16, 119, 170, .25);--danger-hover-bg: rgba(220, 53, 69, .12);--dot-shadow: rgba(0, 0, 0, .35);--dot-shadow-active: rgba(0, 0, 0, .15);--qr-bg: #ffffff}[data-theme=light]{--bg: #ffffff;--surface: #f5f5f5;--border: #d0d4d8;--text: #1a1a1a;--muted: rgba(60, 64, 68, .72);--accent: #0e6999;--accent-dim: #0b5479;--danger: #c62828;--tab-active-bg: #1a1a1a;--tab-active-fg: #ffffff;--link: #1a1a1a;--hover-bg: rgba(0, 0, 0, .05);--btn-fg: #ffffff;--tab-close-active: #aaaaaa;--tab-close-border-active: rgba(255, 255, 255, .2);--ok: #2e7d50;--ok-bg: rgba(46, 125, 80, .1);--ok-border: rgba(46, 125, 80, .35);--err-bg: rgba(198, 40, 40, .08);--err-fg: #c62828;--err-border: rgba(198, 40, 40, .25);--accent-tint-bg: rgba(14, 105, 153, .06);--accent-tint-border: rgba(14, 105, 153, .35);--accent-strong-border: rgba(14, 105, 153, .45);--accent-tint-tag-bg: rgba(14, 105, 153, .1);--accent-tag-fg: #0e6999;--danger-tint-bg: rgba(198, 40, 40, .04);--danger-tint-border: rgba(198, 40, 40, .3);--danger-tag-bg: rgba(198, 40, 40, .12);--danger-tag-fg: #c62828;--accent-line: rgba(14, 105, 153, .18);--chat-out-bg: rgba(14, 105, 153, .1);--chat-out-border: rgba(14, 105, 153, .3);--focus-shadow: rgba(14, 105, 153, .2);--danger-hover-bg: rgba(198, 40, 40, .08);--dot-shadow: rgba(255, 255, 255, .5);--dot-shadow-active: rgba(255, 255, 255, .3);--qr-bg: #ffffff}*{box-sizing:border-box}[hidden]{display:none!important}html{height:100%}body{margin:0;height:100%;min-height:100dvh;display:flex;flex-direction:column;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--font);font-size:1rem;line-height:1.5}a{color:var(--link);text-decoration:none}a:hover{color:var(--accent)}#app{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;width:100%;max-width:none;margin:0;padding:0}.app-shell{display:grid;grid-template-columns:minmax(11.5rem,15rem) 1fr;grid-template-rows:minmax(0,1fr);flex:1;min-height:0;align-self:stretch;border:1px solid var(--border);background:var(--bg)}.app-sidebar{border-right:1px solid var(--border);background:var(--bg);display:flex;flex-direction:column;min-height:0;min-width:0}.sidebar-chats-panel{flex:1;min-height:0;display:flex;flex-direction:column;border-top:1px solid var(--border)}.sidebar-chat-tabs-wrap{flex:1;min-height:0;overflow-y:auto;margin:0;padding:0}.sidebar-chat-tabs-wrap .chat-tabs--sidebar{min-height:0}.sidebar-body{padding:0 .65rem .65rem;font-size:.78rem;color:var(--muted)}.app-main{display:flex;flex-direction:column;flex:1;min-width:0;min-height:0;background:var(--bg)}.dashboard-tabs{display:flex;flex-wrap:wrap;align-items:stretch;gap:0;border-bottom:1px solid var(--border);background:var(--bg)}.sidebar-main-nav{display:flex;flex-direction:column;flex-shrink:0;border-bottom:1px solid var(--border)}.sidebar-tablist{display:flex;flex-direction:column;flex-wrap:nowrap;align-items:stretch}.app-sidebar .dash-tab{width:100%;text-align:left;border:none;border-bottom:1px solid var(--border);padding:.48rem .65rem;margin:0}.app-sidebar .dash-tab:last-child{border-bottom:none}.app-sidebar .dash-tab-external{display:flex;align-items:center;justify-content:space-between;gap:.4rem;color:var(--text);text-decoration:none}.app-sidebar .dash-tab-external:hover{color:var(--text);text-decoration:none}.dash-tab-ext-icon{font-size:.85em;color:var(--muted)}.dash-tab{font:inherit;margin:0;padding:.45rem .85rem;border:none;border-right:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;letter-spacing:.02em}.dash-tab:last-child{border-right:none}.dash-tab:hover:not(.active){background:var(--hover-bg)}.dash-tab.active{background:var(--tab-active-bg);color:var(--tab-active-fg)}.dash-tab:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;z-index:1}.view-panel{flex:1;padding:.85rem 1rem 1.1rem;overflow:auto;min-height:0}.view-panel[hidden]{display:none!important}#view-newchat.view-panel{display:flex;flex-direction:column;min-height:0;padding-top:.65rem;padding-bottom:.75rem;overflow-y:auto}#view-chats.view-panel{display:flex;flex-direction:column;min-height:0;padding-top:.65rem;padding-bottom:.75rem;overflow:hidden}#view-chats.view-panel>*:not(#chatThread):not(.empty-state){flex-shrink:0}#view-chats #chatThread{flex:1;min-height:0}.key-disclosure{border:1px solid var(--border);margin-bottom:.65rem;background:var(--surface)}.key-summary{list-style:none;cursor:pointer;padding:.55rem .7rem;font-size:.82rem;font-weight:600;color:var(--text);-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:.45rem}.key-summary::-webkit-details-marker{display:none}.key-summary:before{content:"▸";display:inline-block;width:.85rem;font-size:.72rem;color:var(--muted);transition:transform .18s ease;flex-shrink:0}.key-disclosure[open]>.key-summary:before{transform:rotate(90deg)}.key-summary:hover:before,.key-disclosure[open]>.key-summary:before{color:var(--accent)}.key-summary:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.key-summary .key-tag{margin-left:.15rem;font-weight:600}.key-disclosure-body{padding:0 .65rem .65rem;border-top:1px solid var(--border)}.site-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem .75rem;flex-shrink:0;padding:.45rem .65rem;margin:0;border-bottom:1px solid var(--border)}.site-brand{display:flex;flex-wrap:nowrap;align-items:baseline;gap:.35rem .65rem;min-width:0}.site-header-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.35rem;flex-shrink:0}button.site-header-btn{font-size:.72rem;padding:.28rem .5rem;line-height:1.2;white-space:nowrap}.invite-link-block{margin:.45rem 0 .55rem}.invite-link-hint{margin:0 0 .4rem;font-size:.78rem;color:var(--muted);line-height:1.45}.share-field-group{margin-bottom:.55rem}.share-field-group:last-child{margin-bottom:0}.share-field-input[readonly],.share-field-textarea[readonly]{cursor:text}.share-field-row{display:flex;gap:.4rem;align-items:stretch}.share-field-row .share-field-input{flex:1;min-width:0}.share-field-copy{flex-shrink:0;white-space:nowrap;font-size:.78rem;padding:0 .7rem;line-height:1}.invite-share-row{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;margin-top:.5rem}.invite-share-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-right:.1rem}.invite-share-btn{font-size:.78rem;line-height:1;padding:.45rem .75rem;white-space:nowrap}.invite-share-btn[hidden]{display:none}@media(max-width:520px){.invite-share-row{gap:.35rem}.invite-share-label{flex-basis:100%;margin:0}.invite-share-btn{flex:1 1 0;min-width:5rem;justify-content:center;padding:.55rem .5rem}}.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}.key-pub-field{min-height:4.5rem;resize:none;margin-bottom:.5rem;word-break:break-all}.brand-name{font-size:1.25rem;letter-spacing:-.02em}.brand-path{font-family:var(--mono);font-size:.95rem;color:var(--muted)}.footer-live{display:flex;flex-direction:row;align-items:center;gap:.5rem;text-align:left;max-width:min(100%,28rem);min-width:0}.site-footer{flex-shrink:0;margin-top:0;padding:.55rem .75rem;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.4rem 1.25rem}.footer-meta{margin:0;font-size:.78rem;color:var(--muted);text-align:right;display:inline-flex;flex-wrap:wrap;align-items:center;gap:.35rem .55rem;line-height:1.4}.footer-meta>.footer-sep{opacity:.5;-webkit-user-select:none;user-select:none}.footer-meta .footer-link{color:var(--muted);padding:.25rem .45rem;border-radius:var(--radius);border:1px solid transparent}.footer-meta .footer-link-discord{display:inline-flex;align-items:center;justify-content:center;line-height:0;padding:.25rem .4rem;min-height:28px}.footer-meta .footer-link-discord .footer-icon{display:block}.footer-meta .footer-link:hover{color:var(--text);border-color:var(--border)}.footer-meta .footer-link:focus-visible{color:var(--accent);outline:2px solid var(--accent);outline-offset:1px}.footer-toggle,.theme-toggle{font-family:var(--font);font-size:.72rem;padding:.3rem .55rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;white-space:nowrap;vertical-align:middle;display:inline-flex;align-items:center;gap:.3rem;min-height:28px}.footer-toggle:hover,.theme-toggle:hover{color:var(--text);border-color:var(--accent)}.footer-toggle:focus-visible,.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.notif-toggle .notif-toggle-glyph{width:.9em;height:.9em;display:inline-block;position:relative;background-color:currentColor;mask-repeat:no-repeat;mask-position:center;mask-size:contain;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;-webkit-mask-size:contain;--bell-svg: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M18 8a6 6 0 0 0-12 0c0 7-3 9-3 9h18s-3-2-3-9'/><path d='M13.73 21a2 2 0 0 1-3.46 0'/></svg>");mask-image:var(--bell-svg);-webkit-mask-image:var(--bell-svg)}.notif-toggle.is-granted{color:var(--accent);border-color:var(--accent)}.notif-toggle.is-denied{color:var(--muted);opacity:.75}.notif-toggle.is-denied .notif-toggle-glyph{--bell-svg: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M13.73 21a2 2 0 0 1-3.46 0'/><path d='M18.63 13A17.89 17.89 0 0 1 18 8'/><path d='M6.26 6.26A5.86 5.86 0 0 0 6 8c0 7-3 9-3 9h14'/><path d='M18 8a6 6 0 0 0-9.33-5'/><line x1='1' y1='1' x2='23' y2='23'/></svg>");mask-image:var(--bell-svg);-webkit-mask-image:var(--bell-svg)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.35rem;margin-bottom:1rem}.panel h2{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 .85rem;font-weight:600}.about-panel .about-lead{font-size:.9rem;color:var(--text);line-height:1.5;margin:0 0 .85rem}.about-list{margin:0;padding-left:1.15rem;font-size:.86rem;color:var(--muted);line-height:1.55}.about-list li{margin-bottom:.65rem}.about-list li:last-child{margin-bottom:0}.about-list strong{color:var(--text)}.about-source-link{display:flex;flex-wrap:wrap;align-items:center;gap:.55rem .85rem}.about-source-cta{display:inline-flex;align-items:center;padding:.5rem .85rem;border:1px solid var(--accent-tint-border);background:var(--accent-tint-bg);color:var(--text);font-weight:600;font-size:.85rem;border-radius:var(--radius)}.about-source-cta:hover{border-color:var(--accent);background:var(--accent-tint-tag-bg);color:var(--text)}.about-source-cta:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.about-source-note{color:var(--muted);font-size:.85rem}.mono-inline{font-family:var(--mono);font-size:.82em}label{display:block;font-size:.82rem;color:var(--muted);margin-bottom:.35rem;letter-spacing:.01em}input[type=text],textarea{width:100%;padding:.5rem .6rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:var(--mono);font-size:.8rem}textarea{min-height:88px;resize:vertical}input:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 .2rem var(--focus-shadow)}.row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end;margin-bottom:.85rem}.row:last-child{margin-bottom:0}.row>div{flex:1;min-width:140px}.open-chat-row .open-chat-input-wrap,.library-search-row .library-search-wrap{flex:1 1 220px;min-width:0}button{font-family:var(--font);font-weight:600;font-size:.85rem;padding:.45rem .85rem;border-radius:var(--radius);border:1px solid var(--accent);cursor:pointer;background:var(--accent);color:var(--btn-fg)}button:hover{filter:brightness(1.08)}button.secondary{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-weight:600;cursor:pointer}a.secondary{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-weight:600;padding:.45rem .85rem;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}a.secondary:hover{color:var(--text);filter:brightness(1.08);text-decoration:none}button:disabled{opacity:.45;cursor:not-allowed;filter:none}button.dash-tab{border:none;border-right:1px solid var(--border);background:transparent;color:var(--text);filter:none}button.dash-tab:hover:not(:disabled):not(.active){filter:none;background:var(--hover-bg)}button.dash-tab.active{background:var(--tab-active-bg);color:var(--tab-active-fg);filter:none}button.dash-tab:last-child{border-right:none}.chat-tab button{border:none;background:transparent;color:inherit;filter:none;font-weight:400}.chat-tab.active button.chat-tab-label{color:var(--tab-active-fg)}.chat-tab button.chat-tab-close{border-left:1px solid var(--border);font-weight:600;font-size:1rem;line-height:1;padding:.15rem .4rem}.chat-tab.active button.chat-tab-close{color:var(--tab-close-active);border-left-color:var(--tab-close-border-active)}.chat-tab button.chat-tab-close:hover{color:var(--danger);background:var(--danger-hover-bg)}.fp{font-family:var(--mono);font-size:.78rem;word-break:break-all;color:var(--text);background:var(--bg);padding:.5rem .65rem;border-radius:var(--radius);border:1px solid var(--border)}.status{font-size:.85rem;margin-top:.5rem}.status.err{color:var(--danger)}.status.ok{color:var(--ok)}.messages{display:flex;flex-direction:column;gap:.65rem;max-height:min(420px,42vh);overflow-y:auto}.msg{padding:.55rem .6rem;border-radius:var(--radius);background:var(--bg);border-bottom:1px solid var(--border);font-size:.85rem}.msg:last-child{border-bottom:none}.msg .meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:.45rem .7rem;font-size:.72rem;color:var(--muted);margin-bottom:.3rem}.msg .msg-sender{color:var(--text);font-weight:600;letter-spacing:.01em}.msg .msg-when{color:var(--muted);font-family:var(--mono);font-size:.7rem}.msg .body{white-space:pre-wrap;word-break:break-word;line-height:1.5}.badge{display:inline-block;font-size:.65rem;padding:.1rem .35rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--muted);margin-right:.35rem;vertical-align:middle}.library-pager{display:none;align-items:center;justify-content:center;flex-wrap:wrap;gap:.75rem 1rem;flex-shrink:0;margin-top:auto;padding-top:.5rem;border-top:1px solid var(--border)}#view-library.view-panel{display:flex;flex-direction:column;min-height:0;overflow:hidden}#view-library .key-intro,#view-library>.row{flex-shrink:0}#view-library #libraryList.messages{flex:1 1 0;min-height:0;max-height:none;overflow-y:auto}.library-page-info{font-size:.82rem;color:var(--muted);font-family:var(--mono)}.server-retention{font-size:.86rem;color:var(--muted);line-height:1.45;margin:.65rem 0 0}.server-retention strong{color:var(--text)}.server-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.65rem;margin:.85rem 0 0}.server-info-card{border:1px solid var(--border);background:var(--surface);padding:.7rem .85rem;display:flex;flex-direction:column;gap:.2rem}.server-info-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}.server-info-value{font-size:1.25rem;color:var(--text);font-weight:700;line-height:1.1}.server-info-hint{font-size:.72rem;color:var(--muted);line-height:1.4}.server-selfhost{display:block;margin-top:1.25rem;padding:.95rem 1.05rem;border:1px solid var(--accent-tint-border);border-left:3px solid var(--accent);background:var(--accent-tint-bg);border-radius:var(--radius)}.server-selfhost-title{margin:0 0 .5rem;font-size:.95rem;font-weight:700;color:var(--fg);letter-spacing:.01em}.server-selfhost-lede{margin:0 0 .65rem;font-size:.9rem;line-height:1.5;color:var(--muted)}.server-selfhost-lede strong{color:var(--fg)}.server-selfhost-steps{margin:0 0 .65rem;padding-left:1.2rem;font-size:.88rem;line-height:1.55;color:var(--muted);display:flex;flex-direction:column;gap:.25rem}.server-selfhost-steps li::marker{color:var(--accent);font-weight:700}.server-selfhost-steps strong{color:var(--fg)}.server-selfhost-foot{margin:0;font-size:.82rem;line-height:1.5;color:var(--muted)}.server-selfhost a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.server-selfhost a:hover{color:var(--accent-dim)}.live-badge{font-weight:700;font-size:.78rem;padding:.2rem .45rem;border-radius:var(--radius);font-family:var(--font)}.live-badge.connecting{background:var(--border);color:var(--muted)}.live-badge.live{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok-border)}.live-badge.offline{background:var(--err-bg);color:var(--err-fg);border:1px solid var(--err-border)}.live-hint{font-size:.85rem;color:var(--muted)}.server-stats{font-size:.88rem;color:var(--muted);margin:.65rem 0 0}.server-stats strong{color:var(--text);font-family:var(--mono)}.key-intro{font-size:.9rem;color:var(--muted);margin:0 0 1rem}#view-newchat .key-intro.chat-intro{margin-bottom:.5rem}.home-intro{display:block;border:1px solid var(--accent-tint-border);background:var(--accent-tint-bg);border-left:3px solid var(--accent);border-radius:var(--radius);padding:.9rem 1rem;margin:0 0 1.1rem}.home-intro-lede{margin:0 0 .5rem;font-size:.95rem;line-height:1.45;color:var(--fg)}.home-intro-steps{margin:0;font-size:.9rem;line-height:1.5;color:var(--muted)}.home-intro-steps strong{color:var(--fg)}.key-block{border-radius:var(--radius);padding:.65rem 0 0;margin-bottom:0;border:none;background:transparent}.key-public{border:1px solid var(--accent-tint-border);background:var(--accent-tint-bg)}.key-private{border:1px solid var(--danger-tint-border);background:var(--danger-tint-bg)}.key-label{font-size:.8rem;font-weight:700;margin-bottom:.35rem}.key-tag{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:.1rem .3rem;border-radius:var(--radius);border:1px solid var(--accent-strong-border);background:var(--accent-tint-tag-bg);color:var(--accent-tag-fg);vertical-align:middle}.key-tag-danger{background:var(--danger-tag-bg);color:var(--danger-tag-fg)}.key-help{font-size:.78rem;color:var(--muted);margin:0 0 .5rem;line-height:1.45}.key-download-row{margin-top:.5rem;margin-bottom:0}.qr-row{display:flex;flex-wrap:wrap;gap:1.25rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--accent-line)}.qr-wrap{flex:1;min-width:160px;max-width:220px}.qr-caption{font-size:.75rem;font-weight:600;margin:0 0 .4rem;color:var(--text)}.qr-hint{font-weight:400;color:var(--muted);font-size:.7rem}.qr-img{display:block;width:180px;height:180px;border-radius:var(--radius);background:var(--qr-bg);padding:4px;border:1px solid var(--border)}.fp-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:.5rem 0 .25rem}.fp.mono{word-break:break-all;line-height:1.5}.chat-intro{margin-top:0}#view-newchat .row{margin-bottom:.45rem}#view-newchat #openChatStatus{margin-top:.2rem;margin-bottom:0}.chat-tabs{display:flex;flex-wrap:nowrap;gap:0;min-height:2rem;align-items:stretch}.chat-tabs--sidebar{flex-direction:column;flex-wrap:nowrap;min-height:2rem;align-items:stretch}@media(min-width:769px){.chat-tabs--mobile{display:none}}.chat-tabs--sidebar .chat-tab{display:flex;flex-direction:row;align-items:stretch;width:100%;border-right:none;border-bottom:1px solid var(--border);flex-shrink:0}.chat-tabs--sidebar .chat-tab:last-child{border-bottom:none}.chat-tabs--sidebar .chat-tab-label{flex:1;min-width:0;max-width:none;text-align:left}.chat-tab{display:inline-flex;align-items:stretch;flex-shrink:0;border-radius:var(--radius);border:none;border-right:1px solid var(--border);background:var(--bg);overflow:hidden}.chat-tab:last-child{border-right:none}.chat-tab.active{background:var(--tab-active-bg)}.chat-tab-label{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--mono);font-size:.75rem;padding:.35rem .5rem .35rem .55rem;border:none;background:transparent;color:var(--text);cursor:pointer;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-tab-unread-dot{flex-shrink:0;width:6px;height:6px;border-radius:50%;background:var(--danger);box-shadow:0 0 0 1px var(--dot-shadow)}.chat-tab.active .chat-tab-unread-dot{box-shadow:0 0 0 1px var(--dot-shadow-active)}.chat-tab.active .chat-tab-label{color:var(--tab-active-fg)}.chat-tab-close{font-size:1rem;line-height:1;padding:.15rem .4rem;border:none;border-left:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;border-radius:0}.chat-tab.active .chat-tab-close{color:var(--tab-close-active);border-left-color:var(--tab-close-border-active)}.chat-tab-close:hover{color:var(--danger);background:var(--danger-hover-bg)}#view-chats>.empty-state.chat-empty-hint{flex:1 1 auto;margin:0;align-self:stretch}.chat-thread{display:flex;flex-direction:column;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border);min-width:0;min-height:0}.chat-with-block{flex-shrink:0;margin:0 0 .4rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}.chat-with-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);flex-shrink:0}.chat-thread-id{margin:0;font-family:var(--mono);font-size:.85rem;color:var(--text);line-height:1.4;word-break:break-all;flex:1;min-width:0;font-weight:600}.chat-thread-id-row{display:flex;gap:.5rem;align-items:center;margin:0}.chat-thread-copy{flex-shrink:0;white-space:nowrap;font-size:.72rem;padding:.25rem .6rem;line-height:1.1}.chat-thread-empty{margin:auto 0;text-align:center;font-size:.85rem;color:var(--muted);font-style:italic}.chat-send-status{margin-top:.35rem;min-height:1.2em;transition:opacity .25s ease}.status.is-fading{opacity:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;margin:auto;padding:2rem 1rem;gap:.65rem;max-width:22rem;color:var(--muted)}.empty-state--inline{margin:1.25rem auto;padding:1.5rem 1rem}.empty-state-glyph{font-family:var(--mono);font-size:1.6rem;line-height:1;color:var(--muted);opacity:.55;letter-spacing:.04em}.empty-state-title{margin:0;font-size:.95rem;font-weight:700;color:var(--text);letter-spacing:.02em}.empty-state-body{margin:0;font-size:.85rem;line-height:1.5;color:var(--muted)}.empty-state-body strong{color:var(--text)}.empty-state-cta{margin-top:.35rem;font-size:.78rem;padding:.45rem .9rem}#view-chats>.empty-state{flex-shrink:0}.chat-messages{flex:1 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable;padding:.45rem 0 .35rem;display:flex;flex-direction:column;gap:.65rem}.chat-composer{flex-shrink:0;padding:.5rem 0 0;border-top:1px solid var(--border)}.chat-composer .row{margin-bottom:0}.chat-composer-row{display:flex;gap:.4rem;align-items:stretch}.chat-composer-row textarea{flex:1;min-width:0;min-height:2.4rem;resize:vertical}.chat-composer-row button{flex-shrink:0;align-self:stretch;padding:.45rem 1.1rem}.chat-line{display:flex;flex-direction:column;gap:.15rem}.chat-line.chat-line-in{align-self:flex-start;max-width:92%}.chat-line.chat-line-out{align-self:flex-end;max-width:92%;align-items:flex-end}.chat-messages>.chat-line+.chat-line.chat-line-cont{margin-top:-.45rem}.chat-bubble{display:inline-block;text-align:left;padding:.45rem .6rem;border-radius:var(--radius);font-size:.86rem;line-height:1.45;white-space:pre-wrap;word-break:break-word;max-width:100%}.chat-line-in .chat-bubble{background:var(--surface);border:1px solid var(--border);color:var(--text)}.chat-line-out .chat-bubble{background:var(--chat-out-bg);border:1px solid var(--chat-out-border);color:var(--text)}.chat-ts{font-size:.66rem;color:var(--muted);font-family:var(--mono);opacity:.75;letter-spacing:.02em;cursor:help;padding:0 .15rem}.chat-line-out .chat-ts{text-align:right}@media(max-width:768px){.site-header{flex-wrap:wrap;padding:.35rem .5rem;gap:.3rem .4rem}.brand-path{display:none}.site-header-actions{gap:.25rem;flex:1 1 auto;min-width:0;justify-content:flex-end}button.site-header-btn{font-size:.7rem;padding:.4rem .55rem;min-height:32px;line-height:1.1}.app-shell{grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr)}.app-sidebar{border-right:none;border-bottom:1px solid var(--border);min-height:0;overflow:hidden}.sidebar-main-nav{flex-direction:row;flex-wrap:wrap;overflow-x:visible}.sidebar-tablist{display:contents}.app-sidebar .dash-tab{flex:1 1 auto;width:auto;border-bottom:none;border-right:1px solid var(--border);padding:.38rem .5rem;font-size:.75rem;white-space:nowrap;text-align:center}.app-sidebar .dash-tab:last-child{border-right:none;border-bottom:none}.app-sidebar .dash-tab-external{flex:0 0 auto;justify-content:center;gap:0;padding-left:.5rem;padding-right:.5rem}.app-sidebar .dash-tab-external .dash-tab-ext-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.app-sidebar .dash-tab-external .dash-tab-ext-icon{color:var(--text);font-size:.9rem}.sidebar-chats-panel{display:none}.chat-tabs--mobile{display:flex;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:0;flex-shrink:0;border-bottom:1px solid var(--border);margin:-.65rem -.65rem .5rem;padding:0}.chat-tabs--mobile:empty{display:none}.chat-tabs--mobile .chat-tab{flex-shrink:0;border-right:1px solid var(--border);border-bottom:none}.chat-tabs--mobile .chat-tab:last-child{border-right:none}.view-panel{padding:.65rem .65rem .75rem}.site-footer{flex-direction:column;align-items:stretch;gap:.45rem;padding:.5rem .6rem}.footer-live{justify-content:flex-start}.footer-meta{font-size:.74rem;text-align:left;justify-content:space-between;width:100%;gap:.25rem .4rem}.footer-meta .theme-toggle{margin-left:auto;min-height:32px;padding:.4rem .65rem}.footer-meta .notif-toggle{min-height:32px;padding:.4rem .6rem}.footer-meta .footer-link{min-height:28px;display:inline-flex;align-items:center}}@media(max-width:420px){.notif-toggle .notif-toggle-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.notif-toggle{padding-left:.5rem;padding-right:.5rem}.notif-toggle .notif-toggle-glyph{width:1em;height:1em}}@media(max-width:480px){#view-newchat .row,#view-server .row{flex-direction:column;align-items:stretch;gap:.5rem}#view-newchat .row>div,#view-server .row>div{min-width:0;width:100%;flex:0 0 auto}#view-newchat .row>button,#view-server .row>button{align-self:stretch}.chat-composer-row{flex-direction:column}.chat-composer-row button{align-self:flex-end;min-width:6rem}.share-field-copy{padding:.45rem .7rem}}@media(max-width:400px){.app-sidebar .dash-tab{padding:.32rem .35rem;font-size:.68rem;letter-spacing:0}button.site-header-btn{font-size:.65rem;padding:.38rem .42rem;min-height:30px}.site-header-actions{gap:.2rem}.view-panel{padding:.55rem .5rem .65rem}}@media(max-height:26rem){body{overflow:auto}#app{overflow:visible}}
