@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--font-primary: "Outfit", sans-serif;--bg-main: #0B0F19;--bg-card: rgba(17, 24, 39, .7);--bg-sidebar: #070A13;--border-glass: rgba(255, 255, 255, .08);--border-glass-hover: rgba(255, 255, 255, .15);--text-primary: #F3F4F6;--text-secondary: #9CA3AF;--text-muted: #6B7280;--primary-color: #6366F1;--secondary-color: #3B82F6;--accent-gradient: linear-gradient(135deg, #6366F1 0%, #3B82F6 100%);--accent-glow: 0 0 20px rgba(99, 102, 241, .25);--bg-bubble-user: #1E293B;--bg-bubble-ai: rgba(99, 102, 241, .1);--border-bubble-ai: rgba(99, 102, 241, .2)}*{box-sizing:border-box;margin:0;padding:0}body,html{font-family:var(--font-primary);background-color:var(--bg-main);color:var(--text-primary);height:100vh;overflow:hidden;-webkit-font-smoothing:antialiased}.app-container{display:grid;grid-template-columns:320px 1fr;height:100vh;width:100vw;background:radial-gradient(circle at 70% 20%,rgba(99,102,241,.08) 0%,transparent 40%),radial-gradient(circle at 10% 80%,rgba(59,130,246,.06) 0%,transparent 35%),var(--bg-main)}.sidebar{background-color:var(--bg-sidebar);border-right:1px solid var(--border-glass);display:flex;flex-direction:column;height:100%;overflow:hidden}.sidebar-header{padding:24px;border-bottom:1px solid var(--border-glass);display:flex;flex-direction:column;gap:16px}.brand{display:flex;align-items:center;gap:12px}.brand-icon{width:32px;height:32px;background:var(--accent-gradient);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;box-shadow:var(--accent-glow)}.brand-title{font-size:1.15rem;font-weight:600;letter-spacing:.5px;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.btn-new-chat{background:var(--accent-gradient);color:#fff;border:none;padding:12px 16px;border-radius:10px;font-family:var(--font-primary);font-weight:500;font-size:.95rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #6366f133}.btn-new-chat:hover{transform:translateY(-2px);box-shadow:0 6px 16px #6366f159;filter:brightness(1.1)}.sidebar-tabs{display:flex;padding:0 16px;margin-top:16px;border-bottom:1px solid var(--border-glass)}.tab-btn{flex:1;background:none;border:none;color:var(--text-secondary);padding:10px 0;font-family:var(--font-primary);font-weight:500;font-size:.9rem;cursor:pointer;position:relative;transition:color .2s ease}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--primary-color)}.tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:2px;background:var(--accent-gradient)}.sidebar-content{flex:1;overflow-y:auto;padding:16px}.sidebar-content::-webkit-scrollbar{width:4px}.sidebar-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.conversation-item{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:8px;margin-bottom:8px;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.conversation-item:hover{background-color:#ffffff08;border-color:var(--border-glass)}.conversation-item.active{background-color:#6366f114;border-color:#6366f133}.convo-info{flex:1;min-width:0;margin-right:8px}.convo-title{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.convo-preview{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.btn-delete-convo{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:0}.conversation-item:hover .btn-delete-convo{opacity:1}.btn-delete-convo:hover{color:#ef4444;background-color:#ef44441a}.main-panel{display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.main-header{height:80px;border-bottom:1px solid var(--border-glass);padding:0 32px;display:flex;align-items:center;justify-content:space-between;background:#0b0f1966;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10}.active-chat-title{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.connection-badge{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-secondary);background-color:#10b9811a;border:1px solid rgba(16,185,129,.2);padding:6px 12px;border-radius:20px}.badge-dot{width:8px;height:8px;background-color:#10b981;border-radius:50%;box-shadow:0 0 8px #10b981}.messages-container{flex:1;overflow-y:auto;padding:32px;display:flex;flex-direction:column;gap:24px}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}.message-row{display:flex;gap:16px;max-width:80%;animation:fadeInUp .3s cubic-bezier(.4,0,.2,1)}.message-row.user{align-self:flex-end;flex-direction:row-reverse}.message-row.assistant{align-self:flex-start}.avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;flex-shrink:0}.message-row.user .avatar{background-color:var(--primary-color);color:#fff}.message-row.assistant .avatar{background:var(--accent-gradient);color:#fff;box-shadow:var(--accent-glow)}.message-bubble{border-radius:16px;padding:14px 18px;font-size:.95rem;line-height:1.5;word-break:break-word}.message-row.user .message-bubble{background-color:var(--bg-bubble-user);color:var(--text-primary);border-top-right-radius:4px;border:1px solid rgba(255,255,255,.05)}.message-row.assistant .message-bubble{background-color:var(--bg-bubble-ai);border:1px solid var(--border-bubble-ai);color:var(--text-primary);border-top-left-radius:4px;box-shadow:0 4px 12px #00000026}.message-time{font-size:.7rem;color:var(--text-muted);margin-top:6px;display:block}.message-row.user .message-time{text-align:right}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:40px;animation:fadeIn .5s ease}.empty-state-icon{font-size:3rem;margin-bottom:20px;animation:float 3s ease-in-out infinite}.empty-state-title{font-size:1.5rem;font-weight:600;margin-bottom:12px;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.empty-state-desc{color:var(--text-secondary);max-width:450px;font-size:.95rem;line-height:1.6}.input-area{padding:24px 32px 32px;background:linear-gradient(180deg,transparent 0%,var(--bg-main) 100%)}.input-wrapper{background-color:var(--bg-card);border:1px solid var(--border-glass);border-radius:14px;padding:8px 12px;display:flex;align-items:center;gap:12px;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.input-wrapper:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 2px #6366f126}.chat-input{flex:1;background:none;border:none;color:var(--text-primary);font-family:var(--font-primary);font-size:.95rem;padding:10px 4px;outline:none;resize:none;max-height:120px}.chat-input::placeholder{color:var(--text-muted)}.btn-send{background:var(--accent-gradient);border:none;color:#fff;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-send:hover{transform:scale(1.05);box-shadow:var(--accent-glow)}.btn-send:disabled{background:var(--bg-bubble-user);color:var(--text-muted);cursor:not-allowed;transform:none;box-shadow:none}.typing-indicator{display:flex;gap:6px;align-items:center;padding:12px 18px;background-color:var(--bg-bubble-ai);border:1px solid var(--border-bubble-ai);border-radius:4px 16px 16px;width:fit-content;margin-left:54px;animation:fadeIn .2s ease}.typing-dot{width:6px;height:6px;background-color:var(--primary-color);border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.typing-dot:nth-child(1){animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}.memory-manager{flex:1;overflow-y:auto;padding:32px;display:flex;flex-direction:column;gap:24px}.memory-header{display:flex;flex-direction:column;gap:16px}.memory-title-wrapper{display:flex;align-items:center;justify-content:space-between}.memory-title{font-size:1.4rem;font-weight:600;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.memory-subtitle{font-size:.9rem;color:var(--text-secondary);line-height:1.5}.search-bar{width:100%;max-width:400px;background-color:var(--bg-card);border:1px solid var(--border-glass);border-radius:10px;padding:10px 16px;color:var(--text-primary);font-family:var(--font-primary);outline:none;font-size:.9rem;transition:all .2s ease}.search-bar:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #6366f126}.memories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.memory-card{background-color:var(--bg-card);border:1px solid var(--border-glass);border-radius:12px;padding:18px;display:flex;flex-direction:column;justify-content:space-between;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.memory-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--accent-gradient);opacity:.7}.memory-card:hover{transform:translateY(-4px);border-color:var(--border-glass-hover);box-shadow:0 8px 24px #00000040}.memory-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.memory-entity{font-size:1.05rem;font-weight:600;color:var(--text-primary)}.btn-delete-memory{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-delete-memory:hover{color:#ef4444;background-color:#ef44441a}.memory-badge{background-color:#6366f11f;border:1px solid rgba(99,102,241,.2);color:#818cf8;font-size:.75rem;padding:3px 8px;border-radius:12px;align-self:flex-start;margin-bottom:8px;font-weight:500}.memory-action{font-size:.85rem;color:var(--text-secondary);line-height:1.5;margin-bottom:14px;flex:1}.memory-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(255,255,255,.05);padding-top:10px;font-size:.75rem;color:var(--text-muted)}.memory-date{display:flex;align-items:center;gap:4px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@media(max-width:768px){.app-container{grid-template-columns:1fr}.sidebar{display:none}}.auth-page-container{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100vw;background:radial-gradient(circle at 10% 20%,rgba(99,102,241,.1) 0%,transparent 45%),radial-gradient(circle at 90% 80%,rgba(59,130,246,.08) 0%,transparent 40%),#0b0f19;padding:20px}.auth-card{background-color:#111827b3;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:40px;width:100%;max-width:440px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 10px 30px #0000004d;animation:fadeInUp .4s cubic-bezier(.4,0,.2,1)}.auth-header{text-align:center;margin-bottom:30px;display:flex;flex-direction:column;align-items:center}.auth-brand-icon{width:48px;height:48px;background:linear-gradient(135deg,#6366f1,#3b82f6);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;margin-bottom:16px;box-shadow:0 0 20px #6366f14d}.auth-title{font-size:1.5rem;font-weight:700;margin-bottom:8px;background:linear-gradient(135deg,#6366f1,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.auth-subtitle{font-size:.88rem;color:var(--text-secondary)}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.form-input{background-color:#0b0f1999;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:12px 16px;color:#fff;font-family:Outfit,sans-serif;outline:none;font-size:.9rem;transition:all .2s ease}.form-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f126}.form-input.error{border-color:#ef4444}.form-error-msg{color:#ef4444;font-size:.78rem;margin-top:2px}.btn-auth-submit{background:linear-gradient(135deg,#6366f1,#3b82f6);color:#fff;border:none;padding:14px;border-radius:8px;font-family:Outfit,sans-serif;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;margin-top:10px;box-shadow:0 4px 12px #6366f133}.btn-auth-submit:hover{transform:translateY(-1px);box-shadow:0 6px 16px #6366f159;filter:brightness(1.1)}.btn-auth-submit:disabled{background:#1e293b;color:var(--text-muted);cursor:not-allowed;transform:none;box-shadow:none}.auth-footer{text-align:center;margin-top:24px;font-size:.88rem;color:var(--text-secondary)}.auth-link{color:#6366f1;text-decoration:none;font-weight:500;transition:color .2s ease}.auth-link:hover{color:#818cf8;text-decoration:underline}.sidebar-user-footer{border-top:1px solid rgba(255,255,255,.08);padding:16px;display:flex;align-items:center;justify-content:space-between;background-color:#070a1380;margin-top:auto}.user-details{display:flex;align-items:center;gap:12px;min-width:0}.user-avatar-small{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;flex-shrink:0}.user-meta{min-width:0}.user-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-logout{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-logout:hover{color:#fff;background-color:#ffffff0d}.warning-banner{background-color:#f59e0b1a;border:1px solid rgba(245,158,11,.25);color:#f59e0b;padding:12px 18px;border-radius:10px;font-size:.85rem;line-height:1.5;margin-bottom:12px}.settings-card{background-color:#111827b3;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:24px;max-width:600px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.admin-page-container{min-height:100vh;width:100vw;background:radial-gradient(circle at 80% 10%,rgba(99,102,241,.06) 0%,transparent 40%),radial-gradient(circle at 20% 90%,rgba(59,130,246,.04) 0%,transparent 35%),#0b0f19;color:var(--text-primary);overflow-y:auto}.admin-navbar{height:70px;border-bottom:1px solid var(--border-glass);padding:0 40px;display:flex;align-items:center;justify-content:space-between;background:#070a13cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100}.admin-nav-brand{display:flex;align-items:center;gap:12px}.admin-brand-logo{font-size:1.4rem}.admin-brand-text{font-size:1.15rem;font-weight:600;letter-spacing:.5px;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.admin-nav-actions{display:flex;align-items:center}.admin-main-content{max-width:1400px;margin:0 auto;padding:40px;display:flex;flex-direction:column;gap:32px}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.stat-card{background-color:var(--bg-card);border:1px solid var(--border-glass);border-radius:14px;padding:24px;display:flex;align-items:center;gap:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #00000026;transition:transform .2s ease}.stat-card:hover{transform:translateY(-2px)}.stat-icon{width:52px;height:52px;background:#ffffff08;border:1px solid var(--border-glass);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.6rem}.stat-info{display:flex;flex-direction:column}.stat-label{font-size:.85rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.8rem;font-weight:700;color:#fff;margin-top:4px}.admin-grid{display:grid;grid-template-columns:2.5fr 1.2fr;gap:32px;align-items:start}@media(max-width:1024px){.admin-grid{grid-template-columns:1fr}}.admin-card-large,.admin-card-small{background-color:var(--bg-card);border:1px solid var(--border-glass);border-radius:14px;padding:28px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #00000026}.card-title{font-size:1.15rem;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-glass);padding-bottom:16px;margin-bottom:20px}.table-responsive{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;text-align:left}.users-table th{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;border-bottom:1px solid var(--border-glass)}.users-table td{padding:16px;border-bottom:1px solid rgba(255,255,255,.05);font-size:.9rem;color:var(--text-primary)}.users-table tr:hover td{background-color:#ffffff03}.role-badge{font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:12px;display:inline-block}.role-badge.admin{background-color:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#f87171}.role-badge.user{background-color:#3b82f61a;border:1px solid rgba(59,130,246,.2);color:#60a5fa}.model-select-wrapper{display:flex;align-items:center;gap:8px}.model-select{background-color:#ffffff0d;border:1px solid var(--border-glass);color:var(--text-primary);font-family:var(--font-primary);font-size:.85rem;font-weight:500;padding:6px 12px;border-radius:8px;outline:none;cursor:pointer;transition:all .2s ease;background-image:none}.model-select:hover{background-color:#ffffff1a;border-color:var(--primary-color)}.model-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #6366f126}.model-select option{background-color:var(--bg-main);color:var(--text-primary);padding:8px}
