:root{--bg:#0a0f1e;--bg2:#111827;--bg3:#1f2937;--bg4:#374151;--text:#f9fafb;--text2:#9ca3af;--text3:#6b7280;--border:#2d3748;--accent:#6366f1;--accent-hover:#4f46e5;--green:#10b981;--red:#ef4444;--amber:#f59e0b;--blue:#3b82f6;--purple:#8b5cf6;--teal:#14b8a6;--pink:#ec4899;--radius:10px;--shadow:0 4px 24px #0006;--font:"Segoe UI", system-ui, sans-serif;--mono:"Cascadia Code", "Fira Code", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5}a{color:var(--accent);text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}.app-shell{height:100vh;display:flex;overflow:hidden}.main-content{background:var(--bg);flex:1;padding:24px;overflow-y:auto}.login-shell{background:radial-gradient(circle at top,#6366f12e,#0000 35%),linear-gradient(#0b1226 0%,#0a0f1e 55%,#08101a 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:#111827eb;border:1px solid #ffffff14;border-radius:20px;width:min(460px,100%);padding:32px;box-shadow:0 24px 70px #00000073}.login-eyebrow{text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:10px;font-size:.72rem}.login-copy{margin:10px 0 20px}.login-submit{justify-content:center;width:100%;margin-top:6px}h1{font-size:1.6rem;font-weight:700}h2{margin-bottom:12px;font-size:1.25rem;font-weight:600}h3{font-size:1rem;font-weight:600}.page-title{align-items:center;gap:10px;margin-bottom:20px;font-size:1.4rem;font-weight:700;display:flex}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.kpi-grid{gap:14px;margin-bottom:20px;display:grid}.kpi-grid.g2{grid-template-columns:repeat(2,1fr)}.kpi-grid.g3{grid-template-columns:repeat(3,1fr)}.kpi-grid.g4{grid-template-columns:repeat(4,1fr)}.kpi-grid.g5{grid-template-columns:repeat(5,1fr)}@media (width<=768px){.kpi-grid.g3,.kpi-grid.g4,.kpi-grid.g5{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--accent-clr,var(--accent));height:3px;position:absolute;top:0;left:0;right:0}.kpi-label{color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:.75rem}.kpi-value{font-size:1.5rem;font-weight:700;font-family:var(--mono);color:var(--accent-clr,var(--text))}.kpi-sub{color:var(--text3);margin-top:4px;font-size:.75rem}.kpi-icon{opacity:.25;font-size:1.4rem;position:absolute;top:12px;right:14px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.85rem}th{background:var(--bg3);color:var(--text2);text-align:left;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:10px 12px;font-size:.75rem;font-weight:600}td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:10px 12px}tr:hover td{background:#ffffff05}tr:last-child td{border-bottom:none}.table-actions{gap:6px;display:flex}.btn{cursor:pointer;font-size:.85rem;font-weight:500;font-family:var(--font);border:none;border-radius:7px;align-items:center;gap:6px;padding:8px 14px;transition:opacity .15s,transform .1s;display:inline-flex}.btn:hover{opacity:.85}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-success{background:var(--green);color:#fff}.btn-danger{background:var(--red);color:#fff}.btn-warning{background:var(--amber);color:#000}.btn-ghost{color:var(--text2);border:1px solid var(--border);background:0 0}.btn-sm{padding:5px 10px;font-size:.78rem}.btn-icon{background:var(--bg3);color:var(--text2);border:1px solid var(--border);border-radius:6px;padding:6px}.btn-icon:hover{color:var(--text);border-color:var(--accent)}.form-group{margin-bottom:14px}label{color:var(--text2);margin-bottom:5px;font-size:.78rem;font-weight:500;display:block}input,select,textarea{background:var(--bg3);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font);border-radius:7px;outline:none;padding:9px 12px;font-size:.88rem;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126}input[type=checkbox]{width:auto;accent-color:var(--accent)}textarea{resize:vertical;min-height:80px}select option{background:var(--bg3)}.form-row{gap:12px;margin-bottom:14px;display:grid}.form-row.c2{grid-template-columns:1fr 1fr}.form-row.c3{grid-template-columns:1fr 1fr 1fr}.modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg2);border:1px solid var(--border);width:480px;max-width:95vw;max-height:90vh;box-shadow:var(--shadow);border-radius:14px;padding:28px;animation:.2s modal-in;overflow-y:auto}.modal.wide{width:720px}@keyframes modal-in{0%{opacity:0;transform:scale(.95)translateY(-10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:22px;padding-bottom:14px;display:flex}.modal-title{font-size:1.1rem;font-weight:700}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:22px;padding-top:14px;display:flex}.badge{letter-spacing:.03em;border-radius:999px;align-items:center;padding:2px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-green{color:var(--green);background:#10b98126}.badge-red{color:var(--red);background:#ef444426}.badge-amber{color:var(--amber);background:#f59e0b26}.badge-blue{color:var(--blue);background:#3b82f626}.badge-purple{color:var(--purple);background:#8b5cf626}.badge-gray{color:var(--text2);background:#6b728033}.badge-teal{color:var(--teal);background:#14b8a626}.sidebar{background:var(--bg2);border-right:1px solid var(--border);flex-direction:column;width:220px;min-width:220px;height:100vh;display:flex;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--border);padding:20px 18px 14px}.sidebar-logo h1{font-size:1.1rem;font-weight:700}.sidebar-logo span{color:var(--text3);font-size:.72rem}.sidebar-section{padding:14px 10px 4px}.sidebar-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:4px;padding:0 8px;font-size:.65rem}.nav-item{cursor:pointer;color:var(--text2);text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:.84rem;transition:background .15s,color .15s;display:flex}.nav-item:hover{background:var(--bg3);color:var(--text)}.nav-item.active{color:var(--accent);background:#6366f126;font-weight:600}.nav-icon{text-align:center;width:20px;font-size:1rem}.alert{border-radius:8px;align-items:center;gap:10px;margin-bottom:14px;padding:12px 16px;font-size:.85rem;display:flex}.alert-warning{color:var(--amber);background:#f59e0b1f;border:1px solid #f59e0b4d}.alert-danger{color:var(--red);background:#ef44441f;border:1px solid #ef44444d}.alert-success{color:var(--green);background:#10b9811f;border:1px solid #10b9814d}.alert-info{color:var(--blue);background:#3b82f61f;border:1px solid #3b82f64d}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-amber{color:var(--amber)}.text-blue{color:var(--blue)}.text-muted{color:var(--text2)}.text-right{text-align:right}.text-mono{font-family:var(--mono)}.flex{display:flex}.flex-center{align-items:center;display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.empty-state{text-align:center;color:var(--text3);padding:48px 20px}.empty-state span{margin-bottom:10px;font-size:2.5rem;display:block}.month-selector{align-items:center;gap:8px;margin-bottom:20px;display:flex}.month-selector select{width:auto;min-width:150px}.chart-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:20px}.chart-title{color:var(--text2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px;font-size:.8rem}.bar-chart{align-items:flex-end;gap:6px;height:140px;display:flex}.bar-group{flex:1;align-items:flex-end;gap:2px;display:flex}.bar{cursor:default;border-radius:4px 4px 0 0;flex:1;min-height:2px;transition:opacity .2s}.bar:hover{opacity:.8}.bar-label{color:var(--text3);text-align:center;margin-top:4px;font-size:.62rem}@media print{.sidebar,.btn,.modal-backdrop{display:none!important}.main-content{padding:0}}
