/* ============================================================
   ITÉRATION 2-A - V4 (révision 2)
   Fond beige clair UNIQUE partout. Header icônes vertes / rond rose.
   Bandes rose & verte = motif blanc faible opacité. Services cartes
   crème flottantes (style C, sans numéro). Témoignages full-width.
   Footer sombre. CTA pilule.
   ============================================================ */

.var-3a {
  --bg: #FFFBF1;          /* fond unique du site */
  --bg-alt: #F8F2E6;      /* surface des cartes (crème clair) */
  /* Couleurs EXACTES de la charte graphique */
  --orange: #eb5c2e;
  --green: #046248;
  --rose: #f2cde3;
  --cream: #F8F2E6;
  --ink: #1d1d1b;
  /* Bouton principal (CTA) : rose (fond) + vert (texte) */
  --cta: var(--rose);
  --cta-ink: var(--green);
  --radius: 999px;
  --radius-lg: 24px;
}

/* ---- Boutons : pilule ---- */
.var-3a .btn { border-radius: 999px; padding: 1.05rem 1.9rem; }
.var-3a .btn-link { border: 1px solid var(--line-strong); border-radius: 999px; padding: 0.85rem 1.5rem; text-transform: none; letter-spacing: 0.02em; }
.var-3a .btn-link:hover { border-color: var(--orange); color: var(--orange); gap: 0.95rem; }

/* Convention : ROSE = bouton "voir plus" (secondaire), pas un appel à l'action */
.var-3a .btn-more { background: var(--rose); color: var(--green); }
.var-3a .btn-more:hover { filter: brightness(1.05); }

/* ============ HEADER - hamburger gauche / logo centre / icônes droite ============ */
.var-3a .site-header { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; }
.var-3a .site-header .brand { justify-self: center; opacity: 0; transform: translateY(-4px); pointer-events: none; transition: opacity .45s ease, transform .45s ease; }
.var-3a .site-header.show-logo .brand { opacity: 1; transform: none; pointer-events: auto; }
.var-3a .site-header .brand img { height: 34px; }
.var-3a .header-cta { justify-self: end; gap: 0.6rem; }

