/* Whitney's Beauty Addicts – Luxe Theme v6.21 (stable + iOS fixes)
   - Mobiel menu (scroll-proof, iOS/Android/desktop)
   - Correcte z-index: header(2000) < backdrop(2050) < panel(2100)
   - Dropdown desktop: hover/focus; mobiel: in panel
   - Toegankelijkheid, focus-visible & prefers-reduced-motion
   - Utilities: container, grid, sections, buttons, badges
*/

/* ===================== 1) Design tokens ===================== */
:root{
  --maxw:1200px;
  --radius:16px;
  --radius-lg:20px;
  --shadow:0 18px 40px rgba(0,0,0,.08);
  --shadow-lg:0 24px 60px rgba(0,0,0,.12);

  --bg:#f6f5ec;
  --panel:#fff;
  --card:#fff;
  --border:#e6dfd6;

  --text:#111;
  --muted:#6d5b54;

  --menu:#2f261f;
  --menu-hover:#000;

  --btn-start:#d1b7a1;
  --btn-end:#efe6dc;

  --thumb-ratio:4/3;
  --thumb-fit:contain;
  --thumb-bg:#00000010;

  --btn-shift-duration:.6s;
}

/* ===================== 2) Reset / Base ===================== */
*{box-sizing:border-box}
html,body{margin:0;max-width:100%;overflow-x:hidden}
body{
  background:var(--bg);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,video,svg{max-width:100%;height:auto;display:block}
img[width][height]{height:auto}
a{color:inherit;text-decoration:none;transition:color .2s,background .2s,border-color .2s,opacity .2s}
a:hover{color:#111}
h1,h2,h3{font-family:"Playfair Display",serif;margin:0 0 .6rem}
h1{font-size:clamp(26px,5.6vw,38px);line-height:1.2}
:where(p,li,small,label,input,textarea,button){color:var(--text)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
.sr-only-focusable:focus{position:static;width:auto;height:auto;clip:auto;white-space:normal;padding:8px;border-radius:8px;background:#fff;border:1px solid var(--border)}
:focus-visible{outline:3px solid color-mix(in srgb, var(--btn-start) 60%, transparent);outline-offset:2px}

.content-clip{overflow-x:clip}
a,p,li,h1,h2,h3{overflow-wrap:anywhere;word-break:break-word}

/* Utilities */
.container{max-width:var(--maxw);margin:0 auto;padding:0 16px}
.section{padding:28px 0}
.text-center{text-align:center}
.meta{color:var(--muted)}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}

/* Grid helpers */
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:980px){.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* ===================== 3) Header / Navigatie ===================== */
.nav{position:sticky;top:0;z-index:2000;background:#fff !important;border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;max-width:var(--maxw);margin:0 auto;padding:10px 16px}
.brand img{width:240px;height:auto}

.menu{display:flex;align-items:center;gap:18px}
.menu a{padding:10px 12px;border-radius:10px;color:var(--menu)}
.menu a:hover{color:var(--menu-hover);background:rgba(0,0,0,.04)}
.menu a[aria-current="page"]{font-weight:700;background:rgba(0,0,0,.06)}

.dropdown{position:relative}
.dropbtn{display:inline-flex;align-items:center;gap:8px;background:transparent;border:0;padding:10px 12px;border-radius:10px;color:var(--menu);cursor:pointer;font:inherit}
.dropbtn:hover,.dropdown:focus-within .dropbtn{background:rgba(0,0,0,.04);color:var(--menu-hover)}
.dropdown-menu{
  position:absolute;top:calc(100% + 6px);left:0;min-width:220px;
  background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);
  padding:6px;display:none;z-index:2050;
}
.dropdown:hover .dropdown-menu,
.dropdown:focus-within .dropdown-menu{display:block}
.dropdown-menu a{display:block;padding:10px 12px;border-radius:8px}
.dropdown-menu a:hover{background:rgba(0,0,0,.05)}
@media (max-width:980px){.dropdown-menu{display:none !important}}

.burger{
  display:none;cursor:pointer;background:var(--bg);
  padding:10px 12px;border:1px solid var(--menu);
  border-radius:12px;color:var(--menu);
  line-height:1;box-shadow:var(--shadow);
  min-width:44px;
}

/* ===================== 4) Mobile panel ===================== */
/* ==== Mobile menu hardfix (z-index, scroll & taps) ==== */
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:900;opacity:0;pointer-events:none;transition:opacity .2s}
.backdrop.show{opacity:1;pointer-events:auto}

.mobile-panel{position:fixed;inset:0 0 0 auto;width:min(85%,360px);
  height:calc(var(--vh,1vh)*100);max-height:calc(var(--vh,1vh)*100);
  z-index:1000;transform:translateX(100%);background:#fff;display:flex;flex-direction:column;overflow:hidden}
.mobile-panel.open{transform:translateX(0)}
.mobile-panel .panel-inner{flex:1;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
html.menu-open,body.menu-open,body.nav-open{overflow:hidden}

/* Taps altijd doorlaten in het paneel */
.mobile-panel, .mobile-panel *{pointer-events:auto}
.mobile-panel{
  position:fixed;inset:0 0 0 auto;width:min(85%,360px);
  height:100dvh;max-height:100dvh;background:#fff !important;color:var(--menu);
  transform:translateX(100%);transition:transform .25s ease;
  box-shadow:-20px 0 60px rgba(0,0,0,.18);z-index:2100;display:flex;flex-direction:column;
  overflow:hidden;
}
.mobile-panel.open{transform:translateX(0)}
.mobile-panel .panel-inner{
  flex:1;min-height:0;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  padding:24px;
  padding-top:calc(24px + env(safe-area-inset-top,0px));
  padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));
}
.mobile-panel a{display:block;padding:12px 8px;border-radius:10px;color:var(--menu)}
.mobile-panel a:hover{background:rgba(0,0,0,.05);color:var(--menu-hover)}
.mobile-close{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--menu);border-radius:10px;padding:10px 12px;background:var(--bg);color:var(--menu);box-shadow:var(--shadow)}

