
/* FutureLuxury UI 2050 — Design System (RTL, Mobile‑First) */
:root{
  --font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", "Noto Sans Arabic", "Tajawal", Arial, sans-serif;

  /* density */
  --space-1: 6px;
  --space-2: 10px;
  --space-3: 14px;
  --space-4: 18px;
  --space-5: 24px;
  --space-6: 32px;

  /* radii */
  --r-sm: 12px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 28px;

  /* shadow (soft + deep) */
  --sh-sm: 0 10px 30px rgba(2,6,23,.06);
  --sh-md: 0 18px 55px rgba(2,6,23,.10);
  --sh-lg: 0 30px 90px rgba(2,6,23,.16);

  /* default brand (overridden by Settings) */
  --brand: #22c55e;
  --brand-2: #38bdf8;

  /* light */
  --bg: #f6f8fb;
  --bg-2:#eef2f7;
  --card: rgba(255,255,255,.92);
  --card-2: rgba(255,255,255,.72);
  --text: #0b1220;
  --muted:#667085;
  --line: rgba(15,23,42,.10);

  /* effects */
  --glass: blur(14px) saturate(140%);
  --focus: 0 0 0 4px rgba(34,197,94,.22);
}

/* Mobile performance: reduce expensive blur to prevent lag on some devices */
@media (max-width: 600px){
  :root{ --glass: none; }
}

html[data-density="compact"]{
  --space-1: 5px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 26px;
}

html[data-theme="dark"]{
  --bg: #070a12;
  --bg-2:#0b1020;
  --card: rgba(14,18,32,.72);
  --card-2: rgba(14,18,32,.52);
  --text: #f3f6ff;
  --muted:#a7b0c2;
  --line: rgba(255,255,255,.10);
  --sh-sm: 0 12px 34px rgba(0,0,0,.35);
  --sh-md: 0 20px 70px rgba(0,0,0,.45);
  --sh-lg: 0 38px 120px rgba(0,0,0,.55);
  --focus: 0 0 0 4px rgba(56,189,248,.22);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:
    radial-gradient(1100px 500px at 10% 10%, rgba(56,189,248,.14), transparent 55%),
    radial-gradient(900px 450px at 85% 18%, rgba(34,197,94,.12), transparent 50%),
    radial-gradient(850px 450px at 50% 90%, rgba(168,85,247,.10), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg-2));
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
small{ opacity:.8; }
.muted{ color:var(--muted); }

/* container */
.container{
  width:100%;
  max-width: 1240px;
  margin-inline:auto;
  padding: clamp(12px, 3vw, 22px);
}

/* top nav */
.nav{
  position: sticky;
  top:0;
  z-index:50;
  backdrop-filter: var(--glass);
  background: linear-gradient(180deg, rgba(255,255,255,.75), rgba(255,255,255,.35));
  border-bottom:1px solid var(--line);
}
html[data-theme="dark"] .nav{
  background: linear-gradient(180deg, rgba(8,10,18,.78), rgba(8,10,18,.40));
}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: var(--space-3);
  padding: var(--space-3) clamp(12px, 3vw, 22px);
  max-width:1240px;
  margin-inline:auto;
}
.brand{ display:flex; align-items:center; gap:12px; min-width:0; }
.brand img{
  width:44px; height:44px; object-fit:contain;
  border-radius: 14px;
  box-shadow: var(--sh-sm);
  background: rgba(255,255,255,.55);
  padding:6px;
}
html[data-theme="dark"] .brand img{ background: rgba(255,255,255,.08); }
.brand .t{ display:flex; flex-direction:column; min-width:0;}
.brand b{
  font-size: 15px;
  letter-spacing:.2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.brand span{
  font-size: 12px;
  color: var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* nav links */
.nav-links{
  display:flex;
  align-items:center;
  gap: 10px;
  flex-wrap:wrap;
  justify-content:center;
}
.chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 10px 14px;
  border-radius: 999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.55);
  backdrop-filter: var(--glass);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
  font-size: 13px;
}
html[data-theme="dark"] .chip{ background: rgba(255,255,255,.06); }
.chip:hover{ transform: translateY(-1px); box-shadow: var(--sh-sm); border-color: rgba(56,189,248,.28); }
.chip.active{
  background: linear-gradient(135deg, rgba(34,197,94,.18), rgba(56,189,248,.14));
  border-color: rgba(56,189,248,.35);
}
.nav-actions{ display:flex; align-items:center; gap: 10px; }

