/* =========================================================
   inzopay — Shared Design System
   Used by every page. Import BEFORE page-specific styles.
   ========================================================= */

:root {
  /* colors — light */
  --bg: #fafaf7;
  --surface: #ffffff;
  --surface-2: #f5f4ee;
  --ink-900: #0b1020;
  --ink-700: #2a2f45;
  --ink-500: #5b6175;
  --ink-400: #858aa0;
  --ink-300: #b6bacb;
  --line: #e7e6df;
  --line-strong: #d6d4c8;
  --primary: #10B981;
  --primary-ink: #ffffff;
  --primary-tint: color-mix(in oklab, var(--primary) 8%, var(--bg));
  --primary-edge: color-mix(in oklab, var(--primary) 20%, transparent);
  --green: oklch(0.72 0.14 160);
  --amber: oklch(0.78 0.13 75);
  --red: #c25a4a;
  /* typography */
  --font-en: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-ar: 'IBM Plex Sans Arabic', 'Inter', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  /* radii */
  --r-sm: 6px; --r: 10px; --r-lg: 14px; --r-xl: 20px;
  /* shadows */
  --sh-sm: 0 1px 0 rgba(12,16,32,.04), 0 1px 2px rgba(12,16,32,.04);
  --sh-md: 0 1px 2px rgba(12,16,32,.06), 0 8px 24px -8px rgba(12,16,32,.12);
  --sh-lg: 0 2px 4px rgba(12,16,32,.06), 0 24px 48px -12px rgba(12,16,32,.18);
}
/*
[data-theme="dark"] {
  --bg: #0a0b10;
  --surface: #111319;
  --surface-2: #15171f;
  --ink-900: #f5f6fa;
  --ink-700: #d6d9e4;
  --ink-500: #8f94a8;
  --ink-400: #6a6f84;
  --ink-300: #3e4256;
  --line: #1d2030;
  --line-strong: #2a2e42;
  --primary-tint: color-mix(in oklab, var(--primary) 18%, #0a0b10);
  --sh-sm: 0 1px 0 rgba(0,0,0,.4);
  --sh-md: 0 1px 2px rgba(0,0,0,.5), 0 8px 24px -8px rgba(0,0,0,.6);
  --sh-lg: 0 2px 4px rgba(0,0,0,.5), 0 24px 48px -12px rgba(0,0,0,.7);
}
*/
[data-theme="dark"] {
  --bg: #3a4550;
  --surface: #2a343e;
  --surface-2: #2a343e;
  --ink-900: #f5f6fa;
  --ink-700: #d6d9e4;
  --ink-500: #8f94a8;
  --ink-400: #6a6f84;
  --ink-300: #3e4256;
  --line: #1d2030;
  --line-strong: #2a2e42;
  --primary-tint: color-mix(in oklab, var(--primary) 18%, #0a0b10);
  --sh-sm: 0 1px 0 rgba(0,0,0,.4);
  --sh-md: 0 1px 2px rgba(0,0,0,.5), 0 8px 24px -8px rgba(0,0,0,.6);
  --sh-lg: 0 2px 4px rgba(0,0,0,.5), 0 24px 48px -12px rgba(0,0,0,.7);
}
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--primary);}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg); color: var(--ink-900);
  font-family: var(--font-ar); font-size: 15px; line-height: 1.55;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  min-height: 100vh;
}
html[lang="en"] body { font-family: var(--font-en); }

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
input, select, textarea { font: inherit; color: inherit; }
code, pre, .mono { font-family: var(--font-mono); }
.wrap { max-width: 1240px; margin: 0 auto; padding: 0 28px; }
.wrap-sm { max-width: 480px; margin: 0 auto; padding: 0 20px; }
.wrap-md { max-width: 860px; margin: 0 auto; padding: 0 24px; }

/* ———— Topbar ———— */
.top { position: sticky; top: 0; z-index: 50;
  backdrop-filter: saturate(180%) blur(10px);
  background: color-mix(in oklab, var(--bg) 82%, transparent);
  border-bottom: 1px solid var(--line);
}
.top-inner { display: flex; align-items: center; gap: 22px; height: 62px; }
.logo { display: flex; align-items: center; gap: 8px; font-weight: 700; letter-spacing: -0.01em;
  font-family: var(--font-en); font-size: 17px; color: var(--ink-900); }
