@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');
:root{--font:'DM Sans',sans-serif;--mono:'JetBrains Mono',monospace;--bg:#fafafa;--bg2:#fff;--bg3:#f3f4f6;--bgh:#f0f1f3;--brd:#e5e7eb;--t1:#111827;--t2:#6b7280;--t3:#9ca3af;--acc:#2563eb;--accl:#dbeafe;--acch:#1d4ed8;--grn:#059669;--grnl:#d1fae5;--grnbg:#ecfdf5;--red:#dc2626;--redl:#fee2e2;--redbg:#fef2f2;--org:#d97706;--orgl:#fef3c7;--shsm:0 1px 2px rgba(0,0,0,.04);--shmd:0 4px 12px rgba(0,0,0,.06);--r:8px;--rL:16px;--sw:250px}
[data-theme=dark]{--bg:#0f1117;--bg2:#1a1d27;--bg3:#232733;--bgh:#2a2e3b;--brd:#2d3242;--t1:#f1f3f7;--t2:#8b92a5;--t3:#5c6378;--acc:#4f8ff7;--accl:#1c2d4f;--acch:#6ba1f9;--grn:#34d399;--grnl:#0d2e23;--grnbg:#0a2119;--red:#f87171;--redl:#3b1515;--redbg:#2a1010;--org:#fbbf24;--orgl:#3b2f0f;--shsm:0 1px 2px rgba(0,0,0,.2);--shmd:0 4px 12px rgba(0,0,0,.3)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px}
body{font-family:var(--font);background:var(--bg);color:var(--t1);line-height:1.6;min-height:100vh;transition:background .3s,color .3s}
a{color:var(--acc);text-decoration:none}a:hover{color:var(--acch)}

/* Layout */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sw);background:var(--bg2);border-right:1px solid var(--brd);padding:20px 0;position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:100}
.sidebar-brand{padding:0 20px 20px;border-bottom:1px solid var(--brd);margin-bottom:12px}
.sidebar-brand h1{font-size:1.15rem;font-weight:700;letter-spacing:-.02em}
.sidebar-brand span{color:var(--acc)}
.sidebar-brand small{display:block;color:var(--t3);font-size:.72rem;margin-top:2px}
.nav-sec{padding:0 10px;margin-bottom:4px}
.nav-sec-title{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--t3);padding:10px 10px 4px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:6px;color:var(--t2);font-size:.87rem;font-weight:450;transition:all .15s}
.nav-item:hover{background:var(--bgh);color:var(--t1)}
.nav-item.active{background:var(--accl);color:var(--acc);font-weight:600}
.nav-item svg{width:17px;height:17px;flex-shrink:0;opacity:.7}
.nav-item.active svg{opacity:1}
.nav-sub{padding-left:16px}
.nav-sub .nav-item{font-size:.8rem;padding:5px 10px}
.main{flex:1;margin-left:var(--sw);padding:24px 32px;max-width:1400px}

/* Top bar */
.top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.page-title{font-size:1.5rem;font-weight:700;letter-spacing:-.03em}
.page-sub{color:var(--t2);font-size:.87rem;margin-top:2px}
.top-actions{display:flex;align-items:center;gap:10px}

/* Period selector */
.period-sel{display:flex;gap:3px;background:var(--bg3);padding:3px;border-radius:6px}
.period-btn{padding:4px 12px;border:none;background:0 0;color:var(--t2);font-family:var(--font);font-size:.78rem;font-weight:500;border-radius:4px;cursor:pointer;transition:all .15s}
.period-btn:hover{color:var(--t1)}
.period-btn.active{background:var(--bg2);color:var(--t1);box-shadow:var(--shsm)}

/* Metrics */
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:20px}
.metric{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r);padding:18px}
.metric-label{font-size:.73rem;color:var(--t3);font-weight:500;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.metric-val{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.metric-chg{font-size:.8rem;font-weight:600;margin-top:3px;font-variant-numeric:tabular-nums}
.pos{color:var(--grn)}
.neg{color:var(--red)}
.neu{color:var(--t2)}

/* Cards */
.card{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--r);padding:20px;margin-bottom:20px}
.card:hover{box-shadow:var(--shmd)}
.card-title{font-size:.8rem;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:14px}

/* Grid */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:20px}

/* Tables */
.tbl-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--brd)}
table{width:100%;border-collapse:collapse;font-size:.85rem}
thead th{background:var(--bg3);padding:9px 14px;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--t2);border-bottom:1px solid var(--brd);white-space:nowrap}
tbody td{padding:9px 14px;border-bottom:1px solid var(--bg3);font-variant-numeric:tabular-nums}
tbody tr:hover{background:var(--bgh)}
tbody tr:last-child td{border-bottom:none}
.text-r{text-align:right}
.text-c{text-align:center}
.text-mono{font-family:var(--mono);font-size:.8rem}

