:root{
  --blue:#6f1d2b;          /* العنّابي الأساسي */
  --blue-2:#8a2433;
  --gold:#a9842a;
  --gold-soft:#f7eed6;
  --ink:#241f22;
  --muted:#7a6f73;
  --line:#ece3e5;
  --bg:#faf6f4;
  --card:#ffffff;
  --green:#3c6e2e;
  --green-soft:#eaf4e2;
  --red:#b23b3b;
  --red-soft:#fbeaea;
  --shadow:0 1px 3px rgba(111,29,43,.08),0 6px 20px rgba(111,29,43,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Tajawal",system-ui,"Segoe UI",Tahoma,Arial,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.6;
  -webkit-text-size-adjust:100%;
}
.wrap{width:100%;max-width:920px;margin:0 auto;padding:0 16px}

/* ---------- topbar ---------- */
.topbar{background:var(--blue);color:#fff;box-shadow:var(--shadow)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;
  flex-wrap:wrap;padding:12px 16px}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:38px;height:38px;border-radius:10px;object-fit:cover;display:block;
  box-shadow:0 0 0 1px rgba(255,255,255,.12)}
.brand-title{font-weight:800;font-size:1.02rem;line-height:1.2}
.brand-sub{font-size:.8rem;color:#e7cdd2}
.nav{display:flex;gap:4px;flex-wrap:wrap}
.nav a{color:#f0dde1;text-decoration:none;padding:7px 12px;border-radius:8px;font-weight:500;font-size:.95rem}
.nav a:hover{background:rgba(255,255,255,.12);color:#fff}
.nav a.active{background:#fff;color:var(--blue);font-weight:700}
.nav .nav-out{color:#f3c9c9}

/* ---------- layout pieces ---------- */
main.wrap{padding-top:22px;padding-bottom:40px}
h1{font-size:1.5rem;margin:.2em 0 .1em;color:var(--blue)}
h2{font-size:1.15rem;margin:0 0 .4em;color:var(--blue-2)}
.sub{color:var(--muted);margin:.2em 0 1.2em}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:18px;box-shadow:var(--shadow);margin-bottom:18px}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row>*{flex:1 1 220px}

/* ---------- stat cards ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px;margin-bottom:18px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow)}
.stat .num{font-size:2rem;font-weight:800;color:var(--blue);line-height:1}
.stat .lbl{color:var(--muted);font-size:.92rem;margin-top:6px}
.stat.gold{border-top:3px solid var(--gold)}
.stat.late{border-top:3px solid var(--red)}
.stat.late .num{color:var(--red)}

/* ---------- forms ---------- */
label{display:block;font-weight:500;margin:12px 0 5px}
input,select,textarea{
  width:100%;padding:11px 12px;border:1px solid #d8ccce;border-radius:10px;
  font:inherit;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--blue-2);outline-offset:1px;border-color:var(--blue-2)}
textarea{min-height:90px;resize:vertical}
.hp{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0 0 0 0);white-space:nowrap;border:0}
.btn{display:inline-flex;align-items:center;gap:6px;justify-content:center;
  background:var(--blue);color:#fff;border:0;border-radius:10px;padding:11px 18px;
  font:inherit;font-weight:700;cursor:pointer;text-decoration:none;min-height:44px}
.btn:hover{background:#561622}
.btn-gold{background:var(--gold);color:#1a1a1a}
.btn-gold:hover{background:#8c6c1f}
.btn-ghost{background:#fff;color:var(--blue);border:1px solid #d8ccce}
.btn-ghost:hover{background:#f7eff0}
.btn-sm{padding:7px 12px;min-height:36px;font-size:.9rem;border-radius:8px}
.btn-block{width:100%}
.btn-ok{background:var(--green)}.btn-ok:hover{background:#2f5724}
.btn-no{background:#fff;color:var(--red);border:1px solid #e3b9b9}.btn-no:hover{background:#fdf1f1}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}

/* ---------- table / lists ---------- */
table{width:100%;border-collapse:collapse}
th,td{text-align:right;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
th{color:var(--muted);font-size:.85rem;font-weight:700}
tr:last-child td{border-bottom:0}
tr.row-late td{background:var(--red-soft)}
tr.row-late a{color:var(--red)}

/* ---------- badges ---------- */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.8rem;font-weight:700}
.b-booked{background:var(--green-soft);color:var(--green)}
.b-cancelled{background:#f5eef0;color:var(--red)}
.b-done{background:#eef2fb;color:#2e5496}
.b-no_show{background:#f0f0f3;color:#666}
.b-rescheduled{background:var(--gold-soft);color:#8a6508}
.b-late{background:var(--red-soft);color:var(--red)}
.b-pending{background:var(--gold-soft);color:#8a6508}
.b-sent{background:var(--green-soft);color:var(--green)}
.b-failed{background:var(--red-soft);color:var(--red)}
.pill{display:inline-block;background:var(--gold-soft);color:#8a6508;border-radius:999px;
  padding:2px 9px;font-size:.78rem;font-weight:700}

.flash{background:var(--green-soft);border:1px solid #bcd9a8;color:var(--green);
  padding:12px 14px;border-radius:10px;margin-bottom:16px;font-weight:500}
.note{background:var(--gold-soft);border:1px solid #ecd9a0;color:#7a5a07;
  padding:12px 14px;border-radius:10px;margin:10px 0}
.note.err{background:var(--red-soft);border-color:#e3b9b9;color:var(--red)}
.empty{text-align:center;color:var(--muted);padding:26px 10px}

.footer{color:var(--muted);text-align:center;font-size:.85rem;padding:24px 0 36px}

/* ---------- public auth/register ---------- */
.center-narrow{max-width:520px;margin:30px auto}
.lead-card{background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:24px;box-shadow:var(--shadow)}
.crest{text-align:center;margin-bottom:6px}
.crest .mk{display:inline-block;width:60px;height:60px;border-radius:14px;object-fit:cover;box-shadow:var(--shadow)}
.otp-input{letter-spacing:.5em;text-align:center;font-size:1.6rem;font-weight:800}
.muted-link{display:block;text-align:center;margin-top:16px;color:var(--blue-2);text-decoration:none}
.muted-link:hover{text-decoration:underline}

/* ---------- slots (booking) ---------- */
.slot-day{margin-bottom:18px}
.slot-day-head{font-weight:800;color:var(--blue);border-right:4px solid var(--gold);
  padding-right:10px;margin:0 0 10px}
.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
.slot-btn{display:flex;flex-direction:column;align-items:center;gap:2px;
  background:#fff;border:1px solid #d8ccce;border-radius:12px;padding:12px 8px;
  cursor:pointer;font:inherit;font-weight:700;color:var(--blue);min-height:56px}
.slot-btn:hover{background:var(--gold-soft);border-color:var(--gold)}
.slot-btn .t{font-size:1.05rem}
.slot-btn .d{font-size:.72rem;color:var(--muted);font-weight:500}

/* ---------- appointment card ---------- */
.appt{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:10px;background:#fff}
.appt .when{font-weight:800;color:var(--blue);font-size:1.05rem}
.appt .meta{color:var(--muted);font-size:.88rem}

/* ---------- mini calendar (availability) ---------- */
.cal-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.cal-title{font-weight:800;color:var(--blue);font-size:1.15rem}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal-dow span{text-align:center;color:var(--muted);font-size:.78rem;font-weight:700;padding:4px 0}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-cell{position:relative;min-height:62px;border:1px solid var(--line);border-radius:10px;padding:6px 7px;background:#fff}
.cal-cell.blank{background:transparent;border:0}
.cal-cell .d{font-weight:700;color:var(--ink);font-size:.9rem}
.cal-cell.today{outline:2px solid var(--blue-2);outline-offset:-2px}
.cal-cell.has{background:var(--gold-soft);border-color:#ecd9a0}
.cal-open{text-decoration:none;display:block;color:inherit}
.cal-mini{font-size:.7rem;color:var(--green);font-weight:700;margin-top:3px}
.cal-mini.book{color:var(--blue-2)}

/* ---------- QR ---------- */
.qr-wrap{text-align:center}
#qrcode{display:inline-block;background:#fff;padding:14px;border-radius:14px;border:1px solid var(--line)}
.copy-box{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.copy-box input{flex:1 1 220px}

/* ---------- in-app modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(36,31,34,.55);display:flex;
  align-items:center;justify-content:center;padding:18px;z-index:1000}
.modal-overlay[hidden]{display:none}
.modal{background:var(--card);border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.28);
  width:100%;max-width:420px;padding:22px;animation:modal-in .14s ease-out}
@keyframes modal-in{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
.modal-msg{font-weight:700;font-size:1.05rem;margin:0 0 12px;line-height:1.6;color:var(--ink)}
.modal-input{margin-bottom:6px}
.modal-err{color:var(--red);font-size:.85rem;margin:4px 0 0;font-weight:500}
.modal-actions{display:flex;gap:10px;justify-content:flex-start;margin-top:16px}
.modal-actions .btn{min-width:96px}

.chk{display:flex;align-items:center;gap:8px;font-weight:500;cursor:pointer}
.chk input{width:auto;margin:0}

/* ---------- super-admin priest switcher ---------- */
.priest-switch{display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  background:var(--gold-soft);border:1px solid #ecd9a0;border-radius:12px;padding:10px 14px;margin-bottom:16px}
.priest-switch label{margin:0;font-weight:700;color:#7a5a07}
.priest-switch select{width:auto;min-width:200px;flex:0 1 auto}

@media(max-width:560px){
  .brand-title{font-size:.95rem}
  h1{font-size:1.3rem}
  .card{overflow-x:auto}
  th,td{padding:8px 9px;font-size:.86rem}
  .cal-cell{min-height:54px;padding:4px;border-radius:8px}
  .cal-cell .d{font-size:.8rem}
  .cal-dow span{font-size:.66rem}
  .slot-grid{grid-template-columns:repeat(auto-fill,minmax(92px,1fr))}
}
