/*
Theme Name:   Libre en Conscience Child
Theme URI:    https://libreenconscience.fr
Description:  Child theme pour libreenconscience.fr — Delphine Perrin, Énergéticienne & Mentor à l'Expansion de Conscience
Author:       Libre en Conscience
Template:     astra
Version:      4.0.1
License:      GNU General Public License v2 or later
Text Domain:  libreenconscience-child
*/

/* ============================================================
   PALETTE OFFICIELLE — Nuit Consciente
   (charte issue des vidéos d'ambiance de la cliente,
   voir CHARTE-GRAPHIQUE.md)
   Noir prune       : #150a13  (fond principal)
   Prune profond    : #1e1020  (sections sombres)
   Carte prune      : #241528  (cartes, encarts)
   Indigo nuit      : #151233  (dégradés ciel)
   Améthyste        : #7b4a9e  (accent structurel)
   Magenta cérémonie: #c94f8e  (accent principal, CTA)
   Rose aurore      : #f4a6bd  (halos, liens)
   Ambre rituel     : #e89850  (lueur chaude, étoiles)
   Crème sable      : #f8e6c6  (titres)
   ============================================================ */

/* Sunborn Sans One — titres H1 (self-hostée).
   ⚠️ Licence « personal use only » : licence commerciale à acquérir
   par la cliente avant mise en ligne (voir CHARTE-GRAPHIQUE.md). */
@font-face {
  font-family: 'Sunborn Sans One';
  src: url('assets/fonts/sunborn-sans-one.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --lec-dark:        #1e1020;   /* prune profond — fonds sombres */
  --lec-brown:       #7b4a9e;   /* améthyste — accent structurel, dégradés */
  --lec-cream:       #f8e6c6;
  --lec-accent:      #c94f8e;   /* magenta cérémonie — CTA, tags */
  --lec-accent-dark: #9c3a6e;   /* version foncée pour hover */
  --lec-amber:       #e89850;   /* ambre rituel — lueur bougie, étoiles */
  --lec-indigo:      #151233;   /* indigo nuit — dégradés ciel */
  --lec-card:        #241528;   /* fond des cartes */
  --lec-bg:          #1a0e1c;
  --lec-bg-light:    #150a13;   /* fond de page — noir prune */
  --lec-text:        #ece0d4;
  --lec-text-light:  #c4aeb4;

  /* Aurore rose — cœur sensoriel de la palette */
  --lec-rose-light:  #ffd9e0;  /* voile nacré */
  --lec-rose:        #f4a6bd;  /* rose aurore principal */
  --lec-rose-deep:   #d76e9b;  /* magenta doux */
  --lec-violet:      #b984c9;  /* trace violette, en faible opacité seulement */
  --lec-rose-glow:   rgba(244,166,189,.55);

  --lec-font-display: 'Sunborn Sans One', 'Arial Black', sans-serif;
  --lec-font-heading: 'proxima-nova', 'Mulish', sans-serif;
  --lec-font-body:    'proxima-nova', 'Mulish', sans-serif;
}

/* ============================================================
   RESET / BASE
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: var(--lec-font-body);
  color: var(--lec-text);
  /* !important : le CSS inline du customizer Astra impose un fond blanc */
  background: var(--lec-bg-light) !important;
  line-height: 1.75;
  margin: 0;
}

h1,h2,h3,h4,h5,h6 {
  font-family: var(--lec-font-heading);
  color: var(--lec-cream);
  line-height: 1.2;
  font-weight: 700;
}

/* H1 — Sunborn Sans One, majuscules, respiration large */
h1 {
  font-family: var(--lec-font-display);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: .05em;
}

a { color: var(--lec-rose); transition: color .3s; }
a:hover { color: var(--lec-accent); }

img { max-width: 100%; height: auto; }

/* ============================================================
   ASTRA OVERRIDES — FULL WIDTH
   ============================================================ */

