/* ═══════════════════════════════════════════════════════════════
   MIQAT — aligné identité site visitearabie (dark/HUD)
   Noir profond #010306 + or chaud #d4a843 + Cinzel + Share Tech Mono
   ═══════════════════════════════════════════════════════════════ */

:root{
  /* Palette site (DARK = défaut) */
  --gold:#d4a843;
  --gold-light:#f0c862;
  --gold-dark:#8b6f2c;
  --green-deep:#3dd68c;
  --green-sage:#5fe9a3;
  --cream:#e8e0cc;
  --bg:#010306;
  --bg-2:#0a0d14;
  --bg-3:#141822;
  --card:var(--bg-2);
  --cream-2:var(--bg-3);
  --text:var(--cream);
  --slate:#e8e0cc;
  --slate-soft:#a09080;
  --terracotta:#e85b8c;
  --night-blue:#52aaee;
  --line:rgba(212,168,67,.2);
  --shadow:0 4px 22px rgba(0,0,0,.55);
  --shadow-lg:0 12px 44px rgba(0,0,0,.7);
  --radius:14px;
  --radius-sm:8px;
  --serif:'Cinzel','Cormorant Garamond',Georgia,serif;
  --sans:'Inter','Manrope',-apple-system,sans-serif;
  --hud:'Share Tech Mono',monospace;
  --arabic:'Amiri','Scheherazade New',serif;
}

