:root{
  /* Navy + gold palette to match the Jamia logo */
  --green:#17255e; --green-dark:#0e1640; --green-light:#2c3f8f;
  --gold:#c9a227; --gold-dark:#a9851a; --gold-light:#e4c75a;
  --cream:#f6f7fb; --ink:#1c2230; --muted:#6b7280; --line:#e4e7f0;
  --white:#fff; --surface:#fff; --surface-2:#f6f7fb; --radius:14px; --shadow:0 10px 30px rgba(23,37,94,.12);
  --shadow-sm:0 4px 14px rgba(15,22,64,.08);
  --font:'Poppins',system-ui,sans-serif; --font-ar:'Noto Naskh Arabic','Amiri',serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--cream);line-height:1.65;font-size:16px}
body.rtl{font-family:var(--font-ar);direction:rtl}
body.rtl .prose,body.rtl h1,body.rtl h2,body.rtl h3,body.rtl h4{font-family:var(--font-ar)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:1180px;margin:0 auto;padding:0 20px}
.center{text-align:center;margin-top:30px}
.narrow{max-width:820px}
.mt{margin-top:40px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;font-family:inherit;
  font-weight:600;padding:12px 24px;border-radius:50px;font-size:15px;transition:.2s;line-height:1}
.btn-sm{padding:9px 18px;font-size:14px}
.btn-lg{padding:15px 32px;font-size:16px}
.btn-block{display:flex;justify-content:center;width:100%;margin-top:10px}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-dark)}
.btn-gold{background:var(--gold);color:#3a2e07}
.btn-gold:hover{background:var(--gold-dark);color:#fff}
.btn-light{background:var(--surface);color:var(--green)}
.btn-light:hover{background:var(--cream)}
.btn-outline{background:transparent;border:2px solid var(--green);color:var(--green)}
.btn-outline:hover{background:var(--green);color:#fff}

/* Topbar */
.topbar{background:var(--green-dark);color:#d8e6df;font-size:13.5px}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;min-height:42px;flex-wrap:wrap;gap:10px}
.topbar a{color:#d8e6df;transition:.2s}
.topbar a:hover{color:var(--gold-light)}
.topbar-contact{display:flex;gap:20px}
.topbar-right{display:flex;align-items:center;gap:18px}
.lang-switch{display:flex;gap:4px}
.lang-switch a{padding:3px 10px;border-radius:20px;font-weight:500}
.lang-switch a.active{background:var(--gold);color:#3a2e07}
.topbar-social{display:flex;gap:12px}

/* Prayer-times dropdown (in topbar) */
.prayer-menu{position:relative}
.prayer-menu summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.1);padding:3px 12px;border-radius:20px;font-weight:500;user-select:none}
.prayer-menu summary::-webkit-details-marker{display:none}
.prayer-menu summary i:first-child{color:var(--gold-light)}
.prayer-menu summary .caret{font-size:10px;transition:transform .2s}
.prayer-menu[open] summary .caret{transform:rotate(180deg)}
.prayer-dropdown{position:absolute;inset-inline-end:0;top:calc(100% + 8px);z-index:120;width:240px;
  background:var(--surface);color:var(--ink);border-radius:12px;box-shadow:0 14px 40px rgba(15,22,64,.25);
  padding:14px 16px;border:1px solid var(--line)}
body.rtl .prayer-dropdown{inset-inline-end:auto;inset-inline-start:0}
.prayer-dropdown::before{content:"";position:absolute;top:-6px;inset-inline-end:18px;width:12px;height:12px;
  background:var(--surface);border-inline-start:1px solid var(--line);border-top:1px solid var(--line);transform:rotate(45deg)}
.pd-head{display:flex;flex-direction:column;gap:3px;padding-bottom:10px;margin-bottom:8px;
  border-bottom:1px dashed var(--line);font-size:13px;color:var(--green)}
.pd-head i{color:var(--gold)}
.pd-city{color:var(--muted)}
.pd-times{list-style:none}
.pd-times li{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13.5px;border-bottom:1px solid #f1f1f1}
.pd-times li:last-child{border:none}
.pd-times li span{color:var(--muted)}
.pd-times li strong{color:var(--green);font-weight:600}

/* Header */
.site-header{background:var(--surface);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:78px;gap:16px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand-mark{width:56px;height:56px;border-radius:12px;display:block;flex-shrink:0;object-fit:contain;background:var(--surface)}
.brand-footer .brand-mark{width:54px;height:54px;padding:5px;border-radius:12px}
.brand-text strong{display:block;font-size:18px;color:var(--green);line-height:1.2;white-space:nowrap}
.brand-text small{color:var(--muted);font-size:11.5px;white-space:nowrap}
.main-nav{display:flex;align-items:center;gap:4px}
.main-nav>a{padding:8px 11px;font-weight:500;color:var(--ink);border-radius:8px;font-size:14.5px;white-space:nowrap}
.main-nav>a:hover,.main-nav>a.active{color:var(--green);background:rgba(23,37,94,.07)}
.nav-toggle{display:none;background:none;border:none;color:var(--green);cursor:pointer;padding:6px;line-height:0}
.nav-toggle svg{display:block}

/* Hero */
.hero{position:relative;background:linear-gradient(135deg,var(--green-dark),var(--green) 60%,var(--green-light));
  color:#fff;padding:110px 0;overflow:hidden}
.hero-overlay{position:absolute;inset:0;opacity:.12;
  background-image:radial-gradient(circle at 20% 20%,#fff 2px,transparent 2px),radial-gradient(circle at 80% 70%,#fff 2px,transparent 2px);
  background-size:60px 60px}
.hero-content{position:relative;text-align:center;max-width:820px}
.hero-badge{display:inline-flex;gap:8px;align-items:center;background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.3);padding:8px 18px;border-radius:50px;font-size:14px;margin-bottom:22px}
.hero h1{font-size:clamp(34px,5vw,58px);line-height:1.1;margin-bottom:16px}
.hero-tagline{font-size:20px;opacity:.92;margin-bottom:14px}
.hero-ayah{font-family:var(--font-ar);font-size:30px;color:var(--gold-light);margin:18px 0 28px}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-icon{font-size:46px;color:var(--gold-light);margin-bottom:14px}

/* Stats */
.stats-bar{background:var(--surface);box-shadow:var(--shadow-sm);position:relative;z-index:2}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);text-align:center}
.stat{padding:28px 10px;border-right:1px solid var(--line)}
.stat:last-child{border:none}
body.rtl .stat{border-right:none;border-left:1px solid var(--line)}
.stat i{font-size:26px;color:var(--gold);display:block;margin-bottom:8px}
.stat strong{display:block;font-size:26px;color:var(--green)}
.stat span{color:var(--muted);font-size:14px}

/* Sections */
.section{padding:72px 0}
.section-alt{background:var(--surface)}
.section-dark{background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff}
.section-head{text-align:center;max-width:680px;margin:0 auto 46px}
.section-head h2{font-size:clamp(26px,3.5vw,38px);color:var(--green);margin-bottom:10px;position:relative;display:inline-block;padding-bottom:14px}
.section-head h2::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:70px;height:4px;border-radius:4px;background:var(--gold)}
.section-head p{color:var(--muted);font-size:17px}
.section-head.light h2{color:#fff}.section-head.light p{color:rgba(255,255,255,.8)}

/* Cards grid */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:26px}

/* Course cards */
.course-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:.25s;display:flex;flex-direction:column}
.course-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.course-card-top{height:120px;position:relative;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,var(--green),var(--green-light))}
.course-card-top.cat-hifz{background:linear-gradient(135deg,#1d6f8b,#2a9fb8)}
.course-card-top.cat-nazra{background:linear-gradient(135deg,#7a4ba8,#9b6fc4)}
.course-card-top.cat-professional{background:linear-gradient(135deg,#b06a2c,#d4944a)}
.course-card-top.cat-online{background:linear-gradient(135deg,#0a6e63,#13a394)}
.course-card-top i{font-size:40px}
.course-card-top .badge{position:absolute;top:12px;inset-inline-end:12px;background:rgba(0,0,0,.25);
  padding:4px 12px;border-radius:20px;font-size:12px}
.course-card-body{padding:22px;display:flex;flex-direction:column;flex:1}
.course-card-body h3{color:var(--green);font-size:19px;margin-bottom:8px}
.course-card-body p{color:var(--muted);font-size:14.5px;flex:1}
.meta{list-style:none;display:flex;flex-wrap:wrap;gap:14px;margin:14px 0;font-size:13px;color:var(--muted)}
.meta i{color:var(--gold)}

/* Filter chips */
.filter-bar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px}
.chip{padding:8px 20px;border-radius:50px;background:var(--surface);border:1px solid var(--line);font-size:14px;font-weight:500;color:var(--ink)}
.chip.active,.chip:hover{background:var(--green);color:#fff;border-color:var(--green)}

/* Progress */
.overall-progress{background:var(--surface);padding:24px;border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:40px}
.overall-progress-info{display:flex;justify-content:space-between;margin-bottom:12px;font-size:15px}
.progress-track{background:#e9ecef;border-radius:50px;height:26px;overflow:hidden}
.progress-track.sm{height:18px}
.progress-fill{height:100%;display:flex;align-items:center;justify-content:flex-end;padding-inline-end:10px;
  color:#fff;font-size:12px;font-weight:600;border-radius:50px;transition:width .8s ease}
.project-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.project-card-img{height:130px;background:linear-gradient(135deg,var(--green-dark),var(--green-light));display:grid;place-items:center;color:rgba(255,255,255,.4);font-size:44px}
.project-card-body{padding:22px}
.project-card-body h3{color:var(--green);margin:10px 0 8px}
.project-card-body p{color:var(--muted);font-size:14.5px;margin-bottom:14px}
.project-card.wide{width:100%}
.status{display:inline-block;padding:4px 14px;border-radius:50px;font-size:12px;font-weight:600;text-transform:capitalize}
.status-in_progress{background:#fff3cd;color:#8a6d00}
.status-completed{background:#d1e7dd;color:#0f5132}
.status-planning{background:#e2e3e5;color:#41464b}
.fund-row{display:flex;justify-content:space-between;font-size:13.5px;margin:12px 0;color:var(--muted)}

/* Timeline */
.timeline{position:relative;padding-inline-start:40px}
.timeline::before{content:"";position:absolute;inset-inline-start:11px;top:0;bottom:0;width:3px;background:var(--line)}
.timeline-item{position:relative;margin-bottom:34px}
.timeline-dot{position:absolute;inset-inline-start:-40px;top:14px;width:46px;height:46px;border-radius:50%;
  background:var(--green);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:700;border:3px solid var(--cream)}

/* Features */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.feature{background:var(--surface);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);text-align:center;transition:.25s}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.feature i{font-size:34px;color:var(--gold);margin-bottom:14px}
.feature h4{color:var(--green);margin-bottom:8px}
.feature p{color:var(--muted);font-size:14.5px}

/* Initiative cards */
.init-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:30px;text-align:center}
.init-card.light-card{background:var(--surface);border-color:var(--line);box-shadow:var(--shadow-sm);color:var(--ink)}
.init-card i{font-size:38px;color:var(--gold-light);margin-bottom:14px}
.init-card.light-card i{color:var(--gold)}
.init-card h3{margin-bottom:10px}
.init-card.light-card h3{color:var(--green)}
.init-card p{opacity:.9;font-size:14.5px;margin-bottom:14px}

/* links */
.link-more{display:inline-flex;gap:6px;align-items:center;color:var(--green);font-weight:600;font-size:14px;margin-top:6px}
.link-more.light{color:var(--gold-light)}
.link-more:hover{gap:10px}

/* Post cards */
.post-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.25s}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.post-card-img{height:170px;background:linear-gradient(135deg,#244,#479);display:grid;place-items:center;color:rgba(255,255,255,.5);font-size:40px;overflow:hidden}
.post-card-img img{width:100%;height:100%;object-fit:cover}
.post-card-body{padding:22px}
.post-card-body time{color:var(--gold-dark);font-size:13px;font-weight:600}
.post-card-body h3{color:var(--green);margin:6px 0 8px;font-size:19px}
.post-card-body p{color:var(--muted);font-size:14.5px}
.post-cover{border-radius:var(--radius);margin-bottom:24px}

/* Faculty */
.faculty-card{background:var(--surface);border-radius:var(--radius);padding:28px;text-align:center;box-shadow:var(--shadow-sm)}
.faculty-photo{width:110px;height:110px;border-radius:50%;margin:0 auto 16px;overflow:hidden;background:var(--cream);display:grid;place-items:center;font-size:42px;color:var(--green-light);border:4px solid var(--gold-light)}
.faculty-photo img{width:100%;height:100%;object-fit:cover}
.faculty-card h3{color:var(--green);font-size:19px}
.faculty-title{color:var(--gold-dark);font-size:14px;font-weight:600;display:block;margin-bottom:10px}
.faculty-card p{color:var(--muted);font-size:14px}

/* Page hero */
.page-hero{background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;padding:70px 0;text-align:center}
.page-hero h1{font-size:clamp(28px,4vw,44px)}
.page-hero p{opacity:.9;margin-top:10px;max-width:680px;margin-inline:auto}
.page-hero .hero-time,.hero-time{color:var(--gold-light);font-weight:600}
.hero-donate{background:linear-gradient(135deg,#7a5b10,var(--gold-dark))}

/* Detail layout */
.detail-layout{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start}
.detail-side{position:sticky;top:100px}
.info-card{background:var(--surface);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}
.info-card h3{color:var(--green);margin-bottom:16px;font-size:18px}
.info-card ul{list-style:none;margin-bottom:18px}
.info-card li{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--line);font-size:14.5px}
.info-card li span{color:var(--muted)}
.prose{font-size:16px;color:#374151}
.prose p{margin-bottom:16px}
.update-list{display:flex;flex-direction:column;gap:18px}
.update-item{background:var(--surface);border-inline-start:4px solid var(--gold);padding:18px 22px;border-radius:10px;box-shadow:var(--shadow-sm)}
.update-item time{color:var(--gold-dark);font-weight:600;font-size:13px}
.update-item h4{color:var(--green);margin:4px 0 6px}
.pill{background:var(--green);color:#fff;font-size:11px;padding:2px 10px;border-radius:20px;vertical-align:middle}

/* Split / online */
.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.split h2{color:var(--green);margin-bottom:14px}
.ticks{list-style:none;margin:18px 0}
.ticks li{padding:8px 0;padding-inline-start:30px;position:relative}
.ticks li::before{content:"\f058";font-family:"Font Awesome 6 Free";font-weight:900;color:var(--green-light);position:absolute;inset-inline-start:0}
.online-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.online-card{background:var(--surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);text-align:center}
.online-card i{font-size:30px;color:var(--gold);margin-bottom:10px}
.online-card h4{color:var(--green);margin-bottom:6px}
.online-card p{color:var(--muted);font-size:13.5px}

/* Forms */
.form-card{background:var(--surface);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px;color:var(--green-dark)}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:15px;background:#fbfaf6}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green-light);background:var(--surface)}
.success-box{background:#d1e7dd;color:#0f5132;padding:18px 22px;border-radius:12px;display:flex;gap:12px;align-items:center;margin-bottom:24px}
.success-box i{font-size:24px}

/* Donate */
.donate-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.donate-methods h2,.donate-form-wrap h2{color:var(--green);margin-bottom:20px}
.method-block{background:var(--surface);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);margin-bottom:20px}
.method-block h3{color:var(--green);font-size:17px;margin-bottom:14px;display:flex;gap:10px;align-items:center}
.bank-row{padding:12px 0;border-bottom:1px dashed var(--line);display:flex;flex-direction:column;gap:2px}
.bank-row:last-child{border:none}
.bank-row code{background:var(--cream);padding:6px 10px;border-radius:6px;font-size:14px;color:var(--green-dark);width:fit-content}
.bank-row em{color:var(--gold-dark);font-size:13px}
.wallet-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px dashed var(--line)}
.wallet-row:last-child{border:none}

/* Contact */
.contact-layout{display:grid;grid-template-columns:340px 1fr;gap:40px;align-items:start}
.ci-item{display:flex;gap:16px;background:var(--surface);padding:20px;border-radius:12px;box-shadow:var(--shadow-sm);margin-bottom:16px}
.ci-item i{font-size:22px;color:var(--gold);width:30px}
.ci-item h4{color:var(--green);font-size:15px}
.ci-item p{color:var(--muted);font-size:14px}
.map-embed{margin-top:40px;border-radius:var(--radius);overflow:hidden}
.map-embed iframe{width:100%;border:0}

/* Daily inspiration */
.inspiration{background:var(--green);padding:40px 0;color:#fff}
.inspiration-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.insp-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:26px;text-align:center}
.insp-label{color:var(--gold-light);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1px}
.insp-arabic{font-family:var(--font-ar);font-size:26px;line-height:1.9;margin:14px 0 10px;color:#fff}
.insp-trans{opacity:.9;font-size:15px}
.insp-card cite{display:block;margin-top:10px;color:var(--gold-light);font-style:normal;font-size:13px}

/* Event cards */
.event-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;gap:18px;padding:20px;align-items:center}
.event-date{background:var(--green);color:#fff;border-radius:12px;width:64px;min-width:64px;text-align:center;padding:10px 0}
.event-date strong{display:block;font-size:26px;line-height:1}
.event-date span{font-size:12px;text-transform:uppercase}
.event-body h3{color:var(--green);font-size:18px;margin-bottom:6px}
.event-body p{color:var(--muted);font-size:13.5px;margin-bottom:8px}
.event-body i{color:var(--gold)}

/* Testimonials */
.testi-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:26px}
.testi-stars{color:var(--gold);margin-bottom:12px}
.testi-card p{font-size:15px;color:#374151;font-style:italic;margin-bottom:18px}
.testi-by{display:flex;align-items:center;gap:12px}
.testi-avatar{width:46px;height:46px;border-radius:50%;background:var(--cream);display:grid;place-items:center;color:var(--green);overflow:hidden}
.testi-avatar img{width:100%;height:100%;object-fit:cover}
.testi-by strong{display:block;color:var(--green)}
.testi-by span{color:var(--muted);font-size:13px}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:#3a2e07;padding:54px 0}
.cta-inner{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.cta-inner h2{font-size:30px;margin-bottom:6px}

/* Footer */
.site-footer{background:var(--green-dark);color:#cdddd4;padding-top:60px;font-size:14.5px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:40px}
.brand-footer{margin-bottom:16px}
.brand-footer strong{color:#fff;font-size:18px}
.footer-col h4{color:#fff;margin-bottom:18px;font-size:16px;position:relative;padding-bottom:10px}
.footer-col h4::after{content:"";position:absolute;bottom:0;inset-inline-start:0;width:36px;height:3px;background:var(--gold)}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a:hover{color:var(--gold-light)}
.footer-contact li{display:flex;gap:10px}
.footer-contact i{color:var(--gold-light);width:18px}
.footer-social{display:flex;gap:12px;margin-top:14px}
.footer-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);display:grid;place-items:center}
.footer-social a:hover{background:var(--gold);color:#3a2e07}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:18px 0;text-align:center;font-size:13.5px}
.footer-bottom a{color:var(--gold-light)}

/* Receipt */
.receipt{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-sm)}
.receipt-head{display:flex;align-items:center;gap:16px;border-bottom:2px solid var(--gold);padding-bottom:18px;margin-bottom:18px}
.receipt-head h2{color:var(--green)}
.receipt-head p{color:var(--muted);font-size:13px}
.receipt-title{text-align:center;color:var(--green);font-size:24px;margin-bottom:10px}
.receipt-status{text-align:center;font-weight:600;padding:6px;border-radius:8px;margin-bottom:18px}
.receipt-status.status-confirmed{background:#d1e7dd;color:#0f5132}
.receipt-status.status-pending{background:#fff3cd;color:#8a6d00}
.receipt-table{width:100%;border-collapse:collapse;margin-bottom:18px}
.receipt-table td,.receipt-table th{padding:10px 6px;border-bottom:1px dashed var(--line);text-align:start}
.receipt-table td{color:var(--muted)}
.receipt-table .amt{color:var(--green);font-size:18px}
.receipt-note{background:var(--cream);padding:14px;border-radius:10px;text-align:center;color:var(--green-dark)}
.receipt-foot{color:var(--muted);font-size:12px;text-align:center;margin-top:12px}
.checkout-amt{font-size:38px;color:var(--green);font-weight:700}
@media print{
  .topbar,.prayer-strip,.site-header,.site-footer,.no-print,.wa-float{display:none!important}
  body{background:var(--surface)}
  .receipt{border:none;box-shadow:none}
}

/* Section block titles */
.block-title{color:var(--green);font-size:24px;margin-bottom:22px;padding-bottom:10px;border-bottom:2px solid var(--line)}
.nav-search{padding:8px 11px;color:var(--green);border-radius:8px}
.nav-search:hover{background:rgba(23,37,94,.07)}

/* Resources / library */
.resource-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;gap:0;overflow:hidden}
.resource-icon{width:90px;min-width:90px;display:grid;place-items:center;font-size:30px;color:#fff;background:var(--green)}
.resource-icon.type-pdf{background:#b03a3a}.resource-icon.type-audio{background:#7a4ba8}.resource-icon.type-video{background:#b06a2c}
.resource-body{padding:18px 20px}
.resource-body h3{color:var(--green);font-size:17px;margin:6px 0 6px}
.resource-body p{color:var(--muted);font-size:13.5px;margin-bottom:12px}
.badge-soft{display:inline-block;background:var(--cream);color:var(--green-dark);padding:2px 10px;border-radius:20px;font-size:11.5px;font-weight:600;text-transform:capitalize}

/* Gallery */
.album-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:block;transition:.25s}
.album-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.album-cover{height:180px;background:linear-gradient(135deg,var(--green-dark),var(--green-light));display:grid;place-items:center;color:rgba(255,255,255,.5);font-size:40px;overflow:hidden}
.album-cover img{width:100%;height:100%;object-fit:cover}
.album-info{padding:16px 20px}
.album-info h3{color:var(--green);font-size:17px}
.album-info span{color:var(--muted);font-size:13px}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:20px}
.g-item{border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:4/3;display:block}
.g-item img{width:100%;height:100%;object-fit:cover}
.g-video{aspect-ratio:16/9;grid-column:span 2}
.g-video iframe{width:100%;height:100%;border:0}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:12px;margin-bottom:30px}
.faq-item{background:var(--surface);border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden}
.faq-item summary{padding:16px 20px;font-weight:600;color:var(--green);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-item summary::after{content:"+";font-size:22px;color:var(--gold)}
.faq-item[open] summary::after{content:"−"}
.faq-answer{padding:0 20px 18px;color:#374151}

/* Search */
.search-form{display:flex;gap:10px;margin-bottom:24px}
.search-form input{flex:1;padding:14px 16px;border:1px solid var(--line);border-radius:10px;font-size:15px;background:var(--surface)}
.search-results{display:flex;flex-direction:column;gap:10px}
.search-result{background:var(--surface);border-radius:10px;padding:14px 18px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:14px}
.search-result:hover{box-shadow:var(--shadow)}
.search-result h3{color:var(--green);font-size:16px}

/* Schedule table */
.table-wrap{overflow-x:auto}
.schedule-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.schedule-table th{background:var(--green);color:#fff;padding:14px 16px;text-align:start;font-size:14px}
.schedule-table td{padding:14px 16px;border-bottom:1px solid var(--line);font-size:14px}
.schedule-table tr:last-child td{border:none}

/* Newsletter */
.newsletter-bar{background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:#3a2e07;padding:30px 0}
.newsletter-inner{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.newsletter-inner h3{font-size:20px}
.newsletter-form{display:flex;gap:10px}
.newsletter-form input{padding:12px 16px;border:none;border-radius:50px;min-width:240px;font-family:inherit}
.newsletter-form .btn{background:var(--green);color:#fff}
.newsletter-form .btn:hover{background:var(--green-dark)}

/* WhatsApp float */
.wa-float{position:fixed;bottom:22px;inset-inline-end:22px;width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;display:grid;place-items:center;font-size:28px;box-shadow:0 8px 24px rgba(37,211,102,.5);z-index:200;transition:.2s}
.wa-float:hover{transform:scale(1.08)}

/* Portal */
.portal-wrap{max-width:1000px;margin:0 auto}
.portal-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:26px;margin-bottom:22px}
.portal-card h2{color:var(--green);font-size:19px;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.portal-stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:22px}
.portal-stat{background:var(--surface);border-radius:12px;padding:20px;box-shadow:var(--shadow-sm);text-align:center}
.portal-stat strong{display:block;font-size:26px;color:var(--green)}
.portal-stat span{color:var(--muted);font-size:13px}
.login-narrow{max-width:420px;margin:0 auto}

/* Timetable grid */
.tt-grid{width:100%;border-collapse:collapse;min-width:680px}
.tt-grid th{background:var(--green);color:#fff;padding:10px;font-size:13px}
.tt-grid td{border:1px solid var(--line);padding:8px;text-align:center;vertical-align:top}
.tt-period{background:var(--cream);font-weight:700;color:var(--green)}
.tt-cell strong{display:block;color:var(--green);font-size:13.5px}
.tt-cell small{display:block;color:var(--muted);font-size:11.5px}

/* Datesheet */
.exam-block{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:28px;overflow:hidden}
.exam-head{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;padding:20px 26px}
.exam-head h2{font-size:21px;margin:0}
.exam-meta{opacity:.85;font-size:13.5px}
.exam-date-badge{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);padding:6px 16px;border-radius:30px;font-size:13.5px}
.ds-table{width:100%;border-collapse:collapse;min-width:600px}
.ds-table th{background:var(--cream);color:var(--green);text-align:start;padding:12px 16px;font-size:13px;border-bottom:2px solid var(--line)}
.ds-table td{padding:12px 16px;border-bottom:1px solid var(--line);font-size:14.5px}
.ds-table tr:hover td{background:#fafdfb}
.table-wrap{overflow-x:auto}
.exam-instr{padding:14px 26px;background:#fff8e6;color:#8a6d00;font-size:13.5px;margin:0}

/* Flash & misc */
.flash{padding:14px 20px;border-radius:10px;margin:20px 0}
.flash-success{background:#d1e7dd;color:#0f5132}
.flash-error{background:#f8d7da;color:#842029}
.empty{text-align:center;color:var(--muted);padding:30px}
.error-page h1{font-size:90px;color:var(--green)}

/* Responsive */
@media(max-width:980px){
  .detail-layout,.donate-layout,.contact-layout,.split,.cta-inner{grid-template-columns:1fr}
  .detail-side{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:none}
}
@media(max-width:1400px){
  .nav-toggle{display:block}
  .main-nav{position:fixed;inset-block:0;inset-inline-end:-100%;width:78%;max-width:320px;background:var(--surface);
    flex-direction:column;align-items:stretch;padding:90px 24px 30px;gap:4px;transition:.3s;box-shadow:-10px 0 40px rgba(0,0,0,.1);overflow-y:auto}
  .main-nav.open{inset-inline-end:0}
  .main-nav .btn{margin-top:8px;justify-content:center}
  .form-row{grid-template-columns:1fr}
  .online-cards{grid-template-columns:1fr}
}
@media(max-width:560px){
  .footer-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .topbar-contact{display:none}
}

/* Portal learning grid */
.learn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.learn-box{background:#fbfaf6;border:1px solid var(--line);border-radius:12px;padding:18px}
.learn-box h3{color:var(--green);font-size:16px;margin-bottom:12px;display:flex;gap:8px;align-items:center}
.learn-box .schedule-table{width:100%;font-size:13.5px}
.learn-list{list-style:none}
.learn-list li{padding:8px 0;border-bottom:1px dashed var(--line)}
.learn-list li:last-child{border:none}
.learn-list a{color:var(--green);font-weight:500}
.learn-list a:hover{color:var(--gold-dark)}

/* ===== Initiatives — modern Islamic design ===== */
.ini-hero{position:relative;overflow:hidden;color:#fff;text-align:center;padding:84px 0 76px;
  background:linear-gradient(135deg,var(--green-dark) 0%,var(--green) 55%,var(--green-light) 100%)}
.ini-hero-pattern{position:absolute;inset:0;opacity:.10;pointer-events:none;
  background-image:radial-gradient(circle at 15% 25%,#fff 1.5px,transparent 1.6px),radial-gradient(circle at 75% 65%,#fff 1.5px,transparent 1.6px);
  background-size:46px 46px}
.ini-hero-inner{position:relative;max-width:760px;margin:0 auto}
.ini-kicker{display:inline-flex;gap:8px;align-items:center;background:rgba(255,255,255,.12);
  border:1px solid rgba(228,199,90,.5);color:var(--gold-light);padding:7px 18px;border-radius:50px;font-size:13.5px;font-weight:500;margin-bottom:18px}
.ini-hero h1{font-size:clamp(30px,4.6vw,50px);line-height:1.1;margin-bottom:14px}
.ini-ayah{font-family:var(--font-ar);font-size:26px;color:var(--gold-light);margin:6px 0 16px}
.ini-lead{font-size:17px;opacity:.92;line-height:1.7}

.ini-section{background:
  radial-gradient(circle at 50% -10%, rgba(23,37,94,.06), transparent 60%), var(--cream)}
.ini-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:26px}
.ini-card{position:relative;display:flex;flex-direction:column;background:var(--surface);border-radius:18px;
  padding:34px 28px 26px;box-shadow:0 6px 22px rgba(15,22,64,.07);overflow:hidden;
  border:1px solid #eef0f7;transition:transform .28s,box-shadow .28s}
.ini-card::before{content:"";position:absolute;top:0;inset-inline-start:0;width:100%;height:5px;
  background:linear-gradient(90deg,var(--gold),var(--gold-light))}
.ini-card:hover{transform:translateY(-8px);box-shadow:0 20px 46px rgba(15,22,64,.16)}
.ini-medallion{width:72px;height:72px;border-radius:18px;display:grid;place-items:center;font-size:28px;
  color:#fff;margin-bottom:18px;background:linear-gradient(135deg,var(--green),var(--green-light));
  box-shadow:0 8px 20px rgba(23,37,94,.25);position:relative}
.ini-medallion::after{content:"";position:absolute;inset:-4px;border-radius:22px;border:1.5px solid rgba(201,162,39,.4)}
.ini-card.ac-b .ini-medallion{background:linear-gradient(135deg,#1d6f8b,#2a9fb8)}
.ini-card.ac-c .ini-medallion{background:linear-gradient(135deg,#7a4ba8,#9b6fc4)}
.ini-card.ac-d .ini-medallion{background:linear-gradient(135deg,#b06a2c,#d4944a)}
.ini-card h3{color:var(--green);font-size:20px;margin-bottom:10px;line-height:1.3}
.ini-card p{color:var(--muted);font-size:14.5px;line-height:1.7;flex:1;margin-bottom:18px}
.ini-more{display:inline-flex;align-items:center;gap:8px;color:var(--gold-dark);font-weight:600;font-size:14px}
.ini-card:hover .ini-more{gap:13px;color:var(--green)}
.ini-more i{transition:transform .25s}

/* Impact strip */
.impact-strip{background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;padding:46px 0}
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.impact-item{padding:8px}
.impact-item i{font-size:26px;color:var(--gold-light);margin-bottom:10px;display:block}
.impact-item strong{display:block;font-size:26px;line-height:1.1}
.impact-item span{opacity:.82;font-size:14px}

/* Initiatives CTA */
.ini-cta{padding:64px 0;background:var(--cream)}
.ini-cta-inner{background:linear-gradient(120deg,#fff,#fbf7ea);border:1px solid #efe6c8;border-radius:22px;
  padding:42px 46px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;
  box-shadow:0 14px 40px rgba(15,22,64,.08)}
.ini-cta-inner h2{color:var(--green);font-size:28px;margin-bottom:8px}
.ini-cta-inner p{color:var(--muted);max-width:560px}
.ini-cta-inner em{color:var(--gold-dark);font-style:italic}
.ini-cta-actions{display:flex;gap:12px;flex-wrap:wrap}
@media(max-width:760px){.impact-grid{grid-template-columns:1fr 1fr}.ini-cta-inner{padding:30px}}

/* ===== Advanced animated hero slider ===== */
.hero-slider{position:relative;overflow:hidden;min-height:clamp(560px,86vh,760px);
  display:grid;color:#fff;isolation:isolate;
  background:radial-gradient(120% 120% at 50% 0%,#1a2a6b 0%,var(--green) 45%,var(--green-dark) 100%)}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;mix-blend-mode:screen}
.hero-blob.hb1{width:520px;height:520px;left:-120px;top:-140px;
  background:radial-gradient(circle,#2c3f8f,transparent 70%);animation:blob1 18s ease-in-out infinite}
.hero-blob.hb2{width:460px;height:460px;right:-120px;top:10%;
  background:radial-gradient(circle,rgba(201,162,39,.55),transparent 70%);animation:blob2 22s ease-in-out infinite}
.hero-blob.hb3{width:420px;height:420px;left:35%;bottom:-160px;
  background:radial-gradient(circle,#13a394,transparent 70%);animation:blob3 20s ease-in-out infinite}
@keyframes blob1{50%{transform:translate(80px,60px) scale(1.15)}}
@keyframes blob2{50%{transform:translate(-70px,50px) scale(1.1)}}
@keyframes blob3{50%{transform:translate(60px,-50px) scale(1.2)}}
.hero-geo{position:absolute;inset:-10%;opacity:.18;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cg fill='none' stroke='%23e4c75a' stroke-width='1'%3E%3Cpath d='M40 8l9 23 23 9-23 9-9 23-9-23-23-9 23-9z'/%3E%3Ccircle cx='40' cy='40' r='3'/%3E%3C/g%3E%3C/svg%3E");
  background-size:90px 90px;animation:geoDrift 60s linear infinite}
@keyframes geoDrift{to{background-position:90px 90px}}
.hero-arch{position:absolute;bottom:-6%;left:50%;transform:translateX(-50%);height:78%;width:auto;opacity:.9;
  animation:archSway 9s ease-in-out infinite}
@keyframes archSway{50%{transform:translateX(-50%) translateY(-8px)}}
.hero-stars span{position:absolute;width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.7);
  top:calc((var(--i)*7%) + 4%);left:calc((var(--i)*61%) % 96%);
  animation:twinkle 3.5s ease-in-out infinite;animation-delay:calc(var(--i)*.27s);opacity:.5}
@keyframes twinkle{0%,100%{opacity:.15;transform:scale(.7)}50%{opacity:.9;transform:scale(1.3)}}

.hero-track{position:absolute;inset:0;z-index:1}
.hero-slide{position:absolute;inset:0;display:grid;place-items:center;opacity:0;visibility:hidden;
  transform:scale(1.06);transition:opacity .9s ease,transform 1.2s ease;pointer-events:none}
.hero-slide.is-active{opacity:1;visibility:visible;transform:scale(1);pointer-events:auto}
.hero-content{position:relative;text-align:center;max-width:880px;padding-block:40px}
.hero-slider .hero-badge{display:inline-flex;gap:9px;align-items:center;background:rgba(255,255,255,.12);
  border:1px solid rgba(228,199,90,.45);color:#fff;padding:8px 20px;border-radius:50px;font-size:14px;
  font-weight:500;margin-bottom:24px;backdrop-filter:blur(6px)}
.hero-slider .hb-ico{color:var(--gold-light);display:inline-flex;animation:spinSlow 8s linear infinite}
@keyframes spinSlow{to{transform:rotate(360deg)}}
.hero-slider h1{font-size:clamp(36px,6vw,64px);line-height:1.06;margin-bottom:18px;letter-spacing:-.5px;
  text-shadow:0 6px 30px rgba(0,0,0,.25)}
.hero-slider .hero-tagline{font-size:clamp(17px,2.2vw,21px);opacity:.94;margin-bottom:14px;max-width:680px;margin-inline:auto}
.hero-slider .hero-ayah{font-family:var(--font-ar);font-size:clamp(24px,3.4vw,34px);color:var(--gold-light);
  margin:14px 0 30px;text-shadow:0 2px 20px rgba(228,199,90,.35)}
.hero-slider .hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-slider .btn-lg{padding:16px 34px;box-shadow:0 10px 30px rgba(0,0,0,.22)}
.hero-slider .btn-gold{position:relative;overflow:hidden}
.hero-slider .btn-gold::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-20deg);
  animation:shine 4.5s ease-in-out infinite}
@keyframes shine{0%,60%{left:-120%}80%,100%{left:130%}}

/* staggered entrance on the active slide */
.hero-slide.is-active .hero-badge{animation:heroUp .7s .15s both}
.hero-slide.is-active h1{animation:heroUp .8s .30s both}
.hero-slide.is-active .hero-tagline{animation:heroUp .8s .45s both}
.hero-slide.is-active .hero-ayah{animation:heroUp .8s .60s both}
.hero-slide.is-active .hero-actions{animation:heroUp .8s .75s both}
@keyframes heroUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

.hero-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:50px;height:50px;border-radius:50%;
  border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.1);color:#fff;cursor:pointer;
  display:grid;place-items:center;backdrop-filter:blur(6px);transition:.25s}
.hero-nav:hover{background:var(--gold);color:#3a2e07;border-color:var(--gold)}
.hero-nav.prev{inset-inline-start:24px}.hero-nav.next{inset-inline-end:24px}
body.rtl .hero-nav svg{transform:scaleX(-1)}
.hero-dots{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:10px}
.hero-dots button{width:11px;height:11px;border-radius:50%;border:none;cursor:pointer;padding:0;
  background:rgba(255,255,255,.35);transition:.3s}
.hero-dots button.is-active{width:34px;border-radius:8px;background:var(--gold)}
.hero-progress{position:absolute;bottom:0;left:0;width:100%;height:3px;background:rgba(255,255,255,.12);z-index:3}
.hero-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-light))}
.hero-progress span.run{animation:heroProg var(--dur,7s) linear forwards}
@keyframes heroProg{from{width:0}to{width:100%}}

@media(max-width:760px){.hero-nav{display:none}.hero-slider{min-height:74vh}}
@media(prefers-reduced-motion:reduce){
  .hero-blob,.hero-geo,.hero-arch,.hero-stars span,.hb-ico,.hero-slider .btn-gold::after{animation:none}
  .hero-slide{transition:opacity .4s}
}

/* ===== Initiatives on dark (home section) ===== */
.ini-dark-section{position:relative;overflow:hidden;
  background:radial-gradient(120% 90% at 50% -10%,#1b2a6b 0%,var(--green) 55%,var(--green-dark) 100%)}
.ini-dark-section::before{content:"";position:absolute;inset:0;opacity:.10;pointer-events:none;
  background-image:radial-gradient(circle at 20% 25%,#fff 1.4px,transparent 1.5px),radial-gradient(circle at 78% 60%,#fff 1.4px,transparent 1.5px);
  background-size:48px 48px}
.ini-dark-section .container{position:relative;z-index:1}
.ini-card.on-dark{background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.12);
  box-shadow:0 10px 30px rgba(0,0,0,.18);backdrop-filter:blur(4px)}
.ini-card.on-dark::before{background:linear-gradient(90deg,var(--gold),var(--gold-light));opacity:.9}
.ini-card.on-dark:hover{background:rgba(255,255,255,.09);box-shadow:0 22px 50px rgba(0,0,0,.34);
  border-color:rgba(228,199,90,.4)}
.ini-card.on-dark h3{color:#fff}
.ini-card.on-dark p{color:rgba(255,255,255,.78)}
.ini-card.on-dark .ini-more{color:var(--gold-light)}
.ini-card.on-dark:hover .ini-more{color:#fff}

/* ===== Professional dropdown navigation ===== */
.main-nav .nav-link{padding:8px 12px;font-weight:500;color:var(--ink);border-radius:8px;font-size:14.5px;white-space:nowrap}
.main-nav .nav-link:hover,.main-nav .nav-link.active{color:var(--green);background:rgba(23,37,94,.07)}
.nav-group{position:relative}
.nav-group-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;
  font-family:inherit;font-size:14.5px;font-weight:500;color:var(--ink);padding:8px 12px;border-radius:8px;white-space:nowrap}
.nav-group-btn .caret{transition:transform .25s;opacity:.7}
.nav-group:hover .nav-group-btn,.nav-group.has-active .nav-group-btn,.nav-group.open .nav-group-btn{color:var(--green);background:rgba(23,37,94,.07)}
.nav-group:hover .nav-group-btn .caret{transform:rotate(180deg)}
.nav-dropdown{position:absolute;top:calc(100% + 10px);inset-inline-start:0;min-width:216px;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 44px rgba(15,22,64,.18);padding:8px;
  opacity:0;visibility:hidden;transform:translateY(10px);transition:.22s;z-index:120}
.nav-dropdown::before{content:"";position:absolute;top:-6px;inset-inline-start:22px;width:12px;height:12px;background:var(--surface);
  border-inline-start:1px solid var(--line);border-top:1px solid var(--line);transform:rotate(45deg)}
.nav-group:hover .nav-dropdown{opacity:1;visibility:visible;transform:none}
.nav-dropdown a{display:flex;align-items:center;gap:9px;padding:10px 14px;border-radius:9px;font-size:14px;color:var(--ink);white-space:nowrap;position:relative}
.nav-dropdown a::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);opacity:0;transition:.2s}
.nav-dropdown a:hover,.nav-dropdown a.active{background:rgba(23,37,94,.06);color:var(--green)}
.nav-dropdown a:hover::before,.nav-dropdown a.active::before{opacity:1}
.nav-search{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:50%;color:var(--green);background:rgba(23,37,94,.06)}
.nav-search:hover{background:var(--green);color:#fff}

@media(max-width:1024px){
  .nav-group{width:100%}
  .nav-group-btn{width:100%;justify-content:space-between;font-size:15px}
  .nav-dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;
    padding:0;margin:2px 0 6px;max-height:0;overflow:hidden;transition:max-height .28s ease;background:transparent}
  .nav-dropdown::before{display:none}
  .nav-group.open .nav-dropdown{max-height:430px}
  .nav-group.open .nav-group-btn .caret{transform:rotate(180deg)}
  .nav-dropdown a{padding-inline-start:26px;font-size:14.5px}
}

/* ===== Fundraising hero (construction progress) ===== */
.fund-hero{position:relative;overflow:hidden;border-radius:22px;margin-bottom:42px;
  background:linear-gradient(135deg,#16245c,#0e1640 60%,#1b2a6b);color:#fff;
  box-shadow:0 20px 50px rgba(15,22,64,.25)}
.fund-hero-glow{position:absolute;width:380px;height:380px;border-radius:50%;top:-150px;inset-inline-end:-100px;
  background:radial-gradient(circle,rgba(201,162,39,.45),transparent 70%);filter:blur(20px);animation:fundGlow 7s ease-in-out infinite}
@keyframes fundGlow{50%{transform:translate(-30px,30px) scale(1.15)}}
.fund-hero-inner{position:relative;z-index:1;padding:34px 38px}
.fund-hero-top{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:22px}
.fund-label{display:inline-flex;align-items:center;gap:8px;color:var(--gold-light);font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.fund-raised{display:block;font-size:clamp(30px,5vw,46px);line-height:1.1;margin:6px 0 4px;
  text-shadow:0 4px 20px rgba(0,0,0,.3)}
.fund-of{color:rgba(255,255,255,.7);font-size:15px}
.fund-cta{box-shadow:0 12px 30px rgba(201,162,39,.4)}
.fund-bar{height:34px;background:rgba(255,255,255,.12);border-radius:50px;overflow:hidden;position:relative;
  border:1px solid rgba(255,255,255,.15)}
.fund-fill{height:100%;border-radius:50px;position:relative;width:0;
  background:linear-gradient(90deg,#caa53d,#e4c75a,#caa53d);
  background-size:200% 100%;animation:fundFill 1.6s ease-out forwards,fundShift 3s linear infinite 1.6s;
  display:flex;align-items:center;justify-content:flex-end;
  box-shadow:0 0 22px rgba(228,199,90,.6)}
.fund-fill::before{content:"";position:absolute;inset:0;border-radius:50px;opacity:.4;
  background-image:linear-gradient(45deg,rgba(255,255,255,.35) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.35) 50%,rgba(255,255,255,.35) 75%,transparent 75%);
  background-size:32px 32px;animation:fundStripes 1s linear infinite}
@keyframes fundFill{from{width:0}to{width:var(--w,100%)}}
@keyframes fundStripes{to{background-position:32px 0}}
@keyframes fundShift{to{background-position:200% 0}}
.fund-pct{position:relative;z-index:1;color:#3a2e07;font-weight:700;font-size:14px;padding-inline-end:14px}
.fund-meta{display:flex;gap:26px;flex-wrap:wrap;margin-top:18px;font-size:14px;color:rgba(255,255,255,.82)}
.fund-meta i{color:var(--gold-light);margin-inline-end:6px}

/* ===== Donate band (sadaqah jariyah) ===== */
.donate-band{position:relative;overflow:hidden;text-align:center;color:#fff;padding:74px 0;
  background:linear-gradient(135deg,var(--green-dark),#16245c 55%,var(--green))}
.donate-band-pattern{position:absolute;inset:0;opacity:.12;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpath d='M30 4l7 19 19 7-19 7-7 19-7-19-19-7 19-7z' fill='none' stroke='%23e4c75a' stroke-width='1'/%3E%3C/svg%3E");background-size:70px 70px;animation:geoDrift 50s linear infinite}
.donate-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.4}
.donate-orb.o1{width:300px;height:300px;background:radial-gradient(circle,rgba(201,162,39,.7),transparent 70%);top:-90px;inset-inline-start:-60px;animation:fundGlow 9s ease-in-out infinite}
.donate-orb.o2{width:260px;height:260px;background:radial-gradient(circle,#13a394,transparent 70%);bottom:-110px;inset-inline-end:-40px;animation:fundGlow 11s ease-in-out infinite}
.donate-band-inner{position:relative;z-index:1;max-width:740px;margin:0 auto}
.donate-band-icon{position:relative;width:84px;height:84px;margin:0 auto 18px;display:grid;place-items:center;
  border-radius:50%;background:rgba(228,199,90,.16);color:var(--gold-light);font-size:34px}
.dbi-ring{position:absolute;inset:0;border-radius:50%;border:2px solid rgba(228,199,90,.5);animation:dbiPulse 2.2s ease-out infinite}
@keyframes dbiPulse{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.6);opacity:0}}
.donate-band h2{font-size:clamp(28px,4vw,42px);margin-bottom:14px}
.donate-hadith{font-family:var(--font-ar);font-size:clamp(20px,2.6vw,26px);color:var(--gold-light);margin-bottom:14px;line-height:1.9}
.donate-sub{font-size:17px;opacity:.9;margin-bottom:24px}
.donate-pills{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:22px}
.donate-pills span{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);padding:8px 18px;border-radius:50px;font-size:14px}
.donate-pills i{color:var(--gold-light)}
.donate-amounts{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.donate-amt{padding:11px 22px;border-radius:12px;font-weight:700;font-size:15px;color:#fff;
  background:rgba(255,255,255,.08);border:1.5px solid rgba(228,199,90,.45);transition:.22s}
.donate-amt:hover{background:var(--gold);color:#3a2e07;border-color:var(--gold);transform:translateY(-3px)}
.donate-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.donate-actions .btn-lg{box-shadow:0 12px 30px rgba(0,0,0,.25)}
@media(max-width:600px){.fund-hero-inner{padding:24px 22px}.fund-meta{gap:14px}}

/* Dar-ul-Ifta disclaimer note */
.ifta-note{display:flex;gap:12px;align-items:flex-start;background:#eef3ff;border:1px solid #d4ddf5;
  border-inline-start:4px solid var(--green-light);border-radius:12px;padding:14px 18px;margin-bottom:24px}
.ifta-note i{color:var(--green-light);font-size:20px;margin-top:2px}
.ifta-note p{color:#3a4256;font-size:14.5px;margin:0}

/* ===== Masjid prayer timetable ===== */
.prayer-timetable{background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;
  border-radius:18px;padding:28px 30px;box-shadow:var(--shadow);max-width:680px;margin:0 auto 30px}
.pt-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid rgba(255,255,255,.18)}
.pt-hijri{font-size:18px;font-weight:600;color:var(--gold-light)}
.pt-city{opacity:.85;font-size:14px}
.pt-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(95px,1fr));gap:10px;margin:0}
.pt-list li{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:12px;
  padding:12px 8px;text-align:center;display:flex;flex-direction:column;gap:4px}
.pt-list li span{opacity:.85;font-size:13px}
.pt-list li strong{color:var(--gold-light);font-size:16px}
.pt-jumuah,.pt-jumuah-rows{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.18);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:15px}
.pt-jumuah strong,.pt-jumuah-rows strong{color:var(--gold-light)}
.pt-note,.pt-meta{margin-top:14px;opacity:.85;font-size:14px;line-height:1.7}

/* ===== Explore directory ===== */
.explore-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.explore-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px 24px;box-shadow:var(--shadow-sm);transition:.2s}
.explore-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.explore-card h3{color:var(--green);font-size:17px;display:flex;align-items:center;gap:10px;padding-bottom:12px;margin-bottom:10px;border-bottom:2px solid var(--line)}
.explore-card h3 i{color:var(--gold)}
.explore-card ul{list-style:none}
.explore-card li a{display:flex;align-items:center;gap:10px;padding:8px 6px;border-radius:8px;color:var(--ink);font-size:14.5px}
.explore-card li a i{color:var(--gold-dark);width:18px;text-align:center;font-size:13px}
.explore-card li a:hover{background:rgba(23,37,94,.06);color:var(--green)}

/* ===== Live Dars ===== */
.dars-layout{display:grid;grid-template-columns:1fr 340px;gap:26px;align-items:start}
.video-frame{position:relative;width:100%;padding-top:56.25%;border-radius:14px;overflow:hidden;background:#0e1640;box-shadow:var(--shadow)}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%}
.video-frame.placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:#fff;padding-top:0;min-height:300px}
.video-frame.placeholder i{font-size:54px;color:#ff0000}
.dars-now{color:var(--green);margin-top:16px;font-size:20px;display:flex;align-items:center;gap:10px}
.live-dot{color:#e02424;font-size:11px;animation:twinkle 1.4s infinite}
.dars-schedule{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:20px;box-shadow:var(--shadow-sm)}
.dars-schedule h3{color:var(--green);margin-bottom:14px}
.dars-list{list-style:none;display:flex;flex-direction:column;gap:12px}
.dars-list li{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px dashed var(--line)}
.dars-list li:last-child{border:none}
.dars-list strong{display:block;color:var(--green);font-size:14.5px}
.dars-list small{color:var(--muted);font-size:12.5px}
.dars-plat{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;color:#fff;flex-shrink:0}
.plat-youtube{background:#ff0000}.plat-facebook{background:#1877f2}
.dars-list li>a{margin-inline-start:auto}
@media(max-width:860px){.dars-layout{grid-template-columns:1fr}}

/* ===== Homepage quick-access bar ===== */
.quick-access{background:var(--cream);padding:26px 0;border-bottom:1px solid var(--line)}
.quick-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:14px}
.quick-grid a{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 8px;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;color:var(--green);font-weight:600;font-size:13px;text-align:center;transition:.2s}
.quick-grid a i{font-size:24px;color:var(--gold-dark);transition:.2s}
.quick-grid a:hover{background:var(--green);color:#fff;transform:translateY(-4px);box-shadow:var(--shadow)}
.quick-grid a:hover i{color:var(--gold-light)}
@media(max-width:980px){.quick-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:560px){.quick-grid{grid-template-columns:repeat(2,1fr)}}

/* Wide (two-column) nav dropdown for long menus */
.nav-dropdown.wide{display:grid;grid-template-columns:1fr 1fr;min-width:440px;gap:0 4px}
.main-nav .nav-link,.nav-group-btn{padding-inline:9px;font-size:14px}
@media(max-width:1400px){.nav-dropdown.wide{grid-template-columns:1fr;min-width:0}}

/* Fit the expanded mega-menu: trim brand tagline + nav spacing on mid desktops */
@media(max-width:1600px){
  .brand-text small{display:none}
  .main-nav{gap:2px}
  .nav-group-btn,.main-nav .nav-link{padding-inline:8px;font-size:13.5px}
}

/* Give the header bar more room than the page container so the full menu fits */
.site-header .container{max-width:1600px}
.topbar .container{max-width:1600px}

/* Right-align the right-most nav dropdowns so wide panels never overflow the viewport */
.nav-group:nth-last-of-type(1) .nav-dropdown,
.nav-group:nth-last-of-type(2) .nav-dropdown{inset-inline-start:auto;inset-inline-end:0}
.nav-group:nth-last-of-type(1) .nav-dropdown::before,
.nav-group:nth-last-of-type(2) .nav-dropdown::before{inset-inline-start:auto;inset-inline-end:22px}
/* belt-and-braces: never let hidden panels create page-level horizontal scroll */
body{overflow-x:clip}

/* ===== Share / da'wah bar ===== */
.share-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:24px 0;padding:14px 18px;
  background:var(--cream);border:1px solid var(--line);border-radius:12px}
.share-label{font-weight:600;color:var(--green);font-size:14px;margin-inline-end:4px}
.share-btn{width:40px;height:40px;border-radius:10px;display:inline-grid;place-items:center;border:none;
  cursor:pointer;color:#fff;font-size:16px;transition:.2s;text-decoration:none}
.share-btn:hover{transform:translateY(-3px)}
.share-btn.wa{background:#25d366}.share-btn.fb{background:#1877f2}.share-btn.tw{background:#111}
.share-btn.tg{background:#229ed9}.share-btn.copy{background:var(--green)}.share-btn.native{background:var(--green-light)}
.share-btn.print{background:var(--gold-dark)}
.share-btn.copied{background:#1a7f55}

/* ===== Back to top ===== */
.to-top{position:fixed;inset-block-end:84px;inset-inline-end:22px;width:46px;height:46px;border-radius:50%;
  background:var(--green);color:#fff;border:none;cursor:pointer;font-size:18px;display:grid;place-items:center;
  box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(12px);transition:.25s;z-index:60}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:var(--green-dark)}
@media print{.share-bar,.to-top,.wa-float,.site-header,.topbar,.site-footer,.newsletter-bar{display:none!important}}

/* ===== Dark mode ===== (light is unchanged — these only apply under [data-theme=dark]) */
html[data-theme="dark"]{
  --cream:#0f1320; --surface:#161c2e; --surface-2:#1b2236;
  --ink:#e7ebf5; --muted:#9aa6c0; --line:#28324d;
  --green:#8aa0ee; --green-light:#3f56b0; /* lighter navy so headings/links stay legible */
}
html[data-theme="dark"] body{background:var(--cream);color:var(--ink)}
html[data-theme="dark"] .section-alt{background:#11162a}
html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{
  background:#1b2236;color:var(--ink);border-color:var(--line)}
html[data-theme="dark"] .prose,html[data-theme="dark"] .prose p,html[data-theme="dark"] .course-card-body p,
html[data-theme="dark"] .feature p,html[data-theme="dark"] .post-card-body p{color:#c4cce0}
html[data-theme="dark"] .topbar,html[data-theme="dark"] .site-footer,html[data-theme="dark"] .section-dark{background:#0b0f1c}
html[data-theme="dark"] .chip,html[data-theme="dark"] .filter-bar .chip{background:var(--surface);color:var(--ink);border-color:var(--line)}
html[data-theme="dark"] .hero,html[data-theme="dark"] .page-hero,html[data-theme="dark"] .ini-hero{filter:saturate(.9)}
html[data-theme="dark"] .share-bar,html[data-theme="dark"] .ifta-note{background:var(--surface-2)}
html[data-theme="dark"] .explore-card li a:hover{background:rgba(255,255,255,.06)}
/* topbar theme toggle */
.theme-toggle{background:none;border:none;color:#d8e6df;cursor:pointer;font-size:15px;padding:2px 6px;line-height:1;border-radius:6px}
.theme-toggle:hover{color:var(--gold-light)}
/* Skip to content (accessibility) */
.skip-link{position:absolute;inset-inline-start:-999px;top:0;z-index:200;background:var(--green);color:#fff;
  padding:10px 18px;border-radius:0 0 8px 0}
.skip-link:focus{inset-inline-start:0}
