/* =========================================================================
   Isabelle Beaugrand — Blocs de section partagés
   Source unique des composants de mise en page, consommés par les pages du
   site (site/) ET par la bibliothèque (sections/). S'appuie sur system.css
   (primitives + tokens) et themes.css (4 thèmes). Tout en tokens sémantiques.
   ========================================================================= */

/* ----------------------------------------------------- coquilles de section */
.sec { padding:80px 0; }
.sec--lg { padding:96px 0; }
.sec__head { display:flex; flex-direction:column; gap:16px; margin-bottom:48px; max-width:640px; }
.sec__head--center { text-align:center; max-width:720px; margin-inline:auto; align-items:center; }

/* chrome de la bibliothèque (pages sections/) */
.pagehead { border-bottom:1px solid var(--line-green-soft); background:var(--cream); }
.pagehead__in { display:flex; align-items:center; justify-content:space-between; height:var(--header-h); }
.pagehead__title { font-size:18px; }
.pagehead__tag { font-size:var(--fs-small); color:var(--ink-50); }

/* =============================================================== HEADER */
.util { background:var(--green-deep); color:var(--cream); font-size:14px; }
.util__in { display:flex; align-items:center; justify-content:space-between; height:40px; }
.util__list { display:flex; gap:24px; align-items:center; }
.util__list span { display:inline-flex; align-items:center; gap:6px; opacity:.92; }

.nav { display:flex; align-items:center; justify-content:space-between; height:var(--header-h); }
.nav__left { display:flex; align-items:center; gap:32px; }
.brand { font-size:18px; letter-spacing:.01em; color:inherit; }
.nav__links { display:flex; align-items:center; gap:24px; font-size:16px; }
.nav__links a { position:relative; padding:4px 0; color:inherit; }
.nav__links a::after { content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:currentColor; transition:width .25s var(--ease); }
.nav__links a:hover::after { width:100%; }
.nav__toggle { display:none; width:44px; height:44px; border:0; background:transparent; flex-direction:column; gap:5px; align-items:center; justify-content:center; color:inherit; }
.nav__toggle span { width:24px; height:2px; background:currentColor; transition:transform .3s var(--ease), opacity .3s var(--ease); }

/* header fixe du site : transparent (clair) sur le hero, opaque crème au scroll */
.site-header { position:fixed; inset:0 0 auto 0; z-index:100; color:var(--cream); transition:background .35s var(--ease), box-shadow .35s var(--ease), color .35s var(--ease); }
.site-header .util { background:rgba(100,107,81,.55); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); }
.site-header .nav__cta { background:var(--taupe); color:var(--ink); }
.site-header.is-stuck { background:rgba(253,249,242,.94); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); box-shadow:0 1px 0 rgba(62,58,54,.08); color:var(--ink); }
.site-header.is-stuck .util { display:none; }
.site-header.is-stuck .nav__cta { background:var(--green); color:var(--cream); }
/* header plein (pages internes) : crème opaque, texte encre, bandeau util conservé */
.site-header--solid { position:sticky; background:rgba(253,249,242,.96); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); color:var(--ink); box-shadow:0 1px 0 var(--line-green-soft); }
.site-header--solid .nav__cta { background:var(--green); color:var(--cream); }
.site-header--solid .nav__links a::after { background:var(--green); }
/* en-tête de page interne (hero court) */
.page-hero { padding:120px 0 72px; text-align:center; }
.page-hero__in { max-width:820px; margin-inline:auto; display:flex; flex-direction:column; align-items:center; gap:22px; }
.page-hero__crumb { font-size:var(--fs-small); color:var(--text-muted); }
.page-hero__crumb a { color:var(--accent); }
.nav__cta { display:inline-flex; align-items:center; justify-content:center; padding:12px 16px; font-size:16px; white-space:nowrap; transition:transform .2s var(--ease), background .2s var(--ease); }
.nav__cta:hover { transform:translateY(-2px); }

/* ================================================================== HERO */
.hero { min-height:600px; display:flex; align-items:center; }
.hero--full { min-height:88vh; }
.hero--full .hero__inner { padding-top:calc(var(--header-h) + 48px); padding-bottom:64px; }
.hero-photo.theme-image > .theme-bg::after {
  background:linear-gradient(100deg, rgba(28,20,20,.82) 0%, rgba(28,20,20,.5) 42%, rgba(28,20,20,.08) 70%);
}
.hero__inner { max-width:640px; display:flex; flex-direction:column; gap:48px; padding-block:56px; }
.hero__head { display:flex; flex-direction:column; gap:40px; }
.hero__tg { display:flex; flex-direction:column; gap:16px; }
.hero .pullquote { max-width:430px; }
.hero__buttons { display:flex; gap:16px; flex-wrap:wrap; }
.trust { display:grid; grid-template-columns:repeat(2,max-content); gap:16px 32px; max-width:480px; }
.trust__item { display:flex; align-items:center; gap:8px; }
.trust__item img { width:20px; height:20px; }
.trust__item span { font-size:16px; letter-spacing:-.03em; color:var(--text); }