[data-theme="light"]{
  --gold:#c9a961;
  --gold-dark:#8b6f3a;
  --green-deep:#0d6e3e;
  --bg:#fdf8f0;
  --bg-2:#fff;
  --bg-3:#f7efdf;
  --card:#fff;
  --cream:#fdf8f0;
  --cream-2:#f7efdf;
  --text:#3d3d3d;
  --slate:#3d3d3d;
  --slate-soft:#5d5d5d;
  --terracotta:#a73e3e;
  --night-blue:#1a4d7a;
  --line:rgba(139,111,58,.18);
  --shadow:0 4px 20px rgba(0,0,0,.08);
  --shadow-lg:0 12px 40px rgba(0,0,0,.12);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:var(--sans);background:var(--bg);color:var(--text);
  font-size:16px;line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background-image:
    radial-gradient(circle at 20% 10%,rgba(212,168,67,.06) 0%,transparent 60%),
    radial-gradient(circle at 80% 80%,rgba(61,214,140,.04) 0%,transparent 60%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 60' opacity='0.06'><path d='M30 0 L37.5 22.5 L60 30 L37.5 37.5 L30 60 L22.5 37.5 L0 30 L22.5 22.5 Z' fill='%23d4a843'/></svg>");
  background-size:auto,auto,180px;
  min-height:100vh;
}
[data-theme="light"] body{
  background-image:
    radial-gradient(circle at 20% 10%,rgba(13,110,62,.04) 0%,transparent 60%),
    radial-gradient(circle at 80% 80%,rgba(201,169,97,.05) 0%,transparent 60%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 60' opacity='0.04'><path d='M30 0 L37.5 22.5 L60 30 L37.5 37.5 L30 60 L22.5 37.5 L0 30 L22.5 22.5 Z' fill='%238b6f3a'/></svg>");
  background-size:auto,auto,180px;
}

a{color:var(--green-deep);text-decoration:none;transition:color .18s}
a:hover{color:var(--gold-dark)}
a:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
img{max-width:100%;height:auto;display:block}

/* ═════════ TYPOGRAPHIE ═════════ */
h1,h2,h3,h4{font-family:var(--serif);color:var(--green-deep);line-height:1.2;font-weight:600}
h1{font-size:clamp(2rem,6vw,3.4rem);letter-spacing:-.01em}
h2{font-size:clamp(1.5rem,4vw,2.25rem);margin-bottom:.5em}
h3{font-size:clamp(1.15rem,2.6vw,1.5rem);color:var(--gold-dark);margin-bottom:.35em}
h4{font-size:1.05rem;color:var(--gold-dark)}
p{margin-bottom:.85em}
strong{color:var(--green-deep);font-weight:600}
[data-theme="dark"] h1,
[data-theme="dark"] h2{color:#7dd09e}
[data-theme="dark"] h3,
[data-theme="dark"] h4{color:var(--gold)}
[data-theme="dark"] strong{color:#7dd09e}

.arabic{
  font-family:var(--arabic);direction:rtl;text-align:right;
  line-height:1.9;color:var(--green-deep);font-weight:400;
}
[data-theme="dark"] .arabic{color:#7dd09e}
.translit{font-style:italic;color:var(--gold-dark);font-size:.93em}
[data-theme="dark"] .translit{color:var(--gold)}

/* ═════════ HEADER ═════════ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(253,248,240,.92);backdrop-filter:saturate(1.2) blur(10px);
  border-bottom:1px solid var(--line);
}
[data-theme="dark"] .site-header{background:rgba(14,20,16,.92)}
.header-inner{
  max-width:1200px;margin:0 auto;padding:12px 18px;
  display:flex;align-items:center;gap:18px;
}
.brand{
  font-family:var(--serif);font-weight:700;font-size:1.1rem;
  color:var(--green-deep);text-decoration:none;flex-shrink:0;
}
.brand .crescent{color:var(--gold);margin-right:6px}
.nav-rapide{display:flex;gap:14px;flex:1;overflow-x:auto;scrollbar-width:none}
.nav-rapide::-webkit-scrollbar{display:none}
.nav-step{
  font-size:.78rem;color:var(--slate-soft);text-transform:uppercase;
  letter-spacing:.1em;white-space:nowrap;padding:6px 0;font-weight:500;
  border-bottom:2px solid transparent;
}
.nav-step.active{color:var(--gold-dark);border-bottom-color:var(--gold)}
[data-theme="dark"] .nav-step.active{color:var(--gold)}
.header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.icon-btn{
  width:38px;height:38px;border-radius:50%;
  background:transparent;border:1px solid var(--line);
  color:var(--slate);cursor:pointer;font-size:1rem;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all .18s;
}
.icon-btn:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
.menu-burger{display:none}
@media (max-width:880px){
  .nav-rapide{display:none}
  .nav-rapide.open{
    display:flex;flex-direction:column;position:absolute;
    top:100%;left:0;right:0;background:var(--card);
    padding:14px 18px;border-bottom:1px solid var(--line);
    box-shadow:var(--shadow-lg);
  }
  .menu-burger{display:inline-flex}
}

/* ═════════ HERO ═════════ */
.hero{
  position:relative;min-height:84vh;display:flex;align-items:center;
  padding:60px 18px;color:#fff;overflow:hidden;text-align:center;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(13,30,20,.78) 0%,rgba(8,18,12,.92) 100%),
    radial-gradient(ellipse at 50% 30%,#1a4d2e 0%,#0d2a18 70%);
  z-index:0;
}
.hero::after{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' opacity='0.08'><polygon points='50,5 60,40 95,50 60,60 50,95 40,60 5,50 40,40' fill='%23c9a961'/></svg>");
  background-size:160px;z-index:1;mix-blend-mode:overlay;
}
.hero-inner{position:relative;z-index:2;max-width:760px;margin:0 auto}
.hero-badge{
  display:inline-block;padding:6px 16px;border-radius:30px;
  background:rgba(201,169,97,.15);border:1px solid var(--gold);
  color:var(--gold);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  margin-bottom:24px;
}
.hero h1{color:#fff;margin-bottom:14px;text-shadow:0 2px 22px rgba(0,0,0,.3)}
.hero-sub{font-size:1.05rem;color:#ddd5c2;margin-bottom:36px;font-weight:300}
.hero-arabic{
  font-family:var(--arabic);font-size:clamp(2rem,6vw,3.6rem);
  color:var(--gold);line-height:1.4;direction:rtl;
  margin:30px 0;text-shadow:0 0 30px rgba(201,169,97,.4);
  animation:gentlePulse 4s ease-in-out infinite;
}
@keyframes gentlePulse{0%,100%{opacity:.92;text-shadow:0 0 22px rgba(201,169,97,.35)}50%{opacity:1;text-shadow:0 0 38px rgba(201,169,97,.6)}}
.hero-cta{
  display:inline-block;padding:14px 30px;border-radius:50px;
  background:linear-gradient(135deg,var(--gold) 0%,#b89241 100%);
  color:#1a1a1a;text-decoration:none;font-weight:600;
  letter-spacing:.05em;font-size:.95rem;
  box-shadow:0 6px 22px rgba(201,169,97,.4);
  transition:all .25s;margin-top:14px;
}
.hero-cta:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(201,169,97,.55);color:#1a1a1a}
.hero-progress{
  margin-top:36px;display:inline-flex;align-items:center;gap:8px;
  font-size:.72rem;color:var(--slate-soft);letter-spacing:.18em;text-transform:uppercase;
}
.hero-progress .dots{display:inline-flex;gap:6px}
.hero-progress .dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2)}
.hero-progress .dot.done{background:var(--gold)}
.hero-progress .dot.current{background:var(--gold);box-shadow:0 0 10px var(--gold)}

/* ═════════ LAYOUT MAIN ═════════ */
.layout{
  max-width:1200px;margin:0 auto;padding:60px 18px;
  display:grid;grid-template-columns:1fr;gap:40px;
}
@media (min-width:1024px){
  .layout{grid-template-columns:240px 1fr;gap:50px;align-items:start}
}

/* ═════════ SOMMAIRE ═════════ */
.toc{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 16px;box-shadow:var(--shadow);
}
@media (min-width:1024px){
  .toc{position:sticky;top:90px;max-height:calc(100vh - 110px);overflow-y:auto}
}
.toc-title{
  font-family:var(--serif);font-size:.85rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold-dark);margin-bottom:12px;
  padding-bottom:10px;border-bottom:1px solid var(--line);font-weight:700;
}
.toc-list{list-style:none}
.toc-list li{margin:0}
.toc-list a{
  display:block;padding:8px 10px;border-radius:6px;
  font-size:.82rem;color:var(--slate);transition:all .15s;
  border-left:2px solid transparent;
}
.toc-list a:hover{background:rgba(13,110,62,.05);color:var(--green-deep)}
.toc-list a.active{
  background:rgba(201,169,97,.1);color:var(--gold-dark);
  border-left-color:var(--gold);font-weight:600;
}
[data-theme="dark"] .toc-list a.active{color:var(--gold)}

.toc-mobile-toggle{
  display:none;width:100%;padding:10px;border:none;
  background:transparent;font-family:inherit;color:var(--slate);
  font-size:.82rem;text-align:left;cursor:pointer;
}
@media (max-width:1023px){
  .toc-mobile-toggle{display:flex;justify-content:space-between;align-items:center}
  .toc-list{display:none;margin-top:12px}
  .toc.open .toc-list{display:block}
  .toc-mobile-toggle::after{content:'▼';font-size:.7rem;transition:transform .2s}
  .toc.open .toc-mobile-toggle::after{transform:rotate(180deg)}
}

/* ═════════ SECTIONS ═════════ */
.content section{margin-bottom:56px;scroll-margin-top:90px;opacity:0;transform:translateY(20px);transition:all .8s ease-out}
.content section.visible{opacity:1;transform:none}
.section-num{
  display:inline-block;width:32px;height:32px;border-radius:50%;
  background:var(--gold);color:#fff;text-align:center;line-height:32px;
  font-family:var(--serif);font-size:.95rem;font-weight:700;margin-right:10px;
  vertical-align:middle;
}
.section-head{display:flex;align-items:center;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.section-intro{color:var(--slate-soft);font-size:1.02rem;margin-bottom:24px;max-width:640px;line-height:1.7}

/* ═════════ CARTES GÉNÉRIQUES ═════════ */
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;
}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.card .icon{
  width:44px;height:44px;border-radius:10px;
  background:linear-gradient(135deg,var(--green-sage) 0%,var(--green-deep) 100%);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;margin-bottom:12px;
}
.card h3{margin-bottom:8px;font-size:1.05rem}
.tag{
  display:inline-block;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;
  padding:2px 8px;border-radius:4px;font-weight:600;margin-bottom:8px;
}
.tag-h{background:rgba(26,77,122,.12);color:var(--night-blue)}
.tag-f{background:rgba(167,62,62,.12);color:var(--terracotta)}
.tag-all{background:rgba(13,110,62,.12);color:var(--green-deep)}
[data-theme="dark"] .tag-h{background:rgba(82,170,238,.18);color:#82c0e8}
[data-theme="dark"] .tag-f{background:rgba(232,128,128,.18);color:#e8a0a0}
[data-theme="dark"] .tag-all{background:rgba(125,208,158,.18);color:#7dd09e}

/* ═════════ ALERT ═════════ */
.alert{
  padding:16px 18px;border-radius:var(--radius-sm);margin:18px 0;
  border-left:4px solid;font-size:.93rem;line-height:1.6;
}
.alert-warn{background:rgba(167,62,62,.06);border-color:var(--terracotta);color:var(--terracotta)}
.alert-info{background:rgba(26,77,122,.06);border-color:var(--night-blue);color:var(--night-blue)}
.alert-tip{background:rgba(13,110,62,.06);border-color:var(--green-deep);color:var(--green-deep)}
[data-theme="dark"] .alert-warn{background:rgba(232,128,128,.08);color:#e8a0a0}
[data-theme="dark"] .alert-info{background:rgba(82,170,238,.08);color:#82c0e8}
[data-theme="dark"] .alert-tip{background:rgba(125,208,158,.08);color:#7dd09e}
.alert strong{color:inherit}

/* ═════════ MIQAT — 5 lieux ═════════ */
.miqats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px;margin-top:18px}
.miqat-card{
  background:var(--card);padding:14px;border-radius:var(--radius-sm);
  border:1px solid var(--line);font-size:.88rem;
}
.miqat-card .name{font-weight:600;color:var(--green-deep);font-family:var(--serif);font-size:1.02rem}
.miqat-card .ar{font-family:var(--arabic);direction:rtl;color:var(--gold-dark);font-size:1.05rem;margin:4px 0}
.miqat-card .gps{font-family:'Courier New',monospace;font-size:.78rem;color:var(--slate-soft);margin:6px 0}
.miqat-card .for-who{font-size:.78rem;color:var(--slate);font-style:italic}
.miqat-card .gmaps{
  display:inline-block;margin-top:8px;font-size:.78rem;color:var(--gold-dark);
  text-decoration:underline;text-decoration-color:var(--gold);
}

/* ═════════ PRÉPARATION ═════════ */
.prep-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}

/* ═════════ VÊTEMENTS — 2 colonnes ═════════ */
.outfits{display:grid;grid-template-columns:1fr;gap:20px;margin-top:18px}
@media (min-width:768px){.outfits{grid-template-columns:1fr 1fr}}
.outfit-card{
  background:var(--card);padding:24px;border-radius:var(--radius);
  border:1px solid var(--line);box-shadow:var(--shadow);
}
.outfit-card.male{border-top:4px solid var(--night-blue)}
.outfit-card.female{border-top:4px solid var(--terracotta)}
.outfit-svg{
  width:120px;height:160px;margin:0 auto 14px;display:block;
  filter:drop-shadow(0 4px 14px rgba(0,0,0,.1));
}
.outfit-card h3{text-align:center;margin-bottom:14px}
.outfit-list{list-style:none;font-size:.88rem;line-height:1.85}
.outfit-list li{padding-left:24px;position:relative;margin-bottom:6px}
.outfit-list li.ok::before{content:'✓';position:absolute;left:0;color:var(--green-deep);font-weight:bold}
.outfit-list li.no::before{content:'✗';position:absolute;left:0;color:var(--terracotta);font-weight:bold}

/* ═════════ NIYYAH — section spéciale ═════════ */
.niyyah-section{
  background:linear-gradient(135deg,rgba(13,110,62,.04) 0%,rgba(201,169,97,.06) 100%);
  border-radius:var(--radius);padding:30px 18px;border:1px solid var(--line);
}
[data-theme="dark"] .niyyah-section{background:linear-gradient(135deg,rgba(13,110,62,.1) 0%,rgba(201,169,97,.08) 100%)}
.niyyah-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-top:18px}
@media (min-width:768px){.niyyah-grid{grid-template-columns:repeat(3,1fr)}}
.niyyah-card{
  background:var(--card);padding:22px 18px;border-radius:var(--radius);
  border:1px solid var(--line);text-align:center;box-shadow:var(--shadow);
  transition:transform .2s;
}
.niyyah-card:hover{transform:translateY(-3px)}
.niyyah-card .label{
  font-family:var(--serif);font-size:.85rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold-dark);margin-bottom:14px;
}
.niyyah-card .ar-big{
  font-family:var(--arabic);font-size:clamp(1.6rem,5vw,2.2rem);
  color:var(--green-deep);direction:rtl;line-height:1.6;margin:14px 0;
}
[data-theme="dark"] .niyyah-card .ar-big{color:#7dd09e}
.niyyah-card .translit{font-size:.88rem;margin:10px 0}
.niyyah-card .fr{color:var(--slate);font-size:.88rem;font-style:italic;margin-bottom:14px}
.niyyah-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.btn-mini{
  padding:7px 14px;border-radius:6px;font-size:.78rem;border:1px solid var(--gold);
  background:transparent;color:var(--gold-dark);cursor:pointer;
  font-family:inherit;transition:all .15s;
}
.btn-mini:hover{background:var(--gold);color:#fff}

/* ═════════ TALBIYA — section pleine largeur ═════════ */
.talbiya-wrap{
  background:linear-gradient(135deg,#0d2a18 0%,#1a4d2e 100%);
  color:#fff;padding:60px 18px;border-radius:var(--radius);
  text-align:center;position:relative;overflow:hidden;margin:24px 0;
}
.talbiya-wrap::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80' opacity='0.06'><polygon points='40,4 48,32 76,40 48,48 40,76 32,48 4,40 32,32' fill='%23c9a961'/></svg>");
  background-size:140px;
}
.talbiya-wrap > *{position:relative;z-index:2}
.talbiya-wrap h2{color:var(--gold);margin-bottom:18px}
.talbiya-arabic{
  font-family:var(--arabic);font-size:clamp(1.6rem,5vw,2.6rem);
  color:#fff;line-height:2.2;direction:rtl;
  margin:30px auto;max-width:920px;
  text-shadow:0 0 40px rgba(201,169,97,.5);
  animation:gentlePulse 4.5s ease-in-out infinite;
}
.talbiya-translit{
  font-family:var(--sans);font-style:italic;color:var(--gold);
  font-size:1rem;margin:14px 0;line-height:1.8;
}
.talbiya-fr{color:#e8e0c8;max-width:680px;margin:14px auto 24px;font-size:.95rem;line-height:1.7}
.talbiya-audio{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:50px;
  background:var(--gold);color:#1a1a1a;cursor:pointer;
  border:none;font-family:inherit;font-weight:600;font-size:.92rem;
  box-shadow:0 6px 20px rgba(201,169,97,.4);transition:all .25s;
}
.talbiya-audio:hover{transform:scale(1.04);box-shadow:0 10px 30px rgba(201,169,97,.6)}
.talbiya-note{
  margin-top:24px;padding:14px;background:rgba(255,255,255,.06);
  border-radius:8px;font-size:.86rem;color:#ddd5c2;
  max-width:560px;margin-left:auto;margin-right:auto;
}

/* ═════════ INTERDITS — onglets ═════════ */
.tabs{display:flex;gap:4px;margin-bottom:18px;border-bottom:1px solid var(--line);overflow-x:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab-btn{
  padding:10px 18px;background:transparent;border:none;cursor:pointer;
  font-family:inherit;font-size:.88rem;color:var(--slate-soft);
  border-bottom:2px solid transparent;font-weight:500;white-space:nowrap;
  transition:all .15s;
}
.tab-btn.active{color:var(--terracotta);border-bottom-color:var(--terracotta);font-weight:600}
.tab-content{display:none}
.tab-content.active{display:block;animation:fadeIn .3s ease-out}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.interdit-list{list-style:none}
.interdit-list li{
  background:rgba(167,62,62,.05);border:1px solid rgba(167,62,62,.2);
  border-radius:var(--radius-sm);padding:14px 16px 14px 50px;margin-bottom:10px;
  position:relative;font-size:.92rem;
}
.interdit-list li::before{
  content:'✗';position:absolute;left:16px;top:50%;transform:translateY(-50%);
  width:24px;height:24px;background:var(--terracotta);color:#fff;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:bold;font-size:.85rem;
}
.interdit-list li strong{color:var(--terracotta);display:block;margin-bottom:2px}
[data-theme="dark"] .interdit-list li{background:rgba(232,128,128,.06);border-color:rgba(232,128,128,.25)}
[data-theme="dark"] .interdit-list li strong{color:#e8a0a0}

/* ═════════ AUTORISÉS ═════════ */
.autorise-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.autorise-item{
  background:rgba(13,110,62,.05);border:1px solid rgba(13,110,62,.2);
  border-radius:var(--radius-sm);padding:12px 14px 12px 42px;position:relative;
  font-size:.9rem;
}
.autorise-item::before{
  content:'✓';position:absolute;left:12px;top:50%;transform:translateY(-50%);
  width:22px;height:22px;background:var(--green-deep);color:#fff;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:bold;font-size:.8rem;
}
[data-theme="dark"] .autorise-item{background:rgba(125,208,158,.06);border-color:rgba(125,208,158,.25)}

/* ═════════ ACCORDÉON ═════════ */
.accordion{display:flex;flex-direction:column;gap:8px}
.acc-item{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.acc-head{
  padding:14px 18px;cursor:pointer;display:flex;justify-content:space-between;
  align-items:center;font-weight:600;color:var(--green-deep);
  font-family:var(--serif);font-size:1rem;
}
[data-theme="dark"] .acc-head{color:#7dd09e}
.acc-head::after{content:'+';font-size:1.4rem;color:var(--gold);transition:transform .25s;font-weight:300}
.acc-item.open .acc-head::after{transform:rotate(45deg)}
.acc-body{
  padding:0 18px;max-height:0;overflow:hidden;
  transition:max-height .35s ease,padding .35s ease;
}
.acc-item.open .acc-body{padding:0 18px 18px;max-height:1000px}

/* ═════════ CONSEILS — slider ═════════ */
.conseils-wrap{
  background:linear-gradient(135deg,#0e2747 0%,#1a4d7a 100%);
  color:#fff;padding:40px 18px;border-radius:var(--radius);
  position:relative;overflow:hidden;text-align:center;
}
.conseils-wrap::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' opacity='0.15'><circle cx='10' cy='10' r='1' fill='%23c9a961'/><circle cx='30' cy='25' r='1.5' fill='%23c9a961'/><circle cx='70' cy='15' r='1' fill='%23c9a961'/><circle cx='50' cy='50' r='2' fill='%23c9a961'/><circle cx='85' cy='60' r='1' fill='%23c9a961'/><circle cx='20' cy='80' r='1.5' fill='%23c9a961'/><circle cx='60' cy='90' r='1' fill='%23c9a961'/></svg>");
  background-size:240px;
}
.conseils-wrap > *{position:relative;z-index:2}
.conseils-wrap h2{color:var(--gold)}
.slider{margin-top:24px;min-height:160px;display:flex;align-items:center;justify-content:center}
.slide{display:none;animation:fadeIn .5s ease-out;max-width:720px}
.slide.active{display:block}
.slide .quote{
  font-family:var(--serif);font-size:clamp(1.05rem,2.4vw,1.3rem);
  font-style:italic;line-height:1.7;color:#fff;margin-bottom:14px;
}
.slide .source{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.slider-nav{display:flex;gap:8px;justify-content:center;margin-top:24px}
.slider-nav button{
  width:10px;height:10px;border-radius:50%;border:none;
  background:rgba(201,169,97,.3);cursor:pointer;transition:all .2s;
}
.slider-nav button.active{background:var(--gold);width:30px;border-radius:5px}

/* ═════════ CHECKLIST ═════════ */
.checklist-wrap{
  background:var(--card);border:2px solid var(--gold);border-radius:var(--radius);
  padding:24px 20px;box-shadow:var(--shadow-lg);
}
.checklist-progress{
  height:8px;background:rgba(201,169,97,.15);border-radius:4px;
  overflow:hidden;margin-bottom:18px;
}
.checklist-progress-bar{
  height:100%;background:linear-gradient(90deg,var(--green-sage),var(--green-deep));
  border-radius:4px;width:0;transition:width .4s ease;
}
.checklist-counter{
  font-size:.82rem;color:var(--slate-soft);text-align:right;margin-bottom:18px;
  font-family:var(--serif);
}
.checklist-counter strong{color:var(--gold-dark);font-size:1.05rem}
.check-item{
  display:flex;align-items:flex-start;gap:12px;padding:12px;
  border-radius:var(--radius-sm);cursor:pointer;
  border:1px solid transparent;transition:all .18s;margin-bottom:6px;
}
.check-item:hover{background:rgba(201,169,97,.05);border-color:var(--line)}
.check-item.checked{background:rgba(13,110,62,.06);border-color:var(--green-deep)}
.check-item input{display:none}
.check-box{
  width:24px;height:24px;border:2px solid var(--gold);border-radius:6px;
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all .2s;
}
.check-item.checked .check-box{background:var(--green-deep);border-color:var(--green-deep)}
.check-box::after{content:'';width:0;height:0;border:solid #fff;border-width:0 0 0 0;transition:all .2s}
.check-item.checked .check-box::after{
  content:'';width:6px;height:11px;border-color:#fff;border-width:0 2.5px 2.5px 0;
  transform:rotate(45deg);margin-bottom:3px;
}
.check-label{font-size:.95rem;line-height:1.5;color:var(--text);font-family:var(--sans)}
.check-item.checked .check-label{color:var(--slate-soft);text-decoration:line-through}
.checklist-actions{display:flex;justify-content:space-between;margin-top:20px;flex-wrap:wrap;gap:10px}
.btn-reset{
  padding:8px 16px;background:transparent;border:1px solid var(--line);
  color:var(--slate-soft);border-radius:6px;cursor:pointer;font-family:inherit;
  font-size:.82rem;
}
.btn-reset:hover{color:var(--terracotta);border-color:var(--terracotta)}
.checklist-success{
  display:none;text-align:center;padding:24px;margin-top:16px;
  background:linear-gradient(135deg,rgba(13,110,62,.1) 0%,rgba(201,169,97,.1) 100%);
  border:1px solid var(--green-deep);border-radius:var(--radius);
}
.checklist-success.show{display:block;animation:popIn .5s cubic-bezier(.18,.89,.32,1.28)}
@keyframes popIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:none}}
.checklist-success .ic{font-size:2.6rem;margin-bottom:10px;display:block}
.checklist-success .ar{
  font-family:var(--arabic);font-size:1.6rem;color:var(--green-deep);direction:rtl;margin:10px 0;
}
[data-theme="dark"] .checklist-success .ar{color:#7dd09e}

/* ═════════ FOOTER ═════════ */
.site-footer{
  background:linear-gradient(180deg,var(--cream-2) 0%,var(--cream) 100%);
  border-top:1px solid var(--line);padding:50px 18px 30px;text-align:center;
}
.footer-cta{
  font-family:var(--serif);font-size:1.4rem;color:var(--green-deep);
  margin-bottom:14px;
}
.btn-next{
  display:inline-block;padding:14px 30px;border-radius:50px;
  background:linear-gradient(135deg,var(--green-deep),#0a5c33);
  color:#fff;text-decoration:none;font-weight:600;letter-spacing:.04em;
  box-shadow:0 6px 22px rgba(13,110,62,.35);transition:all .25s;margin:14px 0 24px;
}
.btn-next:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(13,110,62,.5);color:#fff}
.footer-links{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin:14px 0;font-size:.85rem}
.footer-meta{margin-top:24px;font-size:.78rem;color:var(--slate-soft);max-width:560px;margin-left:auto;margin-right:auto;line-height:1.6}
.footer-quote{
  font-family:var(--arabic);font-size:1.4rem;color:var(--gold-dark);
  margin:24px 0;direction:rtl;
}
.footer-translit{font-style:italic;color:var(--slate-soft);font-size:.88rem}

/* ═════════ MENU MOBILE — Quel est mon Miqât ═════════ */
.gmaps-link{
  display:inline-flex;align-items:center;gap:6px;padding:6px 10px;
  background:rgba(201,169,97,.1);border-radius:6px;font-size:.78rem;
  color:var(--gold-dark);text-decoration:none;margin-top:8px;border:1px solid var(--line);
}
.gmaps-link:hover{background:var(--gold);color:#fff}

/* ═════════ PRINT ═════════ */
@media print{
  .site-header,.toc,.hero-cta,.btn-mini,.talbiya-audio,
  .btn-next,.checklist-actions,.tabs,.icon-btn,
  .conseils-wrap,.hero{display:none!important}
  body{background:#fff;color:#000}
  .layout{grid-template-columns:1fr}
  .card,.outfit-card,.niyyah-card{
    page-break-inside:avoid;box-shadow:none;border:1px solid #ccc;
  }
  h1,h2,h3{color:#000!important}
  .arabic{color:#000!important}
}

/* ═════════ FOCUS / A11Y ═════════ */
button:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.tab-btn:focus-visible{outline-offset:-2px}
[data-theme="dark"] .site-footer{background:linear-gradient(180deg,var(--cream-2) 0%,var(--cream) 100%)}
