/* =========================================================
   CAMIDOGS EDUCATION — Design system
   Palette: vert #2d493d · or #e2a728 · violet #605699
   Type: Fredoka (titres) · Mulish (texte)
   ========================================================= */

:root{
  /* Brand palette */
  --green:#2d493d;
  --green-800:#22372e;
  --green-900:#1a2a23;
  --gold:#e2a728;
  --gold-600:#c8901a;
  --purple:#605699;
  --purple-700:#4d4480;
  --cream:#faf8f3;
  --cream-2:#f3eee3;
  --gray:#e7e9e7;
  --white:#ffffff;

  --ink:#26342c;          /* main text */
  --ink-soft:#5b6a61;     /* muted text */
  --line:#e4e0d4;         /* hairlines on cream */

  /* Lead accent — overridden by [data-accent] (Tweaks) */
  --lead:var(--gold);
  --lead-2:var(--purple);
  --lead-ink:#26342c;     /* text that sits on --lead */

  /* Radii — overridden by [data-radius] */
  --r-xl:34px;
  --r-lg:26px;
  --r-md:18px;
  --r-pill:999px;

  --shadow-sm:0 2px 10px rgba(38,52,44,.06);
  --shadow-md:0 18px 44px -20px rgba(38,52,44,.30);
  --shadow-lg:0 40px 80px -36px rgba(38,52,44,.42);

  --font-display:'Fredoka', system-ui, sans-serif;
  --font-body:'Mulish', system-ui, sans-serif;

  --maxw:1200px;
  --gut:clamp(20px,5vw,64px);
}

/* Accent themes (driven by Tweaks → theme.js sets data-accent on <html>) */
[data-accent="vert"]  { --lead:var(--green);  --lead-2:var(--gold);   --lead-ink:#ffffff; }
[data-accent="or"]    { --lead:var(--gold);   --lead-2:var(--purple); --lead-ink:#26342c; }
[data-accent="violet"]{ --lead:var(--purple); --lead-2:var(--gold);   --lead-ink:#ffffff; }
[data-accent="mix"]   { --lead:var(--gold);   --lead-2:var(--purple); --lead-ink:#26342c; }

[data-radius="doux"]{ --r-xl:18px; --r-lg:14px; --r-md:10px; }

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.05;margin:0;color:var(--green);letter-spacing:-.01em;}
p{margin:0;}
::selection{background:var(--gold);color:var(--green-900);}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);}
.section{padding-block:clamp(64px,9vw,120px);position:relative;}
.center{text-align:center;}

/* Eyebrow / kicker */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-display);font-weight:600;
  text-transform:uppercase;letter-spacing:.16em;font-size:13px;
  color:var(--lead);
}
.eyebrow::before{content:"";width:26px;height:2px;border-radius:2px;background:var(--lead);}
.eyebrow.is-light{color:var(--gold);}
.eyebrow.is-light::before{background:var(--gold);}

.h-display{font-size:clamp(2.4rem,5.6vw,4.4rem);line-height:.98;}
.h-section{font-size:clamp(2rem,4vw,3.1rem);}
.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--ink-soft);max-width:60ch;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--font-display);font-weight:600;font-size:1.02rem;
  padding:.92em 1.6em;border-radius:var(--r-pill);border:2px solid transparent;
  cursor:pointer;transition:transform .18s ease,box-shadow .25s ease,background .2s,color .2s;
  line-height:1;white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em;}
