:root{
  --ink:#15232B;          /* ardoise / zinc */
  --ink-soft:#34474F;
  --muted:#5E6F77;
  --brand:#C25A3A;        /* terracotta / tuile */
  --brand-deep:#A4472C;
  --zinc:#6E828D;         /* aluminium froid */
  --sand:#F7F2EA;         /* crème */
  --sand-2:#EFE7DA;
  --line:#E6DECF;
  --line-soft:#EEE7DB;
  --white:#fff;
  --radius:18px;
  --radius-lg:24px;
  --shadow:0 18px 50px -28px rgba(21,35,43,.45);
  --shadow-soft:0 10px 30px -20px rgba(21,35,43,.35);
  --maxw:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);background:var(--sand);line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4,.brandfont{font-family:'Bricolage Grotesque','Inter',sans-serif;line-height:1.08;letter-spacing:-.01em;color:var(--ink)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand-deep);
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--brand);display:inline-block;border-radius:2px}
.btn{
  display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;
  padding:14px 24px;border-radius:999px;transition:.2s ease;cursor:pointer;border:1.5px solid transparent;
}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 14px 30px -14px rgba(194,90,58,.7)}
.btn-primary:hover{background:var(--brand-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:rgba(21,35,43,.18)}
.btn-ghost:hover{border-color:var(--ink);background:rgba(21,35,43,.04)}
.btn-light{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.4);backdrop-filter:blur(4px)}
.btn-light:hover{background:rgba(255,255,255,.2)}

/* ---------- HEADER ---------- */
header.site{
  position:sticky;top:0;z-index:50;background:rgba(247,242,234,.85);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo{display:flex;align-items:center;gap:11px;font-family:'Bricolage Grotesque';font-weight:800;font-size:1.16rem;letter-spacing:-.02em}
.logo .mark{
  width:38px;height:38px;border-radius:11px;flex:0 0 38px;
  background:linear-gradient(135deg,var(--ink),var(--zinc));
  display:grid;place-items:center;color:#fff;font-size:1.05rem;box-shadow:var(--shadow-soft);
}
.logo .mark span{transform:rotate(0deg)}
.logo small{display:block;font-family:'Inter';font-weight:500;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--zinc)}
nav.menu{display:flex;align-items:center;gap:30px}
nav.menu a{font-size:.93rem;font-weight:500;color:var(--ink-soft);transition:.15s;position:relative}
nav.menu a:hover{color:var(--brand-deep)}
.header-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px}

