@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-navy:#141533;--color-navy-800:#1c1f45;--color-navy-700:#252952;--color-navy-600:#2f3460;--color-navy-500:#3a3f72;--color-blue:#3e53e3;--color-blue-hover:#3347cc;--color-blue-light:#eef0fd;--color-blue-muted:#3e53e31f;--color-white:#fff;--color-gray-50:#f8f9fc;--color-gray-100:#f1f3f9;--color-gray-200:#e4e8f0;--color-gray-300:#cdd3e0;--color-gray-400:#9aa3b8;--color-gray-500:#6b7591;--color-gray-600:#4a5272;--color-gray-700:#333b5c;--color-gray-900:#0f1124;--color-success:#22c55e;--color-success-light:#f0fdf4;--color-warning:#f59e0b;--color-warning-light:#fffbeb;--color-danger:#ef4444;--color-danger-light:#fef2f2;--color-info:#06b6d4;--color-info-light:#ecfeff;--sidebar-width:240px;--sidebar-bg:var(--color-navy);--sidebar-text:#ffffffa6;--sidebar-text-active:#fff;--sidebar-icon-muted:#ffffff59;--surface-bg:var(--color-gray-50);--surface-card:var(--color-white);--surface-border:var(--color-gray-200);--surface-border-subtle:#0000000d;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.6875rem;--font-size-sm:.75rem;--font-size-base:.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;--font-size-4xl:2.25rem;--font-weight-light:300;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.25;--line-height-snug:1.375;--line-height-normal:1.5;--line-height-relaxed:1.625;--letter-spacing-tight:-.02em;--letter-spacing-normal:0em;--letter-spacing-wide:.02em;--letter-spacing-widest:.08em;--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:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -1px #0000000a;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a;--shadow-xl:0 20px 25px -5px #00000014, 0 10px 10px -5px #00000008;--shadow-blue:0 4px 14px #3e53e340;--transition-fast:.1s ease;--transition-base:.15s ease;--transition-slow:.25s ease;--z-sidebar:100;--z-header:90;--z-dropdown:200;--z-modal:300;--z-toast:400}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-gray-700);background-color:var(--surface-bg);overflow-x:hidden}img,svg,video{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}a{color:inherit;text-decoration:none}ul,ol{list-style:none}#root{text-align:left;border:none;width:100%;max-width:100%;min-height:100vh;margin:0;display:flex}.sidebar{width:var(--sidebar-width);background-color:var(--sidebar-bg);height:100vh;z-index:var(--z-sidebar);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-logo{align-items:center;gap:var(--space-3);padding:var(--space-6);border-bottom:1px solid #ffffff0f;flex-shrink:0;display:flex}.sidebar-logo-mark{background:var(--color-blue);border-radius:var(--radius-md);width:32px;height:32px;box-shadow:var(--shadow-blue);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logo-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-white);letter-spacing:var(--letter-spacing-tight)}.sidebar-nav{padding:var(--space-4) var(--space-3);scrollbar-width:none;flex:1;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{display:none}.sidebar-section-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-widest);text-transform:uppercase;color:var(--sidebar-icon-muted);padding:var(--space-4) var(--space-3) var(--space-2)}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--sidebar-text);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);transition:background var(--transition-base), color var(--transition-base);cursor:pointer;margin-bottom:2px;display:flex}.nav-item:hover{color:var(--sidebar-text-active);background-color:#ffffff0f}.nav-item.active{background-color:var(--color-blue);color:var(--sidebar-text-active);box-shadow:var(--shadow-blue)}.nav-item .nav-icon{opacity:.7;flex-shrink:0;width:18px;height:18px}.nav-item.active .nav-icon,.nav-item:hover .nav-icon{opacity:1}.nav-item .nav-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-white);border-radius:var(--radius-full);background:#ffffff26;margin-left:auto;padding:1px 7px}.nav-item.active .nav-badge{background:#fff3}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid #ffffff0f;flex-shrink:0}.sidebar-user{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-base);display:flex}.sidebar-user:hover{background:#ffffff0f}.avatar{border-radius:var(--radius-full);background:var(--color-blue);width:32px;height:32px;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-white);flex-shrink:0;justify-content:center;align-items:center;display:flex}.avatar-lg{width:40px;height:40px;font-size:var(--font-size-base)}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-white);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-user-role{font-size:var(--font-size-xs);color:var(--sidebar-icon-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.main-layout{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-width:0;min-height:100vh;display:flex}.topbar{z-index:var(--z-header);background:var(--color-white);border-bottom:1px solid var(--surface-border);height:64px;padding:0 var(--space-8);align-items:center;gap:var(--space-4);flex-shrink:0;display:flex;position:sticky;top:0}.topbar-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);letter-spacing:var(--letter-spacing-tight)}.topbar-spacer{flex:1}.topbar-actions{align-items:center;gap:var(--space-2);display:flex}.page{padding:var(--space-8);flex:1;overflow-y:auto}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-tight)}.page-subtitle{margin-top:var(--space-1);font-size:var(--font-size-base);color:var(--color-gray-500);line-height:var(--line-height-normal)}.card{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.card-padded{padding:var(--space-6)}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--surface-border);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);letter-spacing:var(--letter-spacing-tight)}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-top:2px}.card-body{padding:var(--space-6)}.stat-grid{gap:var(--space-5);margin-bottom:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.stat-card{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);gap:var(--space-4);transition:box-shadow var(--transition-slow), transform var(--transition-slow);flex-direction:column;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card-header{justify-content:space-between;align-items:flex-start;display:flex}.stat-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-500);letter-spacing:var(--letter-spacing-wide)}.stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.stat-icon-blue{background:var(--color-blue-muted);color:var(--color-blue)}.stat-icon-green{background:var(--color-success-light);color:var(--color-success)}.stat-icon-yellow{background:var(--color-warning-light);color:var(--color-warning)}.stat-icon-red{background:var(--color-danger-light);color:var(--color-danger)}.stat-icon-cyan{background:var(--color-info-light);color:var(--color-info)}.stat-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);letter-spacing:var(--letter-spacing-tight);line-height:1}.stat-change{align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);display:flex}.stat-change-up{color:var(--color-success)}.stat-change-down{color:var(--color-danger)}.stat-change-note{color:var(--color-gray-400);font-weight:var(--font-weight-regular);margin-left:2px}.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}.grid-4{gap:var(--space-5);grid-template-columns:repeat(4,1fr);display:grid}.col-span-2{grid-column:span 2}.col-span-3{grid-column:span 3}.btn{justify-content:center;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:0 var(--space-4);border-radius:var(--radius-md);cursor:pointer;height:36px;transition:background var(--transition-base), box-shadow var(--transition-base), opacity var(--transition-base), transform var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;line-height:1;display:inline-flex}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:disabled:active{transform:none}.btn-primary{background:var(--color-blue);color:var(--color-white);box-shadow:var(--shadow-blue)}.btn-primary:hover:not(:disabled){background:var(--color-blue-hover);box-shadow:0 6px 18px #3e53e359}.btn-secondary{background:var(--color-white);color:var(--color-gray-700);border-color:var(--surface-border);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-300)}.btn-ghost{color:var(--color-gray-500);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-gray-100);color:var(--color-gray-700)}.btn-danger{background:var(--color-danger);color:var(--color-white)}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{height:30px;padding:0 var(--space-3);font-size:var(--font-size-xs)}.btn-lg{height:44px;padding:0 var(--space-6);font-size:var(--font-size-base)}.btn-icon{border-radius:var(--radius-md);width:36px;height:36px;padding:0}.btn-icon-sm{border-radius:var(--radius-sm);width:30px;height:30px;padding:0}.badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);letter-spacing:var(--letter-spacing-wide);align-items:center;gap:4px;padding:3px 8px;display:inline-flex}.badge-blue{background:var(--color-blue-muted);color:var(--color-blue)}.badge-green{background:var(--color-success-light);color:#15803d}.badge-yellow{background:var(--color-warning-light);color:#b45309}.badge-red{background:var(--color-danger-light);color:#b91c1c}.badge-cyan{background:var(--color-info-light);color:#0e7490}.badge-gray{background:var(--color-gray-100);color:var(--color-gray-600)}.badge-navy{background:var(--color-navy);color:var(--color-white)}.badge-dot:before{content:"";border-radius:var(--radius-full);background:currentColor;flex-shrink:0;width:6px;height:6px}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.form-input{height:38px;padding:0 var(--space-3);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-gray-900);background:var(--color-white);transition:border-color var(--transition-base), box-shadow var(--transition-base);outline:none;width:100%}.form-input::placeholder{color:var(--color-gray-400)}.form-input:focus{border-color:var(--color-blue);box-shadow:0 0 0 3px var(--color-blue-muted)}.form-input:disabled{background:var(--color-gray-100);color:var(--color-gray-400);cursor:not-allowed}.form-hint{font-size:var(--font-size-xs);color:var(--color-gray-400)}.form-error{font-size:var(--font-size-xs);color:var(--color-danger)}.search-wrap{position:relative}.search-wrap .search-icon{left:var(--space-3);color:var(--color-gray-400);pointer-events:none;width:16px;height:16px;position:absolute;top:50%;transform:translateY(-50%)}.search-wrap .form-input{padding-left:calc(var(--space-3) + 16px + var(--space-2))}.table-wrap{overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--font-size-base)}.table thead{background:var(--color-gray-50)}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-gray-500);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;border-bottom:1px solid var(--surface-border);white-space:nowrap}.table td{padding:var(--space-4);border-bottom:1px solid var(--surface-border);color:var(--color-gray-700);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--color-gray-50)}.table-cell-primary{font-weight:var(--font-weight-medium);color:var(--color-gray-900)}.table-cell-muted{color:var(--color-gray-400);font-size:var(--font-size-sm)}.tabs{border-bottom:1px solid var(--surface-border);margin-bottom:var(--space-6);gap:2px;display:flex}.tab{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-500);cursor:pointer;transition:color var(--transition-base), border-color var(--transition-base);white-space:nowrap;border-bottom:2px solid #0000;margin-bottom:-1px}.tab:hover{color:var(--color-gray-700)}.tab.active{color:var(--color-blue);border-bottom-color:var(--color-blue)}.tabs-pill{gap:var(--space-1);background:var(--color-gray-100);border-radius:var(--radius-lg);margin-bottom:var(--space-6);border:none;padding:4px;display:flex}.tab-pill{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-500);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-base), color var(--transition-base), box-shadow var(--transition-base);text-align:center;white-space:nowrap;flex:1}.tab-pill.active{background:var(--color-white);color:var(--color-gray-900);box-shadow:var(--shadow-sm)}.divider{background:var(--surface-border);height:1px;margin:var(--space-6) 0;border:none}.progress-bar{background:var(--color-gray-200);border-radius:var(--radius-full);height:6px;overflow:hidden}.progress-fill{border-radius:var(--radius-full);background:var(--color-blue);height:100%;transition:width .4s}.progress-fill-green{background:var(--color-success)}.progress-fill-yellow{background:var(--color-warning)}.progress-fill-red{background:var(--color-danger)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.font-regular{font-weight:var(--font-weight-regular)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-primary{color:var(--color-gray-900)}.text-body{color:var(--color-gray-700)}.text-muted{color:var(--color-gray-500)}.text-faint{color:var(--color-gray-400)}.text-blue{color:var(--color-blue)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.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)}.gap-8{gap:var(--space-8)}.flex-1{flex:1}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.w-full{width:100%}.h-full{height:100%}.rounded-full{border-radius:var(--radius-full)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}@media (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){:root{--sidebar-width:0px}.sidebar{transition:transform var(--transition-slow);width:240px;transform:translate(-240px)}.sidebar.open{transform:translate(0)}.main-layout{margin-left:0}.page{padding:var(--space-5)}.topbar{padding:0 var(--space-5)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.col-span-2,.col-span-3{grid-column:span 1}}