.hero-c { text-align:center; padding:84px 0 92px; }
.hero-c .rings { width:1100px; height:1100px; left:50%; top:-20%; transform:translateX(-50%); }
.hero-c__in { max-width:820px; margin-inline:auto; display:flex; flex-direction:column; align-items:center; gap:28px; }
.hero-c__buttons { display:flex; gap:16px; flex-wrap:wrap; justify-content:center; margin-top:8px; }
.hero-c__strip { display:flex; gap:32px; flex-wrap:wrap; justify-content:center; margin-top:24px; padding-top:28px; border-top:1px solid var(--border); }
.hero-c__strip .trust__item span { color:var(--text-muted); }

/* ============================================================= EDITORIAL */
.split { display:grid; grid-template-columns:1fr 1fr; align-items:stretch; }
.split__media { position:relative; min-height:600px; overflow:hidden; }
.split__media img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.split__content { display:flex; align-items:center; padding:112px 96px; }
.prose { width:100%; max-width:582px; display:flex; flex-direction:column; gap:56px; }
.prose__head { display:flex; flex-direction:column; gap:40px; }
.prose__body { display:flex; flex-direction:column; gap:24px; font-size:20px; color:var(--text); }
.prose__body p { line-height:1.5; }
.leaf--tr { width:120px; right:-10px; top:-24px; transform:rotate(12deg) scaleY(-1); }

.manifesto { text-align:center; padding:92px 0; }
.manifesto__in { max-width:840px; margin-inline:auto; display:flex; flex-direction:column; align-items:center; gap:40px; }
.manifesto__statement { font-size:clamp(28px,3.6vw,40px); line-height:1.2; letter-spacing:-.03em; color:var(--heading); }
.manifesto__sign { display:flex; flex-direction:column; align-items:center; gap:6px; }
.manifesto__sign span.role { font-size:16px; color:var(--text-muted); }
.manifesto .leaf--tr { width:150px; right:4%; top:40px; }
.manifesto .leaf--bl { width:170px; left:2%; bottom:48px; transform:rotate(-28deg); }

.editorial { padding:84px 0; }
.editorial__grid { display:grid; grid-template-columns:0.9fr 1.1fr; gap:80px; align-items:start; }
.editorial__body { display:flex; flex-direction:column; gap:24px; font-size:20px; color:var(--text); }
.stat-rail { display:grid; grid-template-columns:repeat(3,1fr); margin-top:72px; border-top:1px solid var(--border); }
.stat-rail__item { padding:40px 24px 0; }
.stat-rail__item + .stat-rail__item { border-left:1px solid var(--border); }
.ed-num { font-size:clamp(40px,5vw,56px); line-height:1; letter-spacing:-.04em; color:var(--accent); }
.ed-num-label { font-size:16px; color:var(--text-muted); margin-top:8px; }

.asso { min-height:560px; display:flex; align-items:center; }
.asso.theme-image > .theme-bg::after {
  background:linear-gradient(90deg, rgba(40,38,30,.84) 0%, rgba(40,38,30,.55) 45%, rgba(40,38,30,.12) 100%);
}
.asso__in { max-width:560px; display:flex; flex-direction:column; gap:28px; padding:96px 0; }
.asso__title { font-size:clamp(30px,3.6vw,44px); line-height:1.1; letter-spacing:-.035em; color:var(--heading); }
.asso__text { font-size:20px; line-height:1.6; color:var(--text); }

.axis { padding:92px 0; }
.axis .rings { width:1100px; height:1100px; right:-360px; top:-360px; opacity:.9; }
.axis__grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.axis__title { font-size:clamp(32px,4vw,50px); line-height:1.08; letter-spacing:-.04em; color:var(--heading); }
.axis__copy { display:flex; flex-direction:column; gap:24px; font-size:20px; line-height:1.6; color:var(--text); }
.axis__copy em { font-style:italic; font-weight:700; color:var(--accent); }
.axis__copy .btn { align-self:flex-start; margin-top:8px; }

