/* ===========================================================================
 * donations.css — Sacrifice Campaign (حملة الأضاحي 2026)  — LIGHT THEME
 * ---------------------------------------------------------------------------
 * Revised per feedback: white background, brand colours used as ACCENTS only
 * (not the whole surface). Replaces bootstrap.rtl + bootstrap-grid + jquery-ui.
 *
 * Aesthetic direction: clean white editorial form. One warm accent (amber/gold
 * — fitting a sacrifice/charity campaign) paired with the JEA blue for trust.
 * Generous white space, soft shadows, a single coloured header band.
 *
 * Compatibility: iOS Safari, Android Chrome/WebView, older browsers.
 * Flexbox + media queries only. No nesting, no :has(), no container queries.
 * Fonts: Cairo (text) + IBM Plex Sans (numbers via .num).
 * ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@300;400;500;600;700;800&family=IBM+Plex+Sans:wght@300;400;500;600;700&display=swap');

:root{
  /* brand */
  --blue:#2A5E92;
  --blue-d:#1E4670;
  --violet:#665393;

  /* warm accent — the "wow", used sparingly */
  --gold:#C8893B;
  --gold-d:#A86E29;
  --gold-soft:#FBF1E3;

  /* light surfaces */
  --bg:#F4F6FB;          /* page */
  --card:#FFFFFF;        /* panels */
  --line:#E6EAF2;        /* hairlines */
  --line-soft:#F0F2F7;

  /* text on light */
  --ink:#1C2536;         /* headings / primary */
  --ink-2:#5A6478;       /* secondary */
  --ink-3:#8A92A4;       /* muted */

  --r:16px;
  --sh-sm:0 1px 3px rgba(20,30,55,.06), 0 1px 2px rgba(20,30,55,.04);
  --sh-md:0 6px 20px rgba(20,30,55,.08);
  --tr:.22s cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}

html{
  direction:rtl;
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
}

body{
  font-family:'Cairo',-apple-system,'Geeza Pro',sans-serif;
  background:var(--bg);
  color:var(--ink);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{text-decoration:none;color:inherit}
img{display:block;border:0}

.num{
  font-family:'IBM Plex Sans',sans-serif;
  font-variant-numeric:tabular-nums;
  -webkit-font-feature-settings:"tnum";
  font-feature-settings:"tnum";
}

/* --- Navbar — dark slate (#474961) so the WHITE logo reads ---------------- */
.nav{
  display:flex;
  align-items:center;
  gap:14px;
  padding:12px 18px;
  background:#474961;
  border-bottom:3px solid var(--gold);
  box-shadow:var(--sh-sm);
  flex-wrap:wrap;
}
.nav-logo{flex:0 0 auto}
.nav-logo img{height:36px;width:auto}
.nav-site{
  color:#E4E6F0;
  font-weight:700;
  font-size:.92rem;
  padding:6px 10px;
  border-radius:9px;
  transition:var(--tr);
}
.nav-site:hover{background:rgba(255,255,255,.10);color:#fff}
.nav-spacer{flex:1 1 auto}
.nav-greet{
  color:#BFC3D4;
  font-weight:600;
  font-size:.9rem;
  white-space:nowrap;
}
.nav-exit{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:#E4E6F0;
  font-weight:700;
  font-size:.88rem;
  padding:7px 13px;
  border-radius:11px;
  border:1px solid rgba(255,255,255,.18);
  transition:var(--tr);
}
.nav-exit:hover{
  background:rgba(214,103,96,.22);
  border-color:rgba(214,103,96,.5);
  color:#FFD9D6;
}

/* --- Campaign header (bgsection2) ---------------------------------------- */
.bgsection2{
  position:relative;
  background-image:url('bg3333.png');
  background-size:cover;
  background-position:left center;
  background-repeat:no-repeat;
  min-height:150px;
  border-radius:var(--r);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:22px 0;
  box-shadow:var(--sh-md);
  overflow:hidden;
}
/* subtle dark veil so white title is always legible over the art */
.bgsection2:before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(20,30,55,.30),rgba(20,30,55,.05));
}
.bgsection2-title{
  position:relative;
  color:#fff;
  font-weight:800;
  font-size:1.55rem;
  text-align:center;
  padding:0 18px;
  text-shadow:0 2px 10px rgba(0,0,0,.4);
}

/* --- Page shell ---------------------------------------------------------- */
.wrap{
  max-width:680px;
  margin:0 auto;
  padding:0 16px 56px;
}

.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--sh-md);
  padding:8px 18px 20px;
}

