/* =========================================================
   CENTR'AD — Landing de transition
   Charte graphique 2025 :
   - Fond crème ivoire
   - Teal #008080 dominant
   - Sage #aec49e en accent (titres secondaires, formes)
   - Quicksand (titres) · Assistant (textes)
   ========================================================= */

:root{
  /* Couleurs charte */
  --teal:#008080;
  --teal-700:#006a6a;
  --teal-100:#ddffeb;
  --red:#e2464c;
  --yellow:#f8d14e;
  --sage:#aec49e;
  --sage-200:#cfdec5;
  --sage-100:#e6eedf;
  --peach:#ffdab9;
  --orange:#D46946;
  --orange-700:#b95730;

  /* Fond crème (signature) */
  --cream:#fbf5e3;
  --cream-soft:#fdf9ed;
  --cream-deep:#f6efd8;

  /* Texte */
  --ink:#1a2424;
  --ink-soft:#465253;
  --muted:#7a8585;
  --line:#ece4cd;
  --line-soft:#f1ead7;

  --radius-sm:8px;
  --radius:14px;
  --radius-lg:22px;

  --shadow-sm:0 1px 2px rgba(20,40,40,.04), 0 2px 10px rgba(20,40,40,.04);
  --shadow:0 6px 22px rgba(0,80,80,.09), 0 2px 6px rgba(0,0,0,.04);

  --container:1140px;
  --gap:24px;

  --t-fast:.18s ease;
  --t:.25s ease;
}

/* Reset léger */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Assistant',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:17px;
  line-height:1.65;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{max-width:100%;display:block}
a{color:var(--teal);text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{color:var(--teal-700)}
:focus-visible{outline:3px solid var(--yellow);outline-offset:3px;border-radius:6px}

/* Typographie charte
   - Titres : Quicksand bold, teal, MAJUSCULES pour les H2 principaux
   - Body : Assistant */
h1,h2,h3,h4{
  font-family:'Quicksand',system-ui,sans-serif;
  font-weight:700;
  color:var(--ink);
  letter-spacing:-.005em;
  margin:0 0 .5em;
  line-height:1.18;
}
h1{
  font-size:clamp(2.1rem,4.6vw,3.4rem);
  font-weight:700;
  color:var(--ink);
}
h2{
  font-size:clamp(1.45rem,2.6vw,2rem);
  font-weight:700;
  color:var(--teal);
  text-transform:uppercase;
  letter-spacing:.02em;
}
h3{font-size:1.1rem;color:var(--ink)}
p{margin:0 0 1em}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
  position:relative;
}

/* Trait sage sous les titres de section (signature charte) */
.title-bar{
  display:inline-block;
  height:3px;width:64px;background:var(--sage);
  border-radius:3px;margin-top:2px;margin-bottom:18px;
}

/* Eyebrow / petite étiquette sage */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Quicksand',sans-serif;
  font-size:.92rem;font-weight:700;color:var(--sage);
  text-transform:uppercase;letter-spacing:.14em;
  margin:0 0 16px;
}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.55}}

/* Accessibilité */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{
  position:absolute;left:-9999px;top:8px;
  background:var(--ink);color:#fff;padding:10px 14px;border-radius:8px;z-index:100;
  font-weight:700;
}
.skip-link:focus{left:8px}

/* =========================================================
   Header
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,245,227,.88);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  min-height:78px;
}

/* Brand : logo monogramme (image) + wordmark texte
   Le wordmark reproduit la charte (Quicksand light + FORMATION espacé) */
.brand{
  display:inline-flex;align-items:center;gap:12px;
  text-decoration:none;color:var(--ink);
}
.brand-logo{height:46px;width:auto;color:var(--ink)}
.brand-wordmark{
  display:flex;flex-direction:column;line-height:1;
}
.brand-wordmark .wm-name{
  font-family:'Quicksand',sans-serif;
  font-weight:500;font-size:1.45rem;letter-spacing:-.005em;
  color:var(--ink);
}
.brand-wordmark .wm-tag{
  font-family:'Assistant',sans-serif;
  font-weight:400;font-size:.62rem;letter-spacing:.32em;
  color:var(--ink-soft);text-transform:uppercase;
  margin-top:3px;padding-left:1px;
}

