:root{--font-sans:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--radius:12px;--radius-sm:8px;--radius-lg:16px;--transition:.2s cubic-bezier(.4,0,.2,1)}[data-theme=dark]{--bg-primary:#0a0a0a;--bg-secondary:#111;--bg-tertiary:#1a1a1a;--bg-elevated:#1e1e1e;--bg-hover:#252525;--bg-active:#2a2a2a;--border:#2a2a2a;--border-light:#333;--text-primary:#e8e8e8;--text-secondary:#999;--text-tertiary:#666;--accent:#8ab4f8;--accent-hover:#aecbfa;--accent-dim:rgba(138,180,248,.1);--success:#81c995;--error:#f28b82;--warning:#fdd663;--sidebar-bg:#0f0f0f;--input-bg:#1a1a1a;--code-bg:#0d0d0d;--scrollbar:#333;--scrollbar-hover:#555;--shadow:0 4px 24px rgba(0,0,0,.4)}[data-theme=light]{--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-tertiary:#f1f3f4;--bg-elevated:#fff;--bg-hover:#f1f3f4;--bg-active:#e8eaed;--border:#e0e0e0;--border-light:#d0d0d0;--text-primary:#1a1a1a;--text-secondary:#5f6368;--text-tertiary:#9aa0a6;--accent:#1a73e8;--accent-hover:#1557b0;--accent-dim:rgba(26,115,232,.08);--success:#34a853;--error:#ea4335;--warning:#fbbc04;--sidebar-bg:#f8f9fa;--input-bg:#fff;--code-bg:#f6f8fa;--scrollbar:#c0c0c0;--scrollbar-hover:#999;--shadow:0 4px 24px rgba(0,0,0,.08)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover)}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-container{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary)}.login-box{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:48px;width:100%;max-width:400px;box-shadow:var(--shadow)}.login-logo{text-align:center;margin-bottom:32px}.login-logo h1{font-size:24px;font-weight:600;margin-top:12px}.login-logo p{color:var(--text-secondary);font-size:14px;margin-top:4px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:var(--font-sans);transition:border-color var(--transition);outline:none}.form-group input:focus,.form-group select:focus{border-color:var(--accent)}.btn-primary{width:100%;padding:10px 20px;background:var(--accent);color:#000;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition)}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.login-error{color:var(--error);font-size:13px;margin-top:12px;text-align:center}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:280px;min-width:280px;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh}.sidebar-header{padding:16px;border-bottom:1px solid var(--border)}.new-chat-btn{width:100%;padding:10px 16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all var(--transition)}.new-chat-btn:hover{background:var(--bg-hover);border-color:var(--border-light)}.session-list{flex:1;overflow-y:auto;padding:8px}.session-item{padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background var(--transition);margin-bottom:2px}.session-item:hover{background:var(--bg-hover)}.session-item.active{background:var(--accent-dim)}.session-title{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.session-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition)}.session-item:hover .session-actions{opacity:1}.session-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:14px;transition:all var(--transition)}.session-action-btn:hover{background:var(--bg-active);color:var(--text-primary)}.session-action-btn.delete:hover{color:var(--error)}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sidebar-footer-btn{padding:8px 12px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:13px;display:flex;align-items:center;gap:6px;transition:all var(--transition)}.sidebar-footer-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.main-area{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}.top-bar{padding:12px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;min-height:52px}.model-badge{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);background:var(--bg-tertiary);padding:6px 12px;border-radius:20px;border:1px solid var(--border)}.model-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--success)}.model-select{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:var(--font-sans);padding:6px 12px;outline:none;cursor:pointer}.model-select:focus{border-color:var(--accent)}.top-bar-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:16px;transition:all var(--transition)}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.chat-area{flex:1;overflow-y:auto;padding:0}.chat-messages{max-width:820px;margin:0 auto;padding:24px 24px 120px}.message{margin-bottom:24px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.message-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.message-avatar.user{background:var(--accent-dim);color:var(--accent)}.message-avatar.assistant{background:linear-gradient(135deg,#8ab4f8,#c084fc);color:#000}.message-role{font-size:13px;font-weight:600;color:var(--text-primary)}.message-content{padding-left:40px;font-size:14px;line-height:1.7;color:var(--text-primary)}.message-content p{margin-bottom:12px}.message-content p:last-child{margin-bottom:0}.message-content strong{font-weight:600}.message-content em{font-style:italic}.message-content ul,.message-content ol{margin:8px 0;padding-left:24px}.message-content li{margin-bottom:4px}.message-content code:not(pre code){background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;font-family:var(--font-mono);font-size:13px}.message-content a{color:var(--accent);text-decoration:none}.message-content a:hover{text-decoration:underline}.code-block-wrapper{margin:12px 0;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.code-block-lang{font-size:12px;font-weight:500;color:var(--text-secondary);text-transform:uppercase}.copy-btn{padding:4px 10px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:12px;font-family:var(--font-sans);transition:all var(--transition);display:flex;align-items:center;gap:4px}.copy-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.copy-btn.copied{color:var(--success);border-color:var(--success)}.code-block-wrapper pre{margin:0;padding:14px;overflow-x:auto;background:var(--code-bg)!important}.code-block-wrapper code{font-family:var(--font-mono);font-size:13px;line-height:1.6}.copy-chat-btn{margin-top:8px;padding:4px 10px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-tertiary);cursor:pointer;font-size:12px;font-family:var(--font-sans);transition:all var(--transition);display:inline-flex;align-items:center;gap:4px;margin-left:40px}.copy-chat-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.status-bar{padding:8px 24px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-tertiary);background:var(--bg-secondary);min-height:36px}.status-bar .pulse{width:6px;height:6px;border-radius:50%;background:var(--success);animation:pulse 2s infinite}.status-bar.active .pulse{background:var(--accent);animation:pulse .8s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.status-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-input-container{position:absolute;bottom:0;left:0;right:0;padding:16px 24px 20px;background:linear-gradient(transparent,var(--bg-primary) 20%)}.chat-input-wrapper{max-width:820px;margin:0 auto;background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color var(--transition)}.chat-input-wrapper:focus-within{border-color:var(--accent)}.chat-input-row{display:flex;align-items:flex-end;padding:8px 8px 8px 16px;gap:8px}.chat-input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:14px;font-family:var(--font-sans);resize:none;outline:none;min-height:24px;max-height:200px;padding:6px 0;line-height:1.5}.chat-input::placeholder{color:var(--text-tertiary)}.input-actions{display:flex;align-items:center;gap:4px}.input-icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;font-size:18px;transition:all var(--transition)}.input-icon-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.send-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#000;cursor:pointer;font-size:16px;transition:all var(--transition)}.send-btn:hover{background:var(--accent-hover)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.upload-preview{display:flex;gap:8px;padding:8px 16px;border-top:1px solid var(--border);flex-wrap:wrap}.upload-chip{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg-tertiary);border-radius:20px;font-size:12px;color:var(--text-secondary)}.upload-chip button{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:14px;line-height:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:620px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow)}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h2{font-size:18px;font-weight:600}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:18px;transition:all var(--transition)}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:24px}.modal-body .form-group{margin-bottom:16px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.btn-secondary{padding:8px 16px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition)}.btn-secondary:hover{background:var(--bg-hover)}.btn-save{padding:8px 16px;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#000;font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition)}.btn-save:hover{background:var(--accent-hover)}.btn-save:disabled{opacity:.5;cursor:not-allowed}.btn-danger{padding:8px 16px;background:var(--error);border:none;border-radius:var(--radius-sm);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition)}.btn-danger:hover{opacity:.8}.provider-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;transition:border-color var(--transition)}.provider-card.enabled{border-color:var(--accent)}.provider-header{display:flex;align-items:center;gap:12px;cursor:pointer}.provider-header input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.provider-name{font-size:14px;font-weight:600;flex:1}.provider-models{font-size:12px;color:var(--text-tertiary);margin-top:8px}.provider-models span{display:inline-block;background:var(--bg-active);padding:2px 8px;border-radius:12px;margin:2px;font-size:11px}.welcome-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:40px}.welcome-screen h2{font-size:28px;font-weight:600;margin-bottom:8px;background:linear-gradient(135deg,var(--accent),#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.welcome-screen p{color:var(--text-secondary);font-size:15px;max-width:480px;line-height:1.6}.toast{position:fixed;top:20px;right:20px;padding:12px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;z-index:2000;animation:slideIn .3s ease}.toast.success{background:var(--success);color:#000}.toast.error{background:var(--error);color:#fff}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.admin-layout{display:flex;height:100vh;overflow:hidden}.admin-sidebar{width:220px;min-width:220px;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px}.admin-sidebar h3{font-size:16px;font-weight:700;margin-bottom:24px;padding:0 8px;display:flex;align-items:center;gap:8px}.admin-nav-item{padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all var(--transition);margin-bottom:4px;display:flex;align-items:center;gap:8px}.admin-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-nav-item.active{background:var(--accent-dim);color:var(--accent)}.admin-content{flex:1;overflow-y:auto;padding:32px}.admin-content h2{font-size:22px;font-weight:600;margin-bottom:24px}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{text-align:left;padding:10px 12px;background:var(--bg-tertiary);color:var(--text-secondary);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}.admin-table td{padding:10px 12px;border-bottom:1px solid var(--border)}.admin-table tr:hover td{background:var(--bg-hover)}.badge{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.badge.admin{background:#8ab4f826;color:var(--accent)}.badge.user{background:#81c99526;color:var(--success)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.stat-card .label{font-size:12px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-card .value{font-size:28px;font-weight:700}.stat-card .sub{font-size:12px;color:var(--text-secondary);margin-top:4px}.progress-bar{width:100%;height:6px;background:var(--bg-active);border-radius:3px;margin-top:8px;overflow:hidden}.progress-bar .fill{height:100%;border-radius:3px;transition:width .5s ease}.top-bar-user{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer;padding:4px 12px;border-radius:20px;border:1px solid var(--border);background:var(--bg-tertiary)}.top-bar-user:hover{background:var(--bg-hover)}.hamburger-btn{display:none;width:36px;height:36px;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:18px;transition:all var(--transition)}.hamburger-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99;animation:fadeIn .2s ease}.top-bar-left{display:flex;align-items:center;gap:10px}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn .15s ease}.confirm-dialog{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:24px;max-width:380px;width:90%;box-shadow:var(--shadow);text-align:center}.confirm-dialog p{font-size:14px;color:var(--text-primary);margin-bottom:20px;line-height:1.5}.confirm-actions{display:flex;gap:10px;justify-content:center}@media (max-width: 768px){.hamburger-btn{display:flex}.sidebar-overlay{display:block}.sidebar{position:fixed;z-index:100;transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);width:280px;min-width:280px;height:100vh}.sidebar.open{transform:translate(0);box-shadow:4px 0 24px #0000004d}.top-bar{padding:10px 14px;min-height:48px}.model-badge{font-size:12px;padding:4px 10px}.model-select{font-size:12px;padding:4px 8px;max-width:120px}.top-bar-user{font-size:12px;padding:4px 8px}.chat-messages{padding:16px 14px 100px}.message-content{padding-left:0;font-size:14px}.message-header{margin-bottom:4px}.message-avatar{width:24px;height:24px;font-size:12px}.chat-input-container{padding:10px 14px 14px}.chat-input{font-size:16px}.chat-input-row{padding:6px 6px 6px 12px}.status-bar{padding:6px 14px;font-size:11px}.code-block-wrapper pre{font-size:12px}.welcome-screen h2{font-size:22px}.welcome-screen p{font-size:14px}.modal-overlay{align-items:flex-end}.modal{max-width:100%;max-height:90vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-header,.modal-body{padding:16px 18px}.modal-footer{padding:12px 18px}.admin-sidebar{width:60px;min-width:60px;padding:12px 8px}.admin-sidebar h3 span,.admin-nav-item span{display:none}.admin-content{padding:16px}.stat-grid{grid-template-columns:1fr}}@media (max-width: 480px){.top-bar-actions{gap:4px}.top-bar-user{display:none}.model-select{max-width:90px}.chat-messages{padding:12px 10px 90px}}