/* --- Transactions list (table-free; one compact card per txn) ------------ */
.txn-list{display:flex;flex-direction:column;gap:12px}

.txn-allbar{
  display:flex;
  align-items:center;
  gap:10px;
  padding:13px 14px;
  border:1px solid var(--line);
  border-radius:12px;
  background:var(--card);
  font-weight:700;
  font-size:.92rem;
  color:var(--ink);
  cursor:pointer;
  transition:var(--tr);
}
.txn-allbar:hover{border-color:#CFD6E4;background:#FCFCFE}

/* --- The unified transaction card ---------------------------------------- */
.txn-card{
  border:1px solid var(--line);
  border-radius:14px;
  background:var(--card);
  box-shadow:var(--sh-sm);
  overflow:hidden;
  transition:border-color var(--tr), box-shadow var(--tr), background var(--tr);
}
.txn-card:hover{border-color:#CFD6E4}
/* active = its checkbox is checked (class toggled by donations.js) */
.txn-card.is-active{
  border-color:var(--gold);
  box-shadow:0 0 0 1px var(--gold), var(--sh-md);
}

/* card header — checkbox + description + per-item price */
.txn-head{
  display:flex;
  align-items:center;
  gap:11px;
  padding:14px 15px;
  cursor:pointer;
  transition:background var(--tr);
}
.txn-head:hover{background:var(--line-soft)}
.txn-card.is-active .txn-head{background:var(--gold-soft)}

.txn-desc{
  flex:1 1 auto;
  font-weight:700;
  font-size:1rem;
  line-height:1.5;
  color:var(--ink);
}
.txn-unit{
  flex:0 0 auto;
  font-size:.78rem;
  color:var(--ink-3);
  font-weight:600;
  white-space:nowrap;
}
.txn-unit .num{color:var(--ink-2);font-size:.86rem}

.txn-empty{
  text-align:center;
  color:var(--ink-3);
  padding:30px 6px;
  font-weight:600;
  border:1px solid var(--line);
  border-radius:14px;
  background:var(--card);
}

/* --- Checkbox — gold when checked ---------------------------------------- */
.chk{
  -webkit-appearance:none;
  appearance:none;
  flex:0 0 auto;
  width:21px;height:21px;
  margin:0;
  border:2px solid #C2C9D6;
  border-radius:6px;
  background:#fff;
  cursor:pointer;
  position:relative;
  transition:var(--tr);
}
.chk:hover{border-color:var(--gold)}
.chk:checked{
  background:var(--gold);
  border-color:var(--gold);
}
.chk:checked::after{
  content:'';
  position:absolute;
  left:6px;top:2px;
  width:6px;height:11px;
  border:solid #fff;
  border-width:0 2px 2px 0;
  transform:rotate(45deg);
}
.chk:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

/* --- Slider body — COLLAPSES when row inactive --------------------------- *
 * Reflow-safety: the collapse animates max-height ONLY. The inner content
 * has a FIXED height (the head/range/foot never change size as the slider
 * value changes), so the card never resizes mid-slide. Numbers use tabular
 * figures (.num) so digit-count changes (9 -> 10 -> 100) don't shift width.
 */
.txn-slider{
  max-height:0;
  opacity:0;
  overflow:hidden;
  /* transition max-height + opacity only; never width/height of children */
  transition:max-height var(--tr), opacity .18s ease;
}
.txn-card.is-active .txn-slider{
  max-height:220px;          /* >= real content height; generous headroom */
  opacity:1;
}
.txn-slider-inner{padding:4px 15px 15px}

.slider-head,.slider-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-height:34px;           /* fixed row height — no reflow on value change */
}
.slider-cap,.slider-amt-label{
  font-size:.83rem;
  color:var(--ink-2);
  font-weight:600;
}
.slider-count{
  font-size:1.1rem;
  font-weight:800;
  color:#fff;
  background:var(--gold);
  border-radius:9px;
  padding:3px 12px;
  min-width:54px;            /* fits "100" without growing */
  text-align:center;
}
.slider-foot{
  margin-top:6px;
  padding-top:10px;
  border-top:1px dashed #E4D2B2;
}
.slider-amt{display:flex;align-items:baseline;gap:5px}
.slider-amt .num{
  font-size:1.2rem;font-weight:800;color:var(--gold-d);
  min-width:96px;text-align:left;   /* stable width as amount digits change */
}
.cur{font-size:.82rem;color:var(--ink-2);font-weight:600}

/* --- Range input — gold fill, white thumb. Style BOTH engines ------------ */
.range{
  -webkit-appearance:none;
  appearance:none;
  width:100%;
  height:34px;
  margin:10px 0 2px;
  background:transparent;
  cursor:pointer;
  direction:rtl;
  outline:none;            /* default outline suppressed — focus shown on thumb */
}
.range::-webkit-slider-runnable-track{
  height:8px;border-radius:999px;
  background:linear-gradient(90deg,var(--gold),var(--gold-d));
}
.range::-moz-range-track{
  height:8px;border-radius:999px;
  background:linear-gradient(90deg,var(--gold),var(--gold-d));
}
.range::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:24px;height:24px;margin-top:-8px;
  border-radius:50%;
  background:#fff;
  border:3px solid var(--gold);
  box-shadow:0 2px 6px rgba(168,110,41,.4);
}
.range::-moz-range-thumb{
  width:24px;height:24px;
  border-radius:50%;
  background:#fff;
  border:3px solid var(--gold);
  box-shadow:0 2px 6px rgba(168,110,41,.4);
}
.range:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 4px rgba(200,137,59,.3)}
.range:focus-visible::-moz-range-thumb{box-shadow:0 0 0 4px rgba(200,137,59,.3)}

