/* ============================================================
   pages.css — page-specific component styles
   ============================================================ */

/* ===== Utilities ===== */
.text-center{text-align:center}
.alt-bg{background:#fff}
.container.narrow{max-width:820px}
.gold{color:var(--gold)}
.prose p{font-size:1.05rem;line-height:1.85;color:#2a322d;margin-bottom:1.3em}
.prose strong{color:var(--dark)}
.prose em{color:var(--green-dark)}
.gap-2{gap:2rem!important}
.gap-3{gap:3rem!important}
.full-width{grid-column:1/-1}
.full-span{grid-column:1/-1}

/* ===== Hero overrides for new single-col layout ===== */
.hero .container.hero-content{
  grid-template-columns:1fr;
  max-width:780px;
  margin-left:0;
}

/* ===== Hero 2-column split layout ===== */
.hero-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:center;
}
.hero-text{
  display:flex;flex-direction:column;align-items:flex-start;
}
.hero-h1{color:#fff;font-size:clamp(2.4rem,5vw,3.8rem);margin-bottom:1rem;line-height:1.12}
.hero-h1 .gold{color:var(--gold)}
.hero-sub{color:#dceadf;font-size:1.05rem;max-width:520px;margin-bottom:2rem;line-height:1.75}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero-cta .btn-outline{
  background:transparent;color:#fff!important;border-color:rgba(255,255,255,.6)
}
.hero-cta .btn-outline:hover{background:rgba(255,255,255,.15);border-color:#fff}
.hero-bg-overlay{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1481627834876-b7833e8f5570?w=1400&q=80') center/cover;
  opacity:.08;pointer-events:none;z-index:0
}

/* ===== Hero right-side floating image ===== */
.hero-img-wrap{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1.5rem;
  isolation:isolate;
}
.hero-portrait{
  width:100%;
  max-width:420px;
  border-radius:200px 200px 120px 120px;
  object-fit:cover;
  aspect-ratio:3/4;
  position:relative;
  z-index:2;
  box-shadow:0 40px 80px -20px rgba(0,0,0,.45), 0 0 0 6px rgba(219,158,48,.35);
  animation:heroFloat 4s ease-in-out infinite;
}
.hero-img-wrap::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:.5rem;
  transform:translateX(-50%);
  width:92%;
  max-width:420px;
  height:34%;
  background:linear-gradient(180deg, rgba(251,246,233,0) 0%, rgba(251,246,233,.72) 56%, rgba(251,246,233,1) 100%);
  z-index:3;
  pointer-events:none;
  border-radius:0 0 120px 120px;
}
.hero-img-ring{
  position:absolute;
  inset:-18px;
  border-radius:210px 210px 130px 130px;
  border:2px dashed rgba(219,158,48,.4);
  animation:heroRingSpin 18s linear infinite;
  z-index:1;
}
@keyframes heroFloat{
  0%,100%{ transform:translateY(0) }
  50%     { transform:translateY(-18px) }
}
@keyframes heroRingSpin{
  from{ transform:rotate(0deg) }
  to  { transform:rotate(360deg) }
}

/* ===== Hero responsive ===== */
@media(max-width:900px){
  .hero-split{grid-template-columns:1fr;text-align:center;}
  .hero-text{align-items:center;}
  .hero-sub{max-width:100%;}
  .hero-cta{justify-content:center;}
  .hero-img-wrap{max-width:320px;margin:0 auto;}
}

/* ===== Feature cards (Why Choose Us) ===== */
.feature-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:2rem 1.6rem;transition:.3s;
}
.feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--green)}
.feature-card.text-center{text-align:center}
.fc-icon{
  width:62px;height:62px;border-radius:16px;
  background:linear-gradient(135deg,#e8f5ef,#d3f0e1);
  color:var(--green);display:inline-flex;align-items:center;justify-content:center;
  font-size:1.6rem;margin-bottom:1rem;transition:.3s
}
.feature-card:hover .fc-icon{background:var(--green);color:#fff}
.feature-card h3{font-size:1.1rem;margin-bottom:.5rem}
.feature-card p{font-size:.93rem;color:var(--muted);margin:0}

/* ===== Quran verse blockquote ===== */
.quran-verse{
  background:linear-gradient(135deg,var(--green-deep),var(--green-dark));
  color:#fff;border-radius:18px;padding:2.5rem 3rem;margin:3rem auto;
  max-width:900px;text-align:center;position:relative;overflow:hidden
}
.quran-verse::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'><polygon points='40,4 49,32 76,32 54,48 63,75 40,58 17,75 26,48 4,32 31,32' fill='none' stroke='%23DB9E30' stroke-width='.5' opacity='.15'/></svg>");
  background-size:80px;opacity:.6;pointer-events:none
}
.quran-verse .arabic{
  font-family:var(--font-arabic);font-size:1.9rem;color:var(--gold);
  direction:rtl;line-height:2.2;margin-bottom:.8rem;position:relative;z-index:1
}
.quran-verse .translation{
  font-style:italic;color:#e5edd8;font-size:1rem;line-height:1.7;
  margin:0 0 .6rem;position:relative;z-index:1
}
.quran-verse cite{
  color:var(--gold);font-family:var(--font-display);font-size:.82rem;
  letter-spacing:.08em;text-transform:uppercase;position:relative;z-index:1
}

/* ===== 3-Step cards ===== */
.step-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:2.5rem 1.8rem 2rem;text-align:center;position:relative;transition:.35s
}
.step-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold)}
.step-card .step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:50px;height:50px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-soft));
  color:var(--dark);font-family:var(--font-display);font-size:1.3rem;font-weight:700;
  margin-bottom:1.2rem;box-shadow:0 8px 20px rgba(219,158,48,.35)
}
.step-card h3{font-size:1.1rem;margin-bottom:.5rem}
.step-card p{font-size:.93rem;color:var(--muted);margin:0}

