:root{--color-bg-primary: #0a0e17;--color-bg-secondary: #111827;--color-bg-surface: #1a2332;--color-bg-elevated: #1f2b3d;--color-bg-hover: #253349;--color-bg-input: #0d1420;--color-border: #2a3a50;--color-border-subtle: #1e2d42;--color-border-focus: #3b82f6;--color-text-primary: #e8edf5;--color-text-secondary: #8899b0;--color-text-tertiary: #5a6f8a;--color-text-inverse: #0a0e17;--color-accent: #3b82f6;--color-accent-hover: #2563eb;--color-accent-subtle: rgba(59, 130, 246, .12);--color-accent-glow: rgba(59, 130, 246, .25);--color-success: #10b981;--color-success-bg: rgba(16, 185, 129, .12);--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .12);--color-error: #ef4444;--color-error-bg: rgba(239, 68, 68, .12);--color-admin-badge: #a78bfa;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--color-accent-glow);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 280px;--header-height: 56px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;min-height:100vh}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}button{cursor:pointer;font-family:var(--font-family);border:none;outline:none;transition:all var(--transition-base)}input,textarea{font-family:var(--font-family);outline:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border-subtle);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-header{padding:var(--space-6);border-bottom:1px solid var(--color-border-subtle)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3)}.sidebar-logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--color-accent),var(--color-admin-badge));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-md);color:#fff;flex-shrink:0}.brand-mark.with-image{background:#fff;padding:4px;overflow:hidden}.brand-mark img{width:100%;height:100%;object-fit:contain;border-radius:inherit}.sidebar-logo-text{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);line-height:1.3}.sidebar-logo-sub{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:400}.sidebar-nav{flex:1;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast)}.sidebar-link:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar-link.active{background:var(--color-accent-subtle);color:var(--color-accent)}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-4) var(--space-4) var(--space-2)}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--color-border-subtle)}.main-content{flex:1;display:flex;flex-direction:column;min-width:0}.main-header{height:var(--header-height);border-bottom:1px solid var(--color-border-subtle);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);background:var(--color-bg-secondary);flex-shrink:0}.main-header-title{font-size:var(--font-size-md);font-weight:600}.usage-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500}.usage-badge.available{background:var(--color-success-bg);color:var(--color-success)}.usage-badge.exhausted{background:var(--color-error-bg);color:var(--color-error)}.usage-badge.unlimited{background:var(--color-accent-subtle);color:var(--color-accent)}.user-menu{display:flex;align-items:center;gap:var(--space-3)}.user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-accent),var(--color-admin-badge));display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:700;color:#fff}.user-info{display:flex;flex-direction:column}.user-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary)}.role-badge{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.role-badge.admin{color:var(--color-admin-badge)}.role-badge.user{color:var(--color-text-tertiary)}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.chat-message{max-width:80%;padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);font-size:var(--font-size-base);line-height:1.7;animation:messageIn .3s ease}@keyframes messageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{background:var(--color-accent);color:#fff;align-self:flex-end;border-bottom-right-radius:var(--radius-sm)}.chat-message.assistant{background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);align-self:flex-start;border-bottom-left-radius:var(--radius-sm)}.chat-message-meta{margin-top:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-tertiary);display:flex;gap:var(--space-3)}.chat-message.user .chat-message-meta{color:#fff9}.chat-input-container{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-subtle);background:var(--color-bg-secondary)}.chat-input-wrapper{display:flex;gap:var(--space-3);max-width:900px;margin:0 auto}.chat-input{flex:1;padding:var(--space-3) var(--space-5);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:var(--font-size-base);resize:none;transition:border-color var(--transition-fast)}.chat-input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-accent-subtle)}.chat-input::placeholder{color:var(--color-text-tertiary)}.chat-input:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn{padding:var(--space-3) var(--space-6);background:var(--color-accent);color:#fff;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:600;display:flex;align-items:center;gap:var(--space-2)}.chat-send-btn:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:var(--shadow-glow)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.limit-banner{padding:var(--space-4) var(--space-6);background:var(--color-error-bg);border:1px solid rgba(239,68,68,.2);color:var(--color-error);text-align:center;font-size:var(--font-size-sm);font-weight:500}.loading-dots{display:flex;gap:var(--space-1);padding:var(--space-4)}.loading-dot{width:8px;height:8px;background:var(--color-text-tertiary);border-radius:var(--radius-full);animation:dotPulse 1.4s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.landing-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 30%,var(--color-accent-subtle) 0%,transparent 60%),var(--color-bg-primary);padding:var(--space-8);text-align:center}.landing-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--color-accent),var(--color-admin-badge));border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:800;color:#fff;margin-bottom:var(--space-6);box-shadow:var(--shadow-glow)}.landing-title{font-size:var(--font-size-3xl);font-weight:700;background:linear-gradient(135deg,var(--color-text-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-4)}.landing-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);max-width:500px;margin-bottom:var(--space-8);line-height:1.8}.landing-badge{display:inline-block;padding:var(--space-1) var(--space-4);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-bottom:var(--space-8);letter-spacing:.03em}.landing-login-btn{padding:var(--space-4) var(--space-8);background:var(--color-accent);color:#fff;border-radius:var(--radius-lg);font-size:var(--font-size-md);font-weight:600;box-shadow:var(--shadow-glow);margin-bottom:var(--space-3)}.landing-login-btn:hover{background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 0 30px var(--color-accent-glow)}.landing-mock-section{margin-top:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.landing-mock-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);padding:var(--space-1) var(--space-3);background:var(--color-warning-bg);border-radius:var(--radius-full);color:var(--color-warning)}.landing-mock-btns{display:flex;gap:var(--space-3)}.mock-btn{padding:var(--space-3) var(--space-5);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500}.mock-btn:hover{background:var(--color-bg-hover);border-color:var(--color-accent);color:var(--color-text-primary)}.admin-page{padding:var(--space-8);overflow-y:auto}.admin-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-6)}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-6)}.admin-card{background:var(--color-bg-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-6)}.admin-card-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-4)}.admin-stat{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary)}.admin-stat-label{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:var(--radius-full);margin-right:var(--space-2)}.status-dot.online{background:var(--color-success);box-shadow:0 0 6px var(--color-success)}.status-dot.offline{background:var(--color-error);box-shadow:0 0 6px var(--color-error)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);color:var(--color-text-tertiary);text-align:center;gap:var(--space-3)}.empty-state-icon{font-size:2.5rem;opacity:.4}.error-message{padding:var(--space-4);background:var(--color-error-bg);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm)}.logout-btn{padding:var(--space-2) var(--space-4);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-xs)}.logout-btn:hover:not(:disabled){border-color:var(--color-error);color:var(--color-error)}.logout-btn:disabled{opacity:.5;cursor:not-allowed}.error-banner{padding:var(--space-3) var(--space-6);background:var(--color-error-bg);border-top:1px solid rgba(239,68,68,.2);color:var(--color-error);font-size:var(--font-size-sm);font-weight:500;display:flex;align-items:center;justify-content:space-between;cursor:pointer;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.error-dismiss{background:none;color:var(--color-error);font-size:1.25rem;padding:0 var(--space-2);opacity:.7}.error-dismiss:hover{opacity:1}.limit-banner{padding:var(--space-4) var(--space-6);background:linear-gradient(135deg,#ef444414,#ef44440a);border-top:1px solid rgba(239,68,68,.15);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-4)}.limit-banner-icon{font-size:1.5rem;flex-shrink:0}.limit-banner-text{display:flex;flex-direction:column;gap:var(--space-1)}.limit-banner-text strong{color:var(--color-error);font-size:var(--font-size-sm)}.limit-banner-text span{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.send-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:var(--radius-full);animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-loading{display:flex;align-items:center;gap:var(--space-2)}.chat-input-hint{max-width:900px;margin:var(--space-1) auto 0;font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-align:right;padding-right:var(--space-2)}.chat-message-content{white-space:pre-wrap;word-break:break-word}.meta-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;background:#ffffff0a;border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.meta-label{font-weight:600;opacity:.6;text-transform:uppercase;font-size:.625rem;letter-spacing:.05em}.meta-time{font-size:var(--font-size-xs);opacity:.5;margin-left:auto}.usage-progress{font-weight:600}.usage-label{font-size:.6875rem;opacity:.8}.usage-icon{font-size:.875rem}.admin-tabs{display:flex;gap:var(--space-1);margin-bottom:var(--space-6);border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-1)}.admin-tab{padding:var(--space-2) var(--space-5);background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-md) var(--radius-md) 0 0;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.admin-tab:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.admin-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.admin-table-container{overflow-x:auto;margin-top:var(--space-3)}.admin-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.admin-table th{text-align:left;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text-tertiary);font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em}.admin-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle);color:var(--color-text-secondary)}.admin-table tr:hover td{background:var(--color-bg-hover)}.admin-table tr:last-child td{border-bottom:none}.admin-status-badge{display:inline-block;padding:.125rem .5rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.admin-status-badge.online{background:var(--color-success-bg);color:var(--color-success)}.admin-status-badge.offline{background:var(--color-error-bg);color:var(--color-error)}.admin-loading{display:flex;justify-content:center;padding:var(--space-4)}.admin-loading .loading-dots{padding:0}.nav-icon{width:20px;text-align:center;flex-shrink:0}