body.lec-fullwidth .ast-container,
body.lec-fullwidth #content.ast-container,
body.lec-fullwidth .ast-layout-boxed-container,
body.lec-fullwidth #primary,
body.lec-fullwidth #content,
body.lec-fullwidth .site-content,
body.lec-fullwidth .entry-content,
body.lec-fullwidth .hentry,
body.lec-fullwidth .ast-article-single,
body.lec-fullwidth article {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
  display: block !important;
  box-shadow: none !important;
  background: none !important;
}

body.lec-fullwidth .entry-title,
body.lec-fullwidth .ast-archive-description {
  display: none !important;
}

/* ============================================================
   HEADER — toujours visible, sticky, fond sombre
   ============================================================ */

.site-header,
#masthead,
body.lec-is-home .site-header,
body.lec-is-home #masthead {
  background: #150a13 !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
  border-bottom: 1px solid rgba(244,166,189,.2) !important;
  box-shadow: 0 2px 20px rgba(0,0,0,.3) !important;
  backdrop-filter: none !important;
}

/* Logo texte */
.site-title a,
.ast-site-title a,
.site-title a:visited,
.ast-site-title a:visited,
.site-title a:hover,
.ast-site-title a:hover {
  font-family: var(--lec-font-heading) !important;
  font-size: 1.5rem !important;
  color: var(--lec-cream) !important;
  letter-spacing: .05em !important;
  text-decoration: none !important;
}

.site-description,
.ast-site-description {
  color: rgba(248,230,198,.55) !important;
  font-size: .72rem !important;
  letter-spacing: .15em !important;
  text-transform: uppercase !important;
}

/* Logo (symbole hamsa) avant le titre dans le header */
.site-branding .ast-site-identity,
.ast-site-identity {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

.lec-logo-mark {
  display: inline-flex;
  align-items: center;
  line-height: 0;
  color: var(--lec-cream);
  flex: none;
  transition: color .3s;
}
.lec-logo-mark:hover { color: var(--lec-accent); }

.lec-logo-mark__svg {
  height: 42px;
  width: auto;
  display: block;
}

@media (max-width: 768px) {
  .lec-logo-mark__svg { height: 34px; }
}

/* Nav — tous les sélecteurs Astra possibles */
.main-navigation a,
.ast-main-navigation a,
#site-navigation a,
.ast-primary-menu > li > a,
#ast-desktop-header .main-navigation a,
.main-header-bar .main-navigation a,
.ast-header-break-point .main-navigation a,
#masthead .main-navigation a,
.site-header .main-navigation a {
  color: var(--lec-cream) !important;
  font-size: .82rem !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  transition: color .3s !important;
}

.main-navigation a:hover,
.ast-main-navigation a:hover,
#site-navigation a:hover,
.ast-primary-menu > li > a:hover,
#masthead .main-navigation a:hover {
  color: var(--lec-accent) !important;
}

/* ============================================================
   BOUTONS
   ============================================================ */

.lec-btn {
  display: inline-block;
  padding: 14px 32px;
  border-radius: 50px;
  font-family: var(--lec-font-body);
  font-size: .85rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 700;
  text-decoration: none;
  transition: all .3s;
  text-align: center;
  cursor: pointer;
  border: 2px solid transparent;
}

.lec-btn--primary {
  background: var(--lec-accent);
  color: #fff;
  border-color: var(--lec-accent);
}
.lec-btn--primary:hover {
  background: transparent;
  color: var(--lec-rose);
  border-color: var(--lec-rose);
}

.lec-btn--accent {
  background: var(--lec-accent);
  color: #fff;
  border-color: var(--lec-accent);
}
.lec-btn--accent:hover {
  background: transparent;
  color: var(--lec-accent);
}

.lec-btn--brown {
  background: var(--lec-brown);
  color: var(--lec-cream);
  border-color: var(--lec-brown);
}
.lec-btn--brown:hover {
  background: transparent;
  color: var(--lec-brown);
}

.lec-btn--cream {
  background: var(--lec-cream);
  color: var(--lec-dark);
  border-color: var(--lec-cream);
}
.lec-btn--cream:hover {
  background: transparent;
  color: var(--lec-cream);
}

