/* =====================================================================
   PROJECT BINORIA X — Homepage sections
   Built on top of style.css (shared design system)
   ===================================================================== */

/* ============================ HERO ============================== */
.hero{ position:relative; color:#eaf3f2; overflow:hidden;
  background:radial-gradient(120% 120% at 78% 8%, var(--teal) 0%, var(--teal-deep) 42%, var(--teal-900) 100%); }
.hero__pattern{ position:absolute; inset:0; opacity:.10; pointer-events:none;
  background-size:300px; mix-blend-mode:overlay; }
.hero__glow{ position:absolute; width:560px; height:560px; border-radius:50%;
  background:radial-gradient(circle, rgba(184,134,11,.4), transparent 65%);
  filter:blur(40px); top:-160px; right:-120px; pointer-events:none; }
.hero__inner{ display:grid; gap:48px; align-items:center;
  padding-block:clamp(56px,8vw,96px); grid-template-columns:1fr; position:relative; z-index:3; }
@media(min-width:980px){ .hero__inner{ grid-template-columns:1.08fr .92fr; gap:60px; } }
.hero .eyebrow{ color:var(--gold-soft); }
.hero .eyebrow::before{ background:var(--gold-soft); }
.hero h1{ color:#fff; font-size:var(--step-5); margin-bottom:.35em; }
.hero h1 .accent{ color:var(--gold-soft); }
.hero__bismillah{ font-family:var(--font-arabic); direction:rtl; font-size:1.6rem;
  color:var(--gold-soft); margin-bottom:18px; opacity:.92; }
.hero__lead{ font-size:var(--step-1); color:rgba(255,255,255,.86); max-width:560px;
  margin-bottom:30px; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:34px; }
.hero__trust{ display:flex; flex-wrap:wrap; gap:26px 38px; padding-top:24px;
  border-top:1px solid rgba(255,255,255,.14); }
.hero__trust div{ line-height:1.2; }
.hero__trust b{ font-family:var(--font-display); font-size:1.55rem; color:#fff; display:block; }
.hero__trust span{ font-size:.78rem; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(255,255,255,.6); }

/* Hero visual — layered arch panel (graphic placeholder for campus photo) */
.hero__visual{ position:relative; }
.hero__arch{ position:relative; border-radius:240px 240px 24px 24px; overflow:hidden;
  aspect-ratio:4/4.6; border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(160deg,#0a6063,#022b2d);
  box-shadow:var(--shadow-lg); }
.hero__arch svg{ position:absolute; inset:0; width:100%; height:100%; opacity:.9; }
.hero__badge{ position:absolute; left:-18px; bottom:34px; background:#fff; color:var(--navy);
  border-radius:16px; padding:16px 20px; box-shadow:var(--shadow);
  display:flex; align-items:center; gap:14px; }
.hero__badge .hb-ic{ width:46px; height:46px; border-radius:12px; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold)); color:#1c1402; }
.hero__badge b{ font-family:var(--font-display); display:block; font-size:1.15rem; line-height:1; }
.hero__badge small{ color:var(--muted); font-size:.78rem; }

/* ======================= AT A GLANCE =========================== */
.glance{ background:linear-gradient(120deg,var(--teal-deep),var(--teal-900)); position:relative; }
.glance .girih-watermark{ opacity:.07; }
.glance__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px;
  position:relative; z-index:2; }
@media(min-width:760px){ .glance__grid{ grid-template-columns:repeat(4,1fr); } }
.glance .stat{ border-right:1px solid rgba(255,255,255,.1); }
.glance .stat:nth-child(2n){ border-right:none; }
@media(min-width:760px){ .glance .stat{ border-right:1px solid rgba(255,255,255,.1); }
  .glance .stat:nth-child(4n){ border-right:none; } }

/* ========================= ABOUT =============================== */
.about__media{ position:relative; }
.about__panel{ border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:5/4;
  background:linear-gradient(155deg,var(--teal),var(--teal-900)); position:relative;
  box-shadow:var(--shadow-lg); }
.about__panel svg{ position:absolute; inset:0; width:100%; height:100%; opacity:.85; }
.about__est{ position:absolute; right:-16px; top:-16px; background:var(--gold);
  color:#1c1402; border-radius:18px; padding:18px 22px; text-align:center;
  box-shadow:var(--shadow); font-family:var(--font-display); }
.about__est b{ display:block; font-size:1.9rem; line-height:1; }
.about__est span{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; }
.about__points{ display:grid; gap:16px; margin:26px 0 30px; }
.about__points li{ display:flex; gap:14px; align-items:flex-start; }
.about__points .ap-ic{ width:38px; height:38px; flex:none; border-radius:11px; display:grid;
  place-items:center; background:rgba(0,95,99,.1); color:var(--teal); }
.about__points b{ font-family:var(--font-display); color:var(--navy); display:block; font-size:.98rem; }
.about__points small{ color:var(--muted); }

/* ======================== TIMELINE ============================= */
.timeline{ position:relative; max-width:880px; margin-inline:auto; padding-left:8px; }
.timeline::before{ content:""; position:absolute; left:16px; top:8px; bottom:8px; width:2px;
  background:linear-gradient(var(--gold),var(--gold-line)); }
.tl-item{ position:relative; padding:0 0 38px 56px; }
.tl-item:last-child{ padding-bottom:0; }
.tl-node{ position:absolute; left:6px; top:2px; width:22px; height:22px; border-radius:50%;
  background:var(--white); border:3px solid var(--gold); box-shadow:0 0 0 5px rgba(184,134,11,.14);
  display:grid; place-items:center; }
.tl-node::after{ content:""; width:7px; height:7px; border-radius:50%; background:var(--teal); }
.bg-teal .tl-item h3,.bg-teal .tl-year{ color:#fff; }
.tl-year{ font-family:var(--font-display); font-weight:700; color:var(--gold);
  font-size:1.05rem; letter-spacing:.04em; }
.bg-teal .tl-year{ color:var(--gold-soft); }
.tl-item h3{ font-size:1.2rem; margin:.1em 0 .25em; }
.tl-item p{ margin:0; color:var(--muted); font-size:.95rem; }
.bg-teal .tl-item p{ color:rgba(255,255,255,.74); }

/* ====================== LEADERSHIP ============================= */
.leader{ text-align:center; }
.leader__photo{ width:130px; height:130px; border-radius:50%; margin:0 auto 18px;
  background:linear-gradient(150deg,var(--teal),var(--teal-900)); display:grid; place-items:center;
  color:var(--gold-soft); font-family:var(--font-display); font-weight:700; font-size:2rem;
  border:3px solid #fff; box-shadow:0 0 0 2px var(--gold-line), var(--shadow); position:relative; }
.leader__role{ font-size:.76rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold); font-weight:600; }
.leader h3{ font-size:1.18rem; margin:.2em 0 .1em; }
.leader p{ font-size:.9rem; color:var(--muted); margin:0; }

/* ==================== INTERNATIONAL MAP ======================== */
.world{ position:relative; }
.world__map{ position:relative; border-radius:var(--radius-lg); padding:30px;
  background:linear-gradient(150deg,var(--navy),var(--navy-deep)); overflow:hidden; }
.world__map svg{ width:100%; height:auto; color:rgba(255,255,255,.16); }
.world__dot{ fill:var(--gold-soft); }
.world__legend{ display:flex; flex-wrap:wrap; gap:16px 26px; margin-top:22px; }
.world__legend span{ display:inline-flex; align-items:center; gap:8px; font-size:.85rem;
  color:rgba(255,255,255,.8); }
.world__legend i{ width:10px; height:10px; border-radius:50%; background:var(--gold-soft); }

/* ====================== DARUL IFTA ============================= */
.ifta{ background:linear-gradient(135deg,var(--teal-deep),var(--teal-900)); position:relative;
  overflow:hidden; }
.ifta__inner{ display:grid; gap:46px; align-items:center; grid-template-columns:1fr; position:relative; z-index:2; }
@media(min-width:900px){ .ifta__inner{ grid-template-columns:1fr 1fr; } }
.ifta__card{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius); padding:26px; backdrop-filter:blur(6px); }
.ifta__card .arabic{ font-size:1.5rem; color:var(--gold-soft); margin-bottom:10px; }
.ifta__feats{ display:grid; gap:14px; margin-top:6px; }
.ifta__feats li{ display:flex; gap:12px; color:rgba(255,255,255,.86); align-items:flex-start; }
.ifta__feats svg{ width:20px; height:20px; color:var(--gold-soft); flex:none; margin-top:3px; }

/* ======================== GALLERY ============================== */
.gallery-grid{ display:grid; gap:14px; grid-template-columns:repeat(2,1fr);
  grid-auto-rows:160px; }
@media(min-width:760px){ .gallery-grid{ grid-template-columns:repeat(4,1fr); grid-auto-rows:180px; } }
.g-tile{ position:relative; border-radius:16px; overflow:hidden; cursor:pointer;
  background:linear-gradient(150deg,var(--teal),var(--teal-900)); border:1px solid var(--line);
  transition:transform .5s var(--ease); }
.g-tile svg{ position:absolute; inset:0; width:100%; height:100%; opacity:.8; }
.g-tile.wide{ grid-column:span 2; }
.g-tile.tall{ grid-row:span 2; }
.g-tile__cap{ position:absolute; inset:auto 0 0 0; padding:16px;
  background:linear-gradient(transparent,rgba(2,43,45,.85)); color:#fff;
  font-family:var(--font-display); font-weight:500; font-size:.92rem;
  transform:translateY(8px); opacity:0; transition:.4s var(--ease); }
.g-tile:hover{ transform:scale(.985); }
.g-tile:hover .g-tile__cap{ transform:none; opacity:1; }

/* Lightbox */
.lightbox{ position:fixed; inset:0; z-index:1500; background:rgba(2,15,16,.92);
  display:grid; place-items:center; padding:30px; opacity:0; visibility:hidden; transition:.35s; }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox__panel{ width:min(720px,92vw); aspect-ratio:16/10; border-radius:20px; overflow:hidden;
  position:relative; background:linear-gradient(150deg,var(--teal),var(--teal-900));
  box-shadow:var(--shadow-lg); }
.lightbox__panel svg{ position:absolute; inset:0; width:100%; height:100%; opacity:.85; }
.lightbox__cap{ position:absolute; inset:auto 0 0 0; padding:20px;
  background:linear-gradient(transparent,rgba(2,43,45,.9)); color:#fff;
  font-family:var(--font-display); }
.lightbox__close{ position:absolute; top:22px; right:22px; width:46px; height:46px; border-radius:12px;
  background:rgba(255,255,255,.12); color:#fff; border:none; display:grid; place-items:center; }

/* ========================= NEWS =============================== */
.news-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .5s var(--ease), box-shadow .5s; }
.news-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.news-card__media{ aspect-ratio:16/9; position:relative;
  background:linear-gradient(150deg,var(--teal),var(--teal-900)); }
.news-card__media svg{ position:absolute; inset:0; width:100%; height:100%; opacity:.8; }
.news-card__tag{ position:absolute; top:14px; left:14px; background:var(--gold); color:#1c1402;
  font-family:var(--font-display); font-weight:600; font-size:.72rem; letter-spacing:.06em;
  padding:5px 12px; border-radius:999px; }
.news-card__body{ padding:22px 24px 26px; }
.news-card__date{ font-size:.78rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--gold); font-weight:600; }
.news-card h3{ font-size:1.12rem; margin:.45em 0 .4em; }
.news-card p{ font-size:.9rem; color:var(--muted); margin-bottom:0; }