/* ============================================================== SERVICES */
.cards { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.card { position:relative; overflow:hidden; background:var(--surface); padding:36px 24px; display:flex; flex-direction:column; gap:48px; }
.card__circles { position:absolute; width:470px; height:470px; top:-210px; right:-150px; pointer-events:none; opacity:.9; }
.card__body { position:relative; display:flex; flex-direction:column; gap:32px; }
.card__icon { width:32px; height:32px; }
.card__text { display:flex; flex-direction:column; gap:20px; }
.card__lead { font-size:28px; line-height:1.05; letter-spacing:-.02em; color:var(--heading); }
.card__desc { font-style:italic; font-size:18px; line-height:1.15; color:var(--text-muted); }
.card .arrow-link { font-size:16px; margin-top:auto; }

.bento { display:grid; grid-template-columns:1.3fr 1fr 1fr; grid-auto-rows:1fr; gap:16px; }
.tile { position:relative; overflow:hidden; background:var(--surface); padding:32px; display:flex; flex-direction:column; gap:20px; min-height:240px; }
.tile__icon { width:32px; height:32px; }
.tile__title { font-size:24px; line-height:1.1; letter-spacing:-.02em; color:var(--heading); }
.tile__desc { font-style:italic; font-size:16px; line-height:1.4; color:var(--text-muted); }
.tile--feature { grid-row:span 2; background:var(--accent); border-color:transparent; color:var(--primary-fg); justify-content:space-between; }
.tile--feature .tile__title { color:var(--primary-fg); font-size:30px; }
.tile--feature .tile__desc { color:var(--primary-fg); opacity:.82; }
.tile--feature .tile__icon { filter:brightness(0) invert(1); }
.theme-dark .tile--feature .tile__icon { filter:brightness(0); opacity:.9; }
.theme-image .tile--feature { background:var(--green-deep); color:var(--cream); }
.theme-image .tile--feature .tile__title, .theme-image .tile--feature .tile__desc { color:var(--cream); }
.theme-image .tile--feature .tile-cta { background:var(--cream); color:var(--green-deep); }
.tile--wide { grid-column:span 2; }
.tile-cta { display:inline-flex; align-items:center; justify-content:center; padding:12px 16px; background:var(--bg); color:var(--text); font-size:16px; transition:transform .2s var(--ease); }
.tile-cta:hover { transform:translateY(-2px); }

.approaches { position:relative; overflow:hidden; }
.approaches .rings { width:1074px; height:1074px; left:-540px; bottom:-420px; }
.triptych { display:grid; grid-template-columns:repeat(3,1fr); }
.tri { padding:0 40px; display:flex; flex-direction:column; gap:20px; }
.tri + .tri { border-left:1px solid var(--border); }
.tri:first-child { padding-left:0; }
.tri:last-child { padding-right:0; }
.tri__top { display:flex; align-items:baseline; gap:16px; }
.tri__idx { font-size:22px; color:var(--accent); font-weight:700; }
.tri__icon { width:32px; height:32px; }
.tri__name { font-size:26px; line-height:1.1; letter-spacing:-.02em; color:var(--heading); }
.tri__desc { font-style:italic; font-size:17px; line-height:1.5; color:var(--text-muted); }
.tri .arrow-link { margin-top:auto; padding-top:8px; font-size:15px; }

/* =============================================================== PRICING */
.checks { display:flex; flex-direction:column; gap:14px; }
.checks li { display:flex; gap:12px; align-items:flex-start; font-size:16px; line-height:1.45; color:var(--text); }
.checks li::before { content:""; flex:none; width:20px; height:20px; margin-top:2px; background:var(--accent); -webkit-mask:url(../../assets/icons/check-white.svg) center/contain no-repeat; mask:url(../../assets/icons/check-white.svg) center/contain no-repeat; }
.price { display:flex; align-items:baseline; gap:8px; }
.price__amt { font-size:44px; line-height:1; letter-spacing:-.03em; color:var(--heading); }
.price__per { font-size:16px; color:var(--text-muted); }
.rule2 { height:1px; background:var(--border); border:0; margin:4px 0; }
.plans { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; align-items:start; }
.plan { background:var(--surface); padding:40px 32px; display:flex; flex-direction:column; gap:28px; }
.plan--featured { background:var(--surface-2); box-shadow:0 30px 70px -40px rgba(0,0,0,.45); position:relative; }
.plan__flag { position:absolute; top:0; right:0; background:var(--accent); color:var(--primary-fg); font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; padding:6px 14px; }
.plan__name { font-size:24px; letter-spacing:-.02em; color:var(--heading); }
.plan__intro { font-style:italic; font-size:16px; color:var(--text-muted); min-height:46px; }
.offer { display:grid; grid-template-columns:1.3fr .9fr; background:var(--surface); overflow:hidden; }
.offer__main { padding:64px; display:flex; flex-direction:column; gap:28px; }
.invert { background:var(--primary-bg); color:var(--primary-fg); padding:64px 48px; display:flex; flex-direction:column; justify-content:center; gap:24px; }
.invert .price__amt, .invert .price__per, .invert .eyebrow { color:var(--primary-fg); }
.invert .eyebrow { opacity:.85; }
.invert .checks li { color:var(--primary-fg); }
.invert .checks li::before { background:var(--primary-fg); }
.invert__note { font-style:italic; font-size:16px; color:var(--primary-fg); opacity:.82; }
.invert__cta { display:inline-flex; align-items:center; justify-content:center; padding:14px 22px; background:var(--primary-fg); color:var(--primary-bg); font-size:16px; transition:transform .2s var(--ease); }
.invert__cta:hover { transform:translateY(-2px); }

/* =========================================================== TESTIMONIALS */
.stars { display:flex; gap:2px; color:var(--accent); }
.stars svg { width:22px; height:22px; }
.avatar { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg, var(--accent), var(--taupe)); flex:none; }
.person { display:flex; align-items:center; gap:12px; }
.qmark { font-size:64px; line-height:.5; color:var(--accent); font-style:italic; height:34px; }
.qname { font-size:18px; color:var(--heading); }
.qrole { font-size:14px; color:var(--accent); }
.track { display:flex; gap:24px; overflow-x:auto; scroll-snap-type:x mandatory; padding:8px 4px 24px; margin:0 calc(var(--gutter)*-1); padding-inline:var(--gutter); scrollbar-width:none; }
.track::-webkit-scrollbar { display:none; }
.testi { scroll-snap-align:start; flex:0 0 430px; max-width:430px; background:var(--surface); padding:36px 24px; display:flex; flex-direction:column; justify-content:space-between; gap:32px; }
.testi__quote { font-size:16px; line-height:1.5; color:var(--text); }
.testi__foot { display:flex; align-items:center; justify-content:space-between; gap:16px; }
.feature-t { text-align:center; max-width:900px; margin-inline:auto; display:flex; flex-direction:column; align-items:center; gap:32px; }
.feature-t .qmark { font-size:96px; height:54px; }
.feature-t__quote { font-size:clamp(24px,2.8vw,32px); line-height:1.35; letter-spacing:-.02em; color:var(--heading); }
.feature-t__dots { display:flex; gap:8px; margin-top:8px; }
.dot { width:8px; height:8px; border-radius:50%; background:var(--border); }
.dot.is-active { background:var(--accent); }
.tgrid { display:grid; grid-template-columns:1.5fr 1fr; gap:24px; }
.quote { background:var(--surface); padding:48px; display:flex; flex-direction:column; gap:28px; }
.quote__text { font-size:24px; line-height:1.45; font-style:italic; color:var(--text); }
.quote--feature .quote__text { font-size:26px; }
.quote__foot { margin-top:auto; display:flex; align-items:center; gap:14px; }
.tstack { display:grid; grid-template-rows:1fr 1fr; gap:24px; }
.tstack .quote { padding:32px; gap:18px; }
.tstack .quote__text { font-size:18px; }
.tstack .qmark { font-size:54px; height:26px; }
.rating { display:flex; align-items:center; gap:14px; padding:14px 20px; background:var(--surface-2); }
.rating strong { font-size:30px; line-height:1; color:var(--heading); }
.rating small { display:block; font-size:13px; color:var(--accent); }
.thead { display:flex; align-items:flex-end; justify-content:space-between; gap:32px; margin-bottom:48px; flex-wrap:wrap; }
.thead__title { font-size:clamp(28px,3.4vw,44px); line-height:1.08; letter-spacing:-.04em; max-width:680px; color:var(--heading); }