.lec-btn--outline-cream {
  background: transparent;
  color: var(--lec-cream);
  border-color: var(--lec-cream);
}
.lec-btn--outline-cream:hover {
  background: var(--lec-cream);
  color: var(--lec-dark);
}

.lec-btn--lg { padding: 18px 44px; font-size: .95rem; }

/* ============================================================
   HOMEPAGE — HERO VIDÉO
   ============================================================ */

.lec-hero {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 620px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
}

/* Variante immersive : hauteur souple pour contenir les 3 portails sur mobile */
.lec-hero--immersive {
  height: auto;
  min-height: 100vh;
  min-height: 100svh;
  padding: 96px 24px 72px;
}

.lec-hero__video-wrap {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.lec-hero__video-wrap video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lec-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    180deg,
    rgba(21,10,19,.6) 0%,
    rgba(21,10,19,.3) 45%,
    rgba(21,10,19,.65) 100%
  );
}

.lec-hero__content {
  position: relative;
  z-index: 2;
  max-width: min(860px, 90vw);
  width: 100%;
  padding: 0 24px;
  box-sizing: border-box;
}

.lec-hero__brand {
  font-family: var(--lec-font-display);
  font-size: clamp(1.4rem, 4.5vw, 5rem);
  font-weight: 400;
  color: var(--lec-cream);
  letter-spacing: .04em;
  line-height: 1;
  margin: 0 0 18px;
  text-shadow: 0 4px 40px rgba(21,10,19,.7);
  white-space: nowrap;
}

.lec-hero__tagline {
  font-family: var(--lec-font-heading);
  font-style: italic;
  font-size: clamp(1.1rem, 2.8vw, 1.8rem);
  color: var(--lec-cream);
  opacity: .9;
  margin-bottom: 20px;
}

.lec-hero__scroll {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: rgba(248,230,198,.7);
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  text-decoration: none;
}

.lec-hero__scroll svg { animation: lec-bounce 2s ease-in-out infinite; }

@keyframes lec-bounce {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(7px); }
}

/* ============================================================
   HERO — VOILE AURORE ROSE AMBIANT
   Deux nappes radiales floues qui dérivent lentement au-dessus
   de la vidéo (blend screen), sous le contenu.
   ============================================================ */

.lec-hero__aurora {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
  mix-blend-mode: screen;
}

.lec-hero__aurora::before,
.lec-hero__aurora::after {
  content: '';
  position: absolute;
  width: 65vmax;
  height: 65vmax;
  border-radius: 50%;
  filter: blur(70px);
  will-change: transform;
}

.lec-hero__aurora::before {
  top: -22%;
  left: -18%;
  opacity: .32;
  background: radial-gradient(closest-side,
    rgba(244,166,189,.85), rgba(215,110,155,.3) 55%, transparent 75%);
  animation: lec-aurora-drift-a 28s ease-in-out infinite alternate;
}

.lec-hero__aurora::after {
  bottom: -28%;
  right: -14%;
  opacity: .26;
  background: radial-gradient(closest-side,
    rgba(255,217,224,.8), rgba(185,132,201,.25) 60%, transparent 78%);
  animation: lec-aurora-drift-b 34s ease-in-out infinite alternate;
}

@keyframes lec-aurora-drift-a {
  0%   { transform: translate3d(0,0,0) scale(1) rotate(0deg); }
  50%  { transform: translate3d(14vw, 10vh, 0) scale(1.18) rotate(10deg); }
  100% { transform: translate3d(5vw, 20vh, 0) scale(.92) rotate(-8deg); }
}
@keyframes lec-aurora-drift-b {
  0%   { transform: translate3d(0,0,0) scale(1.05); }
  50%  { transform: translate3d(-12vw, -8vh, 0) scale(.9) rotate(-12deg); }
  100% { transform: translate3d(-4vw, -18vh, 0) scale(1.2) rotate(6deg); }
}

