/* =============================================
   HOEVE VOORWAARTS — DESIGN SYSTEM
   Mini Camping Callantsoog
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Nunito:wght@300;400;500;600&display=swap');

/* --- Design Tokens --- */
:root {
  --forest:       #1E3D2F;
  --forest-mid:   #2E5940;
  --moss:         #4A7A5A;
  --moss-light:   #7AAF8A;
  --sand:         #E8D5A0;
  --sand-light:   #F4EDD5;
  --cream:        #FDFAF4;
  --sky:          #C8DFF0;
  --amber:        #C97B1C;
  --amber-light:  #E8A838;
  --white:        #FFFFFF;
  --text:         #1C1A14;
  --text-mid:     #5A5242;
  --text-muted:   #9A8F7E;
  --border:       rgba(30,61,47,.12);
  --border-sand:  rgba(232,213,160,.5);

  --font-serif:   'Playfair Display', Georgia, serif;
  --font-sans:    'Nunito', system-ui, sans-serif;

  --nav-h:        96px;
  --r:            8px;
  --r-lg:         18px;
  --r-xl:         28px;
  --r-2xl:        40px;

  --s-sm:   0 2px 16px rgba(30,61,47,.07);
  --s-md:   0 8px 40px rgba(30,61,47,.12);
  --s-lg:   0 24px 80px rgba(30,61,47,.16);
  --s-warm: 0 8px 40px rgba(201,123,28,.25);
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);background:var(--cream);color:var(--text);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* --- Type Scale --- */
h1,h2,h3,h4{font-family:var(--font-serif);font-weight:400;line-height:1.2;color:var(--text)}
h1{font-size:clamp(2.8rem,6vw,5.2rem);letter-spacing:-.01em}
h2{font-size:clamp(2rem,4vw,3.2rem)}
h3{font-size:clamp(1.4rem,2.5vw,1.9rem)}
h4{font-size:1.15rem;font-family:var(--font-serif)}
p{line-height:1.75}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--moss);font-family:var(--font-sans);
}
.eyebrow::before{content:'';width:24px;height:1.5px;background:var(--moss);flex-shrink:0}
.lead{font-size:1.08rem;line-height:1.85;color:var(--text-mid)}

/* --- Layout --- */
.container{width:min(1160px,100% - 3rem);margin-inline:auto}
section{padding:clamp(72px,10vw,120px) 0}
.section-head{margin-bottom:clamp(2.5rem,5vw,4rem)}
.section-head p{margin-top:1.25rem;color:var(--text-mid);max-width:540px}
.section-head.center{text-align:center}
.section-head.center p{margin-inline:auto}

/* --- Rule --- */
.rule{display:block;width:36px;height:2px;background:var(--amber);margin:1.1rem 0}
.rule.center{margin-inline:auto}

/* =============================================
   BUTTONS
   ============================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.9rem 2.2rem;border-radius:100px;
  font-family:var(--font-sans);font-size:.85rem;font-weight:600;letter-spacing:.04em;
  transition:all .3s cubic-bezier(.25,.46,.45,.94);white-space:nowrap;cursor:pointer;
}
.btn-forest{background:var(--forest);color:var(--white);box-shadow:0 4px 20px rgba(30,61,47,.3)}
.btn-forest:hover{background:var(--forest-mid);box-shadow:var(--s-md);transform:translateY(-2px)}
.btn-amber{background:var(--amber);color:var(--white);box-shadow:var(--s-warm)}
.btn-amber:hover{background:#b06b10;box-shadow:0 8px 40px rgba(201,123,28,.4);transform:translateY(-2px)}
.btn-outline{border:2px solid var(--forest);color:var(--forest);background:transparent}
.btn-outline:hover{background:var(--forest);color:var(--white)}
.btn-outline-white{border:2px solid rgba(255,255,255,.6);color:var(--white);background:transparent}
.btn-outline-white:hover{background:rgba(255,255,255,.15);border-color:var(--white)}
.btn-sm{padding:.65rem 1.5rem;font-size:.8rem}
.btn svg{flex-shrink:0;width:16px;height:16px}

/* =============================================
   NAVIGATION
   ============================================= */
.nav{
  position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:200;
  transition:background .4s,box-shadow .4s;
}
.nav--scrolled{
  background:rgba(253,250,244,.95);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 1px 0 rgba(30,61,47,.1), 0 4px 24px rgba(30,61,47,.06);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h)}

/* Logo */
.nav__logo{display:flex;align-items:center;gap:.75rem;transition:opacity .3s}
.nav__logo:hover{opacity:.85}
.nav__logo img{
  height:76px;width:auto;
}