/* ===== Course cards (simple — name/img/duration/CTA) ===== */
.course-card img,.course-img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.course-card h3{font-size:1.05rem;margin:.9rem 1.2rem .3rem;font-family:var(--font-body);font-weight:600}
.course-card p{font-size:.88rem;color:var(--muted);margin:0 1.2rem .2rem;line-height:1.5}
.course-dur{color:var(--muted);font-size:.85rem;margin:.2rem 1.2rem .8rem!important;display:flex;align-items:center;gap:.35rem}
.course-dur i{color:var(--green)}
.course-card .btn{margin:0 1.2rem 1.4rem;display:inline-block}
.btn-sm{padding:.6rem 1.2rem!important;font-size:.85rem!important}

/* ===== Stats strip ===== */
.stats-strip{background:linear-gradient(120deg,var(--dark),#1e2e24);padding:4rem 0}
.stat-card{
  text-align:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);padding:2rem 1.2rem;color:#fff
}
.stat-card .stat-num{
  font-family:var(--font-display);font-size:3rem;color:var(--gold);
  line-height:1;display:inline
}
.stat-card span{font-family:var(--font-display);font-size:2rem;color:var(--gold)}
.stat-card p{color:#c9cec9;text-transform:uppercase;letter-spacing:.1em;font-size:.9rem;margin:.5rem 0 0}
/* About page stat-card (light bg) */
.section:not(.stats-strip) .stat-card{
  background:#fff;border:1px solid var(--border);color:var(--dark)
}
.section:not(.stats-strip) .stat-card .stat-num,
.section:not(.stats-strip) .stat-card span{color:var(--green-dark)}
.section:not(.stats-strip) .stat-card p{color:var(--muted)}

/* ===== Teaching methodology timeline ===== */
.timeline{display:grid;gap:1.5rem;max-width:820px;margin:0 auto;position:relative}
.timeline::before{
  content:"";position:absolute;left:26px;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,var(--gold),var(--green));opacity:.35
}
.tl-item{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:1.8rem 1.8rem 1.8rem 4.5rem;position:relative;transition:.3s
}
.tl-item:hover{box-shadow:var(--shadow);border-color:var(--green)}
.tl-num{
  position:absolute;left:-2px;top:50%;transform:translate(-50%,-50%);
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-soft));
  color:var(--dark);font-family:var(--font-display);font-size:1.1rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 16px rgba(219,158,48,.35);flex-shrink:0
}
.tl-item h3{font-size:1.1rem;margin-bottom:.4rem}
.tl-item p{font-size:.93rem;color:var(--muted);margin:0}

/* ===== Tutor cards ===== */
.tutor-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:1.6rem 1.2rem;text-align:center;transition:.3s;
  border-top:3px solid var(--gold)
}
.tutor-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.tutor-card h4{font-family:var(--font-display);font-size:.95rem;margin-bottom:.3rem;color:var(--dark)}
.tutor-card p{font-size:.88rem;color:var(--green);font-weight:600;margin-bottom:.3rem}
.tutor-card span{font-size:.82rem;color:var(--muted);background:var(--cream);padding:.2rem .7rem;border-radius:50px}

