:root {
  --bg:        #07080e;
  --surface:   #0c0f1a;
  --card:      #111520;
  --card-hover:#161c2e;
  --border:    rgba(255,255,255,0.06);
  --border-bright: rgba(255,255,255,0.12);
  --text:      #e8edf8;
  --text-dim:  #6b7a99;
  --text-muted:#3d4a6a;
  --green:     #00d48a;
  --green-dim: rgba(0,212,138,0.12);
  --red:       #ff4d6d;
  --red-dim:   rgba(255,77,109,0.12);
  --blue:      #4b9dff;
  --blue-dim:  rgba(75,157,255,0.12);
  --gold:      #f0b429;
  --gold-dim:  rgba(240,180,41,0.12);
  --purple:    #9b7eff;
  --purple-dim:rgba(155,126,255,0.12);
  --pink:      #f472b6;
  --pink-dim:  rgba(244,114,182,0.12);
  --orange:    #fb923c;
  --orange-dim:rgba(251,146,60,0.12);
  --navy:      #1a2e4a;
  --radius:    10px;
  --radius-sm: 6px;
}

/* ── LIGHT THEME ── */
:root.light {
  --bg:        #f0f2f8;
  --surface:   #e4e8f2;
  --card:      #ffffff;
  --card-hover:#f5f7ff;
  --border:    rgba(0,0,0,0.08);
  --border-bright: rgba(0,0,0,0.18);
  --text:      #111827;
  --text-dim:  #4b5a7a;
  --text-muted:#9aa3b8;
  --green:     #00a96e;
  --green-dim: rgba(0,169,110,0.10);
  --red:       #e53935;
  --red-dim:   rgba(229,57,53,0.10);
  --blue:      #1d6fe8;
  --blue-dim:  rgba(29,111,232,0.10);
  --gold:      #c47f00;
  --gold-dim:  rgba(196,127,0,0.10);
  --purple:    #6c3eea;
  --purple-dim:rgba(108,62,234,0.10);
  --pink:      #d63086;
  --pink-dim:  rgba(214,48,134,0.10);
  --orange:    #e06320;
  --orange-dim:rgba(224,99,32,0.10);
  --navy:      #1a2e4a;
}

/* smooth transition when switching themes */
*, *::before, *::after { transition: background-color .2s, border-color .2s, color .15s; }
/* but NOT on transforms/shadows to keep animations snappy */
.card, .btn, input, select { transition: background-color .2s, border-color .2s, color .15s, box-shadow .2s, transform .15s; }