/* Links */
.nav__links{display:flex;align-items:center;gap:2.25rem}
.nav__link{
  font-size:.82rem;font-weight:500;letter-spacing:.06em;
  color:rgba(255,255,255,.8);transition:color .25s;position:relative;padding:.2rem 0;
}
.nav__link::after{
  content:'';position:absolute;bottom:-2px;left:0;right:0;height:1.5px;
  background:var(--amber-light);transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.nav__link:hover,.nav__link.active{color:var(--white)}
.nav__link:hover::after,.nav__link.active::after{transform:scaleX(1)}
.nav--scrolled .nav__link{color:var(--text-mid)}
.nav--scrolled .nav__link:hover,.nav--scrolled .nav__link.active{color:var(--forest)}
.nav__link.active::after{background:var(--amber)}

/* Hamburger */
.nav__toggle{
  display:none;flex-direction:column;justify-content:center;
  gap:5px;padding:6px;width:38px;height:38px;
}
.nav__toggle span{display:block;width:100%;height:2px;background:var(--white);border-radius:2px;transition:all .35s cubic-bezier(.25,.46,.45,.94);transform-origin:center}
.nav--scrolled .nav__toggle span{background:var(--forest)}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Overlay */
.nav__overlay{
  display:none;position:fixed;inset:0;z-index:198;
  background:rgba(10,20,12,.5);backdrop-filter:blur(4px);
  opacity:0;transition:opacity .35s;pointer-events:none;
}
.nav__overlay.open{display:block;opacity:1;pointer-events:all}

/* Mobile drawer */
.nav__drawer{
  display:none;position:fixed;top:var(--nav-h);left:0;right:0;
  background:rgba(253,250,244,.98);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  padding:1.5rem 1.5rem 2.5rem;
  box-shadow:var(--s-lg);z-index:199;
  transform:translateY(-10px);opacity:0;
  transition:transform .35s cubic-bezier(.25,.46,.45,.94),opacity .3s;pointer-events:none;
}
.nav__drawer.open{display:block;transform:translateY(0);opacity:1;pointer-events:all}
.nav__drawer a{
  display:flex;align-items:center;padding:1rem 0;
  border-bottom:1px solid var(--border);font-size:.95rem;
  color:var(--text);letter-spacing:.02em;transition:color .2s;
}
.nav__drawer a:last-of-type{border-bottom:none}
.nav__drawer a:hover{color:var(--forest)}
.nav__drawer .btn{margin-top:1.5rem;width:100%;justify-content:center}
.nav__drawer-close{
  position:absolute;top:1rem;right:1.5rem;
  font-size:1.2rem;color:var(--text-muted);padding:.25rem .5rem;
  transition:color .2s;
}
.nav__drawer-close:hover{color:var(--text)}

/* =============================================
   HERO
   ============================================= */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:flex-end;
  overflow:hidden;
}
.hero__bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  background-image:linear-gradient(to bottom, rgba(10,20,12,.4), rgba(10,20,12,.5));
}
.hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(10,20,12,.2) 0%, rgba(10,20,12,.1) 40%, rgba(10,20,12,.7) 100%);
  z-index:1;
}
.hero__content{
  position:relative;z-index:2;
  padding-bottom:clamp(4rem,8vw,8rem);
  padding-top:calc(var(--nav-h) + 2rem);
  display:flex;justify-content:flex-end;
}

/* Hero card */
.hero-card{
  background:rgba(253,250,244,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-radius:var(--r-xl);padding:clamp(1.5rem,3vw,2.25rem) clamp(1.5rem,3vw,2.5rem);
  box-shadow:var(--s-lg);
  width:clamp(360px,38vw,520px);max-width:calc(100vw - 2rem);
  max-height:calc(100svh - var(--nav-h) - 5rem);overflow-y:auto;
}
.hero-card .eyebrow{margin-bottom:.9rem}
.hero-card h1{color:var(--forest);font-size:clamp(1.75rem,3vw,2.6rem);margin-bottom:.75rem}
.hero-card h1 em{font-style:italic;color:var(--moss)}
.hero-card .lead{margin-bottom:1.25rem;color:var(--text-mid)}
.hero-card__price{
  display:flex;align-items:baseline;gap:.5rem;
  background:rgba(30,61,47,.06);border-radius:var(--r-lg);
  padding:.85rem 1.1rem;margin-bottom:1.5rem;
}
.price-from{font-size:.75rem;color:var(--text-muted)}
.price-amount{font-family:var(--font-serif);font-size:2.2rem;color:var(--amber);line-height:1}
.price-info{font-size:.75rem;color:var(--text-muted);line-height:1.4}
.hero-card__actions{display:flex;gap:.75rem;flex-direction:column}
.hero-card__actions .btn{width:100%;justify-content:center}

/* Scroll hint */
.hero__scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:2;
  color:rgba(255,255,255,.5);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;
  animation:scroll-fade 3s ease-in-out infinite;
}
.hero__scroll svg{width:20px;height:20px}
@keyframes scroll-fade{0%,100%{opacity:.4;transform:translateX(-50%) translateY(0)}50%{opacity:.8;transform:translateX(-50%) translateY(6px)}}

/* =============================================
   MARQUEE
   ============================================= */
.marquee-strip{
  background:var(--forest);padding:.9rem 0;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
}
.marquee-track{display:flex;gap:2rem;width:max-content;animation:marquee 36s linear infinite}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-track span{
  font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.5);white-space:nowrap;
}
.marquee-track .dot{color:var(--moss-light)}

/* =============================================
   INTRO / ABOUT
   ============================================= */
.intro-section{background:var(--cream)}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,6vw,7rem);align-items:center}

.intro-text .eyebrow{margin-bottom:1.25rem}
.intro-text h2{margin-bottom:1rem}
.intro-text .lead{margin-bottom:1.25rem}
.intro-text p{color:var(--text-mid);margin-bottom:.9rem}

.intro-badges{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}
.badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--white);border:1px solid var(--border);border-radius:100px;
  padding:.5rem 1rem;font-size:.78rem;color:var(--text-mid);font-weight:500;
  box-shadow:var(--s-sm);
}
.badge svg{width:15px;height:15px;color:var(--moss);flex-shrink:0}

.intro-visual{position:relative}
.intro-image-wrap{
  position:relative;border-radius:var(--r-xl);overflow:visible;
}
.intro-image-wrap img{
  width:100%;height:600px;object-fit:cover;border-radius:var(--r-xl);
  box-shadow:var(--s-lg);display:block;
}
.intro-stat-card{
  position:absolute;bottom:-1.5rem;left:-2rem;
  background:var(--forest);color:var(--white);
  border-radius:var(--r-lg);padding:1.25rem 1.5rem;
  box-shadow:var(--s-md);
}
.stat-num{
  display:block;font-family:var(--font-serif);font-size:2.4rem;
  color:var(--sand);line-height:1;
}
.stat-label{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:.3rem;display:block}

/* =============================================
   LOCATION / OMGEVING
   ============================================= */
.location-section{background:var(--forest);position:relative;overflow:hidden}
.location-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg, rgba(74,122,90,.2) 0%, transparent 60%);
}
.location-section .eyebrow,.location-section .section-head .eyebrow{color:var(--moss-light)}
.location-section h2{color:var(--white)}
.location-section .rule{background:var(--amber-light)}
.location-section .section-head p{color:rgba(255,255,255,.6)}