/* Wordmark inline : "centr'ad" en Quicksand (typo logo),
   "Formation" rendu dans la police courante du paragraphe. */
.brand-inline{display:inline;white-space:nowrap}
.brand-inline .bi-name{
  font-family:'Quicksand',sans-serif;font-weight:500;
  color:inherit;letter-spacing:-.005em;
}
.brand-inline .bi-tag{
  font:inherit;color:inherit;
  letter-spacing:normal;text-transform:none;
}

/* Navigation */
.site-nav ul{list-style:none;display:flex;gap:6px;margin:0;padding:0;align-items:center}
.site-nav a{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 16px;border-radius:999px;
  text-decoration:none;color:var(--ink);font-weight:600;font-size:.98rem;
  transition:background var(--t-fast),color var(--t-fast);
}
.site-nav a:hover{background:var(--sage-100);color:var(--teal-700)}
.site-nav .nav-cta{
  background:var(--teal);color:#fff;
  box-shadow:0 4px 14px rgba(0,128,128,.18);
}
.site-nav .nav-cta:hover{background:var(--teal-700);color:#fff}
.ext-icon{flex:0 0 auto;opacity:.95}

/* =========================================================
   Boutons
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;
  font-family:'Assistant',sans-serif;font-weight:600;font-size:1rem;
  border-radius:999px;border:1.5px solid transparent;
  text-decoration:none;cursor:pointer;
  transition:transform var(--t-fast),background var(--t-fast),color var(--t-fast),border-color var(--t-fast),box-shadow var(--t-fast);
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:var(--teal);color:#fff;
  box-shadow:0 6px 20px rgba(0,128,128,.22);
}
.btn-primary:hover{background:var(--teal-700);color:#fff}
.btn-secondary{background:var(--orange);color:#fff;box-shadow:0 6px 20px rgba(212,105,70,.22)}
.btn-secondary:hover{background:var(--orange-700);color:#fff}
.btn-ghost{background:transparent;color:var(--teal);border-color:var(--teal)}
.btn-ghost:hover{background:var(--sage-100);color:var(--teal-700);border-color:var(--teal-700)}
.btn-block{display:flex;width:100%}

/* =========================================================
   Décor : arcs/cercles charte
   ========================================================= */
.decor-circle{
  position:absolute;border-radius:50%;pointer-events:none;
  border:18px solid var(--sage);opacity:.55;
}
.decor-arc{
  position:absolute;pointer-events:none;
  width:520px;height:520px;border-radius:50%;
  border:24px solid var(--sage);
  border-color:var(--sage) transparent transparent var(--sage);
  opacity:.45;
}
.decor-monogram{
  position:absolute;pointer-events:none;color:var(--sage);
  opacity:.35;
}

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative;overflow:hidden;
  padding:clamp(24px,3.5vw,48px) 0 clamp(56px,8vw,104px);
  background:
    radial-gradient(900px 420px at 92% 110%, rgba(255,218,185,.45) 0%, transparent 60%),
    radial-gradient(700px 360px at 8% -10%, rgba(174,196,158,.32) 0%, transparent 60%),
    var(--cream);
}
.hero-inner{position:relative;z-index:1;max-width:820px}
.hero h1 .accent{color:var(--orange)}
.hero .lede{
  font-size:clamp(1.05rem,1.6vw,1.22rem);
  color:var(--ink-soft);max-width:62ch;
}
.hero-sub-bar{
  display:inline-block;height:3px;width:72px;background:var(--sage);
  border-radius:3px;margin:6px 0 22px;
}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}

