#zal-lecons /* ═══ Leçons d'Astrologie — Observatoire Zalasrar ═══ */
#zal-lecons{position:relative;overflow:hidden;padding:10px 0 30px}
#zal-lecons *{margin:0;padding:0;box-sizing:border-box}#zal-lecons{
  --bg:#04060d; --panel:rgba(10,15,30,.6); --line:rgba(176,148,74,.22);
  --gold:#c8a951; --gold-hi:#f0d27a; --ink:#efe8d6; --muted:#9aa6bd; --soft:#b9c0cf;
  --green:#3fae86; --red:#d8836b;
}#zal-lecons{
  background:
    radial-gradient(1100px 600px at 50% -12%, #10203c 0%, transparent 60%),
    radial-gradient(800px 500px at 85% 30%, rgba(26,58,92,.25) 0%, transparent 65%),
    radial-gradient(700px 500px at 10% 70%, rgba(124,107,179,.10) 0%, transparent 65%),
    var(--bg);
  color:var(--ink);
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:18px; line-height:1.65;
  min-height:100vh;
}#zal-lecons /* voile d'étoiles en pur CSS */
#zal-lecons::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:
    radial-gradient(1.2px 1.2px at 12% 18%, rgba(240,232,214,.5) 50%, transparent 51%),
    radial-gradient(1px 1px at 32% 64%, rgba(240,210,122,.45) 50%, transparent 51%),
    radial-gradient(1.4px 1.4px at 58% 28%, rgba(240,232,214,.4) 50%, transparent 51%),
    radial-gradient(1px 1px at 76% 74%, rgba(240,232,214,.5) 50%, transparent 51%),
    radial-gradient(1.2px 1.2px at 88% 12%, rgba(240,210,122,.4) 50%, transparent 51%),
    radial-gradient(1px 1px at 44% 88%, rgba(240,232,214,.35) 50%, transparent 51%),
    radial-gradient(1.3px 1.3px at 8% 45%, rgba(240,232,214,.4) 50%, transparent 51%),
    radial-gradient(1px 1px at 66% 52%, rgba(240,210,122,.35) 50%, transparent 51%);
  background-size:900px 700px;
}#zal-lecons .wrap{position:relative;z-index:1;max-width:1060px;margin:0 auto;padding:0 22px}#zal-lecons /* ── En-tête ── */
.hero{text-align:center;padding:78px 0 46px}#zal-lecons .hero .kicker{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.38em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}#zal-lecons .hero .basmala{font-family:'Amiri',serif;font-size:24px;color:rgba(240,210,122,.75);margin-bottom:18px}#zal-lecons .hero h1{
  font-family:'Cinzel',serif;font-weight:600;font-size:clamp(30px,5vw,50px);line-height:1.15;
  background:linear-gradient(180deg,#f5e7bd 0%, #c8a951 78%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  text-wrap:balance;margin-bottom:16px;
}#zal-lecons .hero .sub{max-width:640px;margin:0 auto 26px;color:var(--soft);font-size:19px;font-style:italic;text-wrap:pretty}#zal-lecons .hero .chips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}#zal-lecons .chip{font-family:'Cinzel',serif;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);padding:7px 14px;border-radius:2px;background:rgba(8,12,26,.5)}#zal-lecons .chip b{color:var(--gold-hi);font-weight:600}#zal-lecons /* ── Barre de progression ── */
.progress{margin:8px 0 54px;border:1px solid var(--line);background:var(--panel);padding:16px 20px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}#zal-lecons .progress .bar{flex:1;min-width:200px;height:4px;background:rgba(176,148,74,.15);position:relative}#zal-lecons .progress .bar i{position:absolute;inset:0;right:auto;background:linear-gradient(90deg,var(--gold),var(--gold-hi));box-shadow:0 0 12px rgba(240,210,122,.5)}#zal-lecons .progress .txt{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}#zal-lecons .progress .txt b{color:var(--gold-hi)}#zal-lecons /* ── Modules ── */
.module{margin-bottom:58px}#zal-lecons .module-head{display:flex;align-items:center;gap:18px;margin-bottom:8px}#zal-lecons .module-head .num{
  font-family:'Cinzel',serif;font-size:30px;color:var(--gold-hi);line-height:1;
  border:1px solid var(--line);width:64px;height:64px;display:flex;align-items:center;justify-content:center;
  background:rgba(240,210,122,.05);flex:0 0 auto;text-shadow:0 0 16px rgba(240,210,122,.35);
}#zal-lecons .module-head h2{font-family:'Cinzel',serif;font-weight:600;font-size:23px;color:var(--ink);letter-spacing:.02em}#zal-lecons .module-head .mdesc{color:var(--muted);font-style:italic;font-size:16px;margin-top:2px;text-wrap:pretty}#zal-lecons .module-rule{height:1px;background:linear-gradient(90deg,var(--gold) 0%, transparent 70%);opacity:.45;margin:16px 0 24px}#zal-lecons /* ── Cartes de leçons ── */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}#zal-lecons .card{
  position:relative;border:1px solid var(--line);background:var(--panel);
  padding:22px 22px 18px;display:flex;flex-direction:column;gap:10px;min-height:190px;
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}#zal-lecons .card .n{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--gold);letter-spacing:.1em}#zal-lecons .card h3{font-family:'Cinzel',serif;font-weight:600;font-size:18.5px;line-height:1.3;color:var(--ink);text-wrap:balance}#zal-lecons .card .csub{color:var(--muted);font-style:italic;font-size:15.5px;line-height:1.5;flex:1;text-wrap:pretty}#zal-lecons .card .meta{display:flex;align-items:center;justify-content:space-between;gap:10px;border-top:1px solid rgba(176,148,74,.13);padding-top:12px}#zal-lecons .card .src{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:rgba(154,166,189,.75)}#zal-lecons .card .go{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-hi)}#zal-lecons a.card{text-decoration:none;cursor:pointer}#zal-lecons a.card:hover{transform:translateY(-4px);border-color:rgba(240,210,122,.55);box-shadow:0 14px 38px rgba(0,0,0,.5), 0 0 24px rgba(240,210,122,.10)}#zal-lecons a.card:hover .go{color:#fff;text-shadow:0 0 12px rgba(240,210,122,.8)}#zal-lecons a.card::after{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,transparent,var(--gold-hi),transparent);opacity:0;transition:opacity .25s}#zal-lecons a.card:hover::after{opacity:.8}#zal-lecons /* verrouillée */
.card.locked{opacity:.62;border-style:dashed;border-color:rgba(154,166,189,.25);cursor:not-allowed;user-select:none}#zal-lecons .card.locked h3{color:var(--soft)}#zal-lecons .card.locked .lock{
  position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;
  border:1px solid rgba(154,166,189,.3);background:rgba(8,12,26,.8);
  display:flex;align-items:center;justify-content:center;
}#zal-lecons .card.locked .lock svg{width:13px;height:13px;stroke:var(--muted);fill:none;stroke-width:1.6}#zal-lecons .badge-soon{
  display:inline-flex;align-items:center;gap:7px;
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);border:1px solid rgba(200,169,81,.35);background:rgba(200,169,81,.07);
  padding:5px 11px;border-radius:2px;
}#zal-lecons .badge-soon .dot{width:5px;height:5px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold);animation:pulse 2.2s ease-in-out infinite}@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}#zal-lecons /* ── Page leçon ── */
.lesson{max-width:760px;margin:0 auto;padding:64px 0 40px}#zal-lecons .crumbs{font-family:'Cinzel',serif;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:26px}#zal-lecons .crumbs a{color:var(--gold);text-decoration:none}#zal-lecons .crumbs a:hover{color:var(--gold-hi)}#zal-lecons .lesson-head{border-bottom:1px solid var(--line);padding-bottom:26px;margin-bottom:34px}#zal-lecons .lesson-head .lmodule{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}#zal-lecons .lesson-head h1{font-family:'Cinzel',serif;font-weight:600;font-size:clamp(26px,4.4vw,38px);line-height:1.2;color:var(--ink);text-wrap:balance;margin-bottom:10px}#zal-lecons .lesson-head .lsub{font-size:19px;color:var(--muted);font-style:italic;text-wrap:pretty}#zal-lecons .lesson-head .lmeta{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}#zal-lecons .lesson h2{font-family:'Cinzel',serif;font-weight:600;font-size:22px;color:var(--gold-hi);margin:42px 0 14px}#zal-lecons .lesson p{margin:0 0 16px;color:#dcd6c4;text-wrap:pretty}#zal-lecons .lesson strong{color:var(--ink)}#zal-lecons .lesson em{color:var(--soft)}#zal-lecons .verse{
  border:1px solid var(--line);background:rgba(240,210,122,.035);
  padding:24px 26px;margin:22px 0;text-align:center;
}#zal-lecons .verse .ar{font-family:'Amiri',serif;font-size:27px;line-height:2;color:#f5e7bd;direction:rtl}#zal-lecons .verse .fr{font-style:italic;color:var(--soft);margin-top:10px;font-size:17px}#zal-lecons .verse .ref{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:10px}#zal-lecons .quote{border-left:2px solid var(--gold);padding:4px 0 4px 18px;margin:22px 0;font-style:italic;color:var(--soft);font-size:19px}#zal-lecons .quote .who{display:block;font-style:normal;font-family:'Cinzel',serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:8px}#zal-lecons .tbl{width:100%;border-collapse:collapse;margin:20px 0;font-size:16.5px}#zal-lecons .tbl th{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);text-align:left;padding:10px 12px;border-bottom:1px solid var(--line)}#zal-lecons .tbl td{padding:9px 12px;border-bottom:1px solid rgba(176,148,74,.12);color:#dcd6c4}#zal-lecons .tbl td.ar{font-family:'Amiri',serif;font-size:19px;color:#f5e7bd}#zal-lecons .conform{
  border:1px solid rgba(63,174,134,.35);background:rgba(63,174,134,.05);
  padding:20px 22px;margin:34px 0;
}#zal-lecons .conform .ctitle{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-bottom:8px;display:flex;align-items:center;gap:8px}#zal-lecons .conform p{font-size:16px;color:var(--soft);margin:0 0 8px}#zal-lecons .conform p:last-child{margin:0}#zal-lecons .rigor{
  border:1px solid rgba(216,131,107,.35);background:rgba(216,131,107,.05);
  padding:20px 22px;margin:34px 0;
}#zal-lecons .rigor .ctitle{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:8px}#zal-lecons .rigor p{font-size:16px;color:var(--soft);margin:0}#zal-lecons .lesson-nav{display:flex;gap:14px;margin:48px 0 20px;flex-wrap:wrap}#zal-lecons .lnav{
  flex:1;min-width:240px;border:1px solid var(--line);background:var(--panel);
  padding:16px 18px;text-decoration:none;transition:border-color .25s;
}#zal-lecons .lnav .dir{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}#zal-lecons .lnav .ttl{font-family:'Cinzel',serif;font-size:15px;color:var(--ink)}#zal-lecons a.lnav:hover{border-color:rgba(240,210,122,.5)}#zal-lecons .lnav.locked{opacity:.6;border-style:dashed;cursor:not-allowed}#zal-lecons .lnav.locked .ttl{color:var(--soft)}#zal-lecons .cta{
  border:1px solid rgba(240,210,122,.35);background:rgba(240,210,122,.05);
  padding:22px;margin:40px 0;text-align:center;
}#zal-lecons .cta .t{font-family:'Cinzel',serif;font-size:17px;color:var(--gold-hi);margin-bottom:6px}#zal-lecons .cta p{font-size:16px;color:var(--soft);margin:0 0 14px}#zal-lecons .cta a{display:inline-block;font-family:'Cinzel',serif;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:#04060d;background:linear-gradient(180deg,#f0d27a,#c8a951);padding:11px 26px;text-decoration:none}#zal-lecons .cta a:hover{box-shadow:0 0 24px rgba(240,210,122,.4)}#zal-lecons footer{border-top:1px solid var(--line);margin-top:70px;padding:30px 0 46px;text-align:center}#zal-lecons footer .f{font-family:'Cinzel',serif;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}#zal-lecons footer a{color:var(--gold);text-decoration:none}#zal-lecons footer a:hover{color:var(--gold-hi)}@media (max-width:640px){#zal-lecons .hero{padding:52px 0 34px}#zal-lecons .module-head .num{width:50px;height:50px;font-size:23px}#zal-lecons .verse .ar{font-size:22px}
}