.location-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:0}
.location-card{
  background:rgba(255,255,255,.07);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);
  padding:2.25rem 1.75rem;
  transition:background .3s,border-color .3s,transform .3s;
}
.location-card:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2);transform:translateY(-6px)}
.location-card__icon{
  width:56px;height:56px;border-radius:50%;
  background:rgba(74,122,90,.25);
  display:flex;align-items:center;justify-content:center;
  color:var(--moss-light);margin-bottom:1.5rem;
}
.location-card h3{color:var(--white);font-size:1.25rem;margin-bottom:.6rem}
.location-card p{font-size:.88rem;color:rgba(255,255,255,.55);line-height:1.7}

/* =============================================
   FACILITIES / VOORZIENINGEN
   ============================================= */
.facilities-section{background:var(--sand-light)}
.facilities-inner{}
.facilities-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.facility-item{
  display:flex;align-items:flex-start;gap:1rem;
  background:var(--white);border-radius:var(--r-lg);padding:1.5rem 1.25rem;
  border:1px solid var(--border);
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.facility-item:hover{transform:translateY(-4px);box-shadow:var(--s-sm);border-color:rgba(74,122,90,.2)}
.facility-icon{
  width:48px;height:48px;border-radius:50%;flex-shrink:0;
  background:rgba(30,61,47,.07);
  display:flex;align-items:center;justify-content:center;color:var(--moss);
}
.facility-item h4{font-family:var(--font-serif);font-size:1rem;margin-bottom:.3rem;color:var(--text)}
.facility-item p{font-size:.82rem;color:var(--text-muted);line-height:1.55}

/* =============================================
   PRICING PREVIEW
   ============================================= */
.pricing-preview{background:var(--cream)}
.price-cards-row{display:grid;grid-template-columns:1fr 1.6fr;gap:1.5rem;align-items:start}

.price-card{
  background:var(--white);border-radius:var(--r-xl);
  border:1px solid var(--border);overflow:hidden;
  box-shadow:var(--s-sm);transition:transform .35s,box-shadow .35s;
  min-width:0;
}
.price-card:hover{transform:translateY(-5px);box-shadow:var(--s-md)}
.price-card.featured{border:2px solid var(--moss);box-shadow:var(--s-md)}
.price-card__head{
  background:var(--forest);padding:2rem;
  display:flex;flex-direction:column;align-items:center;text-align:center;
}
.price-card__head .eyebrow{color:var(--moss-light);margin-bottom:.75rem;justify-content:center}
.price-card__head .eyebrow::before{background:var(--moss-light)}
.price-card__head p{color:rgba(255,255,255,.55);font-size:.82rem}
.price-card__amount{
  display:flex;align-items:flex-start;line-height:1;
  font-family:var(--font-serif);color:var(--sand);
  margin-bottom:.25rem;
}
.euro{font-size:1.5rem;margin-top:.4rem;margin-right:.15rem}
.price-card__amount{font-size:4rem}
.price-card__list{padding:1.5rem 2rem;display:flex;flex-direction:column;gap:.75rem}
.price-card__list li{
  display:flex;align-items:center;gap:.65rem;
  font-size:.88rem;color:var(--text-mid);
}
.price-card__list li svg{color:var(--moss);flex-shrink:0;width:18px;height:18px}
.price-card .btn{margin:0 2rem 2rem;width:calc(100% - 4rem);justify-content:center}

/* Extras card */
.price-extras-card{
  background:var(--white);border-radius:var(--r-xl);border:1px solid var(--border);
  padding:2rem;box-shadow:var(--s-sm);
}
.price-extras-card h3{font-size:1.4rem;margin-bottom:1.25rem}
.extras-table{width:100%;border-collapse:collapse}
.extras-table td{
  padding:.65rem .5rem;font-size:.85rem;color:var(--text-mid);
  border-bottom:1px solid rgba(30,61,47,.06);
}
.extras-table td:last-child{text-align:right;color:var(--text);font-weight:500;white-space:nowrap}
.extras-table tr:last-child td{border-bottom:none}
.extras-note{font-size:.78rem;color:var(--text-muted);margin-top:.75rem;line-height:1.6;margin-bottom:1.25rem}
.extras-note a{color:var(--moss);text-decoration:underline;text-underline-offset:2px}

/* =============================================
   BOOKING SECTION
   ============================================= */
.booking-section{background:linear-gradient(135deg, var(--forest) 0%, #163022 100%);position:relative;overflow:hidden}
.booking-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 30% 80%, rgba(74,122,90,.3) 0%, transparent 55%);
}
.booking-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;
}
.booking-text .eyebrow{color:var(--moss-light)}
.booking-text .eyebrow::before{background:var(--moss-light)}
.booking-text h2{color:var(--white);margin-bottom:1rem}
.booking-text .lead{color:rgba(255,255,255,.7);margin-bottom:1.5rem}
.booking-bullets{display:flex;flex-direction:column;gap:.75rem}
.booking-bullets li{
  display:flex;align-items:center;gap:.7rem;
  font-size:.88rem;color:rgba(255,255,255,.65);
}
.booking-bullets li svg{color:var(--moss-light);flex-shrink:0;width:18px;height:18px}

.booking-widget-outer{
  background:rgba(253,250,244,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-xl);padding:2rem;
  min-height:280px;
}
.booking-widget-placeholder{
  text-align:center;padding:3rem 2rem;
  display:flex;flex-direction:column;align-items:center;gap:1.25rem;
}
.booking-widget-placeholder svg{color:rgba(255,255,255,.3)}
.booking-widget-placeholder p{color:rgba(255,255,255,.45);font-size:.9rem;line-height:1.7}
.booking-widget-placeholder--lg{padding:3.5rem 2rem}

/* Tommy Booking widget wrapper */
.tommy-widget-wrap{width:100%;min-height:200px}
.tommy-widget-wrap>div{width:100%}
.booking-widget-placeholder--lg svg{color:var(--moss)}
.booking-widget-placeholder--lg h3{color:var(--text);font-size:1.5rem}
.booking-widget-placeholder--lg p{color:var(--text-mid)}