/* ===================== SPONSORSHIP / DONATION ================== */
.sponsor{ background:linear-gradient(150deg,var(--navy),var(--navy-deep)); position:relative;
  overflow:hidden; color:#fff; }
.sponsor__inner{ display:grid; gap:44px; align-items:center; grid-template-columns:1fr;
  position:relative; z-index:2; }
@media(min-width:920px){ .sponsor__inner{ grid-template-columns:1.05fr .95fr; } }
.sponsor__cost{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius); padding:30px; backdrop-filter:blur(6px); }
.sponsor__cost .row{ display:flex; justify-content:space-between; padding:14px 0;
  border-bottom:1px dashed rgba(255,255,255,.16); }
.sponsor__cost .row:last-child{ border-bottom:none; font-family:var(--font-display);
  font-weight:600; color:var(--gold-soft); font-size:1.1rem; }
.sponsor__cost .row b{ color:#fff; font-family:var(--font-display); }

.give-grid{ display:grid; gap:18px; grid-template-columns:repeat(2,1fr); }
@media(min-width:880px){ .give-grid{ grid-template-columns:repeat(3,1fr); } }
.give-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:26px 22px; text-align:center; transition:transform .4s var(--ease), box-shadow .4s;
  position:relative; }
.give-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--gold-line); }
.give-card__ic{ width:54px; height:54px; border-radius:14px; margin:0 auto 14px; display:grid;
  place-items:center; background:linear-gradient(135deg,rgba(0,95,99,.12),rgba(184,134,11,.14));
  color:var(--teal); }