.logo-mark { width: 24px; height: 24px; border-radius: 6px; background: var(--primary);
  display: grid; place-items: center; position: relative;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--primary) 55%, #000 35%); }
.logo-mark::after { content: ""; width: 9px; height: 9px; border-radius: 3px;
  background: var(--primary-ink); transform: rotate(45deg);
  box-shadow: 0 0 0 2px var(--primary); }
nav.primary { display: flex; gap: 2px; margin-inline-start: 10px; }
nav.primary a { padding: 7px 12px; border-radius: 8px; color: var(--ink-700);
  font-size: 14px; font-weight: 500; }
nav.primary a:hover, nav.primary a.active { background: var(--line); color: var(--ink-900); }
.top-spacer { flex: 1; }
.pill-btn { display: inline-flex; align-items: center; gap: 6px; padding: 7px 10px;
  border: 1px solid var(--line); border-radius: 8px; background: var(--surface);
  color: var(--ink-700); font-size: 13px; font-weight: 500; }
.pill-btn:hover { border-color: var(--line-strong); }

/* ———— Buttons ———— */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 9px 14px; border-radius: 9px; font-size: 14px; font-weight: 600;
  letter-spacing: -0.005em; transition: transform .12s, background .12s, box-shadow .15s, border-color .12s;
  border: 1px solid transparent; cursor: pointer; white-space: nowrap; }
.btn-primary { background: var(--primary); color: var(--primary-ink);
  box-shadow: var(--sh-sm), inset 0 0 0 1px color-mix(in oklab, var(--primary) 60%, #000 30%); }
.btn-primary:hover { box-shadow: var(--sh-md); transform: translateY(-1px); }
.btn-primary:disabled { opacity: .6; cursor: not-allowed; transform: none; }
.btn-outline { border-color: var(--line-strong); color: var(--ink-900); background: var(--surface); }
.btn-outline:hover { background: var(--line); }
.btn-ghost { color: var(--ink-700); }
.btn-ghost:hover { background: var(--line); }
.btn-dark { background: var(--ink-900); color: var(--bg); }
.btn-sm { padding: 6px 10px; font-size: 13px; border-radius: 7px; }
.btn-lg { padding: 12px 18px; font-size: 15px; }
.btn-block { display: flex; width: 100%; }

/* ———— Inputs ———— */
.field { display: block; margin-bottom: 14px; }
.field label { display: block; font-size: 12.5px; color: var(--ink-500);
  font-weight: 500; margin-bottom: 6px; letter-spacing: .01em; }
.input, select.input, textarea.input {
  width: 100%; padding: 10px 12px; background: var(--surface);
  border: 1px solid var(--line-strong); border-radius: 9px; font-size: 14px; color: var(--ink-900);
  outline: none; transition: border-color .15s, box-shadow .15s;
}
.input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-tint); }
.input::placeholder { color: var(--ink-400); }
.input.mono { font-family: var(--font-mono); font-size: 13px; }
.input.error { border-color: var(--red); }
.input-group { display: flex; gap: 8px; }
.input-prefix { display: inline-flex; align-items: center; padding: 0 12px; background: var(--surface-2);
  border: 1px solid var(--line-strong); border-radius: 9px; font-size: 13px; color: var(--ink-500); }

/* checkbox */
.check { display: inline-flex; gap: 8px; align-items: center; font-size: 13.5px; color: var(--ink-700); cursor: pointer; }
.check input { width: 16px; height: 16px; accent-color: var(--primary); }

/* ———— Cards ———— */
.card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 20px; }
.card-sm { padding: 16px; border-radius: var(--r); }
.card h3, .card h4 { margin: 0 0 6px; }

/* ———— Badges / pills ———— */
.badge { display: inline-flex; align-items: center; gap: 6px; padding: 2px 8px; border-radius: 999px;
  font-size: 11.5px; font-weight: 500; font-family: var(--font-en); }
.badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.badge.g { background: color-mix(in oklab, var(--green) 18%, transparent); color: color-mix(in oklab, var(--green) 50%, var(--ink-900)); }
.badge.a { background: color-mix(in oklab, var(--amber) 22%, transparent); color: color-mix(in oklab, var(--amber) 45%, var(--ink-900)); }
.badge.r { background: color-mix(in oklab, var(--red) 18%, transparent); color: var(--red); }
.badge.b { background: var(--primary-tint); color: var(--primary); }
.badge.n { background: var(--line); color: var(--ink-700); }

/* ———— Sidebar / App shell ———— */
.app { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh; }
.side { border-inline-end: 1px solid var(--line); background: var(--surface);
  padding: 18px 14px; position: sticky; top: 0; align-self: start; height: 100vh; overflow-y: auto; }
.side .logo { padding: 4px 6px; margin-bottom: 20px; }
.side .group { margin-bottom: 16px; }
.side h6 { margin: 10px 6px 6px; font-size: 11px; font-weight: 600; color: var(--ink-400);
  letter-spacing: .08em; text-transform: uppercase; }
.side a.nav { display: flex; align-items: center; gap: 10px; padding: 8px 10px;
  border-radius: 8px; font-size: 13.5px; color: var(--ink-700); font-weight: 500; }
.side a.nav:hover { background: var(--line); color: var(--ink-900); }
.side a.nav.active { background: var(--primary-tint); color: var(--primary); }
.side a.nav svg { width: 16px; height: 16px; flex: 0 0 auto; stroke: currentColor; }
.side a.nav .chip { margin-inline-start: auto; background: var(--surface-2); border: 1px solid var(--line);
  font-size: 10.5px; padding: 1px 6px; border-radius: 4px; color: var(--ink-500); font-family: var(--font-mono); }
.side .foot { position: sticky; bottom: 0; background: var(--surface);
  border-top: 1px solid var(--line); margin: 20px -14px -18px; padding: 12px 14px; }
.side .foot .user { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.side .foot .ava { width: 30px; height: 30px; border-radius: 50%; background: var(--primary);
  color: var(--primary-ink); display: grid; place-items: center; font-weight: 700; font-size: 13px; }

.main { padding: 0 0 56px; min-width: 0; }
.page-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 14px; margin-bottom: 22px; }
.page-head h1 { margin: 0; font-size: 26px; letter-spacing: -0.02em; }
.page-head .sub { color: var(--ink-500); font-size: 14px; margin-top: 4px; }
.page-actions { display: flex; gap: 10px; }

/* ———— Tables ———— */
.table { border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; background: var(--surface); }
.table .row { display: grid; padding: 12px 16px; font-size: 13.5px; border-bottom: 1px solid var(--line); align-items: center; }
.table .row:last-child { border-bottom: 0; }
.table .row.head { background: var(--surface-2); color: var(--ink-500); font-size: 11.5px; letter-spacing: .06em; text-transform: uppercase; font-weight: 600; }
.table .row:not(.head):hover { background: var(--surface-2); }
.mono-sm { font-family: var(--font-mono); font-size: 12px; }
.muted { color: var(--ink-500); }
.dim { color: var(--ink-400); }

/* ———— KPI ———— */
.kpis { display: grid; gap: 12px; grid-template-columns: repeat(4, 1fr); margin-bottom: 18px; }
.kpi { padding: 14px 16px; border: 1px solid var(--line); border-radius: var(--r); background: var(--surface); }
.kpi .l { font-size: 11.5px; color: var(--ink-500); letter-spacing: .04em; text-transform: uppercase; }
.kpi .v { font-size: 24px; font-weight: 700; letter-spacing: -.02em; margin: 2px 0 4px; font-family: var(--font-en); }
.kpi .d { font-size: 11.5px; color: var(--green); font-family: var(--font-en); }
.kpi .d.neg { color: var(--red); }

/* ———— Empty ———— */
.empty { padding: 32px; border: 1px dashed var(--line-strong); border-radius: var(--r-lg);
  text-align: center; color: var(--ink-500); background: var(--surface); }
.empty h4 { margin: 0 0 4px; color: var(--ink-900); font-size: 16px; }
.empty p { margin: 0 0 14px; font-size: 13.5px; }

