/* ============================================================
   GARDVIAS — Design System "Été Méditerranée"
   Hivernage de Fond Massane (Vias 34450)
   Palette claire chaleureuse : sable + turquoise mer + terracotta + or soleil
   ============================================================ */

/* ----- 1. RESET + TOKENS ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip;max-width:100vw}
body{overflow-x:clip;max-width:100vw}
img,video,svg{max-width:100%;height:auto}
iframe{max-width:100%;border:0}
.container,section{max-width:100%}
input,textarea,select{max-width:100%}
/* Tables responsive : scrollable horizontal en mobile sans casser l'alignement desktop */
table{max-width:100%}
@media (max-width:768px){
  table.tarifs,table.compare{
    display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;
    white-space:nowrap;font-size:.82rem;
  }
  table.tarifs th,table.tarifs td,table.compare th,table.compare td{padding:9px 12px;font-size:.85rem}
  .article table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
}
img,svg,video{max-width:100%;display:block}
button{cursor:pointer;font:inherit;color:inherit;background:none;border:0}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

:root{
  /* Palette Été Méditerranée */
  --bg:#FAF6EE;            /* Sable crème */
  --bg-2:#F3EDDF;          /* Sable plus chaud */
  --bg-3:#FFFFFF;          /* Blanc pur */
  --card:#FFFFFF;
  --card-hover:#FFFEF7;
  --border:rgba(10,37,64,.08);
  --border-strong:rgba(10,37,64,.16);

  --accent:#1E88A8;        /* Turquoise Méditerranée */
  --accent-2:#2EA3C4;
  --accent-deep:#0F5D78;
  --gold:#F4A261;          /* Or sable soleil */
  --gold-2:#F7B783;
  --gold-deep:#D4884A;
  --terracotta:#E76F51;    /* Terracotta toit Sud */
  --terracotta-2:#EF8D72;

  --text:#0A2540;          /* Bleu nuit profond */
  --text-dim:#3B4A5E;
  --muted:#6B7A8F;

  --success:#2A9D8F;
  --warning:#E9C46A;
  --danger:#E76F51;

  --container:1240px;
  --gutter:24px;
  --radius-sm:12px;
  --radius:24px;
  --radius-lg:32px;
  --pill:999px;

  --ease:cubic-bezier(.32,.72,0,1);
  --dur:.9s;

  --font-display:'Clash Display','Inter',system-ui,sans-serif;
  --font-body:'General Sans','Inter',system-ui,sans-serif;

  --halo-blue:0 16px 50px -10px rgba(30,136,168,.40);
  --halo-gold:0 16px 50px -10px rgba(244,162,97,.45);
  --halo-terra:0 16px 50px -10px rgba(231,111,81,.40);
  --shadow-soft:0 6px 24px -8px rgba(10,37,64,.10);
  --shadow-card:0 20px 40px -16px rgba(10,37,64,.14);
  --shadow-lift:0 30px 60px -20px rgba(10,37,64,.22);
}

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}

/* Halos d'ambiance — soleil chaud + mer */
body::before{
  content:'';
  position:fixed;inset:0;
  background:
    radial-gradient(900px 700px at 90% -10%,rgba(244,162,97,.22),transparent 60%),
    radial-gradient(700px 600px at -5% 110%,rgba(30,136,168,.12),transparent 60%),
    radial-gradient(500px 400px at 80% 90%,rgba(231,111,81,.08),transparent 60%);
  pointer-events:none;z-index:0;
}