.give-card h4{ font-size:1.04rem; margin-bottom:.3em; }
.give-card p{ font-size:.84rem; color:var(--muted); margin-bottom:0; }

/* Bank details */
.bank-grid{ display:grid; gap:18px; grid-template-columns:1fr; }
@media(min-width:680px){ .bank-grid{ grid-template-columns:repeat(2,1fr); } }
.bank-card{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:22px 24px;
  box-shadow:var(--shadow-sm); }
.bank-card__top{ display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding-bottom:14px; margin-bottom:14px; border-bottom:1px solid var(--line-soft); }
.bank-card__name{ font-family:var(--font-display); font-weight:600; color:var(--navy); }
.bank-card__name small{ display:block; font-weight:500; color:var(--muted); font-size:.74rem;
  letter-spacing:.04em; }
.bank-card__chip{ font-family:var(--font-display); font-weight:700; font-size:.72rem;
  color:var(--teal); background:rgba(0,95,99,.08); padding:5px 11px; border-radius:8px;
  letter-spacing:.05em; }
.bank-row{ display:flex; justify-content:space-between; gap:14px; padding:7px 0; font-size:.86rem; }
.bank-row span{ color:var(--muted); }
.bank-row b{ font-family:var(--font-body); color:var(--ink); font-weight:600;
  font-variant-numeric:tabular-nums; word-break:break-all; text-align:right; }