/* ============================================================
   PARTICULES FLOTTANTES (poussière d'étoiles)
   Voile fixe couvrant toute la page d'accueil — sous le header
   (z-index 999), au-dessus des fonds de sections.
   Les spans .lec-particle sont générés par main.js, temporisés
   par variables CSS (--x, --size, --duration, --delay, --drift, --o).
   ============================================================ */

.lec-particles {
  position: fixed;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  overflow: hidden;
}

.lec-particle {
  position: absolute;
  left: var(--x);
  bottom: -10px;
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,235,240,.95), rgba(244,166,189,.4) 60%, transparent);
  box-shadow: 0 0 6px 1px var(--lec-rose-glow);
  opacity: 0;
  animation: lec-particle-rise var(--duration) linear var(--delay) infinite;
}

@keyframes lec-particle-rise {
  0%   { transform: translate3d(0,0,0); opacity: 0; }
  8%   { opacity: var(--o); }
  85%  { opacity: var(--o); }
  100% { transform: translate3d(var(--drift), -105vh, 0); opacity: 0; }
}

/* ============================================================
   PORTAILS — les 3 boutons-icônes, dans leur propre section
   sombre après le hero, avec son propre voile d'aurore rose.
   ============================================================ */

.lec-portals-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: linear-gradient(180deg, var(--lec-indigo) 0%, var(--lec-dark) 55%, #3a1f42 140%);
  padding: clamp(80px, 12vh, 140px) 24px;
}

/* Voile aurore de la section (z-index négatif : derrière les boutons,
   devant le fond — les keyframes drift sont partagés avec le hero) */
.lec-portals-section::before,
.lec-portals-section::after {
  content: '';
  position: absolute;
  width: 65vmax;
  height: 65vmax;
  border-radius: 50%;
  filter: blur(70px);
  z-index: -1;
  mix-blend-mode: screen;
  pointer-events: none;
  will-change: transform;
}

.lec-portals-section::before {
  top: -30%;
  left: -20%;
  opacity: .3;
  background: radial-gradient(closest-side,
    rgba(244,166,189,.85), rgba(215,110,155,.3) 55%, transparent 75%);
  animation: lec-aurora-drift-a 28s ease-in-out infinite alternate;
}

.lec-portals-section::after {
  bottom: -35%;
  right: -18%;
  opacity: .24;
  background: radial-gradient(closest-side,
    rgba(255,217,224,.8), rgba(185,132,201,.25) 60%, transparent 78%);
  animation: lec-aurora-drift-b 34s ease-in-out infinite alternate;
}

.lec-portals {
  display: flex;
  justify-content: center;
  gap: clamp(32px, 8vw, 96px);
  flex-wrap: wrap;
}

@media (max-width: 640px) {
  .lec-portals {
    flex-direction: column;
    align-items: center;
    gap: 48px;
  }
}

.lec-portal {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  transition: transform .4s ease;
}

.lec-portal:hover { transform: translateY(-6px); }

.lec-portal:focus-visible {
  outline: 2px solid var(--lec-cream);
  outline-offset: 8px;
  border-radius: 12px;
}

.lec-portal__icon {
  position: relative;
  width: clamp(150px, 20vw, 250px);
  height: clamp(150px, 20vw, 250px);
  display: grid;
  place-items: center;
  border-radius: 50%;
  isolation: isolate; /* confine les pseudo-éléments aurore */
}

.lec-portal__icon svg {
  width: 62%;
  height: 62%;
  filter: drop-shadow(0 0 10px var(--lec-rose-glow));
}

.lec-portal__label {
  font-family: var(--lec-font-body);
  font-size: .95rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--lec-cream);
  text-shadow: 0 2px 12px rgba(21,10,19,.6);
}

/* --- Aurore rose animée derrière chaque hamsa --- */

.lec-portal__icon::before,
.lec-portal__icon::after {
  content: '';
  position: absolute;
  inset: -16%;
  border-radius: 50%;
  z-index: -1;
  filter: blur(24px);
  will-change: transform;
}