/* =================================================================== CTA */
.band { text-align:center; padding:84px 0; }
.band .rings { width:980px; height:980px; left:50%; top:50%; transform:translate(-50%,-50%); opacity:.7; }
.band__in { max-width:760px; margin-inline:auto; display:flex; flex-direction:column; align-items:center; gap:24px; }
.band__title { font-size:clamp(30px,3.8vw,46px); line-height:1.12; letter-spacing:-.03em; color:var(--heading); }
.band__buttons { display:flex; gap:16px; flex-wrap:wrap; justify-content:center; margin-top:8px; }
.csplit { padding:96px 0; }
.csplit.theme-image > .theme-bg::after { background:linear-gradient(90deg, rgba(40,38,30,.8) 0%, rgba(40,38,30,.5) 55%, rgba(40,38,30,.35) 100%); }
.csplit__grid { display:grid; grid-template-columns:1fr 1fr; gap:96px; align-items:flex-end; }
.csplit__title { font-size:clamp(30px,3.8vw,48px); line-height:1.05; letter-spacing:-.03em; color:var(--heading); }
.cform { display:flex; flex-direction:column; gap:20px; }
.cform__row { display:flex; gap:16px; }
.cform__notes { display:flex; flex-wrap:wrap; gap:16px; }
.news { padding:84px 0; }
.news__panel { position:relative; overflow:hidden; max-width:920px; margin:0 auto; background:var(--surface); padding:64px 72px; text-align:center; }
.news__wave { display:flex; align-items:flex-end; justify-content:center; gap:5px; height:40px; margin-bottom:28px; }
.news__wave span { width:4px; background:var(--accent); opacity:.8; animation:nwave 1.6s ease-in-out infinite; }
@keyframes nwave { 0%,100%{ height:8px } 50%{ height:34px } }
.news__title { font-size:clamp(28px,3.4vw,40px); line-height:1.08; letter-spacing:-.035em; margin-bottom:16px; color:var(--heading); }
.news__lead { font-size:19px; line-height:1.55; max-width:560px; margin:0 auto 32px; color:var(--text-muted); }
.news__form { display:flex; gap:12px; max-width:540px; margin:0 auto; }
.news__notes { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; margin-top:20px; }
.news__note { display:flex; align-items:center; gap:6px; font-size:14px; color:var(--accent); }
.news__note svg { width:18px; height:18px; }