.badge{
  display:none;
  padding: 10px 12px;
  border-radius: 999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.42);
  color: var(--muted);
}
@media (min-width: 900px){
  .badge{ display:inline-flex; }
}

.icon-btn, .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 11px 14px;
  border-radius: 14px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.55);
  color: var(--text);
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, opacity .18s ease;
  backdrop-filter: var(--glass);
  user-select:none;
}
html[data-theme="dark"] .icon-btn,
html[data-theme="dark"] .btn{ background: rgba(255,255,255,.06); }

.icon-btn:hover, .btn:hover{ transform: translateY(-1px); box-shadow: var(--sh-sm); border-color: rgba(34,197,94,.28); }
.icon-btn:active, .btn:active{ transform: translateY(0px) scale(.98); }
.btn.primary{
  border-color: rgba(34,197,94,.38);
  background: linear-gradient(135deg, rgba(34,197,94,.28), rgba(56,189,248,.18));
}
.btn.ghost{ background: transparent; }
.btn:disabled{ opacity:.55; cursor:not-allowed; transform:none; box-shadow:none; }

/* responsive nav (mobile) */
.nav-toggle{ display:inline-flex; }
@media (min-width: 900px){
  .nav-toggle{ display:none; }
}
@media (max-width: 899px){
  .nav-inner{ flex-wrap:wrap; justify-content:space-between; }
  .nav-actions{ width:100%; justify-content:space-between; }
  .nav-actions .btn.ghost{ padding-inline:12px; }
  .nav-links{
    width:100%;
    display:none;
    padding-top: var(--space-2);
    justify-content:flex-start;
  }
  .nav.open .nav-links{ display:flex; }
  .nav-links{ flex-direction:column; align-items:stretch; }
  .chip{ width:100%; justify-content:space-between; }
}

/* cards / layout */
.card{
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-sm);
  backdrop-filter: var(--glass);
}
.card.pad{ padding: var(--space-5); }

.grid{
  display:grid;
  gap: var(--space-4);
}
.grid.kpis{ grid-template-columns: repeat(4, minmax(0,1fr)); }
@media (max-width: 1100px){ .grid.kpis{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 520px){ .grid.kpis{ grid-template-columns: 1fr; } }

.kpi{
  padding: var(--space-4);
  border-radius: var(--r-xl);
  background: linear-gradient(180deg, var(--card), var(--card-2));
  border: 1px solid var(--line);
  position:relative;
  overflow:hidden;
  transition: transform .18s ease, box-shadow .18s ease;
}
.kpi:before{
  content:"";
  position:absolute; inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(56,189,248,.18), transparent 55%),
              radial-gradient(circle at 70% 30%, rgba(34,197,94,.16), transparent 55%),
              radial-gradient(circle at 50% 80%, rgba(168,85,247,.10), transparent 55%);
  transform: rotate(12deg);
}
.kpi > *{ position:relative; }
.kpi:hover{ transform: translateY(-2px); box-shadow: var(--sh-md); }
.kpi b{ font-size: clamp(18px, 2.2vw, 26px); }
.kpi .muted{ font-size: 12px; }

/* tables (no horizontal page scroll) */
.table-wrap{ width:100%; overflow:auto; border-radius: var(--r-xl); border:1px solid var(--line); background: var(--card); }
table{ width:100%; border-collapse:separate; border-spacing:0; min-width: 760px; }
@media (max-width: 820px){ table{ min-width: 700px; } }
th,td{ padding: 14px 14px; text-align:right; border-bottom:1px solid var(--line); font-size:13px; white-space:nowrap; }
th{ position:sticky; top:0; background: linear-gradient(180deg, var(--card), var(--card-2)); z-index:1; }
tr:hover td{ background: rgba(56,189,248,.06); }
td .actions{ display:flex; gap:8px; justify-content:flex-end; flex-wrap:wrap; }