/* Logo + baseline en tête de hero */
.hero-brand{
  display:flex;align-items:center;gap:32px;
  margin:0 0 30px;
}
/* Logo complet : picto + wordmark "centr'ad / Formation" */
.hero-logo-block{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  flex:0 0 auto;line-height:1;
}
.hero-mono{
  height:108px;width:auto;color:var(--ink);
}
.hero-wordmark{
  display:flex;flex-direction:column;align-items:center;line-height:1;
}
.hwm-name{
  font-family:'Quicksand',sans-serif;font-weight:300;
  font-size:1.85rem;letter-spacing:.01em;color:var(--ink);
}
.hwm-tag{
  font-family:'Assistant',sans-serif;font-weight:400;
  font-size:.62rem;letter-spacing:.36em;text-transform:uppercase;
  color:var(--ink);margin-top:6px;padding-left:.18em;
}
/* Conservé pour compat — utilisé ailleurs */
.hero-logo{
  height:104px;width:auto;color:var(--ink);
  flex:0 0 auto;
}
.hero-intro{
  display:flex;flex-direction:column;gap:10px;
}
.hero-context{
  margin:0;
  font-family:'Quicksand',sans-serif;font-weight:700;
  font-size:.88rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--sage);
}
.hero-baseline{
  margin:0;
  font-family:'Quicksand',sans-serif;font-weight:600;
  font-size:clamp(1.1rem,1.7vw,1.32rem);
  color:var(--teal);
  line-height:1.35;letter-spacing:-.005em;
  max-width:46ch;
}
.hero-context-sub{
  margin:0;
  font-size:.95rem;color:var(--ink-soft);line-height:1.55;
  max-width:54ch;
}
.hero-divider{
  height:1px;width:100%;max-width:140px;
  background:linear-gradient(90deg,var(--sage),transparent);
  margin:14px 0 72px;
}
@media (max-width:720px){
  .hero-brand{flex-direction:column;align-items:flex-start;gap:22px}
  .hero-logo{height:82px}
  .hero-mono{height:84px}
  .hwm-name{font-size:1.55rem}
  .hwm-tag{font-size:.56rem;letter-spacing:.32em}
  .hero-logo-block{align-items:flex-start}
}

/* =========================================================
   Sections
   ========================================================= */
.section{position:relative;padding:clamp(64px,9vw,112px) 0;overflow:hidden}
.section-cream{background:var(--cream)}
.section-soft{
  background:var(--cream-soft);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.section-deep{background:var(--cream-deep)}
.section-head{max-width:760px;margin:0 0 40px}
.section-sub{color:var(--ink-soft);font-size:1.05rem;margin:0}

/* Décors retirés à la demande */
.section .decor-tl,
.section .decor-br,
.decor-circle,
.decor-arc,
.decor-monogram{display:none}

/* Cards */
.cards{
  display:grid;gap:var(--gap);
  grid-template-columns:repeat(3,minmax(0,1fr));
  position:relative;z-index:1;
}
.card{
  background:#fff;border:1px solid var(--line);
  padding:30px 28px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  position:relative;overflow:hidden;
}
.card::after{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--teal),var(--sage));
  opacity:.0;transition:opacity var(--t);
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--sage-200)}
.card:hover::after{opacity:1}
.card h3{margin:8px 0 8px;font-size:1.18rem;font-family:'Quicksand',sans-serif}
.card p{margin:0;color:var(--ink-soft)}
.card-icon{
  width:56px;height:56px;border-radius:16px;
  display:grid;place-items:center;color:#fff;margin-bottom:16px;
}
.icon-teal{background:var(--teal)}
.icon-orange{background:var(--orange)}
.icon-sage{background:var(--sage);color:#1a2424}

/* =========================================================
   Bloc éditorial "Qui sommes-nous" — texte fluide, sans pavés
   (même logique que "À propos de centr'ad" dans la section contact)
   ========================================================= */
.about-editorial{
  display:grid;gap:48px;
  grid-template-columns:repeat(3,minmax(0,1fr));
  margin-top:64px;position:relative;z-index:1;
}
.editorial-block{display:flex;flex-direction:column;gap:12px}
.editorial-eyebrow{
  margin:0;font-family:'Quicksand',sans-serif;font-weight:700;
  font-size:.86rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--orange);
}
.editorial-title{
  margin:0;font-family:'Quicksand',sans-serif;font-weight:700;
  font-size:clamp(1.15rem,1.55vw,1.32rem);line-height:1.3;
  color:var(--teal);letter-spacing:-.005em;
}
.editorial-text{
  margin:0;color:var(--ink-soft);line-height:1.65;font-size:.98rem;
}
.editorial-text + .editorial-text{margin-top:6px}
.editorial-text strong{color:var(--ink);font-weight:700}
.accent-orange{color:var(--orange);font-style:normal;font-weight:700}
.accent-teal{color:var(--teal);font-style:normal}