/* ======================== FAQ ================================= */
.faq{ max-width:820px; margin-inline:auto; }
.faq-item{ background:#fff; border:1px solid var(--line); border-radius:14px; margin-bottom:12px;
  overflow:hidden; }
.faq-q{ width:100%; text-align:left; background:none; border:none; padding:20px 22px;
  font-family:var(--font-display); font-weight:600; color:var(--navy); font-size:1rem;
  display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq-q svg{ width:22px; height:22px; color:var(--gold); flex:none; transition:transform .35s; }
.faq-item.open .faq-q svg{ transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a p{ padding:0 22px 20px; margin:0; color:var(--muted); font-size:.93rem; }

/* ===================== CONTACT CTA ============================ */
.cta-band{ background:radial-gradient(120% 140% at 20% 0%, var(--gold) 0%, transparent 55%),
  linear-gradient(135deg,var(--teal-deep),var(--teal-900)); position:relative; overflow:hidden; }
.cta-band__inner{ position:relative; z-index:2; text-align:center; max-width:760px;
  margin-inline:auto; }
.cta-band h2{ color:#fff; }
.cta-band p{ color:rgba(255,255,255,.85); font-size:var(--step-1); }
.cta-band__btns{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin-top:30px; }

/* ============ REAL PHOTO INTEGRATION ============ */
.hero__arch img,.about__panel img,.g-tile img,.news-card__media img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.leader__photo img{ width:100%; height:100%; object-fit:cover; border-radius:50%; }
.leader__photo{ overflow:hidden; }
