/* ============================================================
   Club van Relaxte Moeders — warm editorial design system
   Palette: oat + espresso + marigold  ·  Bricolage Grotesque + Source Serif 4
   ============================================================ */

:root{
  --paper:#FBF6EC;          /* warm oat background        */
  --paper-2:#F5EBDA;        /* deeper cream section band  */
  --cream-card:#FFFCF6;     /* card surface               */
  --ink:#2A2420;            /* warm espresso text         */
  --ink-soft:#5C5247;       /* muted brown body           */
  --marigold:#E0913A;       /* primary accent             */
  --marigold-deep:#BE7320;  /* hover                      */
  --marigold-tint:#F7E7CF;  /* light wash                 */
  --plum:#8A4E59;           /* secondary accent (rose)    */
  --plum-tint:#EFDDDF;
  --sage:#6E7B63;           /* tertiary, sparing          */
  --line:#E7D9C4;           /* borders                    */
  --shadow:24px 28px 60px -34px rgba(78,52,24,.45);
  --shadow-sm:10px 14px 30px -20px rgba(78,52,24,.4);
  --serif:"Source Serif 4",Georgia,serif;
  --display:"Bricolage Grotesque","Source Serif 4",sans-serif;
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--serif);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  /* subtle warm grain */
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:var(--plum);text-decoration-thickness:1.5px;text-underline-offset:3px}
a:hover{color:var(--marigold-deep)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.display{font-family:var(--display);font-weight:700;line-height:1.04;letter-spacing:-.02em}

/* ---------- advertorial disclosure bar ---------- */
.adbar{
  background:var(--ink);color:#F3E4CE;font-family:var(--display);
  font-size:12.5px;letter-spacing:.04em;text-align:center;
  padding:8px 16px;font-weight:500;
}
.adbar strong{color:var(--marigold)}

/* ---------- header / nav ---------- */
.site-head{
  position:sticky;top:0;z-index:50;
  background:rgba(251,246,236,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink)}
.brand-badge{
  width:40px;height:40px;border-radius:50%;flex:none;
  background:radial-gradient(circle at 32% 30%,#F2B65C,var(--marigold) 60%,var(--marigold-deep));
  display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:800;font-size:19px;
  box-shadow:0 6px 16px -6px rgba(190,115,32,.7);
}
.brand-name{font-family:var(--display);font-weight:800;font-size:19px;line-height:1;letter-spacing:-.02em}
.brand-name span{display:block;font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--marigold-deep);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{
  font-family:var(--display);font-weight:600;font-size:15px;color:var(--ink);
  text-decoration:none;position:relative;padding:4px 0;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--marigold);transition:width .25s}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{
  background:var(--ink);color:var(--paper)!important;padding:10px 18px;border-radius:30px;
  font-size:14px!important;
}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--marigold-deep)}
.burger{display:none;background:none;border:0;font-size:26px;color:var(--ink);cursor:pointer}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:72px 0 40px}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(60% 80% at 78% 18%,var(--marigold-tint),transparent 70%),
             radial-gradient(50% 60% at 8% 90%,var(--plum-tint),transparent 70%);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;
  font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--plum);
  background:var(--plum-tint);padding:6px 14px;border-radius:30px;margin-bottom:22px;
}
.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(40px,6vw,68px);line-height:1.02;letter-spacing:-.025em}
.hero h1 em{font-style:normal;color:var(--marigold-deep);position:relative;white-space:nowrap}
.hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:6px;height:11px;background:var(--marigold-tint);z-index:-1;border-radius:4px;transform:rotate(-1deg)}
.hero p.lead{font-size:20px;color:var(--ink-soft);margin:22px 0 30px;max-width:30em}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-figure{position:relative}
.hero-figure img{border-radius:22px;box-shadow:var(--shadow);aspect-ratio:5/4;object-fit:cover;width:100%}
.hero-figure .float-card{
  position:absolute;left:-26px;bottom:-22px;background:var(--cream-card);border:1px solid var(--line);
  border-radius:16px;padding:14px 18px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:12px;max-width:230px;
}
.float-card .dot{width:38px;height:38px;border-radius:50%;background:var(--marigold-tint);display:grid;place-items:center;font-size:20px;flex:none}
.float-card b{font-family:var(--display);font-size:15px;display:block}
.float-card small{color:var(--ink-soft);font-size:13px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:16px;
  padding:14px 26px;border-radius:34px;text-decoration:none;cursor:pointer;border:0;transition:transform .15s,box-shadow .2s,background .2s;
}
.btn-primary{background:var(--marigold);color:#fff;box-shadow:0 12px 24px -12px rgba(190,115,32,.8)}
.btn-primary:hover{background:var(--marigold-deep);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* ---------- wavy divider ---------- */
.wave{display:block;width:100%;height:46px;color:var(--paper-2)}
.section{padding:66px 0}
.section.band{background:var(--paper-2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}

.sec-head{margin-bottom:36px;max-width:38em}
.sec-head .kick{font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--marigold-deep)}
.sec-head h2{font-family:var(--display);font-weight:800;font-size:clamp(28px,4vw,42px);line-height:1.06;margin:8px 0 12px;letter-spacing:-.02em}
.sec-head p{color:var(--ink-soft)}

/* ---------- post grid ---------- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.post-grid.two{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--cream-card);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  display:flex;flex-direction:column;text-decoration:none;color:var(--ink);
  transition:transform .2s,box-shadow .25s,border-color .25s;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--marigold)}
.card-img{aspect-ratio:3/2;overflow:hidden;background:var(--marigold-tint)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .card-img img{transform:scale(1.06)}
.card-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.tag{
  align-self:flex-start;font-family:var(--display);font-weight:700;font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;
  padding:5px 12px;border-radius:30px;margin-bottom:13px;
}
.tag.energie{background:var(--marigold-tint);color:var(--marigold-deep)}
.tag.besparen{background:var(--plum-tint);color:var(--plum)}
.tag.gezin{background:#E2EAD9;color:var(--sage)}
.tag.wonen{background:#E6E0D2;color:#7a6a48}
.card h3{font-family:var(--display);font-weight:700;font-size:21px;line-height:1.18;letter-spacing:-.01em;margin-bottom:9px}
.card:hover h3{color:var(--marigold-deep)}
.card .excerpt{color:var(--ink-soft);font-size:15.5px;flex:1}
.card .meta{display:flex;align-items:center;gap:9px;margin-top:16px;font-size:13.5px;color:var(--ink-soft);font-family:var(--display)}
.card .meta .av{width:26px;height:26px;border-radius:50%;object-fit:cover}

/* ---------- about club band ---------- */
.about-band{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:center}
.about-band img{border-radius:20px;box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover;width:100%}
.about-band h2{font-family:var(--display);font-weight:800;font-size:clamp(26px,3.6vw,38px);line-height:1.08;margin-bottom:16px;letter-spacing:-.02em}
.about-band p{color:var(--ink-soft);margin-bottom:14px}
.pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.pill{background:var(--cream-card);border:1px solid var(--line);border-radius:30px;padding:8px 16px;font-family:var(--display);font-weight:600;font-size:14px}

/* ---------- team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.member{text-align:center}
.member img{width:120px;height:120px;border-radius:50%;object-fit:cover;margin:0 auto 14px;border:4px solid var(--cream-card);box-shadow:var(--shadow-sm)}
.member b{font-family:var(--display);font-weight:700;font-size:18px;display:block}
.member small{color:var(--marigold-deep);font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.04em}
.member p{font-size:14.5px;color:var(--ink-soft);margin-top:8px}

/* ---------- newsletter ---------- */
.news{background:var(--ink);color:var(--paper);border-radius:26px;padding:50px;text-align:center;position:relative;overflow:hidden}
.news::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 80% at 80% 0%,rgba(224,145,58,.35),transparent 70%);z-index:0}
.news>*{position:relative;z-index:1}
.news h2{font-family:var(--display);font-weight:800;font-size:clamp(26px,3.4vw,36px);letter-spacing:-.02em;margin-bottom:10px}
.news p{color:#E8D6BE;max-width:34em;margin:0 auto 24px}
.news form{display:flex;gap:12px;max-width:460px;margin:0 auto;flex-wrap:wrap}
.news input{flex:1;min-width:200px;border:0;border-radius:30px;padding:15px 20px;font-family:var(--serif);font-size:16px;background:#F6ECDB;color:var(--ink)}
.news input:focus{outline:3px solid var(--marigold)}
.news .btn-primary{background:var(--marigold)}
.news .ok{margin-top:16px;color:#9FD8A6;font-family:var(--display);font-weight:600;display:none}
.news .hint{font-size:12.5px;color:#C9B79C;margin-top:14px}

/* ---------- footer ---------- */
.foot{background:var(--ink);color:#D9C9B2;padding:60px 0 28px;font-size:15px}
.foot a{color:#EAD9C0}
.foot a:hover{color:var(--marigold)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;margin-bottom:36px}
.foot h4{font-family:var(--display);color:var(--paper);font-size:15px;letter-spacing:.04em;margin-bottom:14px}
.foot ul{list-style:none}
.foot li{margin-bottom:9px}
.foot .brand-name{color:var(--paper)}
.foot .brand-name span{color:var(--marigold)}
.disclosure{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:18px 20px;font-size:13.5px;line-height:1.65;color:#C7B69C;margin-bottom:30px}
.disclosure b{color:var(--paper)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13.5px;color:#A6957E}

/* ---------- cookie consent ---------- */
.cookie{
  position:fixed;left:18px;right:18px;bottom:18px;z-index:100;max-width:520px;margin:0 auto;
  background:var(--cream-card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);
  padding:22px 24px;display:none;
}
.cookie.show{display:block;animation:slideup .4s cubic-bezier(.2,.8,.2,1)}
@keyframes slideup{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie h4{font-family:var(--display);font-weight:800;font-size:18px;margin-bottom:7px;display:flex;align-items:center;gap:8px}
.cookie p{font-size:14.5px;color:var(--ink-soft);margin-bottom:16px}
.cookie .row{display:flex;gap:10px;flex-wrap:wrap}
.cookie .btn{padding:11px 20px;font-size:14.5px}
.cookie .btn-text{background:none;color:var(--ink-soft);text-decoration:underline;padding:11px 8px}

/* ---------- article ---------- */
.article{max-width:760px;margin:0 auto;padding:48px 26px 20px}
.article .crumbs{font-family:var(--display);font-size:13.5px;color:var(--ink-soft);margin-bottom:20px}
.article h1{font-family:var(--display);font-weight:800;font-size:clamp(32px,5vw,50px);line-height:1.05;letter-spacing:-.025em;margin-bottom:18px}
.article .byline{display:flex;align-items:center;gap:12px;margin-bottom:28px;font-family:var(--display);font-size:14.5px;color:var(--ink-soft)}
.article .byline img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.article .hero-img{border-radius:20px;box-shadow:var(--shadow);margin-bottom:14px;aspect-ratio:16/9;object-fit:cover;width:100%}
.article figcaption{font-size:13px;color:var(--ink-soft);text-align:center;margin-bottom:30px;font-style:italic}
.article p{margin-bottom:22px}
.article h2{font-family:var(--display);font-weight:800;font-size:28px;letter-spacing:-.02em;margin:38px 0 14px}
.article h3{font-family:var(--display);font-weight:700;font-size:21px;margin:28px 0 10px}
.article ul,.article ol{margin:0 0 22px 22px}
.article li{margin-bottom:9px}
.article .lead-p::first-letter{font-family:var(--display);font-weight:800;font-size:3.4em;float:left;line-height:.82;margin:6px 10px 0 0;color:var(--marigold-deep)}
.article blockquote{border-left:4px solid var(--marigold);background:var(--marigold-tint);padding:16px 22px;border-radius:0 12px 12px 0;margin:26px 0;font-size:19px}
.callout{background:var(--cream-card);border:1px solid var(--line);border-radius:16px;padding:24px;margin:30px 0;box-shadow:var(--shadow-sm)}
.callout .tag{margin-bottom:10px}
.callout h3{margin-top:0}
.aff-note{font-size:12.5px;color:var(--ink-soft);font-style:italic;margin-top:8px}
.faq dt{font-family:var(--display);font-weight:700;font-size:18px;margin:20px 0 6px}
.faq dd{margin:0 0 14px;color:var(--ink-soft)}
.share-back{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);margin-top:40px;padding-top:24px;font-family:var(--display);font-size:14px}

/* ---------- generic content page ---------- */
.page{max-width:780px;margin:0 auto;padding:54px 26px}
.page h1{font-family:var(--display);font-weight:800;font-size:clamp(30px,4.5vw,46px);letter-spacing:-.02em;margin-bottom:10px}
.page .sub{color:var(--ink-soft);margin-bottom:30px}
.page h2{font-family:var(--display);font-weight:700;font-size:24px;margin:32px 0 12px}
.page p,.page li{color:var(--ink-soft)}
.page ul{margin:0 0 20px 22px}
.page li{margin-bottom:8px}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}

/* ---------- review components (budgetthuis) ---------- */
.factbox{background:var(--paper-2);border:1px solid var(--line);border-radius:16px;padding:22px 26px;margin:28px 0}
.factbox h4{font-family:var(--display);font-weight:800;font-size:17px;margin-bottom:12px}
.factbox dl{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;margin:0}
.factbox dt{font-family:var(--display);font-weight:700;font-size:14.5px;color:var(--marigold-deep)}
.factbox dd{margin:0;font-size:15.5px}
.verdict{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:30px 0}
.verdict-col{border-radius:16px;padding:20px 22px}
.verdict-col h4{font-family:var(--display);font-weight:800;font-size:16px;margin-bottom:10px;display:flex;align-items:center;gap:7px}
.verdict-col ul{margin:0 0 0 18px}
.verdict-col li{margin-bottom:7px;font-size:15px}
.verdict-col.pros{background:#E8EFE1;border:1px solid #CFE0C0}
.verdict-col.pros h4{color:#4d6b3a}
.verdict-col.cons{background:var(--plum-tint);border:1px solid #E2C9CC}
.verdict-col.cons h4{color:var(--plum)}
.steps{display:flex;flex-direction:column;gap:14px;margin:26px 0}
.step{display:flex;gap:16px;align-items:flex-start}
.step-num{flex:none;width:34px;height:34px;border-radius:50%;background:var(--marigold);color:#fff;font-family:var(--display);font-weight:800;display:grid;place-items:center;counter-increment:step}
.step-num::before{content:counter(step)}
.step-body h4{font-family:var(--display);font-weight:700;font-size:17px;margin-bottom:3px}
.step-body p{margin:0;font-size:15.5px;color:var(--ink-soft)}
.steps{counter-reset:step}
.cta-box{background:var(--ink);color:var(--paper);border-radius:20px;padding:32px;margin:32px 0;text-align:center;position:relative;overflow:hidden}
.cta-box::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 90% at 80% 0%,rgba(224,145,58,.32),transparent 70%)}
.cta-box>*{position:relative}
.cta-box .cta-label{font-family:var(--display);font-weight:700;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--marigold)}
.cta-box h3{font-family:var(--display);font-weight:800;font-size:23px;margin:6px 0 8px;color:var(--paper)}
.cta-box p{color:#E5D4BC;margin-bottom:18px;font-size:16px}
.cta-box .cta-disclaimer{font-size:12.5px;color:#C0AE94;margin:14px 0 0}
.review-pull{font-family:var(--display);font-weight:700;font-size:25px;line-height:1.3;color:var(--marigold-deep);border:0;padding:10px 0;margin:28px 0;text-align:center}
.author-card{display:flex;gap:18px;align-items:flex-start;background:var(--cream-card);border:1px solid var(--line);border-radius:16px;padding:22px;margin:34px 0}
.author-card .av{width:56px;height:56px;border-radius:50%;object-fit:cover;flex:none}
.author-card .nm{font-family:var(--display);font-weight:800;font-size:17px;margin-bottom:4px}
.author-card p{margin:0;font-size:14.5px;color:var(--ink-soft)}

/* ---------- responsive ---------- */
@media(max-width:620px){.verdict{grid-template-columns:1fr}.factbox dl{grid-template-columns:1fr}}
@media(max-width:900px){
  .hero-grid,.about-band{grid-template-columns:1fr;gap:34px}
  .hero-figure{order:-1}
  .post-grid,.post-grid.two{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .news{padding:36px 22px}
}
@media(max-width:620px){
  body{font-size:17px}
  .nav-links{position:fixed;inset:74px 0 auto 0;background:var(--paper);flex-direction:column;gap:0;padding:10px 0;border-bottom:1px solid var(--line);display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 26px;width:100%}
  .burger{display:block}
  .post-grid,.post-grid.two,.team-grid,.foot-grid{grid-template-columns:1fr}
  .hero-figure .float-card{left:10px;bottom:-16px}
  .news form{flex-direction:column}
}
