/* Casa Palma Vista — Gedeelde stijlen */
:root{
  --sand-50:    #FBF7F0;
  --sand-100:   #F5EDE0;
  --sand-200:   #E8D9C0;
  --sand-300:   #D4BE98;
  --terra-dark:  #8F5F5A;
  --terra-mid:   #4A6A64;
  --amber:        #E5BA90;
  --terra-light: #ECCEB1;
  --gold:        #C4A882;
  --wenge:       #3A2D1A;
  --wenge-mid:   #5C4630;
  --stone:       #7D6A52;
  --stone-light: #C4B090;
  --white:       #FFFFFF;
  --focus:       #1D4ED8;
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-sans:  'Nunito Sans', 'Segoe UI', sans-serif;
  --page-pad: clamp(20px, 5.5vw, 80px);
  --sec-gap:  clamp(56px, 9vw, 104px);
  --r:  5px;
  --rl: 12px;
  --sh-sm: 0 2px 8px rgba(48,40,30,.08);
  --sh-md: 0 4px 24px rgba(48,40,30,.13);
  --sh-lg: 0 8px 40px rgba(48,40,30,.18);
}
    
*,*::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(--sand-50);color:var(--wenge);line-height:1.65;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--terra-mid)}
a:hover{color:var(--wenge)}
:focus-visible{outline:3px solid var(--focus);outline-offset:3px;border-radius:var(--r)}
.skip-link{position:absolute;top:-9999px;left:16px;background:var(--focus);color:#fff;padding:10px 18px;border-radius:var(--r);font-size:14px;font-weight:600;z-index:9999;text-decoration:none}
.skip-link:focus{top:16px}

/* Lang bar */
.lang-bar{display:none}
.lang-btn{background:transparent;border:1px solid transparent;color:var(--wenge-mid);font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;min-width:44px;min-height:44px;padding:0 8px;border-radius:var(--r);display:inline-flex;align-items:center;justify-content:center;transition:all .2s}
.lang-btn:hover{color:var(--wenge);background:rgba(48,40,30,.12)}
.lang-btn.active{color:var(--wenge);background:rgba(48,40,30,.18);border-color:rgba(48,40,30,.4)}
.lang-sep{color:rgba(255,255,255,.15);font-size:11px;user-select:none;pointer-events:none;padding:0 2px}

/* Nav */
.site-header{position:sticky;top:0;z-index:200;background:rgba(249,247,241,.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--sand-200);transition:box-shadow .3s}
.site-header.scrolled{box-shadow:var(--sh-md)}
.nav-inner{max-width:1320px;margin:0 auto;padding:0 var(--page-pad);height:68px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.nav-logo img{height:44px;width:auto;display:block;object-fit:contain}
.nav-links{list-style:none;display:flex;align-items:center;gap:clamp(12px,2vw,28px)}
.nav-links a{font-size:11.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--wenge-mid);text-decoration:none;padding:4px 0;position:relative;white-space:nowrap;transition:color .2s}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--terra-mid);border-radius:1px;transition:width .3s}
.nav-links a:hover{color:var(--terra-dark)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--terra-dark)}
.nav-cta{background:var(--terra-dark)!important;color:#fff!important;padding:10px 20px!important;border-radius:var(--r)!important;min-height:44px;display:inline-flex!important;align-items:center}
.nav-cta:hover{background:var(--wenge)!important}
.nav-cta::after{display:none!important}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;background:none;border:1px solid var(--sand-200);border-radius:var(--r);padding:10px;min-width:44px;min-height:44px;transition:background .2s}
.hamburger:hover{background:var(--sand-100)}
.hamburger span{display:block;width:22px;height:2px;background:var(--wenge);border-radius:1px;transform-origin:center;transition:transform .3s,opacity .3s}
.hamburger[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded=true] span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mob-menu{display:none;position:fixed;inset:0;z-index:199}
.mob-menu.open{display:block}
.mob-overlay{position:absolute;inset:0;background:rgba(48,40,30,.45);backdrop-filter:blur(2px);cursor:pointer}
.mob-drawer{position:absolute;top:0;right:0;width:min(320px,86vw);height:100%;background:var(--sand-50);box-shadow:var(--sh-lg);overflow-y:auto;padding:80px 28px 40px;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1)}
.mob-menu.open .mob-drawer{transform:translateX(0)}
.mob-links{list-style:none;display:flex;flex-direction:column;gap:2px}
.mob-links a{display:block;font-size:16px;font-weight:600;color:var(--wenge);text-decoration:none;padding:14px 4px;border-bottom:1px solid var(--sand-200);transition:color .2s,padding-left .2s}
.mob-links a:hover{color:var(--terra-dark);padding-left:10px}
.mob-cta{margin-top:20px!important;background:var(--terra-dark)!important;color:#fff!important;border-radius:var(--r)!important;text-align:center!important;padding:16px!important;border-bottom:none!important}
.mob-cta:hover{background:var(--wenge)!important;color:#fff!important;padding-left:4px!important}

/* Buttons */
.btn-primary,.btn-ghost,.btn-outline{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-sans);font-size:11.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;text-decoration:none;padding:14px 28px;border-radius:var(--r);border:2px solid transparent;cursor:pointer;min-height:48px;white-space:nowrap;transition:background .22s,color .22s,border-color .22s,transform .18s}
.btn-primary{background:var(--terra-dark);color:#fff;border-color:var(--terra-dark)}
.btn-primary:hover{background:var(--wenge);border-color:var(--wenge);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-outline{background:transparent;color:var(--terra-dark);border-color:var(--terra-dark)}
.btn-outline:hover{background:var(--terra-dark);color:#fff}

/* Typography helpers */
.section{max-width:1320px;margin:0 auto;padding:var(--sec-gap) var(--page-pad)}
.sec-label{font-size:10px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--terra-mid);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.sec-label::before{content:'';width:20px;height:2px;background:var(--terra-mid);border-radius:1px;flex-shrink:0}
.sec-label.c{justify-content:center}.sec-label.c::before{display:none}
h2.disp{font-family:var(--font-serif);font-size:clamp(28px,4.2vw,50px);font-weight:400;color:var(--wenge);line-height:1.18;margin-bottom:20px}
h2.disp em{font-style:italic;color:var(--terra-mid)}
.bt{font-size:clamp(14px,1.5vw,15.5px);font-weight:300;color:var(--wenge-mid);line-height:1.85;margin-bottom:14px}

/* Page hero (subpages) */
.page-hero{background:var(--sand-100);border-bottom:1px solid var(--sand-200);padding:clamp(24px,3vw,36px) var(--page-pad);}
.page-hero::after{display:none}
.ph-inner{max-width:1320px;margin:0 auto}
.eyebrow{font-size:10px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--terra-mid);margin-bottom:10px;display:flex;align-items:center;gap:10px}
.eyebrow::before{content:'';width:20px;height:1px;background:var(--terra-mid);flex-shrink:0}
.page-hero h1{font-family:var(--font-serif);font-size:clamp(24px,3.5vw,40px);font-weight:400;color:var(--wenge);line-height:1.15;margin-bottom:8px}
.page-hero h1 em{font-style:italic;color:var(--wenge);font-weight:300;color:rgba(58,45,26,.78);line-height:1.8;max-width:560px}
.page-hero .sub,.ph-inner .sub{color:var(--wenge-mid,#5C4630);font-size:clamp(14px,1.5vw,17px);line-height:1.6;margin-top:6px;max-width:600px}

/* Footer */
footer{background:#3A2D1A;color:rgba(255,255,255,.88);padding:clamp(28px,4vw,44px) var(--page-pad) 24px}
.foot-inner{max-width:1320px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-bottom:24px}
.foot-logo img{height:38px;width:auto;display:block;object-fit:contain;filter:brightness(0) invert(1);opacity:.85}
.foot-links{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.foot-link{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.88);text-decoration:none;font-size:13px;font-weight:300;transition:color .2s;padding:6px 0;min-height:44px}
.foot-link:hover{color:#fff}
.foot-link svg{width:18px;height:18px;flex-shrink:0;color:var(--terra-mid)}
.foot-link span{white-space:nowrap}
.foot-sep{width:1px;height:18px;background:rgba(255,255,255,.12);flex-shrink:0}
.foot-bottom{max-width:1320px;margin:0 auto;border-top:1px solid rgba(255,255,255,.08);padding-top:16px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;font-size:11px;color:rgba(255,255,255,.65)}
.nra{font-size:10px;word-break:break-all;max-width:560px}
@media(max-width:600px){.foot-inner{flex-direction:column;align-items:flex-start;gap:16px}.foot-links{gap:12px}.foot-bottom{flex-direction:column;align-items:flex-start}}


/* Taal dropdown in nav */
.nav-lang{position:relative;margin-left:8px}
.nav-lang-btn{background:var(--sand-100);border:1px solid var(--sand-200);border-radius:var(--r);padding:6px 10px;cursor:pointer;font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--wenge-mid);display:inline-flex;align-items:center;gap:6px;min-height:36px;transition:background .2s,border-color .2s;white-space:nowrap}
.nav-lang-btn:hover{background:var(--sand-200);border-color:var(--sand-300)}
.nav-lang-btn .flag{display:inline-flex;align-items:center;flex-shrink:0;line-height:1}
.nav-lang-btn .flag svg{width:16px;height:12px;border-radius:1px;display:block}
.lang-option .flag{display:inline-flex;align-items:center;flex-shrink:0}
.lang-option .flag svg{width:16px;height:12px;border-radius:1px;display:block}
.mob-lang-btn .flag{display:inline-flex;align-items:center;flex-shrink:0}
.mob-lang-btn .flag svg{width:16px;height:12px;border-radius:1px;display:block}
.nav-lang-btn .chevron{width:10px;height:10px;transition:transform .2s;flex-shrink:0}
.nav-lang.open .nav-lang-btn .chevron{transform:rotate(180deg)}
.nav-lang-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid var(--sand-200);border-radius:var(--rl);box-shadow:var(--sh-md);min-width:140px;overflow:hidden;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .2s,transform .2s,visibility .2s;z-index:300}
.nav-lang.open .nav-lang-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.lang-option{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:13px;font-weight:400;color:var(--wenge-mid);cursor:pointer;transition:background .15s;border:none;background:none;width:100%;text-align:left;font-family:var(--font-sans)}
.lang-option:hover{background:var(--sand-50)}
.lang-option.active{background:var(--sand-100);color:var(--wenge);font-weight:700}
.lang-option .flag{font-size:16px;line-height:1;flex-shrink:0}
.lang-option .lbl{flex:1}
/* Mobiel: taal in drawer */
.mob-lang{padding:20px 0 0;border-top:1px solid var(--sand-200);margin-top:8px}
.mob-lang h5{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--stone-light);margin-bottom:10px}
.mob-lang-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.mob-lang-btn{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--r);border:1px solid var(--sand-200);background:none;cursor:pointer;font-size:13px;font-weight:400;color:var(--wenge-mid);font-family:var(--font-sans);transition:background .15s}
.mob-lang-btn:hover{background:var(--sand-100)}
.mob-lang-btn.active{background:var(--sand-100);color:var(--wenge);font-weight:700;border-color:var(--sand-300)}
.mob-lang-btn .flag{font-size:16px}

/* Reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:none}

/* Responsive */
@media(max-width:768px){.nav-links{display:none}.hamburger{display:flex}}
@media(max-width:1024px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}.foot-bottom{flex-direction:column}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}

    
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:32px}
.why-card{background:#fff;border:1px solid var(--sand-200);border-radius:var(--rl);padding:28px 24px}
.why-icon{width:36px;height:36px;color:var(--terra-mid);margin-bottom:14px}
.why-card h3{font-family:var(--font-serif);font-size:18px;font-weight:600;color:var(--wenge);margin-bottom:8px}
.why-card p{font-size:14px;font-weight:300;color:var(--wenge-mid);line-height:1.75}
@media(max-width:520px){.why-grid{grid-template-columns:1fr}}

.dist-icon{display:flex;align-items:center;color:var(--terra-mid);flex-shrink:0}
/* Compacte paginatitel (vervangt page-hero) */
.page-title{background:var(--sand-100);border-bottom:1px solid var(--sand-200);padding:clamp(28px,3.5vw,44px) var(--page-pad)}
.page-title-inner{max-width:1320px;margin:0 auto}
.page-title h1{font-family:var(--font-serif);font-size:clamp(26px,4vw,44px);font-weight:400;color:var(--wenge);line-height:1.15;margin:0}
.page-title h1 em{font-style:italic;color:var(--terra-dark)}

/* Quote blok — Over ons pagina */
.about-quote{
  position:relative;
  margin:32px 0 8px;
  padding:24px 28px 24px 36px;
  border-left:3px solid var(--terra-mid);
  background:var(--sand-100);
  border-radius:0 var(--rl) var(--rl) 0;
}
.about-quote::before{
  content:'\201C';
  position:absolute;
  top:-8px;
  left:10px;
  font-family:var(--font-serif);
  font-size:72px;
  line-height:1;
  color:var(--terra-mid);
  opacity:.35;
  pointer-events:none;
}
.about-quote p{
  font-family:var(--font-serif);
  font-size:clamp(16px,2vw,20px);
  font-style:italic;
  font-weight:400;
  color:var(--wenge);
  line-height:1.7;
  margin:0;
}
.about-sign{
  font-style:italic;
  color:var(--wenge-mid);
  margin-top:28px !important;
  font-size:14px;
}
.about-sign-name{
  font-family:var(--font-serif);
  font-size:17px;
  font-weight:600;
  color:var(--wenge);
  margin-top:4px !important;
}

/* ── Cookie banner & modal ─────────────────────────────────── */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#fff;border-top:3px solid var(--amber);box-shadow:0 -4px 24px rgba(58,45,26,.12);padding:20px var(--page-pad) 24px;transform:translateY(100%);transition:transform .4s cubic-bezier(.16,1,.3,1)}
#cookie-banner.visible{transform:translateY(0)}
.ck-inner{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:16px 40px;align-items:start}
.ck-text h3{font-family:var(--font-serif);font-size:17px;font-weight:400;color:var(--wenge);margin-bottom:6px}
.ck-text p{font-size:13px;color:var(--wenge-mid);line-height:1.6;max-width:600px}
.ck-text a{color:var(--terra-mid);text-decoration:underline}
.ck-btns{display:flex;gap:10px;align-items:center;flex-wrap:wrap;flex-shrink:0}
.ck-accept{background:var(--terra-dark);color:#fff;border:none;padding:11px 22px;border-radius:var(--rl);font-size:13px;font-weight:700;cursor:pointer;letter-spacing:.04em;white-space:nowrap;transition:background .2s}
.ck-accept:hover{background:var(--wenge)}
.ck-functional{background:transparent;color:var(--wenge);border:1.5px solid var(--sand-300);padding:10px 18px;border-radius:var(--rl);font-size:13px;cursor:pointer;white-space:nowrap;transition:all .2s}
.ck-functional:hover{background:var(--sand-100);border-color:var(--wenge)}
.ck-settings-btn{background:none;border:none;color:var(--stone);font-size:12px;cursor:pointer;text-decoration:underline;padding:4px;white-space:nowrap}
.ck-settings-btn:hover{color:var(--wenge)}
#cookie-modal{position:fixed;inset:0;z-index:10000;background:rgba(58,45,26,.55);display:flex;align-items:center;justify-content:center;padding:var(--page-pad);opacity:0;pointer-events:none;transition:opacity .3s}
#cookie-modal.visible{opacity:1;pointer-events:all}
.ck-modal-box{background:#fff;border-radius:12px;max-width:520px;width:100%;padding:32px 28px;box-shadow:0 20px 60px rgba(58,45,26,.2);max-height:85vh;overflow-y:auto}
.ck-modal-box h3{font-family:var(--font-serif);font-size:20px;font-weight:400;color:var(--wenge);margin-bottom:16px}
.ck-toggle-row{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--sand-200)}
.ck-toggle-row:last-of-type{border-bottom:none}
.ck-toggle-info h4{font-size:14px;font-weight:700;color:var(--wenge);margin-bottom:3px}
.ck-toggle-info p{font-size:12px;color:var(--stone);line-height:1.5;max-width:360px}
.ck-toggle{position:relative;width:40px;height:22px;flex-shrink:0;margin-left:16px;margin-top:2px}
.ck-toggle input{opacity:0;width:0;height:0}
.ck-slider{position:absolute;inset:0;cursor:pointer;background:#ccc;border-radius:22px;transition:.3s}
.ck-slider::before{content:'';position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}
.ck-toggle input:checked+.ck-slider{background:var(--terra-dark)}
.ck-toggle input:checked+.ck-slider::before{transform:translateX(18px)}
.ck-toggle input:disabled+.ck-slider{background:var(--terra-mid);opacity:.7;cursor:not-allowed}
.ck-modal-btns{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}
.ck-save{background:var(--terra-dark);color:#fff;border:none;padding:11px 22px;border-radius:var(--rl);font-size:13px;font-weight:700;cursor:pointer;flex:1;min-width:140px;transition:background .2s}
.ck-save:hover{background:var(--wenge)}
.ck-close-modal{background:transparent;color:var(--wenge);border:1.5px solid var(--sand-300);padding:10px 16px;border-radius:var(--rl);font-size:13px;cursor:pointer;transition:all .2s}
.ck-close-modal:hover{border-color:var(--wenge)}
.ck-footer-wrap{text-align:center;padding:6px var(--page-pad) 10px;border-top:1px solid rgba(255,255,255,.06)}
.ck-footer-link{font-size:11px;color:rgba(255,255,255,.55);cursor:pointer;background:none;border:none;text-decoration:underline;padding:2px 0;font-family:inherit}
.ck-footer-link:hover{color:rgba(255,255,255,.9)}
@media(max-width:700px){.ck-inner{grid-template-columns:1fr}.ck-btns{justify-content:flex-start}}

/* Privacy pagina */
.privacy-h2{font-family:var(--font-serif);font-size:clamp(17px,2vw,22px);font-weight:400;color:var(--wenge);margin:36px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--sand-200)}
.privacy-list{padding-left:24px;margin:10px 0 16px}
.privacy-list li{font-size:15px;color:var(--wenge-mid);line-height:1.75;margin-bottom:6px}

/* Mobile: stack over-ons grid */
.over-ons-grid{grid-template-columns:1fr 1fr}
@media(max-width:700px){
  .over-ons-grid{grid-template-columns:1fr}
}