@media (max-width:880px){
  .about-editorial{grid-template-columns:1fr;gap:36px;margin-top:48px}
}

/* Réassurance */
.reassure{
  display:grid;gap:40px;align-items:center;
  grid-template-columns:1.1fr .9fr;
  position:relative;z-index:1;
}
.reassure-only{
  display:flex;justify-content:center;
  position:relative;z-index:1;
}
.reassure-only .reassure-card{max-width:640px;width:100%}
.reassure-text h2{margin-bottom:.3em}
.reassure-text .title-bar{margin-bottom:22px}
.checklist{list-style:none;padding:0;margin:18px 0 0}
.checklist li{
  position:relative;padding:12px 0 12px 38px;color:var(--ink-soft);
  border-bottom:1px dashed var(--line);
}
.checklist li:last-child{border-bottom:0}
.checklist li::before{
  content:"";position:absolute;left:0;top:14px;
  width:24px;height:24px;border-radius:50%;
  background:var(--sage-100);border:1.5px solid var(--sage);
}
.checklist li::after{
  content:"";position:absolute;left:8px;top:19px;
  width:8px;height:4px;border-left:2px solid var(--teal);border-bottom:2px solid var(--teal);
  transform:rotate(-45deg);
}
.reassure-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:32px;box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:14px;
  position:relative;overflow:hidden;
}
.reassure-card::before{
  content:"";position:absolute;inset:auto -30% -50% auto;width:80%;height:80%;
  background:radial-gradient(closest-side,var(--peach),transparent 70%);
  pointer-events:none;z-index:0;
}
.reassure-card>*{position:relative;z-index:1}
/* Variante avec couverture catalogue à gauche */
.reassure-card.has-visual{
  flex-direction:row;align-items:center;gap:26px;padding:26px;
}
.reassure-card.has-visual .reassure-visual{
  flex:0 0 auto;width:170px;margin:0;line-height:0;
  border-radius:6px;overflow:hidden;
  box-shadow:0 14px 32px rgba(0,80,80,.18), 0 4px 10px rgba(0,0,0,.08);
  transform:rotate(-2.5deg);
  transition:transform var(--t),box-shadow var(--t);
}
.reassure-card.has-visual:hover .reassure-visual{
  transform:rotate(0deg);
  box-shadow:0 18px 40px rgba(0,80,80,.24), 0 6px 14px rgba(0,0,0,.10);
}
.reassure-card.has-visual .reassure-visual img{width:100%;height:auto;display:block}
.reassure-content{flex:1 1 auto;display:flex;flex-direction:column;gap:10px;min-width:0}
@media (max-width:560px){
  .reassure-card.has-visual{flex-direction:column;align-items:stretch}
  .reassure-card.has-visual .reassure-visual{width:140px;align-self:center}
}
.reassure-eyebrow{
  margin:0;font-weight:700;color:var(--orange);text-transform:uppercase;
  letter-spacing:.14em;font-size:.78rem;font-family:'Quicksand',sans-serif;
}
.reassure-title{
  font-family:'Quicksand',sans-serif;font-weight:700;font-size:1.3rem;
  color:var(--ink);margin:0;
}
.link-inline{
  font-weight:600;text-decoration:none;color:var(--teal);
}
.link-inline:hover{text-decoration:underline}

