/* =====================================================================
   AJAR — System UI (admin) design system
   Arabic-first · RTL default · colorful · animated
   Fonts: Changa (display/numbers) + Tajawal (UI/body)
   ===================================================================== */

:root{
  --bg:#eef1fb;
  --surface:#ffffff;
  --surface-2:#f6f7fd;
  --surface-3:#eef1f9;
  --ink:#1e2140;
  --ink-2:#565c82;
  --muted:#9aa0c2;
  --border:#e9ecf7;
  --border-2:#dfe3f2;

  --primary:#6d5efc;
  --primary-600:#5a49ee;
  --primary-tint:#eeecff;

  --blue:#3aa0ff;   --blue-t:#e6f2ff;
  --teal:#12b3a6;   --teal-t:#dcf6f3;
  --green:#22c07d;  --green-t:#dcf7ea;
  --amber:#ff9f2e;  --amber-t:#fff0da;
  --red:#ff5d73;    --red-t:#ffe4e8;
  --pink:#ff5aa8;   --pink-t:#ffe3f1;
  --violet:#8b5cf6; --violet-t:#efe8ff;
  --cyan:#20c4e0;   --cyan-t:#dcf6fb;

  --grad-side:linear-gradient(205deg,#5b3bf0 0%,#7b3ff2 48%,#a939e8 100%);
  --grad-primary:linear-gradient(135deg,#6d5efc 0%,#a13bf0 100%);
  --grad-teal:linear-gradient(135deg,#12b3a6,#22c07d);
  --grad-amber:linear-gradient(135deg,#ff9f2e,#ff5d73);
  --grad-blue:linear-gradient(135deg,#3aa0ff,#8b5cf6);

  --shadow-sm:0 2px 8px -3px rgba(37,40,80,.16);
  --shadow:0 12px 30px -14px rgba(37,40,80,.24), 0 4px 12px -8px rgba(37,40,80,.16);
  --shadow-lg:0 30px 60px -28px rgba(50,40,120,.36);
  --ring:0 0 0 4px rgba(109,94,252,.16);

  --radius:14px;
  --radius-lg:22px;
  --radius-sm:10px;

  --ease:cubic-bezier(.34,1.2,.4,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);

  --font:"Tajawal",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-display:"Changa","Tajawal",system-ui,sans-serif;

  --sb:268px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font);color:var(--ink);
  background:
    radial-gradient(120% 120% at 100% 0,rgba(139,92,246,.10),transparent 42%),
    radial-gradient(120% 120% at 0 100%,rgba(58,160,255,.10),transparent 42%),
    var(--bg);
  line-height:1.6;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{font-family:var(--font-display);margin:0;line-height:1.2;font-weight:700}
::selection{background:var(--primary);color:#fff}
.num{font-family:var(--font-display);font-variant-numeric:tabular-nums;letter-spacing:.5px}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#cfd4ea;border-radius:20px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:#b6bce0;background-clip:content-box}

/* ---------------- App shell ---------------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:var(--sb);flex:0 0 var(--sb);
  position:fixed;inset-block:0;inset-inline-start:0;z-index:60;
  background:var(--grad-side);color:#fff;
  display:flex;flex-direction:column;gap:.4rem;
  padding:1.2rem 1rem;overflow:hidden;
}
.sidebar::before{ /* glow */
  content:"";position:absolute;inset-block-start:-40%;inset-inline-end:-30%;
  width:70%;height:70%;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.28),transparent 65%);pointer-events:none;
}
.sidebar::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}
.sb-brand{display:flex;align-items:center;gap:.7rem;padding:.4rem .6rem 1rem;position:relative;z-index:1}
.sb-brand .logo{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.16);display:grid;place-items:center;backdrop-filter:blur(6px);box-shadow:inset 0 1px 1px rgba(255,255,255,.4)}
.sb-brand .logo svg{width:24px;height:24px}
.sb-brand .name{font-family:var(--font-display);font-weight:800;font-size:1.25rem;line-height:1}
.sb-brand .tag{font-size:.66rem;letter-spacing:.18em;opacity:.75;text-transform:uppercase}
.sb-section{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;opacity:.6;margin:1rem .8rem .3rem;position:relative;z-index:1}
.sb-nav{display:flex;flex-direction:column;gap:.15rem;position:relative;z-index:1;overflow-y:auto}
.sb-link{
  display:flex;align-items:center;gap:.75rem;padding:.7rem .85rem;border-radius:12px;
  color:rgba(255,255,255,.82);font-weight:500;font-size:.95rem;position:relative;
  transition:background .3s var(--ease-soft),color .3s,transform .3s var(--ease);
}
.sb-link svg{width:20px;height:20px;flex:0 0 auto;opacity:.9}
.sb-link .cnt{margin-inline-start:auto;font-family:var(--font-display);font-size:.72rem;font-weight:700;background:rgba(255,255,255,.2);padding:.05rem .5rem;border-radius:20px}
.sb-link:hover{background:rgba(255,255,255,.12);color:#fff;}
[dir="ltr"] .sb-link:hover{/*transform:translateX(3px)*/}
.sb-link.active{background:#fff;color:var(--primary-600);font-weight:700;box-shadow:var(--shadow)}
.sb-link.active svg{opacity:1}
.sb-link.active .cnt{background:var(--primary-tint);color:var(--primary-600)}
.sb-foot{margin-top:auto;position:relative;z-index:1}
.sb-upgrade{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:1rem;backdrop-filter:blur(6px)}
.sb-upgrade h4{font-size:.95rem}
.sb-upgrade p{font-size:.78rem;opacity:.8;margin:.3rem 0 .8rem}

.main{flex:1;min-width:0;margin-inline-start:var(--sb);display:flex;flex-direction:column}

/* ---------------- Topbar ---------------- */
.topbar{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;gap:1rem;
  padding:.85rem clamp(1rem,3vw,2rem);
  background:rgba(255,255,255,.78);backdrop-filter:blur(14px) saturate(150%);
  border-bottom:1px solid var(--border);
}
.burger{display:none;width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:#fff;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.burger span{width:18px;height:2px;background:var(--ink);border-radius:2px;transition:.3s var(--ease)}
.searchbar{flex:1;max-width:420px;position:relative;display:flex;align-items:center}
.searchbar svg{position:absolute;inset-inline-start:.85rem;width:18px;height:18px;color:var(--muted)}
.searchbar input{
  width:100%;padding:.7rem 1rem;padding-inline-start:2.6rem;border-radius:12px;border:1px solid var(--border);
  background:var(--surface-2);color:var(--ink);font-family:inherit;font-size:.9rem;transition:.25s var(--ease-soft);
}
.searchbar input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:var(--ring)}
.topbar-actions{margin-inline-start:auto;display:flex;align-items:center;gap:.5rem}
.icon-btn{
  position:relative;width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--ink-2);
  display:grid;place-items:center;cursor:pointer;transition:.25s var(--ease);
}
.icon-btn svg{width:20px;height:20px}
.icon-btn:hover{color:var(--primary-600);border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.icon-btn .dot{position:absolute;top:8px;inset-inline-end:9px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid #fff}
.lang-toggle{
  height:42px;padding:0 .9rem;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--ink);
  font-family:var(--font-display);font-weight:700;font-size:.85rem;cursor:pointer;transition:.25s var(--ease);
}
.lang-toggle:hover{background:var(--grad-primary);color:#fff;border-color:transparent}
.user{display:flex;align-items:center;gap:.6rem;padding:.25rem;padding-inline-end:.85rem;border-radius:40px;border:1px solid var(--border);background:#fff;cursor:pointer;transition:.25s var(--ease)}
.user:hover{box-shadow:var(--shadow-sm)}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--grad-primary);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:.9rem}
.user .who{line-height:1.15}
.user .who b{font-size:.85rem}
.user .who span{font-size:.72rem;color:var(--muted);display:block}

/* ---------------- Page ---------------- */
.content{padding:clamp(1rem,3vw,2rem);flex:1}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.4rem}
.crumb{font-size:.8rem;color:var(--muted);margin-bottom:.35rem;display:flex;gap:.4rem;align-items:center}
.crumb b{color:var(--primary-600)}
.page-head h1{font-size:clamp(1.5rem,3vw,2rem)}
.page-head p{color:var(--ink-2);font-size:.92rem;margin-top:.2rem}

/* ---------------- Grid ---------------- */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.1rem}
.c3{grid-column:span 3}.c4{grid-column:span 4}.c5{grid-column:span 5}
.c6{grid-column:span 6}.c7{grid-column:span 7}.c8{grid-column:span 8}.c12{grid-column:span 12}

/* ---------------- Panels / cards ---------------- */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.3rem}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.panel-head h3{font-size:1.05rem}
.panel-head .sub{font-size:.78rem;color:var(--muted)}
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:3px}
.seg button{border:0;background:transparent;padding:.4rem .8rem;border-radius:9px;font-size:.8rem;font-weight:600;color:var(--ink-2);cursor:pointer;transition:.25s var(--ease)}
.seg button.on{background:#fff;color:var(--primary-600);box-shadow:var(--shadow-sm)}

/* ---------------- KPI ---------------- */
.kpi{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.2rem 1.3rem;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.kpi:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.kpi .top{display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.kpi .ic{width:50px;height:50px;border-radius:15px;display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-sm)}
.kpi .ic svg{width:26px;height:26px}
.kpi .label{color:var(--ink-2);font-size:.9rem;font-weight:500;margin-top:1rem}
.kpi .value{font-family:var(--font-display);font-weight:800;font-size:2rem;line-height:1.1;margin-top:.15rem;color:var(--ink)}
.kpi .value small{font-size:1rem;font-weight:700;color:var(--muted);margin-inline-start:.25rem}
.kpi .foot{display:flex;align-items:center;gap:.5rem;margin-top:.7rem}
.trend{display:inline-flex;align-items:center;gap:.25rem;font-family:var(--font-display);font-weight:700;font-size:.78rem;padding:.15rem .5rem;border-radius:20px}
.trend svg{width:13px;height:13px}
.trend.up{color:#0f9e63;background:var(--green-t)}
.trend.down{color:#e23e57;background:var(--red-t)}
.kpi .foot .since{font-size:.75rem;color:var(--muted)}
.kpi .spark{position:absolute;inset-block-end:0;inset-inline-start:0;inset-inline-end:0;height:42px;opacity:.9}
.kpi .glow{position:absolute;inset-block-start:-30px;inset-inline-end:-20px;width:120px;height:120px;border-radius:50%;filter:blur(10px);opacity:.16}
.kpi.violet .ic{background:var(--grad-primary)} .kpi.violet .glow{background:var(--primary)}
.kpi.teal .ic{background:var(--grad-teal)} .kpi.teal .glow{background:var(--teal)}
.kpi.amber .ic{background:var(--grad-amber)} .kpi.amber .glow{background:var(--amber)}
.kpi.blue .ic{background:var(--grad-blue)} .kpi.blue .glow{background:var(--blue)}

/* ---------------- Chart holders ---------------- */
.chart-wrap{position:relative;width:100%}
.chart-wrap.tall{height:300px}
.chart-wrap.mid{height:260px}
.doughnut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.doughnut-center b{font-family:var(--font-display);font-size:1.9rem;font-weight:800;line-height:1}
.doughnut-center span{font-size:.78rem;color:var(--muted)}
.legend{display:flex;flex-wrap:wrap;gap:.6rem 1rem;margin-top:1rem}
.legend .li{display:flex;align-items:center;gap:.45rem;font-size:.82rem;color:var(--ink-2)}
.legend .li i{width:11px;height:11px;border-radius:4px}

/* ---------------- Badges ---------------- */
.badge{display:inline-flex;align-items:center;gap:.35rem;font-weight:700;font-size:.75rem;padding:.28rem .65rem;border-radius:20px;font-family:var(--font);white-space:nowrap}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.badge.green{color:#0f9e63;background:var(--green-t)}
.badge.blue{color:#2b7fd6;background:var(--blue-t)}
.badge.amber{color:#c9760a;background:var(--amber-t)}
.badge.red{color:#e23e57;background:var(--red-t)}
.badge.violet{color:#6b45d6;background:var(--violet-t)}
.badge.gray{color:#6b7194;background:var(--surface-3)}

/* ---------------- Buttons ---------------- */
.btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:.5rem;border:1px solid transparent;border-radius:12px;padding:.7rem 1.15rem;font-family:var(--font);font-weight:700;font-size:.9rem;cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s}
.btn svg{width:18px;height:18px}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:0 10px 22px -10px rgba(109,94,252,.7)}
.btn-primary:hover{box-shadow:0 16px 30px -12px rgba(109,94,252,.8);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary-600)}
.btn-soft{background:var(--primary-tint);color:var(--primary-600)}
.btn-soft:hover{background:#e4e0ff}
.btn-sm{padding:.45rem .7rem;font-size:.82rem;border-radius:10px}
.ripple{position:absolute;border-radius:50%;transform:scale(0);background:rgba(255,255,255,.5);animation:ripple .6s var(--ease-soft);pointer-events:none}
.row-act{display:inline-flex;gap:.35rem}
.act{width:32px;height:32px;border-radius:9px;border:1px solid var(--border);background:#fff;color:var(--ink-2);display:grid;place-items:center;cursor:pointer;transition:.25s var(--ease)}
.act svg{width:16px;height:16px}
.act:hover{color:var(--primary-600);border-color:var(--primary);transform:translateY(-2px)}
.act.danger:hover{color:var(--red);border-color:var(--red)}

/* ---------------- Data table ---------------- */
.dt-toolbar{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-bottom:1rem}
.dt-search{position:relative;flex:1;min-width:200px;max-width:340px;display:flex;align-items:center}
.dt-search svg{position:absolute;inset-inline-start:.8rem;width:17px;height:17px;color:var(--muted)}
.dt-search input{width:100%;padding:.6rem .9rem;padding-inline-start:2.4rem;border-radius:11px;border:1px solid var(--border);background:var(--surface-2);font-family:inherit;font-size:.88rem;transition:.25s var(--ease-soft)}
.dt-search input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:var(--ring)}
.chips{display:flex;gap:.4rem;flex-wrap:wrap}
.chip{border:1px solid var(--border);background:#fff;color:var(--ink-2);border-radius:20px;padding:.4rem .85rem;font-size:.8rem;font-weight:600;cursor:pointer;transition:.25s var(--ease)}
.chip:hover{border-color:var(--primary);color:var(--primary-600)}
.chip.on{background:var(--grad-primary);color:#fff;border-color:transparent}
.dt-select{margin-inline-start:auto;display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.82rem}
.dt-select select{border:1px solid var(--border);background:#fff;border-radius:10px;padding:.45rem .7rem;font-family:inherit;font-size:.85rem;color:var(--ink);cursor:pointer}
.table-scroll{overflow-x:auto;border-radius:14px;border:1px solid var(--border)}
table.dt{width:100%;border-collapse:collapse;font-size:.9rem;min-width:640px}
table.dt thead th{
  text-align:start;font-family:var(--font-display);font-weight:700;font-size:.82rem;color:var(--ink-2);
  background:var(--surface-2);padding:.85rem 1rem;white-space:nowrap;border-bottom:1px solid var(--border);position:relative;user-select:none;
}
table.dt thead th.sortable{cursor:pointer;transition:color .2s}
table.dt thead th.sortable:hover{color:var(--primary-600)}
table.dt thead th.sortable::after{content:"⇅";font-size:.7rem;opacity:.4;margin-inline-start:.35rem}
table.dt thead th.asc::after{content:"↑";opacity:1;color:var(--primary-600)}
table.dt thead th.desc::after{content:"↓";opacity:1;color:var(--primary-600)}
table.dt tbody td{padding:.8rem 1rem;border-bottom:1px solid var(--border);color:var(--ink-2);white-space:nowrap}
table.dt tbody tr:last-child td{border-bottom:0}
table.dt tbody tr{transition:background .2s}
table.dt tbody tr:hover{background:var(--surface-2)}
.cell-main{display:flex;align-items:center;gap:.7rem}
.cell-main .thumb{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:#fff;flex:0 0 auto}
.cell-main b{color:var(--ink);font-weight:700;font-family:var(--font-display);font-size:.9rem}
.cell-main small{color:var(--muted);font-size:.75rem;display:block}
.money{font-family:var(--font-display);font-weight:700;color:var(--ink)}
.riyal{font-size:.72em;color:var(--muted);margin-inline-start:2px}
@keyframes dtRow{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.dt-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.8rem;margin-top:1rem}
.dt-info{font-size:.82rem;color:var(--muted)}
.dt-info b{color:var(--ink);font-family:var(--font-display)}
.pager{display:flex;align-items:center;gap:.3rem}
.pager button{min-width:36px;height:36px;padding:0 .5rem;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--ink-2);font-family:var(--font-display);font-weight:700;font-size:.85rem;cursor:pointer;transition:.2s var(--ease);display:grid;place-items:center}
.pager button:hover:not(:disabled){border-color:var(--primary);color:var(--primary-600)}
.pager button.on{background:var(--grad-primary);color:#fff;border-color:transparent;box-shadow:var(--shadow-sm)}
.pager button:disabled{opacity:.4;cursor:not-allowed}
.pager svg{width:16px;height:16px}
[dir="rtl"] .pager .chev{transform:scaleX(-1)}
.dt-empty{padding:3rem 1rem;text-align:center;color:var(--muted)}
.dt-empty svg{width:46px;height:46px;opacity:.5;margin-bottom:.6rem}

/* ---------------- Forms / Login ---------------- */
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.85rem;font-weight:600;color:var(--ink-2);margin-bottom:.4rem}
.input{position:relative;display:flex;align-items:center}
.input>svg{position:absolute;inset-inline-start:.9rem;width:19px;height:19px;color:var(--muted);transition:color .2s}
.input input{
  width:100%;padding:.85rem 1rem;padding-inline-start:2.8rem;border-radius:13px;border:1.5px solid var(--border-2);
  background:var(--surface-2);font-family:inherit;font-size:.95rem;color:var(--ink);transition:.25s var(--ease-soft);
}
.input input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:var(--ring)}
.input input:focus~svg,.input:focus-within>svg{color:var(--primary)}
.input .toggle-pw{position:absolute;inset-inline-end:.6rem;background:none;border:0;color:var(--muted);cursor:pointer;padding:.4rem;border-radius:8px}
.input .toggle-pw:hover{color:var(--primary-600)}
.form-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.2rem}
.check{display:flex;align-items:center;gap:.5rem;font-size:.86rem;color:var(--ink-2);cursor:pointer;user-select:none}
.check input{position:absolute;opacity:0}
.check .box{width:20px;height:20px;border-radius:7px;border:1.5px solid var(--border-2);display:grid;place-items:center;transition:.2s var(--ease);background:#fff}
.check .box svg{width:13px;height:13px;color:#fff;opacity:0;transform:scale(.5);transition:.2s var(--ease)}
.check input:checked+.box{background:var(--grad-primary);border-color:transparent}
.check input:checked+.box svg{opacity:1;transform:scale(1)}
.link{color:var(--primary-600);font-weight:700;font-size:.86rem}
.link:hover{text-decoration:underline}
.btn-block{width:100%;justify-content:center;padding:.9rem;font-size:.98rem}
.divider{display:flex;align-items:center;gap:.9rem;color:var(--muted);font-size:.8rem;margin:1.2rem 0}
.divider::before,.divider::after{content:"";height:1px;background:var(--border-2);flex:1}
.btn-nafath{width:100%;justify-content:center;background:#fff;border:1.5px solid var(--border-2);color:var(--ink);padding:.8rem;font-weight:700}
.btn-nafath:hover{border-color:var(--teal);color:var(--teal)}
.btn-nafath .n{width:22px;height:22px;border-radius:6px;background:var(--grad-teal);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:.7rem}

.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth-brand{
  position:relative;overflow:hidden;background:var(--grad-side);color:#fff;
  padding:clamp(2rem,5vw,4rem);display:flex;flex-direction:column;
}
.auth-brand::after{content:"";position:absolute;inset:0;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}
.blob{position:absolute;border-radius:50%;filter:blur(18px);opacity:.55;pointer-events:none;animation:float 12s var(--ease-soft) infinite}
.blob.b1{width:260px;height:260px;background:#ff5aa8;inset-block-start:-60px;inset-inline-end:-40px}
.blob.b2{width:220px;height:220px;background:#3aa0ff;inset-block-end:6%;inset-inline-start:-60px;animation-delay:-3s}
.blob.b3{width:170px;height:170px;background:#22c07d;inset-block-end:28%;inset-inline-end:12%;animation-delay:-6s}
.auth-brand .inner{position:relative;z-index:1;display:flex;flex-direction:column;height:100%}
.auth-brand .logo{width:54px;height:54px;border-radius:16px;background:rgba(255,255,255,.18);display:grid;place-items:center;box-shadow:inset 0 1px 1px rgba(255,255,255,.5);backdrop-filter:blur(6px)}
.auth-brand .logo svg{width:30px;height:30px}
.auth-brand h2{font-size:clamp(1.8rem,3.2vw,2.8rem);margin-top:auto;font-weight:800}
.auth-brand p{opacity:.85;max-width:40ch;margin-top:1rem;font-size:1rem}
.trust{display:flex;flex-direction:column;gap:.7rem;margin-top:2rem}
.trust .t{display:flex;align-items:center;gap:.7rem;font-size:.92rem}
.trust .t .tick{width:26px;height:26px;border-radius:8px;background:rgba(255,255,255,.18);display:grid;place-items:center}
.trust .t .tick svg{width:15px;height:15px}
.auth-form{display:flex;align-items:center;justify-content:center;padding:clamp(1.5rem,4vw,3rem);position:relative}
.auth-card{width:100%;max-width:420px;animation:fadeUp .7s var(--ease) both}
.auth-card .head{margin-bottom:1.6rem}
.auth-card .head .badge-ar{font-family:var(--font-display);color:var(--primary-600);font-weight:700;font-size:.85rem}
.auth-card .head h1{font-size:1.8rem;margin-top:.3rem}
.auth-card .head p{color:var(--ink-2);font-size:.92rem;margin-top:.3rem}
.auth-lang{position:absolute;inset-block-start:1.3rem;inset-inline-end:1.3rem}

/* ---------------- Reveal + keyframes ---------------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.06s}.reveal[data-d="2"]{transition-delay:.12s}
.reveal[data-d="3"]{transition-delay:.18s}.reveal[data-d="4"]{transition-delay:.24s}
.reveal[data-d="5"]{transition-delay:.3s}.reveal[data-d="6"]{transition-delay:.36s}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(18px,-22px) scale(1.08)}66%{transform:translate(-14px,14px) scale(.95)}}
@keyframes ripple{to{transform:scale(3);opacity:0}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------------- Overlay (mobile) ---------------- */
.scrim{position:fixed;inset:0;background:rgba(30,33,64,.45);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:.3s;z-index:55}
.scrim.show{opacity:1;visibility:visible}

/* ---------------- Responsive ---------------- */
@media (max-width:1100px){
  .c3{grid-column:span 6}.c4{grid-column:span 6}.c8{grid-column:span 12}.c7{grid-column:span 12}.c5{grid-column:span 12}.c6{grid-column:span 12}
}
@media (max-width:1024px){
  .sidebar{transform:translateX(100%);transition:transform .4s var(--ease-soft);box-shadow:var(--shadow-lg)}
  [dir="ltr"] .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-inline-start:0}
  .burger{display:flex}
}
@media (max-width:680px){
  .c3,.c4{grid-column:span 12}
  .auth{grid-template-columns:1fr}
  .auth-brand{display:none}
  .user .who{display:none}
  .searchbar{display:none}
  .page-head{align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
  .blob{animation:none}
}

/* ---------------- Theme toggle icon ---------------- */
.theme-toggle .i-sun{display:none}
[data-theme="dark"] .theme-toggle .i-moon{display:none}
[data-theme="dark"] .theme-toggle .i-sun{display:block}
.auth-theme{position:absolute;inset-block-start:1.3rem;inset-inline-end:4.7rem;z-index:2}

/* ---------------- Invoice detail ---------------- */
.invoice-paper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:clamp(1.4rem,3vw,2.6rem)}
.inv-top{display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;align-items:flex-start;border-bottom:2px solid var(--border);padding-bottom:1.3rem}
.inv-seller{display:flex;gap:.9rem;align-items:center}
.inv-seller .logo{width:52px;height:52px;border-radius:14px;background:var(--grad-primary);display:grid;place-items:center;color:#fff}
.inv-seller .logo svg{width:28px;height:28px}
.inv-seller b{font-family:var(--font-display);font-size:1.15rem}
.inv-seller small{color:var(--muted);font-size:.8rem;display:block}
.inv-title{font-family:var(--font-display);font-size:1.5rem;font-weight:800;text-align:end}
.inv-title small{display:block;color:var(--muted);font-size:.8rem;font-weight:500}
.inv-parties{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1.3rem 0}
.inv-box{background:var(--surface-2);border:1px solid var(--border);border-radius:14px;padding:1rem 1.1rem}
.inv-box h4{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.55rem}
.inv-box .r{display:flex;justify-content:space-between;gap:1rem;font-size:.85rem;padding:.18rem 0;color:var(--ink-2)}
.inv-box .r b{color:var(--ink);font-weight:700}
table.inv-items{width:100%;border-collapse:collapse;font-size:.9rem;margin-top:.4rem}
table.inv-items th{background:var(--surface-2);text-align:start;padding:.7rem .9rem;font-family:var(--font-display);font-size:.78rem;color:var(--ink-2);border-bottom:1px solid var(--border)}
table.inv-items td{padding:.75rem .9rem;border-bottom:1px solid var(--border);color:var(--ink-2)}
table.inv-items td b{color:var(--ink)}
.inv-totals{margin-top:1.2rem;margin-inline-start:auto;max-width:330px;display:flex;flex-direction:column;gap:.5rem}
.inv-totals .r{display:flex;justify-content:space-between;font-size:.9rem;color:var(--ink-2)}
.inv-totals .r b{color:var(--ink)}
.inv-totals .grand{border-top:2px dashed var(--border);margin-top:.4rem;padding-top:.7rem;font-family:var(--font-display);font-weight:800;font-size:1.2rem;color:var(--ink)}
.inv-foot{display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;align-items:center;margin-top:1.6rem;border-top:1px solid var(--border);padding-top:1.3rem}
.inv-foot .note{max-width:42ch;font-size:.82rem;color:var(--muted)}
.side-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.3rem;margin-bottom:1.1rem}
.side-card h3{font-size:1rem;margin-bottom:.9rem}
.qr-box{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.7rem}
.stack-btns{display:flex;flex-direction:column;gap:.6rem}
.stack-btns .btn{justify-content:center;width:100%}

/* ---------------- Dark mode ---------------- */
[data-theme="dark"]{
  --bg:#0d0f1e;--surface:#181b30;--surface-2:#1f2338;--surface-3:#272c48;
  --ink:#eef0fb;--ink-2:#aab0d4;--muted:#7b81a8;--border:#2a2f4f;--border-2:#343a63;
  --primary-tint:#241f4d;
  --blue-t:rgba(58,160,255,.16);--teal-t:rgba(18,179,166,.16);--green-t:rgba(34,192,125,.16);
  --amber-t:rgba(255,159,46,.16);--red-t:rgba(255,93,115,.16);--violet-t:rgba(139,92,246,.2);
  --shadow-sm:0 2px 8px -3px rgba(0,0,0,.5);
  --shadow:0 14px 34px -16px rgba(0,0,0,.6),0 4px 12px -8px rgba(0,0,0,.5);
  --shadow-lg:0 34px 70px -30px rgba(0,0,0,.75);
  --ring:0 0 0 4px rgba(109,94,252,.3);
}
[data-theme="dark"] .topbar{background:rgba(18,21,40,.82)}
[data-theme="dark"] .icon-btn,[data-theme="dark"] .lang-toggle,[data-theme="dark"] .user,
[data-theme="dark"] .chip,[data-theme="dark"] .pager button,[data-theme="dark"] .act,
[data-theme="dark"] .btn-ghost,[data-theme="dark"] .dt-select select,[data-theme="dark"] .burger,
[data-theme="dark"] .check .box{background:var(--surface)}
[data-theme="dark"] .seg button.on{background:var(--surface-3)}
[data-theme="dark"] .btn-soft{color:#b9adff}
[data-theme="dark"] .link,[data-theme="dark"] .crumb b{color:#b9adff}
[data-theme="dark"] .badge.green,[data-theme="dark"] .trend.up{color:#43e0a5}
[data-theme="dark"] .badge.blue{color:#6cc0ff}
[data-theme="dark"] .badge.amber{color:#ffc06b}
[data-theme="dark"] .badge.red,[data-theme="dark"] .trend.down{color:#ff8a9c}
[data-theme="dark"] .badge.violet{color:#b79bff}
[data-theme="dark"] .badge.gray{color:#aab0d4}
[data-theme="dark"] .burger span{background:var(--ink)}

/* ---------------- Settings ---------------- */
.settings-grid{display:grid;grid-template-columns:242px 1fr;gap:1.3rem;align-items:start}
.settings-nav{position:sticky;top:88px;display:flex;flex-direction:column;gap:.15rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:.55rem}
.settings-nav a{display:flex;align-items:center;gap:.65rem;padding:.65rem .8rem;border-radius:12px;font-size:.88rem;font-weight:600;color:var(--ink-2);transition:.2s var(--ease)}
.settings-nav a svg{width:18px;height:18px;opacity:.85;flex:0 0 auto}
.settings-nav a:hover{background:var(--surface-2);color:var(--primary-600)}
.settings-nav a.on{background:var(--primary-tint);color:var(--primary-600)}
.set-sections{display:flex;flex-direction:column;gap:1.2rem;min-width:0}
.set-card{scroll-margin-top:88px}
.set-card .panel-head{border-bottom:1px solid var(--border);padding-bottom:.9rem;margin-bottom:1.2rem}
.set-card .panel-head .ic-sq{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;color:#fff;flex:0 0 auto}
.set-card .panel-head .ic-sq svg{width:21px;height:21px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 1.1rem}
.form-grid .c-full{grid-column:1/-1}
.ctrl{width:100%;padding:.75rem .9rem;border-radius:12px;border:1.5px solid var(--border-2);background:var(--surface-2);font-family:inherit;font-size:.92rem;color:var(--ink);transition:.25s var(--ease-soft)}
.ctrl::placeholder{color:var(--muted)}
.ctrl:focus{outline:none;border-color:var(--primary);background:var(--surface);box-shadow:var(--ring)}
select.ctrl{cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%239aa0c2' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left .9rem center;padding-inline-start:.9rem;padding-inline-end:2.4rem}
[dir="ltr"] select.ctrl{background-position:right .9rem center}
textarea.ctrl{resize:vertical;min-height:82px;line-height:1.6}
.field .hint{font-size:.76rem;color:var(--muted);margin-top:.35rem}
.input-group{display:flex;align-items:stretch}
.input-group .ctrl{border-start-end-radius:0;border-end-end-radius:0}
.input-group .suffix{display:grid;place-items:center;padding:0 1rem;border:1.5px solid var(--border-2);border-inline-start:0;border-start-end-radius:12px;border-end-end-radius:12px;background:var(--surface-3);color:var(--ink-2);font-weight:700;font-family:var(--font-display);white-space:nowrap}
.switch-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 0;border-bottom:1px solid var(--border)}
.switch-row:last-child{border-bottom:0}
.switch-row .txt b{display:block;font-size:.9rem;color:var(--ink);font-weight:700}
.switch-row .txt span{font-size:.78rem;color:var(--muted)}
.switch{position:relative;width:46px;height:26px;flex:0 0 auto}
.switch input{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:pointer;z-index:1}
.switch .track{position:absolute;inset:0;background:var(--border-2);border-radius:20px;transition:.25s var(--ease)}
.switch .track::before{content:"";position:absolute;top:3px;inset-inline-start:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:.25s var(--ease)}
.switch input:checked+.track{background:var(--grad-primary)}
.switch input:checked+.track::before{inset-inline-start:23px}
.logo-up{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap}
.logo-up .prev{width:66px;height:66px;border-radius:16px;background:var(--grad-primary);display:grid;place-items:center;color:#fff;flex:0 0 auto;box-shadow:var(--shadow-sm)}
.logo-up .prev svg{width:34px;height:34px}
.save-bar{position:sticky;bottom:1rem;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:1.3rem;padding:.85rem 1.15rem;background:rgba(255,255,255,.85);backdrop-filter:blur(12px) saturate(150%);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.save-bar .st{display:flex;align-items:center;gap:.5rem;font-size:.83rem;color:var(--ink-2)}
.save-bar .st .dotk{width:9px;height:9px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 4px var(--amber-t)}
[data-theme="dark"] .save-bar{background:rgba(18,21,40,.85)}
[data-theme="dark"] .ctrl,[data-theme="dark"] select.ctrl{background-color:var(--surface-2)}
@media (max-width:900px){
  .settings-grid{grid-template-columns:1fr}
  .settings-nav{position:static;flex-direction:row;flex-wrap:nowrap;overflow-x:auto}
  .settings-nav a{white-space:nowrap}
  .form-grid{grid-template-columns:1fr}
}

/* ---------------- Reports ---------------- */
.rep-filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1rem 1.1rem;margin-bottom:.9rem}
.rf-group{display:flex;flex-direction:column;gap:.4rem;min-width:160px}
.rf-group>label{font-size:.78rem;font-weight:700;color:var(--ink-2)}
.rf-dates{display:flex;gap:.5rem;align-items:center;color:var(--muted)}
.rf-dates .ctrl{min-width:140px}
.rf-actions{margin-inline-start:auto;display:flex;gap:.6rem;align-self:flex-end}
.rep-range{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.86rem;color:var(--ink-2);margin:0 0 1.1rem}
.rep-range b{font-family:var(--font-display);color:var(--ink)}
.rep-range .pill{background:var(--primary-tint);color:var(--primary-600);border-radius:20px;padding:.15rem .65rem;font-weight:700;font-size:.76rem}
@media (max-width:680px){.rf-group{min-width:100%}.rf-actions{margin-inline-start:0;width:100%}.rf-actions .btn{flex:1;justify-content:center}}
.rep-list{display:flex;flex-direction:column;gap:1.05rem}
.rep-list .row{display:grid;grid-template-columns:1.4rem 1fr auto;grid-template-areas:"rk nm vl" "bar bar bar";gap:.3rem .7rem;align-items:center}
.rep-list .row .rk{grid-area:rk;font-family:var(--font-display);font-weight:700;color:var(--muted);font-size:.85rem}
.rep-list .row .nm{grid-area:nm;font-weight:700;color:var(--ink);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rep-list .row .vl{grid-area:vl;font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:.9rem}
.rep-list .row .vl small{color:var(--muted);font-weight:500;font-size:.72em;margin-inline-start:2px}
.rep-bar{grid-area:bar;height:8px;border-radius:20px;background:var(--surface-3);overflow:hidden}
.rep-bar i{display:block;height:100%;border-radius:20px;background:var(--grad-primary);animation:repGrow 1s var(--ease) both}
@keyframes repGrow{from{width:0!important}}

/* ---------------- Toast notifications ---------------- */
.toast-container{position:fixed;inset-block-end:1.5rem;inset-inline-end:1.5rem;z-index:999;display:flex;flex-direction:column;gap:.6rem;max-width:380px;width:100%;pointer-events:none}
.toast{pointer-events:auto;display:flex;align-items:center;gap:.85rem;padding:1rem 1.15rem;border-radius:var(--radius);background:var(--ink);color:#fff;box-shadow:var(--shadow-lg);transform:translateX(0);animation:toastIn .45s var(--ease) both;cursor:pointer;transition:transform .3s var(--ease),opacity .3s}
.toast.removing{transform:translateX(30px);opacity:0}
[dir="ltr"] .toast{animation:toastInLtr .45s var(--ease) both}
[dir="ltr"] .toast.removing{transform:translateX(-30px)}
.toast svg{width:22px;height:22px;flex:0 0 auto}
.toast .tx{flex:1;min-width:0}
.toast .tx b{display:block;font-size:.88rem}
.toast .tx span{display:block;font-size:.78rem;opacity:.8;margin-top:.1rem}
.toast .close{width:24px;height:24px;border-radius:8px;border:0;background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;cursor:pointer;flex:0 0 auto;transition:background .2s}
.toast .close svg{width:14px;height:14px}
.toast .close:hover{background:rgba(255,255,255,.22)}
.toast.success svg{color:var(--green)}
.toast.error svg{color:var(--red)}
.toast.warning svg{color:var(--amber)}
.toast.info svg{color:var(--blue)}
@keyframes toastIn{from{transform:translateX(40px);opacity:0}to{transform:none;opacity:1}}
@keyframes toastInLtr{from{transform:translateX(-40px);opacity:0}to{transform:none;opacity:1}}

/* ---------------- Dropdown ---------------- */
.dropdown{position:relative;display:inline-block}
.dropdown-menu{position:absolute;inset-block-start:calc(100% + 6px);inset-inline-end:0;min-width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:80;opacity:0;visibility:hidden;transform:translateY(-8px) scale(.96);transition:opacity .25s var(--ease-soft),visibility .25s,transform .25s var(--ease-soft);transform-origin:top end;padding:.45rem}
.dropdown-menu.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.dropdown-menu .dd-head{padding:.6rem .65rem .8rem;border-bottom:1px solid var(--border);margin-bottom:.35rem}
.dropdown-menu .dd-head b{display:block;font-size:.88rem}
.dropdown-menu .dd-head span{font-size:.75rem;color:var(--muted)}
.dropdown-menu .dd-item{display:flex;align-items:center;gap:.7rem;padding:.6rem .65rem;border-radius:10px;font-size:.85rem;color:var(--ink-2);font-weight:500;cursor:pointer;transition:background .2s,color .2s}
.dropdown-menu .dd-item:hover{background:var(--surface-2);color:var(--primary-600)}
.dropdown-menu .dd-item svg{width:18px;height:18px;flex:0 0 auto;opacity:.8}
.dropdown-menu .dd-item.danger:hover{color:var(--red)}
.dropdown-menu .dd-divider{height:1px;background:var(--border);margin:.25rem 0}
.dropdown-menu .dd-noti{display:flex;align-items:flex-start;gap:.7rem;padding:.6rem .65rem;border-radius:10px;cursor:pointer;transition:background .2s}
.dropdown-menu .dd-noti:hover{background:var(--surface-2)}
.dropdown-menu .dd-noti .doti{width:8px;height:8px;border-radius:50%;margin-top:5px;flex:0 0 auto}
.dropdown-menu .dd-noti .doti.blue{background:var(--blue)}
.dropdown-menu .dd-noti .doti.amber{background:var(--amber)}
.dropdown-menu .dd-noti .doti.green{background:var(--green)}
.dropdown-menu .dd-noti .txn b{display:block;font-size:.82rem;color:var(--ink);font-weight:700}
.dropdown-menu .dd-noti .txn span{font-size:.73rem;color:var(--muted)}
[data-theme="dark"] .dropdown-menu{background:var(--surface-2);border-color:var(--border-2)}

/* ---------------- Skeleton / loading ---------------- */
.skel{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:skel 1.6s var(--ease-soft) infinite;border-radius:8px;color:transparent!important;user-select:none;pointer-events:none}
.skel.inline{display:inline-block;width:80px;height:1em;vertical-align:middle}
.skel.block{display:block;width:100%;height:14px;margin-bottom:.5rem}
.skel.block:last-child{width:60%;margin-bottom:0}
.skel.h2{height:24px;width:40%;margin-bottom:.6rem}
.skel.h3{height:18px;width:30%;margin-bottom:.4rem}
.skel.p{height:80px;width:100%;margin-bottom:.6rem}
.skel.thumb{width:38px;height:38px;border-radius:10px}
@keyframes skel{from{background-position:200% 0}to{background-position:-200% 0}}

/* ---------------- Validation ---------------- */
.input.error input{border-color:var(--red);box-shadow:0 0 0 3px rgba(255,93,115,.16)}
.input.success input{border-color:var(--green);box-shadow:0 0 0 3px rgba(34,192,125,.16)}
.input .msg{position:absolute;inset-block-end:-1.2rem;inset-inline-start:0;font-size:.74rem;font-weight:600;opacity:0;transition:opacity .2s;pointer-events:none}
.input .msg.show{opacity:1}
.input.error .msg{color:var(--red)}
.input.success .msg{color:var(--green)}
.field .msg-global{font-size:.78rem;font-weight:600;margin-top:.35rem;display:flex;align-items:center;gap:.35rem}
.field .msg-global.error{color:var(--red)}
.field .msg-global.success{color:var(--green)}

/* ---------------- Tooltip ---------------- */
[data-tip]{position:relative}
[data-tip]::after{content:attr(data-tip);position:absolute;z-index:90;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%) scale(.92);background:var(--ink);color:#fff;font-size:.73rem;font-weight:600;padding:.3rem .65rem;border-radius:8px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s var(--ease-soft),transform .2s var(--ease-soft);box-shadow:var(--shadow)}
[data-tip]:hover::after{opacity:1;transform:translateX(-50%) scale(1)}
[data-tip]:active::after{opacity:0}

/* ---------------- Pulse dot ---------------- */
.dot.pulse{animation:pulse 2s var(--ease-soft) infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ---------------- Page transition ---------------- */
.page-enter{animation:pageIn .55s var(--ease) both}
@keyframes pageIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ---------------- Progress bar ---------------- */
.progress{height:8px;border-radius:20px;background:var(--surface-3);overflow:hidden}
.progress i{display:block;height:100%;border-radius:20px;background:var(--grad-primary);transition:width .8s var(--ease)}
.progress i.green{background:var(--grad-teal)}
.progress i.amber{background:var(--grad-amber)}

/* ---------------- Empty state (enhanced) ---------------- */
.dt-empty{padding:3rem 1rem;text-align:center;color:var(--muted)}
.dt-empty svg{width:54px;height:54px;opacity:.4;margin-bottom:.7rem}
.dt-empty b{display:block;font-family:var(--font-display);color:var(--ink-2);font-size:1rem;margin-bottom:.3rem}
.dt-empty span{font-size:.85rem;display:block}

/* ---------------- Noti counter badge animation ---------------- */
.sb-link .cnt.pop{animation:cntPop .4s var(--ease)}
@keyframes cntPop{0%{transform:scale(1)}50%{transform:scale(1.25)}100%{transform:scale(1)}}
.rep-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.rep-card{display:flex;gap:.85rem;align-items:center;padding:1rem;border:1px solid var(--border);border-radius:16px;background:var(--surface-2);transition:.25s var(--ease);cursor:pointer;text-align:start}
.rep-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.rep-card .ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;color:#fff;flex:0 0 auto;box-shadow:var(--shadow-sm)}
.rep-card .ic svg{width:22px;height:22px}
.rep-card .tx{min-width:0}
.rep-card .tx b{display:block;font-size:.92rem;color:var(--ink);font-weight:700}
.rep-card .tx small{color:var(--muted);font-size:.78rem}
.rep-card .dl{margin-inline-start:auto;color:var(--muted);flex:0 0 auto;transition:.25s var(--ease)}
.rep-card:hover .dl{color:var(--primary-600)}
.rep-card .dl svg{width:19px;height:19px;display:block}
@media (max-width:900px){.rep-cards{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.rep-cards{grid-template-columns:1fr}}

/* ---------------- Expiring contracts (dashboard) ---------------- */
.exp-list{display:flex;flex-direction:column}
.exp-row{display:flex;align-items:center;gap:.85rem;padding:.8rem 0;border-bottom:1px solid var(--border)}
.exp-row:last-child{border-bottom:0}
.exp-row .ic{width:40px;height:40px;border-radius:11px;background:var(--surface-2);color:var(--primary-600);display:grid;place-items:center;flex:0 0 auto}
.exp-row .ic svg{width:20px;height:20px}
.exp-row .mn{min-width:0;flex:1}
.exp-row .mn b{display:block;color:var(--ink);font-size:.9rem;font-family:var(--font-display);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.exp-row .mn small{color:var(--muted);font-size:.77rem}
.exp-row .rt{display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;flex:0 0 auto;text-align:end}

/* ---------------- Print (invoice) ---------------- */
@media print{
  .sidebar,.topbar,.scrim,.inv-side,.no-print,.page-head .btn{display:none!important}
  .main{margin:0!important}
  body{background:#fff!important}
  .content{padding:0!important}
  .invoice-paper{box-shadow:none!important;border:0!important}
  .grid{display:block!important}
}
