*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--sand);color:var(--ink);
  font-family:"Figtree",system-ui,sans-serif;
  font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
h1,h2,h3{font-family:"Newsreader",Georgia,serif;font-weight:500;line-height:1.08;letter-spacing:-.01em}
em{font-style:italic}
a{color:inherit;text-decoration:none}
.eyebrow{
  font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  color:var(--tide);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold)}

/* ---------- top bar ---------- */
.site-head{position:relative;z-index:5}
.nav{display:flex;align-items:center;justify-content:space-between;padding:22px 0}
.brand{font-family:"Newsreader",serif;font-size:23px;font-weight:600;letter-spacing:-.01em;color:var(--abyss);display:flex;align-items:center;gap:11px}
.brand .mark{width:30px;height:30px;flex:none}
.nav ul{display:flex;gap:30px;list-style:none;font-size:15.5px;font-weight:500;color:var(--ink-soft)}
.nav ul a:hover{color:var(--abyss)}
.nav .news{border:1px solid var(--abyss);color:var(--abyss);padding:9px 18px;border-radius:2px;font-size:14.5px;font-weight:600}
.nav .news:hover{background:var(--abyss);color:var(--sand)}
@media(max-width:860px){.nav ul{display:none}}

/* ---------- hero: de waterlijn ---------- */
.hero{position:relative;overflow:hidden}
.hero .air{padding:62px 0 92px}
.hero h1{font-size:clamp(38px,6.1vw,72px);max-width:15ch;color:var(--abyss);margin:22px 0 0}
.hero h1 em{color:var(--deep)}
.hero .lead{max-width:50ch;margin-top:26px;font-size:20px;color:var(--ink-soft)}
.cta-row{display:flex;gap:16px;margin-top:34px;flex-wrap:wrap;align-items:center}
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 26px;border:0;border-radius:2px;font-weight:600;font-size:16px;line-height:1.2;cursor:pointer;transition:.18s;text-shadow:none}
.btn-primary,button.btn-primary{background:var(--deep) !important;color:var(--on-dark) !important}
.btn-primary:hover,button.btn-primary:hover{background:var(--abyss) !important}
.btn-ghost{color:var(--abyss);font-weight:600}
.btn-ghost .arr{color:var(--gold);transition:transform .18s}
.btn-ghost:hover .arr{transform:translateX(4px)}

/* waterline svg sits between air and deep */
.waterline{display:block;width:100%;height:46px;margin-bottom:-1px;position:relative;z-index:2}

