/* =========================================================
   WePositif — production styles
   ========================================================= */
:root{
  /* brand */
  --teal:          #0F4C5C;
  --teal-700:      #0a3845;
  --teal-300:      #2a6f80;
  --mint:          #7AC6B5;
  --mint-ink:      #2f8a76;
  --lavender:      #B7A4D6;
  --mustard:       #F4C430;
  --pink:          #F4B6C7;

  /* pastels (card backgrounds — softer than brand swatches) */
  --lav-soft:      #E7DDF2;
  --mint-soft:     #D4EDE5;
  --pink-soft:     #FBDDE4;
  --mustard-soft:  #FBE8A6;
  --teal-soft:     #DDECEE;

  /* surfaces */
  --paper:         #F8F4F0;
  --paper-2:       #F1ECE3;
  --ink:           #1f2a30;
  --ink-2:         #4a5a62;
  --ink-3:         #7a8a92;
  --rule:          rgba(15,76,92,.10);

  /* type */
  --serif: "Fraunces", "DM Serif Display", Georgia, serif;
  --sans:  "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --script:"Caveat", cursive;

  --r-sm: 14px;
  --r-md: 20px;
  --r-lg: 28px;
  --r-xl: 36px;
  --shadow-1: 0 2px 8px rgba(15,76,92,.04), 0 12px 30px rgba(15,76,92,.06);
  --shadow-2: 0 8px 20px rgba(15,76,92,.08), 0 22px 60px rgba(15,76,92,.10);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}

/* ---------- container ---------- */
.container{max-width:1180px;margin:0 auto;padding:0 28px}
@media (max-width:640px){.container{padding:0 20px}}