/* --- Total + submit — blue band for trust/finality ----------------------- */
.summary{
  margin-top:20px;
  padding:18px 20px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--blue),var(--blue-d));
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  box-shadow:var(--sh-sm);
}
.summary-label{font-weight:700;font-size:1rem;color:#DCE6F2}
.summary-total{font-weight:800;font-size:1.6rem;color:#fff}
.summary-total .cur{font-size:.85rem;color:#BED0E4}

.btn{
  border:0;
  border-radius:13px;
  padding:15px 22px;
  font:800 16px 'Cairo',sans-serif;
  cursor:pointer;
  transition:var(--tr);
}
.btn-primary{
  background:linear-gradient(135deg,var(--gold),var(--gold-d));
  color:#fff;
  box-shadow:0 8px 20px rgba(168,110,41,.32);
  width:100%;
  margin-top:14px;
}
.btn-primary:hover{filter:brightness(1.05)}
.btn-primary:active{transform:translateY(1px)}
.btn-primary:disabled{
  background:#D7DBE4;
  color:#9AA2B2;
  box-shadow:none;
  cursor:not-allowed;
}

/* --- index.php capcha form ----------------------------------------------- */
.input{
  width:100%;
  padding:14px 16px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  font-family:'Cairo',sans-serif;
  font-size:16px;            /* >=16px stops iOS focus-zoom */
  outline:0;
  transition:var(--tr);
  margin-bottom:14px;
}
.input::-webkit-input-placeholder{color:var(--ink-3)}
.input::placeholder{color:var(--ink-3)}
.input:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 4px rgba(200,137,59,.14);
}
.capcha-img{
  display:block;
  margin:8px auto 18px;
  border:1px solid var(--line);
  border-radius:10px;
  max-width:100%;
}

/* --- CSS-only spinner (replaces loading.gif) ----------------------------- */
.overlay{
  display:none;
  position:fixed;inset:0;
  z-index:5000;
  background:rgba(28,37,54,.45);
  -webkit-backdrop-filter:blur(2px);
  backdrop-filter:blur(2px);
  align-items:center;
  justify-content:center;
}
.overlay.show{display:flex}
.spinner{
  width:52px;height:52px;
  border-radius:50%;
  border:5px solid rgba(255,255,255,.35);
  border-top-color:var(--gold);
  -webkit-animation:spin .8s linear infinite;
  animation:spin .8s linear infinite;
}
@-webkit-keyframes spin{to{-webkit-transform:rotate(360deg)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* --- iOS Safari Arabic font fix (preserved) ------------------------------ */
@supports (-webkit-touch-callout:none){
  body,h1,h2,h3,h4,h5,h6,select,option,input,button,.form-control,.font-bold{
    font-family:-apple-system,'Geeza Pro',sans-serif !important;
  }
  .num{font-family:'IBM Plex Sans',sans-serif !important}
}

/* --- Small screens ------------------------------------------------------- */
@media (max-width:520px){
  .bgsection2-title{font-size:1.22rem}
  .nav-greet{font-size:.8rem}
  .nav-site{font-size:.82rem}
  .summary{flex-direction:column;align-items:stretch;text-align:center}
  .txn-thead{display:none}
  .txn-row td.txn-main{padding-bottom:6px}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none !important;animation-duration:.001ms !important}
}
