/* =====================================================================
   ÉVOLUMIE — Design system « Épanouissement »
   Coach des femmes en transition · doux & féminin · premium
   ===================================================================== */

:root{
  /* Couleurs */
  --cream:        #F6F1EA;
  --cream-2:      #FBF7F1;
  --surface:      #FFFFFF;
  --sage:         #7C8B6F;
  --sage-deep:    #586547;
  --sage-soft:    #DCE3D1;
  --sage-tint:    #EBEFE2;
  --rose:         #E3BBB3;
  --rose-deep:    #CD9A90;
  --rose-soft:    #F4E2DD;
  --gold:         #C19A5B;
  --ink:          #2C2A26;
  --ink-soft:     #4A4842;
  --muted:        #75716A;
  --line:         rgba(44,42,38,.12);
  --line-soft:    rgba(44,42,38,.07);

  /* Typo */
  --font-display: "Fraunces", "Iowan Old Style", Georgia, "Times New Roman", serif;
  --font-body:    "Mulish", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;

  /* Rayons & ombres */
  --r-sm: 12px;
  --r-md: 20px;
  --r-lg: 28px;
  --r-xl: 40px;
  --shadow-sm: 0 4px 18px -10px rgba(74,72,66,.30);
  --shadow-md: 0 20px 50px -28px rgba(74,72,66,.42);
  --shadow-lg: 0 40px 90px -42px rgba(74,72,66,.50);

  /* Divers */
  --container: 1180px;
  --gutter: clamp(20px, 5vw, 56px);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:hidden; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--font-body);
  font-size:clamp(1rem, .96rem + .25vw, 1.0625rem);
  line-height:1.72;
  color:var(--ink-soft);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  position:relative;
}

/* Atmosphère : washes de couleur + grain subtil */
body::before{
  content:"";
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(60% 50% at 88% -5%, rgba(227,187,179,.30), transparent 60%),
    radial-gradient(55% 45% at -5% 12%, rgba(124,139,111,.18), transparent 60%),
    radial-gradient(50% 40% at 105% 80%, rgba(193,154,91,.12), transparent 55%),
    var(--cream);
}
body::after{
  content:"";
  position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.045'/%3E%3C/svg%3E");
}