/* =================================================================== FAQ */
.faq-list { max-width:820px; }
.faq-item { border-top:1px solid var(--border); }
.faq-item:last-child { border-bottom:1px solid var(--border); }
.faq-q { width:100%; background:none; border:0; display:flex; align-items:center; justify-content:space-between; gap:24px; padding:26px 4px; text-align:left; font-family:inherit; font-size:22px; color:var(--text); letter-spacing:-.01em; line-height:1.3; }
.faq-icon { flex:none; width:28px; height:28px; position:relative; }
.faq-icon::before, .faq-icon::after { content:""; position:absolute; background:var(--accent); left:50%; top:50%; transition:transform .3s var(--ease), opacity .3s var(--ease); }
.faq-icon::before { width:16px; height:2px; transform:translate(-50%,-50%); }
.faq-icon::after { width:2px; height:16px; transform:translate(-50%,-50%); }
.faq-item.is-open .faq-icon::after { transform:translate(-50%,-50%) scaleY(0); opacity:0; }
.faq-a { overflow:hidden; max-height:0; transition:max-height .4s var(--ease); }
.faq-a__inner { padding:0 60px 28px 4px; font-size:18px; line-height:1.65; color:var(--text); }
.faq-a__inner strong { color:var(--accent); }
.faq2 { display:grid; grid-template-columns:.85fr 1.15fr; gap:80px; align-items:start; }
.faq2 .faq-list { max-width:none; }
.faq2__aside { position:sticky; top:24px; display:flex; flex-direction:column; gap:20px; }

/* ================================================================ FOOTER */
.ft { padding:72px 0 40px; }
.ft__top { display:grid; grid-template-columns:1.6fr 1fr 1fr 1.4fr; gap:48px; padding-bottom:40px; }
.ft__brand p { color:var(--text-muted); max-width:300px; line-height:1.6; margin-top:14px; }
.ft h4 { font-size:14px; text-transform:uppercase; letter-spacing:.08em; color:var(--accent); margin-bottom:16px; }
.ft li { margin-bottom:10px; }
.ft a { color:var(--text); }
.ft a:hover { color:var(--accent); }
.ft__news p { color:var(--text-muted); }
.ft-mini { display:flex; gap:8px; margin-top:12px; }
.ft-mini .field { flex:1; min-width:0; }
.ft__bottom { display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; padding-top:28px; border-top:1px solid var(--border); font-size:14px; color:var(--text-muted); }
.ft-social { display:flex; gap:10px; margin-top:18px; }
.ft-social a { width:36px; height:36px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--accent); }
.ft-social a:hover { background:var(--accent); color:var(--bg); }
.ft-social svg { width:18px; height:18px; }