/* forms */
label{ display:block; font-size:12px; color:var(--muted); margin-bottom:8px; }
input, select, textarea{
  width:100%;
  padding: 12px 14px;
  border-radius: 14px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.55);
  color:var(--text);
  outline:none;
  transition: box-shadow .18s ease, border-color .18s ease, background .18s ease;
  backdrop-filter: var(--glass);
}
html[data-theme="dark"] input,
html[data-theme="dark"] select,
html[data-theme="dark"] textarea{ background: rgba(255,255,255,.06); }
input:focus, select:focus, textarea:focus{ box-shadow: var(--focus); border-color: rgba(56,189,248,.35); }
.form-row{ display:grid; gap: var(--space-3); grid-template-columns: 1fr 1fr; }
@media (max-width: 680px){ .form-row{ grid-template-columns: 1fr; } }

/* alerts / toasts */
.alert{
  border-radius: var(--r-lg);
  border:1px solid var(--line);
  padding: 12px 14px;
  margin: 0 0 var(--space-4) 0;
  background: linear-gradient(180deg, var(--card), var(--card-2));
}
.alert.ok{ border-color: rgba(34,197,94,.30); }
.alert.err{ border-color: rgba(239,68,68,.35); }
.toast{
  position: fixed;
  inset-inline: 18px;
  bottom: 18px;
  z-index: 999;
  display:flex;
  flex-direction:column;
  gap:10px;
  pointer-events:none;
}
.toast .t{
  pointer-events:auto;
  max-width: 520px;
  margin-inline:auto;
  border-radius: var(--r-lg);
  border:1px solid var(--line);
  background: linear-gradient(180deg, var(--card), var(--card-2));
  padding: 12px 14px;
  box-shadow: var(--sh-md);
  display:flex;
  align-items:flex-start;
  gap:10px;
  animation: toastIn .22s ease;
}
@keyframes toastIn{ from{ transform: translateY(10px); opacity:0; } to{ transform: translateY(0); opacity:1; } }
.toast .dot{ width:10px; height:10px; border-radius:999px; margin-top:6px; background: var(--brand); }
.toast .t.err .dot{ background:#ef4444; }


/* auth page (login) */
.auth-wrap{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding: clamp(14px, 3vw, 22px);
}
.auth-card{
  width:min(980px, 100%);
  border-radius: 34px;
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.74), rgba(255,255,255,.40));
  backdrop-filter: var(--glass);
  box-shadow: var(--sh-lg);
  overflow:hidden;
  display:grid;
  grid-template-columns: 1.2fr .9fr;
}
html[data-theme="dark"] .auth-card{
  background: linear-gradient(180deg, rgba(14,18,32,.78), rgba(14,18,32,.44));
}
@media (max-width: 860px){
  .auth-card{ grid-template-columns: 1fr; }
}
.auth-left{
  padding: clamp(18px, 3.2vw, 34px);
}
.auth-right{
  padding: clamp(18px, 3.2vw, 34px);
  border-right:1px solid var(--line);
  background:
    radial-gradient(500px 260px at 20% 20%, rgba(56,189,248,.18), transparent 55%),
    radial-gradient(520px 260px at 80% 30%, rgba(34,197,94,.16), transparent 55%),
    radial-gradient(560px 300px at 50% 80%, rgba(168,85,247,.12), transparent 55%);
}
@media (max-width: 860px){
  .auth-right{ border-right:none; border-top:1px solid var(--line); }
}
.auth-logo{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap: 12px;
  margin-bottom: 18px;
}
.auth-logo img{
  width: 120px; height: 120px;
  border-radius: 28px;
  object-fit:contain;
  padding: 14px;
  background: rgba(255,255,255,.55);
  box-shadow: var(--sh-md);
}
html[data-theme="dark"] .auth-logo img{ background: rgba(255,255,255,.06); }
.auth-logo b{ font-size: 20px; letter-spacing:.3px; }
.auth-logo .muted{ font-size: 13px; }
.auth-actions{ display:flex; gap:10px; align-items:center; justify-content:space-between; }
.pw-toggle{ cursor:pointer; opacity:.85; }