/* ----- 2. CONTAINER + UTILS ----- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter);position:relative;z-index:1}
section{padding:96px 0;position:relative;z-index:1}
@media(max-width:768px){section{padding:64px 0}}
@media(max-width:480px){section{padding:48px 0}}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:980px){
  .grid-2{grid-template-columns:1fr!important;gap:32px}
  .grid-3{grid-template-columns:repeat(2,1fr);gap:24px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .grid-3,.grid-4{grid-template-columns:1fr}
}

/* ----- 3. TYPOGRAPHIE ----- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;line-height:1.08;color:var(--text)}
h1{font-size:clamp(2.2rem,5vw,4.4rem)}
h2{font-size:clamp(1.8rem,3.6vw,3rem);margin-bottom:.6em}
h3{font-size:clamp(1.3rem,2vw,1.7rem)}
h4{font-size:1.1rem}
p{color:var(--text-dim);font-size:1.05rem}
.lead{font-size:clamp(1.05rem,1.5vw,1.25rem);color:var(--text-dim);max-width:62ch}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:var(--pill);
  background:#fff;
  color:var(--text);font-weight:700;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid rgba(30,136,168,.25);
  box-shadow:var(--shadow-soft);
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--terracotta);box-shadow:0 0 10px var(--terracotta)}

/* ----- 4. BUTTONS ----- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:var(--pill);
  font-family:var(--font-body);font-weight:600;font-size:.98rem;
  transition:transform .35s var(--ease),background .25s,box-shadow .35s;
  border:1px solid transparent;white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--halo-blue)}
.btn-primary:hover{background:var(--accent-deep);transform:translateY(-2px);box-shadow:0 22px 60px -10px rgba(30,136,168,.55)}
.btn-gold{background:linear-gradient(135deg,var(--gold) 0%,var(--terracotta) 100%);color:#fff;box-shadow:var(--halo-gold)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 22px 60px -10px rgba(231,111,81,.55)}
.btn-ghost{background:#fff;color:var(--text);border:1px solid var(--border-strong);box-shadow:var(--shadow-soft)}
.btn-ghost:hover{background:#fff;border-color:var(--accent);color:var(--accent-deep)}
.btn .arr{display:inline-block;transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* ----- 5. NAV ----- */
.nav-wrap{position:fixed;top:18px;left:0;right:0;z-index:80;display:flex;justify-content:center;padding-inline:var(--gutter)}
.nav{
  display:flex;align-items:center;gap:24px;
  padding:10px 10px 10px 22px;border-radius:var(--pill);
  background:rgba(255,255,255,.92);
  border:1px solid var(--border);
  -webkit-backdrop-filter:blur(14px) saturate(160%);backdrop-filter:blur(14px) saturate(160%);
  box-shadow:0 18px 50px -16px rgba(10,37,64,.18);
  max-width:1100px;width:100%;
}
.nav .brand{font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--text);display:flex;align-items:center;gap:10px}
.nav .brand .logo-mark{
  width:32px;height:32px;border-radius:10px;
  background:linear-gradient(135deg,var(--accent) 0%,var(--terracotta) 100%);
  display:grid;place-items:center;font-size:.9rem;font-weight:700;color:#fff;
  box-shadow:0 6px 14px -4px rgba(30,136,168,.5);
}
.nav .links{display:flex;gap:22px;margin-left:auto;margin-right:8px}
.nav .links a{font-size:.92rem;color:var(--text-dim);transition:color .25s;position:relative;padding:6px 0;font-weight:500}
.nav .links a:hover{color:var(--accent-deep)}
.nav .burger{display:none;width:42px;height:42px;border-radius:50%;background:rgba(10,37,64,.06);align-items:center;justify-content:center}
.nav .burger span{display:block;width:18px;height:2px;background:var(--text);position:relative}
.nav .burger span::before,.nav .burger span::after{content:'';position:absolute;left:0;width:18px;height:2px;background:var(--text)}
.nav .burger span::before{top:-6px}.nav .burger span::after{top:6px}
@media(max-width:920px){
  .nav .links{display:none}
  .nav .burger{display:flex}
  .nav>a.btn-primary{display:none}
  .nav{gap:12px;padding-left:16px}
}