/* ---------- HERO (bandeau pleine largeur) ---------- */
.hero{
  position:relative;min-height:470px;display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;padding:84px 0;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:url('https://images.unsplash.com/photo-1570129477492-45c003edd2be?w=1920&q=80&auto=format&fit=crop') center 55%/cover no-repeat;
}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(21,35,43,.34),rgba(18,30,37,.64))}
.hero-content{max-width:800px;padding:0 24px;color:#fff;text-shadow:0 2px 18px rgba(15,25,31,.45)}
.hero .eyebrow{color:#F0B79C;justify-content:center}
.hero h1{color:#fff;font-size:clamp(2.1rem,4vw,3.4rem);font-weight:800;margin:20px 0 0}
.hero .lead{font-size:1.12rem;color:rgba(255,255,255,.94);margin:20px auto 0;max-width:640px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;justify-content:center}

/* ---------- SECTION GENERIC ---------- */
section{padding:88px 0}
.sec-head{max-width:680px;margin-bottom:46px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(1.9rem,3vw,2.5rem);font-weight:700;margin-top:14px}
.sec-head p{color:var(--ink-soft);margin-top:16px;font-size:1.05rem}

/* ---------- UNIVERS ---------- */
.univers{background:var(--white)}
.uni-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;grid-template-rows:auto auto;gap:22px}
.uni-card{
  position:relative;border-radius:var(--radius);overflow:hidden;color:#fff;min-height:230px;
  display:flex;align-items:flex-end;box-shadow:var(--shadow-soft);transition:.25s ease;isolation:isolate;
}
.uni-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.uni-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:.5s ease}
.uni-card:hover img{transform:scale(1.05)}
.uni-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(21,35,43,.05) 30%,rgba(21,35,43,.82))}
.uni-card .body{padding:26px}
.uni-card h3{color:#fff;font-size:1.3rem;font-weight:700}
.uni-card p{font-size:.9rem;color:rgba(255,255,255,.85);margin-top:7px;max-width:90%}
.uni-card .go{margin-top:14px;font-size:.85rem;font-weight:600;color:#fff;display:inline-flex;align-items:center;gap:7px}
.uni-card.feature{grid-row:span 2;min-height:482px}
.uni-card.feature h3{font-size:1.7rem}
.uni-card.wide{grid-column:span 2}
.uni-tag{
  position:absolute;top:18px;left:18px;z-index:1;background:var(--brand);color:#fff;
  font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:999px;
}

/* ---------- EDITORIAL / QUI SOMMES-NOUS ---------- */
.editorial{background:var(--sand)}
.edi-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.edi-media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.edi-media img{width:100%;height:100%;object-fit:cover;min-height:430px}
.edi-media .float{
  position:absolute;right:-1px;bottom:-1px;background:var(--white);padding:22px 26px;border-radius:18px 0 var(--radius-lg) 0;
  box-shadow:-12px -12px 30px -22px rgba(21,35,43,.4);max-width:230px;
}
.edi-media .float b{font-family:'Bricolage Grotesque';font-size:1.05rem;display:block;margin-bottom:4px}
.edi-media .float span{font-size:.84rem;color:var(--muted)}

/* ---------- GUIDES / ARTICLES ---------- */
.guides{background:var(--white)}
.head-row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:44px}
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.art{
  background:var(--white);border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:.25s ease;
}
.art:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line)}
.art-thumb{position:relative;aspect-ratio:16/10;overflow:hidden}
.art-thumb img{width:100%;height:100%;object-fit:cover;transition:.5s ease}
.art:hover .art-thumb img{transform:scale(1.06)}
.art-cat{position:absolute;top:14px;left:14px;background:rgba(247,242,234,.92);color:var(--brand-deep);font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:6px 12px;border-radius:999px}
.art-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.art .date{font-size:.78rem;color:var(--muted);font-weight:500}
.art h3{font-size:1.15rem;font-weight:700;margin:9px 0 0;line-height:1.25}
.art p{font-size:.92rem;color:var(--ink-soft);margin-top:11px;flex:1}
.art .more{margin-top:16px;font-size:.86rem;font-weight:600;color:var(--brand-deep);display:inline-flex;align-items:center;gap:7px}

/* ---------- QUI SOMMES-NOUS ---------- */
.about{background:var(--sand)}
.about .edi-grid{align-items:center}
.about-card{background:var(--white);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:42px 40px;box-shadow:var(--shadow-soft)}
.about-card h2{font-size:clamp(1.7rem,2.6vw,2.2rem);margin-top:12px}
.about-card p{color:var(--ink-soft);margin-top:15px;font-size:1.02rem}
.about-card .about-sign{font-weight:600;color:var(--ink)}
.about-card .btn{margin-top:26px}

