:root{--bg:#0f1117;--surface:#1a1d27;--surface-hover:#22263a;--surface-active:#2a2f45;--border:rgba(255,255,255,0.08);--border-strong:rgba(255,255,255,0.16);--text:#e8eaf2;--text-muted:#8b8fa8;--text-faint:#555975;--accent:#6366f1;--accent-hover:#7c7fff;--accent-light:rgba(99,102,241,0.15);--accent-glow:rgba(99,102,241,0.3);--success:#22c55e;--warning:#f59e0b;--error:#ef4444;--sidebar-w:260px;--radius:12px;--radius-sm:8px;--radius-xs:6px;--shadow:0 4px 24px rgba(0,0,0,0.4);--shadow-sm:0 2px 8px rgba(0,0,0,0.3);--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","Fira Code","Consolas",monospace}@media (prefers-color-scheme:light){:root{--bg:#f6f7fb;--surface:#ffffff;--surface-hover:#f0f1f8;--surface-active:#e8eaf5;--border:rgba(0,0,0,0.08);--border-strong:rgba(0,0,0,0.16);--text:#1a1d2e;--text-muted:#5b5f7a;--text-faint:#9699ae;--accent:#4f52d8;--accent-hover:#3f42cc;--accent-light:rgba(79,82,216,0.1);--shadow:0 4px 24px rgba(0,0,0,0.08);--shadow-sm:0 2px 8px rgba(0,0,0,0.06)}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;font-family:var(--font-sans);font-size:15px;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);flex-direction:column}.main-content,.sidebar{display:flex;overflow:hidden}.main-content{flex:1 1;flex-direction:column;min-width:0}.sidebar-header{padding:16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.sidebar-logo{font-size:18px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.sidebar-logo span{color:var(--accent)}.sidebar-new-chat{flex:1 1;overflow-y:auto;padding:8px}.sidebar-footer{padding:12px;border-top:1px solid var(--border)}.sidebar-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;color:var(--text-muted);border:none;background:none;width:100%;text-align:left;transition:background .15s,color .15s}.sidebar-item:hover{background:var(--surface-hover);color:var(--text)}.sidebar-item.active{background:var(--accent-light);color:var(--accent)}.sidebar-section-label{padding:8px 12px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint)}.sidebar-chat-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:13.5px;color:var(--text-muted);border:none;background:none;width:100%;text-align:left;transition:background .15s,color .15s;gap:8px}.sidebar-chat-item:hover{background:var(--surface-hover);color:var(--text)}.sidebar-chat-item.active{background:var(--surface-active);color:var(--text)}.sidebar-chat-title{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.sidebar-chat-actions{display:none;gap:4px;flex-shrink:0}.sidebar-chat-item:hover .sidebar-chat-actions{display:flex}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid transparent;font-family:var(--font-sans);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s,opacity .15s;line-height:1.4;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:white}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--surface-hover);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-active)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.btn-danger{background:rgba(239,68,68,.12);color:var(--error);border-color:rgba(239,68,68,.2)}.btn-danger:hover:not(:disabled){background:rgba(239,68,68,.2)}.btn-icon{padding:6px;border-radius:var(--radius-xs);min-width:28px;min-height:28px}.btn-new-chat{width:100%;margin-bottom:8px;padding:10px 14px;background:var(--accent-light);color:var(--accent);border:1px dashed var(--accent-glow);border-radius:var(--radius-sm);justify-content:flex-start;font-size:14px;gap:8px}.btn-new-chat:hover{background:var(--accent);color:white;border-style:solid}.form-group{display:grid;grid-gap:6px;gap:6px}.form-label{font-size:13px;font-weight:500;color:var(--text-muted)}.form-input{width:100%;padding:10px 14px;background:var(--surface-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-sans);font-size:14px;transition:border-color .15s;outline:none}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-input::placeholder{color:var(--text-faint)}.form-error{font-size:13px;color:var(--error);padding:8px 12px;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-xs)}.chat-header{padding:12px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;background:var(--bg);min-height:56px}.chat-header-title{font-size:15px;font-weight:600;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-messages{flex:1 1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:20px}.chat-message{display:flex;gap:14px;max-width:860px;width:100%}.chat-message.user{align-self:flex-end;flex-direction:row-reverse}.chat-message.assistant,.chat-message.system{align-self:flex-start}.chat-message-avatar{width:32px;height:32px;border-radius:50%;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.chat-message.user .chat-message-avatar{background:var(--accent);color:white;border-color:transparent}.chat-message.assistant .chat-message-avatar{background:var(--surface-active);color:var(--accent)}.chat-message-body{flex:1 1;min-width:0}.chat-message-content{padding:12px 16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);font-size:14.5px;line-height:1.65}.chat-message.user .chat-message-content{background:var(--accent);color:white;border-color:transparent;border-radius:var(--radius) var(--radius-xs) var(--radius) var(--radius)}.chat-message.assistant .chat-message-content{border-radius:var(--radius-xs) var(--radius) var(--radius) var(--radius)}.chat-message-meta{margin-top:4px;font-size:11.5px;color:var(--text-faint);display:flex;gap:8px;align-items:center}.chat-message.user .chat-message-meta{justify-content:flex-end}.chat-input-area{padding:16px 24px 20px;background:var(--bg);border-top:1px solid var(--border)}.chat-input-wrapper{max-width:860px;margin:0 auto;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius);display:flex;align-items:flex-end;gap:8px;padding:10px 12px;transition:border-color .15s,box-shadow .15s}.chat-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.chat-textarea{flex:1 1;border:none;background:transparent;color:var(--text);font-family:var(--font-sans);font-size:14.5px;line-height:1.6;resize:none;outline:none;max-height:200px;min-height:24px;overflow-y:auto}.chat-textarea::placeholder{color:var(--text-faint)}.chat-send-btn{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--accent);color:white;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,opacity .15s}.chat-send-btn:hover{background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.model-selector{position:relative}.model-selector-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:13px;cursor:pointer;transition:background .15s}.model-selector-btn:hover{background:var(--surface-hover);color:var(--text)}.model-selector-dropdown{position:absolute;bottom:calc(100% + 6px);left:0;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow);min-width:220px;max-height:300px;overflow-y:auto;z-index:100}.model-option{padding:10px 14px;cursor:pointer;font-size:13.5px;color:var(--text);transition:background .1s;display:flex;justify-content:space-between;align-items:center;gap:8px}.model-option:hover{background:var(--surface-hover)}.model-option.selected{color:var(--accent)}.model-tier-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase}.model-tier-badge.free{background:rgba(34,197,94,.15);color:var(--success)}.model-tier-badge.paid{background:rgba(245,158,11,.15);color:var(--warning)}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4,.markdown-body h5,.markdown-body h6{margin:16px 0 8px;line-height:1.3;font-weight:600}.markdown-body h1{font-size:1.5em}.markdown-body h2{font-size:1.3em}.markdown-body h3{font-size:1.15em}.markdown-body p{margin:0 0 10px}.markdown-body p:last-child{margin-bottom:0}.markdown-body ol,.markdown-body ul{padding-left:20px;margin-bottom:10px}.markdown-body li{margin-bottom:4px}.markdown-body code{font-family:var(--font-mono);font-size:.88em;background:rgba(99,102,241,.12);padding:2px 5px;border-radius:4px}.markdown-body pre{position:relative;margin:12px 0;border-radius:var(--radius-sm);overflow:hidden}.markdown-body pre code{background:none;padding:0;border-radius:0;font-size:13px}.code-block-wrapper{position:relative}.code-copy-btn{position:absolute;top:8px;right:8px;padding:4px 8px;border-radius:var(--radius-xs);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.7);font-size:11px;cursor:pointer;transition:background .15s}.code-copy-btn:hover{background:rgba(255,255,255,.2);color:white}.markdown-body blockquote{border-left:3px solid var(--accent);padding-left:12px;margin:10px 0;color:var(--text-muted)}.markdown-body table{border-collapse:collapse;width:100%;margin:12px 0;font-size:13.5px}.markdown-body td,.markdown-body th{padding:8px 12px;border:1px solid var(--border);text-align:left}.markdown-body th{background:var(--surface-hover);font-weight:600}.markdown-body hr{border:none;border-top:1px solid var(--border);margin:16px 0}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow)}.auth-logo{font-size:22px;font-weight:800;letter-spacing:-.03em;color:var(--text);margin-bottom:6px}.auth-logo span{color:var(--accent)}.auth-subtitle{font-size:13.5px;color:var(--text-muted);margin-bottom:28px}.auth-form{display:grid;grid-gap:16px;gap:16px}.auth-divider{text-align:center;font-size:13px;color:var(--text-faint);margin:4px 0}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.card-title{font-size:15px;font-weight:600}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table th{padding:10px 14px;text-align:left;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint)}.data-table td,.data-table th{border-bottom:1px solid var(--border)}.data-table td{padding:12px 14px;color:var(--text)}.data-table tr:hover td{background:var(--surface-hover)}.data-table tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:20px;font-size:12px;font-weight:500}.badge-green{background:rgba(34,197,94,.12);color:var(--success)}.badge-yellow{background:rgba(245,158,11,.12);color:var(--warning)}.badge-red{background:rgba(239,68,68,.12);color:var(--error)}.badge-blue{background:rgba(99,102,241,.12);color:var(--accent)}.badge-gray{background:var(--surface-hover);color:var(--text-muted)}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.typing-indicator{display:flex;gap:5px;align-items:center;padding:12px 16px}.typing-dot{width:7px;height:7px;border-radius:50%;background:var(--text-faint);animation:bounce 1.2s infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.page-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:16px}.page-title{font-size:20px;font-weight:700}.page-body{flex:1 1;overflow-y:auto;padding:24px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 24px;text-align:center;color:var(--text-muted)}.empty-state-icon{font-size:40px;opacity:.3}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:16px;gap:16px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.stat-value{font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.stat-label{font-size:13px;color:var(--text-muted);margin-top:4px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.flex-1{flex:1 1}.min-w-0{min-width:0}.overflow-hidden{overflow:hidden}.text-ellipsis{text-overflow:ellipsis}.sr-only,.text-ellipsis{overflow:hidden;white-space:nowrap}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;clip:rect(0,0,0,0);border:0}@media (max-width:768px){:root{--sidebar-w:0px}.sidebar{position:fixed;left:-280px;top:0;height:100%;width:280px;z-index:200;transition:left .25s ease}.sidebar.open{left:0}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199}.sidebar.open~.sidebar-overlay{display:block}.chat-input-area,.chat-messages,.page-body{padding-left:16px;padding-right:16px}}