/* ===== Testimonials ===== */
.testimonial-slider{max-width:1100px;margin:0 auto;overflow:hidden}
.testimonial-track{display:flex;align-items:center;justify-content:center;gap:1.5rem;position:relative;min-height:310px;perspective:1000px}
.testi-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:2rem;width:31%;flex-shrink:0;position:absolute;
  transition:transform .6s cubic-bezier(.4,0,.2,1),opacity .6s ease,left .6s cubic-bezier(.4,0,.2,1),filter .6s ease;
  opacity:0;pointer-events:none;filter:blur(2px)
}
.testi-card.is-left{opacity:.7;transform:scale(.92);left:0;z-index:1;pointer-events:auto;filter:none}
.testi-card.is-center{opacity:1;transform:scale(1.04);left:34.5%;z-index:3;pointer-events:auto;box-shadow:var(--shadow);border-color:var(--gold);filter:none}
.testi-card.is-right{opacity:.7;transform:scale(.92);left:69%;z-index:1;pointer-events:auto;filter:none}
.testi-card.is-hidden-left{opacity:0;transform:scale(.85) translateX(-60px);left:-10%;z-index:0}
.testi-card.is-hidden-right{opacity:0;transform:scale(.85) translateX(60px);left:110%;z-index:0}
.testi-card::before{
  content:"\201C";position:absolute;top:.8rem;right:1.2rem;
  font-family:var(--font-display);font-size:4.5rem;color:var(--gold);line-height:1;opacity:.5
}
.testi-card p{font-style:italic;color:#3a423d;font-size:.93rem;line-height:1.7;position:relative;z-index:1}
.testi-card cite{display:block;margin-top:.8rem;font-size:.85rem;color:var(--muted);font-style:normal}
.testi-card .flag{font-size:1rem;margin:0 .2rem}
.testimonial-dots{display:flex;justify-content:center;gap:.55rem;margin-top:1.2rem}
.testimonial-dots button{width:10px;height:10px;border-radius:50%;border:none;background:#d4c8aa;cursor:pointer;transition:.2s}
.testimonial-dots button.active{background:var(--green);transform:scale(1.15)}
@media(max-width:900px){
  .testi-card.is-left,.testi-card.is-right{opacity:0;pointer-events:none}
  .testi-card.is-center{left:50%;transform:scale(1) translateX(-50%);width:90%}
}

.blog-filters{max-width:900px;margin-left:auto;margin-right:auto}

/* ===== CTA section ===== */
.cta-section{
  background:linear-gradient(120deg,var(--green) 0%,var(--green-dark) 100%);
  position:relative;overflow:hidden
}
.cta-section::after{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;border-radius:50%;background:rgba(255,208,80,.14);pointer-events:none}
.cta-section h2{color:#fff}
.cta-section p{color:rgba(255,255,255,.85);font-size:1.05rem;max-width:600px;margin:0 auto}

/* ===== Mission/Vision cards ===== */
.mv-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:2.2rem;transition:.3s
}
.mv-card:hover{box-shadow:var(--shadow);border-color:var(--green)}
.mv-card h3{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;font-size:1.2rem;font-family:var(--font-display)}
.mv-card h3 i{color:var(--gold);font-size:1.1rem}
.mv-card p{color:var(--muted);font-size:.95rem;line-height:1.75;margin:0}

/* ===== FAQ list — alias for faq-wrap (contact/courses pages) ===== */
.faq-list{max-width:820px;margin:0 auto;display:grid;gap:.8rem}

/* ===== Course filter buttons ===== */
.course-filters{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:2.5rem}
.filter-btn{
  background:#fff;border:1px solid var(--border);color:var(--dark);
  padding:.65rem 1.4rem;border-radius:50px;cursor:pointer;
  font-family:var(--font-body);font-weight:600;font-size:.85rem;transition:.25s
}
.filter-btn:hover{border-color:var(--gold);transform:translateY(-2px)}
.filter-btn.active{background:var(--green);color:#fff;border-color:var(--green)}

/* ===== Blog cards (simple) ===== */
.blog-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:.35s}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold)}
.blog-thumb{aspect-ratio:16/10;overflow:hidden}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:.5s}
.blog-card:hover .blog-thumb img{transform:scale(1.07)}
.blog-card-link{display:block;color:inherit;text-decoration:none;height:100%}
.blog-body{padding:1.4rem}
.blog-cat{display:inline-block;background:var(--gold);color:var(--dark);
  padding:.25rem .8rem;border-radius:50px;font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.05em;margin-bottom:.7rem}
.blog-body h3{font-size:1.05rem;margin-bottom:.5rem;font-family:var(--font-display)}
.blog-body h3{color:var(--dark);transition:.2s}
.blog-card:hover .blog-body h3{color:var(--green)}
.blog-body p{color:var(--muted);font-size:.9rem;margin:0}

/* ===== Contact form grid ===== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}}
.form-group{display:flex;flex-direction:column;gap:.3rem}
.form-group.full-span{grid-column:1/-1}
.form-group label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--dark)}
.form-group input,.form-group select,.form-group textarea{
  padding:.85rem 1.1rem;border:1px solid var(--border);border-radius:10px;
  font-family:var(--font-body);font-size:.95rem;background:var(--cream);outline:none;transition:.25s;width:100%
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--green);background:#fff;box-shadow:0 0 0 3px rgba(28,142,90,.1)
}
.form-group textarea{min-height:130px;resize:vertical}

/* ===== Footer grid ===== */
.foot-grid{grid-template-columns:1.4fr 1fr 1fr 1.3fr!important;gap:2.5rem!important}
@media(max-width:992px){.foot-grid{grid-template-columns:1fr 1fr!important}}
@media(max-width:600px){.foot-grid{grid-template-columns:1fr!important}}

/* ===== Page banner sub-headline ===== */
.page-banner p{color:rgba(255,255,255,.82);font-size:1.05rem;max-width:640px;margin:.5rem auto 0}

