@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.auth-layout{background:radial-gradient(circle at 20% 20%, #10a37f24, transparent 28%), radial-gradient(circle at 78% 28%, #4285f41f, transparent 30%), var(--bg-base);min-height:100vh;padding:var(--space-6);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-bg{pointer-events:none;position:absolute;inset:0;overflow:hidden}.orb{filter:blur(74px);opacity:.24;border-radius:50%;position:absolute}.orb-1{background:radial-gradient(circle,#10a37f,#0000 70%);width:400px;height:400px;animation:8s ease-in-out infinite float-glow;top:-100px;left:-100px}.orb-2{background:radial-gradient(circle,#4285f4,#0000 70%);width:300px;height:300px;animation:10s ease-in-out infinite reverse float-glow;bottom:-80px;right:-80px}.orb-3{background:radial-gradient(circle,#7c3aed,#0000 70%);width:200px;height:200px;animation:12s ease-in-out 2s infinite float-glow;top:50%;left:60%}.auth-card{width:100%;max-width:430px;-webkit-backdrop-filter:blur(var(--glass-blur));border-radius:var(--radius-xl);padding:var(--space-8) var(--space-8);box-shadow:var(--shadow-md);animation:gentlePop .42s var(--ease-standard);background:#ffffffd6;border:1px solid #0f172a14;position:relative}.auth-logo{align-items:center;gap:var(--space-2);margin-bottom:var(--space-6);display:flex}.auth-logo-icon{border-radius:var(--radius-md);background:var(--accent-soft-gradient);border:1px solid #10a37f2e;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.auth-logo-text{font-size:var(--font-size-xl);color:var(--text-primary);letter-spacing:0;font-weight:700}.auth-title{font-size:var(--font-size-xl);color:var(--text-primary);margin-bottom:var(--space-1);letter-spacing:0;font-weight:760}.auth-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-6)}.auth-form{gap:var(--space-4);flex-direction:column;display:flex}.form-group{gap:var(--space-1);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.required{color:var(--accent-primary)}.form-input{width:100%;padding:12px var(--space-4);border:1px solid var(--border-default);color:var(--text-primary);font-size:var(--font-size-base);font-family:var(--font-family);transition:all var(--transition-fast);background:#ffffffbd;border-radius:14px}.form-input::placeholder{color:var(--text-disabled)}.form-input:focus{border-color:var(--accent-primary);background:#fff;outline:none;box-shadow:0 0 0 4px #10a37f1a}.form-input.input-error{border-color:var(--error)}.field-error{font-size:var(--font-size-xs);color:var(--error);margin-top:2px}.form-error{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);color:#fca5a5;font-size:var(--font-size-sm);animation:slideUp .24s var(--ease-standard);background:#ef44441a;border:1px solid #ef444440;border-radius:14px;display:flex}.btn-primary{width:100%;padding:13px var(--space-6);font-size:var(--font-size-base);color:#fff;letter-spacing:.2px;margin-top:var(--space-2);background:#202124;border-radius:14px;font-weight:600;position:relative;overflow:hidden}.btn-primary:before{content:"";transition:background var(--transition-fast);background:#fff0;position:absolute;inset:0}.btn-primary:hover:not(:disabled):before{background:#ffffff1a}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 28px #20212433}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.btn-loading{justify-content:center;align-items:center;gap:var(--space-2);display:flex}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}.auth-footer{text-align:center;margin-top:var(--space-6);font-size:var(--font-size-sm);color:var(--text-muted)}.auth-footer a{color:var(--accent-primary);transition:color var(--transition-fast);font-weight:650}.auth-footer a:hover{color:#0f766e;text-decoration:none}@media (width<=480px){.auth-card{padding:var(--space-6)}}.sidebar{width:var(--sidebar-width);transition:width var(--transition-normal), transform var(--transition-normal), opacity var(--transition-normal);z-index:50;-webkit-backdrop-filter:blur(18px)saturate(1.05);background:#f1f1eedb;border-right:1px solid #0f172a12;flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar--closed{border:none;width:0}.sidebar--open{width:var(--sidebar-width)}.sidebar-header{border-bottom:1px solid #0f172a0f;flex-shrink:0;justify-content:space-between;align-items:center;height:60px;padding:12px 14px;display:flex}.sidebar-logo{align-items:center;gap:var(--space-2);min-width:0;display:flex}.sidebar-logo svg{filter:drop-shadow(0 8px 16px #10a37f38)}.sidebar-logo-text{font-size:var(--font-size-md);color:var(--text-primary);letter-spacing:0;font-weight:760}.sidebar-new-btn{border-radius:var(--radius-full);color:#fff;background:#202124;justify-content:center;align-items:center;width:34px;height:34px;display:flex;box-shadow:0 8px 18px #20212429}.sidebar-new-btn:hover{background:#111827;transform:translateY(-1px)scale(1.02)}.sidebar-new-btn:active{transform:scale(.95)}.sidebar-content{flex:1;padding:12px 10px 16px;overflow-y:auto}.sidebar-empty{padding:var(--space-10) var(--space-4);color:var(--text-muted);text-align:center;justify-content:center;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);flex-direction:column;display:flex}.sidebar-empty-icon{border:1px solid var(--border-subtle);width:48px;height:48px;color:var(--text-disabled);margin-bottom:var(--space-2);background:#ffffffb8;border-radius:18px;justify-content:center;align-items:center;display:flex}.sidebar-empty-hint{font-size:var(--font-size-xs);color:var(--text-disabled)}.conv-group{margin-bottom:var(--space-5)}.conv-group-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding:0 9px 8px;font-weight:760}.conv-item{cursor:pointer;transition:background var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast), color var(--transition-fast);animation:slideInLeft .26s var(--ease-standard) both;border:1px solid #0000;border-radius:13px;align-items:center;gap:9px;padding:9px;display:flex;position:relative}.conv-item:hover{background:#ffffffb3;border-color:#0f172a0f;transform:translate(2px)}.conv-item--active{background:#fff;border-color:#10a37f29;box-shadow:0 8px 20px #0f172a12}.conv-item-icon{color:var(--text-disabled);flex-shrink:0;display:flex}.conv-item--active .conv-item-icon{color:var(--accent-primary)}.conv-item-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.conv-item-title{font-size:var(--font-size-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:560;line-height:1.35;overflow:hidden}.conv-item-date{font-size:var(--font-size-xs);color:var(--text-muted)}.conv-item-delete{opacity:0;border-radius:var(--radius-full);width:26px;height:26px;color:var(--text-muted);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.conv-item:hover .conv-item-delete{opacity:1;transform:translate(0)}.conv-item-delete:hover{color:var(--error);background:#ef44441a;transform:scale(1.05)}@media (width<=768px){.sidebar{height:100%;position:fixed;top:0;left:0;transform:translate(-104%);box-shadow:22px 0 45px #0f172a29}.sidebar--open{width:var(--sidebar-width);transform:translate(0)}}.message-row{animation:gentlePop .28s var(--ease-standard) both;gap:13px;padding:2px 0;display:flex}.message-row--user{flex-direction:row-reverse;align-items:flex-start}.message-row--assistant{flex-direction:row;align-items:flex-start}.message-avatar{width:30px;height:30px;font-size:var(--font-size-xs);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;margin-top:4px;font-weight:700;display:flex}.assistant-avatar{background:var(--accent-soft-gradient);border:1px solid #10a37f29;box-shadow:0 8px 20px #10a37f1a}.user-avatar-bubble{display:none}.message-bubble{max-width:min(700px,86%);transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);border-radius:22px;padding:13px 16px;line-height:1.7}.bubble-user{color:#1f2937;box-shadow:var(--shadow-xs);background:#e8f0fe;border:1px solid #4285f41c;border-bottom-right-radius:8px}.bubble-assistant{box-shadow:none;background:0 0;border:1px solid #0000;border-bottom-left-radius:8px;padding-left:0}.message-row--user .message-bubble:hover{transform:translateY(-1px);box-shadow:0 8px 22px #4285f41f}.message-row--assistant .message-bubble{max-width:min(720px,100% - 44px)}.message-text{white-space:pre-wrap;word-break:break-word}.message-error{align-items:center;gap:var(--space-2);color:#b42318;font-size:var(--font-size-sm);display:flex}.message-markdown{font-size:var(--font-size-base);color:var(--text-primary);word-break:break-word;line-height:1.78}.message-markdown>:first-child{margin-top:0}.message-markdown>:last-child{margin-bottom:0}.message-markdown p{margin:.45em 0}.message-markdown h1,.message-markdown h2,.message-markdown h3,.message-markdown h4,.message-markdown h5,.message-markdown h6{color:var(--text-primary);margin:1em 0 .4em;font-weight:760;line-height:1.3}.message-markdown h1{font-size:1.4em}.message-markdown h2{font-size:1.2em}.message-markdown h3{font-size:1.05em}.message-markdown ul,.message-markdown ol{margin:.5em 0;padding-left:1.5em}.message-markdown li{margin:.25em 0}.message-markdown blockquote{border-left:3px solid var(--accent-primary);color:var(--text-secondary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:#10a37f0f;margin:.8em 0;padding:.45em .85em}.message-markdown hr{border:none;border-top:1px solid var(--border-subtle);margin:1em 0}.table-wrapper{border:1px solid var(--border-default);background:var(--bg-elevated);box-shadow:var(--shadow-xs);border-radius:14px;margin:.8em 0;overflow-x:auto}.message-markdown table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.message-markdown th{padding:var(--space-2) var(--space-3);text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border-default);background:#f4f6f5;font-weight:650}.message-markdown td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-subtle)}.message-markdown tr:last-child td{border-bottom:none}.message-markdown tr:hover td{background:#10a37f0a}.code-block{border:1px solid #0f172a1f;border-radius:14px;margin:.8em 0;overflow:hidden;box-shadow:0 12px 26px #0f172a14}.code-block-header{justify-content:space-between;align-items:center;gap:var(--space-2);padding:8px var(--space-4);background:#202124;border-bottom:1px solid #ffffff14;display:flex}.code-lang{font-size:var(--font-size-xs);color:#ffffff9e;text-transform:lowercase;font-weight:600}.code-block-actions{align-items:center;gap:var(--space-1);display:flex}.copy-btn{align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);color:#ffffffb8;border-radius:var(--radius-full);padding:4px 9px;display:flex}.copy-btn:hover{color:#fff;background:#ffffff1f;transform:translateY(-1px)}.message-attachments,.message-artifacts{gap:var(--space-2);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.message-attachment,.message-artifact-chip{align-items:center;gap:var(--space-2);border-radius:var(--radius-full);max-width:260px;font-size:var(--font-size-xs);text-overflow:ellipsis;white-space:nowrap;background:#ffffffc2;border:1px solid #0f172a1a;padding:6px 10px;line-height:1.2;display:inline-flex;overflow:hidden}.message-attachment-icon,.message-artifact-chip span{border-radius:var(--radius-sm);letter-spacing:.04em;background:#10a37f1a;padding:2px 5px;font-size:9px;font-weight:800}.message-artifact-chip{color:var(--text-secondary);border-color:var(--border-subtle);background:#10a37f12}.message-artifact-chip:hover{color:var(--text-primary);border-color:var(--border-accent);transform:translateY(-1px)}.message-citations{gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--border-subtle);flex-direction:column;display:flex}.message-citations-title{color:var(--text-muted);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.06em;font-weight:760}.message-citation{gap:var(--space-2);padding:var(--space-2);border:1px solid var(--border-subtle);color:var(--text-secondary);transition:transform var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);background:#ffffffb8;border-radius:14px;grid-template-columns:22px 1fr;text-decoration:none;display:grid}.message-citation:hover{border-color:var(--border-accent);background:var(--bg-hover);text-decoration:none;transform:translateY(-1px)}.message-citation span{background:var(--bg-active);width:22px;height:22px;color:var(--accent-primary);font-size:var(--font-size-xs);border-radius:50%;justify-content:center;align-items:center;font-weight:800;display:inline-flex}.message-citation strong{color:var(--text-primary);font-size:var(--font-size-sm);line-height:1.3}.message-citation small{color:var(--text-muted);font-size:var(--font-size-xs);grid-column:2;line-height:1.4}.typing-cursor{background:var(--accent-primary);vertical-align:text-bottom;border-radius:1px;width:2px;height:1.1em;margin-left:2px;animation:.9s ease-in-out infinite typing-blink;display:inline-block}@media (width<=640px){.message-row{gap:10px}.message-avatar{width:28px;height:28px}.message-bubble,.message-row--assistant .message-bubble{max-width:calc(100% - 38px)}.bubble-user{max-width:88%}}.chat-window{scroll-behavior:smooth;flex:1;overflow:hidden auto}.chat-messages{flex-direction:column;gap:18px;max-width:820px;margin:0 auto;padding:28px clamp(14px,3vw,28px) 34px;display:flex}.thinking-indicator{align-items:center;gap:var(--space-3);animation:gentlePop .28s var(--ease-standard);padding:10px 0;display:flex}.thinking-avatar{background:var(--accent-soft-gradient);border:1px solid #10a37f29;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.thinking-dots{align-items:center;gap:5px;display:flex}.thinking-dots span{background:var(--accent-primary);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite thinking-bounce}@media (width<=640px){.chat-messages{gap:14px;padding:18px 12px 24px}}.thinking-dots span:nth-child(2){animation-delay:.2s}.thinking-dots span:nth-child(3){animation-delay:.4s}@keyframes thinking-bounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.composer-wrapper{width:100%;max-width:820px;margin:0 auto}.composer-attachments{gap:var(--space-2);margin-bottom:var(--space-2);flex-wrap:wrap;display:flex}.composer-attachment,.composer-attachment-error{align-items:center;gap:var(--space-2);border-radius:var(--radius-full);border:1px solid var(--border-subtle);min-height:30px;font-size:var(--font-size-xs);color:var(--text-secondary);box-shadow:var(--shadow-xs);background:#ffffffdb;padding:5px 8px;display:inline-flex}.composer-attachment-error{color:#fca5a5;background:#ef444414;border-color:#ef444447}.composer-attachment-kind{border-radius:var(--radius-sm);background:var(--bg-active);color:#0f766e;padding:2px 5px;font-size:9px;font-weight:800}.composer-attachment-name{text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.composer-attachment button{border-radius:var(--radius-sm);width:20px;height:20px;color:var(--text-muted);justify-content:center;align-items:center;display:inline-flex}.composer-attachment button:hover{color:var(--error);background:#ef44441a;transform:scale(1.06)}.composer{align-items:flex-end;gap:var(--space-2);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast), background var(--transition-fast);-webkit-backdrop-filter:blur(18px)saturate(1.08);background:#ffffffeb;border:1px solid #0f172a1a;border-radius:30px;padding:10px 10px 10px 16px;display:flex;position:relative;overflow:hidden;box-shadow:0 16px 44px #0f172a21}.composer:before{content:"";opacity:0;pointer-events:none;background:linear-gradient(90deg,#0000,#10a37f14,#0000);width:90px;position:absolute;top:0;bottom:0;left:0;transform:translate(-120%)}.composer-file-input{display:none}.composer:focus-within{border-color:var(--accent-primary);background:#fff;transform:translateY(-1px);box-shadow:0 0 0 4px #10a37f1a,0 22px 58px #0f172a24}.composer:focus-within:before{animation:softSweep 1.2s var(--ease-standard)}.composer--loading{opacity:.9}.composer-input{min-height:24px;max-height:160px;font-size:var(--font-size-base);color:var(--text-primary);line-height:1.6;font-family:var(--font-family);resize:none;background:0 0;border:none;outline:none;flex:1;overflow-y:auto}.composer-input::placeholder{color:var(--text-disabled)}.composer-input:disabled{cursor:not-allowed}.composer-actions{align-items:center;gap:var(--space-1);flex-shrink:0;display:flex}.composer-btn,.composer-tool-btn{border-radius:var(--radius-full);justify-content:center;align-items:center;width:38px;height:38px;display:flex}.composer-tool-btn{color:var(--text-muted);background:0 0;border:1px solid #0000}.composer-tool-btn:hover{color:var(--text-primary);background:#0f172a0d;transform:translateY(-1px)}.composer-tool-btn:active,.composer-btn:active{transform:scale(.94)}.composer-search-toggle.active{color:#0f766e;border-color:var(--border-accent);background:var(--bg-active)}.composer-btn--send{color:#fff;background:#202124;box-shadow:0 12px 24px #20212433}.composer-btn--send:hover{transform:translateY(-2px)scale(1.03);box-shadow:0 16px 30px #2021243d}.composer-btn--send:active{transform:scale(.94)}.composer-btn--stop{color:var(--error);background:#ef444426;border:1px solid #ef44444d;animation:1.5s ease-in-out infinite pulse-glow}.composer-btn--stop:hover{background:#ef444440;transform:translateY(-1px)}.composer-btn--mic{color:var(--text-disabled);cursor:not-allowed;background:0 0}@media (width<=640px){.composer{border-radius:24px;padding:9px}.composer-input{font-size:16px}.composer-btn,.composer-tool-btn{width:36px;height:36px}}.welcome-screen{animation:fadeIn .45s var(--ease-standard);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:clamp(28px,5vw,64px);display:flex;position:relative;overflow:hidden}.welcome-glow{pointer-events:none;z-index:0;opacity:.42;background:radial-gradient(circle at 36% 42%,#10a37f24,#0000 40%),radial-gradient(circle at 70% 42%,#4285f421,#0000 42%);border-radius:50%;width:min(620px,92vw);height:min(420px,68vw);animation:8s ease-in-out infinite float-glow;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.welcome-logo{margin-bottom:var(--space-4);animation:slideUp .42s var(--ease-standard) 50ms both;z-index:1;position:relative}.welcome-logo-hex{background:#ffffffc7;border:1px solid #0f172a14;border-radius:22px;justify-content:center;align-items:center;width:64px;height:64px;display:flex;box-shadow:0 18px 48px #0f172a1a}.welcome-title{color:#202124;text-align:center;letter-spacing:0;margin-bottom:var(--space-3);text-shadow:0 1px #fffffff0;animation:slideUp .42s var(--ease-standard) .12s both;z-index:1;font-size:clamp(30px,4vw,44px);font-weight:780;position:relative}.welcome-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);animation:slideUp .42s var(--ease-standard) .18s both;z-index:1;margin-bottom:28px;position:relative}.model-badge{background:var(--bg-active);border:1px solid var(--border-accent);border-radius:var(--radius-full);color:var(--accent-primary);font-size:var(--font-size-xs);padding:3px 10px;font-weight:600;display:inline-block}.welcome-suggestions{gap:var(--space-3);width:100%;max-width:660px;animation:slideUp .42s var(--ease-standard) .24s both;z-index:1;grid-template-columns:repeat(2,1fr);display:grid;position:relative}.suggestion-chip{text-align:left;min-height:64px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast), background var(--transition-fast);background:#fff;border:1px solid #0f172a1f;border-radius:18px;align-items:center;gap:12px;padding:14px 16px;display:flex;position:relative;overflow:hidden;box-shadow:0 14px 34px #0f172a17}.suggestion-chip:before{content:"";background:var(--accent-gradient);opacity:0;transition:opacity var(--transition-normal);position:absolute;inset:0}.suggestion-chip:hover{border-color:var(--border-accent);background:#fff;transform:translateY(-3px);box-shadow:0 16px 34px #0f172a1a}.suggestion-chip:hover:before{opacity:.05}.suggestion-icon{border-radius:var(--radius-full);color:#0f766e;z-index:1;background:#10a37f14;justify-content:center;align-items:center;width:36px;min-width:36px;height:36px;padding:0;display:inline-flex;position:relative}.suggestion-label{font-size:var(--font-size-sm);color:var(--text-primary);z-index:1;flex:1;font-weight:650;position:relative}.suggestion-arrow{color:var(--text-muted);opacity:0;transition:all var(--transition-fast);z-index:1;position:relative;transform:translate(-4px)}.suggestion-chip:hover .suggestion-arrow{opacity:1;transform:translate(0)}@media (width<=560px){.welcome-suggestions{grid-template-columns:1fr;gap:10px}.welcome-title{font-size:28px}.suggestion-chip{min-height:58px}}@media (height<=760px){.welcome-logo{display:none}.welcome-subtitle{margin-bottom:18px}.welcome-suggestions{max-width:600px}}.model-picker{align-items:center;gap:var(--space-2);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;min-height:36px;transition:border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);box-shadow:var(--shadow-xs);background:#ffffffc2;border:1px solid #0f172a1a;padding:6px 12px;display:flex;position:relative}.model-picker:hover{border-color:var(--border-accent);background:#fff;transform:translateY(-1px);box-shadow:0 8px 20px #0f172a14}.model-picker-icon{flex-shrink:0;font-size:14px;line-height:1}.model-picker-select{appearance:none;color:var(--text-primary);font-size:var(--font-size-sm);font-weight:650;font-family:var(--font-family);cursor:pointer;padding-right:var(--space-1);white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;outline:none;max-width:200px;overflow:hidden}.model-picker-select option,.model-picker-select optgroup{color:var(--text-primary);background:#fff}.model-picker-chevron{color:var(--text-muted);pointer-events:none;flex-shrink:0}.assistant-picker{align-items:center;gap:var(--space-2);border-radius:var(--radius-full);min-height:36px;color:var(--text-primary);box-shadow:var(--shadow-xs);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);background:#ffffffc2;border:1px solid #0f172a1a;padding:0 12px;display:flex}.assistant-picker:hover{border-color:var(--border-accent);background:#fff;transform:translateY(-1px);box-shadow:0 8px 20px #0f172a14}.assistant-picker-icon{color:var(--accent-primary);flex-shrink:0;display:flex}.assistant-picker-select{appearance:none;max-width:170px;color:var(--text-primary);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;outline:none;font-weight:650}.assistant-picker-select option{color:var(--text-primary);background:#fff}.assistant-picker-loading{background:var(--accent-primary);border-radius:50%;width:8px;height:8px;animation:1.1s ease-in-out infinite pulse-glow}@media (width<=768px){.assistant-picker{display:none}}.artifact-panel{border-left:1px solid var(--border-subtle);z-index:20;background:#0f111a;flex-direction:column;width:min(520px,38vw);min-width:360px;height:100vh;display:flex;box-shadow:-16px 0 48px #00000038}.artifact-panel-header{height:64px;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.artifact-panel-kicker{color:var(--accent-primary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.8px;font-weight:700;line-height:1.1}.artifact-panel-header h2{font-size:var(--font-size-md);line-height:1.2}.artifact-icon-btn{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);border:1px solid var(--border-subtle);background:#ffffff08;justify-content:center;align-items:center;display:inline-flex}.artifact-icon-btn:hover{color:var(--text-primary);border-color:var(--border-accent);background:var(--bg-hover)}.artifact-icon-btn.danger:hover{color:#fca5a5;background:#ef44441f;border-color:#ef444459}.artifact-list{gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);flex-shrink:0;display:flex;overflow-x:auto}.artifact-list-item{align-items:center;gap:var(--space-2);border-radius:var(--radius-md);border:1px solid var(--border-subtle);min-width:150px;max-width:220px;color:var(--text-secondary);font-size:var(--font-size-sm);text-align:left;background:#ffffff08;padding:8px 10px;display:flex}.artifact-list-item span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.artifact-list-item.active,.artifact-list-item:hover{color:var(--text-primary);border-color:var(--border-accent);background:var(--bg-active)}.artifact-type{border-radius:var(--radius-sm);color:#c4b5fd;text-transform:uppercase;background:#8b5cf62e;padding:2px 6px;font-size:10px;font-weight:700}.artifact-empty{width:100%;color:var(--text-muted);font-size:var(--font-size-sm);padding:var(--space-2)}.artifact-workspace{flex-direction:column;flex:1;min-height:0;display:flex}.artifact-toolbar{justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);flex-shrink:0;display:flex}.artifact-title-block{flex:1;min-width:0}.artifact-title-input{width:100%;color:var(--text-primary);font-size:var(--font-size-md);font-weight:700}.artifact-meta{color:var(--text-muted);font-size:var(--font-size-xs);margin-top:2px;display:block}.artifact-toolbar-actions{align-items:center;gap:var(--space-1);flex-shrink:0;display:flex}.artifact-mode-btn{border-radius:var(--radius-md);border:1px solid var(--border-subtle);height:32px;color:var(--text-secondary);font-size:var(--font-size-sm);padding:0 10px}.artifact-mode-btn.active,.artifact-mode-btn:hover{color:var(--text-primary);border-color:var(--border-accent);background:var(--bg-active)}.artifact-stage{background:#0b0d14;flex:1;min-height:0}.artifact-editor{width:100%;height:100%;padding:var(--space-4);resize:none;color:var(--text-primary);background:0 0;border:none;outline:none;font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:13px;line-height:1.7}.artifact-preview-frame{background:#fff;border:none;width:100%;height:100%}.artifact-preview-code{height:100%;padding:var(--space-4);color:var(--text-primary);white-space:pre-wrap;background:0 0;margin:0;overflow:auto}@media (width<=980px){.artifact-panel{width:min(92vw,520px);min-width:0;position:fixed;inset:0 0 0 auto}}@media (width<=640px){.artifact-panel{width:100vw}.artifact-toolbar{flex-direction:column}.artifact-toolbar-actions{justify-content:space-between}}.chat-layout{background:0 0;height:100vh;display:flex;overflow:hidden}.chat-workbench{background:var(--bg-base);border-left:1px solid #0f172a0a;flex:1;min-width:0;display:flex;overflow:hidden}.chat-main{flex-direction:column;flex:1;min-width:0;display:flex;position:relative;overflow:hidden}.chat-main:before{content:"";pointer-events:none;background:linear-gradient(#ffffffb8,#fff0 180px),radial-gradient(circle at 50% 0,#4285f41a,#0000 34%);position:absolute;inset:0}.chat-header{-webkit-backdrop-filter:blur(18px)saturate(1.12);z-index:10;background:#f7f7f5c7;border-bottom:1px solid #0f172a0f;flex-shrink:0;justify-content:space-between;align-items:center;height:60px;padding:0 clamp(12px,2vw,22px);display:flex;position:relative}.chat-header-left,.chat-header-right{align-items:center;gap:var(--space-2);min-width:120px;display:flex}.chat-header-right{justify-content:flex-end}.chat-header-center{justify-content:center;align-items:center;gap:var(--space-2);flex:1;min-width:0;display:flex}.header-brand{color:var(--text-primary);letter-spacing:0;font-size:15px;font-weight:700;display:none}.header-icon-btn{border-radius:var(--radius-full);width:38px;height:38px;color:var(--text-secondary);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;display:flex}.header-icon-btn:hover{border-color:var(--border-subtle);color:var(--text-primary);box-shadow:var(--shadow-xs);background:#ffffffd1;transform:translateY(-1px)}.header-icon-btn:active{transform:scale(.96)}.header-admin-btn{align-items:center;gap:var(--space-2);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:#0f766e;border:1px solid var(--border-accent);background:#10a37f1a;padding:8px 12px;font-weight:650;display:flex}.header-admin-btn:hover{background:#10a37f29;transform:translateY(-1px);box-shadow:0 8px 18px #10a37f24}.header-user{align-items:center;gap:var(--space-1);padding-left:var(--space-1);display:flex}.user-avatar{background:var(--accent-gradient);width:32px;height:32px;font-size:var(--font-size-sm);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex;box-shadow:0 8px 20px #10a37f33}.chat-content{z-index:1;flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.composer-area{z-index:2;flex-shrink:0;padding:0 clamp(14px,3vw,28px) 18px;position:relative}.composer-disclaimer{text-align:center;font-size:var(--font-size-xs);color:var(--text-muted);margin-top:9px}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40;animation:fadeIn .2s var(--ease-standard);background:#0f172a57;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar-overlay{display:block}.chat-header-center{flex:1;justify-content:center;margin-left:0}.header-brand{display:inline-flex}.model-picker{display:none}.chat-header-right{min-width:auto}.header-admin-btn{justify-content:center;width:36px;height:36px;padding:0;font-size:0}.header-user .user-avatar,#logout-all-btn{display:none}.composer-area{padding-inline:10px;padding-bottom:12px}}@media (width<=520px){.chat-header{height:56px}.chat-header-left,.chat-header-right{min-width:88px}}.admin-layout{background:var(--bg-base);height:100vh;display:flex;overflow:hidden}.admin-sidebar{background:var(--bg-surface);border-right:1px solid var(--border-subtle);width:220px;padding:var(--space-4);gap:var(--space-4);flex-direction:column;flex-shrink:0;display:flex}.admin-brand{align-items:center;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle);display:flex}.admin-brand-icon{border-radius:var(--radius-md);background:linear-gradient(135deg,#8b5cf633,#6366f133);border:1px solid #8b5cf64d;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.admin-brand-title{font-weight:700;font-size:var(--font-size-md);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.admin-brand-sub{font-size:var(--font-size-xs);color:var(--text-muted)}.admin-nav{gap:var(--space-1);flex-direction:column;flex:1;display:flex}.admin-nav-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-secondary);transition:all var(--transition-fast);text-align:left;font-weight:500;display:flex}.admin-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-nav-item.active{background:var(--bg-active);color:var(--accent-primary)}.admin-back-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-muted);transition:all var(--transition-fast);display:flex}.admin-back-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-main{padding:var(--space-8);flex:1;overflow-y:auto}.admin-section{max-width:900px;animation:.3s fadeIn}.admin-section-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.admin-section-title{font-size:var(--font-size-xl);color:var(--text-primary);margin-bottom:var(--space-1);font-weight:700}.admin-section-desc{font-size:var(--font-size-sm);color:var(--text-muted)}.admin-cards{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.admin-empty{text-align:center;padding:var(--space-12);color:var(--text-muted);font-size:var(--font-size-sm);grid-column:1/-1}.provider-card{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-fast)}.provider-card:hover{border-color:var(--border-accent);box-shadow:0 4px 20px #8b5cf61a}.provider-card--disabled{opacity:.5}.provider-card-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.provider-type-badge{font-size:var(--font-size-xs);color:var(--accent-primary);background:var(--bg-active);border:1px solid var(--border-accent);border-radius:var(--radius-full);text-transform:uppercase;padding:2px 8px;font-weight:600}.provider-status{font-size:var(--font-size-xs);border-radius:var(--radius-full);padding:2px 8px;font-weight:600}.status--active{color:var(--success);background:#10b9811f;border:1px solid #10b98140}.status--inactive{color:var(--text-muted);border:1px solid var(--border-subtle);background:#6b6a8a1a}.provider-name{font-size:var(--font-size-md);color:var(--text-primary);margin-bottom:var(--space-1);font-weight:600}.provider-url{font-size:var(--font-size-xs);color:var(--text-muted);margin-bottom:var(--space-2);word-break:break-all;font-family:JetBrains Mono,monospace}.provider-models{font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:var(--space-4)}.provider-actions{gap:var(--space-2);display:flex}.btn-accent{align-items:center;gap:var(--space-2);padding:9px var(--space-4);background:var(--accent-gradient);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:#fff;transition:all var(--transition-fast);white-space:nowrap;font-weight:600;display:inline-flex}.btn-accent:hover{opacity:.9;transform:translateY(-1px)}.btn-accent:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-sm{border-radius:var(--radius-sm);font-size:var(--font-size-xs);transition:all var(--transition-fast);padding:5px 12px;font-weight:600}.btn-ghost{border:1px solid var(--border-default);color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{color:var(--error);background:#ef444414;border:1px solid #ef44444d}.btn-danger:hover{background:#ef444426}.users-table-wrapper{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.users-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.users-table th{background:var(--bg-overlay);padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);font-weight:600}.users-table td{padding:var(--space-4);border-bottom:1px solid var(--border-subtle);color:var(--text-primary)}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover td{background:var(--bg-hover)}.user-cell{align-items:center;gap:var(--space-3);display:flex}.user-cell-avatar{background:var(--accent-gradient);width:28px;height:28px;font-size:var(--font-size-xs);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.text-muted{color:var(--text-muted)}.role-badge{font-size:var(--font-size-xs);border-radius:var(--radius-full);padding:2px 8px;font-weight:600}.role-user{color:var(--info);background:#3b82f61f;border:1px solid #3b82f640}.role-superadmin{color:var(--accent-primary);background:#8b5cf61f;border:1px solid #8b5cf640}.role-select{background:var(--bg-overlay);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-xs);font-family:var(--font-family);cursor:pointer;padding:3px 8px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;padding:var(--space-4);background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:100%;max-width:480px;box-shadow:var(--shadow-md);animation:.3s slideUp}.modal-card--wide{max-width:620px}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.modal-header h2{font-size:var(--font-size-md);font-weight:700}.modal-close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:12px;display:flex}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-form{padding:var(--space-5) var(--space-6);gap:var(--space-4);flex-direction:column;display:flex}.form-row{gap:var(--space-1);flex-direction:column;display:flex}.form-row label{font-size:var(--font-size-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.form-input-sm{width:100%;padding:8px var(--space-3);background:var(--bg-overlay);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);font-family:var(--font-family);transition:all var(--transition-fast)}.assistant-instructions{resize:vertical;min-height:150px;line-height:1.6}.form-grid{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.assistant-tool-grid{gap:var(--space-2);grid-template-columns:repeat(3,1fr);display:grid}.assistant-tool-grid label{align-items:center;gap:var(--space-2);padding:var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-xs);background:#ffffff08;font-weight:700;display:flex}.assistant-tool-grid input{accent-color:var(--accent-primary)}@media (width<=720px){.admin-layout{flex-direction:column}.admin-sidebar{flex-direction:row;align-items:center;width:100%;overflow-x:auto}.admin-nav{flex-direction:row}.admin-main{padding:var(--space-4)}.form-grid,.assistant-tool-grid{grid-template-columns:1fr}}.form-input-sm:focus{border-color:var(--accent-primary);background:#8b5cf614;outline:none;box-shadow:0 0 0 3px #8b5cf61f}.modal-error{color:#fca5a5;font-size:var(--font-size-sm);padding:var(--space-3);border-radius:var(--radius-md);background:#ef44441a;border:1px solid #ef444433}.modal-footer{justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-2);display:flex}.form-hint{color:var(--text-muted);text-transform:none;letter-spacing:0;margin-left:var(--space-2);font-weight:400;font-size:var(--font-size-xs)}:root{--bg-base:#f7f7f5;--bg-surface:#f1f1ee;--bg-elevated:#fff;--bg-overlay:#ecefeb;--bg-hover:#10a37f14;--bg-active:#10a37f1f;--glass-bg:#ffffffc2;--glass-border:#0f172a14;--glass-blur:18px;--accent-primary:#10a37f;--accent-secondary:#4285f4;--accent-tertiary:#7c3aed;--accent-glow:#10a37f38;--accent-gradient:linear-gradient(135deg, #10a37f 0%, #4285f4 100%);--accent-soft-gradient:linear-gradient(135deg, #10a37f1f, #4285f41c);--text-primary:#202124;--text-secondary:#4b5563;--text-muted:#6b7280;--text-disabled:#a1a1aa;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--border-subtle:#0f172a12;--border-default:#0f172a1c;--border-accent:#10a37f59;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:28px;--radius-full:9999px;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:11px;--font-size-sm:13px;--font-size-base:15px;--font-size-md:16px;--font-size-lg:18px;--font-size-xl:24px;--font-size-2xl:32px;--font-size-3xl:48px;--sidebar-width:260px;--ease-standard:cubic-bezier(.2, 0, 0, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--transition-fast:.16s var(--ease-standard);--transition-normal:.26s var(--ease-standard);--transition-slow:.48s var(--ease-standard);--shadow-xs:0 1px 2px #0f172a0d;--shadow-sm:0 8px 24px #0f172a14;--shadow-md:0 18px 45px #0f172a1f;--shadow-glow:0 18px 55px #10a37f24}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);background:radial-gradient(circle at 48% -15%, #4285f424, transparent 35%), radial-gradient(circle at 85% 12%, #10a37f1a, transparent 28%), var(--bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}#root{flex-direction:column;height:100%;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#0f172a24}::-webkit-scrollbar-thumb:hover{background:#0f172a3d}::selection{color:#063f33;background:#10a37f38}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:var(--radius-sm)}.visually-hidden{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #10a37f00}50%{box-shadow:0 0 34px #10a37f38}}@keyframes typing-blink{0%,to{opacity:1}50%{opacity:0}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes float-glow{0%,to{opacity:.54;transform:translate(0,0)scale(1)}50%{opacity:.78;transform:translateY(-14px)scale(1.04)}}@keyframes dots{0%{content:"."}33%{content:".."}66%{content:"..."}to{content:"."}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes gentlePop{0%{opacity:0;transform:scale(.98)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes softSweep{0%{opacity:0;transform:translate(-120%)}35%{opacity:1}to{opacity:0;transform:translate(120%)}}pre{border-radius:var(--radius-md);font-size:var(--font-size-sm);line-height:1.7;overflow-x:auto}code{font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:.9em}:not(pre)>code{color:#08745d;border-radius:var(--radius-sm);background:#10a37f1a;border:1px solid #10a37f2e;padding:2px 6px}button{cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-base);color:inherit;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast), opacity var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none}button:disabled{cursor:not-allowed;opacity:.5}input,textarea{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);background:0 0;border:none;outline:none}textarea{resize:none;line-height:1.6}a{color:var(--accent-primary);text-decoration:none}a:hover{text-decoration:underline}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important}}