/* footer */
.footer{
  margin-top: var(--space-5);
  padding: var(--space-4) 0;
  color: var(--muted);
  text-align:center;
  font-size: 12px;
}

/* legacy grid helpers */
.grid.cols-2{ grid-template-columns: repeat(2,minmax(0,1fr)); }
.grid.cols-3{ grid-template-columns: repeat(3,minmax(0,1fr)); }
.grid.cols-4{ grid-template-columns: repeat(4,minmax(0,1fr)); }
@media (max-width: 900px){
  .grid.cols-3, .grid.cols-4{ grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 520px){
  .grid.cols-2, .grid.cols-3, .grid.cols-4{ grid-template-columns: 1fr; }
}


/* Debt chips */
.chip{ display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.04); font-size:12px; }
.chip.ok{ border-color: rgba(34,197,94,.35); background: rgba(34,197,94,.12); }
.chip.info{ border-color: rgba(56,189,248,.35); background: rgba(56,189,248,.12); }
.chip.warn{ border-color: rgba(245,158,11,.35); background: rgba(245,158,11,.12); }
.chip.danger{ border-color: rgba(239,68,68,.35); background: rgba(239,68,68,.12); }

/* Details mini */
details.mini summary{ list-style:none; cursor:pointer; }
details.mini summary::-webkit-details-marker{ display:none; }

/* Aging */
.aging{ display:flex; flex-direction:column; gap:10px; }
.aging-row{ display:flex; align-items:center; gap:10px; }
.aging .bar{ flex:1; height:12px; border-radius:999px; background:rgba(255,255,255,.06); overflow:hidden; border:1px solid var(--line); }
.aging .bar .fill{ height:100%; background: linear-gradient(90deg, var(--brand), var(--brand-2)); border-radius:999px; }

/* Table wrap responsive */
.table-wrap{ width:100%; overflow:auto; -webkit-overflow-scrolling: touch; border-radius: var(--r-lg); border:1px solid var(--line); background:rgba(255,255,255,.02); }
.table{ width:100%; border-collapse: collapse; min-width: 860px; }
.table th,.table td{ padding: 12px 14px; border-bottom:1px solid var(--line); vertical-align: top; }
.table th{ text-align:start; font-size:12px; color: var(--muted); font-weight: 700; }
.table td{ font-size: 13px; }
.link{ color: var(--brand-2); text-decoration:none; }
.link:hover{ text-decoration:underline; }


/* Login — Premium 2050 */
body.login{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  overflow:hidden;
  background:
    radial-gradient(1100px 600px at 20% 10%, rgba(56,189,248,.14), transparent 55%),
    radial-gradient(900px 520px at 80% 30%, rgba(34,197,94,.16), transparent 60%),
    radial-gradient(800px 500px at 50% 90%, rgba(168,85,247,.12), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg-2));
}
.login-wrap{ width:100%; max-width:460px; }
.login-card{
  position:relative;
  padding:24px;
  border-radius: var(--r-xl);
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--sh-lg);
  backdrop-filter: blur(18px);
}
.login-card:before{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius: calc(var(--r-xl) + 2px);
  background: linear-gradient(135deg, rgba(56,189,248,.32), rgba(34,197,94,.26), rgba(168,85,247,.22));
  filter: blur(14px);
  opacity:.45;
  z-index:-1;
}
.login-brand{ display:flex; justify-content:center; margin-bottom:18px; }
.login-logo{
  width:min(220px, 70vw);
  height:110px;
  object-fit:contain;
  filter: drop-shadow(0 16px 40px rgba(0,0,0,.35));
  animation: flFade .9s ease both;
}
@keyframes flFade{ from{ opacity:0; transform: translateY(10px) scale(.98);} to{ opacity:1; transform:none;} }
.login-form label{ font-weight:700; font-size:12px; color: var(--muted); }
.login-form input{
  width:100%;
  padding:12px 14px;
  border-radius: 16px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--text);
  outline:none;
}
.login-form input:focus{ box-shadow: var(--focus); border-color: rgba(56,189,248,.35); }
.pw{ display:flex; gap:8px; align-items:center; }
.pw input{ flex:1; }