/* =============================================
   GALLERY PREVIEW
   ============================================= */
.gallery-preview{background:var(--sand-light)}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:320px 320px;
  gap:12px;margin-top:0;
  width:100%;
  padding-inline:clamp(1rem,4vw,3rem);
}
.gallery-thumb{
  position:relative;border-radius:var(--r-lg);overflow:hidden;display:block;
}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.gallery-thumb:hover img{transform:scale(1.06)}
.gallery-thumb__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(30,61,47,.5) 0%, transparent 50%);
  opacity:0;transition:opacity .3s;
}
.gallery-thumb:hover .gallery-thumb__overlay{opacity:1}

/* Gallery layout — tall left, 2x2 right */
.gallery-thumb:nth-child(1),.gallery-thumb.g-tall{grid-column:1/5;grid-row:1/3}
.gallery-thumb:nth-child(2){grid-column:5/9;grid-row:1/2}
.gallery-thumb:nth-child(3){grid-column:9/13;grid-row:1/2}
.gallery-thumb:nth-child(4),.gallery-thumb.g-wide{grid-column:5/9;grid-row:2/3}
.gallery-thumb:nth-child(5){grid-column:9/13;grid-row:2/3}

.gallery-cta{text-align:center;margin-top:2.5rem}

/* =============================================
   REVIEWS
   ============================================= */
.reviews-section{background:var(--cream)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.review-card{
  background:var(--white);border-radius:var(--r-xl);padding:2rem;
  border:1px solid var(--border);box-shadow:var(--s-sm);
  transition:transform .35s,box-shadow .35s;
}
.review-card:hover{transform:translateY(-4px);box-shadow:var(--s-md)}
.review-stars{color:var(--amber);font-size:1rem;letter-spacing:.1em;margin-bottom:1rem}
.review-card blockquote{
  font-family:var(--font-serif);font-size:1.02rem;font-style:italic;
  color:var(--text);line-height:1.65;margin-bottom:1.25rem;
}
.review-author{
  display:flex;align-items:center;gap:.75rem;
  padding-top:1rem;border-top:1px solid var(--border);
}
.review-avatar{
  width:38px;height:38px;border-radius:50%;background:rgba(74,122,90,.15);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-serif);font-size:.85rem;color:var(--moss);font-weight:600;
}
.review-author strong{display:block;font-size:.85rem;font-weight:600;color:var(--text)}
.review-author span{font-size:.75rem;color:var(--text-muted)}

/* =============================================
   CTA BANNER
   ============================================= */
.cta-banner{
  padding:clamp(64px,8vw,100px) 0;
  position:relative;overflow:hidden;
}
.cta-banner__bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg, var(--forest) 0%, #163022 100%);
}
.cta-banner__bg::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 120%, rgba(74,122,90,.4) 0%, transparent 60%);
}
.cta-banner__inner{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:space-between;gap:3rem;flex-wrap:wrap;
}
.cta-banner__text{flex:1;min-width:260px}
.cta-banner__text h2{color:var(--white);margin-bottom:.75rem}
.cta-banner__text p{color:rgba(255,255,255,.6);font-size:1.05rem;max-width:460px}
.cta-banner__actions{display:flex;gap:1rem;flex-wrap:wrap;flex-shrink:0}

/* =============================================
   PAGE HERO (inner pages)
   ============================================= */
.page-hero{
  position:relative;overflow:hidden;
  padding:calc(var(--nav-h) + 80px) 0 80px;
}
.page-hero__bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
}
.page-hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(10,20,12,.65) 0%, rgba(10,20,12,.6) 100%);
}
.page-hero__content{
  position:relative;z-index:1;text-align:center;
}
.page-hero__content .eyebrow{color:var(--moss-light);margin-bottom:1.25rem;justify-content:center}
.page-hero__content .eyebrow::before{background:var(--moss-light)}
.page-hero__content h1{color:var(--white);font-weight:400;margin-bottom:1rem}
.page-hero__content p{color:rgba(255,255,255,.65);max-width:540px;margin-inline:auto;font-size:1.05rem;margin-bottom:1.25rem}
.page-hero--short{padding:calc(var(--nav-h) + 56px) 0 56px}

.breadcrumb{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.78rem;color:rgba(255,255,255,.45);
}
.breadcrumb a{color:rgba(255,255,255,.45);transition:color .2s}
.breadcrumb a:hover{color:rgba(255,255,255,.8)}
.breadcrumb span[aria-hidden]{opacity:.6}

/* =============================================
   TARIEVEN PAGE
   ============================================= */
.pricing-main{background:var(--cream)}
.price-hero-card{
  background:var(--white);border-radius:var(--r-xl);border:1px solid var(--border);
  box-shadow:var(--s-lg);overflow:hidden;
  display:grid;grid-template-columns:auto 1fr;
  border-top:4px solid var(--moss);
}
.price-hero-card__left{
  background:var(--forest);padding:3rem 3.5rem;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  min-width:240px;
}
.price-hero-amount{
  display:flex;align-items:flex-start;line-height:1;margin-bottom:.75rem;
}
.euro-big{font-family:var(--font-serif);font-size:2rem;color:var(--sand);margin-top:.5rem;margin-right:.2rem}
.amount-big{font-family:var(--font-serif);font-size:5rem;color:var(--sand)}
.per{font-family:var(--font-serif);font-size:1.2rem;color:rgba(255,255,255,.45);align-self:flex-end;padding-bottom:.5rem;margin-left:.3rem}
.price-hero-card__left > p{color:rgba(255,255,255,.5);font-size:.82rem;line-height:1.6;max-width:180px}
.price-hero-card__right{padding:2.5rem 3rem}
.price-hero-card__right h3{font-size:1.4rem;margin-bottom:1.25rem}
.included-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}
.included-list li{
  display:flex;align-items:center;gap:.75rem;
  font-size:.9rem;color:var(--text-mid);
}
.included-list li svg{color:var(--moss);flex-shrink:0}