/* Couche 1 : rubans coniques rotatifs */
.lec-portal__icon::before {
  background: conic-gradient(from 0deg,
    transparent 0deg,
    var(--lec-rose-glow) 55deg,
    rgba(215,110,155,.45) 120deg,
    transparent 200deg,
    rgba(185,132,201,.25) 260deg,
    rgba(255,217,224,.35) 310deg,
    transparent 360deg);
  animation: lec-aurora-spin 10s linear infinite;
}

/* Couche 2 : nappes radiales qui respirent */
.lec-portal__icon::after {
  background:
    radial-gradient(circle at 32% 62%, rgba(244,166,189,.5), transparent 58%),
    radial-gradient(circle at 68% 30%, rgba(215,110,155,.35), transparent 55%);
  animation: lec-aurora-breathe 6.5s ease-in-out infinite alternate;
}

@keyframes lec-aurora-spin { to { transform: rotate(360deg); } }

@keyframes lec-aurora-breathe {
  from { transform: scale(.88); opacity: .55; }
  to   { transform: scale(1.14); opacity: .95; }
}

/* Désynchroniser les 3 icônes */
.lec-portal:nth-child(2) .lec-portal__icon::before { animation-delay: -3.3s; }
.lec-portal:nth-child(3) .lec-portal__icon::before { animation-delay: -6.6s; }
.lec-portal:nth-child(2) .lec-portal__icon::after  { animation-delay: -2s; }
.lec-portal:nth-child(3) .lec-portal__icon::after  { animation-delay: -4s; }

/* Hover : l'aurore s'intensifie */
.lec-portal:hover .lec-portal__icon::before { animation-duration: 5s; }
.lec-portal:hover .lec-portal__icon::after  { opacity: 1; }

/* ============================================================
   HERO — APPARITION DOUCE À L'ARRIVÉE
   ============================================================ */

@keyframes lec-fade-up {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* fill-mode backwards : l'état "from" couvre le délai, puis l'animation
   se retire — les transitions hover reprennent la main sur transform. */
.lec-hero--immersive .lec-hero__brand,
.lec-hero--immersive .lec-hero__tagline,
.lec-hero--immersive .lec-hero__scroll {
  animation: lec-fade-up 1.1s cubic-bezier(.22,.61,.36,1) backwards;
}

.lec-hero--immersive .lec-hero__brand   { animation-delay: .3s; }
.lec-hero--immersive .lec-hero__tagline { animation-delay: .65s; }
.lec-hero--immersive .lec-hero__scroll  { animation-delay: 1.2s; }

/* ============================================================
   ACCESSIBILITÉ — mouvement réduit
   L'aurore reste visible mais figée ; particules masquées.
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
  .lec-hero__aurora::before,
  .lec-hero__aurora::after,
  .lec-portals-section::before,
  .lec-portals-section::after,
  .lec-portal__icon::before,
  .lec-portal__icon::after,
  .lec-hero__scroll svg {
    animation: none;
  }
  .lec-particles { display: none; }
  .lec-hero--immersive .lec-hero__brand,
  .lec-hero--immersive .lec-hero__tagline,
  .lec-hero--immersive .lec-hero__scroll {
    animation: none;
  }
}

/* ============================================================
   LEAD MAGNET BANNER
   ============================================================ */

.lec-leadmagnet {
  background: linear-gradient(135deg, var(--lec-dark) 0%, var(--lec-brown) 100%);
  padding: 50px 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.lec-leadmagnet::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 200px; height: 200px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(232,152,80,.2) 0%, transparent 70%);
}

.lec-leadmagnet__eyebrow {
  display: block;
  font-size: .75rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--lec-accent);
  margin-bottom: 10px;
}

.lec-leadmagnet h3 {
  font-family: var(--lec-font-heading);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  color: var(--lec-cream);
  margin-bottom: 10px;
}

.lec-leadmagnet p {
  color: rgba(248,230,198,.8);
  max-width: 520px;
  margin: 0 auto 28px;
  font-size: 1rem;
}

/* ============================================================
   BIO / À PROPOS — HOMEPAGE
   ============================================================ */

