.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--color-bg-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow:hidden}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-5) var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0}.logo-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:800;color:#fff;box-shadow:0 2px 12px var(--color-accent-glow);flex-shrink:0}.logo-text{display:flex;flex-direction:column}.logo-title{font-size:var(--font-size-md);font-weight:700;letter-spacing:-.01em}.logo-sub{font-size:var(--font-size-xs);color:var(--color-text-muted)}.sidebar-nav{flex:1;padding:var(--space-4) var(--space-3);display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);transition:all var(--transition-fast);position:relative}.nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.nav-item--active{background:var(--color-accent-muted);color:var(--color-accent)}.nav-item--active:before{content:"";position:absolute;top:20%;bottom:20%;width:3px;background:var(--gradient-accent);border-radius:0 2px 2px 0;left:-12px}.nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}.nav-label{flex:1}.sidebar-footer{padding:var(--space-4) var(--space-4);border-top:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.user-avatar{width:32px;height:32px;flex-shrink:0;border-radius:50%;background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:700;color:#fff}.user-info{min-width:0}.user-email{font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-primary)}.user-role{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.logout-btn{font-size:16px;flex-shrink:0}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;background:var(--color-bg-base)}.content-inner{padding:var(--space-8) var(--space-10);max-width:1280px}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0}.content-inner{padding:var(--space-4)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg-base);position:relative;overflow:hidden}.login-glow{position:absolute;top:-200px;left:50%;transform:translate(-50%);width:600px;height:400px;background:radial-gradient(ellipse,rgba(99,102,241,.18) 0%,transparent 70%);pointer-events:none}.login-card{width:100%;max-width:420px;margin:var(--space-4);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-8);box-shadow:var(--shadow-lg),0 0 60px #6366f114;position:relative}.login-card:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--color-accent),transparent)}.login-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:var(--space-8)}.login-logo-icon{width:56px;height:56px;border-radius:var(--radius-lg);background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);font-weight:800;color:#fff;box-shadow:0 4px 24px var(--color-accent-glow);margin-bottom:var(--space-4);animation:pulse-glow 3s infinite}@keyframes pulse-glow{0%,to{box-shadow:0 4px 20px #6366f14d}50%{box-shadow:0 4px 32px #6366f180}}.login-title{font-size:var(--font-size-2xl);font-weight:700;letter-spacing:-.02em;margin-bottom:var(--space-1)}.login-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.login-error{background:var(--color-danger-muted);border:1px solid rgba(239,68,68,.2);color:var(--color-danger);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.login-submit{width:100%;justify-content:center;margin-top:var(--space-2);height:44px}.login-hint{margin-top:var(--space-6);text-align:center;font-size:var(--font-size-xs);color:var(--color-text-muted)}.login-hint code{background:var(--color-bg-elevated);border:1px solid var(--color-border);padding:1px 6px;border-radius:var(--radius-sm);font-size:inherit;color:var(--color-accent)}:root{--color-bg-base: #0d0f14;--color-bg-surface: #13161e;--color-bg-elevated: #1a1e2a;--color-bg-hover: #1f2433;--color-border: #252a38;--color-border-subtle: #1e2330;--color-accent: #6366f1;--color-accent-hover: #7c7ff5;--color-accent-muted: rgba(99, 102, 241, .12);--color-accent-glow: rgba(99, 102, 241, .25);--color-success: #22c55e;--color-success-muted: rgba(34, 197, 94, .12);--color-warning: #f59e0b;--color-warning-muted: rgba(245, 158, 11, .12);--color-danger: #ef4444;--color-danger-muted: rgba(239, 68, 68, .12);--color-info: #38bdf8;--color-info-muted: rgba(56, 189, 248, .12);--color-text-primary: #e8eaf0;--color-text-secondary: #8b92a5;--color-text-muted: #555e72;--gradient-accent: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--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;--space-16: 4rem;--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: .875rem;--radius-xl: 1.25rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 12px rgba(0,0,0,.5);--shadow-lg: 0 8px 28px rgba(0,0,0,.6);--transition-fast: .15s ease;--transition-normal: .22s ease;--sidebar-width: 240px;--topbar-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);font-size:var(--font-size-md);color:var(--color-text-primary);background:var(--color-bg-base);-webkit-font-smoothing:antialiased;min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font-family:inherit}input,textarea,select{font-family:inherit}ul,ol{list-style:none}::-webkit-scrollbar{width:5px;height:5px}::-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-muted)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--gradient-accent);color:#fff;box-shadow:0 2px 8px var(--color-accent-glow)}.btn-primary:hover{filter:brightness(1.12);transform:translateY(-1px);box-shadow:0 4px 16px var(--color-accent-glow)}.btn-primary:active{transform:none;filter:brightness(.95)}.btn-secondary{background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-hover);border-color:var(--color-accent);color:var(--color-accent)}.btn-ghost{color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.btn-danger{background:var(--color-danger-muted);color:var(--color-danger);border:1px solid rgba(239,68,68,.2)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--font-size-md)}.card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.card-hover:hover{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent-muted),var(--shadow-md)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-full)}.badge-success{background:var(--color-success-muted);color:var(--color-success)}.badge-warning{background:var(--color-warning-muted);color:var(--color-warning)}.badge-danger{background:var(--color-danger-muted);color:var(--color-danger)}.badge-info{background:var(--color-info-muted);color:var(--color-info)}.badge-accent{background:var(--color-accent-muted);color:var(--color-accent)}.badge-muted{background:var(--color-bg-elevated);color:var(--color-text-muted)}.input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input::placeholder{color:var(--color-text-muted)}.input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-muted)}.label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.table-wrapper{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:500;color:var(--color-text-muted);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border)}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr{background:var(--color-bg-surface);transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--color-bg-hover)}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--color-bg-elevated) 25%,var(--color-bg-hover) 50%,var(--color-bg-elevated) 75%);background-size:800px 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-8);flex-wrap:wrap;gap:var(--space-4)}.page-title{font-size:var(--font-size-2xl);font-weight:700;letter-spacing:-.02em}.page-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-8)}.stat-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);position:relative;overflow:hidden;transition:all var(--transition-normal)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent);opacity:0;transition:opacity var(--transition-normal)}.stat-card:hover{border-color:var(--color-accent);transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:var(--space-4)}.stat-value{font-size:var(--font-size-3xl);font-weight:700;letter-spacing:-.03em;line-height:1;margin-bottom:var(--space-1)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.stat-delta{font-size:var(--font-size-xs);font-weight:500;margin-top:var(--space-2)}.stat-delta.up{color:var(--color-success)}.stat-delta.down{color:var(--color-danger)}.conv-item{display:flex;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--color-border-subtle);cursor:pointer;transition:background var(--transition-fast);position:relative}.conv-item:hover{background:var(--color-bg-hover)}.conv-item.active{background:var(--color-accent-muted)}.conv-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gradient-accent);border-radius:0 2px 2px 0}.conv-avatar{width:40px;height:40px;flex-shrink:0;border-radius:50%;background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:700;color:#fff}.conv-meta{flex:1;min-width:0}.conv-name{font-size:var(--font-size-sm);font-weight:600;margin-bottom:2px}.conv-preview{font-size:var(--font-size-xs);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-time{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0}.conv-unread{width:18px;height:18px;border-radius:50%;background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center;color:var(--color-text-muted)}.empty-state-icon{font-size:48px;margin-bottom:var(--space-4);opacity:.5}.empty-state-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.empty-state-desc{font-size:var(--font-size-sm);max-width:320px}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.animate-fade-in{animation:fade-in .3s ease forwards}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