/* Contact résumé */
.contact-grid{
  display:grid;gap:var(--gap);
  grid-template-columns:repeat(3,minmax(0,1fr));
  align-items:stretch;
  position:relative;z-index:1;
}
.contact-grid.contact-grid--cta{
  grid-template-columns:1fr 1fr;
  gap:28px;
}
.contact-block{
  background:#fff;border:1px solid var(--line);
  padding:26px;border-radius:var(--radius);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
.contact-block::before{
  content:"";position:absolute;top:0;left:0;width:4px;height:100%;
  background:var(--sage);
}
.contact-block h3{
  margin:0 0 8px;color:var(--teal-700);font-size:.85rem;
  text-transform:uppercase;letter-spacing:.14em;
  font-family:'Quicksand',sans-serif;font-weight:700;
}
.contact-block address{font-style:normal;color:var(--ink-soft);line-height:1.7}
.contact-block a{color:var(--ink);font-weight:600;text-decoration:none;border-bottom:1px solid var(--sage)}
.contact-block a:hover{color:var(--teal);border-bottom-color:var(--teal)}
.muted{color:var(--muted);font-size:.92rem}
.contact-cta{margin-top:32px;text-align:center;position:relative;z-index:1}

/* Carte contact avec mini-plan Google Maps */
.contact-block--map{display:flex;flex-direction:column;gap:14px}
.contact-map{
  margin:6px 0 0;border-radius:10px;overflow:hidden;
  border:1px solid var(--line);background:var(--cream-deep);
  aspect-ratio:4/3;line-height:0;
}
.contact-map iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.95)}
.contact-map-link{margin:0}
.contact-map-link a{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:600;color:var(--teal);text-decoration:none;
  border-bottom:1px solid var(--sage);padding-bottom:1px;
}
.contact-map-link a:hover{color:var(--teal-700);border-bottom-color:var(--teal)}

/* Pavé CTA contact (côté droit) */
.contact-cta-card{
  background:linear-gradient(160deg, var(--teal) 0%, var(--teal-700) 100%);
  color:#fff;border-radius:var(--radius);padding:40px 36px;
  display:flex;flex-direction:column;gap:14px;justify-content:center;
  position:relative;overflow:hidden;
  box-shadow:0 14px 32px rgba(0,80,80,.25), 0 4px 10px rgba(0,0,0,.08);
}
.contact-cta-card::before{
  content:"";position:absolute;inset:auto -20% -40% auto;
  width:70%;height:70%;
  background:radial-gradient(closest-side,rgba(248,209,78,.18),transparent 70%);
  pointer-events:none;
}
.contact-cta-card > *{position:relative;z-index:1}
.cta-eyebrow{
  margin:0;font-family:'Quicksand',sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.16em;font-size:.86rem;
  color:var(--yellow);
}
.cta-title{
  margin:0;font-family:'Quicksand',sans-serif;font-weight:700;
  font-size:clamp(1.3rem,2vw,1.65rem);line-height:1.25;color:#fff;
  letter-spacing:-.005em;
}
.cta-text{margin:0 0 6px;color:#cfe9e9;line-height:1.55;font-size:.98rem}
.cta-actions{display:flex;flex-direction:column;gap:12px;margin-top:6px}
.cta-actions .btn{justify-content:center;font-size:1.02rem}
.cta-actions .btn-primary{
  background:#fff;color:var(--teal-700);
  box-shadow:0 6px 18px rgba(0,0,0,.18);
}
.cta-actions .btn-primary:hover{background:var(--cream);color:var(--teal-700)}
.btn-ghost-light{
  background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55);
}
.btn-ghost-light:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff}

/* Lien "Suivez-nous LinkedIn" sous le titre Restons en contact */
.section-head--with-social{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;max-width:none;
}
.section-head--with-social > div{flex:1 1 auto;min-width:0}
.follow-linkedin{
  display:inline-flex;align-items:center;gap:16px;
  text-decoration:none;color:var(--ink);font-weight:600;
  padding:10px 22px 10px 10px;border-radius:999px;
  background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast);
}
.follow-linkedin-text{
  font-family:'Assistant',sans-serif;font-size:1.08rem;font-weight:600;
}
.follow-linkedin-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:50%;
  background:#0a66c2;color:#fff;
  flex:0 0 auto;
  box-shadow:0 6px 16px rgba(10,102,194,.30);
  transition:transform var(--t-fast);
}
.follow-linkedin-icon svg{display:block}
.follow-linkedin:hover,
.follow-linkedin:focus-visible{
  border-color:#0a66c2;color:#0a66c2;
  transform:translateY(-1px);
  box-shadow:var(--shadow);
}
.follow-linkedin:hover .follow-linkedin-icon,
.follow-linkedin:focus-visible .follow-linkedin-icon{
  transform:scale(1.06);
}
@media (max-width:640px){
  .section-head--with-social{align-items:flex-start}
  .follow-linkedin{width:100%;justify-content:space-between}
}