/* conteneur : contexte de positionnement pour le voile d'étoiles */
#zal-lecons{position:relative;overflow:hidden;padding:10px 0 30px}

/* figures d'illustration */
#zal-lecons .lfig{margin:28px 0;text-align:center}
#zal-lecons .lfig img{max-width:100%;height:auto;border:1px solid var(--line);background:rgba(8,12,26,.5);box-shadow:0 18px 50px rgba(0,0,0,.45)}
#zal-lecons .lfig figcaption{font-family:'Cinzel',serif;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:12px}
#zal-lecons .lfig.folio img{max-width:400px}

/* ═══ Confort de lecture (page leçon) ═══ */
#zal-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,#c8a951,#f0d27a);z-index:9999;box-shadow:0 0 10px rgba(240,210,122,.55);transition:width .12s linear}
#zal-lecons .lesson{max-width:720px}
#zal-lecons .lesson p{font-size:19px;line-height:1.78;margin-bottom:20px}
#zal-lecons .lesson .lede::first-letter{font-family:'Cinzel',serif;font-size:62px;line-height:.85;float:left;padding:8px 14px 0 0;color:#f0d27a;text-shadow:0 0 22px rgba(240,210,122,.35)}
#zal-lecons .orn{display:flex;align-items:center;gap:16px;margin:48px 0 6px}
#zal-lecons .orn::before{content:"";height:1px;flex:1;background:linear-gradient(90deg,transparent,rgba(200,169,81,.5))}
#zal-lecons .orn::after{content:"";height:1px;flex:1;background:linear-gradient(90deg,rgba(200,169,81,.5),transparent)}
#zal-lecons .orn span{color:#c8a951;font-size:15px;text-shadow:0 0 14px rgba(240,210,122,.4)}
#zal-lecons .lesson h2{margin-top:10px}
#zal-lecons .verse{position:relative;background:linear-gradient(180deg,rgba(240,210,122,.05),rgba(8,12,26,.35));padding:28px 30px}
#zal-lecons .verse::before{content:"";position:absolute;top:-1px;left:-1px;width:26px;height:26px;border:solid rgba(240,210,122,.65);border-width:2px 0 0 2px}
#zal-lecons .verse::after{content:"";position:absolute;bottom:-1px;right:-1px;width:26px;height:26px;border:solid rgba(240,210,122,.65);border-width:0 2px 2px 0}
#zal-lecons .verse .ar{font-size:29px;line-height:2.05}
#zal-lecons .retenir{border:1px solid var(--line);background:linear-gradient(180deg,rgba(240,210,122,.05),rgba(8,12,26,.4));padding:28px 30px;margin:30px 0}
#zal-lecons .retenir .rt{font-family:'Cinzel',serif;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-hi);margin-bottom:16px}
#zal-lecons .retenir ol{list-style:none;counter-reset:rt;display:grid;gap:14px}
#zal-lecons .retenir li{counter-increment:rt;position:relative;padding-left:46px;color:#dcd6c4;font-size:17.5px;line-height:1.6}
#zal-lecons .retenir li::before{content:counter(rt);position:absolute;left:0;top:1px;width:30px;height:30px;border:1px solid rgba(200,169,81,.55);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:13.5px;color:#f0d27a;background:rgba(240,210,122,.05)}
#zal-lecons .sig{margin:46px 0 6px;text-align:right;border-top:1px solid rgba(176,148,74,.15);padding-top:22px}
#zal-lecons .sig .name{font-family:'Cinzel',serif;font-size:18px;color:#f0d27a;letter-spacing:.06em}
#zal-lecons .sig .role{font-size:14.5px;color:var(--muted);font-style:italic;margin-top:3px}
#zal-lecons .rv{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}
#zal-lecons .rv.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){#zal-lecons .rv{opacity:1;transform:none;transition:none}}
@media (max-width:640px){#zal-lecons .lesson p{font-size:18px}#zal-lecons .verse{padding:22px 18px}#zal-lecons .verse .ar{font-size:23px}}

/* vignettes des cartes de la grille */
#zal-lecons .cthumb{margin:-22px -22px 6px;aspect-ratio:16/9;overflow:hidden;border-bottom:1px solid var(--line);background:#070c1c}
#zal-lecons .cthumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
#zal-lecons a.card:hover .cthumb img{transform:scale(1.05)}
#zal-lecons .cthumb{position:relative}
#zal-lecons .cthumb::after{content:"";position:absolute;inset:0;background:rgba(4,6,13,.28);transition:opacity .3s;pointer-events:none}
#zal-lecons a.card:hover .cthumb::after{opacity:0}
#zal-lecons .cthumb.ph{display:flex;align-items:center;justify-content:center;background:
  radial-gradient(140px 90px at 50% 30%, rgba(26,58,92,.55), transparent 70%),
  radial-gradient(1px 1px at 20% 40%, rgba(240,232,214,.5) 50%, transparent 51%),
  radial-gradient(1px 1px at 75% 25%, rgba(240,210,122,.5) 50%, transparent 51%),
  radial-gradient(1.3px 1.3px at 60% 70%, rgba(240,232,214,.4) 50%, transparent 51%),
  radial-gradient(1px 1px at 35% 75%, rgba(240,210,122,.4) 50%, transparent 51%),
  #070c1c}
#zal-lecons .cthumb.ph span{font-size:34px;color:rgba(200,169,81,.5);text-shadow:0 0 22px rgba(240,210,122,.3)}
#zal-lecons .card.locked .cthumb img{filter:grayscale(.7) brightness(.55)}
#zal-lecons .card.locked .lock{z-index:2}
