
/* ── Responsive ── */
@media(max-width:1280px){
  nav{padding:1rem 1.8rem;}
  .nav-links{gap:1.2rem;}
}
@media(max-width:1100px){
  nav{padding:.9rem 1.2rem;}
  .nav-links{gap:.7rem;}
  .nav-links a{font-size:.62rem;letter-spacing:.05em;}
  .nav-cta{padding:.45rem .9rem;font-size:.62rem;letter-spacing:.04em;}
}
/* ── Hamburger button ── */
.nav-burger{
  display:none;
  flex-direction:column;justify-content:center;gap:5px;
  background:none;border:none;cursor:pointer;padding:.4rem;flex-shrink:0;
}
.nav-burger span{
  display:block;width:22px;height:2px;
  background:var(--or);border-radius:2px;
  transition:transform .3s,opacity .3s;
}
nav.nav-open .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
nav.nav-open .nav-burger span:nth-child(2){opacity:0;}
nav.nav-open .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ── Mobile drawer ── */
nav.nav-open .nav-links{
  display:flex;flex-direction:column;gap:0;
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(28,16,40,.97);backdrop-filter:blur(20px);
  align-items:center;justify-content:center;
  z-index:99;padding:2rem;
}
nav.nav-open .nav-links a{font-size:1rem;letter-spacing:.12em;padding:.8rem 0;}