/* Extras section */
.extras-section{background:var(--sand-light)}
.extras-table-wrap{
  background:var(--white);border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--s-sm);border:1px solid var(--border);
}
.tarieven-table{width:100%;border-collapse:collapse}
.tarieven-table thead tr{background:var(--forest)}
.tarieven-table th{
  padding:1rem 1.25rem;text-align:left;
  font-family:var(--font-sans);font-size:.72rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6);
}
.tarieven-table td{
  padding:1rem 1.25rem;font-size:.88rem;color:var(--text-mid);
  border-bottom:1px solid var(--border);
}
.tarieven-table td:nth-child(2){font-weight:600;color:var(--text);white-space:nowrap}
.tarieven-table tbody tr:last-child td{border-bottom:none}
.tarieven-table tbody tr:hover td{background:rgba(30,61,47,.03)}
.tarieven-note{
  display:flex;align-items:flex-start;gap:.9rem;
  background:rgba(201,123,28,.08);border:1px solid rgba(201,123,28,.2);
  border-radius:var(--r-lg);padding:1.1rem 1.5rem;margin-top:1.5rem;
  font-size:.85rem;color:var(--text-mid);
}
.tarieven-note svg{color:var(--amber);flex-shrink:0;margin-top:.1rem}

/* Rules section */
.rules-section{background:var(--cream)}
.rules-inner{}
.rules-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-top:0}
.rule-item{
  display:flex;align-items:flex-start;gap:1rem;
  background:var(--white);border-radius:var(--r-lg);padding:1.5rem;
  border:1px solid var(--border);
}
.rule-item--no{border-left:4px solid #e05252}
.rule-item--yes{border-left:4px solid var(--moss)}
.rule-item__icon{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.rule-item__icon--no{background:rgba(224,82,82,.1);color:#e05252}
.rule-item__icon--yes{background:rgba(74,122,90,.1);color:var(--moss)}
.rule-item h4{font-family:var(--font-serif);font-size:1rem;margin-bottom:.3rem}
.rule-item p{font-size:.83rem;color:var(--text-muted);line-height:1.55}

/* =============================================
   FAQ
   ============================================= */
.faq-section{background:var(--cream)}
.faq-section--sand{background:var(--sand-light)}
.faq-list{display:flex;flex-direction:column;gap:.75rem}
.faq__item{
  background:var(--white);border-radius:var(--r-lg);
  border:1px solid var(--border);overflow:hidden;
}
.faq__item.open{border-color:var(--moss)}
.faq__question{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem 1.5rem;font-family:var(--font-serif);font-size:1rem;
  color:var(--text);text-align:left;gap:1rem;
  transition:background .2s;cursor:pointer;
}
.faq__question:hover{background:rgba(30,61,47,.03)}
.faq__icon{
  flex-shrink:0;width:20px;height:20px;color:var(--text-muted);
  transition:transform .3s cubic-bezier(.25,.46,.45,.94);
}
.faq__item.open .faq__icon{transform:rotate(180deg);color:var(--moss)}
.faq__answer{
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.25,.46,.45,.94);
}
.faq__answer p{
  padding:.25rem 1.5rem 1.5rem;font-size:.9rem;
  color:var(--text-mid);line-height:1.75;
}

/* =============================================
   CONTACT PAGE
   ============================================= */
.contact-section{background:var(--cream)}
.contact-layout{display:grid;grid-template-columns:1.1fr 1fr;gap:3rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.25rem}
.contact-info-card{
  background:var(--white);border-radius:var(--r-lg);padding:1.5rem;
  border:1px solid var(--border);display:flex;align-items:flex-start;gap:1rem;
  box-shadow:var(--s-sm);
}
.contact-info-icon{
  width:44px;height:44px;flex-shrink:0;background:rgba(30,61,47,.07);
  border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--moss);
}
.contact-info-card h3{font-size:1rem;margin-bottom:.25rem}
.contact-info-card a{color:var(--moss);transition:color .2s;display:inline-block}
.contact-info-card a:hover{color:var(--forest)}
.contact-info-card p,.contact-info-card address{font-size:.88rem;color:var(--text-mid);font-style:normal;line-height:1.65}
.contact-info-tip{
  display:flex;align-items:flex-start;gap:.75rem;
  background:rgba(201,123,28,.08);border:1px solid rgba(201,123,28,.2);
  border-radius:var(--r-lg);padding:1rem 1.25rem;font-size:.83rem;color:var(--text-mid);
}
.contact-info-tip svg{color:var(--amber);flex-shrink:0;margin-top:.1rem}

/* Contact form */
.form-box{
  background:var(--white);border-radius:var(--r-xl);
  padding:clamp(2rem,4vw,3rem);box-shadow:var(--s-lg);border:1px solid var(--border);
}
.form-box h2{font-size:2rem;margin-bottom:.5rem}
.form-box .lead{margin-bottom:2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{margin-bottom:1.25rem}
label{
  display:block;font-size:.72rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;color:var(--text-mid);margin-bottom:.5rem;
}
label span[aria-hidden]{color:var(--amber)}
input,select,textarea{
  width:100%;padding:.85rem 1rem;border:1.5px solid var(--border);border-radius:var(--r);
  background:var(--cream);font-family:var(--font-sans);font-size:.9rem;color:var(--text);
  transition:border-color .25s,box-shadow .25s;outline:none;-webkit-appearance:none;appearance:none;
}
input::placeholder,textarea::placeholder{color:var(--text-muted)}
input:focus,select:focus,textarea:focus{border-color:var(--moss);box-shadow:0 0 0 3px rgba(74,122,90,.12)}
textarea{resize:vertical;min-height:130px}

/* Map section */
.map-section{margin:0;padding:0;background:var(--sand-light)}
.map-wrap iframe{display:block;width:100%;height:480px;border:0}

/* =============================================
   RESERVEREN PAGE
   ============================================= */
.booking-page-section{background:var(--cream)}
.booking-page-layout{display:grid;grid-template-columns:1fr 400px;gap:3rem;align-items:start}
.booking-page-widget .booking-widget-outer{
  background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);
  box-shadow:var(--s-lg);min-height:400px;padding:2.5rem;
}
.booking-page-widget .booking-widget-placeholder{color:var(--text-mid)}
.booking-page-widget .booking-widget-placeholder svg{color:var(--moss)}
.booking-page-sidebar{display:flex;flex-direction:column;gap:1.25rem}
.booking-info-card{
  background:var(--white);border-radius:var(--r-lg);padding:1.75rem;
  border:1px solid var(--border);box-shadow:var(--s-sm);
}
.booking-info-card h3{font-size:1.25rem;margin-bottom:1.25rem;color:var(--text)}
.booking-info-card--sand{background:var(--sand-light)}
.booking-steps{display:flex;flex-direction:column;gap:1.1rem;list-style:none;padding:0}
.booking-steps li{display:flex;align-items:flex-start;gap:.85rem}
.step-num{
  width:28px;height:28px;border-radius:50%;background:var(--forest);color:var(--sand);
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font-size:.78rem;font-weight:700;font-family:var(--font-sans);
  margin-top:.1rem;
}
.booking-steps li strong{display:block;font-size:.9rem;color:var(--text);margin-bottom:.1rem}
.booking-steps li p{font-size:.82rem;color:var(--text-muted);line-height:1.55}
.booking-tips{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.25rem}
.booking-tips li{
  display:flex;align-items:flex-start;gap:.6rem;
  font-size:.85rem;color:var(--text-mid);
}
.booking-tips li svg{color:var(--moss);flex-shrink:0;margin-top:.12rem;width:16px;height:16px}
.booking-contact-card{
  background:var(--forest);border-radius:var(--r-lg);padding:1.5rem;
}
.booking-contact-card p{color:rgba(255,255,255,.6);font-size:.85rem;margin-bottom:.75rem}
.booking-phone{
  display:flex;align-items:center;gap:.6rem;
  font-size:1.1rem;font-weight:600;color:var(--sand);letter-spacing:.01em;
}
.booking-phone svg{color:var(--moss-light)}

/* =============================================
   GALLERY PAGE
   ============================================= */
.gallery-page-section{background:var(--cream)}
.gallery-filters{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2.5rem}
.gallery-filter{
  padding:.6rem 1.4rem;border-radius:100px;font-size:.8rem;font-weight:600;
  border:1.5px solid var(--border);color:var(--text-mid);
  transition:all .25s;cursor:pointer;background:var(--white);
}
.gallery-filter.active,.gallery-filter:hover{
  background:var(--forest);color:var(--white);border-color:var(--forest);
}
.gallery-masonry{
  columns:3;gap:1.25rem;
}
.gallery-item{
  break-inside:avoid;border-radius:var(--r-lg);overflow:hidden;
  position:relative;margin-bottom:1.25rem;display:block;
}
.gallery-item img{width:100%;display:block;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-item figcaption{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top, rgba(30,61,47,.8) 0%, transparent 100%);
  padding:1.5rem 1rem .75rem;font-size:.75rem;color:rgba(255,255,255,.8);
  opacity:0;transition:opacity .3s;
}
.gallery-item:hover figcaption{opacity:1}
.gallery-item--wide{break-inside:avoid}

/* Gallery own photos note */
.gallery-own-photos-note{
  margin-top:3rem;padding:1.75rem 2rem;
  background:var(--white);border-radius:var(--r-xl);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
  box-shadow:var(--s-sm);
}
.gallery-own-photos-note p{font-size:.95rem;color:var(--text-mid);margin:0}

/* =============================================
   ARTICLE / SEO PAGES
   ============================================= */
.article-section{background:var(--cream)}
.article-layout{display:grid;grid-template-columns:1fr 340px;gap:4rem;align-items:start}
.article-body h2{font-size:clamp(1.8rem,3.5vw,2.8rem);margin-bottom:1.25rem}
.article-body h3{font-size:1.5rem;margin:2.25rem 0 .75rem}
.article-body p{color:var(--text-mid);margin-bottom:1rem;line-height:1.8}
.article-body a:not(.btn){color:var(--moss);text-decoration:underline;text-underline-offset:3px}
.article-body a:hover{color:var(--forest)}
.article-list{margin:1rem 0 2rem 0;display:flex;flex-direction:column;gap:1rem}
.article-list li{
  padding:1rem 1.25rem 1rem 1rem;
  background:var(--white);border-radius:var(--r-lg);border:1px solid var(--border);
  font-size:.9rem;color:var(--text-mid);line-height:1.6;
}
.article-list li strong{display:block;color:var(--text);margin-bottom:.2rem;font-family:var(--font-serif)}
.article-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border)}
@media(max-width:600px){
  .article-cta{flex-direction:column}
  .article-cta .btn{width:100%;justify-content:center}
}