/* ----------------------------- Typo ----------------------------- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:430;
  font-optical-sizing:auto;
  color:var(--ink);
  line-height:1.07;
  letter-spacing:-.012em;
  margin:0 0 .5em;
}
h1{ font-size:clamp(2.55rem, 1.6rem + 4.4vw, 4.6rem); font-weight:430; }
h2{ font-size:clamp(2rem, 1.3rem + 3vw, 3.15rem); }
h3{ font-size:clamp(1.32rem, 1.05rem + 1vw, 1.7rem); font-weight:500; }
p{ margin:0 0 1.1em; }
a{ color:var(--sage-deep); text-decoration:none; }
strong{ color:var(--ink); font-weight:700; }
em{ font-style:italic; }
.serif-italic{ font-family:var(--font-display); font-style:italic; font-weight:380; }

.lead{
  font-size:clamp(1.1rem, 1rem + .7vw, 1.32rem);
  line-height:1.6; color:var(--ink-soft);
}
.display{
  font-family:var(--font-display); font-weight:400;
}

/* ----------------------------- Layout ----------------------------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.wrap-narrow{ max-width:760px; margin-inline:auto; }
.section{ padding-block:clamp(64px, 8vw, 124px); position:relative; }
.section--tight{ padding-block:clamp(48px, 6vw, 88px); }
.bg-surface{ background:var(--surface); }
.bg-cream2{ background:var(--cream-2); }
.bg-sage{ background:var(--sage-tint); }
.center{ text-align:center; }
.mb-0{ margin-bottom:0; }

/* ----------------------------- Eyebrow & têtes de section --------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--font-body); font-weight:700;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--sage-deep); margin:0 0 1rem;
}
.eyebrow::before{
  content:""; width:22px; height:1px; background:currentColor; opacity:.6;
}
.eyebrow--center{ justify-content:center; }
.section-head{ max-width:680px; margin-bottom:clamp(36px,5vw,60px); }
.section-head.center{ margin-inline:auto; }
.section-head.center::before{ content:""; display:block; width:36px; height:36px; margin:0 auto 1.05rem;
  background:url("/img/logo-mark.svg") center/contain no-repeat; opacity:.95; }
.section-head p{ font-size:clamp(1.05rem,1rem+.4vw,1.2rem); color:var(--muted); margin-bottom:0; }

/* ----------------------------- Boutons ----------------------------- */
.btn{
  --bg:var(--sage); --fg:#fff; --bd:var(--sage);
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--font-body); font-weight:700; font-size:.98rem; line-height:1;
  padding:1.02em 1.7em; border-radius:999px;
  background:var(--bg); color:var(--fg); border:1.5px solid var(--bd);
  cursor:pointer; text-align:center;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s var(--ease), color .3s var(--ease);
  box-shadow:0 10px 26px -16px rgba(88,101,71,.85);
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 20px 38px -18px rgba(88,101,71,.9); }
.btn:active{ transform:translateY(-1px); }
.btn:focus-visible{ outline:2.5px solid var(--gold); outline-offset:3px; }
.btn--ghost{ --bg:transparent; --fg:var(--sage-deep); --bd:rgba(88,101,71,.4); box-shadow:none; }
.btn--ghost:hover{ --bg:var(--sage-deep); --fg:#fff; --bd:var(--sage-deep); }
.btn--light{ --bg:#fff; --fg:var(--ink); --bd:#fff; }
.btn--rose{ --bg:var(--rose); --fg:#5b3a33; --bd:var(--rose); box-shadow:0 10px 26px -16px rgba(205,154,144,.95); }
.btn--rose:hover{ --bg:var(--rose-deep); --fg:#fff; }
.btn--lg{ padding:1.15em 2.1em; font-size:1.04rem; }
.btn-arrow{ transition:transform .35s var(--ease); }
.btn:hover .btn-arrow{ transform:translateX(4px); }

.textlink{
  display:inline-flex; align-items:center; gap:.5em; font-weight:700; color:var(--sage-deep);
  background-image:linear-gradient(currentColor,currentColor);
  background-size:0% 1.5px; background-position:0 100%; background-repeat:no-repeat;
  transition:background-size .4s var(--ease);
  padding-bottom:2px;
}
.textlink:hover{ background-size:100% 1.5px; }

/* ----------------------------- Chips / tags ----------------------- */
.chips{ display:flex; flex-wrap:wrap; gap:.6rem; }
.chip{
  display:inline-flex; align-items:center; gap:.5em;
  padding:.55em 1.05em; border-radius:999px;
  background:var(--surface); border:1px solid var(--line);
  font-size:.92rem; font-weight:600; color:var(--ink-soft);
  box-shadow:var(--shadow-sm);
}
.chip svg{ width:15px; height:15px; color:var(--sage); flex:none; }

/* ----------------------------- Skip link -------------------------- */
.skip-link{
  position:fixed; left:50%; top:10px; translate:-50% -160%; z-index:100;
  background:var(--sage-deep); color:#fff; padding:.7em 1.2em; border-radius:999px;
  font-weight:700; box-shadow:var(--shadow-md); transition:translate .3s var(--ease);
}
.skip-link:focus-visible{ translate:-50% 0; outline:none; }

/* ----------------------------- Header / nav ----------------------- */
.header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  padding-block:18px;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease), backdrop-filter .4s var(--ease);
}
.header.scrolled{
  background:rgba(246,241,234,.82); backdrop-filter:blur(14px) saturate(1.1);
  box-shadow:0 1px 0 var(--line-soft), 0 18px 40px -34px rgba(74,72,66,.7);
  padding-block:11px;
}
.header__inner{ display:flex; align-items:center; justify-content:space-between; gap:20px; }

.logo{ display:inline-flex; align-items:center; gap:.62rem; }
.logo__mark{ width:40px; height:40px; flex:none; transition:transform .6s var(--ease); }
.logo:hover .logo__mark{ transform:rotate(72deg); }
.logo__text{ display:flex; flex-direction:column; line-height:1; }
.logo__name{ font-family:var(--font-display); font-weight:500; font-size:1.5rem; color:var(--ink); letter-spacing:-.01em; }
.logo__sub{ font-family:var(--font-body); font-weight:700; font-size:.62rem; letter-spacing:.34em; text-transform:uppercase; color:var(--sage); margin-top:3px; }

.nav{ display:flex; align-items:center; gap:clamp(14px,2vw,30px); }
.nav__links{ display:flex; align-items:center; gap:clamp(14px,2vw,30px); list-style:none; margin:0; padding:0; }
.nav__links a{
  font-weight:600; font-size:1rem; color:var(--ink-soft); position:relative; padding:6px 0;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1.5px; width:0; background:var(--sage);
  transition:width .35s var(--ease);
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after,.nav__links a.is-active::after{ width:100%; }
.nav__links a.is-active{ color:var(--sage-deep); }

.nav-toggle{
  display:none; width:46px; height:46px; border:1px solid var(--line); border-radius:50%;
  background:var(--surface); cursor:pointer; position:relative; flex:none;
}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:""; position:absolute; left:50%; top:50%; width:18px; height:2px; border-radius:2px; background:var(--ink);
  transition:transform .35s var(--ease), opacity .25s var(--ease); translate:-50% -50%;
}
.nav-toggle span::before{ top:-6px; }
.nav-toggle span::after{ top:6px; }
body.nav-open .nav-toggle span{ background:transparent; }
body.nav-open .nav-toggle span::before{ transform:translate(-50%,6px) rotate(45deg); top:0; }
body.nav-open .nav-toggle span::after{ transform:translate(-50%,-6px) rotate(-45deg); top:0; }

/* ----------------------------- Hero ----------------------------- */
.hero{ position:relative; padding-top:clamp(130px,16vw,190px); padding-bottom:clamp(60px,8vw,110px); }
.hero__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,72px); align-items:center; }
.hero__badge{
  display:inline-flex; align-items:center; gap:.6em; margin-bottom:1.4rem;
  padding:.5em 1em .5em .6em; border-radius:999px; background:var(--surface);
  border:1px solid var(--line); box-shadow:var(--shadow-sm); font-size:.86rem; font-weight:600; color:var(--ink-soft);
}
.hero__badge .dot{ width:1.7em; height:1.7em; border-radius:50%; background:var(--sage-tint); display:grid; place-items:center; }
.hero__badge .dot svg{ width:1em; height:1em; color:var(--sage-deep); }
.hero h1{ margin-bottom:.45em; }
.hero h1 .accent{ color:var(--sage-deep); font-style:italic; font-weight:380; }
.hero__lead{ max-width:30em; margin-bottom:2rem; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:1rem 1.1rem; align-items:center; }
.hero__meta{ margin-top:2.4rem; display:flex; gap:2.2rem; flex-wrap:wrap; }
.hero__stat .n{ font-family:var(--font-display); font-size:1.9rem; color:var(--ink); line-height:1; }
.hero__stat .l{ font-size:.86rem; color:var(--muted); margin-top:.35rem; }

