:root{color-scheme:dark;--bg: #020617;--bg-elevated: #020617;--bg-subtle: #0f172a;--border-subtle: #1f2937;--text: #e5e7eb;--text-muted: #9ca3af;--accent: #2563eb;--accent-soft: rgba(37, 99, 235, .1);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .15)}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg);color:var(--text)}.app-shell{display:flex;flex-direction:column;height:100vh}.app-shell.centered{align-items:center;justify-content:center}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;border-bottom:1px solid var(--border-subtle);background-color:#0f172ae6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-header-right{display:flex;align-items:center;gap:.75rem}.app-title{font-weight:600}.user-handle{font-size:.875rem;color:var(--text-muted)}.layout{display:flex;flex:1;min-height:0}.sidebar{width:280px;max-width:100%;border-right:1px solid var(--border-subtle);background:linear-gradient(to bottom,#020617,#020617);display:flex;flex-direction:column}.chat-main{flex:1;display:flex;flex-direction:column;background:radial-gradient(circle at top left,#0f172a,#020617)}.login-form{width:320px;padding:2rem;border-radius:.75rem;background:#020617;border:1px solid var(--border-subtle);box-shadow:0 20px 40px #00000073;display:flex;flex-direction:column;gap:1rem}.login-form h1{margin:0 0 .5rem;font-size:1.4rem}.login-form label{font-size:.875rem;display:flex;flex-direction:column;gap:.35rem}.login-form input[type=text],.login-form input[type=password]{padding:.5rem .6rem;border-radius:.4rem;border:1px solid var(--border-subtle);background-color:#020617;color:var(--text)}.login-form input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.login-form .remember-me{flex-direction:row;align-items:center;gap:.5rem}button.primary,button.secondary{border-radius:.4rem;padding:.4rem .8rem;border:1px solid transparent;font-size:.9rem;cursor:pointer}button.primary{background-color:var(--accent);color:#fff}button.primary:disabled{opacity:.6;cursor:default}button.secondary{background-color:transparent;border-color:var(--border-subtle);color:var(--text-muted)}button.secondary.small{padding:.25rem .6rem;font-size:.8rem}button.full-width{width:100%}.conversation-list{display:flex;flex-direction:column;height:100%}.conversation-list-header{padding:.75rem;border-bottom:1px solid var(--border-subtle)}.conversation-list-body{flex:1;overflow-y:auto;padding:.25rem .5rem .75rem;display:flex;flex-direction:column;gap:.25rem}.conversation-item{display:flex;align-items:center;justify-content:space-between;width:100%;border-radius:.5rem;border:1px solid transparent;background:transparent;padding:.4rem .5rem;color:inherit;cursor:pointer;text-align:left}.conversation-item:hover{background-color:#0f172ad9}.conversation-item.selected{background-color:var(--accent-soft);border-color:var(--accent-soft)}.conversation-item-main{flex:1;min-width:0}.conversation-name{font-size:.9rem;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.conversation-meta{margin-top:.15rem;font-size:.7rem;color:var(--text-muted);display:flex;align-items:center;gap:.25rem}.dot-separator:before{content:"•"}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.icon-button{font-size:.8rem;color:var(--text-muted);padding:.1rem .25rem}.icon-button.small{font-size:.7rem}.icon-button:hover{color:#fca5a5}.chat-window{display:flex;flex-direction:column;height:100%}.chat-header{padding:.5rem .75rem;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;gap:.75rem;background-color:#0f172ae6}.chat-header-main{display:flex;align-items:center;gap:.5rem;flex:1}.conversation-name-input{flex:1;min-width:0;padding:.35rem .5rem;border-radius:.4rem;border:1px solid var(--border-subtle);background-color:#020617;color:var(--text)}.provider-select{padding:.35rem .5rem;border-radius:.4rem;border:1px solid var(--border-subtle);background-color:#020617;color:var(--text);font-size:.85rem}.chat-header-actions{display:flex;align-items:center;gap:.5rem}.system-prompt-editor{padding:.5rem .75rem;border-bottom:1px solid var(--border-subtle)}.system-prompt-editor textarea{width:100%;resize:vertical;min-height:3rem;max-height:8rem;padding:.4rem .5rem;border-radius:.4rem;border:1px solid var(--border-subtle);background-color:#020617;color:var(--text);font-size:.85rem}.label-text{font-size:.75rem;color:var(--text-muted);display:block;margin-bottom:.25rem}.messages-container{flex:1;overflow:hidden;padding:.5rem .75rem}.messages-list{height:100%;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding-right:.25rem}.message-bubble{max-width:70%;padding:.5rem .6rem;border-radius:.75rem;border:1px solid rgba(15,23,42,.9);background-color:#0f172ad9;font-size:.9rem}.message-user{align-self:flex-end;background-color:#2563eb1f;border-color:#2563eb66}.message-assistant{align-self:flex-start}.message-meta{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted);margin-bottom:.15rem}.message-meta-right{display:flex;align-items:center;gap:.25rem}.message-actions{display:flex;align-items:center;gap:.15rem}.message-content{line-height:1.4}.message-content pre{background-color:#020617;padding:.4rem .5rem;border-radius:.4rem;overflow-x:auto;font-size:.75rem}.message-images{margin-top:.3rem;display:flex;gap:.25rem;flex-wrap:wrap}.message-images img{max-height:120px;border-radius:.4rem;border:1px solid var(--border-subtle)}.thinking-block{margin-top:.3rem;font-size:.75rem}.thinking-block summary{cursor:pointer;color:var(--text-muted)}.thinking-block pre{background-color:#020617;padding:.35rem .5rem;border-radius:.4rem;white-space:pre-wrap}.chat-input-area{padding:.5rem .75rem .75rem;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:.35rem}.chat-input-row{display:flex;align-items:flex-end;gap:.5rem}.chat-input{flex:1;min-height:2.5rem;max-height:8rem;resize:none;padding:.45rem .55rem;border-radius:.5rem;border:1px solid var(--border-subtle);background-color:#020617;color:var(--text);font-size:.9rem}.chat-input-actions{display:flex;align-items:center;gap:.3rem}.file-input-label{cursor:pointer;font-size:1.2rem}.attached-images{display:flex;flex-wrap:wrap;gap:.25rem}.attached-image{position:relative}.attached-image img{max-height:80px;border-radius:.4rem;border:1px solid var(--border-subtle)}.attached-image .icon-button{position:absolute;top:2px;right:2px;background-color:#0f172acc;border-radius:999px}.muted{color:var(--text-muted)}.muted.small{font-size:.75rem}.small{font-size:.8rem}.error{color:#fecaca;background-color:var(--danger-soft);border-radius:.4rem;padding:.25rem .4rem;font-size:.8rem}@media (max-width: 768px){.sidebar{display:none}.chat-main{width:100%}.mobile-only{display:inline-flex}.chat-header{flex-direction:column;align-items:stretch;gap:.5rem}.chat-header-main{width:100%;display:flex;gap:.5rem}.chat-header-actions{width:100%;display:flex;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.chat-header-actions button{white-space:nowrap}}@media (min-width: 769px){.mobile-only{display:none}}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0f172abf;z-index:60}.drawer{position:absolute;top:0;left:0;height:100%;width:min(320px,85vw);background:linear-gradient(to bottom,#020617,#020617);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-bottom:1px solid var(--border-subtle)}.app-header-left{display:flex;align-items:center;gap:.5rem}.hamburger{font-size:1.1rem;line-height:1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0f172ad9;display:flex;align-items:center;justify-content:center;z-index:50}.modal{width:min(800px,100% - 2rem);max-height:80vh;background-color:#020617;border-radius:.75rem;border:1px solid var(--border-subtle);padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.modal-textarea{width:100%;flex:1;resize:vertical;min-height:200px;max-height:60vh;padding:.4rem .5rem;border-radius:.4rem;border:1px solid var(--border-subtle);background-color:#020617;color:var(--text);font-size:.8rem}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.25rem}
