@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.auth-layout{background: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(80px);opacity:.35;border-radius:50%;position:absolute}.orb-1{background:radial-gradient(circle,#8b5cf6,#0000 70%);width:400px;height:400px;animation:8s ease-in-out infinite float-glow;top:-100px;left:-100px}.orb-2{background:radial-gradient(circle,#6366f1,#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,#a78bfa,#0000 70%);width:200px;height:200px;animation:12s ease-in-out 2s infinite float-glow;top:50%;left:60%}.auth-card{background:var(--glass-bg);border:1px solid var(--glass-border);width:100%;max-width:420px;-webkit-backdrop-filter:blur(var(--glass-blur));border-radius:var(--radius-xl);padding:var(--space-8) var(--space-8);box-shadow:var(--shadow-md), 0 0 60px #8b5cf61a;animation:.5s slideUp;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:linear-gradient(135deg,#8b5cf633,#6366f133);border:1px solid #8b5cf64d;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.auth-logo-text{font-size:var(--font-size-xl);background:var(--accent-gradient);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-weight:700}.auth-title{font-size:var(--font-size-xl);color:var(--text-primary);margin-bottom:var(--space-1);letter-spacing:-.5px;font-weight:700}.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);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base);font-family:var(--font-family);transition:all var(--transition-fast);background:#ffffff0d}.form-input::placeholder{color:var(--text-disabled)}.form-input:focus{border-color:var(--accent-primary);background:#8b5cf614;outline:none;box-shadow:0 0 0 3px #8b5cf626}.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);border-radius:var(--radius-md);color:#fca5a5;font-size:var(--font-size-sm);background:#ef44441a;border:1px solid #ef444440;animation:.3s slideUp;display:flex}.btn-primary{width:100%;padding:13px var(--space-6);background:var(--accent-gradient);border-radius:var(--radius-md);font-size:var(--font-size-base);color:#fff;letter-spacing:.2px;transition:all var(--transition-fast);margin-top:var(--space-2);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: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:500}.auth-footer a:hover{color:#a78bfa;text-decoration:none}@media (width<=480px){.auth-card{padding:var(--space-6)}}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border-subtle);transition:width var(--transition-normal), transform var(--transition-normal);z-index:50;flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar--closed{border:none;width:0}.sidebar--open{width:var(--sidebar-width)}.sidebar-header{padding:var(--space-4);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;height:56px;display:flex}.sidebar-logo{align-items:center;gap:var(--space-2);display:flex}.sidebar-logo-text{font-size:var(--font-size-md);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.sidebar-new-btn{border-radius:var(--radius-md);width:30px;height:30px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.sidebar-new-btn:hover{background:var(--bg-hover);color:var(--accent-primary)}.sidebar-content{padding:var(--space-3) var(--space-2);flex:1;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-radius:var(--radius-lg);background:var(--bg-elevated);width:48px;height:48px;color:var(--text-disabled);margin-bottom:var(--space-2);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-4)}.conv-group-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;padding:0 var(--space-2) var(--space-2);font-weight:600}.conv-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);group:true;display:flex;position:relative}.conv-item:hover{background:var(--bg-hover)}.conv-item--active{background:var(--bg-active)}.conv-item-icon{color:var(--text-muted);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;line-height:1.3;overflow:hidden}.conv-item-date{font-size:var(--font-size-xs);color:var(--text-muted)}.conv-item-delete{opacity:0;border-radius:var(--radius-sm);width:24px;height:24px;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}.conv-item-delete:hover{color:var(--error);background:#ef444426}@media (width<=768px){.sidebar{height:100%;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar--open{width:var(--sidebar-width);transform:translate(0)}}.message-row{gap:var(--space-3);padding:var(--space-2) 0;animation:.3s slideUp;display:flex}.message-row--user{flex-direction:row-reverse}.message-row--assistant{flex-direction:row;align-items:flex-start}.message-avatar{border-radius:var(--radius-md);width:28px;height:28px;font-size:var(--font-size-xs);flex-shrink:0;justify-content:center;align-items:center;margin-top:4px;font-weight:700;display:flex}.assistant-avatar{background:linear-gradient(135deg,#8b5cf633,#6366f133);border:1px solid #8b5cf640}.user-avatar-bubble{background:var(--accent-gradient);color:#fff;font-size:11px}.message-bubble{max-width:min(680px,85%);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);line-height:1.7}.bubble-user{background:var(--accent-gradient);color:#fff;border-bottom-right-radius:var(--radius-sm)}.bubble-assistant{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-bottom-left-radius:var(--radius-sm)}.message-text{white-space:pre-wrap;word-break:break-word}.message-error{align-items:center;gap:var(--space-2);color:#fca5a5;font-size:var(--font-size-sm);display:flex}.message-markdown{font-size:var(--font-size-base);color:var(--text-primary);word-break:break-word}.message-markdown>:first-child{margin-top:0}.message-markdown>:last-child{margin-bottom:0}.message-markdown p{margin:.5em 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:700;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:#8b5cf60f;margin:.8em 0;padding:.4em .8em}.message-markdown hr{border:none;border-top:1px solid var(--border-subtle);margin:1em 0}.table-wrapper{border-radius:var(--radius-md);border:1px solid var(--border-default);margin:.8em 0;overflow-x:auto}.message-markdown table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.message-markdown th{background:var(--bg-overlay);padding:var(--space-2) var(--space-3);text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border-default);font-weight:600}.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:var(--bg-hover)}.code-block{border-radius:var(--radius-md);border:1px solid var(--border-subtle);margin:.8em 0;overflow:hidden}.code-block-header{padding:6px var(--space-4);border-bottom:1px solid var(--border-subtle);background:#0000004d;justify-content:space-between;align-items:center;display:flex}.code-lang{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:lowercase;font-weight:500}.copy-btn{align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast);padding:3px 8px;display:flex}.copy-btn:hover{color:var(--text-primary);background:#ffffff14}.code-block-actions{align-items:center;gap:var(--space-1);display:flex}.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-md);max-width:260px;font-size:var(--font-size-xs);text-overflow:ellipsis;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff2e;padding:6px 9px;line-height:1.2;display:inline-flex;overflow:hidden}.message-attachment-icon,.message-artifact-chip span{border-radius:var(--radius-sm);letter-spacing:.4px;background:#ffffff24;padding:2px 5px;font-size:9px;font-weight:800}.message-artifact-chip{color:var(--text-secondary);border-color:var(--border-subtle);background:#8b5cf614}.message-artifact-chip:hover{color:var(--text-primary);border-color:var(--border-accent)}.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:.7px;font-weight:700}.message-citation{gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-md);border:1px solid var(--border-subtle);color:var(--text-secondary);background:#ffffff08;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}.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}.chat-window{flex:1;overflow:hidden auto}.chat-messages{max-width:780px;padding:var(--space-6) var(--space-4);gap:var(--space-1);flex-direction:column;margin:0 auto;display:flex}.thinking-indicator{align-items:center;gap:var(--space-3);padding:var(--space-3) 0;animation:.3s slideUp;display:flex}.thinking-avatar{border-radius:var(--radius-md);background:linear-gradient(135deg,#8b5cf633,#6366f133);border:1px solid #8b5cf640;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.thinking-dots{align-items:center;gap:5px;display:flex}.thinking-dots span{background:var(--accent-primary);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite thinking-bounce}.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:780px;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-md);border:1px solid var(--border-subtle);min-height:30px;font-size:var(--font-size-xs);color:var(--text-secondary);background:#ffffff0a;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:#c4b5fd;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:#ef44441f}.composer{align-items:flex-end;gap:var(--space-2);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-3) var(--space-3) var(--space-5);transition:all var(--transition-fast);box-shadow:var(--shadow-sm);display:flex}.composer-file-input{display:none}.composer:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b5cf61f, var(--shadow-sm)}.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);width:36px;height:36px;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.composer-tool-btn{color:var(--text-muted);border:1px solid #0000}.composer-tool-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.composer-search-toggle.active{color:var(--accent-primary);border-color:var(--border-accent);background:var(--bg-active)}.composer-btn--send{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 8px #8b5cf666}.composer-btn--send:hover{transform:scale(1.05);box-shadow:0 4px 16px #8b5cf680}.composer-btn--send:active{transform:scale(.95)}.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}.composer-btn--mic{color:var(--text-disabled);cursor:not-allowed;background:0 0}.welcome-screen{padding:var(--space-8);flex-direction:column;flex:1;justify-content:center;align-items:center;animation:.6s fadeIn;display:flex;position:relative;overflow:hidden}.welcome-glow{pointer-events:none;background:radial-gradient(circle,#8b5cf626 0%,#0000 70%);border-radius:50%;width:500px;height:500px;animation:4s ease-in-out infinite pulse-glow;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.welcome-logo{margin-bottom:var(--space-6);animation:.5s .1s both slideUp}.welcome-logo-hex{border-radius:var(--radius-xl);background:linear-gradient(135deg,#8b5cf626,#6366f126);border:1px solid #8b5cf640;justify-content:center;align-items:center;width:72px;height:72px;display:flex;box-shadow:0 0 40px #8b5cf633}.welcome-title{font-size:clamp(var(--font-size-xl), 4vw, var(--font-size-2xl));color:var(--text-primary);text-align:center;letter-spacing:-.5px;margin-bottom:var(--space-3);font-weight:700;animation:.5s .2s both slideUp}.welcome-subtitle{font-size:var(--font-size-sm);color:var(--text-muted);margin-bottom:var(--space-10);animation:.5s .3s both slideUp}.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:2px 10px;font-weight:600;display:inline-block}.welcome-suggestions{gap:var(--space-3);grid-template-columns:repeat(2,1fr);width:100%;max-width:560px;animation:.5s .4s both slideUp;display:grid}.suggestion-chip{align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);text-align:left;transition:all var(--transition-normal);display:flex;position:relative;overflow:hidden}.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);transform:translateY(-2px);box-shadow:0 8px 24px #8b5cf626}.suggestion-chip:hover:before{opacity:.05}.suggestion-icon{z-index:1;font-size:20px;position:relative}.suggestion-label{font-size:var(--font-size-sm);color:var(--text-primary);z-index:1;flex:1;font-weight:500;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}.welcome-title{font-size:var(--font-size-lg)}}.model-picker{align-items:center;gap:var(--space-2);padding:5px var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-full);background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;transition:all var(--transition-fast);display:flex;position:relative}.model-picker:hover{border-color:var(--border-accent);background:var(--bg-hover)}.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:500;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{background:var(--bg-elevated);color:var(--text-primary)}.model-picker-chevron{color:var(--text-muted);pointer-events:none;flex-shrink:0}.assistant-picker{align-items:center;gap:var(--space-2);height:34px;padding:0 var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-full);background:var(--glass-bg);color:var(--text-primary);display:flex}.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:600}.assistant-picker-select option{background:var(--bg-elevated);color:var(--text-primary)}.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:var(--bg-base);height:100vh;display:flex;overflow:hidden}.chat-workbench{flex:1;min-width:0;display:flex;overflow:hidden}.chat-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.chat-header{padding:0 var(--space-4);border-bottom:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(12px);z-index:10;background:#0a0a0fcc;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;display:flex}.chat-header-left,.chat-header-right{align-items:center;gap:var(--space-1);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-icon-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.header-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.header-admin-btn{align-items:center;gap:var(--space-1);padding:6px var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--accent-primary);border:1px solid var(--border-accent);background:var(--bg-active);transition:all var(--transition-fast);font-weight:500;display:flex}.header-admin-btn:hover{background:#8b5cf633}.header-user{align-items:center;gap:var(--space-2);display:flex}.user-avatar{background:var(--accent-gradient);width:30px;height:30px;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}.chat-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.composer-area{padding:var(--space-3) var(--space-4) var(--space-4);flex-shrink:0}.composer-disclaimer{text-align:center;font-size:var(--font-size-xs);color:var(--text-disabled);margin-top:var(--space-2)}.sidebar-overlay{z-index:40;background:#00000080;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar-overlay{display:block}.chat-header-center{margin-left:var(--space-2);flex:0;justify-content:flex-start}.chat-header-right{min-width:auto}.header-admin-btn{justify-content:center;width:36px;height:36px;padding:0;font-size:0}}.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:#0a0a0f;--bg-surface:#111118;--bg-elevated:#1a1a26;--bg-overlay:#22223a;--bg-hover:#8b5cf614;--bg-active:#8b5cf626;--glass-bg:#ffffff0a;--glass-border:#ffffff14;--glass-blur:16px;--accent-primary:#8b5cf6;--accent-secondary:#6366f1;--accent-glow:#8b5cf64d;--accent-gradient:linear-gradient(135deg, #8b5cf6 0%, #6366f1 100%);--text-primary:#f1f0ff;--text-secondary:#a09ec0;--text-muted:#6b6a8a;--text-disabled:#44435a;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--border-subtle:#ffffff0f;--border-default:#ffffff1a;--border-accent:#8b5cf666;--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:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--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;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 24px #0006;--shadow-glow:0 0 40px #8b5cf633}*,: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-color: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:#ffffff1a}::-webkit-scrollbar-thumb:hover{background:#fff3}::selection{color:var(--text-primary);background:#8b5cf659}: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(12px)}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 20px #8b5cf633}50%{box-shadow:0 0 40px #8b5cf680}}@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:.6;transform:translateY(0)scale(1)}50%{opacity:.9;transform:translateY(-20px)scale(1.1)}}@keyframes dots{0%{content:"."}33%{content:".."}66%{content:"..."}to{content:"."}}@keyframes spin{to{transform:rotate(360deg)}}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:#c4b5fd;border-radius:var(--radius-sm);background:#8b5cf626;border:1px solid #8b5cf633;padding:2px 6px}button{cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-base);color:inherit;transition:all var(--transition-fast);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}
