:root{--bleu-nuit-noir:#0d1326;}
/* ============================================================
   COUCHE PREMIUM — optimisation visuelle (ajout, ne casse rien)
   ============================================================ */

/* --- Titres de section avec ornement filet doré --- */
.contenu section > h2,
.tirage-titre,
.mdj-suptitre,
.maillage h2,
.faq-section h2 {
  position: relative;
}
.contenu section > h2::after {
  content: "";
  display: block;
  width: 54px;
  height: 2px;
  margin-top: 0.55rem;
  background: linear-gradient(90deg, var(--or-rose), transparent);
  border-radius: 2px;
}
.faq-section h2::after,
.maillage h2::after {
  content: "✦";
  display: block;
  font-size: 0.7rem;
  color: var(--or-rose);
  margin-top: 0.35rem;
  letter-spacing: 0.4em;
}

/* --- Hero : plus de souffle et de profondeur --- */
.hero { padding-top: 3.2rem; }
.hero h1 {
  font-size: clamp(1.9rem, 4.6vw, 2.9rem);
  line-height: 1.18;
  letter-spacing: -0.01em;
  filter: drop-shadow(0 2px 14px rgba(180, 133, 149, 0.12));
}
.hero-ornament {
  animation: ornFloat 5s ease-in-out infinite;
}
@keyframes ornFloat {
  0%, 100% { opacity: 0.7; transform: translateY(0); }
  50% { opacity: 1; transform: translateY(-3px); }
}

/* --- CTA premium : relief, halo, flèche au survol --- */
.cta-card {
  box-shadow: 0 8px 28px rgba(42, 53, 86, 0.10), inset 0 1px 0 rgba(255,255,255,0.4);
  transition: transform 0.28s cubic-bezier(.4,.2,.2,1), box-shadow 0.28s;
}
.cta-card:hover {
  transform: translateY(-6px) scale(1.012);
  box-shadow: 0 18px 44px rgba(42, 53, 86, 0.18), inset 0 1px 0 rgba(255,255,255,0.5);
}
.cta-card-num {
  position: relative;
  transition: letter-spacing 0.3s;
}
.cta-card:hover .cta-card-num { letter-spacing: 0.012em; }
.cta-card-label::after {
  content: " →";
  opacity: 0;
  transition: opacity 0.3s, transform 0.3s;
  display: inline-block;
}
.cta-card:hover .cta-card-label::after { opacity: 0.7; }

/* --- Cartes de maillage : accent doré progressif --- */
.maillage-card {
  position: relative;
  overflow: hidden;
}
.maillage-card::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--or-rose), var(--rose-poudre-fonce));
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.3s ease;
}
.maillage-card:hover::before { transform: scaleY(1); }

/* --- Séparateurs élégants entre grandes sections --- */
.contenu section + section { position: relative; }
.contenu section + section::before {
  content: "❋";
  position: absolute;
  top: -1.1em;
  left: 50%;
  transform: translateX(-50%);
  color: var(--or-rose);
  opacity: 0.32;
  font-size: 0.85rem;
}

