/* Functional Fit - styles
   Kleuren staan bovenin onder :root. Verander daar 1x en het werkt overal door.
*/

/* ===================== Kleuren, gradient & tokens ===================== */
:root {
  --blue:#1c7ea3;
  --teal:#0e7c82;
  --green:#7DC46A;
  --green-deep:#0a5b60;
  --bg:#ffffff;
  --bg-2:#f7f5ef;
  --sand:#ece4d4;
  --ink:#222c23;
  --ink-soft:#646b62;
  --line:rgba(34,44,35,.12);
  --grad:linear-gradient(90deg,#0e7c82 0%,#7DC46A 100%);
  --grad-soft:linear-gradient(180deg,#e7f4dd 0%,#ffffff 74%);
}
/* ===================== Basis ===================== */
* {
  margin:0;
  padding:0;
  box-sizing:border-box;
}
html {
  scroll-behavior:smooth;
}
body {
  background:var(--bg);
  color:var(--ink);
  font-family:'Hanken Grotesk',sans-serif;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a {
  color:inherit;
  text-decoration:none;
}
.wrap {
  max-width:1180px;
  margin:0 auto;
  padding:0 28px;
}
h1,h2,h3,h4 {
  font-family:'Archivo',sans-serif;
  font-weight:800;
  line-height:1.04;
  letter-spacing:-.02em;
}
.eyebrow {
  font-family:'Archivo';
  font-weight:700;
  font-size:.73rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--green-deep);
}
.grad-text {
  background:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  padding-right:.12em;
  margin-right:-.12em;
}
/* Heartstay-woordmerk: "Heart" roze, "stay" groenblauw, zoals hun logo */
.hs-heart {
  color:#b4257f;
}
.hs-stay {
  color:#3f6e7d;
}
.muted {
  color:var(--ink-soft);
}
/* ===================== Knoppen (pills) ===================== */
.pill {
  display:inline-flex;
  align-items:center;
  gap:.55em;
  font-family:'Archivo';
  font-weight:700;
  font-size:1rem;
  padding:14px 26px;
  border-radius:100px;
  border:0;
  cursor:pointer;
  line-height:1;
  transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s,color .22s;
}
.pill svg {
  width:17px;
  height:17px;
  flex:none;
}
.pill--solid {
  background:
    linear-gradient(180deg,rgba(255,255,255,.34) 0%,rgba(255,255,255,.12) 46%,rgba(255,255,255,0) 54%),
    var(--grad);
  color:#fff;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    inset 0 -3px 7px rgba(8,60,64,.32),
    0 7px 16px rgba(14,124,130,.32),
    0 2px 4px rgba(0,0,0,.16);
}
.pill--solid:hover {
  transform:translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.48),
    inset 0 -3px 7px rgba(8,60,64,.32),
    0 13px 26px rgba(14,124,130,.40),
    0 4px 9px rgba(0,0,0,.20);
}
.pill--solid:active {
  transform:translateY(1px);
  box-shadow:
    inset 0 2px 6px rgba(8,60,64,.45),
    0 2px 6px rgba(14,124,130,.24);
}
/* witte knoppen -> glas met 3D-reliëf */
.pill--ghost,
.pill--line {
  background:
    linear-gradient(180deg,rgba(255,255,255,.78) 0%,rgba(255,255,255,.34) 47%,rgba(255,255,255,.14) 53%,rgba(231,244,221,.5) 100%);
  -webkit-backdrop-filter:blur(10px) saturate(1.35);
  backdrop-filter:blur(10px) saturate(1.35);
  color:var(--ink);
  border:1px solid rgba(125,196,106,.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -3px 6px rgba(95,160,80,.18),
    0 7px 15px rgba(34,44,35,.10),
    0 2px 4px rgba(0,0,0,.07);
}
.pill--ghost:hover,
.pill--line:hover {
  transform:translateY(-2px);
  border-color:var(--green);
  color:var(--green-deep);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -3px 7px rgba(95,160,80,.20),
    0 13px 24px rgba(34,44,35,.14),
    0 4px 8px rgba(0,0,0,.10);
}
.pill--ghost:active,
.pill--line:active {
  transform:translateY(1px);
  box-shadow:
    inset 0 2px 6px rgba(95,160,80,.30),
    0 2px 5px rgba(34,44,35,.12);
}
/* ===================== Navigatie / header ===================== */
#nav {
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:200;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 28px;
  transition:background .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
#nav.scrolled {
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(12px);
  border-color:var(--line);
}
.brand {
  display:flex;
  align-items:center;
  gap:11px;
}
.brand .mark {
  width:40px;
  height:40px;
  flex:none;
}
.brand .mark img,.foot .mark img {
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.word {
  text-transform:uppercase;
}
.brand .word {
  font-family:'Nunito',sans-serif;
  font-weight:800;
  font-size:clamp(1.45rem,3.6vw,1.75rem);
  letter-spacing:0;
}
.nav-right {
  display:flex;
  align-items:center;
  gap:28px;
}
.nav-links {
  display:flex;
  gap:26px;
}
.nav-links a {
  font-family:'Archivo';
  font-weight:600;
  font-size:.84rem;
  color:var(--ink);
  opacity:.7;
  transition:opacity .2s;
}
.nav-links a:hover {
  opacity:1;
}
.menu-btn {
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:0;
  cursor:pointer;
  padding:8px;
}
.menu-btn span {
  width:24px;
  height:2px;
  background:var(--ink);
  border-radius:2px;
}
/* ===================== Taalkeuze (NL / EN / DE) ===================== */
.lang {
  display:flex;
  gap:2px;
  background:rgba(255,255,255,.65);
  border:1px solid var(--line);
  border-radius:100px;
  padding:3px;
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
}
.lang button {
  font-family:'Archivo';
  font-weight:700;
  font-size:.68rem;
  letter-spacing:.05em;
  border:0;
  background:none;
  color:var(--ink-soft);
  padding:5px 10px;
  border-radius:100px;
  cursor:pointer;
  transition:color .2s;
}
.lang button.active {
  background:var(--grad);
  color:#fff;
}
/* grotere variant in het mobiele menu */
.lang--drawer {
  margin-top:28px;
  align-self:flex-start;
}
.lang--drawer button {
  font-size:.95rem;
  padding:9px 18px;
}
@media(max-width:920px) {
  .nav-links {
    display:none;
  }
  .menu-btn {
    display:flex;
  }
  .nav-right .pill {
    display:none;
  }
  /* op mobiel zit de taalkeuze in het menu en de app-balk */
  #nav .lang {
    display:none;
  }
}
/* Heel smalle telefoons: merknaam iets kleiner zodat hij op één regel blijft */
@media(max-width:380px) {
  .brand .word {
    font-size:1.2rem;
  }
  .brand .mark {
    width:34px;
    height:34px;
  }
}
/* ===================== Mobiel menu (drawer) ===================== */
.drawer {
  position:fixed;
  inset:0;
  z-index:300;
  background:var(--bg);
  transform:translateX(100%);
  transition:transform .38s cubic-bezier(.2,.8,.2,1);
  display:flex;
  flex-direction:column;
  padding:24px 28px;
}
.drawer.open {
  transform:none;
}
.drawer-top {
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.drawer .word {
  font-family:'Nunito',sans-serif;
  font-weight:800;
  letter-spacing:-.02em;
}
.drawer-close {
  background:none;
  border:0;
  font-size:2rem;
  cursor:pointer;
  color:var(--ink);
  line-height:1;
}
.drawer-links {
  margin-top:42px;
  display:flex;
  flex-direction:column;
}
.drawer-links a {
  font-family:'Archivo';
  font-weight:800;
  font-size:1.9rem;
  padding:13px 0;
  border-bottom:1px solid var(--line);
}
.drawer .pill {
  margin-top:auto;
  justify-content:center;
  margin-bottom:env(safe-area-inset-bottom);
}
/* ===================== Hero (foto-banner) ===================== */
.hero {
  position:relative;
  min-height:92svh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero-bg {
  position:absolute;
  inset:0;
  z-index:0;
  background:var(--bg);
}
.hero-scrim {
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(100deg,rgba(255,255,255,.97) 0%,rgba(255,255,255,.88) 34%,rgba(255,255,255,.45) 56%,rgba(255,255,255,0) 78%);
}
.hero-inner {
  position:relative;
  z-index:2;
  width:100%;
  padding-top:130px;
  padding-bottom:70px;
}
.hero h1 {
  font-size:clamp(2.8rem,7.5vw,5.8rem);
  font-weight:900;
  max-width:12ch;
}
.hero-sub {
  margin-top:22px;
  max-width:42ch;
  font-size:clamp(1.05rem,2.2vw,1.24rem);
  color:var(--ink-soft);
}
.hero-cta {
  margin-top:32px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.hero-tags {
  margin-top:36px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.chip {
  font-family:'Archivo';
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-soft);
  border:1px solid var(--line);
  border-radius:100px;
  padding:8px 14px;
  background:rgba(255,255,255,.6);
  backdrop-filter:blur(2px);
}
.ph {
  font-family:'Archivo';
  font-weight:600;
  font-size:.76rem;
  letter-spacing:.12em;
  color:var(--ink-soft);
  text-align:center;
  padding:22px;
}
@media(max-width:880px) {
  .hero {
    min-height:auto;
  }
  .hero-inner {
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    padding-top:104px;
    padding-bottom:54px;
  }
  .hero-scrim {
    background:linear-gradient(2deg,rgba(255,255,255,.98) 0%,rgba(255,255,255,.82) 34%,rgba(255,255,255,.3) 64%,rgba(255,255,255,0) 90%);
  }
}
/* Smalle telefoons: kop meeschalen zodat het langste woord ("samenkomen")
   binnen de zijmarges blijft en niet tegen de schermrand drukt */
@media(max-width:480px) {
  .hero h1 {
    font-size:clamp(2rem,11.5vw,2.8rem);
  }
}
/* ===================== Secties algemeen ===================== */
.band {
  padding:clamp(72px,10vw,128px) 0;
}
.band.tint {
  background:var(--bg-2);
}
.section-head {
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:24px;
  flex-wrap:wrap;
  margin-bottom:44px;
}
.section-head h2 {
  font-size:clamp(2rem,5.2vw,3.4rem);
}
.lead {
  font-family:'Archivo';
  font-weight:600;
  font-size:clamp(1.35rem,3vw,2.15rem);
  line-height:1.24;
  letter-spacing:-.015em;
}
/* ===================== Over Michael ===================== */
.about {
  display:grid;
  grid-template-columns:.8fr 1.2fr;
  gap:56px;
  align-items:center;
}
.about-photo {
  width:100%;
  max-width:330px;
  aspect-ratio:1;
  display:flex;
  align-items:center;
  justify-content:center;
}
.about-photo img {
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
@media(max-width:820px) {
  .about {
    grid-template-columns:1fr;
    gap:30px;
  }
  .about-photo {
    max-width:240px;
  }
}
/* ===================== Wat ik doe (diensten) ===================== */
.svc-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.svc {
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:16px;
  padding:32px 28px;
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.svc:hover {
  transform:translateY(-4px);
  box-shadow:0 16px 36px rgba(34,44,35,.07);
  border-color:transparent;
}
/* 3D-glas icoontjes */
.svc-ico {
  width:46px;
  height:46px;
  border-radius:13px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.46) 0%,rgba(255,255,255,.14) 46%,rgba(255,255,255,0) 56%),
    var(--grad);
  display:grid;
  place-items:center;
  color:#fff;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55),
    inset 0 -3px 6px rgba(8,60,64,.35),
    0 7px 14px rgba(14,124,130,.30),
    0 2px 4px rgba(0,0,0,.14);
}
.svc-ico svg {
  width:23px;
  height:23px;
}
.svc h3 {
  font-size:1.42rem;
}
.svc p {
  color:var(--ink-soft);
  font-size:.96rem;
  flex:1;
}
.svc .call {
  font-family:'Archivo';
  font-weight:700;
  font-size:.88rem;
  color:var(--green-deep);
  display:inline-flex;
  gap:6px;
  align-items:center;
}
/* Small-Group les */
.smallgroup {
  margin-top:20px;
  display:flex;
  align-items:flex-start;
  gap:26px;
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:16px;
  padding:32px 30px;
}
.sg-ico {
  flex:none;
  width:54px;
  height:54px;
  border-radius:15px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.46) 0%,rgba(255,255,255,.14) 46%,rgba(255,255,255,0) 56%),
    var(--grad);
  display:grid;
  place-items:center;
  color:#fff;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55),
    inset 0 -3px 6px rgba(8,60,64,.35),
    0 7px 14px rgba(14,124,130,.30),
    0 2px 4px rgba(0,0,0,.14);
}
.sg-ico svg { width:27px; height:27px; }
.sg-body h3 { font-size:1.42rem; margin-top:4px; }
.sg-body p {
  color:var(--ink-soft);
  font-size:.96rem;
  margin-top:12px;
  max-width:64ch;
}
.sg-body .pill { margin-top:20px; }
.sg-img {
  flex:none;
  width:200px;
  align-self:stretch;
  border-radius:14px;
  overflow:hidden;
}
.sg-img img {
  width:100%;
  height:100%;
  min-height:200px;
  object-fit:cover;
  display:block;
}
@media(max-width:820px) {
  .svc-grid {
    grid-template-columns:1fr;
  }
  .smallgroup { flex-direction:column; gap:18px; }
  .sg-img { width:100%; align-self:auto; }
  .sg-img img { min-height:0; max-height:340px; }
}
/* ===================== Ervaringen (testimonials) ===================== */
.quote-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.quote {
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:16px;
  padding:32px 28px;
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.quote:hover {
  transform:translateY(-4px);
  box-shadow:0 16px 36px rgba(34,44,35,.07);
  border-color:transparent;
}
.quote-ico svg {
  width:24px;
  height:24px;
}
.quote-kicker {
  font-family:'Archivo';
  font-weight:700;
  font-size:.76rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--green-deep);
}
.quote blockquote {
  color:var(--ink-soft);
  font-size:.96rem;
  flex:1;
}
.quote figcaption {
  font-family:'Archivo';
  font-weight:600;
  font-size:.85rem;
  color:var(--ink);
}
@media(max-width:820px) {
  .quote-grid {
    grid-template-columns:1fr;
  }
}
/* ===================== Mylogenics-paneel ===================== */
.mylo {
  border-radius:20px;
  padding:clamp(40px,6vw,72px);
  color:#fff;
  background:linear-gradient(90deg,rgba(14,124,130,.95) 0%,rgba(125,196,106,.9) 100%),url('../images/mylo-bg.jpg') center/cover;
}
/* ===================== Natuurband ===================== */
.island-band {
  position:relative;
  min-height:48vh;
  display:flex;
  align-items:flex-end;
  background:url('../images/band-wad.jpg') center/cover fixed;
}
.island-band--paarden {
  background:url('../images/band-paarden.jpg') center/cover fixed;
}
.island-band .wrap {
  position:relative;
  z-index:1;
  padding-top:60px;
  padding-bottom:38px;
}
.island-kicker {
  font-family:'Archivo';
  font-weight:800;
  font-size:clamp(1.3rem,3.2vw,2.2rem);
  color:#fff;
  letter-spacing:-.01em;
  text-shadow:0 2px 24px rgba(0,0,0,.35);
  max-width:18ch;
  line-height:1.1;
}
@media(max-width:880px) {
  .island-band {
    background-attachment:scroll;
    min-height:42vh;
  }
}
.mylo .eyebrow {
  color:rgba(255,255,255,.82);
}
.mylo h2 {
  font-size:clamp(1.9rem,4.6vw,3.1rem);
  max-width:17ch;
  margin-top:14px;
}
.mylo p {
  max-width:54ch;
  margin-top:16px;
  font-size:1.06rem;
  color:rgba(255,255,255,.94);
}
.mylo .tags {
  margin-top:24px;
  display:flex;
  flex-wrap:wrap;
  gap:9px;
}
.mylo .tag {
  font-family:'Archivo';
  font-weight:700;
  font-size:.71rem;
  letter-spacing:.07em;
  text-transform:uppercase;
  border:1.4px solid rgba(255,255,255,.5);
  border-radius:100px;
  padding:8px 14px;
}
.creds {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
  margin-top:40px;
}
.cred {
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:16px;
  padding:26px;
  display:flex;
  gap:18px;
  align-items:flex-start;
  flex-wrap:wrap;
}
.cred .seal {
  width:50px;
  height:50px;
  border-radius:50%;
  flex:none;
  display:grid;
  place-items:center;
  font-family:'Archivo';
  font-weight:900;
  color:#fff;
  background:var(--grad);
  font-size:1rem;
  letter-spacing:-.02em;
}
.cred .seal.alt {
  background:var(--ink);
}
.cred-main {
  flex:1;
  min-width:150px;
}
.cred h4 {
  font-size:1.14rem;
}
.cred .by {
  font-family:'Archivo';
  font-weight:600;
  font-size:.76rem;
  letter-spacing:.03em;
  color:var(--green-deep);
  margin-top:3px;
  text-transform:uppercase;
}
.cred p {
  color:var(--ink-soft);
  font-size:.9rem;
  margin-top:7px;
}
.cred-qr {
  flex:none;
  text-align:center;
  margin-left:auto;
}
.cred-qr img {
  width:128px;
  height:128px;
  border:1px solid var(--line);
  border-radius:12px;
  padding:7px;
  background:#fff;
  display:block;
}
.cred-qr span {
  font-family:'Archivo';
  font-weight:700;
  font-size:.57rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-top:6px;
  display:block;
}
/* knopje onder de QR -> opent het certificaat */
.cred-btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:5px;
  font-family:'Archivo';
  font-weight:700;
  font-size:.64rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  margin-top:14px;
  padding:9px 14px;
  border-radius:100px;
  color:var(--ink);
  background:
    linear-gradient(180deg,rgba(255,255,255,.78) 0%,rgba(255,255,255,.34) 47%,rgba(255,255,255,.14) 53%,rgba(231,244,221,.5) 100%);
  -webkit-backdrop-filter:blur(10px) saturate(1.35);
  backdrop-filter:blur(10px) saturate(1.35);
  border:1px solid rgba(125,196,106,.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -3px 6px rgba(95,160,80,.18),
    0 6px 12px rgba(34,44,35,.10),
    0 2px 4px rgba(0,0,0,.07);
  transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s,border-color .22s,color .22s;
}
.cred-btn:hover {
  border-color:var(--green);
  color:var(--green-deep);
  transform:translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -3px 7px rgba(95,160,80,.20),
    0 11px 20px rgba(34,44,35,.14),
    0 4px 8px rgba(0,0,0,.10);
}
.cred-btn:active {
  transform:translateY(1px);
  box-shadow:inset 0 2px 6px rgba(95,160,80,.30),0 2px 5px rgba(34,44,35,.12);
}
@media(max-width:680px) {
  .creds {
    grid-template-columns:1fr;
  }
  /* QR netjes in het midden van de kaart op telefoonformaat */
  .cred-qr {
    margin:8px auto 0;
  }
}
/* ===================== Heartstay ===================== */
.heart {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  border:1px solid var(--line);
  border-radius:20px;
  overflow:hidden;
  background:var(--bg);
}
.heart-img {
  min-height:320px;
  position:relative;
  background:var(--bg-2);
}
.heart-img img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  position:absolute;
  inset:0;
}
.heart-body {
  padding:clamp(32px,5vw,52px);
}
.heart-eye {
  display:flex;
  align-items:center;
  gap:9px;
  margin-bottom:12px;
}
.heart-eye svg {
  width:22px;
  height:22px;
  color:var(--green);
}
.heart-eye img {
  width:auto;
  height:30px;
}
.heart-body h2 {
  font-size:clamp(1.7rem,4.2vw,2.6rem);
}
.heart-body p {
  color:var(--ink-soft);
  margin-top:14px;
  max-width:46ch;
}
.heart-links {
  margin-top:24px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.heart-links a {
  font-family:'Archivo';
  font-weight:700;
  font-size:.86rem;
  padding:11px 18px;
  border-radius:100px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.78) 0%,rgba(255,255,255,.34) 47%,rgba(255,255,255,.14) 53%,rgba(231,244,221,.5) 100%);
  -webkit-backdrop-filter:blur(10px) saturate(1.35);
  backdrop-filter:blur(10px) saturate(1.35);
  color:var(--ink);
  border:1px solid rgba(125,196,106,.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -3px 6px rgba(95,160,80,.18),
    0 7px 15px rgba(34,44,35,.10),
    0 2px 4px rgba(0,0,0,.07);
  transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s,border-color .22s,color .22s;
  display:inline-flex;
  gap:6px;
  align-items:center;
}
.heart-links a:hover {
  border-color:var(--green);
  color:var(--green-deep);
  transform:translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -3px 7px rgba(95,160,80,.20),
    0 13px 24px rgba(34,44,35,.14),
    0 4px 8px rgba(0,0,0,.10);
}
.heart-links a:active {
  transform:translateY(1px);
  box-shadow:inset 0 2px 6px rgba(95,160,80,.30),0 2px 5px rgba(34,44,35,.12);
}
/* boekknop in Heartstay-roze, met 3D-glans */
.heart-links a.book {
  background:
    linear-gradient(180deg,rgba(255,255,255,.34) 0%,rgba(255,255,255,.12) 46%,rgba(255,255,255,0) 54%),
    #b4257f;
  color:#fff;
  border-color:transparent;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    inset 0 -3px 7px rgba(96,16,58,.35),
    0 7px 16px rgba(180,37,127,.32),
    0 2px 4px rgba(0,0,0,.16);
}
.heart-links a.book:hover {
  color:#fff;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.5),
    inset 0 -3px 7px rgba(96,16,58,.35),
    0 13px 26px rgba(180,37,127,.40),
    0 4px 9px rgba(0,0,0,.20);
}
.heart-links a.book:active {
  box-shadow:
    inset 0 2px 6px rgba(96,16,58,.45),
    0 2px 6px rgba(180,37,127,.24);
}
@media(max-width:820px) {
  .heart {
    grid-template-columns:1fr;
  }
  .heart-img {
    min-height:240px;
    position:relative;
  }
  .heart-img img {
    position:absolute;
  }
}
/* ===================== Contact + formulier ===================== */
.contact {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:54px;
  align-items:start;
}
.mini-ico {
  width:58px;
  height:58px;
  flex:none;
  display:grid;
  place-items:center;
}
.mini-ico img {
  width:100%;
  height:100%;
  object-fit:contain;
}
.contact h2 {
  font-size:clamp(2rem,5.2vw,3.4rem);
}
.crow {
  display:flex;
  gap:14px;
  padding:15px 0;
  border-bottom:1px solid var(--line);
}
.crow .k {
  font-family:'Archivo';
  font-weight:700;
  font-size:.7rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--green-deep);
  width:80px;
  flex:none;
  padding-top:3px;
}
.contact-cta {
  margin-top:24px;
  display:flex;
  gap:11px;
  flex-wrap:wrap;
}
form {
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:18px;
  padding:clamp(24px,4vw,36px);
  display:flex;
  flex-direction:column;
  gap:14px;
}
label {
  font-family:'Archivo';
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-bottom:-8px;
}
input,select,textarea {
  font-family:'Hanken Grotesk';
  font-size:1rem;
  color:var(--ink);
  background:var(--bg-2);
  border:1.4px solid var(--line);
  border-radius:11px;
  padding:13px 15px;
  width:100%;
  transition:border-color .2s;
}
input:focus,select:focus,textarea:focus {
  outline:none;
  border-color:var(--green);
}
textarea {
  resize:vertical;
  min-height:92px;
}
.form-row {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:13px;
}
form .pill {
  justify-content:center;
  margin-top:4px;
}
.form-note {
  font-size:.81rem;
  color:var(--ink-soft);
}
@media(max-width:820px) {
  .contact {
    grid-template-columns:1fr;
    gap:28px;
  }
  .form-row {
    grid-template-columns:1fr;
  }
}
/* ===================== Footer ===================== */
footer {
  border-top:1px solid var(--line);
  padding:54px 0 128px;
  background:var(--bg-2);
}
.foot {
  display:flex;
  justify-content:space-between;
  gap:32px;
  flex-wrap:wrap;
}
.foot .word {
  font-family:'Nunito',sans-serif;
  font-weight:800;
  letter-spacing:-.02em;
  font-size:1.4rem;
  display:flex;
  align-items:center;
  gap:10px;
}
.foot-right {
  display:flex;
  flex-direction:column;
  gap:20px;
  align-items:flex-start;
}
.foot-nav {
  display:flex;
  gap:9px;
  flex-wrap:wrap;
}
.foot-nav a {
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  font-family:'Archivo';
  font-weight:700;
  font-size:.66rem;
  letter-spacing:.02em;
  color:var(--ink-soft);
  padding:11px 15px;
  border:1px solid var(--line);
  border-radius:14px;
  transition:.2s;
  min-width:66px;
}
.foot-nav a:hover {
  border-color:var(--green);
  color:var(--green-deep);
  transform:translateY(-2px);
}
.foot-nav a svg,
.foot-nav a img {
  width:22px;
  height:22px;
  object-fit:contain;
}
.foot-links {
  font-size:.9rem;
  color:var(--ink-soft);
  line-height:1.95;
}
.foot-links a:hover {
  color:var(--green-deep);
}
.foot-col h4 {
  font-family:'Archivo';
  font-size:.71rem;
  letter-spacing:.13em;
  text-transform:uppercase;
  color:var(--green-deep);
  margin-bottom:12px;
}
.foot-col a,.foot-col p {
  display:block;
  color:var(--ink-soft);
  font-size:.91rem;
  margin-bottom:7px;
  transition:color .2s;
}
.foot-col a:hover {
  color:var(--ink);
}
/* kaartje onderin de footer: met hart gemaakt + credit */
.made-box {
  margin-top:36px;
  display:inline-flex;
  flex-direction:column;
  gap:9px;
  padding:20px 24px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.92) 0%,rgba(231,244,221,.45) 100%);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    0 10px 24px rgba(34,44,35,.07),
    0 2px 6px rgba(0,0,0,.04);
}
.foot-heart {
  display:flex;
  align-items:center;
  gap:9px;
  font-family:'Archivo';
  font-weight:700;
  font-size:.84rem;
  color:var(--ink);
}
.foot-heart img {
  width:auto;
  height:28px;
}
.copyright {
  font-size:.78rem;
  color:var(--ink-soft);
}
.credit-line {
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:5px;
  padding-top:14px;
  border-top:1px dashed var(--line);
  font-family:'Archivo';
  font-weight:600;
  font-size:.8rem;
  color:var(--ink-soft);
}
.credit-line img {
  width:30px;
  height:30px;
  flex:none;
  object-fit:contain;
  padding:2px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:9px;
  transition:transform .22s cubic-bezier(.2,.8,.2,1);
}
.credit-line strong {
  color:var(--green-deep);
  font-weight:800;
}
.credit-line:hover strong {
  text-decoration:underline;
}
.credit-line:hover img {
  transform:translateY(-2px);
}
/* ===================== App-balk onderaan (mobiel) ===================== */
.tabbar {
  position:fixed;
  top:auto;
  bottom:0;
  left:0;
  right:0;
  z-index:150;
  display:none;
  justify-content:space-around;
  align-items:center;
  padding:8px 6px calc(8px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(14px);
  border-top:1px solid var(--line);
}
.tabbar a {
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:3px;
  font-family:'Archivo';
  font-weight:700;
  font-size:.62rem;
  letter-spacing:.01em;
  color:var(--ink-soft);
  padding:5px 12px;
  border-radius:12px;
  transition:color .2s;
}
.tabbar a svg {
  width:22px;
  height:22px;
}
.tabbar a img {
  width:22px;
  height:22px;
  object-fit:contain;
}
.tabbar a.active {
  color:var(--green-deep);
}
/* taalknop in de app-balk: tikken wisselt NL -> EN -> DE */
.tabbar .lang-tab {
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:3px;
  font-family:'Archivo';
  font-weight:700;
  font-size:.62rem;
  letter-spacing:.01em;
  color:var(--ink-soft);
  padding:5px 12px;
  border-radius:12px;
  background:none;
  border:0;
  cursor:pointer;
}
.tabbar .lang-tab svg {
  width:22px;
  height:22px;
}
.contact-heart {
  margin-top:20px;
  display:inline-flex;
  align-items:center;
  gap:9px;
  font-family:'Archivo';
  font-weight:700;
  font-size:.9rem;
  color:var(--ink);
  background:
    linear-gradient(180deg,rgba(255,255,255,.78) 0%,rgba(255,255,255,.34) 47%,rgba(255,255,255,.14) 53%,rgba(231,244,221,.5) 100%);
  -webkit-backdrop-filter:blur(10px) saturate(1.35);
  backdrop-filter:blur(10px) saturate(1.35);
  border:1px solid rgba(125,196,106,.45);
  padding:12px 20px;
  border-radius:100px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -3px 6px rgba(95,160,80,.18),
    0 7px 15px rgba(34,44,35,.10),
    0 2px 4px rgba(0,0,0,.07);
  transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s,border-color .22s,color .22s;
}
.contact-heart:hover {
  border-color:var(--green);
  color:var(--green-deep);
  transform:translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -3px 7px rgba(95,160,80,.20),
    0 13px 24px rgba(34,44,35,.14),
    0 4px 8px rgba(0,0,0,.10);
}
.contact-heart:active {
  transform:translateY(1px);
  box-shadow:inset 0 2px 6px rgba(95,160,80,.30),0 2px 5px rgba(34,44,35,.12);
}
.contact-heart svg {
  width:18px;
  height:18px;
  color:var(--green);
}
.contact-heart img {
  width:auto;
  height:24px;
}
@media(max-width:920px) {
  .tabbar {
    display:flex;
  }
  footer {
    padding-bottom:92px;
  }
}
