:root{--color-bg: #f2f4f3;--color-card: #ffffff;--color-surface: #f7f9f8;--color-border: #dde3e1;--color-text: #0a0e0d;--color-muted: #627571;--color-sidebar: #0a0e0d;--color-accent: #00c805;--color-accent-bg: rgba(0, 200, 5, .1);--color-pos: #00a804;--color-neg: #e53e1e;--color-warn: #d97706;--shadow-sm: 0 1px 2px rgba(10, 14, 13, .06);--shadow-md: 0 4px 16px rgba(10, 14, 13, .1);--radius: 8px}[data-theme=dark]{--color-bg: #111514;--color-card: #1c2120;--color-surface: #232a29;--color-border: #2d3533;--color-text: #edf1f0;--color-muted: #7d9491;--color-sidebar: #0d1110;--color-accent: #00c805;--color-accent-bg: rgba(0, 200, 5, .14);--color-pos: #00c805;--color-neg: #ff5533;--color-warn: #f5a623;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .28);--shadow-md: 0 4px 16px rgba(0, 0, 0, .38)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--color-bg);color:var(--color-text);font-size:14px;transition:background .2s,color .2s}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.sidebar{background:var(--color-sidebar);color:#f0f5f3;padding:24px 0;transition:background .2s;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow:hidden}.sidebar-nav{flex:1;overflow-y:auto}.sidebar-brand{padding:0 24px 24px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:16px}.sidebar-brand h1{margin:0;font-size:16px;font-weight:700;letter-spacing:.5px;color:#fff}.sidebar-brand .sub{font-size:11px;color:#ffffff73;text-transform:uppercase;margin-top:2px;letter-spacing:1px}.sidebar nav a{display:block;padding:10px 24px;color:#ffffffa6;font-size:13px;border-left:3px solid transparent;transition:all .15s}.sidebar nav a:hover{background:#ffffff0d;text-decoration:none;color:#ffffffe6}.sidebar nav a.active{background:#00c8051a;border-left-color:var(--color-accent);color:#fff;font-weight:600}.theme-toggle{background:none;border:1px solid rgba(255,255,255,.15);color:#fff9;font-size:15px;cursor:pointer;padding:5px 9px;border-radius:6px;line-height:1;transition:all .15s}.theme-toggle:hover{background:#ffffff14;color:#fff;border-color:#ffffff4d}.sidebar-bottom{margin-top:auto;padding:16px 24px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:flex-end}.main{padding:32px 40px;overflow-x:auto;background:var(--color-bg);transition:background .2s}.page-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:24px}.page-header h1{margin:0;font-size:22px;font-weight:700;color:var(--color-text);letter-spacing:-.3px}.muted{color:var(--color-muted);font-size:13px}.card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow-sm);margin-bottom:20px;transition:background .2s,border-color .2s}.card h2{margin:0 0 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--color-muted)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px}.kpi-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:24px}@media (max-width: 1400px){.kpi-strip{grid-template-columns:repeat(3,1fr)}}.kpi-card.accent{border-left-color:#6366f1}.card-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px}.card-header h2{margin:0}.kpi-card{background:var(--color-card);border:1px solid var(--color-border);border-left:4px solid var(--color-accent);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow-sm);transition:background .2s,border-color .2s}.kpi-card .kpi-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;font-weight:600;color:var(--color-muted);margin-bottom:8px}.kpi-card .kpi-value{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.5px;color:var(--color-text)}.kpi-card .kpi-sub{font-size:12px;color:var(--color-muted);margin-top:6px}.kpi-card.variance.pos{border-left-color:var(--color-warn)}.kpi-card.variance.neg{border-left-color:var(--color-neg)}.kpi-card.variance.zero{border-left-color:var(--color-pos)}.kpi-card.variance.pos .kpi-value,.kpi-card.variance.neg .kpi-value{color:var(--color-neg)}.kpi-card.variance.zero .kpi-value{color:var(--color-pos)}.table{width:100%;border-collapse:collapse;font-size:13px;font-variant-numeric:tabular-nums}.table th,.table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--color-border);white-space:nowrap}.table th{font-weight:700;color:var(--color-muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;background:var(--color-surface);position:sticky;top:0}.table tbody tr:hover{background:var(--color-surface)}.table .right{text-align:right}.table .center{text-align:center}.text-pos{color:var(--color-pos);font-weight:600}.text-neg{color:var(--color-neg);font-weight:600}.text-warn{color:var(--color-warn);font-weight:600}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.badge.open{background:#fef3c7;color:#92400e}.badge.paid{background:#d1fae5;color:#065f46}.badge.shortpay{background:#fed7aa;color:#9a3412}.badge.writeoff{background:#fee2e2;color:#991b1b}.badge.applied{background:#d1fae5;color:#065f46}.badge.unapplied{background:#fee2e2;color:#991b1b}.badge.planned{background:#e0e7ff;color:#3730a3}.badge.active{background:#d1fae5;color:#065f46}[data-theme=dark] .badge.open{background:#eab3082e;color:#fcd34d}[data-theme=dark] .badge.paid{background:#00c80526;color:#4ade80}[data-theme=dark] .badge.shortpay{background:#f973162e;color:#fb923c}[data-theme=dark] .badge.writeoff{background:#ef44442e;color:#f87171}[data-theme=dark] .badge.applied{background:#00c80526;color:#4ade80}[data-theme=dark] .badge.unapplied{background:#ef44442e;color:#f87171}[data-theme=dark] .badge.planned{background:#6366f12e;color:#a5b4fc}[data-theme=dark] .badge.active{background:#00c80526;color:#4ade80}.filters{display:flex;gap:12px;margin-bottom:16px;align-items:center;flex-wrap:wrap}.filters label{font-size:12px;color:var(--color-muted);display:flex;align-items:center;gap:6px}.filters select,.filters input{padding:6px 10px;border:1px solid var(--color-border);border-radius:4px;font-size:13px;background:var(--color-card);color:var(--color-text);font-family:inherit;transition:border-color .15s}.filters select:focus,.filters input:focus{outline:none;border-color:var(--color-accent)}.tabs{display:flex;gap:4px;border-bottom:2px solid var(--color-border);margin-bottom:20px;flex-wrap:wrap}.tabs button{background:none;border:none;padding:10px 16px;font-size:13px;font-weight:500;color:var(--color-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;font-family:inherit}.tabs button:hover{color:var(--color-text)}.tabs button.active{color:var(--color-text);border-bottom-color:var(--color-accent);font-weight:600}.tabs button .count{display:inline-block;background:var(--color-border);color:var(--color-muted);padding:1px 8px;border-radius:10px;font-size:11px;margin-left:6px}.tabs button.active .count{background:var(--color-accent);color:#000}.loading{padding:40px;text-align:center;color:var(--color-muted)}.empty{padding:32px;text-align:center;color:var(--color-muted);font-style:italic}.table-wrap{max-height:600px;overflow:auto;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-card)}.sidebar-divider{height:1px;background:#ffffff14;margin:12px 24px}.btn{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;background:var(--color-card);color:var(--color-text);transition:all .15s;font-family:inherit}.btn:hover{background:var(--color-surface)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-sm{padding:5px 12px;font-size:12px}.btn-xs{padding:3px 8px;font-size:11px}.btn-primary{background:var(--color-accent);color:#000;border-color:var(--color-accent);font-weight:600}.btn-primary:hover{background:#00b004;border-color:#00b004}.btn-danger{background:var(--color-card);color:var(--color-neg);border-color:var(--color-neg)}.btn-danger:hover{background:var(--color-accent-bg)}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-muted)}.btn-outline:hover{border-color:var(--color-accent);color:var(--color-accent)}.compliance-banner{display:flex;align-items:flex-start;gap:16px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.35);border-radius:var(--radius);padding:16px 20px;margin-bottom:24px;font-size:13px;color:var(--color-warn)}.compliance-banner-icon{font-size:20px;flex-shrink:0}.compliance-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}.compliance-card{position:relative}.compliance-card h3{margin:0 0 8px;font-size:15px;font-weight:600;color:var(--color-text)}.compliance-card p{margin:0 0 16px;line-height:1.5}.compliance-status{float:right;margin:-4px -4px 0 12px}.compliance-actions{display:flex;gap:8px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px 24px;font-size:13px}.detail-grid .muted{margin-right:6px}.mobile-header,.sidebar-overlay{display:none}@media (max-width: 768px){.layout{grid-template-columns:1fr}.mobile-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-sidebar);color:#fff;position:sticky;top:0;z-index:50}.hamburger{background:none;border:none;color:#fff;font-size:22px;line-height:1;cursor:pointer;padding:2px 4px}.mobile-header-title{font-size:15px;font-weight:700;letter-spacing:.5px}.sidebar{position:fixed;top:0;left:0;height:100vh;width:260px;z-index:100;transform:translate(-100%);transition:transform .22s ease;overflow-y:auto}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99;opacity:0;pointer-events:none;transition:opacity .22s ease}.sidebar-overlay.open{opacity:1;pointer-events:auto}.main{padding:16px}.kpi-row,.kpi-strip{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.grid-2{grid-template-columns:1fr}.kpi-card .kpi-value{font-size:20px}.kpi-card{padding:14px 16px}.page-header{flex-direction:column;align-items:flex-start;gap:4px;margin-bottom:16px}.filters{flex-direction:column;align-items:flex-start;gap:8px}.filters label,.filters select,.filters input{width:100%}.card{padding:14px 16px;margin-bottom:14px;overflow-x:auto}.table-wrap{max-height:none;overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:2px}.tabs button{white-space:nowrap}.compliance-grid,.detail-grid{grid-template-columns:1fr}}.period-selector{margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.period-selector-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.period-year-select{padding:7px 10px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;font-weight:600;background:var(--color-card);color:var(--color-text);font-family:inherit;cursor:pointer}.period-year-select:focus{outline:none;border-color:var(--color-accent)}.period-presets{display:flex;gap:4px;flex-wrap:wrap}.period-btn{padding:7px 14px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;background:var(--color-card);color:var(--color-muted);transition:all .12s;font-family:inherit}.period-btn:hover{border-color:var(--color-accent);color:var(--color-text)}.period-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:#000;font-weight:700}.period-custom{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px}.period-custom label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--color-muted);text-transform:uppercase;letter-spacing:.4px}.period-custom input[type=date]{padding:6px 10px;border:1px solid var(--color-border);border-radius:4px;font-size:13px;background:var(--color-card);color:var(--color-text);font-family:inherit}.period-custom input[type=date]:focus{outline:none;border-color:var(--color-accent)}.period-custom-sep{color:var(--color-muted);font-size:14px}.kpi-strip.kpi-loading{opacity:.5;pointer-events:none;transition:opacity .15s}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0e0d8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}[data-theme=dark] .modal-backdrop{background:#000000a6}.modal{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);width:100%;max-width:480px;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0;font-size:16px;font-weight:600;color:var(--color-text)}.modal-close{background:none;border:none;font-size:16px;color:var(--color-muted);cursor:pointer;padding:4px 8px;border-radius:4px;line-height:1}.modal-close:hover{background:var(--color-surface)}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.modal-field{display:flex;flex-direction:column;gap:4px}.modal-field-label{font-size:11px;font-weight:700;color:var(--color-muted);text-transform:uppercase;letter-spacing:.5px}.modal-field input,.modal-field select{padding:8px 10px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;color:var(--color-text);background:var(--color-surface);width:100%;font-family:inherit;transition:border-color .15s}.modal-field input:focus,.modal-field select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-bg)}.modal-error{background:#e53e1e1a;border:1px solid rgba(229,62,30,.3);color:var(--color-neg);border-radius:4px;padding:8px 12px;font-size:12px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px 20px;border-top:1px solid var(--color-border)}.btn-edit{background:none;border:1px solid transparent;color:var(--color-muted);padding:2px 7px;border-radius:4px;font-size:11px;cursor:pointer;opacity:0;transition:all .12s;font-family:inherit}tr:hover .btn-edit{opacity:1}.btn-edit:hover{background:var(--color-accent-bg);border-color:var(--color-accent);color:var(--color-accent)}.detail-row{display:flex;align-items:center;gap:8px}.detail-row .btn-edit{opacity:1}.detail-row .btn-edit:not(:hover){color:var(--color-border);border-color:transparent}
