:root{--bg-primary: #ffffff;--bg-secondary: #f9f9fb;--bg-tertiary: #f1f1f5;--bg-sidebar: #f9f9fb;--bg-hover: #f1f1f5;--bg-active: #ebebf0;--bg-input: #ffffff;--bg-message-user: transparent;--bg-message-assistant: transparent;--bg-code: #0f0f12;--bg-modal: rgba(255, 255, 255, .9);--bg-badge: #eff1ff;--text-primary: #0f0f0f;--text-secondary: #6b6b6b;--text-tertiary: #a0a0a0;--text-inverse: #ffffff;--text-code: #e2e8f0;--border-primary: #e5e5e5;--border-secondary: #d4d4d4;--border-focus: #0f0f0f;--accent-primary: #0f0f0f;--accent-secondary: #333333;--accent-hover: #444444;--accent-gradient: linear-gradient(135deg, #0f0f0f 0%, #333333 100%);--accent-soft: rgba(0, 0, 0, .05);--success: #10b981;--warning: #f59e0b;--error: #ef4444;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .12);--shadow-input: 0 4px 16px rgba(0, 0, 0, .08);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-2xl: 28px;--radius-full: 9999px;--sidebar-width: 255px;--sidebar-collapsed: 0px;--header-height: 56px;--input-max-width: 800px;--transition-fast: .15s ease;--transition-slow: .3s ease;font-family:Inter,sans-serif;font-feature-settings:"liga" 1,"calt" 1}@supports (font-variation-settings: normal){:root{font-family:InterVariable,sans-serif}}[data-theme=dark]{--bg-primary: #0a0a0a;--bg-secondary: #121212;--bg-tertiary: #1a1a1a;--bg-sidebar: #0a0a0a;--bg-hover: #161616;--bg-active: #202020;--bg-input: #121212;--bg-message-user: transparent;--bg-message-assistant: transparent;--bg-code: #000000;--bg-modal: rgba(0, 0, 0, .9);--bg-badge: rgba(255, 255, 255, .1);--text-primary: #f5f5f5;--text-secondary: #a3a3a3;--text-tertiary: #737373;--text-inverse: #000000;--text-code: #e2e8f0;--border-primary: #262626;--border-secondary: #404040;--border-focus: #ffffff;--accent-primary: #ffffff;--accent-secondary: #e5e5e5;--accent-hover: #d1d1d1;--accent-gradient: linear-gradient(135deg, #ffffff 0%, #a3a3a3 100%);--accent-soft: rgba(255, 255, 255, .1);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .4);--shadow-md: 0 8px 24px rgba(0, 0, 0, .6);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .8);--shadow-input: 0 4px 16px rgba(0, 0, 0, .4)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:inherit;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow:hidden;height:100vh;position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;background:radial-gradient(ellipse at 0% 0%,rgba(120,140,255,.1) 0%,transparent 45%),radial-gradient(ellipse at 100% 0%,rgba(140,120,255,.08) 0%,transparent 45%),radial-gradient(ellipse at 0% 100%,rgba(100,120,255,.08) 0%,transparent 45%),radial-gradient(ellipse at 100% 100%,rgba(130,110,255,.06) 0%,transparent 45%),radial-gradient(ellipse at 50% 0%,rgba(120,130,255,.04) 0%,transparent 35%),radial-gradient(ellipse at 50% 100%,rgba(110,120,255,.04) 0%,transparent 35%)}#root{height:100vh;display:flex}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}button{cursor:pointer;font-family:inherit;border:none;background:none;font-size:inherit}input,textarea{font-family:inherit;font-size:inherit;border:none;outline:none;background:none;color:inherit}*{scrollbar-width:thin;scrollbar-color:var(--text-tertiary) transparent}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.code-block-wrapper pre::-webkit-scrollbar{height:6px}.code-block-wrapper pre::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px;margin:0 8px}.code-block-wrapper pre::-webkit-scrollbar-thumb{background:#ffffff59;border-radius:3px}.code-block-wrapper pre::-webkit-scrollbar-thumb:hover{background:#ffffff80}.code-block-wrapper pre{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.35) rgba(255,255,255,.05)}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%;background:var(--bg-primary);padding:20px;position:relative}.auth-top-actions{position:absolute;top:20px;right:20px;display:flex;align-items:center;gap:12px}.auth-language-select{padding:6px 28px 6px 10px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;outline:none;transition:all var(--transition-fast);-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:14px}.auth-language-select:hover,.auth-language-select:focus{background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--border-secondary)}.auth-theme-toggle{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.auth-theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-secondary)}.auth-card{width:100%;max-width:420px;background:var(--bg-modal);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-lg);animation:fadeInUp .5s cubic-bezier(.16,1,.3,1)}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo h1{font-size:28px;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.auth-logo p{color:var(--text-secondary);font-size:14px}.auth-logo .app-logo{height:64px;margin-bottom:12px}.app-logo{height:40px;width:auto;vertical-align:middle;margin-right:8px;display:inline-block;transition:filter var(--transition-fast)}[data-theme=dark] .app-logo{filter:invert(1)}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500;color:var(--text-secondary)}.form-group input{padding:12px 16px;background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-soft)}.auth-btn{padding:12px 24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-radius:var(--radius-md);font-weight:600;font-size:15px;margin-top:8px;transition:transform var(--transition-fast),box-shadow var(--transition-fast),opacity var(--transition-fast);border:none}.auth-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px #6366f166;opacity:.9}.auth-btn:active{transform:translateY(0)}.auth-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:var(--error);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}@keyframes typing{0%,to{transform:translateY(0);opacity:.3}50%{transform:translateY(-4px);opacity:1}}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.02);opacity:.8}to{transform:scale(1);opacity:1}}@keyframes slideIn{0%{transform:translate(-10px);opacity:0}to{transform:translate(0);opacity:1}}.message-content{position:relative;transition:all .2s ease;overflow-wrap:break-word}.is-streaming .message-content-text>*:last-child:after{content:"";display:inline-block;width:8px;height:18px;background:var(--accent-primary);margin-left:4px;vertical-align:middle;border-radius:2px;animation:cursorBlink .8s infinite}.is-streaming .code-block-wrapper:last-child:after{display:none}.message-content-text p,.message-content-text li,.message-content-text h1,.message-content-text h2,.message-content-text h3{margin-bottom:.8em}.message-content-text p:last-child{margin-bottom:0}.typing-indicator{display:flex;align-items:center;gap:5px;padding:12px 0 8px;width:fit-content}.typing-indicator span{width:6px;height:6px;background:var(--text-tertiary);border-radius:50%;opacity:.6;animation:premium-typing-bounce 1.4s infinite cubic-bezier(.4,0,.2,1)}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.15s}.typing-indicator span:nth-child(3){animation-delay:.3s}@keyframes premium-typing-bounce{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(-4px);opacity:1;background:var(--text-primary)}}.message-content p,.message-content li,.message-content h1,.message-content h2,.message-content h3{animation:fadeIn .3s ease-out}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:var(--bg-badge);border:1px solid var(--border-primary);border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:8px;box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1)}.status-pill.thinking{background:var(--accent-soft);color:var(--accent-primary);border-color:var(--accent-soft);animation:pulse 2s infinite ease-in-out}.thought-pill-container{border:1px solid var(--border-primary);border-radius:var(--radius-md);margin-bottom:16px;overflow:hidden;background:var(--bg-secondary);transition:var(--transition-slow)}.thought-pill-container.active{border-color:var(--accent-soft);box-shadow:var(--shadow-md)}.thought-pill-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;color:var(--text-secondary);transition:background var(--transition-fast)}.thought-pill-header:hover{background:var(--bg-hover);color:var(--text-primary)}.thought-pill-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.thought-pill-icon{color:var(--accent-primary);display:flex;align-items:center}.thought-pill-content{padding:0 14px 14px;font-size:14px;color:var(--text-secondary);line-height:1.7;font-style:italic;animation:slideIn .3s ease-out}.thought-pill-inner-content{border-left:2px solid var(--border-primary);padding-left:12px}.auth-footer{text-align:center;margin-top:24px;font-size:14px;color:var(--text-secondary)}.auth-footer a{font-weight:600}.app-layout{display:flex;width:100%;height:100vh;overflow:hidden;position:relative}.sidebar{width:var(--sidebar-width);height:100vh;background:var(--bg-sidebar);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;transition:width .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1);flex-shrink:0;overflow:hidden;z-index:1000}.sidebar.collapsed{width:var(--sidebar-collapsed);border-right:none}.sidebar-header{display:flex;align-items:center;gap:6px;padding:14px 12px;min-height:var(--header-height);overflow:hidden}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}.sidebar-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;color:var(--text-secondary);border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}.settings-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.new-chat-pill{display:flex;align-items:center;gap:6px;padding:7px 12px;background:transparent;color:var(--text-primary);border:1px solid var(--border-primary);border-radius:var(--radius-full);font-size:13px;font-weight:500;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);white-space:nowrap;flex:1;min-width:0;overflow:hidden;justify-content:center}.new-chat-pill:hover{background:var(--bg-hover)}.new-chat-btn{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--accent-gradient);color:#fff;border-radius:var(--radius-full);font-weight:500;font-size:13px;flex:1;justify-content:center;transition:transform var(--transition-fast),box-shadow var(--transition-fast);white-space:nowrap}.new-chat-btn:hover{transform:translateY(-1px);box-shadow:0 0 16px #0000001a}.sidebar-conversations{flex:1;overflow-y:auto;padding:4px 8px}.conversation-group-title{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;padding:14px 10px 6px}.conversation-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);position:relative;overflow:hidden}.conversation-item:hover{background:var(--bg-hover);color:var(--text-primary)}.conversation-item.active{background:var(--bg-active);color:var(--text-primary);font-weight:500}.conversation-item-icon{color:var(--text-tertiary);flex-shrink:0}.conversation-item-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;padding-right:0;transition:padding-right .2s ease}.conversation-item:hover .conversation-item-title{padding-right:50px}.conversation-item-actions{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;gap:2px;align-items:center;opacity:0;pointer-events:none;background:var(--bg-hover);padding-left:8px;box-shadow:-10px 0 10px var(--bg-hover);transition:opacity var(--transition-fast)}.conversation-item:hover .conversation-item-actions{opacity:1;pointer-events:auto}.conversation-action-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-sm);color:var(--text-tertiary);transition:background var(--transition-fast),color var(--transition-fast)}.conversation-action-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.conversation-action-btn.delete:hover{color:var(--error);background:#ef44441a}.sidebar-footer{padding:10px 14px;border-top:1px solid var(--border-primary)}.user-profile{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);transition:background var(--transition-fast);cursor:pointer}.user-profile:hover{background:var(--bg-hover)}.user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;color:#fff;flex-shrink:0}.user-info{flex:1;min-width:0}.user-info .name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info .email{font-size:11px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);color:var(--text-tertiary);transition:background var(--transition-fast),color var(--transition-fast)}.logout-btn:hover{background:#ef44441a;color:var(--error)}.main-content{flex:1;display:flex;flex-direction:column;height:100vh;min-width:0;position:relative;background:var(--bg-primary)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;min-height:var(--header-height);border-bottom:1px solid var(--border-primary);background:var(--bg-primary);gap:12px}.chat-header-left{display:flex;align-items:center;gap:8px}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);color:var(--text-secondary)}.chat-header-title{font-size:14px;font-weight:500;color:var(--text-primary);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header-right{display:flex;align-items:center;gap:6px}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.user-menu-container{position:fixed;top:14px;right:20px;z-index:1000}.login-pill{display:flex;align-items:center;gap:8px;background:var(--bg-tertiary);color:var(--text-primary);padding:4px 12px 4px 4px;border-radius:var(--radius-full);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:1px solid var(--border-primary)}.login-pill:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.login-pill-avatar{width:28px;height:28px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6)}.login-pill-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.login-pill-chevron{transition:transform var(--transition-fast);opacity:.5;color:var(--text-tertiary)}.login-pill-chevron.rotated{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:6px;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-header{display:flex;align-items:center;gap:10px;padding:10px 12px}.user-dropdown-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.user-dropdown-info{overflow:hidden}.user-dropdown-name{font-weight:600;font-size:13px;color:var(--text-primary)}.user-dropdown-email{font-size:12px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown-divider{height:1px;background:var(--border-primary);margin:4px 0}.user-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:none;cursor:pointer;font-size:13px;color:var(--text-primary);border-radius:var(--radius-md);transition:background var(--transition-fast)}.user-dropdown-item:hover{background:var(--bg-hover)}.user-dropdown-item.danger{color:#ef4444}.user-dropdown-item.danger:hover{background:#ef444414}.settings-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.settings-modal{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);width:560px;max-width:90vw;max-height:80vh;overflow:hidden;box-shadow:var(--shadow-lg);animation:modalSlideIn .25s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.settings-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border-primary)}.settings-modal-header h2{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.settings-close-btn{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast)}.settings-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-modal-body{display:flex;min-height:350px}.settings-tabs{width:180px;padding:12px;border-right:1px solid var(--border-primary);display:flex;flex-direction:column;gap:2px}.settings-tab{display:flex;align-items:center;gap:8px;padding:10px 12px;border:none;background:none;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);text-align:left}.settings-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-tab.active{background:var(--bg-active);color:var(--text-primary);font-weight:600}.settings-content{flex:1;padding:20px 24px;overflow-y:auto}.settings-section h3{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.settings-field{margin-bottom:16px}.settings-field label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.settings-field input{width:100%;padding:10px 12px;border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:13px;color:var(--text-primary);background:var(--bg-secondary);transition:border-color var(--transition-fast);font-family:inherit}.settings-field input:focus{outline:none;border-color:var(--accent-primary)}.settings-field input:disabled{opacity:.6;cursor:not-allowed}.settings-input-row{display:flex;gap:8px}.settings-input-row input{flex:1}.settings-save-btn{padding:10px 20px;border:none;border-radius:var(--radius-md);background:var(--accent-primary);color:var(--text-inverse);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;display:flex;align-items:center;gap:6px}.settings-save-btn:hover:not(:disabled){opacity:.9}.settings-save-btn:disabled{opacity:.4;cursor:not-allowed}.settings-save-btn.saved{background:#10b981}.theme-toggle-row{display:flex;gap:8px}.theme-option{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:2px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-secondary);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast)}.theme-option:hover{border-color:var(--text-tertiary)}.theme-option.active{border-color:var(--accent-primary);background:var(--bg-active);color:var(--text-primary);font-weight:600}.language-options{display:flex;flex-direction:column;gap:8px}.language-option{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border:2px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-secondary);cursor:pointer;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast)}.language-option:hover{border-color:var(--text-tertiary);background:var(--bg-tertiary)}.language-option.active{border-color:var(--accent-primary);background:var(--bg-active);color:var(--text-primary);font-weight:600}.language-option-label{font-size:15px}.language-check{color:var(--accent-primary)}.danger-card{padding:16px;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);margin-bottom:12px;background:#ef44440a}.danger-card-info{margin-bottom:12px}.danger-card-info strong{font-size:13px;color:var(--text-primary)}.danger-card-info p{font-size:12px;color:var(--text-secondary);margin:4px 0 0}.danger-btn{padding:8px 16px;border:1px solid #ef4444;border-radius:var(--radius-md);background:none;color:#ef4444;font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:6px}.danger-btn:hover,.danger-btn.confirm{background:#ef4444;color:#fff}.danger-btn.cancel{border-color:var(--border-primary);color:var(--text-secondary)}.danger-btn.cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.danger-confirm{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.danger-confirm span{font-size:12px;font-weight:600;color:#ef4444}.toast-notification{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--accent-primary);color:var(--text-inverse);padding:12px 24px;border-radius:var(--radius-full);font-size:13px;font-weight:500;z-index:3000;box-shadow:var(--shadow-lg);animation:toastSlideIn .3s ease-out}@keyframes toastSlideIn{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.attached-file-badge{display:flex;align-items:center;gap:6px;padding:6px 10px;margin:8px 12px 0;background:var(--bg-badge);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:12px;font-weight:500;color:var(--text-primary);width:fit-content}.attached-file-badge button{width:18px;height:18px;border:none;background:var(--bg-hover);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.attached-file-badge button:hover{background:var(--bg-active);color:var(--text-primary)}.web-search-badge{display:flex;align-items:center;gap:6px;padding:6px 10px;margin:8px 12px 0;background:linear-gradient(135deg,#eff1ff,#e8f0fe);border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-md);font-size:12px;font-weight:500;color:#4f46e5;width:fit-content}[data-theme=dark] .web-search-badge{background:linear-gradient(135deg,#6366f126,#8b5cf61a);color:#a5b4fc;border-color:#6366f14d}.web-search-badge button{width:18px;height:18px;border:none;background:#6366f11a;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:inherit;transition:all var(--transition-fast)}.web-search-badge button:hover{background:#6366f133}@media(max-width:600px){.settings-modal-body{flex-direction:column}.settings-tabs{width:100%;flex-direction:row;border-right:none;border-bottom:1px solid var(--border-primary);padding:8px;overflow-x:auto}.settings-tab{white-space:nowrap}}.chat-area{flex:1;overflow-y:auto;display:flex;flex-direction:column}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;gap:16px}.empty-state-icon{width:64px;height:64px;border-radius:var(--radius-lg);background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;color:#fff;animation:float 3s ease-in-out infinite}.empty-state h2{font-size:32px;font-weight:400;color:var(--text-primary);line-height:1.2;letter-spacing:-.5px}.empty-state p{color:var(--text-secondary);font-size:15px;max-width:400px}.suggestion-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:16px;max-width:600px;margin-left:auto;margin-right:auto}.suggestion-chip{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-full);font-size:14px;font-weight:400;color:var(--text-primary);transition:all var(--transition-fast);cursor:pointer}.suggestion-chip:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.messages-container{flex:1;padding:20px 0;display:flex;flex-direction:column}.message{padding:12px 0;animation:fadeIn .3s ease}.message-inner{max-width:var(--input-max-width);margin:0 auto;padding:0 20px;display:flex;gap:16px;width:100%}.message-avatar{width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px;font-weight:600;margin-top:2px}.message.user .message-avatar{background:var(--accent-gradient);color:#fff}@keyframes brain-pulse{0%{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:.8}}.thought-pill-container{margin-bottom:18px;display:flex;flex-direction:column;width:100%;max-width:100%;animation:fadeIn .4s ease-out}.thought-pill-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 14px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-full);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;height:32px;width:fit-content;box-shadow:var(--shadow-sm);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.thought-pill-header:hover{background:var(--bg-hover);border-color:var(--border-secondary);color:var(--text-primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.thought-pill-title{display:flex;align-items:center;gap:8px}.thought-pill-icon{display:flex;align-items:center;color:var(--text-tertiary)}.thought-pill-container.active .thought-pill-icon{color:var(--accent-primary);animation:brain-pulse 2s infinite ease-in-out}.file-attachment-badge{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);margin-bottom:12px;width:fit-content;max-width:100%}.file-attachment-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--accent-primary)}.file-attachment-info{display:flex;flex-direction:column;gap:2px}.file-attachment-name{font-size:14px;font-weight:500;color:var(--text-primary);word-break:break-all}.file-attachment-meta{font-size:12px;color:var(--text-tertiary)}.status-pill{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-full);color:var(--text-secondary);font-size:13px;font-weight:500;margin-bottom:15px;box-shadow:var(--shadow-sm);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn .3s ease-out}.status-pill-dot{width:8px;height:8px;background:var(--accent-primary);border-radius:50%;animation:status-blink 1.5s infinite ease-in-out;box-shadow:0 0 8px var(--accent-primary)}@keyframes status-blink{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.message-avatar.pulse{position:relative}.message-avatar.pulse:after{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;border:2px solid var(--accent-primary);border-radius:50%;animation:avatar-ring-pulse 2s infinite ease-out;opacity:0}.message-avatar.pulse svg{animation:sparkle-pulse 2s infinite ease-in-out;color:var(--accent-primary)}@keyframes sparkle-pulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 0px var(--accent-primary))}50%{transform:scale(1.15);filter:drop-shadow(0 0 8px var(--accent-primary))}}@keyframes avatar-ring-pulse{0%{transform:scale(.95);opacity:.8}to{transform:scale(1.4);opacity:0}}.status-pill-text{font-size:13px;font-weight:500;color:var(--text-secondary)}@keyframes pulse{0%{transform:scale(.95);opacity:.5}50%{transform:scale(1.1);opacity:1}to{transform:scale(.95);opacity:.5}}@keyframes brain-pulse{0%{transform:scale(1);opacity:.7}50%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:.7}}.thought-pill-chevron{display:flex;align-items:center;color:var(--text-tertiary);margin-left:8px;transition:transform .2s ease}.thought-pill-container.active .thought-pill-chevron{color:var(--text-secondary)}.thought-pill-content{margin-top:10px;width:100%;padding:14px 18px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);font-size:14.5px;line-height:1.65;color:var(--text-secondary);font-style:italic;white-space:pre-wrap;position:relative;overflow:hidden;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:inset 0 0 20px #00000005}[data-theme=dark] .thought-pill-content{box-shadow:inset 0 0 20px #ffffff05}.thought-pill-inner-content{border-left:2px solid var(--border-secondary);padding-left:18px;opacity:.9}.thought-pill-container.active .thought-pill-header{background:var(--bg-active);border-color:var(--border-secondary)}.message.assistant .message-body{display:flex;flex-direction:column}.message-body{flex:1;min-width:0}.message-role{font-size:13px;font-weight:600;margin-bottom:4px;color:var(--text-primary)}.message-content{font-size:15px;line-height:1.7;color:var(--text-primary);word-break:break-word}.message-content p{margin-bottom:12px}.message-content p:last-child{margin-bottom:0}.message-content ul,.message-content ol{margin:8px 0;padding-left:24px}.message-content li{margin-bottom:4px}.message-content strong{font-weight:600}.message-content h1,.message-content h2,.message-content h3,.message-content h4,.message-content h5,.message-content h6{margin:16px 0 8px;font-weight:600;line-height:1.3}.message-content h1{font-size:1.5em}.message-content h2{font-size:1.3em}.message-content h3{font-size:1.15em}.message-content blockquote{border-left:3px solid var(--accent-primary);padding:8px 16px;margin:12px 0;background:var(--accent-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-secondary)}.message-content table{width:100%;border-collapse:collapse;margin:12px 0;font-size:14px}.message-content th,.message-content td{padding:8px 12px;border:1px solid var(--border-primary);text-align:left}.message-content th{background:var(--bg-secondary);font-weight:600}.message-content code{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:13px}.message-content :not(pre)>code{background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;font-size:.9em}.code-block-wrapper{position:relative;margin:12px 0;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary);background:var(--bg-code);max-width:100%}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1);font-size:12px;color:#a3a3a3}.code-copy-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-sm);font-size:12px;color:#a3a3a3;transition:all var(--transition-fast)}.code-copy-btn:hover{background:#ffffff1a;color:#fff}.code-block-wrapper pre{margin:0!important;border-radius:0!important;border:none!important;background:transparent!important;overflow-x:auto!important;overflow-y:hidden!important;padding:16px!important}.code-block-wrapper code,.code-block-wrapper span{background:transparent!important}.message-actions{display:flex;gap:4px;margin-top:8px;opacity:0;transition:opacity var(--transition-fast)}.message:hover .message-actions{opacity:1}.message-action-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:var(--radius-sm);font-size:12px;color:var(--text-tertiary);transition:all .3s cubic-bezier(.34,1.56,.64,1)}.message-action-btn:hover{background:var(--bg-hover);color:var(--text-primary);transform:translateY(-2px) scale(1.05)}.chat-input-container{padding:0 20px 20px;background:transparent}.chat-input-box{max-width:var(--input-max-width);margin:0 auto;position:relative;display:flex;flex-direction:column;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-2xl);box-shadow:var(--shadow-input);overflow:visible}.chat-input-textarea-row{padding:14px 18px 4px}.chat-input-textarea-row textarea{width:100%;resize:none;min-height:24px;max-height:200px;font-size:16px;line-height:1.5;color:var(--text-primary);background:transparent}.chat-input-textarea-row textarea::placeholder{color:var(--text-tertiary)}.chat-input-footer{display:flex;align-items:center;justify-content:space-between;padding:6px 10px 10px}.chat-input-footer-right{display:flex;align-items:center;gap:8px}.plus-btn{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);background:transparent;border:1px solid var(--border-primary);flex-shrink:0;transition:all var(--transition-fast)}.plus-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.send-btn-circle{width:34px;height:34px;border-radius:var(--radius-full);background:var(--text-tertiary);color:var(--bg-primary);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);flex-shrink:0}.send-btn-circle.active{background:var(--text-primary)}.send-btn-circle:disabled{cursor:default}.send-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);background:var(--accent-gradient);color:#fff;transition:transform var(--transition-fast),opacity var(--transition-fast);flex-shrink:0}.send-btn:hover{transform:scale(1.05)}.send-btn:disabled{opacity:.3;cursor:default;transform:none}.model-selector-container{position:relative}.model-selector-compact{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:500;color:var(--text-secondary);padding:5px 10px;border-radius:var(--radius-full);transition:all var(--transition-fast);white-space:nowrap}.model-selector-compact:hover{background:var(--bg-hover);color:var(--text-primary)}.model-selector-trigger{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);font-size:12px;font-weight:500;white-space:nowrap;transition:all var(--transition-fast);flex-shrink:0}.model-selector-trigger:hover{background:var(--bg-active);color:var(--text-primary)}.model-selector-dropdown{position:absolute;bottom:calc(100% + 8px);right:0;width:320px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;z-index:200;animation:slideUp .2s ease}.model-selector-header{padding:14px 16px 10px;border-bottom:1px solid var(--border-primary)}.ephemeral-toggle-btn{display:flex;align-items:center;justify-content:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--radius-full);color:var(--text-tertiary);background:var(--bg-primary);border:1px solid var(--border-primary);cursor:pointer;transition:all var(--transition-fast);font-size:13px;font-weight:400;white-space:nowrap}.ephemeral-toggle-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.ephemeral-toggle-btn.active{color:#a855f7;background:#a855f71a}.ephemeral-toggle-btn.active:hover{background:#a855f726}.new-chat-pill.ephemeral-active{background:#a855f71a;border-color:#a855f74d;color:#a855f7}.new-chat-pill.ephemeral-active:hover{background:#a855f726}.ephemeral-banner{display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);color:var(--text-tertiary);font-size:13px;font-weight:400;letter-spacing:-.01em}.ephemeral-banner strong{color:var(--text-secondary);font-weight:500}.ephemeral-banner svg{flex-shrink:0;color:#a855f7;opacity:.7}.model-selector-header h3{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:10px}.model-selector-tabs,.model-tabs{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:2px}.model-tab{flex:1;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;color:var(--text-secondary);text-align:center;transition:all var(--transition-fast)}.model-tab.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.model-tab:hover:not(.active){color:var(--text-primary)}.model-list{padding:8px;max-height:240px;overflow-y:auto}.model-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.model-item:hover{background:var(--bg-hover)}.model-item.active{background:var(--accent-soft)}.model-item-icon{width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;color:#fff}.model-item-info{flex:1}.model-item-name{font-size:13px;font-weight:500;color:var(--text-primary)}.model-item-desc{font-size:11px;color:var(--text-tertiary)}.model-check{color:var(--accent-primary)}.quota-badge{display:inline-flex;align-items:center;font-size:10px;font-weight:600;padding:1px 6px;border-radius:var(--radius-full);background:#7c5cfc26;color:#7c5cfc;margin-left:4px;letter-spacing:.02em}.quota-exhausted-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;font-size:12px;font-weight:500;color:var(--error);background:#ef444414;border-bottom:1px solid rgba(239,68,68,.15)}.model-item.locked,.model-option.locked{opacity:.45;cursor:not-allowed;pointer-events:none}.model-item.locked .model-item-icon,.model-option.locked .model-option-icon{filter:grayscale(1)}.model-option{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.model-option:hover{background:var(--bg-hover)}.model-option.selected{background:var(--accent-soft)}.model-option-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.model-option-info{flex:1}.model-option-name{font-size:13px;font-weight:500;color:var(--text-primary)}.model-option-desc{font-size:11px;color:var(--text-tertiary)}.model-option-check{color:var(--accent-primary)}.input-hint{text-align:center;padding:12px 8px 0;font-size:12px;color:var(--text-tertiary);opacity:.6}.plus-menu{position:absolute;bottom:calc(100% + 8px);left:8px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:200px;overflow:hidden;z-index:1001;padding:4px;animation:slideUp .15s ease}.plus-menu-item{display:flex;align-items:center;gap:12px;padding:10px 12px;font-size:14px;color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.plus-menu-item:hover{background:var(--bg-hover)}.plus-menu-item-icon{color:var(--text-secondary)}.plus-menu-switch{margin-left:auto;width:32px;height:18px;background:var(--border-primary);border-radius:var(--radius-full);position:relative;transition:background .2s}.plus-menu-switch.active{background:var(--success)}.plus-menu-switch:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:var(--radius-full);transition:transform .2s}.plus-menu-switch.active:after{transform:translate(14px)}.soon-badge{font-size:10px;font-weight:700;padding:2px 6px;background:var(--bg-badge);color:#3b82f6;border-radius:4px;margin-left:auto;text-transform:uppercase}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-modal);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:24px;width:90%;max-width:400px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}.modal-content h3{font-size:16px;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.modal-content input{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-size:14px;color:var(--text-primary);margin-bottom:16px}.modal-content input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-soft)}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.modal-btn{padding:8px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:all var(--transition-fast)}.modal-btn.cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.modal-btn.cancel:hover{background:var(--bg-active);color:var(--text-primary)}.modal-btn.confirm{background:var(--accent-gradient);color:#fff}.modal-btn.confirm:hover{box-shadow:0 0 16px #0000001a}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-modal);z-index:99;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.main-content{flex:1;display:flex;flex-direction:column;height:100vh;position:relative;overflow:hidden}.mobile-header{display:none;align-items:center;gap:12px;padding:0 16px;padding-top:env(safe-area-inset-top,0px);height:calc(60px + env(safe-area-inset-top,0px));border-bottom:1px solid var(--border-primary);background:rgba(var(--bg-primary-rgb),.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:sticky;top:0;z-index:900}.mobile-header-spacer{flex:1}.mobile-menu-ref-wrapper{display:flex;align-items:center;flex-shrink:0}@media(max-width:768px){.mobile-header{display:flex!important}}.mobile-user-dropdown-wrapper{display:none}@media(max-width:768px){.mobile-user-dropdown-wrapper{display:block;position:fixed;top:calc(56px + env(safe-area-inset-top,0px));right:10px;z-index:1001}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner{width:20px;height:20px;border:2px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .6s linear infinite}.generated-image-container{margin:12px 0;position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);max-width:100%;width:fit-content;border:1px solid var(--border-primary);background:var(--bg-tertiary);line-height:0}.generated-image{max-width:100%;max-height:512px;object-fit:contain;transition:transform var(--transition-slow)}.generated-image-container:hover .generated-image{transform:scale(1.02)}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.generated-image-container:hover .image-overlay{opacity:1}.image-action-btn{background:#ffffffe6;color:#000;border:none;padding:8px 16px;border-radius:var(--radius-full);font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #0003}.image-action-btn:hover{background:#fff;transform:translateY(-1px)}.suggestion-chip.active{background:var(--bg-active);border-color:var(--accent-primary);color:var(--text-primary)}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{flex:1;padding-right:40px}.password-toggle-btn{position:absolute;right:8px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.password-toggle-btn:hover{color:var(--text-primary)}.password-message{padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;margin-top:4px}.password-message.success{background:#10b9811f;color:#10b981}.password-message.error{background:#ef44441f;color:#ef4444}.admin-page{min-height:100vh;width:100%;background:var(--bg-primary);color:var(--text-primary);overflow-y:auto;display:flex;flex-direction:column}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary);position:sticky;top:0;z-index:10}.admin-header-left{display:flex;align-items:center;gap:12px}.admin-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.admin-back-btn:hover{background:var(--bg-hover)}.admin-title h1{font-size:18px;font-weight:700;margin:0;line-height:1.2}.admin-subtitle{font-size:12px;color:var(--text-tertiary)}.admin-refresh-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.admin-refresh-btn:hover{background:var(--bg-hover)}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;padding:24px}.admin-stat-card{display:flex;align-items:center;gap:14px;padding:18px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.admin-stat-card:hover{border-color:var(--border-secondary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.admin-stat-icon{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:var(--radius-sm);flex-shrink:0}.admin-stat-icon.users-icon{background:#6366f11f;color:#6366f1}.admin-stat-icon.active-icon{background:#10b9811f;color:#10b981}.admin-stat-icon.convos-icon{background:#3b82f61f;color:#3b82f6}.admin-stat-icon.msgs-icon{background:#f59e0b1f;color:#f59e0b}.admin-stat-info{display:flex;flex-direction:column}.admin-stat-value{font-size:22px;font-weight:700;line-height:1.2}.admin-stat-label{font-size:12px;color:var(--text-tertiary);font-weight:500}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 24px 16px;gap:12px}.admin-search{display:flex;align-items:center;gap:10px;flex:1;max-width:600px;padding:10px 16px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary)}.admin-search input{flex:1;border:none;background:none;font-size:13px;color:var(--text-primary);outline:none;font-family:inherit}.admin-search input::placeholder{color:var(--text-tertiary)}.admin-count{font-size:13px;color:var(--text-tertiary);white-space:nowrap}.admin-table-wrapper{padding:0 24px 24px;overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);padding:10px 12px;border-bottom:1px solid var(--border-primary);white-space:nowrap}.admin-table td{padding:12px;border-bottom:1px solid var(--border-primary);vertical-align:middle}.admin-table tbody tr:hover{background:var(--bg-hover)}.current-user-row{background:var(--accent-soft)!important}.admin-user-cell{display:flex;align-items:center;gap:10px;min-width:180px}.admin-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-gradient);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.admin-user-info{display:flex;flex-direction:column;min-width:0}.admin-user-name{font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-user-email{font-size:11px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-role-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.admin-role-badge.admin{background:#6366f11f;color:#6366f1}.admin-role-badge.user{background:var(--bg-tertiary);color:var(--text-secondary)}.admin-role-badge.pro{background:#f59e0b1f;color:#f59e0b}.admin-role-badge.free{background:var(--bg-tertiary);color:var(--text-tertiary)}.admin-quota-cell{font-size:12px;font-weight:500;color:var(--text-secondary);font-variant-numeric:tabular-nums}.quota-unlimited{font-size:16px;color:#f59e0b;font-weight:600}.admin-action-btn.pro-promote{color:#f59e0b}.admin-action-btn.pro-promote:hover{background:#f59e0b1a}.admin-action-btn.active-infinity{color:#f59e0b;background:#f59e0b1a}.admin-quota-edit{margin-top:8px;padding:8px;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.quota-edit-row{display:flex;align-items:center;gap:6px;font-size:12px}.quota-edit-row label{color:var(--text-tertiary);font-weight:500;white-space:nowrap}.quota-edit-row input{width:60px;padding:4px 6px;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:12px;text-align:center}.admin-stat-cell{font-weight:500;color:var(--text-secondary)}.admin-date-cell{font-size:12px;color:var(--text-tertiary);white-space:nowrap}.admin-actions{display:flex;gap:6px}.admin-action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.admin-action-btn:hover:not(:disabled){background:var(--bg-hover)}.admin-action-btn.promote:hover:not(:disabled){border-color:#6366f1;color:#6366f1;background:#6366f114}.admin-action-btn.demote:hover:not(:disabled){border-color:var(--warning);color:var(--warning)}.admin-action-btn.delete:hover:not(:disabled){border-color:var(--error);color:var(--error);background:#ef444414}.admin-action-btn:disabled{opacity:.3;cursor:not-allowed}.admin-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:60px 20px;color:var(--text-tertiary);font-size:14px}.admin-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;z-index:10000;animation:toastIn .3s ease}.admin-toast.success{background:var(--success);color:#fff}.admin-toast.error{background:var(--error);color:#fff}.user-dropdown-item.admin-item{color:#6366f1}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;transform:translate(-100%);z-index:100;width:var(--sidebar-width);box-shadow:var(--shadow-lg)}.sidebar.mobile-open{transform:translate(0)}.sidebar.collapsed{transform:translate(-100%)}.sidebar-overlay.visible{display:block;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999}.sidebar.mobile-open{transform:translate(0)!important;z-index:1000!important}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--text-primary);cursor:pointer;background:none;border:none;padding:0}.chat-header-title{max-width:180px}.message-inner{padding:0 14px}.chat-input-container{padding:12px 14px calc(14px + env(safe-area-inset-bottom,0px));background:var(--bg-primary);border-top:1px solid var(--border-primary);box-shadow:0 -4px 12px #0000000d}.chat-input-wrapper{background:var(--bg-secondary);border-radius:24px;padding:4px 6px 4px 14px;border:1px solid var(--border-primary);box-shadow:none}.chat-input-wrapper:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 2px #7c5cfc1a}.model-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000}.model-selector-dropdown.bottom-sheet{position:fixed;bottom:0!important;left:0!important;right:0!important;width:100%!important;max-width:100%!important;max-height:80vh;background:var(--bg-secondary);border:none;border-radius:20px 20px 0 0;transform:translateY(0)!important;z-index:1001!important;display:flex;flex-direction:column;box-shadow:0 -10px 40px #0000004d;animation:slideUpSheet .3s cubic-bezier(.4,0,.2,1)}.bottom-sheet-handle{width:40px;height:4px;background:var(--border-primary);border-radius:2px;margin:12px auto 8px;flex-shrink:0}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}.model-selector-tabs{padding:8px 16px;background:transparent;border-bottom:1px solid var(--border-primary);gap:8px}.model-tab{padding:8px 12px;font-size:14px;border-radius:12px}.model-list{padding:12px;overflow-y:auto;-webkit-overflow-scrolling:touch}.model-item{margin-bottom:8px;padding:12px;border-radius:16px;background:var(--bg-primary);border:1px solid var(--border-primary)}.model-item.active{background:var(--bg-tertiary);border-color:var(--accent-primary)}.model-item-name{font-weight:600;font-size:15px}.model-item-desc{font-size:12px;opacity:.7}.suggestion-chips{padding:0 10px}.empty-state h2{font-size:24px}.settings-modal{width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0}.settings-modal-body{flex-direction:column}.settings-tabs{flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid var(--border-primary);padding:0;gap:0}.settings-tab{flex:1;justify-content:center;padding:10px 8px;border-radius:0;white-space:nowrap;font-size:12px}.settings-content{padding:16px}.settings-input-row{flex-direction:column}.settings-save-btn{width:100%}.danger-card{flex-direction:column;align-items:flex-start;gap:10px}.danger-btn{width:100%;justify-content:center}.danger-confirm{width:100%;flex-direction:column}.danger-confirm button{width:100%}.user-menu-container{display:none}.hidden-on-mobile{display:none!important}.ephemeral-toggle-btn:not(.mobile-ephemeral){display:none!important}.sidebar-toggle.fixed-toggle{display:none!important}.ephemeral-toggle-btn.mobile-ephemeral{position:static!important;width:34px;height:34px;padding:0;border-radius:50%;flex-shrink:0;border:1px solid var(--border-primary);background:transparent}.ephemeral-toggle-btn.mobile-ephemeral span{display:none}.mobile-login-pill{padding:3px;gap:0;border:1px solid var(--border-primary);flex-shrink:0}.mobile-login-pill .login-pill-name{display:none}.mobile-login-pill .login-pill-avatar{width:26px;height:26px;font-size:11px}.mobile-login-pill .login-pill-chevron{display:none}.mobile-header .user-dropdown,.mobile-user-dropdown{position:fixed;top:calc(60px + env(safe-area-inset-top,0px));right:10px;min-width:220px;z-index:1001}.login-pill-name{display:none}.login-pill{padding:4px 8px;gap:4px}.user-dropdown{right:0;min-width:220px}.plus-menu{left:0;right:auto;min-width:200px}.auth-card{margin:16px;padding:24px;max-width:calc(100vw - 32px)}.auth-logo h1{font-size:22px}.admin-stats{grid-template-columns:repeat(2,1fr);padding:16px;gap:10px}.admin-stat-card{padding:14px}.admin-stat-value{font-size:18px}.admin-header{padding:12px 16px}.admin-title h1{font-size:16px}.admin-toolbar{padding:0 16px 12px;flex-direction:column;align-items:stretch}.admin-search{max-width:none}.admin-table-wrapper{padding:0 16px 16px}.hide-mobile{display:none}.admin-user-cell{min-width:140px}.admin-user-email{max-width:120px}.admin-refresh-btn span,.admin-refresh-btn{font-size:12px;padding:6px 10px}}@media(max-width:480px){.empty-state h2{font-size:20px}.empty-state p{font-size:13px}.suggestion-chips{flex-direction:column;align-items:stretch}.suggestion-chips button{text-align:left}.admin-stats{grid-template-columns:1fr 1fr;gap:8px;padding:12px}.admin-stat-card{padding:12px;gap:10px}.admin-stat-icon{width:36px;height:36px}.admin-stat-value{font-size:16px}}