/* =========================================================================
   PATTERNS ENRICHIS (v2) — média, galeries, zigzag, comparatif, interludes
   Ajoutés pour diversifier la mise en page et densifier le visuel.
   ========================================================================= */

/* harmonisation chromatique des photos (unifie la banque vers la DA chaude) */
.ph,
.split__media img, .mcard__media img, .gallery img,
.lsplit__media img, .interlude > .theme-bg img {
  filter:saturate(.86) contrast(1.02) brightness(1.02) sepia(.05);
}

/* zigzag éditorial : empiler des .split, alterner avec .split--rev */
.split--rev .split__media { order:2; }

/* split à média sticky (pages service longues) */
.lsplit { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:start; }
.lsplit__media { position:sticky; top:104px; overflow:hidden; }
.lsplit__media img { width:100%; height:auto; display:block; }
.lsplit__body { display:flex; flex-direction:column; gap:28px; }
.lsplit__body .prose__body { font-size:19px; }

/* cartes à image (photo en tête) */
.mcards { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.mcards--2 { grid-template-columns:repeat(2,1fr); }
.mcard { position:relative; overflow:hidden; background:var(--surface); display:flex; flex-direction:column; }
.mcard__media { position:relative; aspect-ratio:4/3; overflow:hidden; }
.mcard__media img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.mcard:hover .mcard__media img { transform:scale(1.04); }
.mcard__tag { position:absolute; left:14px; top:14px; z-index:1; background:var(--bg); color:var(--accent); font-size:13px; letter-spacing:.04em; text-transform:uppercase; padding:6px 12px; }
.mcard__body { padding:28px 26px; display:flex; flex-direction:column; gap:14px; flex:1; }
.mcard__title { font-size:24px; line-height:1.1; letter-spacing:-.02em; color:var(--heading); }
.mcard__desc { font-size:16px; line-height:1.55; color:var(--text-muted); }
.mcard .arrow-link { margin-top:auto; padding-top:6px; font-size:15px; }

/* galerie / mosaïque d'images */
.gallery { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:12px; }
.gallery figure { margin:0; position:relative; overflow:hidden; }
.gallery img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .7s var(--ease); }
.gallery figure:hover img { transform:scale(1.06); }
.g-tall { grid-row:span 2; }
.g-wide { grid-column:span 2; }

/* bandeau image intercalé (respiration visuelle) */
.interlude { position:relative; min-height:360px; display:flex; align-items:center; overflow:hidden; }
.interlude > .theme-bg::after { background:linear-gradient(90deg, rgba(40,38,30,.62) 0%, rgba(40,38,30,.3) 60%, rgba(40,38,30,.12) 100%); }
.interlude__in { max-width:600px; display:flex; flex-direction:column; gap:18px; }

/* citation immersive pleine largeur sur photo */
.band.theme-image > .theme-bg::after { background:linear-gradient(180deg, rgba(40,38,30,.74), rgba(40,38,30,.58)); }
.qfull { max-width:920px; margin-inline:auto; text-align:center; display:flex; flex-direction:column; align-items:center; gap:26px; }
.qfull__text { font-size:clamp(26px,3.4vw,42px); line-height:1.28; letter-spacing:-.02em; font-style:italic; color:var(--heading); }
.qfull__by { font-size:16px; color:var(--text-muted); }

/* tableau comparatif (approches) */
.ctable { width:100%; border-collapse:collapse; background:var(--surface); }
.ctable th, .ctable td { padding:18px 22px; text-align:left; border-bottom:1px solid var(--border); vertical-align:top; }
.ctable thead th { background:var(--surface-2); font-size:20px; letter-spacing:-.02em; color:var(--heading); font-weight:400; }
.ctable thead th:first-child { background:transparent; }
.ctable tbody th { font-size:15px; color:var(--text-muted); font-weight:400; white-space:nowrap; }
.ctable td { font-size:16px; line-height:1.5; color:var(--text); }
.ctable tbody tr:last-child th, .ctable tbody tr:last-child td { border-bottom:0; }