/* ===============================
   v8 "SaaS 2050" Upgrade Overrides
   =============================== */
html,body{ overflow-x:hidden; }
:root{
  --font-sans: "IBM Plex Sans Arabic", "Tajawal", system-ui, -apple-system, Segoe UI, Arial;
}
body{ font-family: var(--font-sans); }

/* TopNavbar enhancements */
.TopNavbar{ box-shadow: 0 10px 50px rgba(2,6,23,.10); }
.topnav-backdrop{
  position: fixed; inset: 0;
  background: rgba(2,6,23,.35);
  backdrop-filter: blur(8px);
  opacity:0; pointer-events:none;
  transition: opacity .22s ease;
  z-index: 40;
}
.topnav-backdrop.open{ opacity:1; pointer-events:auto; }

@media (max-width: 899px){
  .TopNavbar__inner{ position: relative; }
  .TopNavbar__links{
    position:absolute;
    top: calc(100% + 10px);
    right: 0; left: 0;
    background: color-mix(in oklab, var(--card) 92%, transparent);
    border:1px solid var(--line);
    border-radius: var(--r-xl);
    padding: 12px;
    box-shadow: 0 30px 80px rgba(2,6,23,.25);
    max-height: 70vh;
    overflow:auto;
  }
  .nav-links{ display:none; }
  .nav.open .nav-links{ display:flex; }
  body.nav-open{ overflow:hidden; }
}

/* Buttons: futuristic micro-interactions */
.btn, .icon-btn, .chip{
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, opacity .18s ease;
}
.btn:hover, .chip:hover{ transform: translateY(-1px); box-shadow: 0 16px 40px rgba(2,6,23,.10); }
.btn:active, .chip:active{ transform: translateY(0); box-shadow: 0 8px 18px rgba(2,6,23,.10); }
.icon-btn:hover{ transform: translateY(-1px) scale(1.02); }
.icon-btn:active{ transform: translateY(0) scale(.99); }

/* Page header */
.PageHeader{
  display:flex; align-items:flex-end; justify-content:space-between; gap:16px;
  padding: 22px 22px 6px;
}
.PageHeader h1{ margin:0; font-size: 30px; letter-spacing:-.5px; }
.PageHeader .sub{ margin-top:8px; color: var(--muted); font-size:13px; }