@media (max-width:880px){
  .contact-grid.contact-grid--cta{grid-template-columns:1fr}
  .contact-cta-card{padding:30px 24px}
}

/* Bandeau photo équipe + présentation (Qui sommes-nous) */
.about-team{
  display:grid;gap:36px;align-items:center;
  grid-template-columns:1fr 1fr;
  margin:0 0 48px;position:relative;z-index:1;
}
.about-team-photo{
  margin:0;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow);
  aspect-ratio:4/3;background:var(--cream-deep);
}
.about-team-photo img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.about-team-msg{display:flex;flex-direction:column;gap:14px}
.about-team-eyebrow{
  margin:0;font-family:'Quicksand',sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.16em;font-size:.86rem;color:var(--orange);
}
.about-team-quote{
  margin:0;font-family:'Quicksand',sans-serif;font-weight:600;
  font-size:clamp(1.1rem,1.55vw,1.28rem);color:var(--teal);
  line-height:1.45;
}
.about-team-text{margin:0;color:var(--ink-soft);line-height:1.6}
@media (max-width:880px){
  .about-team{grid-template-columns:1fr;gap:24px}
}

/* =========================================================
   Footer
   ========================================================= */
.site-footer{
  background:#0e2424;color:#cfe1e1;
  padding:48px 0 28px;margin-top:0;position:relative;overflow:hidden;
}
.site-footer::before{display:none}
.footer-legal{
  position:relative;z-index:1;
  display:grid;gap:24px 32px;
  grid-template-columns:repeat(3,minmax(0,1fr));
  padding-bottom:28px;margin-bottom:24px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-legal--row2{
  grid-template-columns:1.6fr 1fr;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-legal h3{
  margin:0 0 8px;font-family:'Quicksand',sans-serif;font-weight:700;
  color:#fff;font-size:.86rem;text-transform:uppercase;letter-spacing:.14em;
}
.footer-legal p{margin:0 0 10px;color:#b9d0d0;font-size:.92rem;line-height:1.7}
.footer-legal p strong{color:#fff;font-weight:700}
.footer-legal a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(174,196,158,.4)}
.footer-legal a:hover{border-bottom-color:var(--sage)}
.footer-small{font-size:.84rem;color:#90a8a8;line-height:1.6}
.footer-legal [data-placeholder]{
  color:#f8d14e;font-style:italic;background:rgba(248,209,78,.08);
  padding:1px 6px;border-radius:3px;
}
.footer-inner{
  display:grid;gap:14px;align-items:center;
  grid-template-columns:1fr auto;
  position:relative;z-index:1;
}
.footer-brand{margin:0;font-weight:600;color:#fff;font-family:'Quicksand',sans-serif;font-size:.92rem}
.footer-links{list-style:none;display:flex;gap:20px;margin:0;padding:0;justify-self:end}
.footer-links a{color:#cfe1e1;text-decoration:none;border-bottom:1px solid transparent;padding-bottom:2px}
.footer-links a:hover{color:#fff;border-bottom-color:var(--sage)}
@media (max-width: 760px){
  .footer-legal,
  .footer-legal--row2{grid-template-columns:1fr;gap:18px}
  .footer-inner{grid-template-columns:1fr;text-align:center}
  .footer-links{justify-self:center}
}

/* =========================================================
   Page Contact
   ========================================================= */
.contact-hero{
  position:relative;overflow:hidden;
  padding:clamp(48px,7vw,84px) 0 clamp(28px,4vw,44px);
  background:
    radial-gradient(800px 360px at 95% -20%, rgba(174,196,158,.40) 0%, transparent 60%),
    var(--cream);
  border-bottom:1px solid var(--line);
}
.contact-hero::before{display:none}
.contact-layout{
  display:grid;gap:40px;
  grid-template-columns:1.1fr .9fr;
  align-items:start;
  padding:clamp(48px,7vw,88px) 0;
}
.form-card{
  background:#fff;border:1px solid var(--line);
  padding:36px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  position:relative;
}
.form-card h2{margin-top:0;font-size:clamp(1.4rem,2.2vw,1.8rem)}
.form-card .title-bar{margin-bottom:8px}
.field{margin:0 0 18px}
.field label{
  display:block;margin-bottom:6px;font-weight:600;color:var(--ink);
}
.field .req{color:var(--red);margin-left:2px}
.field input,
.field select,
.field textarea{
  width:100%;
  padding:12px 14px;
  font:inherit;color:var(--ink);
  background:#fff;
  border:1.5px solid var(--line);
  border-radius:12px;
  transition:border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);
}
.field input:hover,.field select:hover,.field textarea:hover{border-color:var(--sage-200)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--teal);
  box-shadow:0 0 0 4px rgba(0,128,128,.15);
}
.field textarea{min-height:160px;resize:vertical}
.field-row{display:grid;gap:14px;grid-template-columns:1fr 1fr}
.consent{
  display:flex;gap:10px;align-items:flex-start;
  background:var(--cream-deep);border:1px solid var(--line);
  padding:14px;border-radius:12px;margin:6px 0 18px;
}
.consent input{margin-top:5px;width:18px;height:18px;accent-color:var(--teal)}
.consent label{font-weight:400;color:var(--ink-soft);font-size:.95rem;line-height:1.5}
.honeypot{position:absolute;left:-9999px;top:-9999px;height:0;width:0;overflow:hidden}
.form-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.form-status{font-size:.95rem;color:var(--ink-soft)}
.form-status.is-error{color:var(--red);font-weight:600}
.form-status.is-success{color:var(--teal-700);font-weight:600}
.field.is-error input,.field.is-error textarea,.field.is-error select{
  border-color:var(--red);box-shadow:0 0 0 4px rgba(226,70,76,.12);
}
.field-error{color:var(--red);font-size:.9rem;margin:6px 0 0;font-weight:600}

/* Aside contact */
.contact-side{
  display:flex;flex-direction:column;gap:18px;position:sticky;top:96px;
}
.side-card{
  background:#fff;border:1px solid var(--line);
  padding:24px;border-radius:var(--radius);
  position:relative;overflow:hidden;
}
.side-card::before{
  content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--sage);
}
.side-card h3{
  margin:0 0 8px;color:var(--teal-700);font-size:.85rem;
  text-transform:uppercase;letter-spacing:.14em;
  font-family:'Quicksand',sans-serif;font-weight:700;
}
.side-card p,.side-card address{margin:0 0 6px;color:var(--ink-soft);font-style:normal;line-height:1.7}
.side-card a{color:var(--ink);font-weight:600;text-decoration:none;border-bottom:1px solid var(--sage)}
.side-card a:hover{color:var(--teal);border-bottom-color:var(--teal)}
.map-wrap{
  border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  aspect-ratio:4/3;background:var(--cream-deep);
}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 980px){
  .cards{grid-template-columns:repeat(2,minmax(0,1fr))}
  .reassure{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .contact-layout{grid-template-columns:1fr}
  .contact-side{position:static}
  .footer-inner{grid-template-columns:1fr;text-align:center}
  .footer-links{justify-self:center}
  .footer-meta{justify-self:center}
}
@media (max-width: 640px){
  body{font-size:16.5px}
  .header-inner{min-height:68px}
  .brand-logo{height:38px}
  .brand-wordmark .wm-name{font-size:1.2rem}
  .brand-wordmark .wm-tag{font-size:.55rem;letter-spacing:.28em}
  .site-nav a{padding:9px 14px;font-size:.94rem}
  .cards{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .form-card{padding:24px}
  .btn{padding:13px 20px}
  .cta-row .btn{flex:1 1 auto}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* Print (basique) */
@media print{
  .site-header,.site-footer,.cta-row,.btn,.contact-cta,.decor-tl,.decor-br{display:none}
  body{background:#fff;color:#000}
}