/* Cadre portrait organique */
.portrait{ position:relative; justify-self:center; width:min(100%,440px); }
.portrait__frame{
  position:relative; aspect-ratio:4/5; overflow:hidden;
  border-radius:48% 52% 47% 53% / 60% 56% 44% 40%;
  box-shadow:var(--shadow-lg);
  border:8px solid var(--surface);
}
.portrait__frame img{ width:100%; height:100%; object-fit:cover; display:block; }
.portrait__halo{
  position:absolute; inset:-7% -7% -7% -7%; z-index:-1;
  border-radius:48% 52% 47% 53% / 60% 56% 44% 40%;
  background:linear-gradient(150deg,var(--rose-soft),var(--sage-soft));
  filter:blur(2px);
  animation:morph 16s ease-in-out infinite;
}
.portrait__tag{
  position:absolute; left:-6%; bottom:14%;
  background:var(--surface); border-radius:var(--r-md); padding:.85em 1.1em;
  box-shadow:var(--shadow-md); display:flex; align-items:center; gap:.7em; max-width:230px;
}
.portrait__tag .ico{ width:38px; height:38px; border-radius:50%; background:var(--rose-soft); display:grid; place-items:center; flex:none; }
.portrait__tag .ico svg{ width:19px; height:19px; color:var(--rose-deep); }
.portrait__tag b{ display:block; font-family:var(--font-display); font-size:1.02rem; color:var(--ink); font-weight:500; }
.portrait__tag span{ font-size:.8rem; color:var(--muted); }
.portrait__leaf{ position:absolute; width:84px; color:var(--sage); opacity:.85; top:-7%; right:2%; animation:sway 7s ease-in-out infinite; transform-origin:bottom center; }

/* ----------------------------- « Pour qui » transitions ----------- */
.transitions-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.transition-item{
  display:flex; align-items:center; gap:.85em; padding:1.05em 1.2em;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.transition-item:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:transparent; }
.transition-item .ico{ width:44px; height:44px; flex:none; border-radius:14px; background:var(--sage-tint); display:grid; place-items:center; }
.transition-item .ico svg{ width:22px; height:22px; color:var(--sage-deep); }
.transition-item b{ font-weight:700; color:var(--ink); font-size:1rem; }