.lec-bio {
  background: var(--lec-dark);
  padding: 100px 24px;
  position: relative;
  overflow: hidden;
}

.lec-bio::before {
  content: '';
  position: absolute;
  bottom: -100px; left: -100px;
  width: 350px; height: 350px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(232,152,80,.08) 0%, transparent 70%);
}

.lec-bio__inner {
  max-width: 1060px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 70px;
  align-items: center;
}

@media (max-width: 860px) {
  .lec-bio__inner { grid-template-columns: 1fr; }
}

.lec-bio__photo-wrap {
  position: relative;
  display: flex;
  justify-content: center;
}

.lec-bio__photo {
  width: 320px;
  height: 320px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  border: 4px solid rgba(248,230,198,.25);
  box-shadow: 0 0 0 12px rgba(248,230,198,.06);
}

.lec-bio__title {
  font-family: var(--lec-font-heading);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  color: var(--lec-cream);
  margin-bottom: 24px;
  line-height: 1.2;
}

.lec-bio__text p {
  color: rgba(248,230,198,.8);
  margin-bottom: 14px;
  font-size: 1rem;
}

.lec-bio__actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  align-items: center;
}

.lec-bio__reviews {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  color: var(--lec-cream);
  font-size: .85rem;
  text-decoration: none;
  border: 1px solid rgba(248,230,198,.25);
  padding: 8px 16px;
  border-radius: 50px;
  transition: all .3s;
}

.lec-bio__reviews:hover {
  background: rgba(248,230,198,.1);
  color: var(--lec-cream);
  border-color: var(--lec-cream);
}

/* ============================================================
   BANDEAU URGENCE (pour accompagnement)
   ============================================================ */

.lec-urgency {
  background: linear-gradient(135deg, var(--lec-accent) 0%, var(--lec-brown) 100%);
  padding: 20px 24px;
  text-align: center;
}

.lec-urgency p {
  color: #fff;
  font-size: .9rem;
  margin: 0;
  font-weight: 700;
  letter-spacing: .05em;
}

/* ============================================================
   PAGE HERO (pages internes)
   ============================================================ */

.lec-page-hero {
  padding: 120px 24px 80px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.lec-page-hero--accompagnement {
  background: linear-gradient(160deg, var(--lec-dark) 0%, var(--lec-brown) 60%, var(--lec-accent) 100%);
}

.lec-page-hero--formation {
  background: linear-gradient(160deg, var(--lec-brown) 0%, var(--lec-accent) 60%, var(--lec-rose-deep) 100%);
}

.lec-page-hero--agenda {
  background: linear-gradient(160deg, var(--lec-indigo) 0%, var(--lec-dark) 50%, var(--lec-brown) 100%);
}

.lec-page-hero--apropos {
  background: linear-gradient(160deg, var(--lec-indigo) 0%, var(--lec-dark) 55%, var(--lec-brown) 100%);
}

.lec-page-hero__eyebrow {
  display: block;
  font-size: .78rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--lec-rose-light);
  margin-bottom: 12px;
}

.lec-page-hero__title {
  font-size: clamp(2.2rem, 6vw, 4rem);
  color: var(--lec-cream);
  margin-bottom: 16px;
}

.lec-page-hero__sub {
  font-family: var(--lec-font-heading);
  font-style: italic;
  font-size: clamp(1rem, 2.5vw, 1.5rem);
  color: rgba(248,230,198,.85);
  max-width: 640px;
  margin: 0 auto;
}

/* ============================================================
   SECTION LEVEL UP — ACCOMPAGNEMENT
   ============================================================ */

.lec-levelup {
  padding: 90px 24px;
  background: var(--lec-bg-light);
}

.lec-levelup__inner {
  max-width: 900px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}

@media (max-width: 768px) {
  .lec-levelup__inner { grid-template-columns: 1fr; }
}

.lec-levelup__tag {
  display: inline-block;
  background: var(--lec-accent);
  color: #fff;
  font-size: .7rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: 50px;
  margin-bottom: 16px;
  font-weight: 700;
}