.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.28);opacity:0;pointer-events:none;transition:opacity .2s;z-index:2050}
.backdrop.show{opacity:1;pointer-events:auto}

body.nav-open{background:#fff !important;backdrop-filter:none !important;overflow:hidden}

/* ===================== 5) Buttons ===================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 18px;border-radius:12px;border:none;font-weight:700;
  color:#2a2416;text-shadow:0 1px 0 rgba(255,255,255,.35);
  background:linear-gradient(90deg,var(--btn-start),var(--btn-end));
  background-size:200% 100%;background-position:left center;
  transition:background-position var(--btn-shift-duration) ease,transform .2s,filter .2s,box-shadow .2s;
  box-shadow:0 6px 18px rgba(0,0,0,.06);min-height:44px;margin:0 !important;
  max-width:100%;white-space:normal;
}
.btn:hover{filter:brightness(1.06);transform:translateY(-1px);background-position:right center}
.btn:active{transform:translateY(0) scale(.98);background-position:left center}
.btn + .btn{margin-top:12px !important}
.btn-row{display:flex;flex-wrap:wrap;gap:12px}
.btn-row .btn + .btn{margin-top:0 !important}
.btn--primary{background:linear-gradient(90deg,var(--btn-start),var(--btn-end))}
.btn--ghost{background:#fff;border:1px solid var(--border);box-shadow:none}

/* ===================== 6) Cards & Thumbnails ===================== */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:transform .3s,border-color .3s;min-width:0}
.card:hover{transform:translateY(-3px);border-color:var(--btn-start)}
.card-body{padding:16px;min-width:0}
.card > img:first-child,
.card > a:first-child > img,
.grid .card > a > img:first-child{
  width:100%;aspect-ratio:var(--thumb-ratio);object-fit:var(--thumb-fit);object-position:center;background:var(--thumb-bg);
}
.thumb-cover{object-fit:cover;background:transparent}