/* Article sidebar */
.article-sidebar{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:calc(var(--nav-h) + 2rem)}
.sidebar-card{
  background:var(--white);border-radius:var(--r-lg);padding:1.75rem;
  border:1px solid var(--border);box-shadow:var(--s-sm);
}
.sidebar-card h3{font-size:1.1rem;margin-bottom:1rem;color:var(--text)}
.sidebar-card--forest{background:var(--forest)}
.sidebar-card--forest h3{color:var(--white)}
.sidebar-card--forest p{color:rgba(255,255,255,.55);font-size:.85rem;margin-bottom:.5rem}
.sidebar-links{display:flex;flex-direction:column}
.sidebar-links li{border-bottom:1px solid var(--border)}
.sidebar-links li:last-child{border-bottom:none}
.sidebar-links a{
  display:flex;align-items:center;padding:.7rem 0;
  font-size:.88rem;color:var(--text-mid);transition:color .2s;
}
.sidebar-links a::after{content:'›';margin-left:auto;color:var(--text-muted)}
.sidebar-links a:hover{color:var(--moss)}
.sidebar-price{
  display:flex;align-items:flex-end;gap:.3rem;margin-bottom:.5rem;
}
.sidebar-price .euro{font-family:var(--font-serif);font-size:1.4rem;color:var(--sand);line-height:1.2}
.sidebar-price .amount{font-family:var(--font-serif);font-size:3.5rem;color:var(--sand);line-height:1}
.sidebar-price .per{font-size:.8rem;color:rgba(255,255,255,.45);padding-bottom:.5rem}
.sidebar-distances{display:flex;flex-direction:column;gap:.5rem}
.sidebar-distances li{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.85rem;color:var(--text-mid);padding:.4rem 0;border-bottom:1px solid var(--border);
}
.sidebar-distances li:last-child{border-bottom:none}
.sidebar-distances li strong{color:var(--text);font-weight:600}
.sidebar-phone{
  display:flex;align-items:center;gap:.5rem;
  font-size:1.1rem;font-weight:600;color:var(--sand);
}
address{font-style:normal;font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.8}
address a{color:rgba(255,255,255,.5);transition:color .2s}
address a:hover{color:var(--sand)}