/* ----- MEGA MENU DESKTOP ----- */
.nav .links li{position:relative}
.nav .links a.mega-toggle::after{content:' ▾';font-size:.7em;color:var(--muted)}
.nav .links li.has-mega .mega-panel{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-lift);
  display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:20px;
  min-width:600px;opacity:0;pointer-events:none;visibility:hidden;
  transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s;
  z-index:90;
}
.nav .links li.has-mega.open .mega-panel,
.nav .links li.has-mega:hover .mega-panel{
  opacity:1;pointer-events:auto;visibility:visible;
  transform:translateX(-50%) translateY(2px);
}
.mega-panel::before{
  content:'';position:absolute;top:-10px;left:0;right:0;height:14px;
}
.mega-col h5{
  font-family:var(--font-display);font-size:.75rem;font-weight:700;
  color:var(--terracotta);letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border);
}
.mega-col a{
  display:block;padding:7px 0;color:var(--text);font-size:.92rem;font-weight:500;
  transition:color .2s,padding-left .2s;
}
.mega-col a:hover{color:var(--accent-deep);padding-left:6px}

/* ----- DRAWER MOBILE — accordion sections ----- */
.drawer details.drawer-section{padding:18px 0;border-bottom:1px solid var(--border)}
.drawer details.drawer-section summary{
  font-family:var(--font-display);font-size:1.6rem;font-weight:500;color:var(--text);
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;
}
.drawer details.drawer-section summary::-webkit-details-marker{display:none}
.drawer details.drawer-section summary::after{
  content:'+';font-size:1.6rem;color:var(--accent);transition:transform .25s;
}
.drawer details.drawer-section[open] summary::after{content:'−'}
.drawer .drawer-sub{
  display:block;font-family:var(--font-body);font-size:1rem;
  padding:10px 0 10px 18px;color:var(--text-dim);border-bottom:0;
}
.drawer .drawer-sub:hover{color:var(--accent-deep)}

