:root{
  --blue:#1f3864;
  --blue-2:#2e5496;
  --gold:#b8860b;
  --gold-soft:#fbf3d5;
  --ink:#1f2733;
  --muted:#6b7686;
  --line:#e3e8f0;
  --bg:#f4f6fb;
  --card:#ffffff;
  --green:#3c6e2e;
  --green-soft:#eaf4e2;
  --red:#b23b3b;
  --shadow:0 1px 3px rgba(31,56,100,.08),0 6px 20px rgba(31,56,100,.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:#c7d2e8}
.nav{display:flex;gap:4px;flex-wrap:wrap}
.nav a{color:#dbe4f6;text-decoration:none;padding:7px 12px;border-radius:8px;font-weight:500;font-size:.95rem}
.nav a:hover{background:rgba(255,255,255,.1);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)}

/* ---------- forms ---------- */
label{display:block;font-weight:500;margin:12px 0 5px}
input,select,textarea{
  width:100%;padding:11px 12px;border:1px solid #cdd5e2;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)}
/* مصيدة السبام: مخفية بطريقة آمنة مع RTL (مش بتعمل overflow أفقي) */
.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:#16294a}
.btn-gold{background:var(--gold);color:#1a1a1a}
.btn-gold:hover{background:#9c7209}
.btn-ghost{background:#fff;color:var(--blue);border:1px solid #cdd5e2}
.btn-ghost:hover{background:#f1f4fa}
.btn-sm{padding:7px 12px;min-height:36px;font-size:.9rem;border-radius:8px}
.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}
.service-block{margin-bottom:16px}
.service-head{display:flex;align-items:center;gap:8px;font-weight:800;color:var(--blue);
  border-right:4px solid var(--gold);padding-right:10px;margin:0 0 8px}

/* ---------- badges ---------- */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.8rem;font-weight:700}
.b-nominated{background:#eef2fb;color:var(--blue-2)}
.b-confirmed{background:var(--green-soft);color:var(--green)}
.b-declined{background:#f5eef0;color:var(--red)}
.b-absent{background:#f0f0f3;color:#666}
.pill{display:inline-block;background:var(--gold-soft);color:#8a6508;border-radius:999px;
  padding:2px 9px;font-size:.78rem;font-weight:700}

/* ---------- nominee card ---------- */
.nominee{border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px;background:#fff}
.nominee .name{font-weight:700;font-size:1.05rem}
.nominee .meta{color:var(--muted);font-size:.88rem;margin-top:2px}

.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}
.empty{text-align:center;color:var(--muted);padding:26px 10px}

.wa-box{background:var(--green-soft);border:1px solid #bcd9a8;border-radius:12px;padding:14px;margin-top:8px}
.wa-text{white-space:pre-wrap;font-size:.95rem;margin:0 0 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)}

/* ---------- live service hint on register form ---------- */
.svc-hint{background:#eef2fb;border:1px solid #d5dffb;color:var(--blue-2);
  padding:9px 12px;border-radius:10px;margin-top:8px;font-size:.92rem}

/* ---------- mass calendar ---------- */
.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:64px;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.mass{background:var(--gold-soft);border-color:#ecd9a0}
.cal-cell.mass .d{color:#8a6508}
.cal-open{text-decoration:none;display:block}
.cal-open:hover .cal-tag{background:#9c7209}
.cal-tag{display:inline-block;margin-top:6px;background:var(--gold);color:#1a1a1a;
  border-radius:999px;padding:1px 8px;font-size:.7rem;font-weight:700}
.cal-mini{font-size:.7rem;color:var(--green);font-weight:700;margin-top:3px}
/* per-day add/remove toggle */
.cal-toggle{position:absolute;top:3px;left:3px;margin:0}
.cal-toggle button{width:20px;height:20px;min-height:0;padding:0;border-radius:6px;
  font-size:.8rem;font-weight:800;line-height:1;cursor:pointer;border:1px solid transparent;opacity:.35;transition:opacity .12s}
.cal-cell:hover .cal-toggle button{opacity:1}
.cal-plus{background:#fff;color:var(--blue);border-color:#cdd5e2!important}
.cal-plus:hover{background:var(--blue);color:#fff}
.cal-x{background:#fff;color:var(--red);border-color:#e3b9b9!important}
.cal-x:hover{background:var(--red);color:#fff}
.promote-card{border-top:3px solid var(--gold)}

/* ---------- attendance roll-call ---------- */
.att-summary{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px}
.att-row{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:9px 4px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.att-row:last-child{border-bottom:0}
.att-name{font-weight:700;text-decoration:none;color:var(--ink)}
.att-name:hover{color:var(--blue-2)}
.att-name .meta{font-weight:500;color:var(--muted);font-size:.82rem;margin-inline-start:8px}
.att-actions{display:flex;gap:6px;flex-wrap:wrap}
.chk{display:flex;align-items:center;gap:8px;font-weight:500;cursor:pointer}
.chk input{width:auto;margin:0}

/* ---------- in-app modal (بدل نوافذ المتصفح) ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(31,39,51,.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}
.cal-legend{margin-top:14px;color:var(--muted);font-size:.85rem;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.cal-dot{display:inline-block;width:13px;height:13px;border-radius:4px;vertical-align:middle}
.cal-dot.mass{background:var(--gold-soft);border:1px solid #ecd9a0}
.cal-dot.today{background:#fff;border:2px solid var(--blue-2)}

@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}
  /* في قائمة الشمامسة بس: نخفي عمود الواتساب الثانوي لتوفير مكان */
  .deacons-list th:nth-child(2),.deacons-list td:nth-child(2){display:none}
  .cal-cell{min-height:56px;padding:4px;border-radius:8px}
  .cal-cell .d{font-size:.8rem}
  .cal-tag{font-size:.6rem;padding:1px 5px}
  .cal-dow span{font-size:.66rem}
  .cal-toggle button{opacity:.9}   /* مفيش hover على الموبايل */
}
