/* SyriaFab design system — Arabic-first, RTL-native (logical properties). */

:root {
  --primary: #0f766e;        /* teal-700 */
  --primary-dark: #115e59;
  --primary-soft: #ccfbf1;
  --accent: #d97706;         /* amber-600 */
  --ink: #0f172a;            /* slate-900 */
  --ink-soft: #475569;       /* slate-600 */
  --line: #e2e8f0;           /* slate-200 */
  --paper: #f8fafc;          /* slate-50 */
  --card: #ffffff;
  --ok: #15803d;  --ok-soft: #dcfce7;
  --info: #1d4ed8; --info-soft: #dbeafe;
  --warn: #b45309; --warn-soft: #fef3c7;
  --bad: #b91c1c;  --bad-soft: #fee2e2;
  --muted-soft: #e2e8f0;
  --radius: 10px;
}

* { box-sizing: border-box; }
html { font-size: 16px; }
body {
  margin: 0; background: var(--paper); color: var(--ink);
  font-family: "Segoe UI", Tahoma, "Noto Sans Arabic", system-ui, sans-serif;
  line-height: 1.6;
}
main { max-width: 64rem; margin-inline: auto; padding: 1.25rem; }

/* header ------------------------------------------------------------- */
.topbar {
  background: var(--primary); color: #fff;
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  padding: .6rem 1.25rem;
}
.topbar .brand { font-weight: 800; font-size: 1.15rem; letter-spacing: .5px; }
.topbar .brand small { font-weight: 400; opacity: .85; margin-inline-start: .5rem; }
.topbar nav { display: flex; gap: .25rem; flex-wrap: wrap; }
.topbar a { color: #fff; text-decoration: none; padding: .35rem .7rem; border-radius: 8px; }
.topbar a:hover, .topbar a.active { background: rgba(255,255,255,.16); }
.topbar .spacer { flex: 1; }
.topbar form { margin: 0; }
.topbar select, .topbar button {
  background: rgba(255,255,255,.12); color: #fff; border: 1px solid rgba(255,255,255,.3);
  border-radius: 8px; padding: .45rem .7rem; cursor: pointer; min-block-size: 44px;
}
.topbar a { padding-block: .6rem; }
.bell { position: relative; }
.bell .count {
  position: absolute; inset-block-start: -6px; inset-inline-end: -8px;
  background: #92400e; color: #fff; font-size: .75rem; font-weight: 700;
  border-radius: 999px; padding: .05rem .4rem; min-inline-size: 1.2rem; text-align: center;
}

/* cards & tables ------------------------------------------------------ */
.card {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1rem 1.25rem; margin-block: 1rem;
}
.card h3 { margin-block: 0 .75rem; font-size: 1rem; color: var(--ink-soft);
  text-transform: none; border-block-end: 1px solid var(--line); padding-block-end: .5rem; }
table { border-collapse: collapse; width: 100%; background: var(--card); }
th { text-align: start; font-size: .8rem; color: var(--ink-soft); font-weight: 600;
  border-block-end: 2px solid var(--line); padding: .5rem .6rem; }
td { border-block-end: 1px solid var(--line); padding: .55rem .6rem; vertical-align: middle; }
tr:hover td { background: #f1f5f9; }
.table-card { padding: 0; overflow: hidden; }
.table-card table { border: 0; }
.empty { color: var(--ink-soft); text-align: center; padding: 1.5rem; }

/* buttons & forms ------------------------------------------------------ */
button, .btn {
  font: inherit; cursor: pointer; border-radius: 8px; border: 1px solid var(--line);
  background: #fff; color: var(--ink); padding: .55rem 1rem; min-block-size: 44px;
  display: inline-flex; align-items: center; justify-content: center; gap: .35rem;
}
button:hover { border-color: var(--primary); color: var(--primary-dark); }
.btn-primary, form.primary button {
  background: var(--primary); border-color: var(--primary); color: #fff; font-weight: 600;
}
.btn-primary:hover, form.primary button:hover { background: var(--primary-dark); color: #fff; }
.btn-danger { background: var(--bad-soft); border-color: #fca5a5; color: var(--bad); }
.btn-danger:hover { background: var(--bad); color: #fff; }
input, select, textarea {
  font: inherit; padding: .6rem .7rem; border: 1px solid var(--line); border-radius: 8px;
  background: #fff; max-inline-size: 100%; min-block-size: 44px;
}
textarea { min-block-size: 6rem; }
.auth-card { max-inline-size: 26rem; margin-inline: auto; }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--primary-soft); border-color: var(--primary); }
form.stack p { display: flex; flex-direction: column; gap: .3rem; max-inline-size: 28rem; }
form.inline { display: inline-flex; gap: .35rem; align-items: center; flex-wrap: wrap; }
label { font-size: .9rem; color: var(--ink-soft); }
.help { font-size: .8rem; color: var(--ink-soft); }

/* badges --------------------------------------------------------------- */
.badge {
  display: inline-block; padding: .15rem .6rem; border-radius: 999px;
  font-size: .8rem; font-weight: 700; white-space: nowrap;
}
.badge-intake { background: var(--muted-soft); color: var(--ink-soft); }
.badge-money  { background: var(--warn-soft);  color: var(--warn); }
.badge-work   { background: var(--info-soft);  color: var(--info); }
.badge-done   { background: var(--ok-soft);    color: var(--ok); }
.badge-alert  { background: var(--bad-soft);   color: var(--bad); }

/* journey steps ---------------------------------------------------------- */
.steps { display: flex; gap: .25rem; margin-block: 1rem; flex-wrap: wrap; }
.step {
  flex: 1; min-inline-size: 7rem; text-align: center; font-size: .8rem;
  padding: .45rem .25rem; background: var(--card); border: 1px solid var(--line);
  color: var(--ink-soft); border-radius: 8px; position: relative;
}
.step.active { background: var(--primary); border-color: var(--primary); color: #fff; font-weight: 700; }
.step.done { background: var(--primary-soft); border-color: var(--primary-soft); color: var(--primary-dark); }

/* alerts / messages -------------------------------------------------------- */
.msg { padding: .7rem 1rem; margin-block: .75rem; border-radius: 8px; border: 1px solid; }
.msg-success { background: var(--ok-soft); border-color: #86efac; color: var(--ok); }
.msg-error   { background: var(--bad-soft); border-color: #fca5a5; color: var(--bad); }
.msg-warning { background: var(--warn-soft); border-color: #fcd34d; color: var(--warn); }
.msg-info    { background: var(--info-soft); border-color: #93c5fd; color: var(--info); }
.banner-exception {
  background: var(--bad-soft); border: 1px solid #fca5a5; color: var(--bad);
  padding: .8rem 1rem; border-radius: var(--radius); margin-block: 1rem; font-weight: 600;
}

/* misc ------------------------------------------------------------------ */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr)); gap: 1rem; }
.kv { display: flex; gap: 1.25rem; flex-wrap: wrap; color: var(--ink-soft); font-size: .9rem; }
.kv b { color: var(--ink); }
.mono { font-family: ui-monospace, Consolas, monospace; font-size: .85rem; }
.actions { display: flex; gap: .4rem; flex-wrap: wrap; align-items: center; }
.chip { display: inline-block; background: var(--card); border: 1px solid var(--line);
  padding: .2rem .65rem; border-radius: 999px; font-size: .8rem; text-decoration: none; color: var(--ink-soft); }
.chip:hover, .chip.active { border-color: var(--primary); color: var(--primary-dark); }
.timeline { list-style: none; margin: 0; padding: 0; }
.timeline li { padding: .45rem .75rem; border-inline-start: 3px solid var(--line); margin-inline-start: .5rem; }
.timeline li:first-child { border-inline-start-color: var(--primary); }
.timeline .t-when { color: var(--ink-soft); font-size: .8rem; }
footer { color: var(--ink-soft); font-size: .8rem; text-align: center; padding: 2rem 0 1rem; }

/* htmx loading indicator ---------------------------------------------------- */
#busy { position: fixed; inset-block-start: 0; inset-inline: 0; block-size: 3px;
  background: var(--accent); opacity: 0; transition: opacity .2s; z-index: 50; }
.htmx-request #busy, #busy.htmx-request { opacity: 1; }

@media (max-width: 640px) {
  main { padding: .75rem; }
  .topbar { padding: .5rem .75rem; }
  .steps { flex-direction: column; }
}