/* ---------- CATEGORIE (archive) ---------- */
.cat-hero{position:relative;min-height:340px;display:flex;align-items:flex-end;overflow:hidden;padding:64px 0;color:#fff}
.cat-hero::before{content:"";position:absolute;inset:0;z-index:-2;background-image:var(--cat-img,linear-gradient(135deg,#33474f,#15232b));background-size:cover;background-position:center 55%}
.cat-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(21,35,43,.4),rgba(18,30,37,.74))}
.cat-hero .eyebrow{color:#F0B79C}
.cat-crumb{font-size:.82rem;color:rgba(255,255,255,.78);margin-bottom:14px}
.cat-crumb a:hover{color:#fff;text-decoration:underline}
.cat-hero h1{color:#fff;font-size:clamp(2rem,3.6vw,3rem);font-weight:800;margin:14px 0 0;text-shadow:0 2px 18px rgba(15,25,31,.4)}
.cat-hero p{color:rgba(255,255,255,.92);max-width:660px;margin:14px 0 0;font-size:1.06rem;text-shadow:0 2px 18px rgba(15,25,31,.4)}
.empty-state{text-align:center;max-width:600px;margin:0 auto;background:var(--white);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:54px 40px;box-shadow:var(--shadow-soft)}
.empty-state .ico{font-size:2.6rem}
.empty-state h2{font-size:1.6rem;margin-top:16px}
.empty-state p{color:var(--ink-soft);margin-top:12px;font-size:1.02rem}
.empty-state .btn{margin-top:26px}

/* ---------- PAGE DE CONTENU (légales / à propos) ---------- */
.page-hero{background:var(--ink);color:#fff;padding:72px 0 58px}
.page-hero .eyebrow{color:#F0B79C}
.page-hero h1{color:#fff;font-size:clamp(2rem,3.4vw,2.8rem);font-weight:800;margin:14px 0 0}
.page-hero .sub{color:rgba(255,255,255,.72);margin-top:12px;font-size:.95rem}
.prose{max-width:760px;margin:0 auto;padding:60px 24px 88px}
.prose h2{font-size:1.5rem;font-weight:700;margin:40px 0 0}
.prose h3{font-size:1.14rem;font-weight:700;margin:26px 0 0}
.prose p{margin-top:14px;color:var(--ink-soft);font-size:1.02rem}
.prose ul{margin:14px 0 0 20px;color:var(--ink-soft)}
.prose li{margin-top:8px}
.prose a{color:var(--brand-deep);text-decoration:underline}
.prose .lead{font-size:1.12rem;color:var(--ink)}
.prose .note{background:var(--sand-2);border-left:3px solid var(--brand);padding:16px 20px;border-radius:0 12px 12px 0;margin-top:22px;font-size:.96rem;color:var(--ink-soft)}
.prose .todo{color:var(--brand-deep);font-weight:600}

/* ---------- PAGE LÉGALE SIMPLE (modèle PrimePiscine, centré) ---------- */
.legal-hero{background:var(--sand);text-align:center;padding:88px 24px 58px;border-bottom:1px solid var(--line)}
.legal-hero .bar{width:42px;height:1px;background:var(--brand);margin:0 auto 22px}
.legal-eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-deep)}
.legal-hero h1{font-family:'Fraunces',serif;font-style:italic;font-weight:600;font-size:clamp(2.3rem,5vw,3.6rem);color:var(--ink);margin:16px 0 0;letter-spacing:-.01em}
.legal-hero .sub{font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:1.3rem;color:var(--brand-deep);margin:14px 0 0}
.legal-hero .lede{max-width:580px;margin:18px auto 0;color:var(--muted);font-size:1rem}
.legal-body{max-width:680px;margin:0 auto;padding:62px 24px 92px;text-align:center}
.legal-body p{color:var(--ink-soft);font-size:1.05rem;margin-top:22px;line-height:1.75}
.legal-body p:first-child{margin-top:0}
.legal-body a{color:var(--brand-deep);text-decoration:underline}

/* ---------- PAGE À PROPOS (stylée, modèle Maisonya) ---------- */
.ap-hero{background:var(--sand);padding:78px 0 8px;text-align:center}
.ap-hero h1{font-size:clamp(2.2rem,4.4vw,3.3rem);font-weight:800;max-width:900px;margin:18px auto 0}
.ap-hero .lead{max-width:700px;margin:20px auto 0;color:var(--ink-soft);font-size:1.12rem}
.ap-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ap-gallery img{width:100%;height:280px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-soft)}
.ap-gallery.tall img{height:230px}
.edi-grid.reverse .edi-media{order:2}
.ap-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.ap-stat{text-align:center;padding:32px 18px;background:var(--white);border:1px solid var(--line-soft);border-radius:var(--radius);box-shadow:var(--shadow-soft)}
.ap-stat b{font-family:'Bricolage Grotesque';font-size:2.1rem;font-weight:800;color:var(--brand-deep);display:block;line-height:1}
.ap-stat span{font-size:.9rem;color:var(--muted);margin-top:10px;display:block}
.ap-values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ap-val{background:var(--white);border:1px solid var(--line-soft);border-radius:var(--radius);padding:32px 28px;transition:.2s ease}
.ap-val:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--line)}
.ap-val .ico{width:50px;height:50px;border-radius:13px;background:var(--sand-2);display:grid;place-items:center;font-size:1.5rem}
.ap-val h3{font-size:1.2rem;margin-top:18px}
.ap-val p{color:var(--ink-soft);margin-top:10px;font-size:.95rem}
.ap-cta{background:var(--ink);color:#fff;text-align:center;border-radius:var(--radius-lg);padding:66px 30px;box-shadow:var(--shadow)}
.ap-cta h2{color:#fff;font-size:clamp(1.8rem,3vw,2.4rem)}
.ap-cta p{color:rgba(255,255,255,.82);max-width:580px;margin:16px auto 0;font-size:1.05rem}
.ap-cta .hero-actions{margin-top:30px}
@media(max-width:1000px){
  .ap-stats{grid-template-columns:1fr 1fr}
  .ap-values{grid-template-columns:1fr}
  .ap-gallery{grid-template-columns:1fr 1fr}
  .edi-grid.reverse .edi-media{order:0}
}
@media(max-width:560px){
  .ap-stats,.ap-gallery{grid-template-columns:1fr}
}

/* ---------- FOOTER (magazine, harmonisé parc — modèle PrimePiscine) ---------- */
.mag-footer{background:var(--ink);color:rgba(255,255,255,.86);padding:84px 0 44px}
.mag-footer-top{text-align:center;padding-bottom:52px;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:48px}
.mag-footer-logo{width:64px;height:64px;margin:0 auto 22px;background:#fff;color:var(--ink);font-family:'Fraunces',serif;font-style:italic;font-weight:700;font-size:1.7rem;border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 32px rgba(0,0,0,.3)}
.mag-footer-name{font-family:'Fraunces',serif;font-style:italic;font-weight:600;font-size:1.9rem;color:#fff;margin:0 0 14px;letter-spacing:-.01em}
.mag-footer-tagline{max-width:600px;margin:0 auto;font-size:.96rem;line-height:1.65;color:rgba(255,255,255,.74)}
.mag-footer-cols{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:48px;margin-bottom:52px}
.mag-footer-col h4{font-family:'Fraunces',serif;font-style:italic;font-weight:600;font-size:1.15rem;color:#fff;margin:0 0 22px}
.mag-footer-col ul{list-style:none;margin:0;padding:0}
.mag-footer-col li{margin-bottom:11px}
.mag-footer-col a{display:inline-flex;align-items:center;gap:9px;color:rgba(255,255,255,.74);font-size:.92rem;transition:color .2s,gap .22s}
.mag-footer-col a::before{content:"\203A";color:var(--brand);font-weight:700;font-size:1rem;line-height:1}
.mag-footer-col a:hover{color:#fff;gap:14px}
.mag-footer-col a strong{color:#fff}
.mag-footer-col p{font-size:.92rem;line-height:1.6;color:rgba(255,255,255,.74);margin:0 0 10px}
.mag-footer-social{display:flex;gap:10px;margin-top:22px}
.mag-footer-social a{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.3);border-radius:999px;color:rgba(255,255,255,.88);transition:all .22s;gap:0}
.mag-footer-social a::before{content:none}
.mag-footer-social a:hover{background:#fff;color:var(--ink);border-color:#fff;transform:translateY(-2px)}
.mag-footer-social svg{width:16px;height:16px;fill:currentColor}
.mag-footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:28px;text-align:center;font-size:.82rem;color:rgba(255,255,255,.55);letter-spacing:.02em}
.mag-footer-bottom em{font-style:italic;color:rgba(255,255,255,.72)}
.mag-footer-bottom .sep{margin:0 8px;opacity:.45}
@media(max-width:900px){.mag-footer-cols{grid-template-columns:1fr 1fr;gap:36px}.mag-footer-name{font-size:1.6rem}}
@media(max-width:560px){.mag-footer-cols{grid-template-columns:1fr;gap:32px}.mag-footer-bottom .sep{display:block;height:6px;visibility:hidden}}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1000px){
  .hero{min-height:400px;padding:64px 0}
  .uni-grid{grid-template-columns:1fr 1fr}
  .uni-card.feature{grid-row:auto;min-height:240px}
  .edi-grid{grid-template-columns:1fr;gap:38px}
  .art-grid{grid-template-columns:1fr 1fr}
  nav.menu{display:none}
  .burger{display:flex}
}
@media(max-width:560px){
  .wrap{padding:0 18px}
  section{padding:60px 0}
  .uni-grid,.art-grid{grid-template-columns:1fr}
  .hero-actions .btn{flex:1;justify-content:center}
}

/* ============================================================
   PAGE BUSINESS / LANDING LEGACY (lp-*)
   Règle SEO : le bloc texte (H1+intro) est 1er dans le DOM ;
   le widget est remonté visuellement via order CSS.
   ============================================================ */
.lp-hero{position:relative;min-height:clamp(360px,40vw,460px);display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.lp-hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.lp-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(21,35,43,.18),rgba(16,26,32,.82))}
.lp-hero-content{padding:46px 0;text-shadow:0 2px 20px rgba(15,25,31,.5)}
.lp-crumb{font-size:.8rem;color:rgba(255,255,255,.82);margin-bottom:14px}
.lp-crumb a{color:rgba(255,255,255,.82)}
.lp-crumb a:hover{color:#fff;text-decoration:underline}
.lp-hero .eyebrow{color:#F0B79C}
.lp-hero h1{color:#fff;font-size:clamp(2rem,3.8vw,3rem);font-weight:800;margin:12px 0 0;max-width:880px}
/* zone intro + widget : DOM = intro puis widget ; visuel = 2 colonnes, widget mis en avant */
/* corps haut : L'essentiel encadré + widget juste en dessous, centrés */
.lp-top{background:var(--sand);padding:54px 0 72px}
.lp-body{max-width:880px;margin:0 auto;padding:0 24px}
.lp-essential{background:var(--white);border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:34px 38px}
.lp-essential .label{display:inline-flex;align-items:center;gap:8px;font-size:.74rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-deep);margin-bottom:14px}
.lp-essential .label::before{content:"●";color:var(--brand);font-size:.7rem}
.lp-intro{font-size:1.06rem;color:var(--ink-soft)}
.lp-intro p{margin-top:14px}
.lp-intro p:first-child{margin-top:0}
.lp-intro .key{list-style:none;margin:20px 0 0;padding:0;display:grid;gap:10px}
.lp-intro .key li{display:flex;gap:10px;align-items:flex-start;font-size:.98rem;color:var(--ink)}
.lp-intro .key li::before{content:"✓";color:var(--brand);font-weight:800}
.lp-widget{margin-top:26px}
/* WIDGET premium */
.wdg{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}
.wdg-head{background:linear-gradient(135deg,var(--ink),#27424d);color:#fff;padding:22px 26px}
.wdg-head .tag{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#F0B79C}
.wdg-head h3{color:#fff;font-size:1.3rem;font-weight:700;margin-top:6px}
.wdg-head p{color:rgba(255,255,255,.78);font-size:.88rem;margin-top:6px}
.wdg-body{padding:24px 26px}
.wdg-field{margin-top:18px}
.wdg-field:first-child{margin-top:0}
.wdg-field label{display:block;font-size:.86rem;font-weight:600;color:var(--ink);margin-bottom:8px}
.wdg-field .val{float:right;color:var(--brand-deep);font-weight:700}
.wdg input[type=range]{width:100%;accent-color:var(--brand);height:4px}
.wdg-seg{display:flex;gap:8px;flex-wrap:wrap}
.wdg-seg button{flex:1;min-width:72px;padding:10px 8px;border:1.5px solid var(--line);background:var(--white);border-radius:10px;font:inherit;font-size:.86rem;font-weight:600;color:var(--ink-soft);cursor:pointer;transition:.15s}
.wdg-seg button.on{background:var(--brand);border-color:var(--brand);color:#fff}
.wdg-out{margin:22px 26px 26px;background:var(--sand);border-radius:14px;padding:20px}
.wdg-out .big{font-family:'Bricolage Grotesque';font-size:1.9rem;font-weight:800;color:#059669;line-height:1}
.wdg-out .big small{font-size:.9rem;color:var(--muted);font-weight:600}
.wdg-rows{margin-top:14px;display:grid;gap:8px}
.wdg-rows div{display:flex;justify-content:space-between;font-size:.9rem;color:var(--ink-soft);padding:7px 0;border-top:1px solid var(--line)}
.wdg-rows div b{color:var(--ink)}
.wdg-note{font-size:.78rem;color:var(--muted);margin:0 26px 22px;line-height:1.5}
/* sections de contenu */
.lp-sec{padding:74px 0}
.lp-sec.alt{background:var(--white)}
.lp-sec h2{font-size:clamp(1.7rem,2.6vw,2.2rem);font-weight:700;max-width:760px}
.lp-sec .sub{color:var(--ink-soft);margin-top:14px;font-size:1.05rem;max-width:760px}
.lp-prose{max-width:780px;margin-top:18px}
.lp-prose p{color:var(--ink-soft);font-size:1.04rem;margin-top:14px}
.lp-prose h3{font-size:1.18rem;font-weight:700;margin-top:26px}
.lp-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px}
.lp-card{background:var(--white);border:1px solid var(--line-soft);border-radius:var(--radius);padding:28px 26px;transition:.2s;display:block;color:inherit}
.lp-sec.alt .lp-card{background:var(--sand)}
a.lp-card{cursor:pointer}
a.lp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--brand)}
a.lp-card .ico{transition:.2s}
a.lp-card:hover .ico{background:var(--brand);color:#fff}
.lp-card .ico{width:46px;height:46px;border-radius:12px;background:var(--sand-2);display:grid;place-items:center;font-size:1.35rem}
.lp-card h3{font-size:1.12rem;margin-top:16px}
.lp-card p{color:var(--ink-soft);font-size:.94rem;margin-top:9px}
.steps{display:grid;gap:16px;margin-top:30px;counter-reset:st}
.step{display:flex;gap:18px;background:var(--white);border:1px solid var(--line-soft);border-radius:14px;padding:22px 24px}
.lp-sec.alt .step{background:var(--sand)}
.step .n{flex:0 0 38px;width:38px;height:38px;border-radius:10px;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800}
.step h3{font-size:1.08rem}
.step p{color:var(--ink-soft);font-size:.95rem;margin-top:5px}
.faq{max-width:820px;margin-top:30px;display:grid;gap:12px}
.faq details{background:var(--white);border:1px solid var(--line-soft);border-radius:12px;padding:4px 22px}
.lp-sec.alt .faq details{background:var(--sand)}
.faq summary{cursor:pointer;font-weight:700;padding:18px 0;list-style:none;position:relative;padding-right:30px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:16px;font-size:1.4rem;color:var(--brand);font-weight:400}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--ink-soft);padding:0 0 18px;font-size:.97rem}
.link-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
.link-card{display:flex;flex-direction:column;gap:8px;background:var(--white);border:1px solid var(--line-soft);border-radius:14px;padding:22px;min-height:120px;transition:.2s}
.lp-sec.alt .link-card{background:var(--sand)}
.link-card:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:var(--shadow-soft)}
.link-card .k{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--zinc)}
.link-card h3{font-size:1.05rem}
.link-card .go{margin-top:auto;font-size:.86rem;font-weight:600;color:var(--brand-deep)}
@media(max-width:1000px){
  .lp-essential{padding:28px 24px}
  .lp-cards,.link-cards{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .lp-cards,.link-cards{grid-template-columns:1fr}
}

/* widget diagnostic (cases à cocher) */
.wdg-check{display:grid;gap:10px;margin-top:4px}
.wdg-check label{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;cursor:pointer;font-size:.92rem;color:var(--ink-soft);transition:.15s}
.wdg-check label:hover{border-color:var(--zinc)}
.wdg-check input{margin-top:3px;accent-color:var(--brand);width:17px;height:17px;flex:0 0 auto}
.wdg-check input:checked+span{color:var(--ink);font-weight:600}
.wdg-verdict{font-size:.92rem;color:var(--ink-soft);margin-top:6px}
/* section maillage image : on réutilise .art-grid/.art ; titre de section */
.rel-sec{background:var(--sand)}
.rel-sec.alt{background:var(--white)}

/* liens internes visibles dans le corps rédactionnel */
.lp-intro a,.lp-prose a,.lp-card a,.lp-essential a,.lp-sec .sub a{
  color:var(--brand-deep);text-decoration:underline;text-underline-offset:2px;
  text-decoration-thickness:1.5px;text-decoration-color:rgba(194,90,58,.45);font-weight:600;transition:.15s;
}
.lp-intro a:hover,.lp-prose a:hover,.lp-card a:hover,.lp-essential a:hover{
  color:var(--brand);text-decoration-color:var(--brand);
}

/* formulaire de contact CF7 */
.alug-form{display:grid;gap:16px;margin-top:8px}
.alug-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.alug-form input[type=text],.alug-form input[type=email],.alug-form textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;font:inherit;background:#fff}
.alug-form textarea{resize:vertical;min-height:120px}
.alug-form .wpcf7-spinner{margin-left:10px}
.wpcf7-response-output{margin-top:14px!important;border-radius:10px;font-size:.92rem}
@media(max-width:560px){.alug-form .row2{grid-template-columns:1fr}}

/* bloc SEO : 1er dans le DOM (après la nav), affiché visuellement en bas via order */
.lp-flow{display:flex;flex-direction:column}
.seo-bottom{order:60;background:var(--sand-2);border-top:1px solid var(--line);padding:54px 0}
.seo-bottom h2{font-size:1.3rem;font-weight:700;color:var(--ink-soft)}
.seo-bottom p{color:var(--muted);font-size:.96rem;margin-top:12px;max-width:920px;line-height:1.75}
.seo-bottom a{color:var(--brand-deep);text-decoration:underline}

/* réseaux sociaux dans le header (liens -> home) */
.head-social{display:flex;gap:12px;align-items:center;padding-right:14px;margin-right:4px;border-right:1px solid var(--line)}
.head-social a{color:var(--zinc);display:inline-flex;transition:.15s}
.head-social a:hover{color:var(--brand-deep);transform:translateY(-1px)}
.head-social svg{width:16px;height:16px;fill:currentColor}
@media(max-width:1000px){.head-social{display:none}}

/* page contact classique (intro + formulaire) */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:start}
.contact-intro h2{font-size:clamp(1.7rem,2.6vw,2.2rem);font-weight:700;margin-top:14px}
.contact-intro p{color:var(--ink-soft);margin-top:16px;font-size:1.04rem}
.contact-info{list-style:none;margin:24px 0 0;padding:0;display:grid;gap:12px}
.contact-info li{display:flex;gap:11px;align-items:flex-start;color:var(--ink);font-size:.98rem}
.contact-info li b{font-weight:700}
.contact-info .ic{flex:0 0 36px;width:36px;height:36px;border-radius:10px;background:var(--sand-2);display:grid;place-items:center;font-size:1.05rem}
.contact-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px 36px;box-shadow:var(--shadow-soft)}
@media(max-width:1000px){.contact-grid{grid-template-columns:1fr;gap:34px}}