/* KPI Cards */
.KPIGrid{ display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; }
@media (max-width: 1100px){ .KPIGrid{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 560px){ .KPIGrid{ grid-template-columns: 1fr; } }

/* KPI Tiles (Dashboard) */
.KPITile{ position:relative; overflow:hidden; border-radius: var(--r-xl); padding: 16px 16px; min-height: 94px; display:flex; gap: 12px; align-items:center;
  border: 1px solid color-mix(in srgb, var(--card-border), transparent 20%);
  background: linear-gradient(135deg, color-mix(in srgb, var(--card), #fff 10%), color-mix(in srgb, var(--card), #000 2%));
  box-shadow: var(--shadow-2);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.KPITile:hover{ transform: translateY(-2px); box-shadow: var(--shadow-3); border-color: color-mix(in srgb, var(--brand-2), transparent 55%); }
.KPITile .ico{ width: 46px; height:46px; border-radius: 16px; display:grid; place-items:center; font-size: 22px;
  background: radial-gradient(80% 80% at 30% 20%, color-mix(in srgb, var(--brand-2), transparent 60%), transparent),
              linear-gradient(135deg, color-mix(in srgb, var(--brand), transparent 70%), color-mix(in srgb, var(--brand-2), transparent 80%));
  border:1px solid color-mix(in srgb, var(--brand-2), transparent 65%);
}
.KPITile .meta{ flex:1; }
.KPITile .lbl{ font-size: 13px; color: var(--muted); }
.KPITile .val{ font-size: 22px; font-weight: 900; letter-spacing: .2px; margin-top: 2px; }
.KPITile .unit{ font-size: 12px; color: var(--muted); margin-top: 2px; }

.KPITile:before{ content:""; position:absolute; inset:-2px; background: radial-gradient(600px 160px at 70% 0%, color-mix(in srgb, var(--brand-2), transparent 78%), transparent 60%);
  pointer-events:none;
}
.KPITile.kpi-a:before{ background: radial-gradient(520px 170px at 80% 0%, color-mix(in srgb, var(--brand-2), transparent 78%), transparent 60%); }
.KPITile.kpi-b:before{ background: radial-gradient(520px 170px at 80% 0%, color-mix(in srgb, var(--brand), transparent 78%), transparent 60%); }
.KPITile.kpi-c:before{ background: radial-gradient(520px 170px at 80% 0%, color-mix(in srgb, #f59e0b, transparent 80%), transparent 60%); }
.KPITile.kpi-d:before{ background: radial-gradient(520px 170px at 80% 0%, color-mix(in srgb, #a855f7, transparent 82%), transparent 60%); }

.AnalyticsGrid{ display:grid; grid-template-columns: 1fr 1.35fr; gap: 14px; margin-top: 14px; }
@media (max-width: 980px){ .AnalyticsGrid{ grid-template-columns: 1fr; } }
.ChartCard{ padding: 16px; }
.ChartCard .title{ display:flex; align-items:flex-end; justify-content:space-between; gap: 12px; margin-bottom: 10px; }
.ChartCard .title h3{ margin:0; font-size: 16px; }
.ChartCard .title .hint{ color: var(--muted); font-size: 12px; }
.ChartWrap{ height: 260px; }
@media (max-width: 560px){ .ChartWrap{ height: 220px; } }

/* Dashboard layout helpers */
.DashGrid{ display:grid; grid-template-columns: 1fr 1.2fr; gap: 14px; margin-top: 14px; }
@media (max-width: 1020px){ .DashGrid{ grid-template-columns: 1fr; } }

.card-pad{ padding: 16px; }
.CardHead{ display:flex; align-items:flex-start; justify-content:space-between; gap: 14px; margin-bottom: 12px; }
.CardHead h3{ margin:0; font-size: 16px; }
.CardHead .muted{ color: var(--muted); font-size: 12px; margin-top: 4px; }

.ChartWrap{ display:grid; grid-template-columns: 220px 1fr; gap: 12px; align-items:center; }
@media (max-width: 620px){ .ChartWrap{ grid-template-columns: 1fr; } }
.ChartWrap #donut{ width:100% !important; height: 220px !important; }

.Legend{ display:flex; flex-direction:column; gap: 8px; }
.LegendRow{ display:flex; align-items:center; gap: 10px; padding: 8px 10px; border-radius: 14px; border: 1px solid var(--card-border); background: color-mix(in srgb, var(--card), #fff 4%); }
.LegendRow .dot{ width:10px; height:10px; border-radius: 99px; background: color-mix(in srgb, var(--brand-2), transparent 20%); box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand-2), transparent 85%); }
.LegendRow .name{ flex:1; font-size: 13px; }
.LegendRow .num{ font-size: 12px; color: var(--muted); }

.ChartOnly{ height: 260px; }
.ChartOnly canvas{ width:100% !important; height:100% !important; }

.DebtMini{ display:flex; gap: 10px; flex-wrap:wrap; }
.DebtMini .mini{ border: 1px solid var(--card-border); border-radius: 16px; padding: 10px 12px; background: color-mix(in srgb, var(--card), #fff 4%); min-width: 140px; }
.DebtMini .mini span{ display:block; font-size: 12px; color: var(--muted); }
.DebtMini .mini b{ font-size: 16px; }

.RecentGrid{ display:grid; grid-template-columns: 1fr; gap: 14px; margin-top: 14px; }
.KPICard{ position:relative; overflow:hidden; }
.KPICard::before{
  content:""; position:absolute; inset:-40px;
  background: radial-gradient(closest-side, color-mix(in oklab, var(--brand) 35%, transparent), transparent 70%);
  opacity:.55;
  transform: translate3d(0,0,0);
}
.KPICard .kpi-label{ position:relative; font-size:12px; color:var(--muted); }
.KPICard .kpi-value{ position:relative; font-size:28px; font-weight:900; letter-spacing:-.5px; }

/* Analytics cards */
.AnalyticsGrid{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 980px){ .AnalyticsGrid{ grid-template-columns: 1fr; } }
.ChartCard canvas{ width:100% !important; height: 260px !important; }

/* Data table section */
.DataTable{ overflow:hidden; }
.DataTable .table-wrap{ overflow:auto; -webkit-overflow-scrolling: touch; }
.DataTable table{ min-width: 820px; }
@media (max-width: 700px){ .DataTable table{ min-width: 720px; } }

/* Empty state */
.EmptyState{
  display:flex; flex-direction:column; gap:10px; align-items:center; justify-content:center;
  padding: 34px; color: var(--muted); text-align:center;
}
.EmptyState .icon{ font-size:28px; }
.EmptyState b{ color: var(--text); }

/* Print styles for reports */
@media print{
  body{ background:#fff !important; }
  .TopNavbar, .footer, .btn, .icon-btn, .chip, .topnav-backdrop, .toast{ display:none !important; }
  .card{ box-shadow:none !important; border:1px solid #e5e7eb !important; }
  .container{ padding:0 !important; }
  .print-page{ padding: 18mm 14mm; }
  .print-header{ display:flex; justify-content:space-between; align-items:flex-start; margin-bottom: 10mm; }
  .print-header .meta{ font-size: 11px; color:#334155; }
  .print-header img{ height: 44px; width:auto; }
  .print-footer{ position: fixed; bottom: 8mm; left: 14mm; right: 14mm; font-size: 11px; color:#334155; display:flex; justify-content:space-between; }
  a[href]:after{ content:""; }
}


/* Auth (Login) — Futuristic */
.auth-bg{
  min-height:100vh;
  background:
    radial-gradient(900px 500px at 10% 10%, rgba(56,189,248,.18), transparent 55%),
    radial-gradient(900px 500px at 90% 0%, rgba(34,197,94,.14), transparent 55%),
    radial-gradient(900px 500px at 80% 90%, rgba(139,92,246,.14), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.75));
}
html[data-theme="dark"] .auth-bg{
  background:
    radial-gradient(900px 500px at 10% 10%, rgba(56,189,248,.14), transparent 55%),
    radial-gradient(900px 500px at 90% 0%, rgba(34,197,94,.10), transparent 55%),
    radial-gradient(900px 500px at 80% 90%, rgba(139,92,246,.10), transparent 55%),
    linear-gradient(180deg, rgba(2,6,23,.95), rgba(2,6,23,.90));
}
.auth-shell{ min-height:100vh; display:grid; place-items:center; padding:24px 14px; }
.auth-card{
  width:min(460px, 100%);
  border-radius: 28px;
  border: 1px solid color-mix(in oklab, var(--line) 80%, transparent);
  background: color-mix(in oklab, var(--card) 88%, transparent);
  box-shadow: 0 30px 100px rgba(2,6,23,.18);
  padding: 18px 18px 16px;
  position:relative;
  overflow:hidden;
  animation: fadeUp .55s ease both;
}
.auth-card::before{
  content:"";
  position:absolute; inset:-60px;
  background: radial-gradient(closest-side, rgba(56,189,248,.22), transparent 70%);
  opacity:.6;
  pointer-events:none;
}
@keyframes fadeUp{ from{ opacity:0; transform: translateY(10px) scale(.99);} to{ opacity:1; transform: translateY(0) scale(1);} }
@media (prefers-reduced-motion: reduce){ .auth-card{ animation:none; } }

.auth-top{ display:flex; justify-content:flex-start; position:relative; z-index:1; }
.auth-brand{ text-align:center; padding: 4px 10px 14px; position:relative; z-index:1; }
.auth-logo{ width: 120px; height: 120px; object-fit:contain; filter: drop-shadow(0 14px 20px rgba(2,6,23,.18)); }
.auth-title{ font-size: 22px; font-weight: 900; letter-spacing:-.3px; margin-top: 8px; }
.auth-sub{ font-size: 12px; color: var(--muted); margin-top:6px; }
.auth-form{ position:relative; z-index:1; }
.pw-wrap{ display:flex; gap:10px; align-items:center; }
.pw-wrap .input{ flex:1; }
.auth-footer{ margin-top: 14px; font-size: 12px; color: var(--muted); text-align:center; position:relative; z-index:1; }

@media (max-width: 980px){ .grid.cols-2{ grid-template-columns: 1fr; } }

/* Subtle page motion */
.container .card{ animation: cardIn .28s ease both; }
@keyframes cardIn{ from{ opacity:0; transform: translateY(6px);} to{ opacity:1; transform: translateY(0);} }
@media (prefers-reduced-motion: reduce){ .container .card{ animation:none; } }

/* --- Responsive TopNavbar (mobile drawer) --- */
.topnav-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.28);backdrop-filter:blur(6px);z-index:40}
@media (max-width: 980px){
  .TopNavbar__links{position:fixed;top:74px;right:12px;left:12px;max-height:70vh;overflow:auto;
    background:var(--card);border:1px solid var(--stroke);border-radius:var(--r-lg);padding:10px;
    transform:translateY(-8px);opacity:0;pointer-events:none;transition:.18s ease;z-index:50}
  body.nav-open .TopNavbar__links{transform:translateY(0);opacity:1;pointer-events:auto}
  .badge{display:none}
}

/* --- Command Palette --- */
.CommandPalette{position:fixed;inset:0;z-index:60;display:grid;place-items:start center;padding-top:10vh}
.CommandPalette__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(10px)}
.CommandPalette__panel{position:relative;width:min(720px,92vw);background:var(--card);border:1px solid var(--stroke);
  border-radius:18px;box-shadow:0 30px 90px rgba(0,0,0,.35);overflow:hidden}
.CommandPalette__top{display:flex;gap:10px;align-items:center;padding:14px;border-bottom:1px solid var(--stroke)}
.CommandPalette__top input{flex:1;background:transparent;border:0;outline:none;font-size:16px;color:var(--text)}
.CommandPalette__top kbd{font-family:inherit;background:var(--chip);border:1px solid var(--stroke);border-radius:10px;padding:6px 10px;color:var(--muted)}
.CommandPalette__list{max-height:340px;overflow:auto;padding:8px}
.cmd-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;color:var(--text);
  text-decoration:none;transition:.14s ease}
.cmd-item:hover{background:var(--chip);transform:translateY(-1px)}
.cmd-item .i{width:28px;display:grid;place-items:center}
.cmd-item .go{margin-right:auto;color:var(--muted)}
.cmd-empty{padding:18px;color:var(--muted);text-align:center}
.CommandPalette__hint{padding:10px 14px;border-top:1px solid var(--stroke);color:var(--muted);font-size:12px}

/* --- Focus Mode --- */
body.focus-mode .TopNavbar{position:sticky;top:0;opacity:.08;pointer-events:none}
body.focus-mode .TopNavbar:hover{opacity:1;pointer-events:auto}

.logo{width:42px;height:42px;border-radius:14px;object-fit:contain;background:rgba(255,255,255,.06);padding:6px;margin-inline-end:10px}
.brand-title{font-weight:800;letter-spacing:.2px}
.kpis-inline{display:flex;gap:18px;align-items:center}
.kpis-inline .v{font-weight:800;font-size:18px}
.card.soft{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.form.inline{display:flex;gap:10px;align-items:end;flex-wrap:wrap}
.mt{margin-top:12px}