/* =============================================
   FOOTER
   ============================================= */
.footer{background:var(--forest);padding:80px 0 0;color:rgba(255,255,255,.5)}
.footer__inner{
  display:grid;grid-template-columns:1.8fr 1fr 1fr 1.2fr;
  gap:3rem;padding-bottom:3.5rem;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.footer__brand .footer__logo{
  display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;
  transition:opacity .3s;
}
.footer__brand .footer__logo:hover{opacity:.8}
.footer__brand .footer__logo img{
  height:150px;width:auto;
}
.footer__brand p{font-size:.85rem;color:rgba(255,255,255,.38);line-height:1.75;max-width:260px}

.footer__nav h4,.footer__contact h4{
  font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.25);margin-bottom:1.25rem;font-family:var(--font-sans);
}
.footer__nav ul{display:flex;flex-direction:column;gap:.65rem}
.footer__nav a{font-size:.85rem;color:rgba(255,255,255,.45);transition:color .2s}
.footer__nav a:hover{color:var(--sand)}
.footer__contact address{font-style:normal;font-size:.85rem;color:rgba(255,255,255,.45);line-height:1.9}
.footer__contact address p{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.75rem}
.footer__contact address svg{flex-shrink:0;margin-top:.25rem;opacity:.6}
.footer__contact address a{color:rgba(255,255,255,.45);transition:color .2s}
.footer__contact address a:hover{color:var(--sand)}

.footer__bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding:.75rem 0;font-size:.76rem;color:rgba(255,255,255,.2);flex-wrap:wrap;gap:.5rem;
}
.footer__bottom a{color:rgba(255,255,255,.2);transition:color .2s}
.footer__bottom a:hover{color:var(--sand)}
.footer-svr-logo{height:44px;width:auto;vertical-align:middle;opacity:.9}


/* =============================================
   FLOATING PHONE BUTTON
   ============================================= */
.phone-float{
  position:fixed;bottom:2rem;right:2rem;z-index:150;
  width:52px;height:52px;border-radius:50%;
  background:var(--forest);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--s-md);
  transition:transform .3s,box-shadow .3s;
}
.phone-float:hover{transform:translateY(-3px);box-shadow:var(--s-lg)}
.phone-float svg{width:20px;height:20px}

/* =============================================
   ANIMATIONS
   ============================================= */
[data-fade]{opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.25,.46,.45,.94),transform .75s cubic-bezier(.25,.46,.45,.94)}
[data-fade].visible{opacity:1;transform:none}
[data-delay="0"]{transition-delay:0s}
[data-delay="60"]{transition-delay:.06s}
[data-delay="80"]{transition-delay:.08s}
[data-delay="100"]{transition-delay:.1s}
[data-delay="120"]{transition-delay:.12s}
[data-delay="150"]{transition-delay:.15s}
[data-delay="160"]{transition-delay:.16s}
[data-delay="180"]{transition-delay:.18s}
[data-delay="200"]{transition-delay:.2s}
[data-delay="240"]{transition-delay:.24s}
[data-delay="300"]{transition-delay:.3s}

/* =============================================
   RESPONSIVE
   ============================================= */
@media(max-width:1200px){
  .article-layout{grid-template-columns:1fr 280px;gap:2.5rem}
  .booking-page-layout{grid-template-columns:1fr 340px}
}

@media(max-width:1024px){
  .nav__links,.nav__links .btn{display:none}
  .nav__toggle{display:flex}
  .hero__content{justify-content:center}
  .hero-card{max-width:100%}
  .intro-grid{grid-template-columns:1fr;gap:3rem}
  .intro-image-wrap img{height:400px}
  .intro-stat-card{display:none}
  .location-grid{grid-template-columns:1fr 1fr}
  .facilities-grid{grid-template-columns:1fr 1fr}
  .price-cards-row{grid-template-columns:1fr}
  .price-hero-card{grid-template-columns:1fr}
  .price-hero-card__left{padding:2.5rem}
  .reviews-grid{grid-template-columns:1fr 1fr}
  .contact-layout{grid-template-columns:1fr;gap:2.5rem}
  .article-layout{grid-template-columns:1fr;gap:2.5rem}
  .article-sidebar{position:static;display:grid;grid-template-columns:repeat(2,1fr)}
  .booking-page-layout{grid-template-columns:1fr}
  .gallery-masonry{columns:2}
  .footer__inner{grid-template-columns:1fr 1fr;gap:2.5rem}
  .cta-banner__inner{flex-direction:column;text-align:center}
  .cta-banner__text p{margin-inline:auto}
}