/* ============ courses.php : filter bar ============ */
.filter-bar{
  display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin:0 auto 2.5rem
}
.filter-bar button{
  background:#fff;border:1px solid var(--border);color:var(--dark);
  padding:.65rem 1.4rem;border-radius:50px;cursor:pointer;font-family:var(--font-body);
  font-weight:600;font-size:.85rem;transition:.25s;display:inline-flex;align-items:center;gap:.4rem
}
.filter-bar button i{color:var(--gold);font-size:.75rem}
.filter-bar button:hover{border-color:var(--gold);transform:translateY(-2px)}
.filter-bar button.active{background:var(--green);color:#fff;border-color:var(--green)}
.filter-bar button.active i{color:var(--gold-light)}

/* ============ blogs.php : blog cards + featured post ============ */
.featured-post{
  display:grid;grid-template-columns:1.1fr 1fr;gap:0;background:#fff;
  border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)
}
.featured-post .img{position:relative;min-height:340px;overflow:hidden}
.featured-post .img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.featured-post:hover .img img{transform:scale(1.06)}
.featured-post .body{padding:2.2rem;display:flex;flex-direction:column;justify-content:center}
.featured-post h2{font-family:var(--font-display);font-size:1.7rem;line-height:1.3;margin:0}
.featured-post h2 a{color:var(--dark);text-decoration:none;transition:.2s}
.featured-post h2 a:hover{color:var(--green)}
@media(max-width:768px){
  .featured-post{grid-template-columns:1fr}
  .featured-post .img{min-height:220px}
  .featured-post .body{padding:1.6rem}
  .featured-post h2{font-size:1.3rem}
}

.blog-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:.35s
}
.blog-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--gold)}
.blog-card .thumb{position:relative;aspect-ratio:16/10;overflow:hidden}
.blog-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.blog-card:hover .thumb img{transform:scale(1.08)}
.blog-card .cat-pill{
  position:absolute;top:1rem;left:1rem;background:var(--gold);color:var(--dark);
  padding:.3rem .9rem;border-radius:50px;font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.05em
}
.blog-card .body{padding:1.5rem;display:flex;flex-direction:column;flex:1}
.blog-card .meta{display:flex;gap:1rem;font-size:.78rem;color:var(--muted);margin-bottom:.7rem}
.blog-card .meta i{color:var(--gold);margin-right:.3rem}
.blog-card h3{font-family:var(--font-display);font-size:1.1rem;line-height:1.4;margin:0 0 .6rem}
.blog-card h3 a{color:var(--dark);text-decoration:none;transition:.2s}
.blog-card h3 a:hover{color:var(--green)}
.blog-card p{color:var(--muted);font-size:.9rem;margin:0 0 1rem;flex:1}
.blog-card .read{
  color:var(--green);font-weight:700;font-size:.85rem;text-decoration:none;
  text-transform:uppercase;letter-spacing:.05em;display:inline-flex;gap:.4rem;align-items:center;transition:.2s
}
.blog-card .read:hover{color:var(--gold);gap:.7rem}

/* ============ contact.php : info cards, form, map ============ */
.info-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:2rem 1.5rem;text-align:center;transition:.3s
}
.info-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold)}
.info-card .ico{
  width:62px;height:62px;border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--green-dark));
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;
  margin:0 auto 1rem;box-shadow:0 8px 18px -6px rgba(28,142,90,.4)
}
.info-card h4{font-family:var(--font-display);margin:0 0 .5rem;font-size:1.05rem}
.info-card p{color:var(--muted);font-size:.9rem;margin:0;line-height:1.6}
.info-card a{color:var(--green-dark);text-decoration:none;font-weight:600}
.info-card a:hover{color:var(--gold)}

.contact-form{
  background:#fff;border:1px solid var(--border);border-radius:18px;padding:2.2rem
}
.contact-form h3{font-family:var(--font-display);margin:0 0 .3rem;font-size:1.5rem}
.contact-form p.sub{color:var(--muted);font-size:.92rem;margin-bottom:1.6rem}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.contact-form .full{grid-column:1/-1}
.contact-form label{display:block;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--dark);margin-bottom:.4rem}
.contact-form input,.contact-form textarea,.contact-form select{
  width:100%;padding:.85rem 1.1rem;border:1px solid var(--border);border-radius:10px;
  font-family:var(--font-body);font-size:.95rem;background:var(--cream);outline:none;transition:.25s
}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{
  border-color:var(--green);background:#fff;box-shadow:0 0 0 3px rgba(28,142,90,.1)
}
.contact-form textarea{min-height:140px;resize:vertical}
@media(max-width:600px){.contact-form .row{grid-template-columns:1fr}}

.map-wrap{
  border-radius:18px;overflow:hidden;border:1px solid var(--border);
  box-shadow:var(--shadow);aspect-ratio:4/3
}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}

