.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:.5rem 1.125rem;border-radius:var(--radius-md);font-weight:500;font-size:var(--text-sm);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;line-height:1.4}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:16px;height:16px;flex-shrink:0}.btn-primary{background:var(--accent-gradient);color:#fff;border-color:transparent;box-shadow:0 2px 8px #6366f14d}.btn-primary:hover:not(:disabled){background:var(--accent-gradient-hover);box-shadow:0 4px 16px #6366f166;transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--surface-border)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--surface-border-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--accent-primary-bg);color:var(--accent-primary)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-sm{padding:.325rem .75rem;font-size:var(--text-xs)}.btn-lg{padding:.75rem 1.5rem;font-size:var(--text-base)}.btn-icon{padding:.5rem;width:36px;height:36px}.input-group{display:flex;flex-direction:column;gap:var(--space-1)}.input-group label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}.input{padding:.5rem .75rem;background:var(--bg-input);border:1px solid var(--surface-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);transition:all var(--transition-fast);outline:none}.input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-bg)}.input::placeholder{color:var(--text-tertiary)}.input-error{border-color:var(--danger)}.select{padding:.5rem 2rem .5rem .75rem;background:var(--bg-input);border:1px solid var(--surface-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238b8ca7' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.card{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base)}.card-hover:hover{border-color:var(--surface-border-hover);background:var(--bg-card-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-glass{background:var(--surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-6)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:.2rem .625rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;white-space:nowrap}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.badge-accent{background:var(--accent-primary-bg);color:var(--accent-primary)}.modal-backdrop{position:fixed;inset:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-xl);padding:var(--space-8);min-width:420px;max-width:640px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .25s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.modal-header h2{font-size:var(--text-lg);font-weight:700}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--surface-border)}.table-container{overflow-x:auto;border:1px solid var(--surface-border);border-radius:var(--radius-lg)}table{width:100%;border-collapse:collapse}thead{background:var(--bg-tertiary)}th{padding:.75rem 1rem;text-align:left;font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}td{padding:.75rem 1rem;font-size:var(--text-sm);border-top:1px solid var(--surface-border)}tbody tr:hover{background:var(--bg-card-hover)}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot.success{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.warning{background:var(--warning);box-shadow:0 0 6px var(--warning)}.status-dot.danger{background:var(--danger);box-shadow:0 0 6px var(--danger)}.status-dot.running{background:var(--info);box-shadow:0 0 6px var(--info);animation:pulse 1.5s infinite}.metric-card{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);position:relative;overflow:hidden}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-gradient);opacity:0;transition:opacity var(--transition-base)}.metric-card:hover:before{opacity:1}.metric-card .metric-value{font-size:var(--text-2xl);font-weight:800}.metric-card .metric-label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.metric-card .metric-change{font-size:var(--text-xs);font-weight:600}.metric-card .metric-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.toggle{position:relative;width:44px;height:24px;cursor:pointer}.toggle input{display:none}.toggle-slider{position:absolute;inset:0;background:var(--bg-tertiary);border-radius:var(--radius-full);transition:var(--transition-base);border:1px solid var(--surface-border)}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:var(--text-secondary);top:2px;left:2px;transition:var(--transition-base)}.toggle input:checked+.toggle-slider{background:var(--accent-primary);border-color:var(--accent-primary)}.toggle input:checked+.toggle-slider:before{transform:translate(20px);background:#fff}.switch{position:relative;display:inline-block;width:32px;height:18px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-tertiary);transition:.4s}.slider:before{position:absolute;content:"";height:14px;width:14px;left:2px;bottom:2px;background-color:#fff;transition:.4s}input:checked+.slider{background-color:var(--accent-primary)}input:focus+.slider{box-shadow:0 0 1px var(--accent-primary)}input:checked+.slider:before{transform:translate(14px)}.slider.round{border-radius:34px}.slider.round:before{border-radius:50%}.tabs{display:flex;gap:0;border-bottom:1px solid var(--surface-border)}.tab{padding:.6rem 1.25rem;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast);background:none;border-top:none;border-left:none;border-right:none}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);font-weight:600}.search-input{display:flex;align-items:center;gap:var(--space-2);background:var(--bg-input);border:1px solid var(--surface-border);border-radius:var(--radius-md);padding:0 var(--space-3)}.search-input svg{width:16px;height:16px;color:var(--text-tertiary);flex-shrink:0}.search-input input{background:none;border:none;outline:none;color:var(--text-primary);padding:.5rem 0;flex:1;font-size:var(--text-sm)}.builder-container{display:flex;height:100%;overflow:hidden}.builder-canvas{flex:1;position:relative;background:var(--bg-primary)}.builder-toolbar{display:flex;gap:var(--space-2);background:var(--surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:var(--space-2);border-radius:var(--radius-lg);border:1px solid var(--surface-border)}.builder-actions{display:flex;gap:var(--space-2)}.config-panel{width:380px;background:var(--bg-secondary);border-left:1px solid var(--surface-border);display:flex;flex-direction:column;overflow:hidden;animation:slideInRight .25s ease}.config-panel-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--surface-border);display:flex;align-items:center;justify-content:space-between}.config-panel-body{flex:1;padding:var(--space-5);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-4)}.ai-chat-panel{width:400px;background:var(--bg-secondary);border-left:1px solid var(--surface-border);display:flex;flex-direction:column}.ai-chat-messages{flex:1;overflow-y:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.ai-chat-input{padding:var(--space-4);border-top:1px solid var(--surface-border);display:flex;gap:var(--space-2)}.ai-chat-input .input{flex:1}.chat-msg{display:flex;gap:var(--space-3)}.chat-msg.user{flex-direction:row-reverse}.chat-msg-bubble{max-width:85%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);line-height:1.6}.chat-msg.user .chat-msg-bubble{background:var(--accent-primary);color:#fff;border-bottom-right-radius:4px}.chat-msg.ai .chat-msg-bubble{background:var(--bg-tertiary);border-bottom-left-radius:4px}.chat-msg-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700}.chat-msg.user .chat-msg-avatar{background:var(--accent-gradient);color:#fff}.chat-msg.ai .chat-msg-avatar{background:var(--bg-tertiary);color:var(--accent-primary);border:1px solid var(--surface-border)}.mapper-container{display:flex;height:100%;position:relative}.mapper-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-lg);margin:var(--space-2)}.mapper-panel-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--surface-border);display:flex;align-items:center;justify-content:space-between}.mapper-panel-header h3{font-size:var(--text-sm);font-weight:600}.mapper-fields{flex:1;overflow-y:auto;padding:var(--space-2)}.mapper-field{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-sm);gap:var(--space-2)}.mapper-field:hover{background:var(--accent-primary-bg)}.mapper-field.mapped{background:var(--accent-primary-bg);border-left:3px solid var(--accent-primary)}.mapper-field.ambiguous{background:var(--warning-bg);border-left:3px solid var(--warning)}.mapper-canvas-container{width:120px;flex-shrink:0;position:relative}.confidence-badge{font-size:var(--text-xs);font-weight:700;padding:.15rem .5rem;border-radius:var(--radius-full)}.confidence-high{background:var(--success-bg);color:var(--success)}.confidence-medium{background:var(--warning-bg);color:var(--warning)}.confidence-low{background:var(--danger-bg);color:var(--danger)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4)}.template-card{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all var(--transition-base)}.template-card:hover{border-color:var(--accent-primary);transform:translateY(-3px);box-shadow:var(--shadow-glow)}.template-card-body{padding:var(--space-5)}.template-card-body h3{font-size:var(--text-base);font-weight:700;margin-bottom:var(--space-2)}.template-card-body p{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.template-card-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--surface-border);display:flex;align-items:center;justify-content:space-between}.template-tags{display:flex;gap:var(--space-1);flex-wrap:wrap;margin-top:var(--space-3)}.code-editor-container{display:flex;height:100%;gap:0;overflow:hidden}.code-editor-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.code-editor-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--surface-border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary)}.code-editor-body{flex:1;overflow:hidden}.code-output{height:200px;background:var(--bg-primary);border-top:1px solid var(--surface-border);padding:var(--space-4);overflow-y:auto;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary)}.filter-bar{display:flex;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;align-items:center}.filter-chip{padding:.3rem .75rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;cursor:pointer;border:1px solid var(--surface-border);background:transparent;color:var(--text-secondary);transition:all var(--transition-fast)}.filter-chip.active{background:var(--accent-primary-bg);color:var(--accent-primary);border-color:var(--accent-primary)}.filter-chip:hover{border-color:var(--surface-border-hover)}.folder-tree{display:flex;flex-direction:column;gap:var(--space-1)}.folder-item{display:flex;align-items:center;gap:var(--space-2);padding:.4rem .75rem;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-sm)}.folder-item:hover{background:var(--accent-primary-bg)}.folder-item.active{background:var(--accent-primary-bg);color:var(--accent-primary)}.folder-children{padding-left:var(--space-6)}.split-view{display:flex;height:100%;overflow:hidden}.split-left{width:280px;border-right:1px solid var(--surface-border);display:flex;flex-direction:column;overflow:hidden;background:var(--bg-secondary)}.split-right{flex:1;display:flex;flex-direction:column;overflow:hidden}.react-flow__background{background:var(--bg-primary)!important}.react-flow__node{cursor:grab}.react-flow__node:active{cursor:grabbing}.react-flow__minimap{background:var(--bg-secondary)!important;border:1px solid var(--surface-border)!important;border-radius:var(--radius-md)!important}.react-flow__controls{border:1px solid var(--surface-border)!important;border-radius:var(--radius-md)!important;overflow:hidden}.react-flow__controls button{background:var(--bg-secondary)!important;border-bottom:1px solid var(--surface-border)!important;color:var(--text-secondary)!important;fill:var(--text-secondary)!important}.react-flow__controls button:hover{background:var(--bg-card-hover)!important}:root{--bg-primary: #0a0b14;--bg-secondary: #12131f;--bg-tertiary: #1a1b2e;--bg-card: #161729;--bg-card-hover: #1e1f35;--bg-input: #1a1b2e;--bg-overlay: rgba(0, 0, 0, .6);--surface-border: rgba(255, 255, 255, .06);--surface-border-hover: rgba(255, 255, 255, .12);--surface-glass: rgba(22, 23, 41, .8);--text-primary: #f0f0f5;--text-secondary: #8b8ca7;--text-tertiary: #5a5b78;--text-inverse: #0a0b14;--accent-primary: #6366f1;--accent-primary-hover: #818cf8;--accent-primary-bg: rgba(99, 102, 241, .12);--accent-secondary: #8b5cf6;--accent-gradient: linear-gradient(135deg, #6366f1, #8b5cf6);--accent-gradient-hover: linear-gradient(135deg, #818cf8, #a78bfa);--success: #10b981;--success-bg: rgba(16, 185, 129, .12);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .12);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .12);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .12);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.125rem;--text-xl: 1.5rem;--text-2xl: 1.875rem;--text-3xl: 2.25rem;--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: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(99, 102, 241, .3);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--sidebar-width: 260px;--sidebar-collapsed: 68px;--topbar-height: 60px}*,*: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-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow:hidden;height:100vh}#root{height:100vh;display:flex}a{color:var(--accent-primary);text-decoration:none}a:hover{color:var(--accent-primary-hover)}input,textarea,select,button{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.flex{display:flex}.flex-1{flex:1}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.m-0{margin:0}.text-center{text-align:center}.relative{position:relative}.absolute{position:absolute}.inset-0{inset:0}.w-full{width:100%}.h-full{height:100%}.rounded{border-radius:var(--radius-sm)}.rounded-lg{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-lg)}.overflow-hidden{overflow:hidden}.transition-all{transition:var(--transition-base)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--surface-border);display:flex;flex-direction:column;transition:width var(--transition-base);flex-shrink:0;height:100vh;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{padding:var(--space-5) var(--space-5);display:flex;align-items:center;gap:var(--space-3);border-bottom:1px solid var(--surface-border);height:var(--topbar-height)}.sidebar-brand h1{font-size:var(--text-lg);font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;white-space:nowrap}.sidebar-nav{flex:1;padding:var(--space-3);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-section{padding:var(--space-3) var(--space-3) var(--space-1);font-size:var(--text-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:.55rem .75rem;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-sm);font-weight:500;text-decoration:none;white-space:nowrap}.nav-item:hover{background:var(--accent-primary-bg);color:var(--text-primary)}.nav-item.active{background:var(--accent-primary-bg);color:var(--accent-primary);font-weight:600}.nav-item svg{width:20px;height:20px;flex-shrink:0}.sidebar-footer{padding:var(--space-3);border-top:1px solid var(--surface-border)}.topbar{height:var(--topbar-height);background:var(--bg-secondary);border-bottom:1px solid var(--surface-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:var(--space-4)}.topbar-right{display:flex;align-items:center;gap:var(--space-3)}.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.breadcrumb span:last-child{color:var(--text-primary);font-weight:600}.notification-btn{position:relative}.notification-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;background:var(--danger);color:#fff;font-size:.625rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:380px;background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100;max-height:400px;overflow-y:auto}.notification-item{padding:var(--space-4);border-bottom:1px solid var(--surface-border);cursor:pointer;transition:background var(--transition-fast)}.notification-item:hover{background:var(--bg-card-hover)}.notification-item:last-child{border-bottom:none}.ai-mode-indicator{display:flex;align-items:center;gap:var(--space-2);padding:.3rem .75rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-sm);color:#fff;cursor:pointer}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.page-content{flex:1;overflow-y:auto;padding:var(--space-6)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.page-header h1{font-size:var(--text-xl);font-weight:800}.page-header p{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-4)}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-top:var(--space-6)}.chart-card{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-5)}.chart-card h3{font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-4)}.login-page{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.15),transparent 70%);top:-100px;right:-100px;border-radius:50%}.login-page:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,.1),transparent 70%);bottom:-50px;left:-50px;border-radius:50%}.login-card{background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-xl);padding:var(--space-10);width:100%;max-width:440px;z-index:1;box-shadow:var(--shadow-lg)}.login-card h1{text-align:center;margin-bottom:var(--space-2);font-size:var(--text-xl);font-weight:800}.login-card .subtitle{text-align:center;color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-8)}.login-form{display:flex;flex-direction:column;gap:var(--space-4)}.login-brand{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-6)}.login-brand img{width:40px;height:40px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-line{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--border-color) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;height:16px}.skeleton-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.fade-in{animation:fadeIn .3s ease}.slide-up{animation:slideUp .3s ease}.spinner{animation:spin .8s linear infinite}@media(max-width:1200px){.charts-grid{grid-template-columns:1fr}}.sidebar-hamburger,.sidebar-overlay{display:none}@media(max-width:768px){.sidebar-hamburger{display:flex;align-items:center;justify-content:center;position:fixed;top:14px;left:16px;z-index:1100;width:36px;height:36px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:18px;cursor:pointer}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000073;z-index:1049}.sidebar{display:none;position:fixed;top:0;left:0;height:100%;z-index:1050}.sidebar.mobile-open{display:flex;flex-direction:column}.metrics-grid{grid-template-columns:1fr 1fr}}.skip-nav-link{position:absolute;top:-60px;left:0;z-index:9999;padding:8px 16px;background:var(--accent-primary);color:#fff;font-size:var(--text-sm);font-weight:600;border-radius:0 0 var(--radius-md) 0;text-decoration:none;transition:top .15s}.skip-nav-link:focus{top:0}@media(max-width:640px){.page-content{padding:var(--space-4)}.charts-grid{grid-template-columns:1fr}.table-container{overflow-x:auto}.modal{max-width:calc(100vw - 1rem);max-height:calc(100vh - 4rem);overflow-y:auto}}