/* ---------- typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;color:var(--teal);letter-spacing:-.01em;line-height:1.1;margin:0}
.eyebrow{
  font-family:var(--sans);
  font-size:12px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--mint-ink);
}
.script{font-family:var(--script);font-weight:600;color:var(--mint-ink)}
.lead{color:var(--ink-2);font-size:17px;max-width:60ch}
.muted{color:var(--ink-3)}
.small{font-size:13px;color:var(--ink-3)}

.h-display{font-size:clamp(40px, 5.4vw, 64px);font-weight:500}
.h-1{font-size:clamp(34px, 4vw, 48px);font-weight:500}
.h-2{font-size:clamp(28px, 3.2vw, 38px);font-weight:500}
.h-3{font-size:22px;font-weight:600}
.h-4{font-size:18px;font-weight:600}

.accent-mint{color:var(--mint-ink)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  border:1.5px solid transparent;
  border-radius:999px;
  padding:13px 22px;
  font-family:var(--sans);font-weight:500;font-size:15px;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
  white-space:nowrap;
}
.btn .arrow{transition:transform .18s ease}
.btn:hover .arrow{transform:translateX(3px)}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-700);transform:translateY(-1px);box-shadow:0 10px 24px rgba(15,76,92,.18)}
.btn-outline{background:transparent;color:var(--teal);border-color:var(--teal)}
.btn-outline:hover{background:var(--teal);color:#fff;transform:translateY(-1px)}
.btn-mustard{background:var(--mustard);color:var(--teal)}
.btn-mustard:hover{background:#f6d055;transform:translateY(-1px);box-shadow:0 10px 24px rgba(244,196,48,.35)}
.btn-ghost-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost-white:hover{background:#fff;color:var(--teal);border-color:#fff}
.btn-sm{padding:9px 16px;font-size:14px}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(248,244,240,.85);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  transition:box-shadow .25s ease, background .25s ease;
}
.site-header.scrolled{
  background:rgba(248,244,240,.95);
  box-shadow:0 1px 0 var(--rule), 0 12px 24px -16px rgba(15,76,92,.18);
}
.site-header .row{
  display:flex;align-items:center;gap:24px;
  padding:14px 0;
}
.brand{display:inline-flex;align-items:center;gap:10px;color:var(--teal);font-weight:700;font-size:20px;letter-spacing:-.01em}
.brand-icons{display:inline-flex;gap:6px;align-items:center;margin-right:4px}
.brand-icons span{width:14px;height:14px;display:inline-block;border-radius:3px}
.brand-icons .puzzle{background:var(--mustard);clip-path:polygon(0 0,70% 0,70% 30%,100% 30%,100% 70%,70% 70%,70% 100%,0 100%)}
.brand-icons .rainbow{background:linear-gradient(180deg, var(--mint) 0 33%, var(--mustard) 33% 66%, var(--pink) 66% 100%);border-radius:14px 14px 0 0;height:10px;width:14px;align-self:center}
.brand-icons .heart{background:var(--pink);clip-path:path('M7 12 L1.5 6.5 a3 3 0 0 1 5-3 a3 3 0 0 1 5 3 z');-webkit-clip-path:path('M7 12 L1.5 6.5 a3 3 0 0 1 5-3 a3 3 0 0 1 5 3 z')}
.nav{display:flex;gap:6px;margin-left:auto}
.nav a{
  padding:8px 16px;border-radius:999px;
  font-size:14px;color:var(--ink-2);
  transition:color .15s ease, background .15s ease;
}
.nav a:hover{color:var(--teal)}
.nav a.current{background:var(--mint-soft);color:var(--teal);font-weight:500}
.header-cta{margin-left:auto}
.menu-btn{display:none;border:none;background:transparent;padding:6px;margin-left:auto;color:var(--teal)}
.menu-btn svg{width:26px;height:26px}

@media (max-width:1024px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--paper);padding:14px 20px 22px;gap:4px;border-top:1px solid var(--rule);box-shadow:0 18px 30px -18px rgba(15,76,92,.2)}
  .nav.open{display:flex}
  .nav a{padding:12px 14px;border-radius:12px;font-size:16px}
  .menu-btn{display:inline-flex;order:3}
  .header-cta{display:none}
  .site-header .row{padding:12px 0}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  padding:60px 0 90px;
  overflow:hidden;
}
.hero .blob{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;z-index:0}
.hero .blob.peach{background:#FCD9C8;width:520px;height:520px;left:-160px;bottom:-160px;opacity:.85}
.hero .blob.pink{background:#F4B6C7;width:380px;height:380px;left:-60px;bottom:-220px;opacity:.55}
.hero .blob.mint{background:#BFE6D9;width:380px;height:380px;right:-120px;top:60px;opacity:.7}
.hero .blob.lav{background:#D7C8EE;width:280px;height:280px;right:120px;top:-100px;opacity:.45}

.hero-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns: 1.05fr .95fr;gap:60px;align-items:center;
}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;
  border-radius:999px;
  padding:8px 14px 8px 10px;
  box-shadow:0 1px 0 var(--rule), 0 8px 24px -10px rgba(15,76,92,.18);
  font-size:13px;color:var(--ink-2);
  font-weight:500;
}
.hero-badge .dot{width:18px;height:18px;border-radius:50%;background:var(--mustard);display:inline-flex;align-items:center;justify-content:center;color:var(--teal);font-size:11px}

.hero h1{
  font-family:var(--serif);
  font-size:clamp(40px, 5.2vw, 64px);
  font-weight:500;
  line-height:1.06;
  letter-spacing:-.015em;
  margin:22px 0 22px;
}
.hero h1 .em{color:var(--mint-ink);font-style:italic;font-weight:500}
.hero .sub{font-size:16.5px;color:var(--ink-2);max-width:48ch;line-height:1.65}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero .trust{margin-top:14px;color:var(--ink-3);font-size:13px}

.hero-photo{
  position:relative;
  justify-self:end;
  width:min(100%, 460px);
}
.hero-photo .frame{
  position:relative;
  border-radius:200px 200px 24px 24px / 220px 220px 24px 24px;
  overflow:hidden;
  aspect-ratio: 4/5;
  background:#eee;
  box-shadow: 0 30px 60px -30px rgba(15,76,92,.35);
}
.hero-photo .frame img{
  width:100%;height:100%;object-fit:cover;object-position:center 15%;
}
.hero-photo .float-badge{
  position:absolute;
  left:-18px;bottom:32px;
  background:#fff;
  border-radius:14px;
  padding:10px 14px 10px 12px;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 1px 0 var(--rule), 0 14px 30px -10px rgba(15,76,92,.2);
}
.hero-photo .float-badge .ico{
  width:32px;height:32px;border-radius:10px;
  background:var(--pink-soft);display:inline-flex;align-items:center;justify-content:center;color:var(--teal);
}
.hero-photo .float-badge .ico svg{width:18px;height:18px}
.hero-photo .float-badge b{display:block;font-size:13px;color:var(--teal);font-weight:600}
.hero-photo .float-badge span{font-size:12px;color:var(--ink-3)}

.hero-chips{
  position:absolute;right:0;bottom:-58px;
  display:flex;flex-direction:column;gap:8px;align-items:flex-start;
}
.hero-chip{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2)}
.hero-chip .ic{width:22px;height:22px;border-radius:50%;background:var(--paper-2);display:inline-flex;align-items:center;justify-content:center;color:var(--teal)}
.hero-chip .ic svg{width:13px;height:13px}

@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-photo{justify-self:center}
  .hero-chips{position:static;flex-direction:row;margin-top:30px}
  .hero{padding:40px 0 70px}
}

/* ---------- sections / cards ---------- */
section{padding:80px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 44px}
.section-head .eyebrow{display:block;margin-bottom:12px}
.section-head h2{margin-bottom:14px}
.section-head .lead{margin:0 auto;color:var(--ink-2);max-width:60ch}