@media(max-width:1024px){
  nav{padding:.9rem 1rem;}
  .nav-links{display:none;}
  .nav-burger{display:flex;}
}
@media(max-width:768px){
  nav{padding:.9rem 1.5rem;}
  .nav-links{display:none;}
  /* Al-Qalb : panneaux empilés en colonne sur mobile */
  .alqalb-layout.open{flex-direction:column;max-width:100%;}
  .alqalb-layout.open .alqalb-panel{max-width:100%;width:100%;padding:1.8rem 1.5rem 0;}
  .alqalb-layout.open .alqalb-center{max-width:100%;}
  .alqalb-panel--left{order:1;}
  .alqalb-center{order:2;}
  .alqalb-panel--right{order:3;}
  .alqalb-panel--left .alqalb-panel-body,.alqalb-panel--right .alqalb-panel-body{text-align:center;}
  .alqalb-panel--left .alqalb-divider{margin-left:auto;margin-right:auto;}
  .alqalb-divider{margin-left:auto;margin-right:auto;}
  .pourquoi-grid,.oustaz-grid{grid-template-columns:1fr;gap:2rem;}
  .chiffres-grid{grid-template-columns:repeat(2,1fr);}
  .oustaz-photo-wrap img.oustaz-photo{
    width:min(188px,72vw);
    height:min(188px,72vw);
  }
  .oustaz-photo-wrap--placeholder{
    width:min(188px,72vw);
    height:min(188px,72vw);
  }
  .bootcamp-avenir-list{padding:0 1.5rem;}
  .footer-tagline{letter-spacing:.16em;line-height:1.7;}
  .footer-contact,.footer-links{flex-direction:column;gap:.65rem;}
}
@keyframes hadith-left{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── Calligraphie arabe décorative ── */
.calli-bg{
  position:fixed;inset:0;
  pointer-events:none;z-index:0;
  overflow:hidden;
}
.calli-svg{
  position:absolute;
  user-select:none;
}
.calli-1{
  width:600px;top:8%;left:-5%;
  transform:rotate(-8deg);
  animation:calli-float 18s ease-in-out infinite;
}
.calli-2{
  width:400px;top:38%;right:2%;
  transform:rotate(6deg);
  animation:calli-float 24s ease-in-out infinite reverse;
}
.calli-3{
  width:500px;bottom:22%;left:10%;
  transform:rotate(-4deg);
  animation:calli-float 20s ease-in-out infinite 4s;
}
.calli-4{
  width:700px;bottom:5%;right:-8%;
  transform:rotate(5deg);
  animation:calli-float 28s ease-in-out infinite 8s;
}
/* ── Verset animé An-Nâzi'at ── */
.verset-naziat-wrap{
  text-align:center;
  padding:2.5rem 1rem;
}
.verset-ligne{
  display:block;
  font-family:var(--font-title);
  font-style:italic;
  opacity:0;
  transform:translateY(16px);
  transition:opacity .9s ease, transform .9s ease;
}
.verset-ligne.visible{
  opacity:1;
  transform:translateY(0);
}
.verset-ligne-1{ transition-delay:.1s; font-size:clamp(1rem,2.2vw,1.4rem); color:var(--or); }
.verset-ligne-2{ transition-delay:.5s; font-size:clamp(.9rem,1.8vw,1.2rem); color:var(--or); margin-top:.5rem; }
.verset-trad-1{ transition-delay:.9s; font-size:clamp(.88rem,1.5vw,1.05rem); color:rgba(255,255,255,0.65); font-style:italic; margin-top:.8rem; font-family:var(--font-body); }
.verset-trad-2{ transition-delay:1.3s; font-size:clamp(.88rem,1.5vw,1.05rem); color:rgba(255,255,255,0.65); font-style:italic; font-family:var(--font-body); }
.verset-ref-anim{ transition-delay:1.7s; font-size:.78rem; color:rgba(255,255,255,0.4); margin-top:.5rem; font-family:var(--font-ui); }
@keyframes pulse-or{0%,100%{opacity:.7}50%{opacity:1}}
.mawa-word{ color:var(--or); font-weight:600; animation:pulse-or 2.5s ease-in-out infinite; }
/* ── Sections fond ivoire — textes adaptés ── */
.offres .section-label,
.rejoindre .section-label{color:#E1A730;}
.offres .section-title,
.rejoindre .section-title{color:#552F84;}
.offres .divider,
.rejoindre .divider{background:#E1A730;opacity:.4;}
.rejoindre .fondatrice-bio,
.rejoindre p{color:rgba(61,31,101,.65);}

.offres .section-label{color:#FFFFFF;font-weight:700;}
.offres .section-title{color:#FFFFFF;font-weight:700;}
.offres .divider{background:#E1A730;}
.gif-section .section-label{color:#FFFFFF;font-weight:700;}
.gif-section .section-title{color:#FFFFFF;font-weight:700;}
.gif-section .divider{background:#E1A730;}

.rejoindre .section-label{color:#FFFFFF;font-weight:700;}
.rejoindre .section-title{color:#FFFFFF;font-weight:700;}
.rejoindre .divider{background:#E1A730;}

.bc-classe{
  margin:.8rem 0;
  background:rgba(225,167,48,.07);
  border:1px solid rgba(225,167,48,.18);
  border-radius:6px;
  padding:.7rem 1rem;
}
.bc-classe-label{
  font-family:var(--font-ui);
  font-size:.62rem;
  color:var(--or);
  letter-spacing:.15em;
  text-transform:uppercase;
  font-weight:700;
  margin-bottom:.4rem;
  display:block;
}
.bc-classe-item{
  font-family:var(--font-body);
  font-size:.88rem;
  color:rgba(255,255,255,.78);
  line-height:1.75;
}
.bc-classe-ou{
  font-family:var(--font-body);
  font-style:italic;
  color:rgba(225,167,48,.5);
  font-size:.85rem;
  display:block;
  text-align:center;
  margin:.1rem 0;
}

.bc-avenir{position:relative;opacity:.82;}
.bc-avenir::after{content:'À venir';position:absolute;top:12px;right:12px;background:rgba(225,167,48,.15);border:1px solid rgba(225,167,48,.3);color:var(--or);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .6rem;font-family:var(--font-ui);font-weight:600;}
.bc-interest-btn{display:block;border:1px solid rgba(225,167,48,.35);color:var(--or);padding:.55rem 1.2rem;font-family:var(--font-ui);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:all .3s;background:transparent;margin-top:.8rem;width:100%;text-align:center;box-sizing:border-box;}
.bc-interest-btn:hover{background:rgba(225,167,48,.08);border-color:var(--or);}

@keyframes calli-float{
  0%,100%{transform:translateY(0) rotate(var(--r,0deg));}
  50%{transform:translateY(-18px) rotate(var(--r,0deg));}
}
