@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";
:root{--primary-50:#eef2ff;--primary-100:#d8e0ff;--primary-200:#b3c4ff;--primary-300:#829cff;--primary-400:#5a75f5;--primary-500:#3b55e6;--primary-600:#2a3fbf;--primary-700:#1e2d99;--primary-800:#142073;--primary-900:#0c1650;--accent-50:#f0fdfa;--accent-100:#ccfbf1;--accent-200:#99f6e4;--accent-300:#5eead4;--accent-400:#2dd4bf;--accent-500:#14b8a6;--accent-600:#0d9488;--accent-700:#0f766e;--neutral-50:#f8fafc;--neutral-100:#f1f5f9;--neutral-200:#e2e8f0;--neutral-300:#cbd5e1;--neutral-400:#94a3b8;--neutral-500:#64748b;--neutral-600:#475569;--neutral-700:#334155;--neutral-800:#1e293b;--neutral-900:#0f172a;--success-50:#f0fdf4;--success-100:#dcfce7;--success-500:#22c55e;--success-600:#16a34a;--success-700:#15803d;--warning-50:#fffbeb;--warning-100:#fef3c7;--warning-500:#f59e0b;--warning-600:#d97706;--danger-50:#fef2f2;--danger-100:#fee2e2;--danger-500:#ef4444;--danger-600:#dc2626;--info-50:#eff6ff;--info-100:#dbeafe;--info-500:#3b82f6;--info-600:#2563eb;--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-elevated:#fff;--bg-sidebar:#0f172a;--bg-sidebar-hover:#1e293b;--bg-sidebar-active:#3b55e626;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--text-inverse:#fff;--text-sidebar:#cbd5e1;--text-sidebar-active:#fff;--border-light:#e2e8f0;--border-medium:#cbd5e1;--border-focus:#3b55e6;--glass-bg:#ffffffbf;--glass-border:#fff3;--glass-blur:16px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--space-0:0;--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;--space-20:5rem;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-2xl:28px;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--shadow-2xl:0 25px 50px -12px #00000026;--shadow-glow:0 0 20px #3b55e626;--shadow-glow-accent:0 0 20px #14b8a626;--shadow-card:0 1px 3px #0000000a, 0 4px 12px #00000008;--shadow-card-hover:0 4px 12px #00000014, 0 8px 24px #0000000f;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width:260px;--sidebar-collapsed-width:72px;--header-height:64px;--content-max-width:1400px;--z-dropdown:100;--z-sticky:200;--z-modal-backdrop:300;--z-modal:400;--z-toast:500;--z-tooltip:600}[data-theme=dark]{--bg-primary:#0b1120;--bg-secondary:#111827;--bg-elevated:#1a2332;--bg-sidebar:#060b18;--bg-sidebar-hover:#111827;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-tertiary:#64748b;--border-light:#1e293b;--border-medium:#334155;--glass-bg:#111827cc;--glass-border:#33415580;--shadow-card:0 1px 3px #0003, 0 4px 12px #00000026;--shadow-card-hover:0 4px 12px #0000004d, 0 8px 24px #0003}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:var(--leading-normal);min-height:100vh;overflow-x:hidden}a{color:inherit;text-decoration:none}img,svg{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}ul,ol{list-style:none}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.font-light{font-weight:300}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--neutral-700)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #3b55e666}50%{box-shadow:0 0 0 8px #3b55e600}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes progress-stripe{0%{background-position:1rem 0}to{background-position:0 0}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) ease-out}.animate-fade-in-down{animation:fadeInDown var(--transition-slow) ease-out}.animate-slide-in-left{animation:slideInLeft var(--transition-slow) ease-out}.animate-slide-in-right{animation:slideInRight var(--transition-slow) ease-out}.animate-scale-in{animation:scaleIn var(--transition-base) ease-out}.animate-spin{animation:1s linear infinite spin}.animate-float{animation:3s ease-in-out infinite float}.stagger-children>*{animation:fadeInUp var(--transition-slow) ease-out both}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:60ms}.stagger-children>:nth-child(3){animation-delay:.12s}.stagger-children>:nth-child(4){animation-delay:.18s}.stagger-children>:nth-child(5){animation-delay:.24s}.stagger-children>:nth-child(6){animation-delay:.3s}.stagger-children>:nth-child(7){animation-delay:.36s}.stagger-children>:nth-child(8){animation-delay:.42s}.skeleton{background:linear-gradient(90deg, var(--neutral-200) 25%, var(--neutral-100) 50%, var(--neutral-200) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}[data-theme=dark] .skeleton{background:linear-gradient(90deg, var(--neutral-800) 25%, var(--neutral-700) 50%, var(--neutral-800) 75%);background-size:200% 100%}:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px;border-radius:var(--radius-sm)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);font-size:var(--text-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;font-weight:600;line-height:1.5;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";opacity:0;transition:opacity var(--transition-fast);background:linear-gradient(135deg,#ffffff1a,#0000);position:absolute;inset:0}.btn:hover:after{opacity:1}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));color:#fff;box-shadow:var(--shadow-sm), 0 2px 8px #3b55e640}.btn-primary:hover{background:linear-gradient(135deg, var(--primary-400), var(--primary-500));box-shadow:var(--shadow-md), 0 4px 12px #3b55e659;transform:translateY(-1px)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-light);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--neutral-50);border-color:var(--border-medium);box-shadow:var(--shadow-sm)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--neutral-100);color:var(--text-primary)}.btn-danger{background:linear-gradient(135deg, var(--danger-500), var(--danger-600));color:#fff;box-shadow:var(--shadow-sm), 0 2px 8px #ef444440}.btn-danger:hover{box-shadow:var(--shadow-md), 0 4px 12px #ef444459;transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg, var(--success-500), var(--success-600));color:#fff;box-shadow:var(--shadow-sm), 0 2px 8px #22c55e40}.btn-success:hover{box-shadow:var(--shadow-md), 0 4px 12px #22c55e59;transform:translateY(-1px)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-sm)}.btn-lg{padding:var(--space-3) var(--space-8);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md);width:36px;height:36px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-card);transition:all var(--transition-base)}.card-hover:hover{box-shadow:var(--shadow-card-hover);border-color:var(--border-medium);transform:translateY(-2px)}.card-glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.card-accent{border-left:4px solid var(--primary-500)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-base);color:var(--text-primary);font-weight:600}.card-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.stats-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-card);transition:all var(--transition-base);position:relative;overflow:hidden}.stats-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stats-card[data-color=blue]:before{background:linear-gradient(90deg, var(--primary-400), var(--primary-600))}.stats-card[data-color=teal]:before{background:linear-gradient(90deg, var(--accent-400), var(--accent-600))}.stats-card[data-color=amber]:before{background:linear-gradient(90deg, var(--warning-500), #f97316)}.stats-card[data-color=green]:before{background:linear-gradient(90deg, var(--success-500), var(--success-700))}.stats-card[data-color=red]:before{background:linear-gradient(90deg, var(--danger-500), #dc2626)}.stats-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.stats-card .stats-icon{border-radius:var(--radius-md);width:44px;height:44px;margin-bottom:var(--space-3);justify-content:center;align-items:center;font-size:20px;display:flex}.stats-card[data-color=blue] .stats-icon{background:var(--primary-50);color:var(--primary-600)}.stats-card[data-color=teal] .stats-icon{background:var(--accent-50);color:var(--accent-600)}.stats-card[data-color=amber] .stats-icon{background:var(--warning-50);color:var(--warning-600)}.stats-card[data-color=green] .stats-icon{background:var(--success-50);color:var(--success-600)}.stats-card[data-color=red] .stats-icon{background:var(--danger-50);color:var(--danger-600)}.stats-value{font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.02em;margin-bottom:var(--space-1);font-weight:800;line-height:1}.stats-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.stats-change{align-items:center;gap:var(--space-1);font-size:var(--text-xs);border-radius:var(--radius-full);margin-top:var(--space-2);padding:2px 8px;font-weight:600;display:inline-flex}.stats-change.positive{background:var(--success-50);color:var(--success-700)}.stats-change.negative{background:var(--danger-50);color:var(--danger-600)}.input-group{gap:var(--space-1);flex-direction:column;display:flex}.input-label{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);background:var(--bg-secondary);border:1.5px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast)}.input:hover{border-color:var(--border-medium)}.input:focus{border-color:var(--primary-500);outline:none;box-shadow:0 0 0 3px #3b55e61a}.input::placeholder{color:var(--text-tertiary)}.input-error{border-color:var(--danger-500)}.input-error:focus{box-shadow:0 0 0 3px #ef44441a}.input-helper{font-size:var(--text-xs);color:var(--text-tertiary)}.input-error-msg{font-size:var(--text-xs);color:var(--danger-500)}.input-with-icon{position:relative}.input-with-icon .input{padding-left:var(--space-10)}.input-with-icon .input-icon{left:var(--space-3);color:var(--text-tertiary);pointer-events:none;font-size:18px;position:absolute;top:50%;transform:translateY(-50%)}.badge{align-items:center;gap:var(--space-1);font-size:var(--text-xs);border-radius:var(--radius-full);white-space:nowrap;padding:2px 10px;font-weight:600;display:inline-flex}.badge-blue{background:var(--primary-50);color:var(--primary-700)}.badge-green{background:var(--success-50);color:var(--success-700)}.badge-red{background:var(--danger-50);color:var(--danger-600)}.badge-amber{background:var(--warning-50);color:var(--warning-600)}.badge-teal{background:var(--accent-50);color:var(--accent-700)}.badge-gray{background:var(--neutral-100);color:var(--neutral-600)}.badge-dot:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.table-wrapper{border:1px solid var(--border-light);border-radius:var(--radius-lg);background:var(--bg-secondary);width:100%;overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{padding:var(--space-3) var(--space-4);font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;text-align:left;background:var(--neutral-50);border-bottom:1px solid var(--border-light);white-space:nowrap;font-weight:600}.table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-primary);border-bottom:1px solid var(--border-light);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--neutral-50)}.table-clickable tbody tr{cursor:pointer}[data-theme=dark] .table th{background:var(--neutral-900)}[data-theme=dark] .table tbody tr:hover{background:var(--neutral-800)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);animation:fadeIn var(--transition-fast) ease-out;background:#00000080;position:fixed;inset:0}.modal{background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);z-index:var(--z-modal);width:90%;max-width:560px;max-height:90vh;animation:scaleIn var(--transition-base) ease-out;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%)}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-lg);font-weight:700}.modal-body{padding:var(--space-6)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-light);display:flex}.toast-container{top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);gap:var(--space-2);flex-direction:column;display:flex;position:fixed}.toast{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);min-width:320px;max-width:420px;animation:slideInRight var(--transition-base) ease-out;display:flex}.toast-success{border-left:4px solid var(--success-500)}.toast-error{border-left:4px solid var(--danger-500)}.toast-warning{border-left:4px solid var(--warning-500)}.toast-info{border-left:4px solid var(--info-500)}.toast-message{flex:1}.toast-title{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.toast-description{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px}.toast-close{color:var(--text-tertiary);border-radius:var(--radius-sm);padding:2px}.toast-close:hover{color:var(--text-primary);background:var(--neutral-100)}.dropzone{border:2px dashed var(--border-medium);border-radius:var(--radius-xl);padding:var(--space-12) var(--space-8);text-align:center;transition:all var(--transition-base);cursor:pointer;background:var(--bg-secondary)}.dropzone:hover{border-color:var(--primary-400);background:var(--primary-50)}.dropzone.active{border-color:var(--primary-500);background:var(--primary-50);box-shadow:0 0 0 4px #3b55e61a}.dropzone-icon{margin-bottom:var(--space-4);color:var(--text-tertiary);transition:all var(--transition-base);font-size:48px}.dropzone:hover .dropzone-icon,.dropzone.active .dropzone-icon{color:var(--primary-500);transform:translateY(-4px)}.dropzone-title{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:var(--space-2);font-weight:600}.dropzone-subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.dropzone-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-3)}.progress-bar{background:var(--neutral-200);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--primary-500), var(--accent-500));border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow);position:relative}.progress-bar-fill.animated{background-image:linear-gradient(45deg,#ffffff26 25%,#0000 25% 50%,#ffffff26 50% 75%,#0000 75%,#0000);background-size:1rem 1rem;animation:1s linear infinite progress-stripe}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--space-6);opacity:.4;font-size:64px}.empty-state-title{font-size:var(--text-xl);color:var(--text-primary);margin-bottom:var(--space-2);font-weight:700}.empty-state-description{font-size:var(--text-sm);color:var(--text-secondary);max-width:400px;margin-bottom:var(--space-6)}.layout-wrapper{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);height:100vh;color:var(--text-sidebar);z-index:var(--z-sticky);transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar-logo{align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-5);min-height:var(--header-height);border-bottom:1px solid #ffffff0f;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--primary-400), var(--accent-400));border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;font-weight:800;display:flex}.sidebar-logo-text{font-size:var(--text-base);color:#fff;white-space:nowrap;font-weight:700}.sidebar-logo-badge{background:var(--accent-500);color:#fff;border-radius:var(--radius-full);letter-spacing:.05em;text-transform:uppercase;padding:1px 6px;font-size:9px;font-weight:700}.sidebar-nav{padding:var(--space-4) var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.sidebar-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--neutral-500);padding:var(--space-4) var(--space-3) var(--space-2);font-size:10px;font-weight:700}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-sidebar);transition:all var(--transition-fast);font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{background:var(--bg-sidebar-hover);color:#fff}.sidebar-link.active{background:var(--bg-sidebar-active);color:var(--primary-300)}.sidebar-link.active:before{content:"";background:var(--primary-400);border-radius:0 4px 4px 0;width:3px;height:20px;position:absolute;top:50%;left:-12px;transform:translateY(-50%)}.sidebar-link-icon{text-align:center;flex-shrink:0;width:22px;font-size:18px}.sidebar-link-badge{background:var(--danger-500);color:#fff;border-radius:var(--radius-full);text-align:center;min-width:20px;margin-left:auto;padding:1px 7px;font-size:11px;font-weight:700}.sidebar-footer{padding:var(--space-4);border-top:1px solid #ffffff0f}.sidebar-user{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer;display:flex}.sidebar-user:hover{background:var(--bg-sidebar-hover)}.sidebar-user-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--primary-400), var(--accent-400));width:34px;height:34px;font-size:var(--text-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--text-sm);color:#fff;white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user-role{font-size:var(--text-xs);color:var(--neutral-400)}.main-content{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-base);flex:1}.main-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border-bottom:1px solid var(--border-light);z-index:var(--z-sticky);height:var(--header-height);padding:0 var(--space-8);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.main-header-left{align-items:center;gap:var(--space-4);display:flex}.main-header-right{align-items:center;gap:var(--space-3);display:flex}.page-title{font-size:var(--text-xl);color:var(--text-primary);font-weight:700}.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.main-body{padding:var(--space-8);max-width:var(--content-max-width);animation:fadeInUp var(--transition-slow) ease-out}.notification-bell{border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-light);width:40px;height:40px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:18px;display:flex;position:relative}.notification-bell:hover{background:var(--neutral-100);color:var(--text-primary)}.notification-bell .badge-count{border-radius:var(--radius-full);background:var(--danger-500);color:#fff;border:2px solid var(--bg-primary);justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-weight:700;animation:2s ease-in-out infinite pulse-glow;display:flex;position:absolute;top:-4px;right:-4px}.search-bar{width:100%;max-width:400px;position:relative}.search-bar input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) var(--space-10);font-size:var(--text-sm);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-full);color:var(--text-primary);transition:all var(--transition-fast)}.search-bar input:focus{border-color:var(--primary-400);outline:none;width:110%;box-shadow:0 0 0 3px #3b55e614}.search-bar .search-icon{left:var(--space-3);color:var(--text-tertiary);font-size:16px;position:absolute;top:50%;transform:translateY(-50%)}.search-bar .search-shortcut{right:var(--space-3);font-size:var(--text-xs);color:var(--text-tertiary);background:var(--neutral-100);border-radius:var(--radius-sm);font-family:var(--font-mono);padding:1px 6px;position:absolute;top:50%;transform:translateY(-50%)}.grid-stats{gap:var(--space-5);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.grid-2{gap:var(--space-5);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-5);grid-template-columns:repeat(3,1fr);display:grid}.alert-item{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer;display:flex}.alert-item:hover{background:var(--neutral-50)}.alert-item-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.alert-item-dot.critical{background:var(--danger-500)}.alert-item-dot.warning{background:var(--warning-500)}.alert-item-dot.info{background:var(--info-500)}.alert-item-dot.success{background:var(--success-500)}.alert-item-content{flex:1;min-width:0}.alert-item-text{font-size:var(--text-sm);color:var(--text-primary);line-height:var(--leading-normal)}.alert-item-time{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.calendar-grid{background:var(--border-light);border-radius:var(--radius-lg);border:1px solid var(--border-light);grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.calendar-header-cell{padding:var(--space-2) var(--space-1);font-size:var(--text-xs);color:var(--text-secondary);text-align:center;background:var(--neutral-50);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.calendar-cell{min-height:80px;padding:var(--space-1);background:var(--bg-secondary);transition:background var(--transition-fast);position:relative}.calendar-cell:hover{background:var(--neutral-50)}.calendar-cell.other-month{opacity:.3}.calendar-cell.today{background:var(--primary-50)}.calendar-day-number{font-size:var(--text-xs);color:var(--text-primary);padding:var(--space-1);font-weight:600}.calendar-cell.today .calendar-day-number{background:var(--primary-500);color:#fff;border-radius:var(--radius-full);justify-content:center;align-items:center;width:24px;height:24px;display:flex}.calendar-event{white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border-radius:3px;margin-top:1px;padding:1px 4px;font-size:10px;overflow:hidden}.calendar-event.expiry{background:var(--danger-100);color:var(--danger-600)}.calendar-event.payment{background:var(--warning-100);color:var(--warning-600)}.calendar-event.renewal{background:var(--success-100);color:var(--success-700)}.tabs{gap:var(--space-1);border-bottom:1px solid var(--border-light);margin-bottom:var(--space-6);display:flex}.tab{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;border-bottom:2px solid #0000;font-weight:500}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--primary-600);border-bottom-color:var(--primary-500);font-weight:600}.gauge-wrapper{align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.gauge{width:120px;height:120px;position:relative}.gauge-circle{width:100%;height:100%;font-size:var(--text-2xl);color:var(--text-primary);border-radius:50%;justify-content:center;align-items:center;font-weight:800;display:flex}.gauge-label{font-size:var(--text-sm);color:var(--text-secondary);text-align:center;font-weight:600}@media (max-width:1024px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.main-body{padding:var(--space-4)}.main-header{padding:0 var(--space-4)}.grid-stats{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{grid-template-columns:1fr}.search-bar input:focus{width:100%}}@media (max-width:480px){.grid-stats{grid-template-columns:1fr}}.auth-wrapper{background:var(--bg-primary);min-height:100vh;padding:var(--space-4);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-wrapper:before{content:"";background:radial-gradient(circle at 30% 40%,#3b55e60f 0%,#0000 50%),radial-gradient(circle at 70% 60%,#14b8a60a 0%,#0000 50%);width:200%;height:200%;animation:20s ease-in-out infinite alternate float;position:absolute;top:-50%;left:-50%}.auth-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-2xl);width:100%;max-width:440px;padding:var(--space-10);box-shadow:var(--shadow-xl);z-index:1;animation:fadeInUp var(--transition-slow) ease-out;position:relative}.auth-logo{align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);justify-content:center;display:flex}.auth-logo-icon{background:linear-gradient(135deg, var(--primary-400), var(--accent-400));border-radius:var(--radius-lg);color:#fff;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;font-weight:800;display:flex}.auth-logo-text{font-size:var(--text-xl);background:linear-gradient(135deg, var(--primary-500), var(--accent-500));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.auth-title{font-size:var(--text-2xl);text-align:center;margin-bottom:var(--space-2);font-weight:800}.auth-subtitle{font-size:var(--text-sm);color:var(--text-secondary);text-align:center;margin-bottom:var(--space-8)}.auth-form{gap:var(--space-5);flex-direction:column;display:flex}.auth-divider{align-items:center;gap:var(--space-4);color:var(--text-tertiary);font-size:var(--text-xs);display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-light);flex:1;height:1px}.auth-footer{text-align:center;margin-top:var(--space-6);font-size:var(--text-sm);color:var(--text-secondary)}.auth-footer a{color:var(--primary-500);transition:color var(--transition-fast);font-weight:600}.auth-footer a:hover{color:var(--primary-600)}.confidence-bar{align-items:center;gap:var(--space-3);display:flex}.confidence-bar-track{background:var(--neutral-200);border-radius:var(--radius-full);flex:1;height:8px;overflow:hidden}.confidence-bar-fill{border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.confidence-bar-fill.high{background:linear-gradient(90deg, var(--success-500), var(--accent-500))}.confidence-bar-fill.medium{background:linear-gradient(90deg, var(--warning-500), #f97316)}.confidence-bar-fill.low{background:linear-gradient(90deg, var(--danger-500), #dc2626)}.confidence-label{font-size:var(--text-sm);text-align:right;min-width:40px;font-weight:700}.policy-type-badge{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;display:inline-flex}.landing-hero{min-height:100vh;padding:var(--space-8);text-align:center;background:linear-gradient(135deg, var(--neutral-900) 0%, #1a1f3d 50%, var(--primary-900) 100%);color:#fff;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.landing-hero:before{content:"";background:radial-gradient(circle,#3b55e626,#0000 70%);width:600px;height:600px;animation:6s ease-in-out infinite float;position:absolute;top:20%;left:50%;transform:translate(-50%)}.landing-hero-content{z-index:1;max-width:800px;position:relative}.landing-hero h1{margin-bottom:var(--space-6);background:linear-gradient(135deg, #fff 0%, var(--primary-200) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(2.5rem,5vw,4rem);font-weight:800;line-height:1.1}.landing-hero p{font-size:var(--text-lg);color:var(--neutral-300);margin-bottom:var(--space-8);line-height:var(--leading-relaxed)}.landing-cta-group{justify-content:center;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.landing-cta-primary{padding:var(--space-3) var(--space-8);background:linear-gradient(135deg, var(--primary-400), var(--primary-600));color:#fff;font-size:var(--text-base);border-radius:var(--radius-full);transition:all var(--transition-base);font-weight:700;box-shadow:0 4px 20px #3b55e666}.landing-cta-primary:hover{transform:translateY(-2px);box-shadow:0 6px 30px #3b55e680}.landing-cta-secondary{padding:var(--space-3) var(--space-8);color:#fff;font-size:var(--text-base);border-radius:var(--radius-full);transition:all var(--transition-base);background:#ffffff14;border:1px solid #ffffff26;font-weight:600}.landing-cta-secondary:hover{background:#ffffff26;border-color:#ffffff4d}.review-panel{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-xl);overflow:hidden}.review-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-light);background:var(--neutral-50);justify-content:space-between;align-items:center;display:flex}.review-body{padding:var(--space-6)}.review-section{margin-bottom:var(--space-6)}.review-section-title{font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3);align-items:center;gap:var(--space-2);font-weight:700;display:flex}.review-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.review-field{flex-direction:column;gap:2px;display:flex}.review-field-label{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500}.review-field-value{font-size:var(--text-sm);color:var(--text-primary);padding:var(--space-2) var(--space-3);background:var(--neutral-50);border-radius:var(--radius-sm);border:1px solid var(--border-light);font-weight:600}.review-field-value.editable{cursor:text;transition:all var(--transition-fast)}.review-field-value.editable:hover{border-color:var(--primary-300)}.review-field-value.editable:focus{border-color:var(--primary-500);outline:none;box-shadow:0 0 0 3px #3b55e61a}.review-actions{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-light);background:var(--neutral-50);display:flex}.chart-container{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-card)}.chart-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.chart-title{font-size:var(--text-base);color:var(--text-primary);font-weight:700}.chart-legend{align-items:center;gap:var(--space-4);display:flex}.chart-legend-item{align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary);display:flex}.chart-legend-dot{border-radius:50%;width:8px;height:8px}.spinner{border:2.5px solid var(--neutral-200);border-top-color:var(--primary-500);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner-lg{border-width:3.5px;width:40px;height:40px}.ai-processing{padding:var(--space-12);justify-content:center;align-items:center;gap:var(--space-6);flex-direction:column;display:flex}.ai-brain{font-size:64px;animation:2s ease-in-out infinite float}.ai-dots{gap:var(--space-2);display:flex}.ai-dots span{background:var(--primary-500);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite float}.ai-dots span:nth-child(2){animation-delay:.2s}.ai-dots span:nth-child(3){animation-delay:.4s}.ai-status-text{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.skeleton{background:linear-gradient(90deg, var(--neutral-100) 25%, var(--neutral-200) 50%, var(--neutral-100) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-card)}.skeleton-line{height:14px;margin-bottom:var(--space-3);border-radius:var(--radius-sm)}.skeleton-line.short{width:60%}.skeleton-line.medium{width:80%}.skeleton-line.long{width:100%}.skeleton-circle{border-radius:50%;width:44px;height:44px}.skeleton-value{width:120px;height:28px;margin-bottom:var(--space-2);border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pulse-circle{animation:2s ease-out infinite pulse-ring}@keyframes pulse-ring{0%{box-shadow:0 0 #4f46e566}70%{box-shadow:0 0 0 20px #4f46e500}to{box-shadow:0 0 #4f46e500}}.mobile-menu-btn{display:none!important}@media (max-width:768px){.mobile-menu-btn{display:flex!important}.sidebar{transition:transform var(--transition-base);transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0!important}.grid-stats{grid-template-columns:repeat(2,1fr)!important}.grid-2,.hero-grid,.review-grid{grid-template-columns:1fr!important}.search-bar{display:none!important}}@media (max-width:480px){.grid-stats{grid-template-columns:1fr!important}}