/* Drawer mobile */
.drawer{position:fixed;inset:0;background:rgba(250,246,238,.98);z-index:90;display:none;flex-direction:column;padding:96px 32px 48px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}
.drawer.open{display:flex}
.drawer a{font-family:var(--font-display);font-size:1.8rem;padding:18px 0;border-bottom:1px solid var(--border);color:var(--text)}
.drawer .close{position:absolute;top:24px;right:24px;width:44px;height:44px;border-radius:50%;background:#fff;display:grid;place-items:center;color:var(--text);font-size:1.4rem;box-shadow:var(--shadow-soft)}

/* ----- 6. HERO ----- */
.hero{padding:160px 0 80px;position:relative;overflow:hidden;min-height:96vh;display:flex;align-items:center}
.hero-media{position:absolute;inset:0;z-index:-1;overflow:hidden}
/* Double overlay : gradient horizontal pour lisibilité H1 gauche + bottom fade pour transition douce */
.hero-media::after{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(90deg,
      rgba(250,246,238,.94) 0%,
      rgba(250,246,238,.82) 25%,
      rgba(250,246,238,.55) 50%,
      rgba(250,246,238,.20) 75%,
      rgba(250,246,238,.05) 100%),
    linear-gradient(180deg,rgba(250,246,238,0) 70%,rgba(250,246,238,.75) 100%);
}
.hero-media::before{
  /* Halo doré chaud sur le côté droit pour réchauffer la vidéo */
  content:'';position:absolute;inset:0;z-index:1;
  background:radial-gradient(800px 600px at 95% 50%,rgba(244,162,97,.18),transparent 60%);
  pointer-events:none;
}
.hero-media img,.hero-media video{width:100%;height:100%;object-fit:cover;object-position:center}

.hero .container{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.hero h1{margin:18px 0 18px;color:var(--text)}
.hero h1 .accent{background:linear-gradient(135deg,var(--accent) 0%,var(--terracotta) 80%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero .lead{margin-bottom:30px;font-size:1.18rem;color:var(--text-dim)}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.hero-trust{display:flex;gap:24px;flex-wrap:wrap;color:var(--text-dim);font-size:.92rem}
.hero-trust .item{display:flex;align-items:center;gap:8px;font-weight:500}

.hero-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:32px;
  box-shadow:var(--shadow-lift);
}
.hero-card h3{margin-bottom:20px;color:var(--text)}
.hero-card .pricing-mini{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.hero-card .price-row{display:flex;justify-content:space-between;align-items:baseline;padding:14px 16px;background:var(--bg-2);border-radius:var(--radius-sm);border:1px solid var(--border)}
.hero-card .price-row .label{font-weight:600;color:var(--text)}
.hero-card .price-row .label small{display:block;color:var(--muted);font-size:.8rem;font-weight:400;margin-top:2px}
.hero-card .price-row .val{font-family:var(--font-display);font-size:1.4rem;color:var(--accent-deep);font-weight:600}
.hero-card .price-row .val small{font-size:.85rem;color:var(--muted)}
.hero-card .price-row.featured{background:linear-gradient(135deg,rgba(244,162,97,.12),rgba(231,111,81,.06));border-color:var(--terracotta)}
.hero-card .price-row.featured .val{color:var(--terracotta)}

@media(max-width:980px){
  .hero{padding:140px 0 60px;min-height:auto}
  .hero .container{grid-template-columns:1fr!important;gap:40px}
  .hero h1{font-size:2.4rem}
  .hero .lead{font-size:1.05rem}
  /* MOBILE : overlay sable crème opaque pour lisibilité H1 (override gradient horizontal desktop) */
  .hero-media::after{
    background:linear-gradient(180deg,rgba(250,246,238,.88) 0%,rgba(250,246,238,.82) 40%,rgba(250,246,238,.65) 70%,rgba(250,246,238,.95) 100%)!important;
  }
}

/* ----- 7. PILLS EEAT ----- */
.eeat-pills{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
@media(max-width:768px){.eeat-pills{grid-template-columns:repeat(2,1fr)}}
.pill-eeat{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:22px 18px;text-align:center;
  box-shadow:var(--shadow-soft);
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;
}
.pill-eeat:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);border-color:var(--accent)}
.pill-eeat .ic{font-size:1.8rem;margin-bottom:10px}
.pill-eeat .val{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--accent-deep);display:block;margin-bottom:4px}
.pill-eeat .lbl{color:var(--muted);font-size:.85rem;font-weight:500}

/* ----- 8. SECTION HEADER ----- */
.section-head{text-align:center;max-width:780px;margin:0 auto 56px}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{margin-bottom:14px}
.section-head p{margin-inline:auto}

/* ----- 9. FORMULES (3 cards prix) ----- */
.formulas{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}
@media(max-width:980px){.formulas{grid-template-columns:1fr;gap:18px;max-width:480px;margin-inline:auto}}
.formula{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:36px 28px;position:relative;
  box-shadow:var(--shadow-soft);
  transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;
}
.formula:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift);border-color:var(--accent)}
.formula.featured{border-color:var(--terracotta);box-shadow:0 24px 60px -16px rgba(231,111,81,.25)}
.formula .ribbon{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--gold) 0%,var(--terracotta) 100%);color:#fff;font-size:.78rem;font-weight:700;
  padding:6px 16px;border-radius:var(--pill);letter-spacing:.05em;text-transform:uppercase;
  box-shadow:var(--halo-terra);
}
.formula h3{color:var(--text);margin-bottom:8px}
.formula .sub{color:var(--muted);font-size:.92rem;margin-bottom:20px}
.formula .price{display:flex;align-items:baseline;gap:6px;margin-bottom:24px}
.formula .price .num{font-family:var(--font-display);font-size:3rem;font-weight:600;color:var(--accent-deep)}
.formula .price .unit{color:var(--muted);font-size:.95rem}
.formula.featured .price .num{color:var(--terracotta)}
.formula ul{display:flex;flex-direction:column;gap:11px;margin-bottom:28px}
.formula ul li{display:flex;align-items:flex-start;gap:10px;font-size:.95rem;color:var(--text-dim)}
.formula ul li::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--accent);margin-top:7px;flex-shrink:0}
.formula.featured ul li::before{background:var(--terracotta)}
.formula .cta{width:100%;justify-content:center}