/* ===================== 7) Pricing blocks & badges ===================== */
.price-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.price-item{
  display:grid;grid-template-columns:minmax(0,1fr) auto;
  gap:12px;align-items:start;
  padding:12px 14px;border-radius:12px;background:#fff;border:1px solid var(--border);box-shadow:0 2px 6px rgba(0,0,0,.05);
  min-width:0;
}
.price-item .title,
.price-item .money{
  font-weight:700;line-height:1.35;min-width:0;
  overflow-wrap:anywhere;word-break:break-word;white-space:normal;
  -webkit-hyphens:auto;hyphens:auto;
}
.price-item .money{font-weight:800;margin-left:10px;align-self:center}
.price-group > h3{margin:18px 0 8px;font-size:1.05rem;font-weight:800}

.rates{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.rate{
  display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;
  background:linear-gradient(135deg,#f6f2ee,#efe6de);border:1px solid rgba(0,0,0,.05);font-weight:800;
  box-shadow:0 1px 4px rgba(0,0,0,.06)
}
.rate small{font-weight:600;opacity:.65}
.nowrap{white-space:nowrap}

/* Responsive price fix */
@media (max-width:560px){
  .price-item{grid-template-columns:1fr;row-gap:4px}
  .price-item .money{margin:2px 0 0;align-self:flex-start}
  .price-list{gap:12px}
}

/* ===================== 8) Responsive tweaks ===================== */
@media (max-width:980px){
  .menu{display:none}
  .burger{display:inline-flex;align-items:center;justify-content:center}
  .brand img{width:190px}
}
@media (max-width:640px){
  .brand img{width:170px}
  :root{--thumb-ratio:1/1}
  .btn-row{flex-direction:column}
}

/* ===================== 9) Forms ===================== */
main form, .container form{
  --cf-gap:14px; --cf-border:var(--border,#e6dfd6); --cf-muted:var(--muted,#6d5b54);
  --cf-radius:14px; --cf-shadow:0 6px 18px rgba(0,0,0,.06);
  display:block;background:#fff;border:1px solid var(--cf-border);border-radius:16px;box-shadow:var(--cf-shadow);padding:18px;
}
main form label, .container form label{display:block;font-weight:700;margin:14px 0 6px}
main form :is(input[type="text"],input[type="email"],input[type="tel"],input[type="url"],input[type="search"],input[type="password"],textarea),
.container form :is(input[type="text"],input[type="email"],input[type="tel"],input[type="url"],input[type="search"],input[type="password"],textarea){
  width:100%;padding:12px 14px;border:1px solid var(--cf-border);border-radius:var(--cf-radius);background:#fff;font:inherit;line-height:1.4;
  box-shadow:inset 0 1px 0 rgba(0,0,0,.03);transition:border-color .15s,box-shadow .15s,background .15s;
}
main form textarea, .container form textarea{min-height:160px;resize:vertical}
main form :is(input,textarea)::placeholder, .container form :is(input,textarea)::placeholder{color:color-mix(in srgb, var(--cf-muted) 70%, #fff);opacity:.95}
main form :is(input,textarea):focus, .container form :is(input,textarea):focus{
  outline:0;border-color:color-mix(in srgb, var(--btn-start) 55%, var(--cf-border));
  box-shadow:0 0 0 3px color-mix(in srgb, var(--btn-start) 22%, transparent);
}
main form :is(input,textarea):required:user-invalid, .container form :is(input,textarea):required:user-invalid{
  border-color:#e66;box-shadow:0 0 0 3px rgba(230,102,102,.15);
}
@media (min-width:640px){
  main form .row-2, .container form .row-2{display:grid;grid-template-columns:2fr 1fr;gap:var(--cf-gap)}
}
main form input[type="checkbox"], .container form input[type="checkbox"]{width:18px;height:18px;accent-color:var(--btn-start);vertical-align:top;margin-right:10px}
main form :is(button[type="submit"],input[type="submit"]), .container form :is(button[type="submit"],input[type="submit"]){
  display:inline-block;padding:12px 18px;border-radius:12px;border:0;font-weight:800;color:#2a2416;
  text-shadow:0 1px 0 rgba(255,255,255,.35);background:linear-gradient(90deg,var(--btn-start),var(--btn-end));
  background-size:200% 100%;background-position:left center;box-shadow:var(--cf-shadow);
  transition:background-position .6s ease,transform .2s,filter .2s,box-shadow .2s;margin-top:18px;min-height:44px;
}
@media (hover:hover){
  main form :is(button[type="submit"],input[type="submit"]):hover, .container form :is(button[type="submit"],input[type="submit"]):hover{
    filter:brightness(1.06);transform:translateY(-1px);background-position:right center;
  }
}
main form :is(button[type="submit"],input[type="submit"]):active, .container form :is(button[type="submit"],input[type="submit"]):active{transform:translateY(0) scale(.98)}

.hp-field{
  position:absolute !important;
  left:-9999px !important;
  width:1px; height:1px;
  opacity:0; pointer-events:none;
}
/* ===================== 10) Motion & mobile polish ===================== */
@media (max-width:640px){ input,textarea,select,button{font-size:16px} }
input,textarea,select,button{-webkit-appearance:none;appearance:none;background-clip:padding-box}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}

/* === Bedankt-pagina polish === */

/* Hero-CTA's: lucht, nette stacking, gelijke hoogte */
.hero .actions{justify-content:center}
.hero .actions .btn{
  min-width: 220px;
  min-height: 48px;
  border-radius: 14px;
  box-shadow: var(--shadow);
}
@media (max-width: 640px){
  .hero .actions{flex-direction:column;align-items:stretch}
  .hero .actions .btn{width:100%}
}

/* “Wat kun je nu doen?” kaarten */
.feature-grid{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:980px){.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.feature-grid{grid-template-columns:1fr}}

.card--soft{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow)}
.card--soft .card-body{padding:18px}
.card--soft h3{margin:0 0 .4rem}

/* CTA-stapels in de kaarten */
.cta-stack{display:flex;flex-wrap:wrap;gap:10px}
.cta-stack .btn{min-height:44px}
@media (max-width:640px){
  .cta-stack{flex-direction:column}
  .cta-stack .btn{width:100%}
}

/* Q&A widget overlap voorkomen bij sectie-randen */
.section{position:relative}
.section.has-floating-widget{padding-bottom:96px} /* ruimte voor “Vragen?” bubble */

/* Visuele details */
.badge{display:inline-block;padding:.45rem .9rem;border-radius:999px;background:#f3efe9;border:1px solid #eadfd7;color:#7a675e;font-weight:600}

/* ===== iOS/Touch polish (add-on for v6.21) ===== */

/* 1) Tap "hover" simulatie op iOS: fade/hover ook op touch */
html.touch-capable .btn.is-tapping,
html.touch-capable .btn:active{
  filter: brightness(1.06);
  transform: translateY(-1px);
}

/* voorkom grijze tap highlight op iOS */
a, .btn, button { -webkit-tap-highlight-color: rgba(0,0,0,0); }

/* 2) iOS 100vh fix: gebruikt --vh uit main.js */
.mobile-panel{
  height: calc(var(--vh, 1vh) * 100);
  max-height: calc(var(--vh, 1vh) * 100);
}

/* 3) Zeker weten: koppen en price-rijen mogen altijd afbreken */
h1, h2, h3{
  overflow-wrap:anywhere;
  word-break:break-word;
  -webkit-hyphens:auto; hyphens:auto;
}
.price-item .title,
.price-item .money{
  overflow-wrap:anywhere;
  word-break:break-word;
  -webkit-hyphens:auto; hyphens:auto;
}