/* responsive des patterns v2 */
@media (max-width:980px){
  .split--rev .split__media { order:0; }
  .lsplit { grid-template-columns:1fr; gap:36px; }
  .lsplit__media { position:static; }
  .mcards { grid-template-columns:1fr 1fr; }
  .gallery { grid-template-columns:repeat(2,1fr); grid-auto-rows:180px; }
  .ctable { display:block; overflow-x:auto; white-space:nowrap; }
}
@media (max-width:620px){
  .mcards, .mcards--2 { grid-template-columns:1fr; }
  .gallery { grid-template-columns:1fr 1fr; grid-auto-rows:140px; }
  .g-wide, .g-tall { grid-column:auto; grid-row:auto; }
  .interlude__in { max-width:none; }
}

/* =========================================================================
   INTERACTIONS — survol des cartes + transitions de page
   ========================================================================= */

/* survol des cartes : léger soulèvement + ombre douce (le transform se compose
   avec le translate/scale individuels que pose GSAP, donc pas de conflit) */
.mcard, .card, .tile, .plan, .testi, .quote {
  transition: transform .5s var(--ease), box-shadow .5s var(--ease);
}
.mcard:hover, .card:hover, .plan:hover, .testi:hover, .quote:hover {
  transform: translateY(-6px);
  box-shadow: 0 28px 55px -34px rgba(62,58,54,.45);
}
.tile:hover { transform: translateY(-4px); box-shadow: 0 22px 44px -30px rgba(62,58,54,.4); }

/* quand GSAP est actif : le bloc reveal est rendu visible par CSS (GSAP n'anime
   que les enfants, sans transform inline sur le bloc → le :hover reste libre) */
.is-motion .reveal { opacity: 1; translate: 0 0; transition: none; }
.is-motion .mcard, .is-motion .card, .is-motion .tile,
.is-motion .plan, .is-motion .testi, .is-motion .quote {
  transition: transform .5s var(--ease), box-shadow .5s var(--ease);
}
.is-motion .mcard:hover, .is-motion .card:hover, .is-motion .plan:hover,
.is-motion .testi:hover, .is-motion .quote:hover {
  transform: translateY(-6px); box-shadow: 0 28px 55px -34px rgba(62,58,54,.45);
}
.is-motion .tile:hover { transform: translateY(-4px); box-shadow: 0 22px 44px -30px rgba(62,58,54,.4); }

/* overlay de transition de page (positionné/animé par motion.js) */
.page-transition {
  position:fixed; inset:0; z-index:9999;
  background:var(--green-deep);
  display:flex; align-items:center; justify-content:center;
  pointer-events:none;
}
.page-transition__mark {
  color:var(--cream); font-size:clamp(20px,3vw,30px); letter-spacing:.02em;
}
@media (prefers-reduced-motion: reduce) {
  .page-transition { display:none; }
  .mcard, .card, .tile, .plan, .testi, .quote { transition: none; }
}

/* ============================================================ RESPONSIVE */
@media (max-width:1100px){
  .csplit__grid { gap:56px; }
}
@media (max-width:980px){
  .split { grid-template-columns:1fr; }
  .split__media { min-height:360px; }
  .split__content { padding:64px var(--gutter); }
  .prose { max-width:none; gap:40px; }
  .editorial__grid { grid-template-columns:1fr; gap:40px; }
  .stat-rail { grid-template-columns:1fr; }
  .stat-rail__item + .stat-rail__item { border-left:0; border-top:1px solid var(--border); }
  .leaf--bl { display:none; }
  .axis__grid { grid-template-columns:1fr; gap:40px; }
  .cards { grid-template-columns:1fr; }
  .bento { grid-template-columns:1fr 1fr; }
  .tile--feature { grid-row:auto; grid-column:span 2; }
  .tile--wide { grid-column:span 2; }
  .triptych { grid-template-columns:1fr; }
  .tri { padding:32px 0; }
  .tri + .tri { border-left:0; border-top:1px solid var(--border); }
  .plans { grid-template-columns:1fr; }
  .offer { grid-template-columns:1fr; }
  .offer__main { padding:48px var(--gutter); }
  .tgrid { grid-template-columns:1fr; }
  .quote { padding:36px; }
}
@media (max-width:900px){
  .nav__links { display:none; }
  .nav__toggle { display:flex; }
  .util__list .hide-m { display:none; }
  .nav__links.is-open { display:flex; position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:flex-start; gap:4px; padding:16px var(--gutter) 24px; background:rgba(253,249,242,.98); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); box-shadow:0 12px 24px -16px rgba(62,58,54,.4); }
  .site-header .nav__links.is-open a { color:var(--ink); }
  .faq2 { grid-template-columns:1fr; gap:40px; }
  .faq2__aside { position:static; }
  .csplit__grid { grid-template-columns:1fr; gap:40px; align-items:stretch; }
  .cform__row { flex-direction:column; }
  .news__form { flex-direction:column; }
  .news__panel { padding:48px 28px; }
  .ft__top { grid-template-columns:1fr 1fr; }
  .ft__brand, .ft__news { grid-column:1 / -1; }
}
@media (max-width:620px){
  .hero { min-height:0; }
  .hero--full { min-height:0; }
  .hero__inner { padding-block:96px 64px; gap:40px; }
  .hero--full .hero__inner { padding-top:calc(var(--header-h) + 56px); }
  .trust { grid-template-columns:1fr; }
  .hero-c { padding:96px 0 72px; }
  .bento { grid-template-columns:1fr; }
  .tile--feature, .tile--wide { grid-column:auto; }
  .ft__top { grid-template-columns:1fr; }
}