.btn-primary{background:var(--lead);color:var(--lead-ink);box-shadow:0 12px 26px -12px color-mix(in srgb,var(--lead) 75%,#000);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 34px -14px color-mix(in srgb,var(--lead) 75%,#000);}
.btn-dark{background:var(--green);color:#fff;}
.btn-dark:hover{transform:translateY(-2px);background:var(--green-800);}
.btn-ghost{background:transparent;border-color:var(--green);color:var(--green);}
.btn-ghost:hover{background:var(--green);color:#fff;transform:translateY(-2px);}
.btn-ghost-light{background:transparent;border-color:rgba(255,255,255,.5);color:#fff;}
.btn-ghost-light:hover{background:#fff;color:var(--green);border-color:#fff;}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;transition:background .3s,box-shadow .3s,padding .3s;}
.site-header::before{content:"";position:absolute;inset:0;background:color-mix(in srgb,var(--cream) 86%,transparent);backdrop-filter:blur(10px);opacity:0;transition:opacity .3s;}
.site-header.scrolled::before{opacity:1;}
.site-header.scrolled{box-shadow:0 1px 0 var(--line);}
.nav{position:relative;display:flex;align-items:center;justify-content:space-between;gap:18px;padding-block:16px;}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0;}
.brand img{height:46px;width:auto;}
.nav-links{display:flex;align-items:center;gap:4px;}
.nav-links a{
  font-family:var(--font-display);font-weight:500;font-size:1rem;white-space:nowrap;
  padding:.5em .95em;border-radius:var(--r-pill);color:var(--green);
  transition:background .2s,color .2s;position:relative;
}
.nav-links a:hover{background:color-mix(in srgb,var(--lead) 18%,transparent);}
.nav-links a.active{background:var(--green);color:#fff;}

/* Nav dropdown */
.nav-item{position:relative;display:flex;align-items:center;}
.nav-drop-toggle{
  display:inline-flex;align-items:center;gap:5px;cursor:pointer;
  font-family:var(--font-display);font-weight:500;font-size:1rem;white-space:nowrap;
  padding:.5em .95em;border-radius:var(--r-pill);color:var(--green);
  transition:background .2s,color .2s;
}
.nav-drop-toggle:hover{background:color-mix(in srgb,var(--lead) 18%,transparent);}
.nav-drop-toggle.active{background:var(--green);color:#fff;}
.nav-drop-toggle .caret{width:14px;height:14px;transition:transform .25s;}
.nav-item:hover .nav-drop-toggle .caret,.nav-item:focus-within .nav-drop-toggle .caret{transform:rotate(180deg);}
.dropdown-menu{
  position:absolute;top:calc(100% + 6px);left:0;min-width:236px;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);
  box-shadow:var(--shadow-md);padding:8px;display:flex;flex-direction:column;gap:2px;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s,transform .2s,visibility .2s;z-index:120;
}
.nav-item:hover .dropdown-menu,.nav-item:focus-within .dropdown-menu{opacity:1;visibility:visible;transform:none;}
.dropdown-menu a{
  font-family:var(--font-display);font-weight:500;font-size:.98rem;color:var(--green);
  padding:.66em .85em;border-radius:12px;white-space:nowrap;display:flex;flex-direction:column;gap:1px;
}
.dropdown-menu a small{font-family:var(--font-body);font-weight:500;color:var(--ink-soft);font-size:.78rem;}
.dropdown-menu a:hover{background:color-mix(in srgb,var(--lead) 16%,transparent);}
.nav-cta{display:flex;align-items:center;gap:12px;}
.nav-toggle{display:none;background:var(--green);border:none;color:#fff;width:46px;height:46px;border-radius:14px;cursor:pointer;align-items:center;justify-content:center;}
.nav-toggle svg{width:22px;height:22px;}

/* ---------- Hero ---------- */
.hero{position:relative;padding-top:clamp(32px,5vw,64px);padding-bottom:clamp(48px,7vw,96px);overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center;}
.hero-copy h1{margin-bottom:.4em;}
.hero-copy .lead{margin-bottom:1.7em;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.hero-media{position:relative;}
.hero-photo{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/4.6;}
.hero-photo img{width:100%;height:100%;object-fit:cover;}
.hero-blob{position:absolute;border-radius:50%;filter:blur(2px);opacity:.5;z-index:-1;}
.blob-a{width:340px;height:340px;background:var(--lead);top:-60px;right:-40px;opacity:.22;}
.blob-b{width:260px;height:260px;background:var(--lead-2);bottom:-50px;left:-60px;opacity:.18;}

/* floating badge cards */
.float-card{
  position:absolute;background:#fff;border-radius:var(--r-md);
  box-shadow:var(--shadow-md);padding:14px 18px;display:flex;align-items:center;gap:12px;
  font-family:var(--font-display);font-weight:600;color:var(--green);
}
.float-card small{display:block;font-family:var(--font-body);font-weight:600;color:var(--ink-soft);font-size:.78rem;letter-spacing:.02em;}
.float-card .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex-shrink:0;}
.float-1{top:24px;left:-26px;}
.float-2{bottom:30px;right:-22px;}

/* ---------- Trust strip ---------- */
.trust{background:var(--white);border-block:1px solid var(--line);}
.trust-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 30px;padding-block:26px;}
.trust-item{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:500;color:var(--green);font-size:1rem;}
.trust-item .dot{width:9px;height:9px;border-radius:50%;background:var(--lead);}

/* ---------- Section heading block ---------- */
.sec-head{max-width:62ch;margin-bottom:clamp(34px,4.5vw,56px);}
.sec-head.center{margin-inline:auto;}
.sec-head .eyebrow{margin-bottom:16px;}
.sec-head p{margin-top:14px;}

/* ---------- Service cards (home) ---------- */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.4vw,28px);}
.card{
  position:relative;background:#fff;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);
  display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.card-media{aspect-ratio:16/10;overflow:hidden;}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.card:hover .card-media img{transform:scale(1.05);}
.card-body{padding:24px 26px 28px;display:flex;flex-direction:column;gap:10px;flex:1;}
.card-num{font-family:var(--font-display);font-weight:600;color:var(--lead);font-size:.85rem;letter-spacing:.14em;}
.card h3{font-size:1.5rem;}
.card p{color:var(--ink-soft);font-size:1rem;}
.card-link{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:600;color:var(--green);padding-top:8px;}
.card-link svg{width:18px;height:18px;transition:transform .25s;}
.card:hover .card-link svg{transform:translateX(4px);}
.card.wide{grid-column:1/-1;flex-direction:row;align-items:stretch;}
.card.wide .card-media{flex:0 0 42%;aspect-ratio:auto;}
.card.wide .card-media img{height:100%;}
.card.wide .card-body{justify-content:center;padding:30px clamp(26px,3vw,46px);}
@media (max-width:760px){.card.wide{flex-direction:column;}.card.wide .card-media{flex:auto;aspect-ratio:16/10;}}

/* ---------- Blog ---------- */
.post-cat{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:600;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--lead);}
.post-cat::before{content:"";width:18px;height:2px;border-radius:2px;background:var(--lead);}
.post-meta{display:flex;align-items:center;gap:10px;margin-top:auto;padding-top:10px;color:var(--ink-soft);font-size:.86rem;}
.post-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--ink-soft);}
.card.wide .post-cat{margin-bottom:4px;}
.card.wide h3{font-size:clamp(1.6rem,2.6vw,2.1rem);}
.newsletter{background:var(--green);color:#fff;border-radius:var(--r-xl);padding:clamp(34px,5vw,56px);position:relative;overflow:hidden;display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center;}
.newsletter h2{color:#fff;}
.newsletter p{color:rgba(255,255,255,.84);margin-top:10px;}
.newsletter .paw-wm{position:absolute;width:240px;opacity:.08;right:-40px;bottom:-50px;}
.news-form{display:flex;gap:10px;flex-wrap:wrap;}
.news-form input{flex:1;min-width:200px;font-family:var(--font-body);font-size:1rem;padding:13px 18px;border-radius:var(--r-pill);border:none;background:rgba(255,255,255,.95);color:var(--ink);}
.news-form input:focus{outline:none;box-shadow:0 0 0 4px color-mix(in srgb,var(--gold) 50%,transparent);}
@media (max-width:760px){.newsletter{grid-template-columns:1fr;}}

/* ---------- Approach (split) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center;}
.split.rev .split-media{order:2;}
.split-media{position:relative;}
.split-media img{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow-md);object-fit:cover;}
.split-media.tall img{aspect-ratio:4/4.7;}
.feature-list{display:grid;gap:18px;margin-top:26px;}
.feature{display:flex;gap:16px;align-items:flex-start;}
.feature .ic{width:48px;height:48px;border-radius:14px;flex-shrink:0;display:grid;place-items:center;background:color-mix(in srgb,var(--lead) 16%,#fff);}
.feature .ic svg{width:24px;height:24px;color:var(--green);}
.feature h4{font-size:1.18rem;margin-bottom:3px;}
.feature p{color:var(--ink-soft);font-size:1rem;}

/* ---------- Stats band ---------- */
.band-green{background:var(--green);color:#fff;position:relative;overflow:hidden;}
.band-green h2,.band-green h3{color:#fff;}
.band-green .paw-wm{position:absolute;width:360px;opacity:.07;right:-40px;bottom:-80px;pointer-events:none;}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;z-index:1;}
.stat{text-align:center;}
.stat .num{font-family:var(--font-display);font-weight:700;font-size:clamp(2.6rem,5vw,3.7rem);color:var(--gold);line-height:1;}
.stat .lbl{margin-top:8px;font-family:var(--font-display);font-weight:500;letter-spacing:.04em;color:rgba(255,255,255,.86);font-size:.95rem;text-transform:uppercase;}
.stat+.stat{border-left:1px solid rgba(255,255,255,.16);}

/* ---------- Testimonials ---------- */
.reviews-head{display:flex;flex-wrap:wrap;gap:20px;align-items:flex-end;justify-content:space-between;margin-bottom:38px;}
.google-badge{display:inline-flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:10px 18px;box-shadow:var(--shadow-sm);font-family:var(--font-display);font-weight:600;color:var(--green);}
.stars{color:var(--gold);letter-spacing:2px;font-size:1.05rem;}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px;}
.review .stars{font-size:1rem;}
.review p{color:var(--ink);font-size:1.05rem;}
.review .who{display:flex;align-items:center;gap:12px;margin-top:auto;}
.review .av{width:44px;height:44px;border-radius:50%;background:color-mix(in srgb,var(--lead) 22%,#fff);display:grid;place-items:center;font-family:var(--font-display);font-weight:600;color:var(--green);}
.review .who b{font-family:var(--font-display);color:var(--green);display:block;}
.review .who small{color:var(--ink-soft);}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--green) 0%,var(--green-800) 100%);color:#fff;border-radius:var(--r-xl);padding:clamp(40px,6vw,72px);text-align:center;}
.cta-band h2{color:#fff;margin-bottom:14px;}
.cta-band p{color:rgba(255,255,255,.85);max-width:54ch;margin:0 auto 28px;}
.cta-band .paw-wm{position:absolute;width:300px;opacity:.09;left:-50px;top:-60px;}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;background:var(--cream-2);overflow:hidden;padding-top:clamp(40px,6vw,80px);padding-bottom:clamp(48px,7vw,88px);}
.page-hero .paw-wm{position:absolute;width:300px;opacity:.08;right:2%;top:-40px;}
.page-hero .lead{margin-top:16px;}
.breadcrumb{font-family:var(--font-display);font-weight:500;color:var(--ink-soft);font-size:.95rem;margin-bottom:18px;}
.breadcrumb a:hover{color:var(--lead);}

/* ---------- Service detail rows ---------- */
.srow{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center;}
.srow+.srow{margin-top:clamp(56px,7vw,104px);}
.srow.rev .srow-media{order:2;}
.srow-media{position:relative;}
.srow-media img{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow-md);aspect-ratio:5/4;object-fit:cover;}
.srow-media .tag{position:absolute;top:16px;left:16px;background:#fff;border-radius:var(--r-pill);padding:8px 16px;font-family:var(--font-display);font-weight:600;color:var(--green);box-shadow:var(--shadow-sm);}
.srow-body h2{font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:14px;}
.srow-body .price{display:inline-block;margin-top:6px;font-family:var(--font-display);font-weight:600;color:var(--lead);}
.ticks{display:grid;gap:11px;margin:22px 0 26px;}
.tick{display:flex;gap:12px;align-items:flex-start;color:var(--ink);}
.tick svg{width:22px;height:22px;flex-shrink:0;color:var(--lead);margin-top:2px;}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step;}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 24px;box-shadow:var(--shadow-sm);position:relative;}
.step .n{width:46px;height:46px;border-radius:14px;background:var(--lead);color:var(--lead-ink);font-family:var(--font-display);font-weight:700;font-size:1.3rem;display:grid;place-items:center;margin-bottom:16px;}
.step h4{font-size:1.2rem;margin-bottom:6px;}
.step p{color:var(--ink-soft);font-size:.98rem;}

/* ---------- About ---------- */
.about-hero{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(32px,5vw,64px);align-items:center;}
.about-portrait{position:relative;}
.about-portrait img{width:100%;border-radius:var(--r-xl);box-shadow:var(--shadow-md);aspect-ratio:4/4.8;object-fit:cover;}
.cred-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:8px;}
.cred{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:20px;box-shadow:var(--shadow-sm);}
.cred b{font-family:var(--font-display);color:var(--green);display:block;font-size:1.05rem;}
.cred small{color:var(--ink-soft);}
.mentors{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.chip{font-family:var(--font-display);font-weight:500;background:#fff;border:1px solid var(--line);color:var(--green);padding:.5em 1em;border-radius:var(--r-pill);box-shadow:var(--shadow-sm);}

/* timeline */
.timeline{display:grid;gap:0;margin-top:10px;}
.tl{display:grid;grid-template-columns:120px 1fr;gap:24px;padding:22px 0;border-top:1px solid var(--line);align-items:start;}
.tl:last-child{border-bottom:1px solid var(--line);}
.tl .yr{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--lead);}
.tl .yr-count{display:block;font-family:var(--font-body);font-weight:600;font-size:.78rem;color:var(--ink-soft);letter-spacing:.04em;margin-top:2px;}
.tl-list{list-style:none;display:grid;gap:9px;margin:0;padding:0;}
.tl-list li{position:relative;padding-left:20px;color:var(--ink-soft);}
.tl-list li::before{content:"";position:absolute;left:0;top:11px;width:7px;height:7px;border-radius:50%;background:var(--lead);}
.tl-list li b{color:var(--green);font-family:var(--font-display);font-weight:500;}
.tl-list li .en-cours{font-family:var(--font-display);font-weight:600;font-size:.72rem;letter-spacing:.06em;color:var(--purple);background:color-mix(in srgb,var(--purple) 14%,#fff);padding:.15em .6em;border-radius:var(--r-pill);margin-left:6px;}
.tl p{color:var(--ink-soft);}
.tl h4{font-size:1.15rem;margin-bottom:4px;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,60px);align-items:start;}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(26px,3.4vw,40px);box-shadow:var(--shadow-md);}
.field{margin-bottom:18px;}
.field label{display:block;font-family:var(--font-display);font-weight:500;color:var(--green);margin-bottom:7px;font-size:.98rem;}
.field input,.field textarea,.field select{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  padding:13px 16px;border:1.5px solid var(--line);border-radius:14px;background:var(--cream);
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--lead);box-shadow:0 0 0 4px color-mix(in srgb,var(--lead) 20%,transparent);background:#fff;}
.field textarea{min-height:130px;resize:vertical;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-note{font-size:.86rem;color:var(--ink-soft);margin-top:6px;}
.form-success{display:none;text-align:center;padding:20px;background:color-mix(in srgb,var(--green) 8%,#fff);border:1px solid color-mix(in srgb,var(--green) 22%,#fff);border-radius:var(--r-md);color:var(--green);font-family:var(--font-display);font-weight:500;}
.form-success.show{display:block;}

.info-card{background:var(--green);color:#fff;border-radius:var(--r-lg);padding:clamp(26px,3.4vw,40px);position:relative;overflow:hidden;}
.info-card h3{color:#fff;}
.info-card .paw-wm{position:absolute;width:240px;opacity:.08;right:-50px;bottom:-60px;}
.info-item{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-top:1px solid rgba(255,255,255,.14);}
.info-item:first-of-type{border-top:none;}
.info-item .ic{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.12);display:grid;place-items:center;flex-shrink:0;}
.info-item .ic svg{width:20px;height:20px;color:var(--gold);}
.info-item b{font-family:var(--font-display);display:block;}
.info-item span,.info-item a{color:rgba(255,255,255,.82);}
.info-item a:hover{color:var(--gold);}
.zone-chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:14px;}
.zone-chips .z{background:rgba(255,255,255,.12);border-radius:var(--r-pill);padding:.45em .95em;font-family:var(--font-display);font-weight:500;font-size:.92rem;}

/* FAQ */
.faq{max-width:820px;margin-inline:auto;}
.qa{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow-sm);}
.qa summary{cursor:pointer;list-style:none;padding:20px 24px;font-family:var(--font-display);font-weight:600;color:var(--green);font-size:1.12rem;display:flex;justify-content:space-between;gap:16px;align-items:center;}
.qa summary::-webkit-details-marker{display:none;}
.qa summary .pl{width:24px;height:24px;flex-shrink:0;position:relative;transition:transform .25s;}
.qa summary .pl::before,.qa summary .pl::after{content:"";position:absolute;background:var(--lead);border-radius:2px;}
.qa summary .pl::before{top:11px;left:2px;right:2px;height:2px;}
.qa summary .pl::after{left:11px;top:2px;bottom:2px;width:2px;}
.qa[open] summary .pl{transform:rotate(45deg);}
.qa .ans{padding:0 24px 22px;color:var(--ink-soft);}

/* ---------- Footer ---------- */
.site-footer{background:var(--green-900);color:rgba(255,255,255,.78);padding-block:clamp(48px,6vw,72px) 30px;position:relative;overflow:hidden;}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:16px;font-family:var(--font-display);}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px;}
.footer-brand .logo-chip{background:#fff;border-radius:var(--r-md);padding:14px 16px;display:inline-block;margin-bottom:18px;}
.footer-brand .logo-chip img{height:42px;}
.footer-brand p{font-size:.98rem;max-width:34ch;}
.flinks{display:grid;gap:10px;}
.flinks a:hover{color:var(--gold);}
.footer-contact a:hover{color:var(--gold);}
.lang-row{display:flex;gap:8px;margin-top:14px;}
.lang-row span{font-family:var(--font-display);font-weight:600;font-size:.82rem;letter-spacing:.06em;border:1px solid rgba(255,255,255,.2);border-radius:var(--r-pill);padding:.3em .8em;color:rgba(255,255,255,.7);}
.footer-bottom{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center;margin-top:42px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);font-size:.86rem;}
.footer-paw{position:absolute;width:280px;opacity:.05;right:-30px;bottom:-70px;}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}
.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-media{max-width:520px;margin-inline:auto;}
  .split,.srow,.about-hero,.contact-grid{grid-template-columns:1fr;}
  .split.rev .split-media,.srow.rev .srow-media{order:0;}
  .stats{grid-template-columns:repeat(2,1fr);gap:30px 16px;}
  .stat:nth-child(3){border-left:none;}
  .reviews{grid-template-columns:1fr;}
  .steps{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}
}
@media (max-width:760px){
  body{font-size:17px;}
  .nav-links,.nav-cta .btn{display:none;}
  .nav-toggle{display:inline-flex;}
  .nav-cta{display:block;}
  .site-header.nav-open .nav-links{
    display:flex;position:absolute;top:100%;left:var(--gut);right:var(--gut);
    flex-direction:column;align-items:stretch;background:#fff;border:1px solid var(--line);
    border-radius:var(--r-lg);padding:14px;gap:6px;box-shadow:var(--shadow-md);
  }
  .site-header.nav-open .nav-links a{text-align:center;padding:.8em;}
  .site-header.nav-open .nav-item{flex-direction:column;align-items:stretch;}
  .site-header.nav-open .nav-drop-toggle{justify-content:center;padding:.8em;}
  .site-header.nav-open .nav-drop-toggle .caret{display:none;}
  .site-header.nav-open .dropdown-menu{
    position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:none;padding:2px 0 6px;background:transparent;
  }
  .site-header.nav-open .dropdown-menu a{text-align:center;align-items:center;background:color-mix(in srgb,var(--lead) 8%,transparent);}
  .cards{grid-template-columns:1fr;}
  .field-row{grid-template-columns:1fr;}
  .stat+.stat{border-left:none;}
  .stats{gap:26px;}
}
@media (max-width:480px){
  .stats{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .float-card{display:none;}
}

/* =========================================================
   FEEL TWEAKS (Prestations) — compound, expressive controls
   Driven by data-mood / data-rhythm / data-photo on <html>.
   Defaults (naturel / standard / naturel) = base look.
   ========================================================= */

/* ---- Ambiance : Tendre — doux, chaleureux, enveloppant ---- */
html[data-mood="tendre"]{
  --cream:#fbf8f1; --cream-2:#f6efe1;
  --r-xl:42px; --r-lg:32px; --r-md:24px;
  --ink-soft:#6c796f;
  --shadow-sm:0 3px 16px rgba(38,52,44,.05);
  --shadow-md:0 28px 58px -26px rgba(38,52,44,.20);
}
html[data-mood="tendre"] .lead{line-height:1.78;}
html[data-mood="tendre"] .srow-media .tag{background:color-mix(in srgb,var(--lead) 22%,#fff);color:var(--green);box-shadow:var(--shadow-sm);}
html[data-mood="tendre"] .eyebrow{letter-spacing:.13em;}
html[data-mood="tendre"] .step .n{border-radius:18px;}

/* ---- Ambiance : Vif — punchy, énergique, contrasté ---- */
html[data-mood="vif"]{
  --r-xl:20px; --r-lg:14px; --r-md:10px;
  --shadow-md:0 22px 44px -18px rgba(38,52,44,.44);
}
html[data-mood="vif"] .srow-media .tag{background:var(--lead);color:var(--lead-ink);box-shadow:0 8px 20px -8px color-mix(in srgb,var(--lead) 70%,#000);}
html[data-mood="vif"] .eyebrow{letter-spacing:.22em;font-weight:700;}
html[data-mood="vif"] .srow-body .eyebrow::before,html[data-mood="vif"] .sec-head .eyebrow::before{width:34px;height:3px;}
html[data-mood="vif"] .tick svg{color:var(--lead);}
html[data-mood="vif"] .card,html[data-mood="vif"] .srow-media img{transition:transform .3s ease,box-shadow .3s ease;}
html[data-mood="vif"] .srow-media img{box-shadow:var(--shadow-md);}

/* ---- Rythme : Aéré — respiration éditoriale ---- */
html[data-rhythm="aere"] .section{padding-block:clamp(92px,13vw,170px);}
html[data-rhythm="aere"] .srow{gap:clamp(40px,6vw,92px);}
html[data-rhythm="aere"] .srow+.srow{margin-top:clamp(84px,11vw,156px);}
html[data-rhythm="aere"] .sec-head{margin-bottom:clamp(44px,6vw,74px);}
html[data-rhythm="aere"] .lead{font-size:1.16rem;}
html[data-rhythm="aere"] .steps{gap:30px;}

/* ---- Rythme : Dense — efficace, riche en contenu ---- */
html[data-rhythm="dense"] .section{padding-block:clamp(40px,6vw,72px);}
html[data-rhythm="dense"] .srow{gap:clamp(22px,3vw,46px);}
html[data-rhythm="dense"] .srow+.srow{margin-top:clamp(36px,5vw,60px);}
html[data-rhythm="dense"] .ticks{gap:8px;}
html[data-rhythm="dense"] .lead{font-size:1rem;}

/* ---- Photos : overlay plumbing ---- */
html[data-photo="chaud"] .srow-media,html[data-photo="signature"] .srow-media{position:relative;}
html[data-photo] .srow-media .tag{z-index:2;}
html[data-photo="chaud"] .srow-media img:not([style*="aspect-ratio:3"]),
html[data-photo="signature"] .srow-media img:not([style*="aspect-ratio:3"]){position:relative;}

/* ---- Photos : Chaud — grade chaleureux ---- */
html[data-photo="chaud"] .srow-media img{filter:saturate(1.14) contrast(1.03) brightness(1.02);}
html[data-photo="chaud"] .srow-media::after{
  content:"";position:absolute;inset:0;border-radius:var(--r-lg);pointer-events:none;z-index:1;
  background:linear-gradient(165deg,rgba(226,167,40,.16),rgba(96,86,153,.05) 60%,transparent);
  mix-blend-mode:multiply;
}

/* ---- Photos : Signature — duotone vert de marque ---- */
html[data-photo="signature"] .srow-media img{filter:grayscale(.55) contrast(1.08) brightness(1.03);}
html[data-photo="signature"] .srow-media::after{
  content:"";position:absolute;inset:0;border-radius:var(--r-lg);pointer-events:none;z-index:1;
  background:color-mix(in srgb,var(--green) 42%,transparent);
  mix-blend-mode:multiply;
}