@media(max-width:768px){
  :root{--nav-h:80px}
  .nav__logo img{height:64px}

  /* Hero kaart omhoog + geen interne scroll */
  .hero__content{padding-top:calc(var(--nav-h) + 1rem);padding-bottom:1.5rem;align-items:flex-end}
  .hero-card{padding:1.5rem;max-height:none;overflow-y:visible}
  .hero-card h1{margin-bottom:.5rem}
  .hero-card .lead{margin-bottom:.85rem}
  .hero-card__price{padding:.65rem .85rem;margin-bottom:1rem}
  .hero-card__actions{gap:.5rem}

  .location-grid{grid-template-columns:1fr}
  .facilities-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .rules-grid{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr;gap:2rem}
  .footer__bottom{flex-direction:column;text-align:center}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gallery-thumb{min-height:200px}
  .gallery-thumb:nth-child(1),.gallery-thumb.g-tall{grid-column:1/3;grid-row:auto;min-height:260px}
  .gallery-thumb:nth-child(4),.gallery-thumb.g-wide{grid-column:1/3;grid-row:auto;min-height:220px}
  .gallery-thumb:nth-child(2),.gallery-thumb:nth-child(3),.gallery-thumb:nth-child(5){grid-column:auto;grid-row:auto}
  .gallery-masonry{columns:2}
  .article-sidebar{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .tarieven-table th:last-child,.tarieven-table td:last-child{display:none}
  .booking-page-sidebar{display:none}
}

@media(max-width:480px){
  :root{--nav-h:64px}
  .container{width:calc(100% - 2rem)}
  h1{font-size:2.4rem}

  /* Hero kaart — klein scherm */
  .hero__content{padding-top:calc(var(--nav-h) + .75rem);padding-bottom:1rem}
  .hero-card{padding:1.1rem;max-height:none;overflow-y:visible}
  .hero-card h1{font-size:1.6rem;margin-bottom:.35rem}
  .hero-card .lead{font-size:.87rem;margin-bottom:.6rem}
  .hero-card__price{padding:.5rem .7rem;margin-bottom:.65rem;gap:.3rem}
  .price-amount{font-size:1.85rem}
  .hero-card__actions{gap:.4rem}
  .gallery-grid{grid-template-columns:1fr}
  .gallery-thumb:nth-child(n){grid-column:auto;min-height:200px}
  .gallery-masonry{columns:1}
  .price-hero-card__left{padding:2rem}
  .amount-big{font-size:4rem}

  /* Tarieven blokken — homepage */
  .price-extras-card{padding:1.25rem}
  .price-extras-card h3{font-size:1.15rem}
  .extras-table td{padding:.5rem .35rem;font-size:.8rem}
  .extras-table td:last-child{white-space:normal;word-break:break-word}
  .price-card__list{padding:1.25rem}
  .price-card .btn{margin:0 1.25rem 1.25rem;width:calc(100% - 2.5rem)}
}

/* =============================================
   CONTACT FORM 7 — match site design
   ============================================= */
.wpcf7-form .form-group{margin-bottom:1.25rem}
.wpcf7-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:0}
.wpcf7-form .form-row .form-group{margin-bottom:0}

/* Span-wrapper verwijder visuele impact */
.wpcf7-form-control-wrap{display:block}

/* Inputs overnemen van site-stijl (al globaal gestyled, maar CF7 reset soms) */
.wpcf7-form-control.wpcf7-text,
.wpcf7-form-control.wpcf7-email,
.wpcf7-form-control.wpcf7-tel,
.wpcf7-form-control.wpcf7-select,
.wpcf7-form-control.wpcf7-textarea{
  width:100%;padding:.85rem 1rem;border:1.5px solid var(--border);border-radius:var(--r);
  background:var(--cream);font-family:var(--font-sans);font-size:.9rem;color:var(--text);
  transition:border-color .25s,box-shadow .25s;outline:none;-webkit-appearance:none;appearance:none;
}
.wpcf7-form-control.wpcf7-text:focus,
.wpcf7-form-control.wpcf7-email:focus,
.wpcf7-form-control.wpcf7-tel:focus,
.wpcf7-form-control.wpcf7-select:focus,
.wpcf7-form-control.wpcf7-textarea:focus{border-color:var(--moss);box-shadow:0 0 0 3px rgba(74,122,90,.12)}
.wpcf7-form-control.wpcf7-textarea{resize:vertical;min-height:130px}

/* GDPR checkbox */
.cf7-gdpr .wpcf7-acceptance{display:flex;align-items:flex-start;gap:.6rem}
.cf7-gdpr .wpcf7-acceptance input[type="checkbox"]{
  width:18px;height:18px;flex-shrink:0;margin-top:.1rem;
  accent-color:var(--forest);cursor:pointer;
}
.cf7-gdpr .wpcf7-list-item{display:flex;gap:.6rem;align-items:flex-start}
.cf7-gdpr .wpcf7-list-item-label{font-size:.875rem;color:var(--text-mid);line-height:1.5}
.cf7-gdpr .wpcf7-list-item-label a{color:var(--forest);text-decoration:underline}

/* Submit knop */
.wpcf7-form .wpcf7-submit{
  width:100%;justify-content:center;margin-top:.5rem;
  display:block;cursor:pointer;
}

/* Validatie feedback */
.wpcf7-not-valid-tip{font-size:.75rem;color:#c0392b;margin-top:.3rem;display:block}
.wpcf7-form-control.wpcf7-not-valid{border-color:#c0392b !important}
.wpcf7-response-output{
  margin-top:1.25rem;padding:.85rem 1rem;border-radius:var(--r);font-size:.88rem;border:1px solid transparent;
}
.wpcf7-form.sent .wpcf7-response-output{background:#d4edda;border-color:#c3e6cb;color:#155724}
.wpcf7-form.failed .wpcf7-response-output,
.wpcf7-form.spam .wpcf7-response-output{background:#f8d7da;border-color:#f5c6cb;color:#721c24}
.wpcf7-form.invalid .wpcf7-response-output{background:#fff3cd;border-color:#ffeeba;color:#856404}

/* Spinner verbergen (optioneel) */
.wpcf7-spinner{display:none}

@media(max-width:640px){
  .wpcf7-form .form-row{grid-template-columns:1fr}
  .wpcf7-form .form-row .form-group{margin-bottom:1.25rem}
}