/* --- Réponse rapide (encart) : carte vitrée premium --- */
.reponse-rapide {
  background: linear-gradient(150deg, rgba(243,238,248,0.7), rgba(255,255,255,0.55));
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid var(--lavande-aube);
  border-left: 3px solid var(--or-rose);
  border-radius: var(--radius-lg);
  padding: 1.4rem 1.6rem;
  box-shadow: 0 6px 24px rgba(42,53,86,0.07);
}
.reponse-rapide-titre {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.reponse-rapide-titre::before {
  content: "✶";
  color: var(--or-rose);
  font-size: 0.9rem;
}

/* --- Apparition douce des sections au scroll (CSS pur) --- */
@media (prefers-reduced-motion: no-preference) {
  .contenu section,
  .message-jour,
  .tirage,
  .direct,
  .maillage {
    animation: sectionRise 0.7s ease both;
    animation-timeline: view();
    animation-range: entry 0% entry 32%;
  }
  @keyframes sectionRise {
    from { opacity: 0; transform: translateY(22px); }
    to { opacity: 1; transform: translateY(0); }
  }
}

/* --- Header : filet doré sous le brand au scroll --- */
.site-header { transition: box-shadow 0.3s, background 0.3s; }
.brand-mark { transition: transform 0.4s ease; }
.brand:hover .brand-mark { transform: rotate(-12deg) scale(1.08); }

/* --- FAQ : chevron animé et fond au survol --- */
.faq-item {
  border-radius: var(--radius);
  transition: background 0.25s;
}
.faq-item summary {
  transition: color 0.2s;
}
.faq-item summary:hover { color: var(--rose-poudre-fonce); }
.faq-item[open] {
  background: linear-gradient(180deg, rgba(243,238,248,0.5), transparent);
}

/* --- Boutons d'appel sticky mobile : relief --- */
.sticky-mobile { box-shadow: 0 -4px 24px rgba(42,53,86,0.12); }

/* --- Liens de contenu : soulignement doré animé --- */
.contenu p a:not(.cta-card) {
  background-image: linear-gradient(var(--or-rose), var(--or-rose));
  background-size: 0% 1.5px;
  background-repeat: no-repeat;
  background-position: left bottom;
  transition: background-size 0.3s;
  text-decoration: none;
}
.contenu p a:not(.cta-card):hover { background-size: 100% 1.5px; }

/* --- Typo : meilleure lecture des grands paragraphes --- */
.contenu p { text-wrap: pretty; }
.hero h1, .tirage-titre, .mdj-titre { text-wrap: balance; }


/* ============ MODULES PREMIUM V2 ============ */

/* ---- LE DIRECT : panneau nocturne vivant ---- */
.direct2{position:relative;border-radius:22px;padding:1.7rem 1.8rem;margin:2rem auto;max-width:var(--max-width-text);
  background:radial-gradient(120% 140% at 15% 0%,rgba(74,85,120,.55),transparent 55%),radial-gradient(100% 120% at 100% 100%,rgba(180,133,149,.35),transparent 50%),linear-gradient(155deg,var(--bleu-nuit-fonce),var(--bleu-nuit-noir));
  overflow:hidden;box-shadow:0 24px 60px rgba(13,19,38,.35),inset 0 1px 0 rgba(255,255,255,.08);color:#ede9f5}
.direct2-sky{position:absolute;inset:0;pointer-events:none}
.direct2-sky i{position:absolute;width:2px;height:2px;border-radius:50%;background:#fff;opacity:0;animation:tw 4s ease-in-out infinite}
@keyframes tw{0%,100%{opacity:0;transform:scale(.6)}50%{opacity:.9;transform:scale(1)}}
.direct2-glow{position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(201,161,122,.18),transparent 70%);top:-120px;right:-60px;animation:dr 16s ease-in-out infinite}
@keyframes dr{0%,100%{transform:translate(0,0)}50%{transform:translate(-30px,28px)}}
.direct2-head{position:relative;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.4rem}
.direct2-titre{font-family:var(--serif-titre);font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--or-rose-clair);margin:0}
.direct2-clock{font-family:var(--serif-corps);font-variant-numeric:tabular-nums;font-size:1.05rem;color:#cfc9e0;letter-spacing:.04em}
.direct2-grid{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:1.4rem;align-items:center}
@media(max-width:560px){.direct2-grid{grid-template-columns:1fr;gap:1.4rem}}
.presence{display:flex;align-items:center;gap:1rem}
.presence-orb{position:relative;width:54px;height:54px;flex:0 0 auto}
.presence-orb::before{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 40% 35%,var(--vert-dispo),#3f7a3c);box-shadow:0 0 18px rgba(126,199,122,.6)}
.presence-orb::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:1.5px solid rgba(126,199,122,.5);animation:ha 2.4s ease-out infinite}
@keyframes ha{0%{transform:scale(.7);opacity:.7}100%{transform:scale(1.5);opacity:0}}
.presence-txt .presence-h{font-family:var(--serif-titre);font-weight:500;font-size:1.05rem;margin:0 0 .2rem;color:#fff}
.presence-txt p{font-size:.96rem;margin:0;color:#b9b3cc;line-height:1.4}
.moon-block{display:flex;align-items:center;gap:1rem;justify-content:flex-end}
@media(max-width:560px){.moon-block{justify-content:flex-start}}
.moon{position:relative;width:50px;height:50px;border-radius:50%;background:#e8e4d8;box-shadow:inset -3px -3px 8px rgba(0,0,0,.15),0 0 22px rgba(232,228,216,.35);overflow:hidden;flex:0 0 auto}
.moon-shadow{position:absolute;top:0;left:0;width:50px;height:50px;border-radius:50%;background:var(--bleu-nuit-noir)}
.moon-txt{text-align:right}
@media(max-width:560px){.moon-txt{text-align:left}}
.moon-txt strong{display:block;font-family:var(--serif-titre);font-weight:500;font-size:.98rem;color:#fff}
.moon-txt span{font-size:.9rem;color:#b9b3cc;text-transform:capitalize}
.direct2-foot{position:relative;margin-top:1.4rem;padding-top:1.1rem;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.direct2-note{font-style:italic;font-size:.92rem;color:#a59fbb;margin:0}
.direct2-cta{font-family:var(--serif-titre);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bleu-nuit-noir);background:linear-gradient(135deg,var(--or-rose-clair),var(--or-rose));padding:.7rem 1.3rem;border-radius:30px;text-decoration:none;box-shadow:0 6px 18px rgba(201,161,122,.4);transition:transform .25s,box-shadow .25s;white-space:nowrap}
.direct2-cta:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(201,161,122,.55)}
@media(prefers-reduced-motion:reduce){.direct2-sky i,.direct2-glow,.presence-orb::after{animation:none}}

/* ---- TIRAGE : jeu en éventail ---- */
.tirage2{margin:3.5rem auto;max-width:var(--max-width-text);text-align:center}
.tirage2-titre{font-family:var(--serif-titre);font-weight:500;font-size:1.6rem;color:var(--bleu-nuit-doux);margin:0 0 .6rem}
.tirage2-intro{font-family:var(--serif-corps);font-size:1.05rem;font-style:italic;color:var(--texte-clair);max-width:36rem;margin:0 auto 2rem;line-height:1.55}
.tirage2-stage{position:relative;min-height:300px;display:flex;align-items:center;justify-content:center}
.fan{position:relative;width:300px;height:240px;margin:0 auto;transition:opacity .4s}
.fan.is-hidden{opacity:0;pointer-events:none}
.fan-card{position:absolute;left:50%;top:20px;width:120px;height:188px;margin-left:-60px;border:1px solid var(--or-rose);border-radius:12px;cursor:pointer;
  background:linear-gradient(160deg,var(--bleu-nuit-doux),var(--bleu-nuit-fonce));
  box-shadow:0 8px 24px rgba(13,19,38,.3);transform-origin:bottom center;transition:transform .35s cubic-bezier(.4,.2,.2,1),box-shadow .3s;display:flex;align-items:center;justify-content:center}
.fan-card::after{content:"✦";color:var(--or-rose-clair);font-size:1.6rem;opacity:.8}
.fan-card:nth-child(1){transform:rotate(-22deg) translateY(18px)}
.fan-card:nth-child(2){transform:rotate(-11deg) translateY(5px)}
.fan-card:nth-child(3){transform:rotate(0deg)}
.fan-card:nth-child(4){transform:rotate(11deg) translateY(5px)}
.fan-card:nth-child(5){transform:rotate(22deg) translateY(18px)}
.fan-card:hover{transform:translateY(-16px) rotate(0deg) scale(1.04);box-shadow:0 18px 40px rgba(13,19,38,.45);z-index:5}
.drawn{display:flex;flex-direction:column;align-items:center;gap:1.2rem;animation:dz .5s ease both}
@keyframes dz{from{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:none}}
.drawn-card{width:210px;min-height:300px;border-radius:16px;border:1px solid var(--or-rose);
  background:linear-gradient(160deg,#fff,var(--lavande-pale));box-shadow:0 18px 50px rgba(42,53,86,.22);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:1.8rem 1.4rem;
  position:relative;animation:flip .8s cubic-bezier(.4,.2,.2,1)}
@keyframes flip{0%{transform:rotateY(90deg);opacity:0}100%{transform:rotateY(0);opacity:1}}
.drawn-card::before{content:"";position:absolute;inset:-2px;border-radius:18px;background:radial-gradient(circle at 50% 0%,rgba(201,161,122,.4),transparent 60%);z-index:-1;animation:lueur 2.5s ease-in-out infinite}
@keyframes lueur{0%,100%{opacity:.4}50%{opacity:.8}}
.drawn-nom{font-family:var(--serif-titre);font-weight:600;font-size:1.35rem;color:var(--bleu-nuit-doux);text-align:center;line-height:1.2}
.drawn-cle{font-family:var(--serif-titre);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--rose-poudre-fonce)}
.drawn-msg{font-family:var(--serif-corps);font-size:1.08rem;font-style:italic;color:var(--texte-fonce);line-height:1.5;text-align:center;margin-top:.3rem}
.tirage2-retirer{cursor:pointer;font-family:var(--serif-titre);letter-spacing:.1em;text-transform:uppercase;font-size:.74rem;color:var(--rose-poudre-fonce);background:none;border:1px solid var(--lavande-aube);border-radius:30px;padding:.6rem 1.4rem;transition:background .25s,color .25s}
.tirage2-retirer:hover{background:var(--lavande-pale);color:var(--bleu-nuit-doux)}
@media(prefers-reduced-motion:reduce){.drawn-card,.drawn{animation:none}.drawn-card::before{animation:none}}
@media(max-width:560px){.fan{transform:scale(.82)}}

/* ---- MESSAGE DU JOUR : carte mise en scène ---- */
.mdj2{margin:3.5rem auto;max-width:var(--max-width-text)}
.mdj2-card{position:relative;overflow:hidden;border-radius:20px;padding:2.6rem 2.2rem;text-align:center;
  background:radial-gradient(110% 130% at 50% 0%,rgba(235,229,242,.9),transparent 60%),linear-gradient(160deg,#fff,var(--lavande-pale));
  border:1px solid var(--lavande-aube);box-shadow:0 14px 44px rgba(42,53,86,.08)}
.mdj2-halo{position:absolute;top:-80px;left:50%;width:300px;height:300px;margin-left:-150px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,161,122,.16),transparent 70%);animation:mh 9s ease-in-out infinite}
@keyframes mh{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.12);opacity:1}}
.mdj2-sup{position:relative;font-family:var(--serif-titre);text-transform:uppercase;letter-spacing:.24em;font-size:.7rem;color:var(--or-rose);margin:0 0 1rem}
.mdj2-titre{position:relative;font-family:var(--serif-titre);font-weight:500;font-size:1.7rem;color:var(--bleu-nuit-doux);margin:0 0 1rem;transition:opacity .5s}
.mdj2-texte{position:relative;font-family:var(--serif-corps);font-size:1.3rem;line-height:1.6;color:var(--texte-fonce);max-width:34rem;margin:0 auto 1.4rem;transition:opacity .5s}
.mdj2-note{position:relative;font-family:var(--serif-corps);font-size:.9rem;font-style:italic;color:var(--texte-clair);max-width:32rem;margin:0 auto;line-height:1.5}
.mdj2-fade{opacity:0}
@media(prefers-reduced-motion:reduce){.mdj2-halo{animation:none}}
@media(max-width:560px){.mdj2-card{padding:2rem 1.4rem}.mdj2-titre{font-size:1.4rem}.mdj2-texte{font-size:1.12rem}}