.wa-card{
  background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;
  border-radius:18px;padding:1.8rem;display:flex;align-items:center;gap:1rem;
  text-decoration:none;transition:.3s
}
.wa-card:hover{transform:translateY(-4px);box-shadow:0 16px 30px -10px rgba(18,140,126,.4)}
.wa-card i{font-size:2.4rem}
.wa-card h4{font-family:var(--font-display);margin:0;color:#fff;font-size:1.1rem}
.wa-card p{margin:.2rem 0 0;font-size:.88rem;opacity:.9}

/* ============ blog-detail.php : full single-post layout ============ */
.post-layout{display:grid;grid-template-columns:1fr 320px;gap:3rem;align-items:start}
@media(max-width:992px){.post-layout{grid-template-columns:1fr}}

.post-hero-img{
  width:100%;aspect-ratio:16/8;object-fit:cover;border-radius:18px;
  box-shadow:0 30px 60px -20px rgba(20,40,30,.25);margin-bottom:2rem
}

.post-meta-row{
  display:flex;flex-wrap:wrap;gap:1.4rem;color:var(--muted);font-size:.9rem;
  padding:1rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  margin-bottom:2rem
}
.post-meta-row span{display:inline-flex;align-items:center;gap:.45rem}
.post-meta-row i{color:var(--green)}
.post-meta-row .author-mini{display:inline-flex;align-items:center;gap:.6rem}
.post-meta-row .author-mini img{width:34px;height:34px;border-radius:50%;object-fit:cover;border:2px solid var(--gold)}
.post-meta-row .author-mini strong{color:var(--dark);font-weight:600}

.post-body{font-size:1.05rem;line-height:1.85;color:#2a322d}
.post-body p{margin:0 0 1.4em}
.post-body h2{font-family:var(--font-display);font-size:1.8rem;margin:2.5rem 0 1rem;color:var(--dark);position:relative;padding-left:1.2rem}
.post-body h2::before{content:"";position:absolute;left:0;top:.4em;bottom:.4em;width:4px;border-radius:4px;background:linear-gradient(180deg,var(--gold),var(--green))}
.post-body h3{font-family:var(--font-display);font-size:1.3rem;margin:2rem 0 .8rem;color:var(--green-dark)}
.post-body ul,.post-body ol{margin:0 0 1.4em;padding-left:1.4rem}
.post-body li{margin-bottom:.5em}
.post-body li::marker{color:var(--gold)}
.post-body blockquote{
  margin:2rem 0;padding:1.4rem 1.8rem 1.4rem 3.4rem;background:var(--cream);
  border-left:4px solid var(--gold);border-radius:0 12px 12px 0;font-style:italic;color:var(--dark);
  position:relative;font-size:1.05rem
}
.post-body blockquote::before{
  content:"\f10d";font-family:"Font Awesome 6 Free";font-weight:900;
  position:absolute;left:1.2rem;top:1rem;color:var(--gold);font-size:1.6rem;opacity:.8
}
.post-body img{border-radius:12px;margin:1.5rem 0;box-shadow:var(--shadow)}
.post-body a{color:var(--green);text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:3px}
.post-body code{background:var(--cream);padding:.15em .45em;border-radius:4px;font-size:.92em;color:var(--green-dark)}

.highlight-card{
  background:linear-gradient(160deg,var(--green-deep) 0%,var(--green-dark) 100%);
  color:#fff;border-radius:16px;padding:2rem 2.4rem;margin:2.5rem 0;text-align:center;position:relative;overflow:hidden
}
.highlight-card::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'><polygon points='40,4 49,32 76,32 54,48 63,75 40,58 17,75 26,48 4,32 31,32' fill='none' stroke='%23DB9E30' stroke-width='.5' opacity='.2'/></svg>");
  background-size:80px;opacity:.5
}
.highlight-card > *{position:relative;z-index:2}
.highlight-card .ar{font-family:var(--font-arabic);font-size:1.8rem;color:var(--gold);direction:rtl;line-height:2;margin-bottom:.8rem}
.highlight-card .tr{font-style:italic;color:#e5edd8;margin:0 0 .4em}
.highlight-card .src{color:var(--gold);font-family:var(--font-display);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase}

.share-row{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  padding:1.4rem 0;margin:2.5rem 0 1rem;border-top:1px solid var(--border);border-bottom:1px solid var(--border)
}
.share-row .tags{display:flex;flex-wrap:wrap;gap:.5rem}
.share-row .tags a{
  background:var(--cream);color:var(--green-dark);padding:.3rem .9rem;border-radius:50px;
  font-size:.78rem;font-weight:600;text-decoration:none;transition:.25s
}
.share-row .tags a:hover{background:var(--green);color:#fff}
.share-row .share{display:flex;align-items:center;gap:.6rem}
.share-row .share span{font-size:.85rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.share-row .share a{
  width:38px;height:38px;border-radius:50%;background:var(--cream);color:var(--green);
  display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:.25s
}
.share-row .share a:hover{background:var(--gold);color:var(--dark);transform:translateY(-3px)}

.author-bio{
  background:#fff;border:1px solid var(--border);border-radius:18px;padding:2rem;
  display:flex;gap:1.5rem;align-items:flex-start;margin:2rem 0
}
.author-bio img{width:90px;height:90px;border-radius:50%;object-fit:cover;border:3px solid var(--gold);flex-shrink:0}
.author-bio h4{font-family:var(--font-display);margin:0 0 .2rem;font-size:1.2rem}
.author-bio .role{color:var(--green);font-weight:600;font-size:.85rem;margin-bottom:.6rem}
.author-bio p{color:var(--muted);font-size:.92rem;margin:0 0 .8rem;line-height:1.6}
.author-bio .social{display:flex;gap:.5rem}
.author-bio .social a{width:32px;height:32px;border-radius:50%;background:var(--cream);color:var(--green);display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;text-decoration:none;transition:.25s}
.author-bio .social a:hover{background:var(--green);color:#fff}
@media(max-width:600px){.author-bio{flex-direction:column;text-align:center;align-items:center}}

.prev-next{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:2rem 0}
.prev-next a{
  background:#fff;border:1px solid var(--border);border-radius:14px;padding:1.2rem 1.4rem;
  text-decoration:none;color:var(--dark);transition:.3s;display:block
}
.prev-next a:hover{border-color:var(--gold);box-shadow:var(--shadow);transform:translateY(-3px)}
.prev-next .lab{font-size:.72rem;text-transform:uppercase;letter-spacing:.15em;color:var(--green);font-weight:700;margin-bottom:.4rem;display:block}
.prev-next .lab i{margin:0 .3rem}
.prev-next .ti{font-family:var(--font-display);font-size:.95rem;line-height:1.4;display:block}
.prev-next a.next{text-align:right}
@media(max-width:600px){.prev-next{grid-template-columns:1fr}.prev-next a.next{text-align:left}}

.sidebar{position:sticky;top:120px;display:flex;flex-direction:column;gap:1.6rem}
.side-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:1.5rem}
.side-card h4{
  font-family:var(--font-display);font-size:1.05rem;margin:0 0 1rem;padding-bottom:.7rem;
  border-bottom:2px solid var(--gold);display:inline-block
}
.side-search{position:relative}
.side-search input{
  width:100%;padding:.85rem 2.6rem .85rem 1.1rem;border-radius:50px;border:1px solid var(--border);
  background:var(--cream);outline:none;font-family:var(--font-body);font-size:.9rem;color:var(--dark);transition:.25s
}
.side-search input:focus{border-color:var(--green);background:#fff;box-shadow:0 0 0 3px rgba(28,142,90,.1)}
.side-search button{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  width:36px;height:36px;border-radius:50%;background:var(--green);color:#fff;
  border:none;cursor:pointer;font-size:.8rem
}
.cat-list{list-style:none;padding:0;margin:0}
.cat-list li{display:flex;justify-content:space-between;padding:.6rem 0;border-bottom:1px dashed var(--border)}
.cat-list li:last-child{border-bottom:none}
.cat-list a{color:var(--dark);text-decoration:none;font-size:.92rem;transition:.2s;display:flex;align-items:center;gap:.5rem}
.cat-list a i{color:var(--gold);font-size:.65rem}
.cat-list a:hover{color:var(--green);transform:translateX(4px)}
.cat-list .count{background:var(--cream);color:var(--muted);font-size:.72rem;padding:.15rem .55rem;border-radius:50px;font-weight:600}

.recent-post{display:flex;gap:.8rem;align-items:flex-start;padding:.8rem 0;border-bottom:1px dashed var(--border)}
.recent-post:last-child{border-bottom:none;padding-bottom:0}
.recent-post img{width:64px;height:64px;border-radius:10px;object-fit:cover;flex-shrink:0}
.recent-post a{color:var(--dark);font-family:var(--font-display);font-size:.85rem;line-height:1.4;text-decoration:none;font-weight:700;display:block;margin-bottom:.2rem}
.recent-post a:hover{color:var(--green)}
.recent-post small{color:var(--muted);font-size:.72rem}
.recent-post small i{color:var(--gold);margin-right:.3rem}

.tag-cloud{display:flex;flex-wrap:wrap;gap:.4rem}
.tag-cloud a{
  background:var(--cream);color:var(--green-dark);padding:.35rem .8rem;border-radius:50px;
  font-size:.75rem;font-weight:600;text-decoration:none;transition:.25s
}
.tag-cloud a:hover{background:var(--green);color:#fff}

.side-cta{
  background:linear-gradient(160deg,var(--green-deep),var(--green-dark));color:#fff;
  border-radius:16px;padding:2rem;text-align:center;position:relative;overflow:hidden
}
.side-cta::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><polygon points='30,3 37,24 58,24 41,36 47,57 30,44 13,57 19,36 2,24 23,24' fill='none' stroke='%23DB9E30' stroke-width='.4' opacity='.25'/></svg>");
  background-size:60px;opacity:.6
}
.side-cta > *{position:relative;z-index:2}
.side-cta i{font-size:2.2rem;color:var(--gold);margin-bottom:.8rem;display:block}
.side-cta h4{color:#fff;border:none;padding:0;display:block;font-size:1.1rem;margin-bottom:.6rem}
.side-cta p{color:#cfd6d2;font-size:.88rem;margin-bottom:1.2rem}

.comments{margin-top:3rem}
.comment{display:flex;gap:1.2rem;padding:1.5rem 0;border-bottom:1px solid var(--border)}
.comment img{width:54px;height:54px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--gold)}
.comment .meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem;flex-wrap:wrap;gap:.5rem}
.comment h5{font-family:var(--font-display);margin:0;font-size:1rem;color:var(--dark)}
.comment time{color:var(--muted);font-size:.78rem}
.comment p{color:#3a423d;margin:0 0 .5rem;font-size:.95rem;line-height:1.7}
.comment .reply{font-size:.78rem;color:var(--gold);font-weight:600;text-decoration:none;text-transform:uppercase;letter-spacing:.05em}
.comment .reply:hover{color:var(--green)}
.comment.reply-to{margin-left:4rem;background:var(--cream);padding:1.2rem;border-radius:12px;border-bottom:none}

.cf-wrap{background:#fff;border:1px solid var(--border);border-radius:18px;padding:2rem;margin-top:2rem}
.cf{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cf .full{grid-column:1/-1}
.cf label{display:block;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--dark);margin-bottom:.4rem}
.cf input,.cf textarea{
  width:100%;padding:.85rem 1.1rem;border:1px solid var(--border);border-radius:10px;
  font-family:var(--font-body);font-size:.95rem;background:var(--cream);outline:none;transition:.25s
}
.cf input:focus,.cf textarea:focus{border-color:var(--green);background:#fff;box-shadow:0 0 0 3px rgba(28,142,90,.1)}
.cf textarea{min-height:140px;resize:vertical}
@media(max-width:600px){.cf{grid-template-columns:1fr}}

/* Article extras: TOC, takeaways, callouts, table, video, mini-faq, resource, newsletter */
.toc{
  background:linear-gradient(160deg,#fff 0%,var(--cream) 100%);
  border:1px solid var(--border);border-left:4px solid var(--gold);
  border-radius:14px;padding:1.4rem 1.6rem;margin:0 0 2.2rem
}
.toc h5{font-family:var(--font-display);margin:0 0 .8rem;font-size:1rem;color:var(--green-dark);display:flex;align-items:center;gap:.5rem}
.toc h5 i{color:var(--gold)}
.toc ol{margin:0;padding-left:1.2rem;columns:2;column-gap:2rem}
.toc ol li{margin-bottom:.4rem;font-size:.9rem}
.toc ol li::marker{color:var(--gold);font-weight:700}
.toc a{color:var(--dark);text-decoration:none;transition:.2s}
.toc a:hover{color:var(--green);padding-left:4px}
@media(max-width:600px){.toc ol{columns:1}}

.takeaways{
  background:#fff;border:2px dashed var(--gold);border-radius:14px;
  padding:1.5rem 1.8rem;margin:2rem 0
}
.takeaways h4{font-family:var(--font-display);margin:0 0 .8rem;font-size:1.1rem;color:var(--dark);display:flex;align-items:center;gap:.5rem}
.takeaways h4 i{color:var(--gold)}
.takeaways ul{list-style:none;padding:0;margin:0}
.takeaways li{padding:.4rem 0 .4rem 1.8rem;position:relative;font-size:.95rem}
.takeaways li::before{
  content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;
  position:absolute;left:0;top:.4rem;color:#fff;background:var(--green);
  width:1.3rem;height:1.3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem
}

.figure{margin:2rem 0}
.figure img{width:100%;border-radius:14px;display:block;box-shadow:0 20px 40px -20px rgba(20,40,30,.25)}
.figure figcaption{
  text-align:center;font-size:.85rem;color:var(--muted);font-style:italic;
  margin-top:.7rem;padding:0 1rem
}

.callout{
  display:flex;gap:1rem;padding:1.2rem 1.4rem;border-radius:12px;margin:1.8rem 0;
  border-left:4px solid var(--green)
}
.callout .ico{
  flex-shrink:0;width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff
}
.callout h5{font-family:var(--font-display);margin:0 0 .3rem;font-size:1rem}
.callout p{margin:0;font-size:.92rem;line-height:1.65}
.callout.tip{background:#eaf5ee}
.callout.tip .ico{background:var(--green)}
.callout.tip h5{color:var(--green-dark)}
.callout.warn{background:#fdf3e2;border-left-color:var(--gold)}
.callout.warn .ico{background:var(--gold);color:var(--dark)}
.callout.warn h5{color:#7a5b15}

.cmp-table{width:100%;border-collapse:collapse;margin:2rem 0;font-size:.92rem;border-radius:12px;overflow:hidden;box-shadow:0 8px 20px -10px rgba(20,40,30,.12)}
.cmp-table thead{background:linear-gradient(135deg,var(--green-deep),var(--green-dark));color:#fff}
.cmp-table th,.cmp-table td{padding:.9rem 1.1rem;text-align:left;border-bottom:1px solid var(--border)}
.cmp-table th{font-family:var(--font-display);font-size:.85rem;letter-spacing:.05em;text-transform:uppercase}
.cmp-table tbody tr{background:#fff;transition:.2s}
.cmp-table tbody tr:nth-child(even){background:var(--cream)}
.cmp-table tbody tr:hover{background:#f3ead0}
.cmp-table .ok{color:var(--green-dark);font-weight:700}
.cmp-table .ng{color:#b54343;font-weight:700}

.video-embed{
  position:relative;aspect-ratio:16/9;border-radius:16px;overflow:hidden;
  margin:2rem 0;cursor:pointer;background:#000;box-shadow:0 25px 50px -20px rgba(0,0,0,.4)
}
.video-embed img{width:100%;height:100%;object-fit:cover;opacity:.75;transition:.4s}
.video-embed:hover img{opacity:.55;transform:scale(1.04)}
.video-embed .play{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:#fff;flex-direction:column;gap:.6rem
}
.video-embed .play .btn-play{
  width:78px;height:78px;border-radius:50%;background:var(--gold);color:var(--dark);
  display:flex;align-items:center;justify-content:center;font-size:1.6rem;
  box-shadow:0 0 0 0 rgba(219,158,48,.7);animation:videoPulse 2s infinite
}
.video-embed .play span{font-family:var(--font-display);font-size:1rem;text-shadow:0 2px 8px rgba(0,0,0,.6)}
@keyframes videoPulse{0%{box-shadow:0 0 0 0 rgba(219,158,48,.7)}70%{box-shadow:0 0 0 25px rgba(219,158,48,0)}100%{box-shadow:0 0 0 0 rgba(219,158,48,0)}}

.mini-faq{margin:2rem 0}
.mini-faq details{
  background:#fff;border:1px solid var(--border);border-radius:10px;
  margin-bottom:.6rem;padding:0 1.2rem;transition:.25s
}
.mini-faq details[open]{border-color:var(--gold);box-shadow:0 6px 18px -8px rgba(20,40,30,.15)}
.mini-faq summary{
  cursor:pointer;padding:1rem 0;font-family:var(--font-display);font-size:.98rem;
  color:var(--dark);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem
}
.mini-faq summary::-webkit-details-marker{display:none}
.mini-faq summary::after{
  content:"\f067";font-family:"Font Awesome 6 Free";font-weight:900;
  color:var(--gold);font-size:.85rem;transition:.3s
}
.mini-faq details[open] summary::after{content:"\f068";color:var(--green)}
.mini-faq details > p{padding:0 0 1.1rem;color:var(--muted);font-size:.92rem;line-height:1.7;margin:0;border-top:1px dashed var(--border);padding-top:.9rem}

.resource-card{
  display:flex;align-items:center;gap:1.2rem;
  background:linear-gradient(135deg,var(--cream) 0%,#fff 100%);
  border:1px solid var(--border);border-radius:14px;padding:1.4rem;margin:2rem 0;transition:.3s
}
.resource-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold)}
.resource-card .r-ico{
  flex-shrink:0;width:60px;height:60px;border-radius:12px;
  background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:var(--dark);
  display:flex;align-items:center;justify-content:center;font-size:1.6rem
}
.resource-card .r-body{flex:1}
.resource-card h5{font-family:var(--font-display);margin:0 0 .25rem;font-size:1rem}
.resource-card small{color:var(--muted);font-size:.82rem}
.resource-card .btn{padding:.6rem 1.2rem;font-size:.82rem}
@media(max-width:600px){.resource-card{flex-direction:column;text-align:center}}

.inline-news{
  background:linear-gradient(135deg,var(--green-deep),#0e3725);color:#fff;
  border-radius:18px;padding:2.2rem;margin:2.5rem 0;text-align:center;position:relative;overflow:hidden
}
.inline-news::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at top right,rgba(219,158,48,.3),transparent 60%)
}
.inline-news > *{position:relative;z-index:2}
.inline-news i{font-size:2rem;color:var(--gold);margin-bottom:.6rem;display:block}
.inline-news h4{font-family:var(--font-display);font-size:1.3rem;margin:0 0 .5rem;color:#fff}
.inline-news p{color:#cfd6d2;font-size:.92rem;margin:0 0 1.2rem;max-width:500px;margin-left:auto;margin-right:auto}
.inline-news form{display:flex;gap:.5rem;max-width:440px;margin:0 auto;flex-wrap:wrap}
.inline-news input{flex:1;min-width:200px;padding:.85rem 1.2rem;border:none;border-radius:50px;outline:none;font-family:var(--font-body)}
.inline-news .btn{padding:.85rem 1.6rem}

.inline-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2rem 0}
.inline-stats .stat{
  text-align:center;padding:1.4rem .8rem;background:var(--cream);
  border-radius:12px;border-bottom:3px solid var(--gold)
}
.inline-stats .stat .num{font-family:var(--font-display);font-size:2rem;color:var(--green-dark);display:block;line-height:1}
.inline-stats .stat .lab{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.4rem;display:block;font-weight:600}
@media(max-width:600px){.inline-stats{grid-template-columns:1fr 1fr}}