.card{
  background:#fff;
  border-radius:var(--r-md);
  padding:28px;
  box-shadow:var(--shadow-1);
  transition:transform .25s ease, box-shadow .25s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.card h3{margin-bottom:8px}
.card p{color:var(--ink-2);margin:0}
.card.lav{background:var(--lav-soft)}
.card.mint{background:var(--mint-soft)}
.card.pink{background:var(--pink-soft)}
.card.mustard{background:var(--mustard-soft)}
.card.teal-soft{background:var(--teal-soft)}
.card.teal-solid{background:var(--teal);color:#fff}
.card.teal-solid h3, .card.teal-solid h4{color:#fff}
.card.teal-solid p{color:rgba(255,255,255,.82)}
.card.mustard-solid{background:var(--mustard);color:var(--teal)}
.card.lav-solid{background:var(--lavender);color:var(--teal)}
.card.pink-solid{background:var(--pink);color:var(--teal)}

/* grids */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){
  .grid-3,.grid-4{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
}
@media (max-width:560px){
  .grid-3,.grid-4{grid-template-columns:1fr}
}

/* pain cards (Pour qui) */
.pain{
  background:var(--lav-soft);
  border-radius:var(--r-md);
  padding:22px;
  font-size:15px;
  color:var(--teal-700);
  line-height:1.55;
  transition:transform .2s ease, box-shadow .2s ease;
}
.pain:hover{transform:translateY(-2px);box-shadow:var(--shadow-1)}
.pain.lav{background:var(--lav-soft)}
.pain.mint{background:var(--mint-soft)}
.pain.pink{background:var(--pink-soft)}
.pain.mustard{background:var(--mustard-soft)}
.pain.teal-soft{background:var(--teal-soft)}

/* service tiles (4) */
.tile{
  border-radius:var(--r-lg);
  padding:30px 28px;
  min-height:300px;
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.tile .ic{
  width:42px;height:42px;border-radius:12px;
  background:rgba(255,255,255,.18);
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.tile.teal{background:var(--teal);color:#fff}
.tile.teal h3, .tile.teal .arrow-link{color:#fff}
.tile.teal .ic{background:rgba(255,255,255,.12)}
.tile.mustard{background:var(--mustard);color:var(--teal)}
.tile.mustard .ic{background:rgba(15,76,92,.10)}
.tile.lav{background:var(--lavender);color:var(--teal)}
.tile.lav .ic{background:rgba(255,255,255,.35)}
.tile.pink{background:var(--pink);color:var(--teal)}
.tile.pink .ic{background:rgba(255,255,255,.45)}
.tile h3{margin-bottom:8px;font-size:21px}
.tile p{font-size:14.5px;line-height:1.55;margin:0 0 18px;color:inherit;opacity:.92}
.arrow-link{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:600;font-size:14.5px;
  color:var(--teal);
}
.arrow-link .arrow{transition:transform .18s ease}
.arrow-link:hover .arrow{transform:translateX(3px)}

/* announcement */
.announce{
  margin:30px auto 0;max-width:920px;
  background:var(--pink-soft);
  border-radius:999px;
  padding:14px 22px;
  display:flex;align-items:center;gap:14px;
  font-size:14.5px;color:var(--teal);
}
.announce .star{
  width:28px;height:28px;border-radius:50%;
  background:#fff;display:inline-flex;align-items:center;justify-content:center;color:var(--mustard);flex-shrink:0;
}
.announce a{margin-left:auto;color:var(--teal);font-weight:600;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
@media (max-width:640px){.announce{border-radius:18px;flex-wrap:wrap}.announce a{margin-left:0}}

/* testimonials */
.testi{background:#fff;border-radius:var(--r-md);padding:24px;box-shadow:var(--shadow-1);min-height:170px}
.testi .stars{color:var(--mustard);font-size:16px;letter-spacing:2px;margin-bottom:12px}
.testi blockquote{font-family:var(--serif);font-style:italic;font-size:17px;color:var(--teal);margin:0 0 16px;font-weight:500}
.testi .who{font-size:13px;color:var(--ink-3);border-top:1px solid var(--rule);padding-top:12px}

/* final CTA */
.final{
  background:var(--teal);
  color:#fff;
  border-radius:var(--r-xl);
  padding:64px 40px;
  text-align:center;
  position:relative;overflow:hidden;
  box-shadow:0 30px 60px -30px rgba(15,76,92,.5);
}
.final h2{color:#fff;font-size:clamp(28px,3.6vw,42px);font-weight:500;max-width:18ch;margin:0 auto 14px}
.final p{color:rgba(255,255,255,.85);max-width:54ch;margin:0 auto}
.final .cta-row{display:flex;justify-content:center;gap:14px;margin-top:28px;flex-wrap:wrap}
.final .deco{position:absolute;pointer-events:none;opacity:.10}
.final .deco.rainbow{right:-30px;top:30px;width:200px;height:200px}
.final .deco.dots{left:30px;bottom:30px;width:140px;height:140px}
.final .small-note{margin-top:18px;color:rgba(255,255,255,.7);font-size:13px}

/* footer */
.site-footer{
  margin-top:80px;
  background:var(--paper-2);
  padding:60px 0 26px;
}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:40px}
.footer-grid h4{font-family:var(--serif);font-size:18px;color:var(--teal);margin-bottom:14px;font-weight:600}
.footer-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14.5px;color:var(--ink-2)}
.footer-grid a{color:var(--ink-2)}
.footer-grid a:hover{color:var(--teal)}
.footer-blurb{color:var(--ink-2);font-size:14.5px;margin:12px 0 0;max-width:32ch;line-height:1.6}
.footer-tag{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mint-ink);margin-top:6px}
.footer-bar{
  text-align:center;color:var(--ink-3);font-size:13px;
  margin-top:40px;padding-top:24px;border-top:1px solid var(--rule);
}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* floating WhatsApp */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:60;
  width:56px;height:56px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 30px -8px rgba(37,211,102,.55), 0 4px 10px rgba(0,0,0,.1);
  transition:transform .2s ease, box-shadow .2s ease;
}
.wa-float:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 22px 38px -8px rgba(37,211,102,.6)}
.wa-float svg{width:28px;height:28px}

/* page transitions */
.page{display:none}
.page.active{display:block}

/* gentle reveal on scroll — opt-in via .js on <html> and only for off-screen elements */
.reveal{opacity:1;transform:none}
.js .reveal.pending{opacity:0;transform:translateY(14px);transition:opacity .7s ease, transform .7s ease}
.js .reveal.pending.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .js .reveal.pending{opacity:1;transform:none;transition:none}
}

/* utilities */
.center{text-align:center}
.mt-0{margin-top:0}
.mt-3{margin-top:18px}
.mt-4{margin-top:28px}
.mb-0{margin-bottom:0}
.row-center{display:flex;justify-content:center}
.hr{height:1px;background:var(--rule);border:0;margin:0}
.divider{display:inline-block;margin:0 8px;color:var(--ink-3)}

/* serif italic pull */
.pull{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(18px, 1.8vw, 22px);
  color:var(--teal);
  max-width:42ch;text-align:center;margin:36px auto 24px;line-height:1.5;font-weight:500;
}

/* numbered step */
.step{
  background:#fff;border-radius:var(--r-md);padding:26px;box-shadow:var(--shadow-1);
  display:flex;flex-direction:column;gap:10px;height:100%;
}
.step .n{
  width:38px;height:38px;border-radius:50%;
  background:var(--teal);color:#fff;
  font-family:var(--serif);font-weight:600;font-size:16px;
  display:inline-flex;align-items:center;justify-content:center;
}
.step.lav{background:var(--lav-soft)}
.step.lav .n{background:var(--lavender);color:var(--teal)}
.step.mint{background:var(--mint-soft)}
.step.mint .n{background:var(--mint);color:#fff}
.step.pink{background:var(--pink-soft)}
.step.pink .n{background:var(--pink);color:var(--teal)}
.step.mustard{background:var(--mustard-soft)}
.step.mustard .n{background:var(--mustard);color:var(--teal)}

/* check list */
.check-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px 28px}
@media (max-width:640px){.check-list{grid-template-columns:1fr}}
.check-list li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-2);font-size:15.5px;line-height:1.55}
.check-list li .ck{
  flex-shrink:0;margin-top:2px;
  width:22px;height:22px;border-radius:50%;
  background:var(--mint);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
}
.check-list li .ck svg{width:12px;height:12px}

/* product card */
.product{background:#fff;border-radius:var(--r-md);padding:0;box-shadow:var(--shadow-1);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s ease, box-shadow .25s ease}
.product:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.product .ph{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;color:var(--teal)}
.product .ph.lav{background:linear-gradient(135deg, var(--lav-soft), #F0E5FB)}
.product .ph.mint{background:linear-gradient(135deg, var(--mint-soft), #D9F3EA)}
.product .ph.mustard{background:linear-gradient(135deg, var(--mustard-soft), #FCEDB4)}
.product .ph.pink{background:linear-gradient(135deg, var(--pink-soft), #FCE3EA)}
.product .body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.product .body h3{font-size:19px}
.product .body p{color:var(--ink-2);font-size:14.5px;margin:0;flex:1}
.product .actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:6px}

/* form */
.form-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:32px}
@media (max-width:900px){.form-grid{grid-template-columns:1fr}}
.form-card{background:#fff;border-radius:var(--r-lg);padding:36px;box-shadow:var(--shadow-1)}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:13px;font-weight:600;color:var(--teal);letter-spacing:.02em}
.field input, .field textarea{
  border:1.5px solid var(--rule);
  background:var(--paper);
  border-radius:12px;
  padding:12px 14px;
  font:inherit;color:var(--ink);
  transition:border-color .15s ease, background .15s ease, box-shadow .15s ease;
}
.field input:focus, .field textarea:focus{outline:none;border-color:var(--mint);background:#fff;box-shadow:0 0 0 4px rgba(122,198,181,.18)}
.field textarea{min-height:130px;resize:vertical}

.contact-info{background:var(--teal);color:#fff;border-radius:var(--r-lg);padding:36px;box-shadow:var(--shadow-1)}
.contact-info h2{color:#fff;margin-bottom:18px}
.contact-info ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:18px}
.contact-info li{display:flex;gap:14px;align-items:flex-start}
.contact-info .ic{
  width:36px;height:36px;border-radius:10px;
  background:rgba(244,196,48,.18);color:var(--mustard);
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-info .ic svg{width:18px;height:18px}
.contact-info b{display:block;color:#fff;font-weight:600;font-size:14.5px}
.contact-info span{color:rgba(255,255,255,.78);font-size:14px}

/* calendar */
.cal-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:900px){.cal-grid{grid-template-columns:1fr}}
.cal-card{background:#fff;border-radius:var(--r-md);padding:30px;box-shadow:var(--shadow-1)}
.cal-card.lav{background:var(--lav-soft)}
.cal-card h3{font-size:22px;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.cal-card .pill{
  display:inline-flex;align-items:center;gap:6px;
  background:#fff;color:var(--teal);
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  padding:5px 10px;border-radius:999px;margin-bottom:14px;
}
.cal-card.lav .pill{background:#fff}
.cal-card ul{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:10px}
.cal-card li{
  display:flex;align-items:center;gap:12px;
  background:var(--paper);border-radius:12px;padding:10px 14px;
  font-size:14.5px;color:var(--ink-2);
}
.cal-card.lav li{background:rgba(255,255,255,.7)}
.cal-card li b{color:var(--teal);font-weight:600;min-width:90px}

.calendly{
  margin-top:36px;background:#fff;border:2px dashed var(--rule);
  border-radius:var(--r-lg);padding:48px 32px;text-align:center;
  color:var(--ink-2);
}
.calendly h3{font-size:22px;margin-bottom:10px}

/* sub-hero (inner pages) */
.subhero{padding:80px 0 30px;position:relative;overflow:hidden}
.subhero .blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0;opacity:.6}
.subhero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:center}
.subhero h1{font-size:clamp(34px,4.4vw, 54px);font-weight:500;margin:18px 0 18px;line-height:1.08}
.subhero .lead{font-size:17px}
.subhero-aside{
  background:#fff;border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-1);
}
.subhero-aside.mustard{background:var(--mustard);color:var(--teal)}
@media (max-width:900px){.subhero-grid{grid-template-columns:1fr}.subhero{padding:50px 0 10px}}

/* info card (Therapie) */
.info-card{background:#fff;border-radius:var(--r-lg);padding:36px;box-shadow:var(--shadow-1)}
.info-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px 28px}
@media (max-width:640px){.info-list{grid-template-columns:1fr}}
.info-list li{display:flex;gap:14px;align-items:flex-start}
.info-list li .ic{
  flex-shrink:0;width:36px;height:36px;border-radius:10px;
  background:var(--mint-soft);color:var(--teal);
  display:inline-flex;align-items:center;justify-content:center;
}
.info-list b{display:block;color:var(--teal);font-weight:600;font-size:14.5px}
.info-list span{color:var(--ink-2);font-size:14.5px}

/* module card (Formations) */
.module{
  background:#fff;border-radius:var(--r-md);padding:26px;box-shadow:var(--shadow-1);
  position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
.module:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.module.lav{background:var(--lav-soft)}
.module.mint{background:var(--mint-soft)}
.module.pink{background:var(--pink-soft)}
.module.mustard{background:var(--mustard-soft)}
.module .num{font-family:var(--serif);font-style:italic;color:var(--mint-ink);font-size:13px;font-weight:600;letter-spacing:.04em}
.module h3{font-size:22px;margin:6px 0 10px}
.module p{color:var(--ink-2);font-size:14.5px;margin:0 0 16px}
.module .meta{font-size:12px;color:var(--ink-3);padding-top:14px;border-top:1px solid rgba(15,76,92,.08)}

/* page anchor offset (sticky header) */
.page{scroll-margin-top:80px}

/* SVG deco motifs */
.motif{position:absolute;pointer-events:none}

/* responsive tweaks for hero photo on small screens */
@media (max-width:560px){
  .hero{padding:30px 0 60px}
  .hero h1{font-size:38px}
  .hero-photo{width:84%}
  .hero-photo .frame{border-radius:160px 160px 22px 22px / 180px 180px 22px 22px}
  .hero-photo .float-badge{left:0}
  section{padding:60px 0}
  .final{padding:48px 22px}
}