.lec-levelup h2 {
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: 20px;
  line-height: 1.1;
}

.lec-levelup p { color: var(--lec-text-light); margin-bottom: 14px; }

.lec-levelup__price-box {
  background: var(--lec-dark);
  border-radius: 16px;
  padding: 36px 32px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.lec-levelup__price-box::before {
  content: '';
  position: absolute;
  top: -40px; right: -40px;
  width: 120px; height: 120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(232,152,80,.3) 0%, transparent 70%);
}

.lec-levelup__price-label {
  font-size: .75rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(248,230,198,.6);
  margin-bottom: 6px;
  display: block;
}

.lec-levelup__price-old {
  font-size: 1.2rem;
  color: rgba(248,230,198,.4);
  text-decoration: line-through;
  display: block;
  margin-bottom: 4px;
}

.lec-levelup__price-current {
  font-family: var(--lec-font-heading);
  font-size: 4rem;
  font-weight: 700;
  color: var(--lec-cream);
  line-height: 1;
  display: block;
}

.lec-levelup__price-mention {
  font-size: .8rem;
  color: var(--lec-accent);
  margin: 6px 0 28px;
  display: block;
  font-weight: 700;
}

.lec-levelup__features {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  text-align: left;
}

.lec-levelup__features li {
  color: rgba(248,230,198,.85);
  font-size: .9rem;
  padding: 7px 0;
  border-bottom: 1px solid rgba(248,230,198,.1);
  padding-left: 20px;
  position: relative;
}

.lec-levelup__features li::before {
  content: '✦';
  position: absolute;
  left: 0;
  color: var(--lec-accent);
  font-size: .65rem;
  top: 10px;
}

/* ============================================================
   PRODUIT NUMÉRIQUE — section dans accompagnement
   ============================================================ */

.lec-produit {
  background: var(--lec-bg);
  padding: 80px 24px;
}

.lec-produit__inner {
  max-width: 800px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

@media (max-width: 640px) {
  .lec-produit__inner { grid-template-columns: 1fr; }
}

.lec-produit__cover {
  border-radius: 12px;
  background: linear-gradient(135deg, var(--lec-dark), var(--lec-brown));
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 4rem;
  box-shadow: 0 12px 40px rgba(0,0,0,.45);
}

.lec-produit h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); margin-bottom: 10px; }
.lec-produit p { color: var(--lec-text-light); margin-bottom: 20px; font-size: .95rem; }

.lec-produit__price {
  font-family: var(--lec-font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--lec-rose);
  margin-bottom: 20px;
  display: block;
}

/* ============================================================
   FORMATION — CARTOUCHES
   ============================================================ */

.lec-formations {
  padding: 90px 24px;
  background: var(--lec-bg-light);
}

.lec-formations__grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 28px;
  max-width: 1000px;
  margin: 50px auto 0;
}

@media (max-width: 700px) {
  .lec-formations__grid { grid-template-columns: 1fr; }
}

.lec-fcard {
  background: var(--lec-card);
  border: 1px solid rgba(244,166,189,.12);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,.45);
  transition: transform .3s, box-shadow .3s;
  display: flex;
  flex-direction: column;
  border-top: 4px solid var(--lec-brown);
}

.lec-fcard:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 50px rgba(0,0,0,.55), 0 0 30px rgba(244,166,189,.12);
}

.lec-fcard__header {
  background: linear-gradient(135deg, var(--lec-dark), var(--lec-brown));
  padding: 24px 28px 20px;
}

.lec-fcard__date {
  display: inline-block;
  background: var(--lec-accent);
  color: #fff;
  font-size: .72rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 50px;
  margin-bottom: 10px;
  font-weight: 700;
}

.lec-fcard__title {
  font-family: var(--lec-font-heading);
  font-size: 1.5rem;
  color: var(--lec-cream);
  margin: 0;
}