/* light mode specific overrides */
:root.light body { background: var(--bg); }
:root.light .header { background: linear-gradient(135deg,#1d2e5a 0%,#2a4080 100%); }
:root.light .header * { color: #e8edf8 !important; }
:root.light .header input { background: rgba(255,255,255,.15) !important; border-color: rgba(255,255,255,.25) !important; color: #fff !important; }
:root.light .modal-overlay { background: rgba(0,0,0,.4); }
:root.light .modal { box-shadow: 0 20px 60px rgba(0,0,0,.2); }
:root.light .card { box-shadow: 0 2px 12px rgba(0,0,0,.07); }
:root.light .card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.12); }
:root.light table thead th { background: var(--surface); }
:root.light ::-webkit-scrollbar-track { background: var(--surface); }
:root.light ::-webkit-scrollbar-thumb { background: #b0bcd4; }
:root.light .tab.active { background: var(--card); color: var(--blue) !important; }
:root.light .tag { background: rgba(0,0,0,.06); color: var(--text-dim); }
:root.light .info-box { border-width: 1px; }
:root.light input, :root.light select, :root.light textarea {
  background: var(--card);
  border-color: rgba(0,0,0,.15);
  color: var(--text);
}
:root.light input:focus, :root.light select:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(29,111,232,.12);
}
:root.light .ms-hdr { background: var(--surface); color: var(--text-dim); }
:root.light .ms-row:hover { background: rgba(0,0,0,.03); }
:root.light .sec-hdr { background: transparent; border-bottom: 2px solid var(--border); }
:root.light .view-toggle { background: var(--surface); }
:root.light .btn-export { background: rgba(255,255,255,.2) !important; color: #e8edf8 !important; border-color: rgba(255,255,255,.3) !important; }
:root.light .btn-export:hover { background: rgba(255,255,255,.35) !important; }
:root.light .clientDropdown, :root.light #clientDropdown { background: var(--card); }
/* ── SKIP LINK ── */
.skip-link{position:absolute;top:-50px;left:0;background:var(--blue);color:#fff;padding:10px 18px;z-index:200;font-size:13px;font-weight:600;font-family:'Syne',sans-serif;border-radius:0 0 var(--radius-sm) 0;text-decoration:none;transition:top .2s}
.skip-link:focus{top:0}

*{box-sizing:border-box;margin:0;padding:0}
body {
  font-family:'Inter',sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:13px;
  min-height:100vh;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -20%, rgba(75,157,255,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 80% 80%, rgba(155,126,255,0.05) 0%, transparent 50%);
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:#2a3555;border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:#3d4f80}

/* ── HEADER ── */
header {
  background: linear-gradient(135deg, #0c0f1a 0%, #0f1527 100%);
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(12px);
}
.hdr-left{display:flex;align-items:center;gap:14px}
.hdr-left img{height:32px;filter:brightness(0) invert(1);opacity:.9;object-fit:contain}
.brand-name {
  font-family:'Syne',sans-serif;
  font-size:15px;
  font-weight:700;
  letter-spacing:.3px;
  color:#e8edf8;
}
.brand-sub {
  font-size:10px;
  color:rgba(232,237,248,.6);
  letter-spacing:.5px;
  text-transform:uppercase;
  margin-top:1px;
}
.hdr-divider {
  width:1px;
  height:28px;
  background:var(--border-bright);
}
.hdr-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.year-ctrl{display:flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 10px}
.year-ctrl button{
  background:none;border:none;color:var(--text-dim);width:20px;height:20px;
  cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;
  border-radius:4px;transition:all .15s;
}
.year-ctrl button:hover{background:var(--border);color:var(--text)}
.year-label{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:600;min-width:40px;text-align:center;color:var(--blue)}
.ob-box{display:flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 10px}
.ob-box span{font-size:10px;color:var(--text-dim);white-space:nowrap;text-transform:uppercase;letter-spacing:.3px}
.ob-box input{
  width:90px;padding:3px 6px;border-radius:4px;border:1px solid var(--border);
  font-size:12px;font-weight:600;background:rgba(255,255,255,.04);color:var(--text);
  text-align:right;font-family:'JetBrains Mono',monospace;outline:none;
  transition:border-color .15s;
}
.ob-box input:focus{border-color:var(--blue)}
.ob-box button{
  background:var(--blue);border:none;color:#fff;border-radius:4px;
  padding:3px 8px;cursor:pointer;font-size:11px;font-weight:600;
  transition:all .15s;
}
.ob-box button:hover{background:#3a8bf0}
.ob-saved{font-size:10px;color:var(--green);opacity:0;transition:opacity .4s;font-weight:600}
.btn-export{
  padding:6px 12px;border:none;border-radius:var(--radius-sm);cursor:pointer;
  font-size:11px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;
  transition:all .15s;
}
.btn-pdf{background:rgba(255,77,109,.15);color:var(--red);border:1px solid rgba(255,77,109,.3)}
.btn-pdf:hover{background:var(--red);color:#fff}
.btn-xls{background:rgba(0,212,138,.15);color:var(--green);border:1px solid rgba(0,212,138,.3)}
.btn-xls:hover{background:var(--green);color:#000}
.export-dropdown{position:relative}
.export-menu{display:none;position:absolute;top:calc(100% + 4px);right:0;background:var(--card);border:1px solid var(--border-bright);border-radius:var(--radius-sm);box-shadow:0 8px 30px rgba(0,0,0,.5);z-index:60;min-width:160px;overflow:hidden}
.export-dropdown.open .export-menu{display:block}
.export-menu button{display:block;width:100%;padding:10px 14px;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text);font-family:'Syne',sans-serif;font-size:11px;font-weight:600;text-align:left;cursor:pointer;transition:background .12s}
.export-menu button:last-child{border-bottom:none}
.export-menu button:hover{background:var(--blue-dim)}

/* ── TABS ── */
.tabs {
  display:flex;background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:0 24px;overflow-x:auto;
  gap:2px;
  -webkit-mask-image:linear-gradient(to right,transparent,black 20px,black calc(100% - 20px),transparent);
  mask-image:linear-gradient(to right,transparent,black 20px,black calc(100% - 20px),transparent);
}
.tabs::-webkit-scrollbar{height:4px}
.tabs::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:2px}
.tab {
  padding:14px 16px;cursor:pointer;
  font-family:'Syne',sans-serif;font-size:11px;font-weight:600;
  color:var(--text-dim);border:none;border-bottom:2px solid transparent;
  margin-bottom:-1px;white-space:nowrap;
  letter-spacing:.5px;text-transform:uppercase;
  transition:all .2s;background:none;
}
.tab:hover{color:var(--text)}
.tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.tab-sep{width:1px;background:var(--border-bright);margin:8px 6px;flex-shrink:0}

/* ── CONTENT ── */
.content[hidden]{display:none}
.content{padding:20px 24px;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ── CARDS ── */
/* ── AGED RECEIVABLES ── */
.ar-banner{border-radius:var(--radius);overflow:hidden;margin-bottom:16px;}
.ar-strip{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr;gap:0;}
.ar-bucket{padding:12px 16px;border-right:1px solid rgba(255,255,255,.06);}
.ar-bucket:last-child{border-right:none;}
.ar-bucket .ab-label{font-family:'Syne',sans-serif;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;}
.ar-bucket .ab-amt{font-family:'JetBrains Mono',monospace;font-size:17px;font-weight:700;line-height:1;}
.ar-bucket .ab-count{font-size:9px;margin-top:3px;opacity:.75;}
.ar-bucket.current{background:rgba(75,157,255,.08);}  .ar-bucket.current .ab-label,.ar-bucket.current .ab-amt{color:var(--blue);}
.ar-bucket.d30{background:rgba(240,180,41,.08);}      .ar-bucket.d30 .ab-label,.ar-bucket.d30 .ab-amt{color:var(--gold);}
.ar-bucket.d60{background:rgba(251,146,60,.10);}      .ar-bucket.d60 .ab-label,.ar-bucket.d60 .ab-amt{color:var(--orange);}
.ar-bucket.d90{background:rgba(255,77,109,.12);}      .ar-bucket.d90 .ab-label,.ar-bucket.d90 .ab-amt{color:var(--red);}
.ar-bucket.d90p{background:rgba(255,77,109,.22);animation:pulseBg 2.5s infinite;}
.ar-bucket.d90p .ab-label,.ar-bucket.d90p .ab-amt{color:var(--red);}
@keyframes pulseBg{0%,100%{background:rgba(255,77,109,.22);}50%{background:rgba(255,77,109,.32);}}
.ar-table-wrap{background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);}
.ar-row{display:grid;grid-template-columns:16px 1fr 120px 90px 90px 110px 90px;gap:8px;align-items:center;padding:9px 14px;border-bottom:1px solid var(--border);font-size:11px;}
.ar-row:last-child{border-bottom:none;}
.ar-row:hover{background:rgba(255,255,255,.02);}
.ar-hdr{font-family:'Syne',sans-serif;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted) !important;background:var(--surface) !important;}
.ar-hdr:hover{background:var(--surface) !important;}
.age-pill{display:inline-block;padding:2px 7px;border-radius:10px;font-family:'Syne',sans-serif;font-size:9px;font-weight:700;letter-spacing:.2px;white-space:nowrap;}
.age-current{background:rgba(75,157,255,.12);color:var(--blue);}
.age-d30{background:rgba(240,180,41,.12);color:var(--gold);}
.age-d60{background:rgba(251,146,60,.15);color:var(--orange);}
.age-d90{background:rgba(255,77,109,.15);color:var(--red);}
.age-d90p{background:rgba(255,77,109,.28);color:var(--red);font-size:10px;}
.ar-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0;}

/* ── CALENDAR LAYOUT ── */
.cal-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.cal-day-hdr{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.cal-day-label{text-align:center;font-family:'Syne',sans-serif;font-size:9px;font-weight:700;color:var(--text-dim);padding:6px;text-transform:uppercase;letter-spacing:.5px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}

.cal-day{min-height:90px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px;position:relative;transition:border-color .15s;}
.cal-day:hover{border-color:var(--border-bright);}
.cal-day.today{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue) inset;}
.cal-day.other-month{opacity:.35;}
.cal-day-num{font-family:'Syne',sans-serif;font-size:11px;font-weight:700;color:var(--text-dim);margin-bottom:4px;}
.cal-day.today .cal-day-num{color:var(--blue);}
.cal-event{font-size:9px;padding:2px 5px;border-radius:3px;margin-bottom:2px;font-family:'Syne',sans-serif;font-weight:700;cursor:default;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.2px;}
.cal-event.income{background:var(--green-dim);color:var(--green);}
.cal-event.expense{background:var(--red-dim);color:var(--red);}
.cal-event.vat{background:var(--purple-dim);color:var(--purple);}
.cal-event.salary{background:var(--gold-dim);color:var(--gold);}
.cal-event.tax{background:rgba(251,146,60,.15);color:var(--orange);}
.cal-event.overdue{background:rgba(255,77,109,.25);color:var(--red);}
.cal-more{font-size:9px;color:var(--text-muted);font-family:'Syne',sans-serif;}
.upcoming-row{display:grid;grid-template-columns:90px 1fr auto auto;gap:10px;align-items:center;padding:8px 12px;border-radius:var(--radius-sm);margin-bottom:4px;border-left:3px solid;}
.upcoming-row.income{background:var(--green-dim);border-color:var(--green);}
.upcoming-row.expense{background:var(--red-dim);border-color:var(--red);}
.upcoming-row.vat{background:var(--purple-dim);border-color:var(--purple);}
.upcoming-row.salary{background:var(--gold-dim);border-color:var(--gold);}
.upcoming-row.overdue{background:rgba(255,77,109,.2);border-color:var(--red);}
/* ── P&L ── */
.pnl-table{width:100%;border-collapse:collapse;font-size:11px;}
.pnl-table th{font-family:'Syne',sans-serif;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-dim);padding:8px 10px;text-align:right;border-bottom:2px solid var(--border);white-space:nowrap;}
.pnl-table th:first-child{text-align:left;min-width:180px;}
.pnl-table td{padding:7px 10px;text-align:right;border-bottom:1px solid var(--border);font-family:'JetBrains Mono',monospace;}
.pnl-table td:first-child{text-align:left;font-family:'Syne',sans-serif;font-weight:600;color:var(--text);}
.pnl-section td{font-family:'Syne',sans-serif !important;font-weight:700 !important;font-size:10px !important;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim) !important;background:var(--surface);padding:10px 10px 4px !important;}
.pnl-total td{font-weight:700 !important;font-size:12px !important;border-top:2px solid var(--border) !important;border-bottom:2px solid var(--border) !important;}
.pnl-subtotal td{font-weight:700 !important;border-top:1px solid var(--border-bright) !important;}
.pnl-indent td:first-child{padding-left:24px !important;font-weight:400 !important;color:var(--text-dim) !important;font-family:'Inter',sans-serif !important;font-size:11px !important;}
.pnl-pos{color:var(--green) !important;}
.pnl-neg{color:var(--red) !important;}
.cards{display:grid;grid-template-columns:repeat(8,1fr);gap:10px;margin-bottom:16px}
.card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px 16px;
  position:relative;
  overflow:hidden;
  transition:all .2s;
}
.card::before {
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
}
.card:hover{border-color:var(--border-bright);transform:translateY(-1px)}
.card .lbl {
  font-family:'Syne',sans-serif;font-size:9px;
  color:var(--text-muted);text-transform:uppercase;
  letter-spacing:.7px;margin-bottom:8px;
}
.card .val {
  font-family:'JetBrains Mono',monospace;
  font-size:15px;font-weight:700;color:var(--text);
}
.card .sparkline{height:24px;margin-top:6px;opacity:.6}
.card-accent {
  position:absolute;bottom:0;left:0;width:3px;height:100%;border-radius:0 0 0 var(--radius);
}
.card.inc .val{color:var(--green)}
.card.exp .val{color:var(--red)}
.card.net .val{color:var(--text)}
.card.vat-c .val{color:var(--purple)}
.card.vat-p .val{color:var(--gold)}
.card.vat-n .val{color:var(--blue)}
.card.div .val{color:var(--pink)}
.card.wht .val{color:var(--purple)}
.card.tax .val{color:var(--red)}

/* ── SECTIONS ── */
.section {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 20px;
  margin-bottom:14px;
  position:relative;
  overflow:hidden;
}
.section::before {
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);
}
.sec-hdr{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:14px;flex-wrap:wrap;gap:8px;
}
.sec-title {
  font-family:'Syne',sans-serif;font-size:12px;font-weight:700;
  color:var(--text);letter-spacing:.3px;text-transform:uppercase;
}
.sec-sub{font-size:10px;color:var(--text-dim);margin-top:3px}

/* ── BUTTONS ── */
.btn{
  padding:6px 14px;border:none;border-radius:var(--radius-sm);
  cursor:pointer;font-size:11px;font-weight:600;
  font-family:'Syne',sans-serif;letter-spacing:.3px;
  transition:all .15s;text-transform:uppercase;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(75,157,255,.3)}
.btn-primary:hover{background:var(--blue);color:#fff}
.btn-success{background:var(--green-dim);color:var(--green);border:1px solid rgba(0,212,138,.3)}
.btn-success:hover{background:var(--green);color:#000}
.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid rgba(255,77,109,.3)}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-div{background:var(--pink-dim);color:var(--pink);border:1px solid rgba(244,114,182,.3)}
.btn-div:hover{background:var(--pink);color:#fff}
.btn-sm{padding:4px 10px;font-size:10px}
.btn-paid{background:rgba(0,212,138,.1);color:var(--green);border:1px solid rgba(0,212,138,.25)}
.btn-unpaid{background:rgba(240,180,41,.1);color:var(--gold);border:1px solid rgba(240,180,41,.25)}
.view-toggle {
  display:flex;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-sm);overflow:hidden;
}
.view-toggle button {
  padding:8px 16px;border:none;cursor:pointer;font-size:11px;
  min-height:36px;
  font-family:'Syne',sans-serif;font-weight:600;letter-spacing:.3px;
  text-transform:uppercase;background:none;color:var(--text-dim);
  transition:all .15s;
}
.view-toggle button.active{background:var(--blue);color:#fff}

/* ── TABLE SCROLL WRAPPER ── */
.table-scroll{position:relative;overflow-x:auto}
.table-scroll::after{
  content:'';position:absolute;top:0;right:0;bottom:0;width:32px;
  background:linear-gradient(to right,transparent,var(--card));
  pointer-events:none;opacity:0;transition:opacity .2s;
}
.table-scroll.has-scroll::after{opacity:1}

/* ── TABLES ── */
table{width:100%;border-collapse:collapse}
thead{border-bottom:1px solid var(--border)}
th {
  text-align:left;padding:8px 10px;
  font-family:'Syne',sans-serif;font-size:9px;
  color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;
  font-weight:700;
}
td{
  padding:9px 10px;border-bottom:1px solid rgba(255,255,255,.03);
  vertical-align:middle;font-size:11px;color:var(--text);
}
tr:last-child td{border-bottom:none}
tbody tr{transition:background .15s}
tbody tr:hover td{background:rgba(255,255,255,.025)}
.no-data{text-align:center;color:var(--text-muted);padding:30px;font-size:11px}
.empty-state{text-align:center;padding:36px 20px}
.empty-icon{font-size:28px;margin-bottom:8px;opacity:.6}
.empty-title{font-family:'Syne',sans-serif;font-size:12px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}
.empty-desc{font-size:11px;color:var(--text-muted);margin-bottom:14px;line-height:1.6}

/* ── BADGES ── */
.badge{
  display:inline-block;padding:3px 8px;border-radius:20px;
  font-size:9px;font-weight:700;letter-spacing:.3px;
  font-family:'Syne',sans-serif;text-transform:uppercase;
}
.badge-confirmed{background:rgba(0,212,138,.12);color:var(--green)}
.badge-pending{background:rgba(240,180,41,.12);color:var(--gold)}
.badge-overdue{background:var(--red-dim);color:var(--red)}
.badge-paid{background:var(--pink-dim);color:var(--pink)}
.badge-declared{background:var(--purple-dim);color:var(--purple)}
.badge-invoiced{background:var(--blue-dim);color:var(--blue)}
.badge-received{background:rgba(0,212,138,.12);color:var(--green)}
.badge-partial{background:rgba(240,180,41,.12);color:var(--gold)}

/* ── TAGS ── */
.tag{
  display:inline-block;padding:2px 7px;border-radius:4px;
  font-size:10px;font-weight:500;
  background:rgba(75,157,255,.1);color:var(--blue);
  margin:1px;border:1px solid rgba(75,157,255,.2);
}
.tag-freelance{background:var(--purple-dim);color:var(--purple);border-color:rgba(155,126,255,.2)}
.tag-salary{background:var(--gold-dim);color:var(--gold);border-color:rgba(240,180,41,.2)}
.tag-deductible{background:rgba(0,212,138,.12);color:var(--green);border:1px solid rgba(0,212,138,.25);font-size:9px;padding:1px 6px;border-radius:3px;font-family:'Syne',sans-serif;font-weight:700;letter-spacing:.2px;white-space:nowrap}
.deduct-savings-box{background:linear-gradient(135deg,rgba(0,212,138,.08),rgba(0,212,138,.03));border:1px solid rgba(0,212,138,.2);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:14px}
.deduct-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:11px}
.deduct-row:last-child{border-bottom:none}
background:rgba(255,77,109,.12);color:var(--red);border:1px solid rgba(255,77,109,.25);font-size:9px}
.tag-bonus-easter{background:rgba(155,126,255,.12);color:var(--purple);border:1px solid rgba(155,126,255,.25);font-size:9px}
.tag-bonus-holiday{background:rgba(0,212,138,.12);color:var(--green);border:1px solid rgba(0,212,138,.25);font-size:9px}
.tag-bonus-regular{background:rgba(75,157,255,.1);color:var(--blue);border:1px solid rgba(75,157,255,.2);font-size:9px}

/* ── INFO BOXES ── */
.info-box{
  border-radius:var(--radius-sm);padding:10px 14px;
  margin-bottom:12px;font-size:11px;line-height:1.7;
}
.info-blue{background:var(--blue-dim);border:1px solid rgba(75,157,255,.2);color:#7fb5ff}
.info-violet{background:var(--purple-dim);border:1px solid rgba(155,126,255,.2);color:#b8a7ff}
.info-red{background:var(--red-dim);border:1px solid rgba(255,77,109,.2);color:#ff8fa3}
.info-amber{background:var(--gold-dim);border:1px solid rgba(240,180,41,.2);color:#f5c842}

/* ── MODALS ── */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.7);backdrop-filter:blur(6px);
  z-index:100;align-items:center;justify-content:center;
}
.modal-overlay.active{display:flex}
.modal{
  background:var(--card);
  border:1px solid var(--border-bright);
  border-radius:14px;padding:24px;
  width:640px;max-width:calc(100vw - 32px);max-height:92vh;overflow-y:auto;
  box-shadow:0 25px 80px rgba(0,0,0,.6);
}
.modal h2{
  font-family:'Syne',sans-serif;font-size:14px;font-weight:700;
  margin-bottom:16px;color:var(--text);
  letter-spacing:.3px;text-transform:uppercase;
  padding-bottom:12px;border-bottom:1px solid var(--border);
}
.fg{margin-bottom:10px}
.fg label{
  display:block;font-family:'Syne',sans-serif;font-size:9px;
  color:var(--text-dim);margin-bottom:4px;font-weight:700;
  letter-spacing:.5px;text-transform:uppercase;
}
.fg input,.fg select{
  width:100%;padding:8px 10px;
  border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:12px;background:var(--surface);
  color:var(--text);outline:none;
  font-family:'Inter',sans-serif;
  transition:border-color .15s;
}
.fg input:focus,.fg select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(75,157,255,.15)}
.fg select option{background:var(--card)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fr3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.ms-list{
  border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:8px;margin-top:4px;max-height:240px;overflow-y:auto;
  background:var(--surface);
}
.ms-row{display:grid;gap:6px;margin-bottom:6px;align-items:center}
.ms-row.income-ms{grid-template-columns:1fr 1fr 1fr auto auto}
.ms-row.expense-ms{grid-template-columns:1fr 1fr auto}
.ms-row.salary-ms{grid-template-columns:1.4fr 1fr 1fr 1fr 1fr auto}
.ms-row input{
  padding:5px 7px;border:1px solid var(--border);border-radius:4px;
  font-size:11px;width:100%;background:var(--card);
  color:var(--text);outline:none;font-family:'JetBrains Mono',monospace;
}
.ms-row input:focus{border-color:var(--blue)}
.ms-row input[readonly]{background:rgba(255,255,255,.03);color:var(--text-dim)}
.ms-hdr{
  display:grid;gap:6px;margin-bottom:4px;
  font-family:'Syne',sans-serif;font-size:9px;
  color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px;
}
.ms-hdr.income-hdr{grid-template-columns:1fr 1fr 1fr auto auto}
.ms-hdr.expense-hdr{grid-template-columns:1fr 1fr auto}
.ms-hdr.salary-hdr{grid-template-columns:1.4fr 1fr 1fr 1fr 1fr auto}
.add-ms{
  background:none;border:1px dashed rgba(255,255,255,.15);
  color:var(--text-muted);padding:5px;width:100%;
  border-radius:4px;cursor:pointer;font-size:11px;margin-top:4px;
  transition:all .15s;
}
.add-ms:hover{border-color:var(--blue);color:var(--blue)}
.modal-actions{
  display:flex;gap:8px;justify-content:flex-end;
  margin-top:16px;padding-top:14px;border-top:1px solid var(--border);
}
.preview-box{border-radius:var(--radius-sm);padding:12px 14px;font-size:11px;margin-bottom:10px}
.preview-violet{background:var(--purple-dim);border:1px solid rgba(155,126,255,.2)}
.preview-amber{background:var(--gold-dim);border:1px solid rgba(240,180,41,.2)}
.preview-row{display:flex;justify-content:space-between;margin-bottom:4px}
.preview-total{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:8px;margin-top:6px;font-weight:700;font-size:13px;
  font-family:'JetBrains Mono',monospace;
}
.chart-wrap{position:relative;height:230px}
.pj-table th,.pj-table td{text-align:right;font-size:10px;font-family:'JetBrains Mono',monospace}
.pj-table th:first-child,.pj-table td:first-child{text-align:left;font-family:'Inter',sans-serif}
.pos{color:var(--green);font-weight:700}
.neg{color:var(--red);font-weight:700}
.sh-bar{height:5px;border-radius:3px;background:rgba(255,255,255,.05);overflow:hidden;margin-top:4px}
.sh-bar-fill{height:100%;border-radius:3px;transition:width .8s ease}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.salary-box{
  display:none;
  background:var(--gold-dim);border:1px solid rgba(240,180,41,.2);
  border-radius:var(--radius-sm);padding:12px;margin-top:8px;
}
.fl-box{
  display:none;
  background:var(--purple-dim);border:1px solid rgba(155,126,255,.2);
  border-radius:var(--radius-sm);padding:12px;margin-top:8px;
}
.tax-card{
  background:var(--card);border-radius:var(--radius);
  padding:16px;border:1px solid var(--border);
  border-left:3px solid var(--red);
}

.client-opt {
  padding:8px 12px;font-size:11px;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  border-bottom:1px solid rgba(255,255,255,.04);transition:background .12s;
}
.client-opt:last-child{border-bottom:none}
.client-opt:hover,.client-opt.highlighted{background:rgba(75,157,255,.1)}
.client-opt .co-name{font-weight:600;color:var(--text)}
.client-opt .co-type{font-size:9px;padding:2px 6px;border-radius:3px;font-family:'Syne',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.client-opt .co-type.income-type{background:var(--green-dim);color:var(--green)}
.client-opt .co-type.expense-type{background:var(--red-dim);color:var(--red)}
.client-opt .co-type.both-type{background:var(--blue-dim);color:var(--blue)}
.client-opt-add{
  padding:9px 12px;font-size:11px;cursor:pointer;
  color:var(--green);font-weight:700;
  display:flex;align-items:center;gap:6px;
  border-top:1px solid var(--border);
  font-family:'Syne',sans-serif;
}
.client-opt-add:hover{background:var(--green-dim)}
.client-opt-new-badge{
  font-size:9px;padding:1px 5px;background:var(--green-dim);
  color:var(--green);border-radius:3px;font-family:'Syne',sans-serif;font-weight:700
}
/* Directory modal */
.dir-modal{width:680px;max-width:calc(100vw - 32px)}
.dir-row{display:grid;grid-template-columns:1fr 1fr auto auto;gap:8px;margin-bottom:4px;align-items:center}
.dir-hdr{display:grid;grid-template-columns:1fr 1fr auto auto;gap:8px;margin-bottom:6px;font-family:'Syne',sans-serif;font-size:9px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px}

@media(max-width:1200px){.cards{grid-template-columns:repeat(4,1fr)}}
@media(max-width:960px){.cards{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .content{padding:12px 14px}
  .two-col{grid-template-columns:1fr}
  header{height:auto;padding:10px 14px}
  .hdr-right{flex-wrap:wrap;gap:6px}
  .modal{width:100vw;max-width:100vw;max-height:100vh;height:100vh;border-radius:0;padding:16px;margin:0}
  .confirm-modal{width:100vw;height:auto;max-height:80vh;border-radius:12px;margin:auto}
  .fr,.fr3{grid-template-columns:1fr}
  .tabs{padding:0 12px}
  .fg input,.fg select,.fg textarea{min-height:44px;font-size:16px}
  .btn{min-height:44px}
  .cal-day{min-height:60px;padding:4px}
  .cal-day-num{font-size:10px}
  .cal-event{font-size:8px;padding:1px 3px}
  .cal-day-label{font-size:0}
  .cal-day-label::after{content:attr(data-short);font-size:9px}
  .cal-summary{grid-template-columns:repeat(2,1fr)}
}

/* ── ANIMATIONS ── */
@keyframes fadeUp {
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
.card{animation:fadeUp .3s ease both}
.card:nth-child(1){animation-delay:.05s}
.card:nth-child(2){animation-delay:.08s}
.card:nth-child(3){animation-delay:.11s}
.card:nth-child(4){animation-delay:.14s}
.card:nth-child(5){animation-delay:.17s}
.card:nth-child(6){animation-delay:.20s}
.card:nth-child(7){animation-delay:.23s}
.card:nth-child(8){animation-delay:.26s}
.section{animation:fadeUp .35s .1s ease both}

/* ── NUMBER ANIMATION ── */
.val{transition:all .3s ease}

/* ── SPECIAL CARD STYLES ── */
.card-ob .val{color:var(--blue)}
.card-received .val{color:var(--green)}

/* ── SALARY BOX LABELS ── */
.salary-box .fg label{color:rgba(240,180,41,.8)}
.fl-box .fg label{color:rgba(155,126,255,.8)}

/* ── MODAL INPUT NUMBER ── */
.fg input[type=number]{font-family:'JetBrains Mono',monospace}
.fg input[type=date]{font-family:'JetBrains Mono',monospace}

/* ── TABLE NUMBER CELLS ── */
td[style*="font-weight"]{font-family:'JetBrains Mono',monospace}

/* ── STATUS STRIP ── */
.status-strip {
  height:2px;width:100%;
  background:linear-gradient(90deg,var(--blue),var(--purple),var(--pink));
  position:fixed;top:0;left:0;z-index:100;
}

/* ── CONFIRM DIALOG ── */
.confirm-modal{width:380px;padding:20px 24px}

/* ── PAY MODAL BOX ── */
#payModalOverlay .modal{width:400px}
#payInfo{color:var(--green)}

/* ── METRIC CARD GLOW ── */
.card.inc{border-left:2px solid var(--green)}
.card.exp{border-left:2px solid var(--red)}
.card.div{border-left:2px solid var(--pink)}
.card.wht{border-left:2px solid var(--purple)}
.card.tax{border-left:2px solid var(--red)}

/* ── SKELETON LOADING ── */
.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--card-hover) 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}
.skeleton-line{height:12px;margin-bottom:8px;border-radius:3px}
.skeleton-line.w60{width:60%}
.skeleton-line.w40{width:40%}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── LOADING SPINNER ── */
@keyframes spin { to { transform: rotate(360deg) } }
.spinner {
  width:24px;height:24px;border:2.5px solid var(--border);
  border-top-color:var(--blue);border-radius:50%;
  animation:spin .6s linear infinite;
}

/* ── LOGOUT BUTTON ── */
.btn-logout:hover{background:rgba(255,77,109,.3) !important}