/* Badges */
.badge{display:inline-flex;padding:2px 9px;border-radius:100px;font-size:.7rem;font-weight:600}
.badge-exempt{background:var(--grnbg);color:var(--grn)}
.badge-soon{background:var(--orgl);color:var(--org)}
.badge-taxable{background:var(--redbg);color:var(--red)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border:none;border-radius:6px;font-family:var(--font);font-size:.87rem;font-weight:550;cursor:pointer;transition:all .15s}
.btn-primary{background:var(--acc);color:#fff}
.btn-primary:hover{background:var(--acch);color:#fff}
.btn-sec{background:var(--bg3);color:var(--t1);border:1px solid var(--brd)}
.btn-sec:hover{background:var(--bgh)}
.btn-sm{padding:4px 10px;font-size:.78rem}

/* Forms */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:.8rem;font-weight:550;color:var(--t2);margin-bottom:5px}
.form-input,.form-select{width:100%;padding:8px 12px;border:1px solid var(--brd);border-radius:6px;background:var(--bg2);color:var(--t1);font-family:var(--font);font-size:.88rem}
.form-input:focus,.form-select:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px var(--accl)}

/* Upload zone */
.upload-zone{border:2px dashed var(--brd);border-radius:var(--rL);padding:40px;text-align:center;cursor:pointer;transition:all .2s}
.upload-zone:hover{border-color:var(--acc);background:var(--accl)}
.upload-zone p{color:var(--t2);font-size:.88rem}
.upload-zone .hint{font-size:.75rem;color:var(--t3);margin-top:5px}

/* Import result */
.import-result{padding:18px;border-radius:var(--r);margin-bottom:18px}
.import-result.success{background:var(--grnbg);border:1px solid var(--grn)}
.import-result.error{background:var(--redbg);border:1px solid var(--red)}
.import-stats{display:flex;gap:20px;margin-top:10px}
.import-stat .number{font-size:1.3rem;font-weight:700}
.import-stat .label{font-size:.72rem;color:var(--t2)}

/* Charts */
.chart-box{position:relative;height:300px;margin-top:10px}

/* Breadcrumb */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--t3);margin-bottom:14px}
.breadcrumb a{color:var(--t2)}
.breadcrumb a:hover{color:var(--acc)}
.breadcrumb .sep{color:var(--brd)}

/* Pagination */
.pagination{display:flex;gap:4px;justify-content:center;margin-top:18px}
.pagination a,.pagination span{padding:5px 11px;border-radius:6px;font-size:.8rem;color:var(--t2);border:1px solid var(--brd)}
.pagination a:hover{background:var(--bgh)}
.pagination .active{background:var(--acc);color:#fff;border-color:var(--acc)}

/* Theme toggle */
.theme-toggle{width:34px;height:34px;border:1px solid var(--brd);border-radius:6px;background:var(--bg2);color:var(--t2);display:flex;align-items:center;justify-content:center;cursor:pointer}
.theme-toggle:hover{background:var(--bgh);color:var(--t1)}

/* Login */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-card{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--rL);padding:44px;width:100%;max-width:380px;box-shadow:0 8px 24px rgba(0,0,0,.08)}
.login-card h1{font-size:1.4rem;font-weight:700;margin-bottom:4px}
.login-card .sub{color:var(--t2);font-size:.87rem;margin-bottom:28px}
.login-error{background:var(--redbg);color:var(--red);padding:9px 12px;border-radius:6px;font-size:.83rem;margin-bottom:14px}
.login-card .btn-primary{width:100%;padding:10px;justify-content:center;margin-top:6px}

/* Empty state */
.empty{text-align:center;padding:50px 20px;color:var(--t3)}
.empty h3{color:var(--t2);margin-bottom:6px}

/* Warning banner */
.warn-banner{background:var(--orgl);border:1px solid var(--org);border-radius:var(--r);padding:10px 16px;margin-bottom:16px;font-size:.85rem;color:var(--org)}

/* Responsive */
@media(max-width:1024px){.grid-2,.grid-3{grid-template-columns:1fr}.main{padding:16px}.metrics{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);transition:transform .25s ease}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0;padding:12px 10px}
  .metrics{grid-template-columns:repeat(2,1fr);gap:8px}
  .metric{padding:12px 10px}
  .metric-val{font-size:1.1rem}
  .metric-label{font-size:.65rem}
  .metric-chg{font-size:.72rem}
  .top-bar{flex-direction:column;align-items:flex-start;gap:10px}
  .top-actions{width:100%;flex-wrap:wrap}
  .page-title{font-size:1.2rem}
  .card{padding:14px 10px}
  /* Hamburger button visible */
  .mob-menu{display:flex !important}
  /* Overlay */
  .mob-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.45);z-index:99}
  .mob-overlay.open{display:block}
  /* Tables: horizontal scroll with smaller text */
  .tbl-wrap{margin:0 -10px;border-radius:0;border-left:none;border-right:none}
  table{font-size:.76rem}
  thead th{padding:7px 8px;font-size:.65rem}
  tbody td{padding:7px 8px}
  /* Period/filter buttons wrap nicely */
  .period-sel{flex-wrap:wrap}
  .period-btn{padding:3px 8px;font-size:.7rem}
  /* Dashboard card tabs smaller */
  .card [style*="border-bottom:2px solid var(--bd)"] button,
  .card div[style*="border-bottom"] button{padding:8px 12px !important;font-size:.78rem !important}
  /* Pagination */
  .pagination a,.pagination span{padding:4px 8px;font-size:.72rem}
}