/* ----- 10. SERVICES ADD ----- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}
@media(max-width:920px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.services-grid{grid-template-columns:1fr}}
.svc-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:28px;
  box-shadow:var(--shadow-soft);
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;
}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:var(--accent)}
.svc-card .ic{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg,rgba(30,136,168,.18),rgba(30,136,168,.06));
  display:grid;place-items:center;font-size:1.5rem;
  margin-bottom:18px;color:var(--accent-deep);
}
.svc-card h4{color:var(--text);margin-bottom:8px;font-size:1.2rem;font-family:var(--font-display)}
.svc-card p{font-size:.95rem}
.svc-card .price-tag{display:inline-block;margin-top:14px;padding:5px 12px;border-radius:var(--pill);background:rgba(244,162,97,.18);color:var(--gold-deep);font-size:.85rem;font-weight:600}

/* ----- 11. PROCESS (HowTo) ----- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:24px;position:relative}
@media(max-width:920px){.process{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.process{grid-template-columns:1fr}}
.step{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:28px 24px;position:relative;
  box-shadow:var(--shadow-soft);
}
.step .num{
  position:absolute;top:-18px;left:24px;
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-deep) 100%);
  display:grid;place-items:center;font-family:var(--font-display);font-weight:600;color:#fff;font-size:1.05rem;
  box-shadow:var(--halo-blue);
}
.step h4{margin:14px 0 8px;color:var(--text);font-size:1.15rem}
.step p{font-size:.94rem}

/* ----- 12. AVANT/APRÈS SLIDER ----- */
.ba-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:24px}
@media(max-width:920px){.ba-wrap{grid-template-columns:1fr}}
.ba{
  position:relative;border-radius:var(--radius);overflow:hidden;
  container-type:inline-size;aspect-ratio:16/10;
  background:#fff;border:1px solid var(--border);
  box-shadow:var(--shadow-card);
}
.ba .media{position:absolute;inset:0;width:100cqw;height:100%;object-fit:cover}
.ba .pane{position:absolute;inset:0;width:50%;overflow:hidden;border-right:3px solid #fff}
.ba .pane.before{width:50%}
.ba .pane .lbl{position:absolute;top:14px;left:14px;background:#fff;padding:5px 12px;border-radius:var(--pill);font-size:.8rem;font-weight:700;color:var(--text);box-shadow:var(--shadow-soft)}
.ba .pane.after .lbl{left:auto;right:14px;background:var(--accent);color:#fff}
.ba .handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;display:grid;place-items:center;cursor:ew-resize;box-shadow:0 10px 25px rgba(10,37,64,.35);z-index:5;border:2px solid var(--accent)}
.ba .handle::before{content:'⇄';color:var(--accent-deep);font-weight:700;font-size:1.05rem}
.ba input[type=range]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;z-index:10;margin:0}

.ba-text h3{color:var(--text);margin-bottom:14px}
.ba-text ul{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.ba-text ul li{display:flex;gap:10px;align-items:flex-start;color:var(--text-dim);font-size:.96rem}
.ba-text ul li::before{content:'✓';color:var(--terracotta);font-weight:700}

/* ----- 13. ZONE INTERVENTION (chips) ----- */
.chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:36px}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border-radius:var(--pill);
  background:#fff;border:1px solid var(--border);
  color:var(--text);font-size:.92rem;font-weight:500;
  box-shadow:var(--shadow-soft);
  transition:all .25s;
}
.chip:hover{border-color:var(--accent);color:var(--accent-deep);background:#fff;transform:translateY(-2px);box-shadow:var(--shadow-card)}
.chip .pin{color:var(--terracotta)}

/* ----- 14. FONDATEUR ----- */
.founder{
  background:linear-gradient(135deg,#fff 0%,var(--bg-2) 100%);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:48px;display:grid;grid-template-columns:280px 1fr;gap:48px;align-items:center;
  box-shadow:var(--shadow-card);
}
@media(max-width:768px){.founder{grid-template-columns:1fr;padding:32px;text-align:center}}
.founder .portrait{
  width:240px;height:240px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent) 0%,var(--terracotta) 100%);
  display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-size:5rem;font-weight:600;
  border:4px solid #fff;box-shadow:0 24px 60px -16px rgba(30,136,168,.5);
  margin:0 auto;
}
.founder h3{color:var(--text);margin-bottom:8px}
.founder .role{color:var(--terracotta);font-size:.95rem;font-weight:600;margin-bottom:18px}
.founder blockquote{font-size:1.1rem;color:var(--text-dim);font-style:italic;line-height:1.65;border-left:3px solid var(--accent);padding-left:20px;margin:18px 0}
.founder .meta{display:flex;gap:24px;flex-wrap:wrap;color:var(--muted);font-size:.88rem;margin-top:18px}
@media(max-width:768px){.founder blockquote{border-left:0;border-top:3px solid var(--accent);padding:18px 0 0;text-align:left}.founder .meta{justify-content:center}}