.hero .deep{
  background:linear-gradient(180deg,var(--deep) 0%,var(--abyss) 100%);
  color:var(--on-dark);position:relative;
}
/* subtle caustic light below the surface */
.hero .deep::before{
  content:"";position:absolute;inset:0;opacity:.10;pointer-events:none;
  background:
    radial-gradient(120px 60px at 18% 0%,#fff,transparent 70%),
    radial-gradient(160px 70px at 62% 8%,#fff,transparent 70%),
    radial-gradient(120px 50px at 88% 0%,#fff,transparent 70%);
}
.credrow{display:grid;grid-template-columns:repeat(3,1fr);gap:0;position:relative}
.credrow .c{padding:40px 34px 46px}
.credrow .c+.c{border-left:1px solid rgba(255,255,255,.12)}
.credrow .n{font-family:"Newsreader",serif;font-size:40px;font-weight:500;color:#fff;line-height:1}
.credrow .n small{font-size:18px;color:var(--tide-soft)}
.credrow .l{margin-top:12px;color:var(--on-dark-soft);font-size:15.5px;line-height:1.45}
@media(max-width:760px){.credrow{grid-template-columns:1fr}.credrow .c+.c{border-left:0;border-top:1px solid rgba(255,255,255,.12)}}

/* ---------- section base ---------- */
.section{padding:96px 0}
.shead{max-width:60ch}
.shead h2{font-size:clamp(28px,3.8vw,42px);color:var(--abyss);margin-top:16px}
.shead p{margin-top:14px;color:var(--ink-soft);font-size:18.5px}

/* ---------- three doors ---------- */
.doors{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.door{background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:34px 30px 30px;display:flex;flex-direction:column;min-height:230px;transition:.2s}
.door:hover{transform:translateY(-3px);border-color:var(--tide)}
.door .k{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--tide)}
.door h3{font-size:24px;margin:14px 0 0;color:var(--abyss)}
.door p{margin-top:10px;color:var(--ink-soft);font-size:16px;flex:1}
.door .go{margin-top:18px;font-weight:600;color:var(--abyss);font-size:15.5px}
.door .go .arr{color:var(--gold)}
@media(max-width:860px){.doors{grid-template-columns:1fr}}

/* ---------- kennisbank ---------- */
.kb{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.kb-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:54px;margin-top:48px;align-items:start}
.feat{border-left:2px solid var(--gold);padding-left:26px}
.feat .k,.art .k{font-size:12.5px;letter-spacing:.13em;text-transform:uppercase;font-weight:700;color:var(--tide)}
.feat h3{font-size:clamp(26px,3.4vw,38px);margin:14px 0 0;color:var(--abyss)}
.feat p{margin-top:16px;color:var(--ink-soft)}
.feat .meta{margin-top:18px;font-size:14.5px;color:var(--ink-soft);font-style:italic}
.artlist{display:flex;flex-direction:column}
.art{padding:24px 0;border-top:1px solid var(--line)}
.art:first-child{border-top:0;padding-top:0}
.art h4{font-family:"Newsreader",serif;font-weight:500;font-size:22px;color:var(--abyss);margin:8px 0 0}
.art p{font-size:15.5px;color:var(--ink-soft);margin-top:6px}
@media(max-width:860px){.kb-grid{grid-template-columns:1fr;gap:36px}}

/* ---------- rating band ---------- */
.rating{background:linear-gradient(180deg,var(--abyss),var(--deep));color:var(--on-dark)}
.rating .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.rating .eyebrow{color:var(--tide-soft)}
.rating .eyebrow::before{background:var(--gold)}
.rating h2{font-size:clamp(28px,3.6vw,40px);color:#fff;margin-top:16px}
.rating p{margin-top:18px;color:var(--on-dark-soft)}
.stars{display:flex;gap:8px;margin:26px 0 4px}
.stars svg{width:34px;height:34px}
.rating .guard{margin-top:22px;display:flex;gap:22px;flex-wrap:wrap}
.rating .guard span{font-size:14px;color:var(--tide-soft);display:flex;align-items:center;gap:8px}
.rating .guard span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold)}
.ratecard{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.14);border-radius:6px;padding:36px}
.ratecard .big{font-family:"Newsreader",serif;font-size:64px;color:#fff;line-height:1}
.ratecard .big small{font-size:22px;color:var(--tide-soft)}
.ratecard .sub{color:var(--on-dark-soft);margin-top:10px}
.ratecard hr{border:0;border-top:1px solid rgba(255,255,255,.14);margin:24px 0}
.ratecard .pill{font-size:13.5px;letter-spacing:.06em;color:var(--tide-soft)}
@media(max-width:860px){.rating .wrap{grid-template-columns:1fr;gap:34px}}

/* ---------- media / quote ---------- */
.media{text-align:center}
.media .label{font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
.logos{display:flex;justify-content:center;gap:46px;flex-wrap:wrap;margin:26px 0 60px;opacity:.55;font-family:"Newsreader",serif;font-size:21px;color:var(--ink)}
.quote{max-width:24ch;margin:0 auto;font-family:"Newsreader",serif;font-size:clamp(28px,4vw,44px);line-height:1.18;color:var(--abyss)}
.quote em{color:var(--deep)}
.qby{margin-top:22px;color:var(--ink-soft);font-size:15.5px}

/* ---------- newsletter ---------- */
.news-sec{background:var(--paper);border-top:1px solid var(--line)}
.news-sec .wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.news-sec h2{font-size:clamp(26px,3.4vw,38px);color:var(--abyss)}
.news-sec p{color:var(--ink-soft);margin-top:12px}
.nform{display:flex;gap:12px;flex-wrap:wrap}
.nform input{flex:1;min-width:220px;padding:15px 18px;border:1px solid var(--line);border-radius:2px;background:#fff;font:inherit;font-size:16px}
.nform input:focus{outline:2px solid var(--tide);outline-offset:1px;border-color:transparent}
@media(max-width:860px){.news-sec .wrap{grid-template-columns:1fr;gap:26px}}

/* ---------- footer ---------- */
.site-foot{background:var(--abyss);color:var(--on-dark-soft);padding:70px 0 40px}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px}
.fbrand{font-family:"Newsreader",serif;font-size:22px;color:#fff;display:flex;align-items:center;gap:11px}
.fbrand .mark{width:28px;height:28px}
.site-foot p{font-size:15px;margin-top:16px;max-width:34ch;color:var(--on-dark-soft)}
.site-foot h5{color:#fff;font-size:13px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;margin-bottom:16px}
.site-foot li{list-style:none;margin-bottom:10px;font-size:15px}
.site-foot li a:hover{color:var(--tide-soft)}
.fbot{border-top:1px solid rgba(255,255,255,.12);margin-top:48px;padding-top:24px;font-size:13.5px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
@media(max-width:860px){.fgrid{grid-template-columns:1fr 1fr}}

/* ---------- article (single) ---------- */
.dwx-article{max-width:760px;margin:0 auto;padding:64px 32px 90px}
.dwx-article .a-eyebrow{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--tide)}
.dwx-article h1{font-size:clamp(32px,4.6vw,52px);color:var(--abyss);margin:16px 0 0}
.dwx-article .a-meta{margin-top:18px;color:var(--ink-soft);font-size:15px;font-style:italic}
.dwx-article .a-body{margin-top:34px;font-size:19px}
.dwx-article .a-body p{margin:0 0 22px}
.dwx-article .a-body h2{font-size:30px;color:var(--abyss);margin:40px 0 14px}
.dwx-article .a-body h3{font-size:23px;color:var(--abyss);margin:32px 0 10px}
.dwx-article .a-body a{color:var(--tide);text-decoration:underline;text-underline-offset:3px}
.author-box{margin-top:54px;padding:28px 30px;background:var(--paper);border:1px solid var(--line);border-radius:6px;display:flex;gap:20px;align-items:flex-start}
.author-box .ab-k{font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--tide);font-weight:700}
.author-box h4{font-family:"Newsreader",serif;font-weight:500;font-size:22px;color:var(--abyss);margin:6px 0 0}

/* ---------- generic page (Elementor-content / pagina's) ---------- */
.dwx-page{max-width:var(--maxw);margin:0 auto;padding:64px 32px}

/* ---------- Over Shiva ---------- */
.person-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:54px;align-items:start}
.person-portrait{aspect-ratio:4/5;border-radius:6px;background:linear-gradient(160deg,var(--deep),var(--abyss));display:flex;align-items:flex-end;padding:22px;color:var(--on-dark-soft);font-size:13px;letter-spacing:.04em}
.person-bio h2{font-size:clamp(26px,3.4vw,38px);color:var(--abyss)}
.person-bio h3{font-size:23px;color:var(--abyss);margin:34px 0 12px}
.person-bio p{margin-top:18px;color:var(--ink-soft);font-size:18px}
.creds{list-style:none;margin-top:6px}
.creds li{padding:14px 0;border-top:1px solid var(--line);font-size:16.5px;color:var(--ink-soft)}
.creds li strong{color:var(--abyss)}
@media(max-width:860px){.person-grid{grid-template-columns:1fr;gap:30px}}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.contact-list{list-style:none;margin-top:28px}
.contact-list li{padding:14px 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:3px;font-size:17px;color:var(--abyss)}
.contact-list li span{font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--tide);font-weight:700}
.contact-list li a{color:var(--abyss)}
.contact-form{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:32px}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:30px}}

/* ---------- forms ---------- */
.dwx-form{display:flex;flex-direction:column;gap:16px}
.dwx-form label{display:flex;flex-direction:column;gap:7px;font-size:14.5px;font-weight:600;color:var(--abyss)}
.dwx-form input,.dwx-form textarea{padding:13px 15px;border:1px solid var(--line);border-radius:2px;background:#fff;font:inherit;font-size:16px;font-weight:400}
.dwx-form input:focus,.dwx-form textarea:focus,.nform input:focus{outline:2px solid var(--tide);outline-offset:1px;border-color:transparent}
.dwx-form button{align-self:flex-start;margin-top:6px}
.dwx-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.dwx-note{padding:12px 16px;border-radius:3px;font-size:15px;margin-bottom:18px}
.dwx-note--ok{background:#e6f1ec;color:#1c5c3e;border:1px solid #bcd9c9}
.dwx-note--err{background:#f6e9e6;color:#8a3a28;border:1px solid #e3c6bd}

/* ---------- FAQ ---------- */
.faq{margin-top:40px;max-width:820px}
.faq details{border-top:1px solid var(--line);padding:6px 0}
.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:20px 36px 20px 0;position:relative;font-family:"Newsreader",serif;font-size:21px;color:var(--abyss);font-weight:500}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:18px;font-size:24px;color:var(--gold);font-family:"Figtree",sans-serif;transition:transform .2s}
.faq details[open] summary::after{content:"\2013"}
.faq details p{color:var(--ink-soft);font-size:17px;padding:0 0 22px;max-width:70ch}

@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(14px);animation:rise .7s ease forwards}
  @keyframes rise{to{opacity:1;transform:none}}
}