/* ===== Ajouts thème WP : formulaire contact + prose légale ===== */
.cfield { width:100%; min-width:0; font-family:inherit; font-size:16px; color:var(--ink); padding:14px 16px; background:#fff; border:1px solid var(--taupe); }
.cfield:focus-visible { outline:2px solid var(--green); outline-offset:0; border-color:var(--green); }
textarea.cfield { min-height:130px; resize:vertical; line-height:1.5; }
.legal { max-width:760px; margin-inline:auto; display:flex; flex-direction:column; gap:14px; }
.legal h2 { font-size:24px; letter-spacing:-.02em; color:var(--heading); margin-top:24px; }
.legal h2:first-child { margin-top:0; }
.legal p, .legal li { font-size:16px; line-height:1.7; color:var(--text); }
.legal ul { padding-left:20px; list-style:disc; }
.legal a { color:var(--accent); }

/* ===== Hero plein écran « image claire » — image de fond SANS voile sombre ===== */
.hero-photo--light > .theme-bg { display:block; }
.hero-photo--light > .theme-bg::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(253,249,242,.94) 0%, rgba(253,249,242,.66) 38%, rgba(253,249,242,.18) 62%, rgba(253,249,242,0) 82%);
}
@media (max-width:780px){
  .hero-photo--light > .theme-bg::after {
    background:linear-gradient(180deg, rgba(253,249,242,.5) 0%, rgba(253,249,242,.85) 55%, rgba(253,249,242,.96) 100%);
  }
}

/* ===== Accessibilité ===== */
/* focus clavier visible et homogène */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible, [tabindex]:focus-visible {
  outline: 2px solid var(--green-deep);
  outline-offset: 2px;
  border-radius: 0;
}
/* contraste AA des petits libellés olive sur fonds clairs (eyebrow/tag/role/index) */
.theme-white .eyebrow, .theme-cream .eyebrow,
.theme-white .mcard__tag, .theme-cream .mcard__tag,
.theme-white .tag, .theme-cream .tag,
.theme-white .qrole, .theme-cream .qrole,
.theme-white .tri__idx, .theme-cream .tri__idx,
.theme-white .news__note, .theme-cream .news__note { color: #5b6242; }

/* ===== Correctifs (retours client) ===== */
/* Listes à puces dans les contenus longs (le reset global retire les puces) */
.prose__body ul, .lsplit__body ul, .axis__copy ul, .editorial__body ul,
.band__in ul, .interlude__in ul, .manifesto__in ul {
  list-style: disc; padding-left: 1.25em; margin: 10px 0; font-size: inherit;
}
.prose__body ul li, .lsplit__body ul li, .axis__copy ul li, .editorial__body ul li,
.band__in ul li, .interlude__in ul li, .manifesto__in ul li {
  margin-bottom: 8px; line-height: 1.5; padding-left: 4px;
}
.prose__body ul li::marker, .lsplit__body ul li::marker, .axis__copy ul li::marker,
.editorial__body ul li::marker, .band__in ul li::marker { color: var(--accent); }

/* Panneau vert « invert » : ses libellés restent clairs (priorité sur le correctif a11y) */
.theme-white .invert .eyebrow, .theme-cream .invert .eyebrow,
.theme-white .invert .price__amt, .theme-cream .invert .price__amt,
.theme-white .invert .price__per, .theme-cream .invert .price__per { color: var(--primary-fg); }

/* Champ newsletter lisible sur fonds sombres / image (pied de page, CTA) */
.theme-dark .field, .theme-image .field {
  background: rgba(253,249,242,.16); border-color: rgba(253,249,242,.45); color: var(--cream);
}
.theme-dark .field::placeholder, .theme-image .field::placeholder { color: rgba(253,249,242,.6); }
