@import url('https://fonts.googleapis.com/css2?family=Amiri:wght@400;700&family=Noto+Naskh+Arabic:wght@400;600&display=swap');

/* =========================================================
   ROOT / RESET
========================================================= */
:root{--nav:#14532d; --nav2:#166534; --accent:#22c55e; --accent2:#16a34a; --text:#0f172a; --muted:#475569; --bg:#f8fafc; --card:#ffffff; --shadow:0 14px 38px rgba(15,23,42,.08); --shadow-hover:0 18px 42px rgba(15,23,42,.12); --radius:22px; --max:1100px; --border:rgba(15,23,42,.10);}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0; font-family:Arial, Helvetica, sans-serif; color:var(--text); background:radial-gradient(circle at top left, rgba(34,197,94,.08), transparent 30%), linear-gradient(180deg, #eaf5ef 0%, #ffffff 100%);}
img{max-width:100%; display:block;}
.container{width:min(var(--max), calc(100% - 32px)); margin:0 auto;}

/* =========================================================
   GLOBAL / UTILITIES
========================================================= */
.card{background:#fff; border:1px solid rgba(2,8,23,.08); border-radius:20px; padding:22px; box-shadow:0 10px 24px rgba(2,8,23,.05);}
.badge{display:inline-flex; align-items:center; gap:8px; padding:6px 10px; border-radius:999px; font-weight:700; font-size:.78rem; background:rgba(34,197,94,.14); color:#0b5a2b; border:1px solid rgba(34,197,94,.25); width:max-content;}
.badge.warn{background:rgba(245,158,11,.14); border-color:rgba(245,158,11,.25); color:#7a4b00;}
.muted{color:var(--muted);}
.small{font-size:.92rem;}
.row{display:flex; gap:12px; align-items:center;}
.grid{display:grid; gap:18px;}
.grid-2{grid-template-columns:repeat(2, minmax(0,1fr));}
.grid-3{grid-template-columns:repeat(3, minmax(0,1fr));}
.section-title{margin:0 0 8px; font-size:1.5rem; color:#0f172a;}
.section-intro{margin:0 0 14px; color:#475569; line-height:1.8;}
.inline-icon{height:18px; vertical-align:middle; margin:0 4px; display:inline-block; white-space:nowrap;}
.loading,.error-message,.empty-message{background:white; border-radius:20px; padding:18px 20px; text-align:center;}

/* =========================================================
   HEADER SHELL
========================================================= */
.site-header{background:linear-gradient(135deg, #0f5132, #198754); color:#fff; padding:18px 20px 14px; position:relative;}
.header-center{max-width:1100px; margin:0 auto; display:grid; grid-template-columns:auto 1fr auto; gap:18px; align-items:center;}
.header-logo-wrap{display:inline-flex; align-items:center; justify-content:center; text-decoration:none;}
.header-logo{height:75px; width:auto; transition:transform .25s ease, opacity .25s ease;}
.header-logo:hover{transform:scale(1.05); opacity:.95;}
.header-main{text-align:center;}
.header-title{margin:0; font-size:clamp(1.35rem, 2.6vw, 2.15rem); line-height:1.15; color:#fff;}
.header-text{font-size:16px; letter-spacing:.4px; font-weight:500; margin:6px 0 10px; opacity:.95; color:#fff;}
.date-box{font-size:13px; opacity:.92; line-height:1.4;}
.date-sep{display:inline-block; margin:0 8px; opacity:.7;}
.header-actions{display:flex; align-items:center; gap:12px; justify-content:flex-end;}
.header-donate-btn{display:inline-flex; align-items:center; justify-content:center; padding:10px 16px; border-radius:999px; background:#fff; color:#0f5132; text-decoration:none; font-weight:800; white-space:nowrap;}
.header-donate-btn:hover{background:#f0fdf4;}

/* =========================================================
   NAV SHELL
========================================================= */
.main-nav{background:linear-gradient(135deg,var(--nav),var(--nav2)); color:#fff; position:sticky; top:0; z-index:1000; box-shadow:0 8px 20px rgba(0,0,0,.12);}
.nav-shell{position:relative;}
.nav-toggle{display:none; background:none; border:none; cursor:pointer; padding:10px 4px; flex:0 0 auto; margin-left:auto;}
.nav-toggle span{display:block; width:24px; height:2px; background:#fff; margin:5px 0;}
.nav-bottom{border-top:1px solid rgba(255,255,255,.15);}
.nav-menu{display:flex; justify-content:center; list-style:none; padding:8px 12px; margin:0; gap:5px; max-width:1100px; margin-inline:auto; flex-wrap:wrap;}
.nav-item{position:relative;}
.nav-link{color:#fff; text-decoration:none; padding:10px 14px; border-radius:8px; font-weight:600; display:flex; align-items:center; gap:5px; background:none; border:none; cursor:pointer; font:inherit; white-space:nowrap;}
.nav-link:hover,.nav-item.active>.nav-link,.nav-link:focus-visible{background:rgba(255,255,255,.12); outline:none;}
.nav-cta{background:#fff; color:var(--nav); font-weight:700;}
.nav-cta:hover,.nav-cta:focus-visible{background:#f0fdf4;}
.dropdown{position:absolute; top:100%; left:0; background:#fff; color:#333; min-width:240px; border-radius:12px; box-shadow:0 12px 30px rgba(0,0,0,.15); display:none; padding:8px; z-index:20;}
.nav-item:hover .dropdown,.nav-item:focus-within .dropdown{display:block;}
.dropdown-link{display:block; padding:10px 12px; text-decoration:none; color:#333; border-radius:8px;}
.dropdown-link:hover,.dropdown-link.active,.dropdown-link:focus-visible{background:#f3f4f6; outline:none;}
.caret{font-size:12px;}
.translator-wrap{padding:10px 0 0;}

/* =========================================================
   HEADER SEARCH
========================================================= */
.site-search-form{display:flex; align-items:center; gap:8px; min-width:0;}
.site-search-form input[type="text"]{width:220px; max-width:100%; padding:8px 12px; border:1px solid rgba(15,81,50,.16); border-radius:10px; background:#fff; color:var(--text); font-size:14px; outline:none;}
.site-search-form input[type="text"]:focus{border-color:rgba(25,135,84,.55); box-shadow:0 0 0 3px rgba(34,197,94,.12);}
.site-search-form button{border:0; border-radius:10px; padding:8px 12px; background:linear-gradient(135deg, var(--nav2), var(--nav)); color:#fff; font-size:14px; cursor:pointer; white-space:nowrap;}
.site-search-form button:hover{filter:brightness(.96);}

/* =========================================================
   FOOTER
========================================================= */
.site-footer{background:linear-gradient(135deg, #0f5132, #198754); color:#fff; padding:10px;}
.footer-inner{max-width:1100px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:10px;}
.footer-logo-wrap{display:flex; align-items:center; flex:0 0 auto; text-decoration:none;}
.footer-text{flex:1; text-align:center; font-size:14px; line-height:1.6;}
.footer-logo{height:60px; width:auto; display:block; transition:transform .25s ease, opacity .25s ease;}
.footer-logo:hover{transform:scale(1.05); opacity:1;}

/* =========================================================
   RESPONSIVE SHELL
========================================================= */
@media (max-width:980px){
  .header-center{grid-template-columns:1fr; text-align:center;}
  .header-logo-wrap,.header-actions{justify-content:center;}
  .header-actions{flex-direction:column;}
  .site-search-form input[type="text"]{width:170px;}

  .nav-toggle{display:block;}
  .nav-bottom{display:none;}
  .main-nav.open .nav-bottom{display:block;}
  .nav-menu{flex-direction:column; align-items:stretch; padding:15px; gap:8px;}
  .nav-item{width:100%;}
  .nav-link{width:100%; justify-content:space-between;}
  .dropdown{position:static; box-shadow:none; background:transparent; display:none; padding:8px 0 0; min-width:0;}
  .nav-item:hover .dropdown,.nav-item:focus-within .dropdown{display:none;}
  .nav-item.open .dropdown{display:block;}
  .dropdown-link{color:#fff; padding:10px 14px; background:rgba(255,255,255,.06); margin-top:6px;}
  .dropdown-link:hover,.dropdown-link.active,.dropdown-link:focus-visible{background:rgba(255,255,255,.12); color:#fff;}
}

@media (max-width:768px){
  .header-logo{height:60px;}
  .header-title{font-size:1.2rem;}
  .header-text{font-size:12px;}
  .date-box{font-size:12px;}
  .footer-inner{flex-direction:column; text-align:center;}
  .footer-logo{height:55px; margin-top:10px;}
  .footer-text{font-size:12px;}
}

@media (max-width:700px){
  .site-search-form{width:100%;}
  .site-search-form input[type="text"]{flex:1 1 auto; width:100%; min-width:0;}
  .site-search-form button{flex:0 0 auto;}
}

/* =========================================================
   HERO
========================================================= */
.hero-wrap{padding:18px 0 8px; position:relative;}
.hero-card{position:relative; overflow:hidden; border-radius:28px; min-height:200px; background:linear-gradient(135deg, rgba(20,83,45,.90), rgba(22,163,74,.85)), url('../images/masjid2.png') center/cover no-repeat; box-shadow:var(--shadow); display:flex; align-items:center;}
.hero-content{position:relative; z-index:2; padding:42px 34px; max-width:760px; color:#fff;}
.hero-badge{display:inline-block; padding:7px 14px; border-radius:999px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.16); font-size:.82rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; margin-bottom:16px;}
.hero-content h1{margin:0 0 12px; font-size:clamp(2rem, 4vw, 3.2rem); line-height:1.1;}
.hero-divider{width:88px; height:4px; border-radius:999px; background:linear-gradient(90deg, #fff, rgba(255,255,255,.45)); margin:0 0 16px;}
.hero-content p{margin:0; line-height:1.75; color:rgba(255,255,255,.94); font-size:1.03rem;}

/* =========================================================
   FANCY HERO
========================================================= */
.hero-image{position:relative; height:520px; overflow:hidden;}
.hero-image img{width:100%; height:100%; object-fit:cover;}
.hero-overlay{position:absolute; top:0; left:0; right:0; bottom:0; background:linear-gradient(to bottom, rgba(0,0,0,.25), rgba(0,0,0,.65));}
.hero-title-wrap{position:absolute; top:50%; left:50%; transform:translate(-50%, -50%); text-align:center; color:#fff; background:rgba(0,0,0,.35); padding:30px 40px; border-radius:18px; backdrop-filter:blur(6px);}
.hero-tag{font-weight:600; letter-spacing:1px;}
.hero-btn{display:inline-block; margin-top:15px; background:#22c55e; color:#fff; padding:10px 18px; border-radius:8px; text-decoration:none; font-weight:600;}
.hero-btn:hover{background:#16a34a;}

/* =========================================================
   PAGE INTRO / STATS
========================================================= */
.page-intro{padding:34px 0 8px;}
.page-intro-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:22px; align-items:stretch;}
.intro-card,.stats-card{background:rgba(255,255,255,.88); border:1px solid rgba(20,83,45,.08); border-radius:var(--radius); box-shadow:var(--shadow); padding:26px; backdrop-filter:blur(8px);}
.intro-card h2,.stats-card h3{margin:0 0 12px; color:var(--nav);}
.intro-card p,.stats-card p{margin:0; color:var(--muted); line-height:1.8;}
.stats-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:14px; margin-top:18px;}
.stat{padding:16px; border-radius:16px; background:linear-gradient(180deg, #f8fff9, #ffffff); border:1px solid rgba(34,197,94,.16);}
.stat strong{display:block; font-size:1.35rem; color:var(--nav2); margin-bottom:4px;}
.stat span{color:var(--muted); font-size:.92rem;}

/* =========================================================
   FEATURED / PARTNERS
========================================================= */
.featured-section{padding:20px 0 34px;}
.featured-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:22px;}
.featured-card{background:rgba(255,255,255,.95); border:1px solid rgba(34,197,94,.12); border-radius:24px; overflow:hidden; box-shadow:var(--shadow); transition:.25s ease;}
.featured-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-hover);}
.featured-image{display:block; width:100%; height:220px; object-fit:cover; background:#f1f5f9;}
.featured-body{padding:20px;}
.featured-body h3{margin:0 0 8px; line-height:1.35; font-size:1.2rem;}
.featured-body h3 a{text-decoration:none; color:var(--text);}
.featured-body h3 a:hover{color:var(--nav2);}
.source-logo{height:34px; width:auto; object-fit:contain; filter:grayscale(100%); opacity:.85; transition:all .3s ease;}
.source-logo:hover{filter:grayscale(0%); opacity:1; transform:scale(1.05);}
.zakat-btn{display:inline-block; padding:2px 8px; border-radius:999px; background:#22c55e; color:#fff; text-decoration:none; font-size:11px; font-weight:600; margin-left:6px;}

.partners-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; margin-top:14px;}
.partner-card{background:#fff; border-radius:18px; padding:18px; text-align:center; text-decoration:none; color:inherit; box-shadow:var(--shadow); transition:.2s ease; border:1px solid rgba(34,197,94,.10);}
.partner-card:hover{transform:translateY(-3px); box-shadow:var(--shadow-hover);}
.partner-card img{height:70px; margin:0 auto 10px; object-fit:contain;}
.partner-name{font-weight:600; font-size:.95rem; color:var(--text);}

/* =========================================================
   TIMELINE
========================================================= */
.timeline-section{padding:46px 0 80px;}
.section-heading{text-align:center; max-width:760px; margin:0 auto 46px;}
.section-tag{display:inline-block; padding:6px 14px; border-radius:999px; background:rgba(34,197,94,.12); color:#15803d; font-size:.82rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; margin-bottom:14px;}
.section-heading h2{margin:0 0 12px; font-size:clamp(1.9rem, 4vw, 2.7rem); line-height:1.15; color:var(--nav);}
.section-heading p{margin:0; color:var(--muted); font-size:1.02rem; line-height:1.75;}
.press-timeline{position:relative; max-width:960px; margin:0 auto; padding:8px 0;}
.press-timeline::before{content:""; position:absolute; top:0; bottom:0; left:145px; width:4px; border-radius:999px; background:linear-gradient(180deg, var(--accent) 0%, var(--nav2) 100%); box-shadow:0 0 0 6px rgba(34,197,94,.08);}
.timeline-item{position:relative; display:grid; grid-template-columns:115px 1fr; gap:30px; align-items:start; margin-bottom:34px;}
.timeline-year{text-align:right; font-size:1.12rem; font-weight:800; color:var(--nav2); padding-top:18px;}
.timeline-item::after{content:""; position:absolute; left:137px; top:24px; width:18px; height:18px; border-radius:50%; background:var(--accent); border:4px solid #fff; box-shadow:0 0 0 5px rgba(34,197,94,.18); z-index:2;}
.timeline-card{background:rgba(255,255,255,.94); border:1px solid rgba(34,197,94,.10); border-radius:22px; padding:22px; box-shadow:var(--shadow); transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;}
.timeline-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-hover); border-color:rgba(34,197,94,.24);}
.timeline-content{display:grid; grid-template-columns:140px 1fr; gap:20px; align-items:center;}
.timeline-image{position:relative;}
.timeline-image img{width:140px; height:100px; object-fit:cover; display:block; border-radius:14px; box-shadow:0 10px 24px rgba(15,23,42,.14); border:1px solid rgba(20,83,45,.10); transition:transform .25s ease; background:#f1f5f9;}
.timeline-card:hover .timeline-image img{transform:scale(1.03);}
.timeline-source{display:inline-block; margin-bottom:10px; font-size:.82rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--accent2);}
.timeline-card h3{margin:0 0 8px; font-size:1.24rem; line-height:1.35;}
.timeline-card h3 a{text-decoration:none; color:var(--text);}
.timeline-card h3 a:hover{color:var(--nav2);}
.timeline-date{margin:0 0 12px; font-size:.95rem; color:#64748b; font-weight:600;}
.timeline-desc{margin:0 0 14px; color:var(--muted); line-height:1.75;}
.read-link{display:inline-flex; align-items:center; gap:8px; font-weight:800; color:var(--nav2); text-decoration:none;}
.read-link:hover{color:var(--accent2);}
.timeline-divider{margin:60px 0 40px; text-align:center; position:relative;}
.timeline-divider span{background:linear-gradient(135deg,var(--nav),var(--nav2)); color:#fff; padding:12px 28px; border-radius:999px; font-weight:800; letter-spacing:.08em; font-size:.85rem; box-shadow:0 8px 20px rgba(0,0,0,.15); text-transform:uppercase;}
.timeline-divider:before{content:""; position:absolute; left:0; right:0; top:50%; height:2px; background:linear-gradient(90deg,transparent,#e5e7eb,transparent); z-index:-1;}

/* =========================================================
   CTA
========================================================= */
.media-cta{padding:0 0 80px;}
.media-cta .cta-card{display:grid; grid-template-columns:1fr auto; gap:20px; align-items:center;}
.cta-card{background:linear-gradient(135deg, var(--nav), var(--nav2)); color:#fff; border-radius:26px; padding:32px; box-shadow:var(--shadow);}
.cta-card h3{margin:0 0 10px; font-size:1.6rem;}
.cta-card p{margin:0; color:rgba(255,255,255,.9); line-height:1.75; max-width:720px;}
.cta-btn{display:inline-block; padding:14px 20px; border-radius:999px; background:#fff; color:var(--nav); text-decoration:none; font-weight:800; white-space:nowrap;}
.cta-btn:hover{background:#f0fdf4;}
.cta-flex{display:flex; justify-content:space-between; align-items:center; gap:20px;}
.cta-left{flex:1;}
.cta-right{flex-shrink:0;}
.cta-logo img{transition:transform .25s ease;}
.cta-logo:hover img{transform:scale(1.05);}
.whatsapp-btn{display:inline-flex; align-items:center; gap:10px;}
.whatsapp-icon{width:22px; height:22px; object-fit:contain;}

/* =========================================================
   FAQ
========================================================= */
.faq-toolbar{padding:22px 0 8px;}
.faq-toolbar-card{display:grid; gap:18px; padding:22px;}
.faq-toolbar-top{display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px;}
.faq-toolbar-top p{margin:0; color:var(--muted);}
.faq-search-wrap{position:relative;}
.faq-search{width:100%; min-height:56px; border-radius:16px; border:1px solid rgba(15,23,42,.12); background:#fff; padding:0 18px 0 52px; font:inherit; font-size:1rem; color:#0f172a; box-shadow:0 10px 24px rgba(15,23,42,.06); transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;}
.faq-search:focus{outline:none; border-color:#198754; box-shadow:0 14px 32px rgba(25,135,84,.14);}
.faq-search-icon{position:absolute; left:16px; top:50%; transform:translateY(-50%); pointer-events:none; font-size:1.05rem; opacity:.7;}
.faq-search-clear{position:absolute; right:10px; top:50%; transform:translateY(-50%); border:none; background:transparent; font:inherit; font-size:.92rem; color:#198754; cursor:pointer; padding:8px 10px; border-radius:10px; display:none;}
.faq-search-clear.show{display:inline-flex; align-items:center; justify-content:center;}
.faq-filter-row{display:flex; flex-wrap:wrap; gap:10px;}
.faq-filter-btn{appearance:none; border:1px solid rgba(15,23,42,.1); background:#fff; color:#0f172a; border-radius:999px; padding:10px 14px; font:inherit; font-size:.95rem; line-height:1; cursor:pointer; transition:all .2s ease; box-shadow:0 8px 20px rgba(15,23,42,.05);}
.faq-filter-btn:hover,.faq-filter-btn:focus{outline:none; transform:translateY(-1px); border-color:rgba(25,135,84,.35); box-shadow:0 12px 24px rgba(25,135,84,.10);}
.faq-filter-btn.active{background:linear-gradient(135deg, #0f5132, #198754); color:#fff; border-color:transparent;}
.faq-filter-count{opacity:.72; margin-left:6px; font-size:.85em;}
.faq-updated{color:var(--muted); font-size:.95rem;}
.faq-accordion{display:grid; gap:14px;}
.faq-item{border-radius:22px; border:1px solid rgba(15,23,42,.08); background:#fff; box-shadow:0 12px 28px rgba(15,23,42,.05); overflow:hidden; transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease; scroll-margin-top:110px;}
.faq-item:hover{transform:translateY(-2px); border-color:rgba(25,135,84,.22); box-shadow:0 18px 34px rgba(15,23,42,.08);}
.faq-item.active{border-color:rgba(25,135,84,.30); box-shadow:0 20px 38px rgba(25,135,84,.10);}
.faq-question{width:100%; border:none; background:transparent; padding:20px 22px; display:flex; align-items:flex-start; justify-content:space-between; gap:16px; text-align:left; cursor:pointer; font:inherit;}
.faq-question:focus{outline:none;}
.faq-item:focus-within{border-color:rgba(25,135,84,.34); box-shadow:0 0 0 4px rgba(25,135,84,.08), 0 18px 34px rgba(15,23,42,.08);}
.faq-question-main{display:flex; align-items:flex-start; gap:14px; min-width:0; flex:1;}
.faq-question-icon{flex:0 0 auto; width:38px; height:38px; display:inline-flex; align-items:center; justify-content:center; border-radius:999px; background:rgba(15,81,50,.08); color:#0f5132; font-weight:700; font-size:.95rem; margin-top:1px;}
.faq-question-text{min-width:0; flex:1;}
.faq-question-text h3{margin:0; font-size:1.06rem; line-height:1.45; color:#0f172a;}
.faq-question-sub{display:flex; flex-wrap:wrap; align-items:center; gap:8px; margin-top:8px;}
.faq-mini-tag{display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px; background:rgba(2,132,199,.08); color:#0c4a6e; font-size:.82rem; font-weight:700; line-height:1;}
.faq-toggle{flex:0 0 auto; width:42px; height:42px; border-radius:999px; background:rgba(15,23,42,.04); display:inline-flex; align-items:center; justify-content:center; position:relative; transition:background .2s ease, transform .2s ease;}
.faq-toggle::before,.faq-toggle::after{content:""; position:absolute; background:#0f5132; border-radius:999px; transition:transform .2s ease, opacity .2s ease;}
.faq-toggle::before{width:16px; height:2px;}
.faq-toggle::after{width:2px; height:16px;}
.faq-item.active .faq-toggle{background:rgba(25,135,84,.10); transform:rotate(180deg);}
.faq-item.active .faq-toggle::after{opacity:0; transform:scaleY(.4);}
.faq-answer{display:grid; grid-template-rows:0fr; transition:grid-template-rows .28s ease;}
.faq-item.active .faq-answer{grid-template-rows:1fr;}
.faq-answer-inner{min-height:0; overflow:hidden;}
.faq-answer-content{padding:0 22px 22px 74px; color:#334155; line-height:1.75; border-top:1px solid rgba(15,23,42,.06); margin-top:0;}
.faq-answer-content .faq-answer-text{margin-top:16px;}
.faq-more-link{color:#198754; text-decoration:none; font-weight:700;}
.faq-more-link:hover{text-decoration:underline;}
.faq-no-results{display:none; padding:16px 0 0;}
.faq-no-results.show{display:block;}
.faq-no-results-card{padding:28px; text-align:center;}
.faq-no-results-card h3{margin:0 0 10px;}
.faq-no-results-card p{margin:0 auto 16px; max-width:660px; color:var(--muted);}
.faq-empty-card{padding:28px; text-align:center;}
.faq-empty-card h2{margin-top:0;}
mark.faq-highlight{background:#fff3bf; color:inherit; padding:0 .12em; border-radius:.2em;}

/* =========================================================
   FORMS / EVENT PROPOSAL
========================================================= */
.proposal-wrap{padding:40px 0 60px;}
.proposal-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:start;}
.proposal-card,.info-card{background:#fff; border-radius:20px; box-shadow:0 10px 30px rgba(0,0,0,.08); padding:26px;}
.proposal-card h2,.info-card h3{margin:0 0 10px;}
.form-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:16px;}
.form-group{display:flex; flex-direction:column; gap:8px;}
.form-group.full{grid-column:1 / -1;}
.form-group.two{grid-column:span 2;}
.form-group.third{grid-column:span 1;}
label{font-weight:600;}
input,select,textarea{width:100%; padding:12px 14px; border:1px solid #d7d7d7; border-radius:12px; font:inherit; background:#fff;}
textarea{min-height:110px; resize:vertical;}
.checkbox-grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px 18px; margin-top:6px;}
.check-item{display:flex; align-items:flex-start; gap:10px; font-size:.98rem; font-weight:400; line-height:1.5;}
.check-item input{width:auto; margin-top:3px; flex-shrink:0;}
.btn-row{display:flex; gap:12px; flex-wrap:wrap; margin-top:8px;}
.btn-primary,.btn-secondary{display:inline-block; border:none; border-radius:12px; padding:12px 18px; font:inherit; font-weight:700; cursor:pointer; text-decoration:none;}
.btn-primary{background:#166534; color:#fff;}
.btn-secondary{background:#f2f2f2; color:#222;}
.info-list{margin:14px 0 0; padding-left:18px; color:#555; line-height:1.7;}
.status-box{margin-top:18px; padding:14px 16px; border-radius:14px; background:#f6faf6; border:1px solid #d6ead8; color:#1f4d2f; display:none;}
.section-note{margin:8px 0 0; color:#666; font-size:.95rem;}
.form-section-title{margin:10px 0 0; font-size:1.05rem; color:#166534;}

/* =========================================================
   QURAN PAGE
========================================================= */
.quran-tools{padding:10px 0 26px;}
.quran-panel{background:rgba(255,255,255,.95); border-radius:24px; padding:22px; box-shadow:var(--shadow);}
.quran-controls{display:grid; grid-template-columns:1.2fr .8fr .8fr auto; gap:14px; align-items:end;}
.quran-field label{display:block; font-weight:700; margin-bottom:6px;}
.quran-field select{width:100%; padding:12px; border-radius:14px; border:1px solid #dbe4ea;}
.quran-btn{padding:12px 18px; border-radius:999px; border:none; background:linear-gradient(135deg,var(--nav),var(--nav2)); color:#fff; font-weight:700; cursor:pointer;}
.quran-reader{padding:20px 0 80px;}
.surah-header{background:linear-gradient(135deg,rgba(20,83,45,.96),rgba(22,163,74,.92)); color:#fff; border-radius:24px; padding:26px; margin-bottom:24px;}
.surah-arabic-name{font-family:'Amiri','Noto Naskh Arabic',serif; font-size:2rem; direction:rtl;}
.verses-list{display:grid; gap:18px;}
.verse-card{background:#fff; border-radius:22px; padding:22px; box-shadow:var(--shadow);}
.verse-arabic{font-family:'Amiri','Noto Naskh Arabic',serif; font-size:2rem; direction:rtl; text-align:right; color:#065f46; margin:10px 0 14px;}

.aya-section{padding:10px 10px;}
.aya-card{background:#ffffff; border-radius:18px; padding:20px; text-align:center; box-shadow:0 10px 35px rgba(0,0,0,.05); border-top:5px solid #16a34a;}
.aya-badge{display:inline-block; background:#dcfce7; color:#166534; padding:6px 14px; border-radius:50px; font-size:22px; font-weight:600; margin-bottom:20px;}
.aya-arabic{font-family:'Amiri','Noto Naskh Arabic',serif; font-size:22px; line-height:2; direction:rtl; color:#065f46; margin-bottom:20px;}
.aya-divider{width:80px; height:3px; background:linear-gradient(to right, #22c55e, #16a34a); margin:20px auto; border-radius:10px;}
.aya-english{font-size:14px; color:#374151; max-width:700px; margin:auto;}
.aya-reference{margin-top:10px; color:#16a34a; font-weight:600;}

/* =========================================================
   ADVISORY / NOTICE
========================================================= */
.notice-card{background:#fff; border-radius:18px; box-shadow:0 10px 30px rgba(0,0,0,.08); padding:28px;}
.notice-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:30px; align-items:center;}
.notice-title{margin:10px 0;}
.notice-text{color:var(--muted); margin-bottom:12px;}
.notice-image img{width:100%; border-radius:14px; box-shadow:0 6px 20px rgba(0,0,0,.12);}
.notice-actions{margin-top:15px;}

/* =========================================================
   FACEBOOK
========================================================= */
.facebook-section{padding:20px 0 34px;}
.facebook-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:22px; align-items:start;}
.facebook-card,.facebook-side-card,.facebook-posts-card{background:rgba(255,255,255,.95); border:1px solid rgba(34,197,94,.12); border-radius:24px; padding:22px; box-shadow:var(--shadow);}
.facebook-card h2,.facebook-side-card h2,.facebook-posts-card h2{margin:0 0 8px; color:var(--nav);}
.facebook-card p,.facebook-side-card p,.facebook-posts-card p{margin:0; color:var(--muted); line-height:1.75;}
.facebook-embed-wrap{margin-top:16px; overflow:hidden; border-radius:18px; background:#fff;}
.facebook-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px;}
.facebook-btn{display:inline-flex; align-items:center; justify-content:center; padding:12px 18px; border-radius:999px; text-decoration:none; font-weight:800; transition:.2s ease;}
.facebook-btn.primary{background:linear-gradient(135deg,var(--nav),var(--nav2)); color:#fff;}
.facebook-btn.primary:hover{transform:translateY(-2px); box-shadow:var(--shadow-hover);}
.facebook-btn.secondary{background:#fff; color:var(--nav); border:1px solid rgba(20,83,45,.12);}
.facebook-btn.secondary:hover{background:#f8fafc; transform:translateY(-2px);}
.facebook-info-list{display:grid; gap:14px; margin-top:16px;}
.facebook-info-item{padding:16px; border-radius:18px; background:linear-gradient(180deg, #f8fff9, #ffffff); border:1px solid rgba(34,197,94,.14);}
.facebook-info-item h3{margin:0 0 6px; font-size:1rem; color:var(--nav);}
.facebook-info-item p{margin:0; color:var(--muted); line-height:1.7; font-size:.96rem;}
.facebook-posts-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:18px;}
.facebook-placeholder{min-height:220px; display:flex; align-items:center; justify-content:center; text-align:center; border-radius:18px; border:1px dashed rgba(20,83,45,.18); background:#f8fafc; color:var(--muted); padding:20px; line-height:1.7;}

/* =========================================================
   BOOKS / LIBRARY
========================================================= */
.books-shell{max-width:1100px; margin:0 auto; padding:32px 20px 56px;}
.books-grid{display:grid; grid-template-columns:1fr 320px; gap:24px; align-items:start;}
.book-sidebar{display:grid; gap:18px;}
.book-actions{display:grid; gap:12px;}
.book-btn{display:inline-flex; align-items:center; justify-content:center; text-align:center; padding:12px 16px; border-radius:12px; text-decoration:none; font-weight:700; transition:.2s ease;}
.book-btn.primary{background:linear-gradient(135deg, #16a34a, #22c55e); color:#fff;}
.book-btn.secondary{background:rgba(255,255,255,.8); color:var(--text); border:1px solid rgba(22,163,74,.18);}
.book-btn:hover{transform:translateY(-1px);}
.book-list{margin:0; padding-left:18px; line-height:1.8;}
.muted-sm{font-size:.95rem; opacity:.88;}
.library-preview{display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:14px; margin-top:18px;}
.library-tile{padding:16px; border-radius:16px; background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(248,250,252,.95)); border:1px solid rgba(22,163,74,.12); box-shadow:0 10px 24px rgba(15,23,42,.06);}
.library-tile h4{margin:0 0 6px; font-size:1rem;}
.library-tile p{margin:0; font-size:.95rem; line-height:1.65; color:var(--muted);}
.books-note{margin-top:18px; padding:14px 16px; border-left:4px solid #22c55e; background:rgba(34,197,94,.08); border-radius:12px;}
.books-note p{margin:0;}

/* =========================================================
   FOUNDERS
========================================================= */
.founders-section{padding:60px 0; background:linear-gradient(180deg,#ffffff 0%, #f8fafc 100%);}
.founders-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center;}
.founders-image{position:relative; border-radius:20px; overflow:hidden; box-shadow:0 20px 40px rgba(0,0,0,.12);}
.founders-image img{width:100%; height:100%; object-fit:cover; display:block;}
.founders-overlay{position:absolute; inset:0; background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,.45));}
.founders-content h2{margin:6px 0 14px; font-size:28px;}
.founders-quote{font-style:italic; color:#166534; font-size:1.05rem; margin-bottom:14px;}
.founders-names{margin-top:20px; display:grid; gap:10px;}
.founder{padding:12px 14px; border-left:4px solid #22c55e; background:#f8fafc; border-radius:8px;}
.founder strong{display:block; font-size:1.05rem;}
.founder span{color:#666; font-size:.9rem;}

/* =========================================================
   EVENT META / MAP / VISIT
========================================================= */
.event-meta-block{margin:12px 0 12px; display:grid; gap:12px;}
.event-org-section,.event-partners-section{background:#f8fafc; border:1px solid rgba(34,197,94,.15); border-radius:16px; padding:8px 8px;}
.event-meta-label{font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:#15803d; margin-bottom:6px;}
.event-org-row{display:flex; align-items:center; gap:10px;}
.event-partners-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(180px, 1fr)); gap:10px;}
.event-partner-card{display:flex; align-items:center; gap:10px; background:#ffffff; border:1px solid rgba(15,23,42,.08); border-radius:12px; padding:10px;}
.event-meta-logo{width:40px; height:40px; object-fit:contain; border-radius:10px; background:#fff; border:1px solid rgba(15,23,42,.08); padding:4px; flex-shrink:0;}
.event-meta-name{font-size:10px; font-weight:600; color:#0f172a; line-height:1.35;}

.map-embed iframe{width:100%; height:480px; border:0; border-radius:16px; box-shadow:var(--shadow);}
.visit-card{padding:28px;}
.visit-wrap{display:grid; grid-template-columns:1.2fr .8fr; gap:30px; align-items:center;}
.visit-map iframe{width:100%; height:350px; border:0; border-radius:14px; box-shadow:0 8px 24px rgba(0,0,0,.08);}

/* =========================================================
   DONATION METHODS
========================================================= */
.methods-grid{display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:20px; align-items:stretch;}
.methods-grid .method{height:100%;}
.method{border:1px solid var(--border); border-radius:16px; padding:18px; background:#fff; display:flex; flex-direction:column; gap:10px; transition:.15s ease;}
.method:hover{transform:translateY(-3px); box-shadow:0 16px 40px rgba(2,8,23,.15);}
.method h3{margin:0;}
.action{display:inline-flex; align-items:center; justify-content:center; padding:10px 12px; border-radius:12px; border:1px solid var(--border); background:#fff; font-weight:700; text-decoration:none; color:inherit;}
.action.primary{background:linear-gradient(180deg,var(--accent),var(--accent2)); color:#062014; border-color:transparent;}
.action:hover{filter:brightness(.98);}
.copyline{display:flex; gap:10px; align-items:center; flex-wrap:wrap;}
.code{font-weight:700; padding:8px 10px; border-radius:12px; border:1px dashed rgba(2,8,23,.25); background:#fff;}

/* =========================================================
   PRAYER APP
========================================================= */
.app-download{display:flex; align-items:center; gap:16px; flex-wrap:wrap; justify-content:center; background:#f8f8f8; border-radius:12px; padding:16px 20px; margin:20px auto; max-width:700px;}
.app-logo{max-width:60px; height:auto;}
.app-text{text-align:center; max-width:320px;}
.app-text strong{display:block; font-size:1.1rem;}
.app-text span{font-size:.9rem; color:#555;}
.app-buttons{display:flex; gap:12px;}
.app-download a{padding:12px 18px; border-radius:8px; text-decoration:none; font-weight:700; font-size:15px; color:#fff; display:inline-flex; align-items:center; gap:6px;}
.btn-ios{background:#000;}
.btn-android{background:#3ddc84; color:#0b3d1f;}
.app-download a:hover{opacity:.9;}

/* =========================================================
   CONTACT FAB
========================================================= */
.contact-fab-wrap{position:fixed; right:20px; bottom:20px; z-index:1200;}
.contact-fab-main{width:60px; height:60px; border:none; border-radius:50%; background:linear-gradient(135deg, #0f5132, #198754); color:#fff; box-shadow:0 12px 24px rgba(2,8,23,.18); cursor:pointer; display:inline-flex; align-items:center; justify-content:center; font-size:24px; position:relative; transition:transform .2s ease, box-shadow .2s ease;}
.contact-fab-main:hover{transform:translateY(-2px); box-shadow:0 16px 28px rgba(2,8,23,.24);}
.contact-fab-main .fab-icon{position:absolute; transition:opacity .2s ease, transform .2s ease;}
.contact-fab-main .fab-close{opacity:0; transform:scale(.8);}
.contact-fab-wrap.open .contact-fab-main .fab-open{opacity:0; transform:scale(.8);}
.contact-fab-wrap.open .contact-fab-main .fab-close{opacity:1; transform:scale(1);}
.contact-fab-menu{position:absolute; right:0; bottom:74px; display:flex; flex-direction:column; gap:10px; align-items:flex-end; pointer-events:none;}
.contact-fab-item{display:inline-flex; align-items:center; gap:10px; min-width:150px; padding:10px 14px; border-radius:999px; text-decoration:none; color:#fff; font-weight:700; box-shadow:0 10px 22px rgba(2,8,23,.16); opacity:0; transform:translateY(10px) scale(.96); transition:opacity .22s ease, transform .22s ease;}
.contact-fab-wrap.open .contact-fab-menu{pointer-events:auto;}
.contact-fab-wrap.open .contact-fab-item{opacity:1; transform:translateY(0) scale(1);}
.contact-fab-wrap.open .contact-fab-item:nth-child(1){transition-delay:.02s;}
.contact-fab-wrap.open .contact-fab-item:nth-child(2){transition-delay:.05s;}
.contact-fab-wrap.open .contact-fab-item:nth-child(3){transition-delay:.08s;}
.contact-fab-item.whatsapp{background:#25D366;}
.contact-fab-item.email{background:#0f5132;}
.contact-fab-item.phone{background:#1f6feb;}
.fab-item-icon{width:22px; height:22px; display:inline-flex; align-items:center; justify-content:center; flex:0 0 22px;}
.fab-item-label{line-height:1; white-space:nowrap;}

/* =========================================================
   POPUP / LIBRARY SUPPORT PAGE
========================================================= */
.popup-page{max-width:1100px; margin:0 auto; padding:24px 16px 36px;}
.popup-page .library-shell{background:#fff; border:1px solid rgba(2,8,23,.08); border-radius:24px; box-shadow:0 18px 40px rgba(2,8,23,.08); overflow:hidden;}
.popup-page .mini-topbar{background:linear-gradient(135deg, #0f5132, #198754); color:#fff; padding:14px 18px; display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;}
.popup-page .mini-brand{display:flex; align-items:center; gap:12px;}
.popup-page .mini-brand img{width:48px; height:48px; object-fit:contain; border-radius:50%; background:rgba(255,255,255,.12); padding:4px;}
.popup-page .mini-brand h2{margin:0; font-size:1rem; line-height:1.2;}
.popup-page .mini-brand p{margin:2px 0 0; font-size:.92rem; opacity:.92;}
.popup-page .mini-actions{display:flex; gap:10px; flex-wrap:wrap;}
.popup-page .mini-btn{display:inline-flex; align-items:center; justify-content:center; padding:10px 16px; border-radius:999px; text-decoration:none; font-weight:700; transition:.2s ease; border:1px solid rgba(255,255,255,.28);}
.popup-page .mini-btn.light{background:#fff; color:#0f5132;}
.popup-page .mini-btn.ghost{color:#fff; background:rgba(255,255,255,.08);}
.popup-page .mini-btn:hover{transform:translateY(-1px);}
.popup-page .page-body{padding:22px;}

.popup-page .hero-wrap{margin-bottom:22px; padding:0;}
.popup-page .hero-card{position:relative; overflow:hidden; border-radius:22px; min-height:340px; background:linear-gradient(rgba(15,81,50,.72), rgba(15,81,50,.72)), url('images/projects/library.jpg') center/cover no-repeat; display:flex; align-items:center; box-shadow:0 10px 24px rgba(2,8,23,.05);}
.popup-page .hero-content{position:relative; z-index:2; max-width:760px; padding:34px 28px; color:#fff;}
.popup-page .hero-badge{display:inline-block; padding:7px 12px; border-radius:999px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.18); font-size:.82rem; font-weight:700; letter-spacing:.02em; margin-bottom:14px;}
.popup-page .hero-content h1{margin:0 0 10px; font-size:clamp(2rem, 4vw, 3rem); line-height:1.08;}
.popup-page .hero-divider{width:88px; height:4px; border-radius:999px; background:linear-gradient(90deg, #bbf7d0, #ffffff); margin:14px 0 16px;}
.popup-page .hero-content p{margin:0 0 14px; font-size:1.03rem; line-height:1.75; color:rgba(255,255,255,.95);}
.popup-page .hero-cta{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px;}

.popup-page .cta-btn{display:inline-flex; align-items:center; justify-content:center; padding:12px 18px; border-radius:12px; font-weight:700; text-decoration:none; border:1px solid transparent;}
.popup-page .cta-btn.primary{background:#fff; color:#0f5132;}
.popup-page .cta-btn.secondary{background:rgba(255,255,255,.10); color:#fff; border-color:rgba(255,255,255,.22);}

.popup-page .card{background:#fff; border:1px solid rgba(2,8,23,.08); border-radius:20px; padding:22px; box-shadow:0 10px 24px rgba(2,8,23,.05); margin-bottom:18px;}
.popup-page .badge{display:inline-block; padding:6px 11px; border-radius:999px; background:#e8f7ee; color:#0f5132; font-weight:700; font-size:.82rem; margin-bottom:10px; width:auto;}
.popup-page .muted{color:#475569;}
.popup-page .quote-block{background:linear-gradient(135deg, #0f5132, #198754); color:#fff; border-radius:22px; padding:24px; margin-bottom:18px; box-shadow:0 12px 28px rgba(15,81,50,.18);}
.popup-page .quote-ar{font-size:clamp(1.45rem, 3vw, 2rem); line-height:1.95; text-align:right; margin:0 0 14px; font-family:"Amiri","Noto Naskh Arabic","Scheherazade New",serif;}
.popup-page .quote-en{margin:0; font-size:1rem; line-height:1.85; color:rgba(255,255,255,.96);}
.popup-page .quote-ref{margin-top:10px; font-weight:700; color:#dcfce7;}

.popup-page .method{background:#fff; border:1px solid rgba(2,8,23,.08); border-radius:18px; overflow:hidden; box-shadow:0 10px 22px rgba(2,8,23,.05); display:flex; flex-direction:column; height:100%; padding:0;}
.popup-page .method-image{width:100%; height:200px; object-fit:cover; display:block; background:#f1f5f9;}
.popup-page .method-body{padding:18px; flex:1; display:flex; flex-direction:column;}
.popup-page .method-label{font-size:.8rem; font-weight:700; color:#198754; text-transform:uppercase; letter-spacing:.04em; margin-bottom:6px;}
.popup-page .method h3{margin:0 0 8px; font-size:1.18rem; color:#0f172a;}
.popup-page .method p{margin:0 0 10px; color:#475569; line-height:1.75;}

.popup-page .pill-row{display:flex; flex-wrap:wrap; gap:10px; margin-top:8px;}
.popup-page .pill{display:inline-flex; align-items:center; padding:8px 12px; border-radius:999px; background:#f0fdf4; border:1px solid #dcfce7; color:#166534; font-size:.92rem; font-weight:700;}
.popup-page .support-options{display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:18px; margin-top:8px;}
.popup-page .support-box{border:1px solid rgba(2,8,23,.08); border-radius:18px; padding:18px; background:linear-gradient(180deg, #ffffff 0%, #f9fcfa 100%); box-shadow:0 10px 22px rgba(2,8,23,.04);}
.popup-page .support-box h3{margin:0 0 8px; color:#0f172a; font-size:1.15rem;}
.popup-page .support-box p{margin:0 0 14px; color:#475569; line-height:1.75;}
.popup-page .btn{display:inline-flex; align-items:center; justify-content:center; width:100%; padding:12px 16px; border-radius:12px; text-decoration:none; font-weight:700; transition:.2s ease; box-sizing:border-box;}
.popup-page .btn-primary{background:linear-gradient(135deg, #0f5132, #198754); color:#fff; box-shadow:0 10px 20px rgba(25,135,84,.18);}
.popup-page .btn-outline{border:1px solid rgba(15,81,50,.18); color:#0f5132; background:#fff;}
.popup-page .btn:hover{transform:translateY(-1px);}
.popup-page .highlight{background:linear-gradient(135deg, rgba(34,197,94,.08), rgba(255,255,255,1)); border:1px solid rgba(34,197,94,.14);}
.popup-page .list-clean{margin:0; padding-left:18px; color:#334155; line-height:1.85;}
.popup-page .list-clean li{margin-bottom:8px;}
.popup-page .closing-note{text-align:center; font-size:1.02rem; line-height:1.8; color:#334155; max-width:820px; margin:0 auto;}

/* =========================================================
   RESPONSIVE CONTENT
========================================================= */
@media (max-width:980px){.books-grid{grid-template-columns:1fr;}}
@media (max-width:900px){.site-search-form input[type="text"]{width:170px;} .facebook-grid,.proposal-grid,.founders-grid,.methods-grid{grid-template-columns:1fr;} .facebook-posts-grid{grid-template-columns:1fr;} .form-grid,.checkbox-grid,.grid-3,.grid-2,.popup-page .support-options,.page-intro-grid,.cta-card{grid-template-columns:1fr;} .popup-page .hero-content{padding:28px 20px;} .popup-page .page-body{padding:16px;}}
@media (max-width:768px){.notice-grid,.visit-wrap{grid-template-columns:1fr;} .notice-image,.visit-map{order:-1;} .map-embed iframe{height:320px;} .contact-fab-wrap{right:14px; bottom:14px;} .contact-fab-main{width:56px; height:56px;} .contact-fab-item{min-width:132px; padding:9px 12px; font-size:.95rem;} .cta-flex{flex-direction:column; text-align:center;} .cta-right{margin-top:12px;} .hero-content{padding:28px 22px;} .press-timeline::before{left:16px;} .timeline-item{grid-template-columns:1fr; gap:12px; padding-left:44px;} .timeline-year{text-align:left; padding-top:0; font-size:1rem;} .timeline-card{padding:18px;} .timeline-content{grid-template-columns:1fr; align-items:start;} .timeline-image img{width:100%; height:190px;} .stats-grid{grid-template-columns:1fr;} .faq-toolbar-card{padding:18px;} .faq-question{padding:18px;} .faq-answer-content{padding:0 18px 18px 18px;} .faq-question-main{gap:12px;} .faq-question-icon{width:34px; height:34px;} .faq-toolbar-top{align-items:flex-start;}}
@media (max-width:640px){.books-shell{padding:24px 14px 44px;} .library-preview{grid-template-columns:1fr;}}