:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color-scheme:light dark;--bg: #0f1115;--panel: #1a1d24;--border: #2a2f3a;--accent: #4f8cff;--user: #2563eb;--assistant: #2a2f3a;--text: #e6e8ec;--muted: #9aa3b2}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text)}.app{max-width:1040px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}.login{margin:10vh auto 0;display:flex;flex-direction:column;gap:.6rem;width:320px;padding:1.5rem;background:var(--panel);border:1px solid var(--border);border-radius:12px}.login h1{margin:0 0 .5rem;text-align:center}.tabs{display:flex;gap:.5rem}.tabs button{flex:1;background:transparent;border:1px solid var(--border)}.tabs button.active{border-color:var(--accent);color:var(--accent)}input,button{font:inherit;padding:.55rem .7rem;border-radius:8px;border:1px solid var(--border);background:#0d0f14;color:var(--text)}button{cursor:pointer;background:var(--accent);border-color:var(--accent);color:#fff}button:disabled{opacity:.5;cursor:default}button.link{background:transparent;border:none;color:var(--muted);text-decoration:underline}.error{color:#ff6b6b;font-size:.85rem}.topbar{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem;border-bottom:1px solid var(--border)}.topbar-actions{display:flex;align-items:center;gap:.75rem}.tabs .tab{padding:.35rem .8rem;border-radius:8px;color:var(--muted);text-decoration:none;border:1px solid transparent}.tabs .tab:hover{color:var(--text)}.tabs .tab.active{color:var(--accent);border-color:var(--accent)}.content{flex:1;min-height:0;display:flex;flex-direction:column}.chat-page{display:flex;flex:1;min-height:0}.conversation-list{width:260px;flex-shrink:0;border-right:1px solid var(--border);padding:.75rem;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.conversation-new{background:var(--panel);border:1px solid var(--border);color:var(--text)}.conversation-status{margin:0;color:var(--muted);font-size:.85rem}.conversation-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.conversation-item{display:flex;align-items:center;gap:.4rem;border:1px solid transparent;border-radius:8px}.conversation-item.active{border-color:var(--accent)}.conversation-open{flex:1;min-width:0;text-align:left;background:transparent;border:none;color:var(--text);display:flex;flex-direction:column;gap:.15rem;padding:.45rem .55rem}.conversation-title{font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-summary{font-size:.75rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-delete{flex-shrink:0;background:transparent;border:none;color:var(--muted);font-size:.75rem;text-decoration:underline;padding:.2rem .4rem}.chat-page .chat{flex:1;min-width:0}.documents-page{display:flex;flex-direction:column}.documents-page .upload{padding:.75rem 1rem;border-bottom:1px solid var(--border)}.search-bar{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-bottom:1px solid var(--border)}.search-input{flex:1}.search-clear{background:transparent;border:none;color:var(--muted);font-size:1.1rem;padding:0 .4rem}.search-results{padding:.75rem 1rem}.search-results-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.search-result{display:flex;flex-direction:column;gap:.2rem;padding:.5rem .6rem;background:var(--panel);border:1px solid var(--border);border-radius:8px}.search-result-title{font-size:.9rem;font-weight:600}.search-result-snippet{font-size:.82rem;color:var(--muted);word-break:break-word}.chat{display:flex;flex-direction:column;flex:1;min-height:0}.conn-bar{font-size:.8rem;color:var(--muted);padding:.4rem 1rem;display:flex;align-items:center;gap:.4rem}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot.online{background:#36d399}.dot.offline{background:#ff6b6b}.conn-error{color:#ff6b6b}.messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.6rem}.empty{color:var(--muted);margin:auto}.bubble{max-width:80%;padding:.6rem .8rem;border-radius:12px;white-space:pre-wrap;word-break:break-word;line-height:1.4}.bubble.user{align-self:flex-end;background:var(--user)}.bubble.assistant{align-self:flex-start;background:var(--assistant)}.bubble.clarifying{border:1px solid var(--accent)}.bubble.doc-notice{display:flex;align-items:center;gap:.6rem;color:var(--muted)}.doc-download{font-size:.8rem;padding:.3rem .6rem}.bubble ul{margin:.3rem 0 0;padding-left:1.1rem}.caret{display:inline-block;width:7px;height:1em;margin-left:2px;background:var(--accent);vertical-align:text-bottom;animation:blink 1s steps(2,start) infinite}@keyframes blink{to{visibility:hidden}}.citations{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;padding:0 1rem .3rem}.citations-label{font-size:.8rem;color:var(--muted)}.chip{font-size:.72rem;padding:.15rem .5rem;border-radius:999px;background:var(--panel);border:1px solid var(--border);color:var(--muted)}.status{padding:0 1rem .3rem;font-size:.8rem;color:var(--accent)}.status.error{color:#ff6b6b}.composer{display:flex;gap:.5rem;padding:.75rem 1rem 1rem;border-top:1px solid var(--border)}.composer input{flex:1}.composer .mic,.composer .speak{background:var(--panel);border:1px solid var(--border);color:var(--text);padding:0 .6rem}.composer .mic.listening{border-color:#ff6b6b;animation:pulse 1s ease-in-out infinite}.composer .speak.on{border-color:#4ade80}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.upload{display:flex;align-items:center;gap:.5rem}.upload button{background:var(--panel);border:1px solid var(--border);color:var(--text)}.upload-status{font-size:.8rem;color:var(--muted)}.upload-status.error{color:#ff6b6b}.memories{padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--panel)}.memories-title{margin:0 0 .5rem;font-size:1rem}.memories-status{margin:0;color:var(--muted);font-size:.85rem}.memories-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.memories-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-size:.9rem}.memories-content{flex:1;word-break:break-word}.documents{padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--panel)}.documents-title{margin:0 0 .5rem;font-size:1rem}.documents-status{margin:0;color:var(--muted);font-size:.85rem}.documents-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.documents-item{display:flex;align-items:center;gap:.6rem;font-size:.9rem}.documents-name{flex:1;word-break:break-word}.documents-error{color:#b91c1c;font-size:.8rem;max-width:16rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-badge{flex-shrink:0;padding:.1rem .5rem;border-radius:999px;font-size:.78rem;white-space:nowrap}.doc-badge-ok{background:#dcfce7;color:#166534}.doc-badge-fail{background:#fee2e2;color:#991b1b}.doc-badge-pending{background:#fef9c3;color:#854d0e}.documents-delete{flex-shrink:0;padding:.1rem .5rem;border:1px solid #fecaca;border-radius:6px;background:#fff;color:#b91c1c;font-size:.78rem;cursor:pointer}.documents-delete:hover:not(:disabled){background:#fee2e2}.documents-delete:disabled{opacity:.5;cursor:default}.settings-page{padding:1rem 1.25rem}.settings-page h1{font-size:1.3rem;margin:0 0 1rem}.settings-banner{background:#dcfce7;color:#166534;padding:.5rem .75rem;border-radius:8px;font-size:.9rem;margin:0 0 1rem}.mail-connect{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:1rem 1.25rem;max-width:32rem}.mail-connect h2{font-size:1.05rem;margin:0 0 .75rem}.mail-connect-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.mail-connect-email{font-weight:600;word-break:break-all}.mail-connect-hint{margin:0;color:var(--muted);font-size:.9rem;flex:1}.mail-connect-status{color:var(--muted);padding:1rem 1.25rem}.mail-connect-button{background:var(--accent);border:none;color:#fff;padding:.5rem 1rem;border-radius:8px;cursor:pointer;white-space:nowrap}.mail-connect-button:disabled{opacity:.5;cursor:default}.confirm-card{margin:0 1rem .5rem;padding:.75rem .9rem;background:var(--panel);border:1px solid var(--accent);border-radius:12px}.confirm-card-title{display:block;margin-bottom:.3rem}.confirm-card-summary{margin:0 0 .6rem;color:var(--text);font-size:.9rem;word-break:break-word}.confirm-card-actions{display:flex;align-items:center;gap:.75rem}.confirm-card-ok{background:var(--accent);border:none;color:#fff;padding:.4rem .9rem;border-radius:8px;cursor:pointer}.confirm-card-ok:disabled,.confirm-card-cancel:disabled{opacity:.5;cursor:default}.mail-settings{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:1rem 1.25rem;max-width:32rem}.mail-settings h2{font-size:1.05rem;margin:0 0 .75rem}.mail-settings-status{color:var(--muted);padding:1rem 1.25rem}.mail-settings-row{display:flex;align-items:flex-start;gap:.6rem;padding:.5rem 0;cursor:pointer}.mail-settings-row input{margin-top:.2rem}.mail-settings-label{display:flex;flex-direction:column;gap:.15rem;font-weight:600}.mail-settings-hint{color:var(--muted);font-size:.85rem;font-weight:400}.mail-notification-card{margin:0 1rem .5rem;padding:.75rem .9rem;background:var(--panel);border:1px solid var(--accent);border-radius:12px;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.mail-notification-meta{display:flex;flex-direction:column;gap:.15rem;min-width:0}.mail-notification-from{font-weight:600;word-break:break-all}.mail-notification-subject{color:var(--muted);font-size:.9rem;word-break:break-word}.mail-notification-actions{display:flex;align-items:center;gap:.75rem}.mail-notification-open{background:var(--accent);border:none;color:#fff;padding:.4rem .9rem;border-radius:8px;cursor:pointer;white-space:nowrap}