/* Icônes rondes : fond ROSE, glyphe VERT */
.var-3a .site-header .burger,
.var-3a .icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: 999px;
  background: transparent; border: 0; color: var(--green);
  cursor: pointer; transition: background .2s ease, color .2s ease;
}
.var-3a .site-header .burger { justify-self: start; }
.var-3a .site-header .burger svg { width: 20px; height: 20px; }
.var-3a .icon-btn svg { width: 19px; height: 19px; }
.var-3a .site-header .burger:hover,
.var-3a .icon-btn:hover { background: var(--green); color: #fff; }

/* ============ MENU PLEIN ÉCRAN - fond vert, logo + liens blancs centrés ============ */
.var-3a .mobile-menu { background: var(--green); justify-content: center; align-items: center; text-align: center; }
.var-3a .mobile-menu .close { color: #fff; }
.var-3a .mm-inner { display: flex; flex-direction: column; align-items: center; gap: clamp(1.8rem, 4vw, 2.8rem); }
.var-3a .mm-logo img { height: clamp(54px, 8vw, 88px); width: auto; }
.var-3a .mobile-menu nav { display: flex; flex-direction: column; align-items: center; gap: clamp(0.1rem, 0.8vw, 0.4rem); }
.var-3a .mobile-menu a { color: #fff; border: 0; font-size: clamp(1.9rem, 4.6vw, 3rem); font-weight: 700; letter-spacing: -0.03em; padding: 0.12rem 0; transition: color .2s ease; }
.var-3a .mobile-menu a:hover { color: var(--rose); }
.var-3a .mm-icons { display: flex; gap: 1rem; margin-top: 0.4rem; }
.var-3a .mm-ic { width: 46px; height: 46px; border-radius: 999px; border: 1px solid rgba(255,255,255,0.5); display: grid; place-items: center; color: #fff; transition: background .2s ease, color .2s ease, border-color .2s ease; }
.var-3a .mm-ic svg { width: 19px; height: 19px; }
.var-3a .mm-ic:hover { background: #fff; color: var(--green); border-color: #fff; }

/* ============ HERO - logo au-dessus du slogan, SANS texture ============ */
.var-3a .hero { padding-top: clamp(78px, 12vh, 130px); padding-bottom: clamp(70px, 10vw, 130px); }
.var-3a .hero .pattern-bg { display: none; }
.var-3a .hero-grid { grid-template-columns: 1fr; }
.var-3a .hero-copy { max-width: 64ch; margin-inline: auto; text-align: center; }
.var-3a .hero-logo { display: block; }
.var-3a .hero-logo img { height: clamp(64px, 9vw, 116px); width: auto; margin: 0 auto clamp(1.5rem, 3vw, 2.6rem); }
.var-3a .hero .display { font-size: clamp(3.2rem, 9vw, 7.6rem); color: #046248; font-weight: 800; line-height: 0.85; letter-spacing: -0.03em; }
.var-3a .hero .display .hero-em { color: var(--orange); }
.var-3a .hero .display .hero-title__accent { display: inline-block; color: #f2cde3; transform: rotate(-3deg); }
.var-3a .hero .lead { max-width: 56ch; margin-inline: auto; margin-top: clamp(1.9rem, 3vw, 2.8rem); }
/* Photo bannière du hero (home) - 50% de la largeur de l'écran (full-width − marges en mobile) */
.var-3a .hero-photo { position: relative; left: 50%; transform: translateX(-50%); width: 50vw; max-width: 860px; margin: clamp(1.9rem, 3vw, 2.8rem) 0 0; }
.var-3a .hero-photo img { width: 100%; height: auto; aspect-ratio: 1200 / 462; object-fit: cover; border-radius: clamp(14px, 1.6vw, 22px); display: block; box-shadow: 0 30px 70px -34px rgba(29,29,27,0.4); }
@media (max-width: 900px) { .var-3a .hero-photo { width: 80vw; max-width: none; } }
@media (max-width: 600px) { .var-3a .hero-photo { width: calc(100vw - 40px); } }
/* Titres de section centrés par défaut (le bloc « C'est qui Sapé » n'utilise pas .section-head) */
.var-3a .section-head { margin-inline: auto; text-align: center; }
.var-3a .section-head .lead, .var-3a .section-head > p { margin-left: auto; margin-right: auto; }

/* ============ BANDES TEXTURÉES - motif BLANC faible opacité ============ */
.var-3a .band { overflow: hidden; }
.var-3a .band > .pattern-bg {
  inset: 0; width: 100%; height: 100%;
  background-image: none; background-color: #fff;
  -webkit-mask: var(--pattern-url) center / cover no-repeat;
  mask: var(--pattern-url) center / cover no-repeat;
  mix-blend-mode: normal;
}
.var-3a .band .wrap, .var-3a .band .vest-gallery { position: relative; z-index: 1; }

/* Bloc 2 (#decouvrir) - TON VERT : titre rose, texte blanc, boutons blancs/vert */
.var-3a .band-rose { background: var(--green); color: #fff; }
.var-3a .band-rose > .pattern-bg { opacity: 0.12; }
.var-3a .band-rose .band-inner { text-align: center; max-width: 840px; margin-inline: auto; }
.var-3a .band-rose .h2 { color: #fff; }
.var-3a .band-rose p { color: rgba(255,255,255,0.86); font-size: 1.12rem; margin: 1.2rem auto 2.1rem; max-width: 50ch; }
.var-3a .band-rose .band-actions { display: flex; flex-wrap: wrap; gap: 0.9rem; justify-content: center; }
.var-3a .band-rose .btn-white { background: #fff; color: var(--green); }
.var-3a .band-rose .btn-white:hover { filter: brightness(0.97); }

/* Bloc 6 (#vestiaire) - TON ROSE : titre vert, texte vert, boutons blancs/rose */
.var-3a .band-green { background: var(--rose); color: var(--green); }
.var-3a .band-green > .pattern-bg { opacity: 0.16; }
.var-3a .band-green .band-head { text-align: center; max-width: 760px; margin-inline: auto; margin-bottom: clamp(2.2rem, 4vw, 3.4rem); }
.var-3a .band-green .h2 { color: var(--green); }
.var-3a .band-green .band-head p { color: var(--green); opacity: 0.82; margin: 1.1rem auto 0; }
.var-3a .band-green .cta-actions { display: flex; flex-wrap: wrap; gap: 0.9rem; justify-content: center; margin-top: clamp(2.2rem, 4vw, 3.2rem); position: relative; z-index: 1; }
.var-3a .band-green .btn-primary { background: #fff; color: var(--rose); }
.var-3a .band-green .btn-primary:hover { filter: none; background: #fff; }
.var-3a .band-green .btn-green { background: #fff; color: var(--rose); }
.var-3a .band-green .btn-green:hover { background: #fff; }

/* ============ Carrousel vestiaire - 3/2/1 items, boucle, swipe ============ */
.var-3a .vest-carousel { --vc-per: 3; --vc-gap: 14px; position: relative; display: flex; align-items: center; gap: clamp(8px, 1.6vw, 20px); width: 100%; max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gutter); }
.var-3a .vc-viewport { overflow: hidden; flex: 1 1 auto; }
.var-3a .vc-track { display: flex; gap: var(--vc-gap); transition: transform .45s cubic-bezier(.2,.7,.3,1); }
.var-3a .vc-track .ph, .var-3a .vc-track .vc-img { flex: 0 0 auto; width: calc((100% - var(--vc-gap) * (var(--vc-per) - 1)) / var(--vc-per)); min-width: 0; height: auto; aspect-ratio: 3/4; border: 7px solid #fff; border-radius: var(--radius-lg); background-color: #efe2da; }
.var-3a .vc-track .vc-img { object-fit: cover; display: block; }
.var-3a .vc-track .ph::after { background: #fff; color: var(--rose); border-color: transparent; }
.var-3a .vc-arrow { flex: 0 0 auto; width: 48px; height: 48px; border-radius: 999px; border: 0; background: #fff; color: var(--green); cursor: pointer; display: grid; place-items: center; box-shadow: 0 10px 28px -12px rgba(0,0,0,0.35); transition: transform .2s ease, background .2s ease; }
.var-3a .vc-arrow:hover { transform: scale(1.07); }
.var-3a .vc-arrow svg { width: 22px; height: 22px; }
@media (max-width: 1023px) { .var-3a .vest-carousel { --vc-per: 2; } }
@media (max-width: 639px) { .var-3a .vest-carousel { --vc-per: 1; --vc-gap: 10px; } .var-3a .vc-arrow { width: 42px; height: 42px; } }

/* Galerie pleine largeur (bloc 6) : hauteurs égales, bord blanc */
.var-3a .band-green .vest-gallery {
  display: flex; gap: clamp(8px, 1vw, 14px);
  height: clamp(300px, 40vw, 520px);
  width: 100%; margin: 0; padding-inline: clamp(12px, 2vw, 28px);
}
.var-3a .band-green .vest-gallery .ph {
  height: 100%; width: 0; margin: 0 !important;
  border-radius: var(--radius-lg); border: 7px solid #fff;
  background-color: #efe2da;
}
.var-3a .band-green .vest-gallery .ph::after { background: #fff; color: var(--rose); border-color: transparent; }
.var-3a .band-green .vest-gallery .ph:nth-child(1) { flex: 0.78; }
.var-3a .band-green .vest-gallery .ph:nth-child(2) { flex: 1.40; }
.var-3a .band-green .vest-gallery .ph:nth-child(3) { flex: 0.66; }
.var-3a .band-green .vest-gallery .ph:nth-child(4) { flex: 1.30; }

/* ============ HISTOIRE - citation Montserrat, CTA rose ============ */
.var-3a #histoire { background: var(--bg); }

/* ============ PAGE NOTRE HISTOIRE ============ */
.var-3a .nh-eyebrow { font-size: var(--fs-label); letter-spacing: 0.2em; text-transform: uppercase; color: var(--green); font-weight: 600; margin: 0 0 0.9rem; }
.var-3a .section-head.center .nh-eyebrow { display: block; }

/* Mission */
.var-3a .nh-mission { padding-top: clamp(20px, 3vw, 40px); }
.var-3a .nh-mission-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.var-3a .nh-mission-media .ph { aspect-ratio: 3 / 4; border-radius: var(--radius-lg); }
.var-3a .nh-mission-body p { color: var(--ink-70); margin: 0 0 1.2rem; }
.var-3a .nh-mission-body .nh-mission-end { color: var(--orange); font-weight: 600; font-size: clamp(1.1rem, 1.6vw, 1.35rem); margin-bottom: 0; }

/* Fil vertical */
.var-3a .nh-timeline { list-style: none; margin: 0 auto; padding: 0; max-width: 760px; position: relative; }
.var-3a .nh-timeline::before { content: ""; position: absolute; left: 27px; top: 8px; bottom: 8px; width: 2px; background: linear-gradient(var(--orange), color-mix(in srgb, var(--orange) 30%, transparent)); }
.var-3a .nh-step { position: relative; display: grid; grid-template-columns: 56px 1fr; gap: clamp(1rem, 2.5vw, 2rem); padding-bottom: clamp(2.2rem, 4vw, 3.4rem); }
.var-3a .nh-step:last-child { padding-bottom: 0; }
.var-3a .nh-marker { position: relative; z-index: 1; width: 56px; height: 56px; border-radius: 50%; background: var(--orange); color: #fff; display: grid; place-items: center; font-weight: 700; font-size: 0.92rem; letter-spacing: -0.02em; box-shadow: 0 0 0 6px var(--bg); }
.var-3a .nh-marker span { line-height: 1; }
.var-3a .nh-card { padding-top: 0.3rem; }
.var-3a .nh-step-label { display: block; font-size: var(--fs-label); letter-spacing: 0.18em; text-transform: uppercase; color: var(--green); font-weight: 600; margin-bottom: 0.5rem; }
.var-3a .nh-card h3 { font-size: clamp(1.4rem, 2.4vw, 2rem); font-weight: 700; letter-spacing: -0.03em; color: var(--ink); margin: 0 0 0.8rem; }
.var-3a .nh-card p { color: var(--ink-70); margin: 0 0 0.9rem; }
.var-3a .nh-card p:last-child { margin-bottom: 0; }

/* Valeurs */
.var-3a .bg-soft { background: var(--bg-alt); }
.var-3a .nh-values-sec .wrap { max-width: 1480px; }
.var-3a .nh-values { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(2rem, 4vw, 4rem); }
.var-3a .nh-value { text-align: center; }
.var-3a .nh-vic { display: inline-grid; place-items: center; width: 64px; height: 64px; border-radius: 50%; background: color-mix(in srgb, var(--orange) 12%, transparent); color: var(--orange); margin-bottom: 1.2rem; }
.var-3a .nh-vic svg { width: 28px; height: 28px; }
.var-3a .nh-value:nth-child(2) .nh-vic { background: color-mix(in srgb, var(--green) 14%, transparent); color: var(--green); }
.var-3a .nh-value:nth-child(3) .nh-vic { background: #f7dbe8; color: #c2557a; }
.var-3a .nh-value h3 { font-size: 1.3rem; font-weight: 700; letter-spacing: -0.02em; margin: 0 0 0.6rem; color: var(--ink); }
.var-3a .nh-value p { color: var(--ink-70); margin: 0; font-size: var(--fs-body); }
@media (max-width: 880px) {
  .var-3a .nh-mission-grid { grid-template-columns: 1fr; }
  .var-3a .nh-mission-media { display: none; }
  .var-3a .nh-values { grid-template-columns: repeat(2, 1fr); gap: 2rem 1.4rem; }
}
@media (max-width: 540px) {
  .var-3a .nh-values { grid-template-columns: 1fr; }
  .var-3a .nh-timeline::before { left: 23px; }
  .var-3a .nh-step { grid-template-columns: 48px 1fr; }
  .var-3a .nh-marker { width: 48px; height: 48px; font-size: 0.82rem; }
}
.var-3a .histoire-grid { grid-template-columns: 0.9fr 1.1fr; align-items: center; }
.var-3a .histoire-media .ph { aspect-ratio: 3 / 4; border-radius: var(--radius-lg); }
.var-3a .histoire-body .h2 { color: var(--orange); margin-bottom: 1.6rem; }
.var-3a .citation {
  font-family: var(--sans); font-style: italic; font-weight: 500;
  font-size: clamp(1.45rem, 2.5vw, 2.05rem); line-height: 1.26; letter-spacing: -0.015em;
  color: var(--ink); max-width: 26ch; margin: 0 0 1.6rem;
}
.var-3a .histoire-body p:not(.citation):not(.nh-eyebrow) { color: var(--ink-70); }
.var-3a .histoire-cta { margin-top: 2.2rem; }

/* ============ CHIFFRES CLÉS - orange + motif ============ */
.var-3a .keyfacts { border: 0; background: var(--orange); color: #fff; overflow: hidden; }
.var-3a .keyfacts .pattern-bg { inset: 0; width: 100%; height: 100%; opacity: 0.16; mix-blend-mode: multiply; }
.var-3a .keyfacts .wrap { position: relative; z-index: 1; padding-block: clamp(50px, 7vw, 96px); }
.var-3a .kf { border-left: 1px solid rgba(255,255,255,0.28); padding: 0.4rem clamp(1.4rem, 3vw, 3rem); align-items: center; text-align: center; gap: 0.8rem; }
.var-3a .kf:first-child { border-left: 0; }
.var-3a .kf-n { color: #fff; font-size: clamp(3rem, 6vw, 5rem); letter-spacing: -0.05em; }
.var-3a .kf-l { color: rgba(255,255,255,0.9); max-width: 22ch; margin-inline: auto; }
.var-3a .kf-n span { color: rgba(255,255,255,0.6); }

/* ============ SERVICES - liste éditoriale (plus de cartes) ============ */
.var-3a #services { background: var(--bg); }
.var-3a #services .h2 { color: var(--orange); white-space: nowrap; font-size: clamp(1.7rem, 3.6vw, 2.9rem); }
/* === Services : damier crème & vert (cartes flottantes) === */
.var-3a .services-grid { border: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(0.9rem, 1.4vw, 1.3rem); }
.var-3a .service { position: relative; border: 0; border-radius: var(--radius-lg); padding: clamp(1.8rem, 2.6vw, 2.4rem); min-height: 210px; display: flex; flex-direction: column; box-shadow: 0 16px 40px -30px rgba(29,29,27,0.3); transition: transform .3s ease, box-shadow .3s ease; }
.var-3a .service:hover { transform: translateY(-5px); box-shadow: 0 28px 58px -26px rgba(29,29,27,0.34); }
.var-3a .service h3 { font-size: 1.45rem; font-weight: 700; letter-spacing: -0.02em; margin: 0 0 0.7rem; }
.var-3a .service:has(.soon) h3 { padding-right: 5rem; }
.var-3a .service p { margin: 0; font-size: var(--fs-body); line-height: 1.55; max-width: none; }
/* Damier : crème d'abord (crème, vert, crème, vert, crème, vert) */
.var-3a .service:nth-child(odd) { background: var(--cream); }
.var-3a .service:nth-child(odd) h3 { color: var(--green); }
.var-3a .service:nth-child(odd) p { color: var(--ink-70); }
.var-3a .service:nth-child(even) { background: var(--green); }
.var-3a .service:nth-child(even) h3 { color: #fff; }
.var-3a .service:nth-child(even) p { color: rgba(255,255,255,0.85); }
/* Tags discrets, non colorés */
.var-3a .service .s-tags { display: flex; flex-wrap: wrap; gap: 0.45rem; margin-top: auto; padding-top: 1.1rem; }
.var-3a .service .s-tags span { font-size: 0.7rem; font-weight: 600; padding: 0.28rem 0.7rem; border-radius: 999px; background: rgba(29,29,27,0.06); color: var(--ink-45); }
.var-3a .service:nth-child(even) .s-tags span { background: rgba(255,255,255,0.14); color: rgba(255,255,255,0.7); }
/* Tag « Bientôt » (carte Photobooth) */
.var-3a .service .soon { position: absolute; top: 1.2rem; right: 1.2rem; display: inline-flex; align-items: center; gap: 0.4rem; font-size: 0.64rem; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 700; padding: 0.34rem 0.7rem; border-radius: 999px; background: var(--rose); color: var(--green); border: 0; }
.var-3a .service .soon::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--green); }
@media (max-width: 880px) { .var-3a .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .var-3a .services-grid { grid-template-columns: 1fr; } }

/* ============ TARIFS - cartes flottantes ============ */
.var-3a #tarifs-section { background: var(--bg); }
.var-3a #tarifs-section .wrap, .var-3a #tarifs-recap .wrap { max-width: 1360px; }
.var-3a .t-eyebrow { font-size: var(--fs-label); letter-spacing: 0.2em; text-transform: uppercase; color: var(--green); font-weight: 600; margin: 0 0 0.9rem; }
.var-3a #tarifs-section .h2 { color: var(--orange); }
.var-3a .t-note { margin-top: 1rem; font-size: 0.92rem; color: var(--ink-45); font-weight: 500; }
.var-3a .tarifs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 1.6vw, 1.5rem); align-items: stretch; }
.var-3a .tarif {
  position: relative; background: var(--bg-alt); border-radius: var(--radius-lg);
  padding: clamp(2rem, 3vw, 2.8rem); display: flex; flex-direction: column;
  box-shadow: 0 16px 40px -30px rgba(29,29,27,0.34);
}
.var-3a .tarif-pop { background: var(--orange); color: #fff; box-shadow: 0 30px 64px -28px rgba(235,92,46,0.5); }
.var-3a .tarifs-grid { align-items: stretch; }
.var-3a .tarif .t-head h3 { font-size: 1.5rem; font-weight: 600; color: var(--ink); margin: 0 0 1.1rem; letter-spacing: -0.02em; }
.var-3a .tarif-pop .t-head h3 { padding-right: 6.5rem; }
.var-3a .tarif .t-price { font-size: clamp(2rem, 3.4vw, 2.7rem); font-weight: 700; color: var(--orange); letter-spacing: -0.03em; line-height: 1; }
.var-3a .tarif .t-price span { display: block; font-size: 0.8rem; font-weight: 500; letter-spacing: 0.04em; color: var(--ink-45); margin-top: 0.55rem; min-height: 1.1em; }
.var-3a .tarif ul { list-style: none; margin: 1.6rem 0 0; padding: 1.6rem 0 0; border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 0.7rem; flex: 1; }
.var-3a .tarif li { position: relative; padding-left: 1.6rem; color: var(--ink-70); font-size: var(--fs-body); line-height: 1.45; }
.var-3a .tarif li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--green); font-weight: 700; }
.var-3a .tarif .btn { margin-top: 1.8rem; align-self: flex-start; }
.var-3a .tarif:not(.tarif-pop) ul { margin-bottom: 0; }
.var-3a .t-badge { position: absolute; top: 1.3rem; right: 1.3rem; background: #fff; color: var(--orange); font-size: 0.64rem; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700; padding: 5px 11px; border-radius: 999px; }
/* Carte Signature (orange) */
.var-3a .tarif-pop .t-head h3 { color: #fff; padding-right: 6.5rem; }
.var-3a .tarif-pop .t-price { color: #fff; }
.var-3a .tarif-pop .t-price span { color: rgba(255,255,255,0.78); }
.var-3a .tarif-pop ul { border-top-color: rgba(255,255,255,0.28); }
.var-3a .tarif-pop li { color: rgba(255,255,255,0.94); }
.var-3a .tarif-pop li::before { color: #fff; }
.var-3a .tarif-pop .btn-primary { background: #fff; color: var(--orange); }
.var-3a .tarif-pop .btn-primary:hover { filter: none; background: #fff; }
/* Carte Prestige (verte) */
.var-3a .tarifs-grid .tarif:last-child { background: var(--green); color: #fff; }
.var-3a .tarifs-grid .tarif:last-child .t-head h3 { color: #fff; }
.var-3a .tarifs-grid .tarif:last-child .t-price { color: #fff; }
.var-3a .tarifs-grid .tarif:last-child .t-price span { color: rgba(255,255,255,0.74); }
.var-3a .tarifs-grid .tarif:last-child ul { border-top-color: rgba(255,255,255,0.24); }
.var-3a .tarifs-grid .tarif:last-child li { color: rgba(255,255,255,0.92); }
.var-3a .tarifs-grid .tarif:last-child li::before { color: var(--rose); }
/* Notes bas de section */
.var-3a .tarif-notes { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 2.4rem); margin-top: clamp(2.2rem, 3.5vw, 3.4rem); }
.var-3a .tarif-notes div { font-size: 0.92rem; color: var(--ink-70); line-height: 1.5; padding-top: 1rem; border-top: 1px solid var(--line); }
.var-3a .tarif-notes strong { color: var(--ink); font-weight: 600; }
@media (max-width: 900px) {
  .var-3a .tarifs-grid { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
  .var-3a .tarif-notes { grid-template-columns: 1fr; }
}

/* ============ TÉMOIGNAGES - cartes full-width, marges fines, fond unique ============ */
.var-3a #temoignages { background: var(--bg); }
.var-3a #temoignages .temo-grid {
  grid-template-columns: 1fr; gap: clamp(1rem, 1.6vw, 1.4rem);
  padding-inline: clamp(16px, 4vw, 56px); max-width: 1500px; margin-inline: auto;
}
.var-3a .temo {
  background: var(--bg-alt); border: 0; border-radius: var(--radius-lg);
  box-shadow: 0 18px 44px -32px rgba(29,29,27,0.28);
  display: grid; grid-template-columns: 260px 1fr; gap: clamp(1.5rem, 3vw, 3.5rem); align-items: center;
  padding: clamp(2rem, 3vw, 3rem) clamp(2rem, 4vw, 3.6rem);
}
.var-3a .temo .quote-mark { display: none; }
.var-3a .temo-side .stars { color: var(--orange); margin-bottom: 0.9rem; }
.var-3a .temo-side .who { font-weight: 600; font-size: 1.05rem; }
.var-3a .temo-side .role { color: var(--ink-45); font-size: var(--fs-label); margin-top: 4px; }
.var-3a .temo-main p { color: var(--ink); font-size: var(--fs-body); line-height: 1.55; margin: 0; }

/* ============ FOOTER - sombre (remplace le rose) ============ */
.var-3a .site-footer { background: var(--green); color: #fff; }
.var-3a .footer-brand img { filter: none; }
.var-3a .footer-brand p { color: #fff; }
.var-3a .footer-col h4 { color: rgba(255,255,255,0.72); }
.var-3a .footer-col a, .var-3a .footer-col li { color: #fff; }
.var-3a .footer-col a:hover { color: var(--rose); }
.var-3a .footer-grid { border-bottom-color: rgba(255,255,255,0.2); }
.var-3a .footer-social a { border-color: rgba(255,255,255,0.5); color: #fff; }
.var-3a .footer-social a:hover { background: #fff; border-color: #fff; color: var(--green); }
.var-3a .footer-bottom { color: rgba(255,255,255,0.72); }

@media (max-width: 980px) {
  .var-3a .histoire-grid { grid-template-columns: 1fr; }
  .var-3a .histoire-media { order: -1; }
  .var-3a .histoire-media .ph { aspect-ratio: 16/10; }
}
@media (max-width: 760px) {
  .var-3a .band-green .vest-gallery { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; height: auto; padding-inline: 0; }
  .var-3a .band-green .vest-gallery .ph { width: auto; height: auto; aspect-ratio: 3/4; }
  .var-3a .temo { grid-template-columns: 1fr; gap: 1.1rem; }
}
@media (max-width: 700px) {
  .var-3a .keyfacts-grid { grid-template-columns: 1fr; gap: 1.6rem; }
  .var-3a .kf { border-left: 0; border-top: 1px solid rgba(255,255,255,0.28); padding: 1.4rem 0 0; }
  .var-3a .kf:first-child { border-top: 0; padding-top: 0; }
}
@media (max-width: 600px) {
  .var-3a #services .h2 { white-space: normal; }
}

/* ============================================================
   AJOUTS MULTI-PAGES (intro de page, liens services, FAQ)
   ============================================================ */

/* Liens sous les services */
.var-3a .svc-links { display: flex; flex-wrap: wrap; gap: 0.9rem; justify-content: center; margin-top: clamp(2.4rem, 4vw, 3.4rem); }

/* Intro de page = hero réutilisé, sans logo ni CTA */
.var-3a .hero-inner { padding-top: clamp(140px, 18vh, 200px); padding-bottom: clamp(36px, 5vw, 72px); }
.var-3a .hero-inner .hero-grid { grid-template-columns: 1fr; }
.var-3a .hero-inner .display { font-size: clamp(2.5rem, 6vw, 4.6rem); }
.var-3a .hero-inner .lead { max-width: 56ch; }

/* Titre de section récap (services/tarifs sur pages dédiées) */
.var-3a .recap { border-top: 1px solid var(--line); }
/* Page tarifs : pas de trait entre les tarifs et le récap services */
.var-3a #services-recap { border-top: 0; }
/* Note en pied de la grille tarifs */
.var-3a .tarifs-foot { text-align: center; max-width: 70ch; margin: clamp(2rem, 3.5vw, 3rem) auto 0; color: var(--ink-45); font-size: 0.92rem; line-height: 1.5; }

/* FAQ - accordéon discret */
.var-3a .faq { background: var(--bg); }
.var-3a .faq-grid { max-width: 860px; margin: 0 auto; border-top: 1px solid var(--line); }
.var-3a .faq-item { border-bottom: 1px solid var(--line); }
.var-3a .faq-q { width: 100%; background: none; border: 0; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 1.2rem; padding: clamp(1.1rem, 2vw, 1.6rem) 0; text-align: left; font-family: var(--sans); }
.var-3a .faq-q span { font-size: clamp(1.05rem, 1.7vw, 1.35rem); font-weight: 600; color: var(--ink); letter-spacing: -0.01em; transition: color .2s ease; }
.var-3a .faq-q:hover span { color: var(--orange); }
.var-3a .faq-ic { position: relative; width: 18px; height: 18px; flex: none; }
.var-3a .faq-ic::before, .var-3a .faq-ic::after { content: ""; position: absolute; background: var(--orange); transition: transform .3s ease; }
.var-3a .faq-ic::before { top: 8px; left: 0; width: 18px; height: 2px; }
.var-3a .faq-ic::after { left: 8px; top: 0; width: 2px; height: 18px; }
.var-3a .faq-item.open .faq-ic::after { transform: scaleY(0); }
.var-3a .faq-a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .35s ease; }
.var-3a .faq-item.open .faq-a { grid-template-rows: 1fr; }
.var-3a .faq-a > div { overflow: hidden; }
.var-3a .faq-a p { margin: 0; padding-bottom: clamp(1.1rem, 2vw, 1.6rem); color: var(--ink-70); max-width: 66ch; line-height: 1.6; }

/* Page Services - lignes éditoriales alternées */
.var-3a .srv-list { display: flex; flex-direction: column; gap: clamp(2.6rem, 6vw, 6rem); }
.var-3a .srv-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.8rem, 4vw, 4.5rem); align-items: stretch; }
.var-3a .srv-row:nth-child(even) .srv-media { order: 2; }
.var-3a .srv-media .ph { aspect-ratio: 4/3; }
.var-3a .srv-media { position: relative; border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 24px 54px -32px rgba(29,29,27,0.42); min-height: 230px; }
.var-3a .srv-media .srv-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.var-3a .srv-eyebrow { display: inline-flex; align-items: center; gap: 0.6rem; font-size: var(--fs-label); letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600; color: var(--green); margin-bottom: 0.9rem; }
.var-3a .srv-eyebrow .soon { background: transparent; border: 1px solid rgba(4,98,72,0.4); border-radius: 999px; padding: 0.25rem 0.65rem; color: var(--green); font-size: 0.62rem; }
.var-3a .srv-body h3 { font-size: clamp(1.6rem, 2.8vw, 2.4rem); font-weight: 600; color: var(--green); letter-spacing: -0.02em; margin-bottom: 0.9rem; }
.var-3a .srv-body p { color: var(--ink-70); font-size: var(--fs-body); line-height: 1.7; margin: 0 0 1.1rem; max-width: 50ch; }
.var-3a .srv-ideal { font-size: 0.95rem; color: var(--ink); }
.var-3a .srv-ideal strong { color: var(--orange); font-weight: 600; }
.var-3a .srv-body .s-tags { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1.3rem; }
.var-3a .srv-body .s-tags span { font-size: 0.74rem; font-weight: 600; padding: 0.32rem 0.8rem; border-radius: 999px; background: rgba(29,29,27,0.06); color: var(--ink-45); }
@media (max-width: 760px) {
  .var-3a .srv-row { grid-template-columns: 1fr; gap: 1.2rem; }
  .var-3a .srv-media { position: static; order: 2; min-height: 0; overflow: visible; box-shadow: none; }
  .var-3a .srv-row:nth-child(even) .srv-media { order: 2; }
  .var-3a .srv-media .ph { aspect-ratio: 4/3; }
  .var-3a .srv-media .srv-img { position: static; width: 100%; height: auto; aspect-ratio: 4/3; border-radius: var(--radius-lg); box-shadow: 0 24px 54px -32px rgba(29,29,27,0.42); }
}

/* Notre histoire - page dédiée */
.var-3a .nh-body .citation { font-style: italic; font-size: clamp(1.3rem, 2vw, 1.7rem); line-height: 1.4; color: var(--ink); margin: 0 0 1.6rem; }
.var-3a .nh-body p { color: var(--ink-70); font-size: var(--fs-body); line-height: 1.72; margin: 0 0 1.2rem; }
.var-3a .nh-sign { margin-top: 1.6rem; font-weight: 700; color: var(--orange); }
.var-3a .nh-sign span { display: block; font-weight: 500; color: var(--ink-45); font-size: var(--fs-label); letter-spacing: 0.12em; text-transform: uppercase; margin-top: 4px; }