/* ----------------------------- Offres / cartes -------------------- */
.offers{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.2vw,28px); align-items:stretch; }
.offer{
  position:relative; display:flex; flex-direction:column;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(26px,3vw,38px); overflow:hidden;
  transition:transform .45s var(--ease), box-shadow .45s var(--ease);
}
.offer:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.offer__illus{ width:62px; height:62px; margin-bottom:1.3rem; color:var(--sage); }
.offer__illus svg{ width:100%; height:100%; }
.offer h3{ margin-bottom:.4em; }
.offer__price{ font-family:var(--font-display); color:var(--sage-deep); font-size:1.05rem; margin-bottom:1rem; display:flex; align-items:baseline; gap:.4em; }
.offer__price .free{ color:var(--gold); }
.offer p{ color:var(--muted); }
.offer__list{ list-style:none; margin:0 0 1.6rem; padding:0; display:grid; gap:.6rem; }
.offer__list li{ display:flex; gap:.6em; align-items:flex-start; font-size:.96rem; color:var(--ink-soft); }
.offer__list svg{ width:18px; height:18px; color:var(--sage); flex:none; margin-top:.18em; }
.offer .btn{ margin-top:auto; width:100%; }
.offer--featured{ background:var(--sage-deep); border-color:var(--sage-deep); color:#EEF0E7; }
.offer--featured h3,.offer--featured .offer__price{ color:#fff; }
.offer--featured .offer__price .free{ color:#F0D2CB; }
.offer--featured p,.offer--featured .offer__list li{ color:#DDE2D2; }
.offer--featured .offer__illus,.offer--featured .offer__list svg{ color:var(--rose); }
.offer--featured .btn{ --bg:#fff; --fg:var(--sage-deep); --bd:#fff; }
.offer--featured .btn:hover{ --bg:var(--rose); --fg:#5b3a33; --bd:var(--rose); }
.offer__ribbon{
  position:absolute; top:18px; right:-34px; transform:rotate(45deg);
  background:var(--rose); color:#5b3a33; font-size:.72rem; font-weight:800; letter-spacing:.12em;
  text-transform:uppercase; padding:.4em 3em;
}

/* ----------------------------- Méthode / étapes ------------------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(18px,2.4vw,30px); position:relative; }
.steps::before{
  content:""; position:absolute; top:34px; left:9%; right:9%; height:2px;
  background:repeating-linear-gradient(90deg,var(--rose) 0 10px,transparent 10px 20px); opacity:.6; z-index:0;
}
.step{ position:relative; z-index:1; text-align:center; }
.step__num{
  width:70px; height:70px; margin:0 auto 1.1rem; border-radius:50%;
  background:var(--cream-2); border:2px solid var(--rose);
  display:grid; place-items:center; font-family:var(--font-display); font-size:1.7rem; color:var(--sage-deep);
  box-shadow:0 0 0 8px var(--cream);
  transition:transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease);
}
.step:hover .step__num{ transform:translateY(-4px); background:var(--sage-deep); color:#fff; }
.step h3{ font-size:1.18rem; margin-bottom:.35em; }
.step p{ font-size:.95rem; color:var(--muted); margin:0; }

/* ----------------------------- Témoignages ----------------------- */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.2vw,26px); }
.quote-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(26px,3vw,36px); position:relative; display:flex; flex-direction:column;
  box-shadow:var(--shadow-sm);
}
.quote-card .mark{ font-family:var(--font-display); font-size:4.2rem; line-height:.6; color:var(--rose); height:.4em; }
.quote-card p{ font-size:1.04rem; color:var(--ink-soft); font-style:italic; font-family:var(--font-display); font-weight:340; }
.quote-card .stars{ color:var(--gold); letter-spacing:.12em; margin-bottom:.6rem; font-size:.95rem; }
.quote-author{ display:flex; align-items:center; gap:.8em; margin-top:auto; padding-top:1.2rem; }
.avatar{
  width:48px; height:48px; border-radius:50%; flex:none; display:grid; place-items:center;
  font-family:var(--font-display); font-weight:600; font-size:1.15rem; color:#fff; background:var(--sage);
}
.avatar.r{ background:var(--rose-deep); } .avatar.g{ background:var(--gold); }
.quote-author b{ display:block; color:var(--ink); font-weight:700; font-size:.98rem; }
.quote-author span{ font-size:.85rem; color:var(--muted); }
.quote-card--feature{ background:var(--sage-deep); border-color:var(--sage-deep); box-shadow:var(--shadow-lg); }
.quote-card--feature .mark{ color:var(--rose); }
.quote-card--feature p{ color:#EEF0E7; }
.quote-card--feature .quote-author b{ color:#fff; }
.quote-card--feature .quote-author span{ color:rgba(255,255,255,.72); }

/* ----------------------------- Bandeaux image -------------------- */
.band{
  position:relative; overflow:hidden; border-radius:var(--r-xl);
  background:var(--sage-deep); color:#fff;
  padding:clamp(48px,7vw,96px) clamp(28px,5vw,80px);
}
.band--image{ background-size:cover; background-position:center; }
.band--image::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(105deg, rgba(44,42,38,.74), rgba(88,101,71,.52) 60%, rgba(44,42,38,.30));
}
.band__inner{ position:relative; max-width:660px; }
.band--center .band__inner{ margin-inline:auto; text-align:center; max-width:720px; }
.band h2,.band h3{ color:#fff; }
.band p{ color:rgba(255,255,255,.9); }
.band .eyebrow{ color:var(--rose); }
.band--quote .band__inner{ max-width:880px; }
.band--quote blockquote{ margin:0; font-family:var(--font-display); font-weight:380; font-style:italic;
  font-size:clamp(1.5rem,1.1rem+2vw,2.6rem); line-height:1.32; color:#fff; }
.band--quote cite{ display:block; margin-top:1.4rem; font-style:normal; font-family:var(--font-body);
  font-weight:700; font-size:.95rem; letter-spacing:.04em; color:var(--rose); }

/* ----------------------------- FAQ ------------------------------- */
.faq{ max-width:820px; margin-inline:auto; }
.faq details{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md);
  padding:.4em 1.4em; margin-bottom:14px; transition:box-shadow .3s var(--ease), border-color .3s;
}
.faq details[open]{ box-shadow:var(--shadow-md); border-color:transparent; }
.faq summary{
  list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:1em;
  padding:1.05em 0; font-family:var(--font-display); font-size:1.14rem; font-weight:500; color:var(--ink);
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .plus{ width:30px; height:30px; flex:none; border-radius:50%; background:var(--sage-tint);
  display:grid; place-items:center; position:relative; transition:transform .35s var(--ease), background .3s; }
.faq summary .plus::before,.faq summary .plus::after{ content:""; position:absolute; background:var(--sage-deep); border-radius:2px; }
.faq summary .plus::before{ width:13px; height:2px; } .faq summary .plus::after{ width:2px; height:13px; transition:transform .35s var(--ease); }
.faq details[open] summary .plus{ background:var(--sage-deep); }
.faq details[open] summary .plus::before,.faq details[open] summary .plus::after{ background:#fff; }
.faq details[open] summary .plus::after{ transform:rotate(90deg); }
.faq details > div{ padding:0 0 1.2em; color:var(--muted); }
.faq details > div p:last-child{ margin-bottom:0; }

/* ----------------------------- Formulaires ----------------------- */
.form{ display:grid; gap:1.1rem; }
.form .row{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.field{ display:grid; gap:.45rem; }
.field label{ font-weight:700; color:var(--ink); font-size:.95rem; }
.field .req{ color:var(--rose-deep); }
.field input,.field textarea,.field select{
  width:100%; font:inherit; color:var(--ink);
  padding:.9em 1.1em; background:var(--surface);
  border:1.5px solid var(--line); border-radius:var(--r-sm);
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.field textarea{ min-height:150px; resize:vertical; }
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none; border-color:var(--sage); box-shadow:0 0 0 4px rgba(124,139,111,.16);
}
.field input::placeholder,.field textarea::placeholder{ color:#A9A49B; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; overflow:hidden; }
.form-consent{ display:flex; gap:.7em; align-items:flex-start; font-size:.9rem; color:var(--muted); }
.form-consent input{ margin-top:.25em; width:auto; }
.alert{ border-radius:var(--r-md); padding:1.1em 1.3em; border:1px solid; display:flex; gap:.8em; align-items:flex-start; }
.alert svg{ width:22px; height:22px; flex:none; margin-top:.1em; }
.alert--ok{ background:#EEF3E7; border-color:var(--sage-soft); color:var(--sage-deep); }
.alert--err{ background:#FBEEEC; border-color:#EBC4BD; color:#9A4B3C; }
.alert b{ color:inherit; }

/* ----------------------------- Cartes contact -------------------- */
.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,4vw,56px); align-items:start; }
.contact-cards{ display:grid; gap:14px; }
.contact-card{ display:flex; gap:1em; align-items:flex-start; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--r-md); padding:1.3em 1.4em; }
.contact-card .ico{ width:46px; height:46px; flex:none; border-radius:14px; background:var(--sage-tint); display:grid; place-items:center; }
.contact-card .ico svg{ width:22px; height:22px; color:var(--sage-deep); }
.contact-card b{ display:block; color:var(--ink); margin-bottom:.15em; font-family:var(--font-display); font-weight:500; font-size:1.1rem; }
.contact-card a{ font-weight:600; }
.contact-card span{ color:var(--muted); font-size:.94rem; }

/* ----------------------------- Footer ----------------------------- */
.footer{ position:relative; background:var(--ink); color:#CFC9BF; padding-top:clamp(56px,7vw,90px); margin-top:0; overflow:hidden; }
.footer::before{ content:""; position:absolute; right:3%; bottom:8%; width:150px; height:150px;
  background:url("/img/logo-mark.svg") center/contain no-repeat; opacity:.06; z-index:0; pointer-events:none; }
.footer .container{ position:relative; z-index:1; }
.footer a{ color:#CFC9BF; }
.footer a:hover{ color:#fff; }
.footer__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:clamp(28px,4vw,56px); padding-bottom:48px; }
.footer .logo__name{ color:#fff; } .footer .logo__sub{ color:var(--rose); }
.footer__about p{ color:#A8A299; max-width:30ch; margin-top:1.1rem; }
.footer h4{ font-family:var(--font-body); font-weight:800; font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:#fff; margin-bottom:1.1rem; }
.footer__col ul{ list-style:none; margin:0; padding:0; display:grid; gap:.7rem; }
.footer__col a{ color:#A8A299; font-size:.98rem; }
.footer__social{ display:flex; gap:.7rem; margin-top:1.2rem; }
.footer__social a{ width:44px; height:44px; border-radius:50%; border:1px solid rgba(255,255,255,.16);
  display:grid; place-items:center; transition:background .3s var(--ease), transform .3s var(--ease), border-color .3s; }
.footer__social a:hover{ background:var(--sage); border-color:var(--sage); transform:translateY(-3px); }
.footer__social svg{ width:20px; height:20px; color:#fff; }
.footer__bar{ border-top:1px solid rgba(255,255,255,.1); padding:22px 0; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:.86rem; color:#8C877F; }
.footer__bar a{ color:#8C877F; }

/* ----------------------------- Page hero (intérieures) ------------ */
.page-hero{ padding-top:clamp(140px,16vw,200px); padding-bottom:clamp(30px,5vw,60px); text-align:center; position:relative; }
.page-hero .breadcrumb{ font-size:.85rem; color:var(--muted); margin-bottom:1rem; }
.page-hero .breadcrumb a{ color:var(--sage-deep); }
.page-hero h1{ margin-bottom:.3em; }
.page-hero p{ max-width:620px; margin-inline:auto; color:var(--muted); font-size:clamp(1.05rem,1rem+.4vw,1.22rem); }

/* ----------------------------- À propos --------------------------- */
.about-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(30px,5vw,72px); align-items:center; }
.about-portrait{ position:relative; }
.about-portrait img{ width:100%; border-radius:var(--r-xl) var(--r-xl) 120px var(--r-xl); box-shadow:var(--shadow-lg); display:block; }
.about-portrait .badge-float{ position:absolute; right:-4%; top:8%; background:var(--surface); border-radius:var(--r-md);
  box-shadow:var(--shadow-md); padding:1em 1.2em; text-align:center; }
.about-portrait .badge-float .n{ font-family:var(--font-display); font-size:2rem; color:var(--sage-deep); line-height:1; }
.about-portrait .badge-float .l{ font-size:.78rem; color:var(--muted); margin-top:.3rem; }
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px); }
.value{ text-align:center; padding:clamp(22px,3vw,32px); background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); }
.value .ico{ width:58px; height:58px; margin:0 auto 1rem; border-radius:50%; background:var(--rose-soft); display:grid; place-items:center; }
.value .ico svg{ width:28px; height:28px; color:var(--rose-deep); }
.value h3{ font-size:1.2rem; margin-bottom:.3em; } .value p{ color:var(--muted); font-size:.95rem; margin:0; }

/* prose */
.prose p{ margin-bottom:1.2em; }
.prose h2{ margin-top:1.6em; }
.signature{ font-family:var(--font-display); font-style:italic; font-size:1.7rem; color:var(--sage-deep); margin-top:.6rem; }

/* ----------------------------- Décoratifs ------------------------- */
.blob{ position:absolute; z-index:0; border-radius:50%; filter:blur(46px); opacity:.5; pointer-events:none; }
.blob--sage{ background:radial-gradient(circle,var(--sage-soft),transparent 70%); }
.blob--rose{ background:radial-gradient(circle,var(--rose-soft),transparent 70%); }
.has-deco{ position:relative; }
.has-deco > .container{ position:relative; z-index:1; }
.deco-leaf{ position:absolute; color:var(--sage); opacity:.18; z-index:0; pointer-events:none; }

/* 404 */
.error-page{ min-height:72vh; display:grid; place-items:center; text-align:center; padding-top:120px; }
.error-page .big{ font-family:var(--font-display); font-size:clamp(6rem,18vw,12rem); color:var(--sage-soft); line-height:.9; }

/* ----------------------------- Animations ------------------------- */
@keyframes morph{
  0%,100%{ border-radius:48% 52% 47% 53% / 60% 56% 44% 40%; }
  50%{ border-radius:54% 46% 56% 44% / 44% 52% 48% 56%; }
}
@keyframes sway{ 0%,100%{ transform:rotate(-6deg); } 50%{ transform:rotate(6deg); } }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-14px); } }

.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }

/* load (hero) */
.load-up{ opacity:0; transform:translateY(24px); animation:loadUp .95s var(--ease) forwards; }
.load-up[data-d="1"]{ animation-delay:.12s; } .load-up[data-d="2"]{ animation-delay:.24s; }
.load-up[data-d="3"]{ animation-delay:.36s; } .load-up[data-d="4"]{ animation-delay:.48s; }
.load-up[data-d="5"]{ animation-delay:.6s; }
@keyframes loadUp{ to{ opacity:1; transform:none; } }

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .reveal{ opacity:1; transform:none; }
  .load-up{ opacity:1; transform:none; animation:none; }
}

/* ----------------------------- Responsive ------------------------- */
@media (max-width:1000px){
  .hero__grid{ grid-template-columns:1fr; }
  .portrait{ order:-1; width:min(78%,360px); }
  .portrait__tag{ left:auto; right:-2%; }
  .about-grid{ grid-template-columns:1fr; }
  .about-portrait{ max-width:460px; margin-inline:auto; }
  .contact-grid{ grid-template-columns:1fr; }
  .offers{ grid-template-columns:1fr; max-width:480px; margin-inline:auto; }
  .quotes{ grid-template-columns:1fr; max-width:520px; margin-inline:auto; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:820px){
  .nav__links, .nav .btn{ display:none; }
  .nav-toggle{ display:grid; place-items:center; }
  /* Tiroir mobile */
  .mobile-nav{
    position:fixed; inset:0; z-index:55; background:var(--cream);
    display:flex; flex-direction:column; justify-content:center; gap:.4rem;
    padding:var(--gutter); transform:translateY(-100%); transition:transform .5s var(--ease); visibility:hidden;
  }
  body.nav-open .mobile-nav{ transform:none; visibility:visible; }
  .mobile-nav a{ font-family:var(--font-display); font-size:2rem; color:var(--ink); padding:.35em 0; border-bottom:1px solid var(--line-soft); }
  .mobile-nav a:last-of-type{ border:0; }
  .mobile-nav .btn{ margin-top:1.4rem; align-self:flex-start; }
  .transitions-grid{ grid-template-columns:1fr 1fr; }
  .steps{ grid-template-columns:1fr 1fr; gap:30px 18px; }
  .steps::before{ display:none; }
  .values{ grid-template-columns:1fr; max-width:420px; margin-inline:auto; }
  .form .row{ grid-template-columns:1fr; }
  .hero__meta{ gap:1.6rem; }
}
@media (min-width:821px){ .mobile-nav{ display:none; } }
@media (max-width:520px){
  .transitions-grid{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; }
  .portrait__leaf{ display:none; }
  .hero__cta .btn{ width:100%; }
}

/* =====================================================================
   CRÉATIF · NATURE  (vagues organiques, arches, botaniques)
   ===================================================================== */

/* ----- Vagues de transition entre sections ----- */
.wave{ line-height:0; margin:0; position:relative; z-index:2; }
.wave svg{ display:block; width:100%; height:clamp(44px,6.5vw,92px); }

/* ----- Cadres en arche ----- */
.arch{ border-radius:49% 49% 12px 12px / 30% 30% 6px 6px; overflow:hidden; }

/* Cadre organique doux (sans liseré blanc épais) */
.organic-frame{ display:block; position:relative; aspect-ratio:4/5; overflow:hidden;
  border-radius:48% 52% 47% 53% / 60% 56% 44% 40%;
  box-shadow:var(--shadow-lg); animation:morph 18s ease-in-out infinite; }
.organic-frame img{ width:100%; height:100%; object-fit:cover; display:block; border-radius:0; }

/* ----- Illustrations botaniques ----- */
.bot{ position:absolute; z-index:3; display:block; pointer-events:none; }
.botanical{ display:block; width:100%; height:auto; pointer-events:none; will-change:transform; }
.float-soft{ animation:floaty 9s ease-in-out infinite; }
.sway-soft{ animation:sway 8s ease-in-out infinite; transform-origin:50% 100%; }

/* ----- Section sauge profond (moment « vert » à la Daliah) ----- */
.section--sage{ background:var(--sage-deep); color:#E6EADD; position:relative; }
.section--sage h1,.section--sage h2,.section--sage h3{ color:#fff; }
.section--sage .eyebrow{ color:var(--rose); }
.section--sage .section-head p{ color:rgba(255,255,255,.82); }

/* ----- Héro : portrait en arche + ambiance ----- */
.portrait--arch .portrait__frame{ border-radius:48% 48% 14px 14px / 31% 31% 6px 6px; aspect-ratio:4/4.9; }
.portrait--arch .portrait__halo{ border-radius:48% 48% 14px 14px / 31% 31% 6px 6px; animation:none; inset:-5% -5% -3%; }
.hero{ overflow:visible; }

/* ----- Galerie d'ambiance en arches (remplace les offres) ----- */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2.6vw,34px); align-items:start; }
.gallery figure{ margin:0; position:relative; }
.gallery .arch{ display:block; aspect-ratio:3/4.1; border:7px solid #fff; box-shadow:var(--shadow-md); }
.gallery img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.1s var(--ease); }
.gallery figure:hover img{ transform:scale(1.05); }
.gallery figure:nth-child(2){ transform:translateY(34px); }
.gallery figcaption{ text-align:center; margin-top:1.1rem; font-family:var(--font-display); font-style:italic; font-weight:380; color:var(--sage-deep); font-size:1.18rem; }

/* ----- Portrait rond « Rencontrez Emmeline » ----- */
.meet-grid{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(34px,5vw,80px); align-items:center; }
.portrait-round{ position:relative; width:min(100%,440px); aspect-ratio:1; justify-self:center; }
.portrait-round .ring{ position:absolute; inset:0; border-radius:50%; overflow:hidden; border:9px solid #fff; box-shadow:var(--shadow-lg); }
.portrait-round .ring img{ width:100%; height:100%; object-fit:cover; }
.portrait-round .halo-round{ position:absolute; inset:-6%; border-radius:50%; z-index:-1;
  background:linear-gradient(150deg,var(--rose-soft),var(--sage-soft)); filter:blur(3px); }
.portrait-round .bot-top{ position:absolute; width:38%; top:-33%; right:-2%; z-index:2; transform:rotate(24deg); }
.portrait-round .bot-bottom{ position:absolute; width:30%; bottom:-7%; left:-8%; z-index:2; transform:rotate(-14deg); }
.portrait-round .seal{ position:absolute; bottom:6%; right:2%; width:96px; height:96px; border-radius:50%;
  background:var(--cream-2); display:grid; place-items:center; box-shadow:var(--shadow-md); z-index:3;
  font-family:var(--font-display); font-style:italic; color:var(--sage-deep); text-align:center; font-size:.92rem; line-height:1.15; padding:10px; }

/* ----- Emphase italique (style éditorial) ----- */
.it{ font-style:italic; font-weight:380; }
.u-sage{ color:var(--sage-deep); }
.u-rose{ color:var(--rose-deep); }
.offer__list--no svg{ color:var(--rose-deep); }

@media (max-width:1000px){
  .meet-grid{ grid-template-columns:1fr; }
  .portrait-round{ order:-1; width:min(74%,360px); }
}
@media (max-width:760px){
  .gallery{ grid-template-columns:1fr; max-width:380px; margin-inline:auto; gap:34px; }
  .gallery figure:nth-child(2){ transform:none; }
  .bot.hide-sm{ display:none; }
}

/* =====================================================================
   EFFETS « WOAW » · animations
   ===================================================================== */
.hero__grid{ position:relative; z-index:2; }

/* Ken Burns doux sur les portraits */
.portrait__frame img{ animation:evKen 22s ease-in-out infinite alternate; }
.portrait-round .ring img{ animation:evKen 24s ease-in-out infinite alternate; }

/* Reflet (sheen) sur les boutons */
.btn{ position:relative; overflow:hidden; isolation:isolate; }
.btn > *{ position:relative; z-index:1; }
.btn::after{
  content:""; position:absolute; top:0; bottom:0; left:-130%; width:55%; z-index:0;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent); transform:skewX(-18deg);
}
.btn:hover::after{ animation:evSheen .85s var(--ease); }
@keyframes evKen{ from{ transform:scale(1); } to{ transform:scale(1.09); } }
@keyframes evSheen{ to{ left:140%; } }

@media (prefers-reduced-motion: no-preference){
  /* Croissance des botaniques : la tige se dessine, les feuilles/fleurs éclosent */
  .botanical .bs{ stroke-dasharray:1; stroke-dashoffset:1; }
  .botanical.grown .bs{ animation:evDraw 1.7s var(--ease) forwards; }
  .botanical .bl{ opacity:0; transform:scale(.12); transform-box:fill-box; transform-origin:50% 88%;
    transition:opacity .55s var(--ease), transform .75s var(--ease); }
  .botanical.grown .bl{ opacity:1; transform:scale(1); transition-delay:calc(var(--i,0) * 52ms + .45s); }
  @keyframes evDraw{ to{ stroke-dashoffset:0; } }


  /* Pluie de pétales */
  .petals{ position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:1; }
  .petal{ position:absolute; top:-8%; width:12px; height:12px; border-radius:0 100% 0 100%;
    background:linear-gradient(135deg,var(--rose-deep),var(--rose-soft)); opacity:0; filter:blur(.2px);
    animation-name:evFall; animation-timing-function:linear; animation-iteration-count:infinite; }
  @keyframes evFall{
    0%{ transform:translateY(-12vh) rotate(0) scale(var(--sc,1)); opacity:0; }
    12%{ opacity:.8; } 86%{ opacity:.62; }
    100%{ transform:translateY(112vh) translateX(48px) rotate(330deg) scale(var(--sc,1)); opacity:0; }
  }

  /* Parallaxe (appliquée par JS sur .blob via translate3d) */
  .blob{ will-change:transform; }
}

/* =====================================================================
   RÉSERVATION · widget type Calendly dans la DA
   ===================================================================== */
.booking{
  display:grid; grid-template-columns:.82fr 1.18fr;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  overflow:hidden; box-shadow:var(--shadow-lg); max-width:920px; margin-inline:auto;
}
.booking__aside{
  background:var(--sage-deep); color:#E6EADD; padding:clamp(26px,3vw,40px);
  display:flex; flex-direction:column; gap:1.05rem; position:relative;
}
.booking__aside .b-mark{ width:52px; height:52px; }
.booking__aside h3{ color:#fff; margin:0 0 .35rem; }
.booking__aside .b-meta{ display:flex; align-items:center; gap:.65em; color:rgba(255,255,255,.86); font-size:.96rem; }
.booking__aside .b-meta svg{ width:19px; height:19px; color:var(--rose); flex:none; }
.booking__aside .b-note{ margin:auto 0 0; color:rgba(255,255,255,.72); font-family:var(--font-display); font-style:italic; font-size:1.05rem; }
.booking-demo{ display:inline-block; font-size:.7rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase;
  color:#fff; background:rgba(255,255,255,.16); padding:.34em .8em; border-radius:999px; }
.booking-success .booking-demo{ color:var(--gold); background:#fff6e9; border:1px solid #ecdcbf; margin-top:.7rem; }

.booking__main{ padding:clamp(22px,3vw,38px); }
.cal-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:1.1rem; }
.cal-head strong{ font-family:var(--font-display); font-weight:500; font-size:1.32rem; color:var(--ink); text-transform:capitalize; }
.cal-nav{ width:38px; height:38px; border-radius:50%; border:1px solid var(--line); background:var(--cream-2);
  color:var(--sage-deep); font-size:1.2rem; line-height:1; cursor:pointer; }
.cal-nav:disabled{ opacity:.35; cursor:default; }
.cal-dow{ display:grid; grid-template-columns:repeat(7,1fr); gap:7px; margin-bottom:8px; }
.cal-dow span{ text-align:center; font-size:.72rem; font-weight:800; letter-spacing:.06em; color:var(--muted); }
.cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:7px; }
.cal-day{ aspect-ratio:1; display:grid; place-items:center; border:0; border-radius:13px; background:transparent;
  font:inherit; font-weight:600; font-size:.98rem; color:var(--ink); }
.cal-pad{ visibility:hidden; }
.cal-day.is-off{ color:#CBC6BD; }
.cal-day.is-free{ position:relative; background:var(--sage-tint); color:var(--sage-deep); cursor:pointer;
  transition:background .25s var(--ease), color .25s var(--ease), transform .25s var(--ease); }
.cal-day.is-free::after{ content:""; position:absolute; bottom:6px; left:50%; translate:-50% 0; width:4px; height:4px; border-radius:50%; background:var(--gold); }
.cal-day.is-free:hover{ background:var(--sage); color:#fff; transform:translateY(-2px); }
.cal-day.is-free.sel{ background:var(--sage-deep); color:#fff; }
.cal-day.is-free:hover::after,.cal-day.is-free.sel::after{ background:#fff; }
.booking-hint{ margin:1.1rem 0 0; font-size:.88rem; color:var(--muted); }
.booking-back,.booking-back2{ background:none; border:0; padding:0; margin-bottom:1.1rem; cursor:pointer;
  color:var(--sage-deep); font:inherit; font-weight:700; }
.booking-back:hover,.booking-back2:hover{ text-decoration:underline; }
.slots{ display:grid; grid-template-columns:repeat(auto-fill,minmax(92px,1fr)); gap:11px; margin-top:1.1rem; }
.slot{ padding:.85em .6em; border-radius:12px; border:1.5px solid var(--line); background:var(--surface);
  font:inherit; font-weight:700; color:var(--sage-deep); cursor:pointer; transition:all .2s var(--ease); }
.slot:hover{ border-color:var(--sage); background:var(--sage-tint); transform:translateY(-2px); }
.slot.sel{ background:var(--sage-deep); color:#fff; border-color:var(--sage-deep); }
.booking-success{ text-align:center; padding:1.4rem 0 .6rem; }
.booking-success .ok-ico{ width:66px; height:66px; border-radius:50%; background:var(--sage-tint); display:grid; place-items:center; margin:0 auto 1rem; }
.booking-success .ok-ico svg{ width:32px; height:32px; color:var(--sage-deep); }

@media (max-width:720px){
  .booking{ grid-template-columns:1fr; }
  .booking__aside{ flex-direction:row; flex-wrap:wrap; align-items:center; gap:.7rem 1.2rem; }
  .booking__aside .b-note{ display:none; }
}