/* ----- 15. FAQ ----- */
.faq{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq details{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:20px 24px;box-shadow:var(--shadow-soft);
  transition:border-color .25s,box-shadow .25s;
}
.faq details[open]{border-color:var(--accent);box-shadow:var(--shadow-card)}
.faq summary{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-family:var(--font-display);font-weight:500;font-size:1.1rem;color:var(--text);
  cursor:pointer;list-style:none;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:1.5rem;color:var(--accent);transition:transform .3s;line-height:1}
.faq details[open] summary::after{content:'−'}
.faq .answer{margin-top:14px;color:var(--text-dim);font-size:.98rem;line-height:1.7}

/* ----- 16. MAILLAGE (cards similar) ----- */
.maillage{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:920px){.maillage{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.maillage{grid-template-columns:1fr}}
.related{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;display:flex;flex-direction:column;gap:12px;
  box-shadow:var(--shadow-soft);
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.related:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:var(--accent)}
.related .ic{font-size:1.6rem;color:var(--terracotta)}
.related h4{color:var(--text);font-size:1.15rem}
.related p{font-size:.92rem}
.related .more{margin-top:auto;display:inline-flex;align-items:center;gap:8px;color:var(--accent-deep);font-weight:600;font-size:.92rem}

/* ----- 17. CTA BAND ----- */
.cta-band{
  background:linear-gradient(135deg,var(--accent-deep) 0%,var(--accent) 60%,var(--terracotta) 130%);
  border-radius:var(--radius-lg);
  padding:60px;text-align:center;position:relative;overflow:hidden;
  box-shadow:var(--shadow-lift);
}
.cta-band::before{
  content:'';position:absolute;top:-50%;right:-20%;width:60%;height:200%;
  background:radial-gradient(circle,rgba(244,162,97,.35),transparent 60%);
}
.cta-band h2{color:#fff;margin-bottom:14px;position:relative}
.cta-band p{color:rgba(255,255,255,.95);font-size:1.12rem;max-width:580px;margin:0 auto 28px;position:relative}
.cta-band .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}
.cta-band .btn-ghost{background:rgba(255,255,255,.15);color:#fff;border-color:rgba(255,255,255,.4);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.cta-band .btn-ghost:hover{background:#fff;color:var(--accent-deep)}
@media(max-width:768px){.cta-band{padding:40px 24px}}

/* ----- 18. DEVIS EXPRESS ----- */
.devis-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:980px){.devis-wrap{grid-template-columns:1fr}}
.form-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:36px;box-shadow:var(--shadow-lift);
}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.field label{font-size:.88rem;color:var(--muted);font-weight:600}
.field input,.field select,.field textarea{
  background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:14px 16px;color:var(--text);font-family:inherit;font-size:1rem;
  transition:border-color .25s,box-shadow .25s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(30,136,168,.15)}
.field textarea{min-height:110px;resize:vertical}
.form-card .btn{width:100%;justify-content:center;margin-top:8px}
.form-card .rgpd{font-size:.78rem;color:var(--muted);margin-top:12px;text-align:center;line-height:1.5}

/* ----- 19. FOOTER ----- */
footer{padding:80px 0 30px;background:var(--text);color:#FAF6EE;margin-top:60px;position:relative;z-index:1}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
@media(max-width:920px){.footer-grid{grid-template-columns:repeat(2,1fr);gap:32px}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
footer h4{color:#fff;font-size:1rem;margin-bottom:18px;font-family:var(--font-display)}
footer p{color:rgba(250,246,238,.7);font-size:.92rem}
footer .brand-block .brand{font-family:var(--font-display);font-size:1.4rem;color:#fff;display:flex;align-items:center;gap:10px;margin-bottom:14px}
footer .brand-block p{margin-bottom:18px}
footer .social{display:flex;gap:10px}
footer .social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);display:grid;place-items:center;color:#fff;transition:all .25s;text-decoration:none}
footer .social a:hover{background:var(--accent);border-color:var(--accent)}
footer ul{display:flex;flex-direction:column;gap:10px}
footer ul a{color:rgba(250,246,238,.75);font-size:.92rem;transition:color .2s}
footer ul a:hover{color:var(--gold)}
footer .nap{display:flex;flex-direction:column;gap:8px;color:rgba(250,246,238,.85);font-size:.92rem}
footer .nap a{color:rgba(250,246,238,.85)}
.footer-bottom{padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;color:rgba(250,246,238,.55);font-size:.85rem}
.footer-bottom a{color:rgba(250,246,238,.75)}
.footer-bottom a:hover{color:var(--gold)}

/* ----- 20. STICKY CTA MOBILE ----- */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;display:none;z-index:70;padding:12px;background:rgba(255,255,255,.96);border-top:1px solid var(--border-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);gap:10px;box-shadow:0 -10px 30px rgba(10,37,64,.10)}
.sticky-cta .btn{flex:1;justify-content:center;padding:14px 18px;font-size:.95rem}
@media(max-width:768px){.sticky-cta{display:flex}body{padding-bottom:74px}}

/* ----- 21. REVEAL ANIM (sauf hero — leçon Mery'clean LCP) ----- */
.reveal{opacity:0;transform:translateY(20px);filter:blur(2px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease),filter var(--dur) var(--ease)}
.reveal.in{opacity:1;transform:translateY(0);filter:blur(0)}
.hero .reveal,.page-hero .reveal{opacity:1!important;transform:none!important;filter:none!important;transition:none!important}

/* ----- 22. ANIMATIONS HERO SVG (vie sans média externe) ----- */
@keyframes sunPulse{0%,100%{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}
@keyframes waveSlide{0%{transform:translateX(0)}100%{transform:translateX(-80px)}}
@keyframes palmSway{0%,100%{transform:rotate(-1.2deg)}50%{transform:rotate(1.2deg)}}
@keyframes birdFly{0%{transform:translate(0,0)}100%{transform:translate(900px,-80px)}}
@keyframes vanDrive{0%{transform:translate(540px,680px)}55%{transform:translate(540px,680px)}100%{transform:translate(540px,680px)}}
@keyframes vanWiggle{0%,100%{transform:translate(540px,680px) rotate(0)}50%{transform:translate(540px,680.5px) rotate(.15deg)}}
@keyframes shimmer{0%,100%{opacity:.4}50%{opacity:.9}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

.hero-media svg #sun-disc{transform-origin:1180px 260px;animation:sunPulse 5.5s ease-in-out infinite}
.hero-media svg #wave-1{animation:waveSlide 7s linear infinite;animation-direction:alternate}
.hero-media svg #wave-2{animation:waveSlide 9s linear infinite}
.hero-media svg #shimmer-1,.hero-media svg #shimmer-2,.hero-media svg #shimmer-3{animation:shimmer 3s ease-in-out infinite}
.hero-media svg #shimmer-2{animation-delay:.7s}
.hero-media svg #shimmer-3{animation-delay:1.4s}
.hero-media svg #palm-left{transform-origin:105px 510px;animation:palmSway 6s ease-in-out infinite}
.hero-media svg #palm-right{transform-origin:1325px 470px;animation:palmSway 7s ease-in-out infinite;animation-delay:1s}
.hero-media svg #bird-flock{animation:birdFly 28s linear infinite}
.hero-media svg #van-group{animation:vanWiggle 4s ease-in-out infinite}

/* Bouton CTA gold avec balayage de lumière au hover */
.btn-gold{position:relative;overflow:hidden}
.btn-gold::after{
  content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);
  transition:left .9s var(--ease);
}
.btn-gold:hover::after{left:160%}

/* Reveal staggered pour cards */
.formula.reveal:nth-child(1){transition-delay:0s}
.formula.reveal:nth-child(2){transition-delay:.12s}
.formula.reveal:nth-child(3){transition-delay:.24s}
.svc-card.reveal:nth-child(1),.pill-eeat:nth-child(1){transition-delay:0s}
.svc-card.reveal:nth-child(2),.pill-eeat:nth-child(2){transition-delay:.08s}
.svc-card.reveal:nth-child(3),.pill-eeat:nth-child(3){transition-delay:.16s}
.svc-card.reveal:nth-child(4),.pill-eeat:nth-child(4){transition-delay:.24s}
.svc-card.reveal:nth-child(5){transition-delay:.32s}
.svc-card.reveal:nth-child(6){transition-delay:.40s}

/* Compteur EEAT : style chiffre + animation */
.pill-eeat .val{transition:color .3s}
.pill-eeat .ic{display:inline-block;animation:float 4s ease-in-out infinite}
.pill-eeat:nth-child(2) .ic{animation-delay:.5s}
.pill-eeat:nth-child(3) .ic{animation-delay:1s}
.pill-eeat:nth-child(4) .ic{animation-delay:1.5s}

/* Respect motion preferences */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}

/* ----- 22bis. UNIVERS GRID (galerie photos) ----- */
.universe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}
@media(max-width:920px){.universe-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.universe-grid{grid-template-columns:1fr}}
.universe-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-soft);
  transition:transform .35s var(--ease),box-shadow .35s;
  display:flex;flex-direction:column;
}
.universe-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift)}
.universe-card img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform 1.2s var(--ease)}
.universe-card:hover img{transform:scale(1.05)}
.universe-card figcaption{padding:22px 24px 26px;display:flex;flex-direction:column;gap:6px}
.universe-card .cat{
  display:inline-block;align-self:flex-start;
  padding:4px 12px;border-radius:var(--pill);
  background:rgba(30,136,168,.12);color:var(--accent-deep);
  font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:4px;
}
.universe-card h4{color:var(--text);font-size:1.2rem;font-family:var(--font-display);margin-top:4px}
.universe-card p{font-size:.94rem;margin-top:4px}

/* ----- 23. ACCESSIBILITÉ ----- */

/* ----- 22. ACCESSIBILITÉ ----- */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}
.skip{position:absolute;top:-100px;left:0;padding:10px 16px;background:var(--accent);color:#fff;z-index:200}
.skip:focus{top:10px;left:10px}