.lec-fcard__body {
  padding: 24px 28px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.lec-fcard__desc {
  color: var(--lec-text-light);
  font-size: .93rem;
  flex: 1;
  margin-bottom: 18px;
  line-height: 1.65;
}

.lec-fcard__price {
  font-family: var(--lec-font-heading);
  font-size: 2rem;
  font-weight: 700;
  color: var(--lec-cream);
  margin-bottom: 16px;
  display: block;
}

/* ============================================================
   AGENDA — ÉVÉNEMENTS
   ============================================================ */

.lec-events {
  padding: 90px 24px;
  background: var(--lec-bg-light);
}

.lec-events__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 28px;
  max-width: 1100px;
  margin: 50px auto 0;
}

.lec-ecard {
  background: var(--lec-card);
  border: 1px solid rgba(244,166,189,.12);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,.45);
  transition: transform .3s, box-shadow .3s;
  display: flex;
  flex-direction: column;
}

.lec-ecard:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 50px rgba(0,0,0,.55), 0 0 30px rgba(244,166,189,.12);
}

.lec-ecard__visual {
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
  position: relative;
  overflow: hidden;
}

.lec-ecard--retraite .lec-ecard__visual {
  background: linear-gradient(135deg, #3a1f42, var(--lec-brown));
}
.lec-ecard--webinaire .lec-ecard__visual {
  background: linear-gradient(135deg, var(--lec-indigo), var(--lec-brown));
}
.lec-ecard--festival .lec-ecard__visual {
  background: linear-gradient(135deg, var(--lec-accent), var(--lec-amber));
}
.lec-ecard--formation-link .lec-ecard__visual {
  background: linear-gradient(135deg, var(--lec-brown), var(--lec-rose));
}

.lec-ecard__body { padding: 22px 22px 20px; flex: 1; display: flex; flex-direction: column; }

.lec-ecard__date {
  display: inline-block;
  font-size: .72rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--lec-accent);
  font-weight: 700;
  margin-bottom: 6px;
}

.lec-ecard__title {
  font-family: var(--lec-font-heading);
  font-size: 1.35rem;
  color: var(--lec-cream);
  margin: 0 0 8px;
}

.lec-ecard__desc {
  color: var(--lec-text-light);
  font-size: .88rem;
  flex: 1;
  margin-bottom: 18px;
  line-height: 1.6;
}

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer, #colophon {
  background: var(--lec-dark) !important;
  color: rgba(248,230,198,.7);
  border-top: 1px solid rgba(232,152,80,.2);
  padding: 40px 24px !important;
  text-align: center;
}

.site-footer a, #colophon a {
  color: var(--lec-cream);
}
.site-footer a:hover, #colophon a:hover {
  color: var(--lec-accent);
}

.site-footer .ast-footer-copyright,
#colophon .ast-footer-copyright {
  color: rgba(248,230,198,.5);
  font-size: .8rem;
}

/* ============================================================
   UTILS
   ============================================================ */

.lec-section {
  padding: 80px 24px;
  max-width: 920px;
  margin: 0 auto;
}

.lec-section-center { text-align: center; }

.lec-section h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); margin-bottom: 18px; }
.lec-section p { color: var(--lec-text-light); margin-bottom: 14px; font-size: 1rem; }

.lec-divider {
  height: 4px;
  background: linear-gradient(90deg, var(--lec-brown), var(--lec-rose), var(--lec-amber));
  border: none;
  margin: 0;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 768px) {
  .lec-hero__brand { font-size: clamp(1.1rem, 5.5vw, 2rem); white-space: nowrap; }
  .lec-bio { padding: 60px 20px; }
  .lec-bio__photo { width: 220px; height: 220px; }
  .lec-levelup, .lec-produit, .lec-formations, .lec-events { padding: 60px 20px; }
}

/* ============================================================
   ASTRA BUTTONS OVERRIDE
   ============================================================ */

.ast-button, .button, input[type="submit"] {
  background: var(--lec-accent) !important;
  border-color: var(--lec-accent) !important;
  border-radius: 50px !important;
  color: #fff !important;
}

.ast-button:hover, .button:hover, input[type="submit"]:hover {
  background: var(--lec-brown) !important;
  border-color: var(--lec-brown) !important;
}