/* ———— Placeholder ———— */
.ph {
  background: repeating-linear-gradient(135deg, transparent 0 6px, color-mix(in oklab, var(--ink-400) 12%, transparent) 6px 7px), var(--surface-2);
  border: 1px solid var(--line); border-radius: var(--r);
  display: grid; place-items: center; color: var(--ink-400);
  font-family: var(--font-mono); font-size: 11px;
}

/* ———— RTL ———— */
html[dir="rtl"] .flip-rtl { transform: scaleX(-1); }

/* ———— Utilities ———— */
.hidden { display: none !important; }

/* ———— Password toggle ———— */
.input-wrap { position: relative; }
.input-wrap .input { padding-inline-end: 42px; width: 100%; }
.input-eye { position: absolute; inset-inline-end: 12px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; color: var(--ink-400); padding: 0;
  display: flex; align-items: center; }
.input-eye:hover { color: var(--ink-700); }

/* ———— Form feedback ———— */
.field-error { color: var(--red); font-size: 12px; margin-top: 4px; display: none; }
.alert-error { background: color-mix(in oklab, var(--red) 10%, var(--bg));
  border: 1px solid color-mix(in oklab, var(--red) 30%, transparent);
  color: var(--red); padding: 10px 14px; border-radius: 9px;
  font-size: 13.5px; margin-bottom: 14px; display: none; }
.alert-success { background: color-mix(in oklab, var(--green) 10%, var(--bg));
  border: 1px solid color-mix(in oklab, var(--green) 30%, transparent);
  color: color-mix(in oklab, var(--green) 60%, var(--ink-900));
  padding: 10px 14px; border-radius: 9px; font-size: 13.5px; display: none; }

/* ———— Card head ———— */
.card-head { margin: 0; padding: 16px 20px;
  border-bottom: 1px solid var(--line); }
.card-head h3 { margin: 0; font-size: 15px; font-weight: 700; }

/* ———— Input prefix / readonly ———— */
.input-prefix-wrap { display: flex; align-items: stretch; }
.input-prefix { display: inline-flex; align-items: center; padding: 0 12px;
  background: var(--surface-2); border: 1px solid var(--line);
  border-inline-end: 0; border-radius: 9px 0 0 9px;
  font-size: 13px; color: var(--ink-500); white-space: nowrap; flex: 0 0 auto; }
[dir="rtl"] .input-prefix { border-radius: 0 9px 9px 0;
  border-inline-end: 1px solid var(--line); border-inline-start: 0; }
.input-prefixed { border-radius: 0 9px 9px 0 !important; flex: 1; }
[dir="rtl"] .input-prefixed { border-radius: 9px 0 0 9px !important; }
.input-readonly { background: var(--surface-2) !important;
  color: var(--ink-500) !important; cursor: not-allowed; }

/* ———— Toast Notification ———— */
.toast { position:fixed; bottom:24px; inset-inline-end:24px; z-index:999;
  padding:12px 18px; border-radius:var(--r); font-size:14px; font-weight:500;
  box-shadow:var(--sh-lg); pointer-events:none;
  opacity:0; transform:translateY(8px); transition:opacity .2s, transform .2s; }
.toast.toast-show { opacity:1; transform:translateY(0); }
.toast.toast-success { background:color-mix(in oklab, var(--green) 15%, var(--surface));
  border:1px solid color-mix(in oklab, var(--green) 30%, transparent);
  color:color-mix(in oklab, var(--green) 60%, var(--ink-900)); }
.toast.toast-error { background:color-mix(in oklab, var(--red) 10%, var(--surface));
  border:1px solid color-mix(in oklab, var(--red) 30%, transparent); color:var(--red); }
.toast.toast-warn { background:color-mix(in oklab, var(--amber) 15%, var(--surface));
  border:1px solid color-mix(in oklab, var(--amber) 35%, transparent);
  color:color-mix(in oklab, var(--amber) 55%, var(--ink-900)); }

/* ———— Mobile ———— */
@media (max-width: 900px) {
  .app { grid-template-columns: 1fr; }
  .side { display: none; }
  .kpis { grid-template-columns: repeat(2, 1fr); }
  nav.primary { display: none; }
}
