/* Pippa Employee Portal — RTL base styles.
 * RULES (PLAN §6.1): CSS LOGICAL PROPERTIES ONLY — never physical left/right
 * or margin-left/right. Use margin-inline / padding-inline / inset-inline /
 * border-inline / text-align:start|end. Self-hosted Vazirmatn (no Google Fonts).
 */

/* ── Self-hosted Vazirmatn (woff2 in /static/fonts) ──────────────────── */
@font-face {
  font-family: "Vazirmatn";
  src: url("/static/fonts/Vazirmatn-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Vazirmatn";
  src: url("/static/fonts/Vazirmatn-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg: #f4f5f7;
  --surface: #ffffff;
  --ink: #1f2430;
  --muted: #6b7280;
  --primary: #0f6cbd;     /* Microsoft/Teams-ish blue */
  --primary-ink: #ffffff;
  --secondary: #374151;
  --border: #e1e4e8;
  --danger-bg: #fde8e8;
  --danger-ink: #9b1c1c;
  --warn-bg: #fef3c7;
  --warn-ink: #92400e;
  --radius: 12px;
  /* System sans fallback so layout is correct even before the woff2 is dropped in. */
  --font: "Vazirmatn", "Segoe UI", Tahoma, system-ui, "Noto Sans Arabic", sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font);
  line-height: 1.7;
}

/* ── Layout ──────────────────────────────────────────────────────────── */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 0.75rem;
  padding-inline: 1.25rem;
  background: var(--surface);
  border-block-end: 1px solid var(--border);
}
.brand { font-weight: 700; font-size: 1.1rem; }
.topnav { display: flex; align-items: center; gap: 0.75rem; }
.user { color: var(--muted); }

.container {
  max-inline-size: 880px;
  margin-inline: auto;
  padding-inline: 1rem;
  padding-block: 1.5rem;
}

.footer {
  text-align: center;
  color: var(--muted);
  padding-block: 1.5rem;
  font-size: 0.9rem;
}

/* ── Cards ───────────────────────────────────────────────────────────── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem;
  margin-block-end: 1rem;
}
.login-card { max-inline-size: 420px; margin-inline: auto; }
.card-title { margin-block-start: 0; font-size: 1.4rem; }
.section-title { font-size: 1.1rem; margin-block-start: 1.5rem; }

/* ── Forms (RTL, logical props) ──────────────────────────────────────── */
.form { display: flex; flex-direction: column; gap: 1rem; }
.field { display: flex; flex-direction: column; gap: 0.35rem; }
.field-label { font-size: 0.95rem; color: var(--secondary); }
.input {
  inline-size: 100%;
  padding-block: 0.7rem;
  padding-inline: 0.9rem;
  font-family: var(--font);
  font-size: 1rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  text-align: start;
  min-block-size: 48px; /* ≥48px tap target (§6.1) */
}
.input:focus { outline: 2px solid var(--primary); outline-offset: 1px; }
.amount { letter-spacing: 0.02em; }

/* ── Buttons ─────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding-block: 0.7rem;
  padding-inline: 1.1rem;
  min-block-size: 48px;
  border: 1px solid transparent;
  border-radius: 8px;
  font: inherit;
  cursor: pointer;
  text-decoration: none;
}
.btn-block { inline-size: 100%; }
.btn-primary { background: var(--primary); color: var(--primary-ink); }
.btn-secondary { background: var(--secondary); color: #fff; }
.btn-ghost { background: transparent; border-color: var(--border); color: var(--ink); }

/* ── Alerts ──────────────────────────────────────────────────────────── */
.alert {
  padding-block: 0.7rem;
  padding-inline: 0.9rem;
  border-radius: 8px;
  margin-block-end: 1rem;
}
.alert-error { background: var(--danger-bg); color: var(--danger-ink); }
.alert-warn { background: var(--warn-bg); color: var(--warn-ink); }

.divider {
  display: flex;
  align-items: center;
  text-align: center;
  color: var(--muted);
  margin-block: 1rem;
}
.divider::before, .divider::after {
  content: "";
  flex: 1;
  border-block-start: 1px solid var(--border);
}
.divider span { padding-inline: 0.75rem; }

.hint { color: var(--muted); font-size: 0.9rem; }

/* ── Lists / key-value ───────────────────────────────────────────────── */
.module-list { list-style: none; padding-inline: 0; }
.module-item {
  padding-block: 0.6rem;
  padding-inline: 0.9rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-block-end: 0.5rem;
}
.kv { display: grid; grid-template-columns: max-content 1fr; gap: 0.4rem 1.5rem; }
.kv dt { color: var(--muted); }
.kv dd { margin-inline-start: 0; font-weight: 600; }

/* ── Leave module (tables, balance box, tags, inline fields) ──────────── */
.row { display: flex; gap: 1rem; flex-wrap: wrap; }
.row > .field { flex: 1; min-inline-size: 9rem; }
.field-inline { display: flex; align-items: center; gap: 0.5rem; color: var(--secondary); }

.balance-box {
  background: #eef5fb;
  border: 1px solid #cfe2f3;
  border-radius: 8px;
  padding-block: 0.7rem;
  padding-inline: 0.9rem;
  margin-block-end: 1rem;
}

.tbl { inline-size: 100%; border-collapse: collapse; }
.tbl th, .tbl td {
  text-align: start;             /* logical — never left/right */
  padding-block: 0.55rem;
  padding-inline: 0.6rem;
  border-block-end: 1px solid var(--border);
  font-size: 0.95rem;
}
.tbl th { color: var(--muted); font-weight: 600; }
.actions { display: flex; gap: 0.4rem; flex-wrap: wrap; align-items: center; }
.reject-form { display: flex; gap: 0.3rem; align-items: center; }
.btn-sm { min-block-size: 36px; padding-block: 0.35rem; padding-inline: 0.7rem; font-size: 0.85rem; }
.input-sm { min-block-size: 36px; padding-block: 0.3rem; inline-size: 8rem; }
.tag {
  display: inline-block;
  background: var(--warn-bg);
  color: var(--warn-ink);
  border-radius: 6px;
  padding-block: 0.05rem;
  padding-inline: 0.4rem;
  font-size: 0.78rem;
}
