@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-bg: #0f172a;--color-sidebar: #0d1526;--color-surface: #1e2d45;--color-surface-2: #253554;--color-border: #2a3f60;--color-border-light: #334d75;--color-primary: #2563eb;--color-primary-dark: #1d4ed8;--color-primary-glow: rgba(37, 99, 235, .15);--color-accent: #38bdf8;--color-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #6366f1;--color-text: #e2e8f0;--color-text-muted: #94a3b8;--color-text-dim: #64748b;--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-md: 13px;--font-size-base: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-2xl: 24px;--sidebar-width: 240px;--topbar-height: 56px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 0 3px var(--color-primary-glow);--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg);line-height:1.5;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}.layout{display:flex;min-height:100vh}.main-content{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column;min-width:0}.page-body{padding:20px 24px;flex:1;margin-top:var(--topbar-height);overflow-x:hidden}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--color-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;z-index:100;overflow-y:auto}.sidebar-logo{padding:16px 16px 12px;border-bottom:1px solid var(--color-border)}.sidebar-logo h1{font-size:17px;font-weight:800;color:#fff;letter-spacing:-.3px}.sidebar-logo span{display:block;font-size:10px;color:var(--color-accent);font-weight:500;text-transform:uppercase;letter-spacing:1px;margin-top:1px}.sidebar-section-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-accent);padding:18px 16px 6px;opacity:.9}.sidebar-nav{flex:1;padding:6px 0}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:13px;font-weight:500;color:var(--color-text-muted);cursor:pointer;border-radius:0;text-decoration:none;transition:all var(--transition);position:relative}.nav-item:hover{background:var(--color-primary-glow);color:var(--color-text)}.nav-item.active{background:var(--color-primary-glow);color:#fff;font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-primary);border-radius:0 2px 2px 0}.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.8}.nav-item.active svg,.nav-item:hover svg{opacity:1}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--color-border);font-size:12px;color:var(--color-text-dim)}.topbar{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--topbar-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:99}.topbar-title{font-size:15px;font-weight:600;color:var(--color-text)}.topbar-right{display:flex;align-items:center;gap:12px}.topbar-badge{display:flex;align-items:center;gap:6px;padding:5px 10px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:12px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition)}.topbar-badge:hover{border-color:var(--color-primary);color:var(--color-text)}.topbar-user{display:flex;align-items:center;gap:8px;padding:5px 10px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition)}.topbar-user:hover{background:var(--color-surface-2)}.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h2{font-size:20px;font-weight:700;color:#fff;letter-spacing:-.3px}.page-header p{font-size:12px;color:var(--color-text-muted);margin-top:2px}.page-actions{display:flex;gap:8px;align-items:center}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px}.card-title{font-size:13px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;display:flex;align-items:center;gap:8px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:20px}.kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden;transition:border-color var(--transition)}.kpi-card:hover{border-color:var(--color-border-light)}.kpi-card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--kpi-color, var(--color-primary))}.kpi-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted)}.kpi-value{font-size:26px;font-weight:800;color:#fff;letter-spacing:-.5px;line-height:1}.kpi-sub{font-size:11px;color:var(--color-text-dim)}.kpi-icon{position:absolute;right:14px;top:14px;opacity:.15;width:36px;height:36px}.table-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.table-toolbar{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--color-border);flex-wrap:wrap}table{width:100%;border-collapse:collapse;font-size:12.5px}thead th{background:var(--color-surface-2);padding:9px 12px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);white-space:nowrap;border-bottom:1px solid var(--color-border);-webkit-user-select:none;user-select:none;cursor:pointer}thead th:hover{color:var(--color-text)}tbody tr{border-bottom:1px solid var(--color-border);transition:background var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#ffffff06}tbody td{padding:8px 12px;color:var(--color-text);vertical-align:middle;font-size:12.5px}tbody td.muted{color:var(--color-text-muted);font-size:12px}.table-pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid var(--color-border);font-size:12px;color:var(--color-text-muted)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-size:12.5px;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);border:1px solid transparent;text-decoration:none;white-space:nowrap;font-family:var(--font-family)}.btn svg{width:14px;height:14px}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:var(--color-surface-2);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover{border-color:var(--color-primary);color:#fff}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover{background:#b91c1c}.btn-ghost{background:transparent;color:var(--color-text-muted);border-color:transparent}.btn-ghost:hover{background:var(--color-surface-2);color:var(--color-text)}.btn-sm{padding:4px 10px;font-size:11.5px}.btn-icon{padding:6px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition)}.btn-icon:hover{background:var(--color-surface-2);color:var(--color-text)}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group.full-width{grid-column:1 / -1}label{font-size:11.5px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}input,select,textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:13px;padding:7px 10px;font-family:var(--font-family);transition:border-color var(--transition);width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-glow)}input::placeholder,textarea::placeholder{color:var(--color-text-dim)}select option{background:var(--color-surface)}textarea{resize:vertical;min-height:80px}.field-error{font-size:11px;color:var(--color-danger)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:99px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.badge-success{background:#22c55e1f;color:#4ade80}.badge-warning{background:#f59e0b1f;color:#fbbf24}.badge-danger{background:#ef44441f;color:#f87171}.badge-info{background:#6366f11f;color:#a5b4fc}.badge-primary{background:#2563eb26;color:var(--color-accent)}.badge-muted{background:var(--color-surface-2);color:var(--color-text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:640px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}.modal-header{padding:16px 20px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:15px;font-weight:700}.modal-body{padding:20px}.modal-footer{padding:12px 20px;border-top:1px solid var(--color-border);display:flex;gap:8px;justify-content:flex-end}.modal-lg{max-width:900px}.search-wrap{position:relative;flex:1;max-width:280px}.search-wrap svg{position:absolute;left:8px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--color-text-dim);pointer-events:none}.search-wrap input{padding-left:30px}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}.chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px}.chart-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:14px}.alert{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-radius:var(--radius-md);font-size:12.5px;border:1px solid}.alert-warning{background:#f59e0b14;border-color:#f59e0b40;color:#fbbf24}.alert-danger{background:#ef444414;border-color:#ef444440;color:#f87171}.alert-success{background:#22c55e14;border-color:#22c55e40;color:#4ade80}.divider{border:none;border-top:1px solid var(--color-border);margin:16px 0}.text-muted{color:var(--color-text-muted)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-sm{font-size:12px}.fw-600{font-weight:600}.fw-700{font-weight:700}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-0{margin-bottom:0}.spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}.loading-center{display:flex;align-items:center;justify-content:center;padding:48px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;color:var(--color-text-dim);gap:8px}.empty-state svg{width:40px;height:40px;opacity:.3}.empty-state p{font-size:13px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media print{body{background:#fff!important;color:#000!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.sidebar,.topbar,.btn:not(.btn-print-visible),.page-header button{display:none!important}.main-content{margin-left:0!important;padding:0!important}.page-body{margin-top:0!important;padding:0!important}.card{background:#fff!important;border:1px solid #ddd!important;box-shadow:none!important;color:#000!important;page-break-inside:avoid;margin-bottom:20px}.card-title{color:#444!important;border-bottom:1px solid #eee;padding-bottom:5px}table{border:1px solid #eee}thead th{background:#f9f9f9!important;color:#333!important}tbody td{color:#000!important;border-bottom:1px solid #eee}.badge{border:1px solid #ccc!important;background:transparent!important;color:#000!important}}
