/* ============ SHARED PAGE STYLES — subpages ============ */
/* Loaded after site.css. Used by: 404, cookies, privacy, AV, blog, blogposts */

/* ---- Page hero (light) ---- */
.page-hero{
  background:var(--bg);
  border-bottom:1px solid var(--line);
  padding:120px 0 64px;
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.4;
  background:
    radial-gradient(ellipse 50% 35% at 90% 10%, rgba(245,162,20,.15), transparent 60%),
    radial-gradient(ellipse 40% 30% at 5% 90%, rgba(124,92,250,.08), transparent 60%);
}
.page-hero .container{position:relative;z-index:1}
.page-hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent-deep);margin-bottom:20px;
}
.page-hero-eyebrow::before{
  content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);
}
.page-hero h1{
  font-family:var(--font-display);font-weight:400;letter-spacing:-.02em;
  font-size:clamp(2.4rem,5.6vw,4rem);line-height:1.02;margin:0;color:var(--ink);
  max-width:22ch;
}
.page-hero h1 em{font-style:italic;color:var(--accent-deep)}
.page-hero .lede{
  font-size:1.12rem;line-height:1.55;color:var(--ink-mute);
  max-width:58ch;margin:22px 0 0;
}
.page-hero-meta{
  display:flex;gap:18px;flex-wrap:wrap;margin-top:26px;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;
  color:var(--ink-mute);text-transform:uppercase;
}
.page-hero-meta span{display:inline-flex;align-items:center;gap:8px}
.page-hero-meta .sep{opacity:.4}

/* ---- Long-form content ---- */
.prose{
  max-width:720px;margin:0 auto;padding:80px 0;
  font-size:1.02rem;line-height:1.72;color:var(--ink);
}
.prose h2{
  font-family:var(--font-display);font-weight:400;letter-spacing:-.015em;
  font-size:1.85rem;line-height:1.15;color:var(--ink);
  margin:64px 0 16px;scroll-margin-top:100px;
}
.prose h2 .mono-num{
  display:block;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;
  color:var(--accent-deep);text-transform:uppercase;margin-bottom:8px;font-weight:500;
}
.prose h3{
  font-family:var(--font-body);font-weight:600;letter-spacing:-.005em;
  font-size:1.15rem;line-height:1.3;color:var(--ink);
  margin:40px 0 12px;
}
.prose p{margin:0 0 18px;color:var(--ink);opacity:.88}
.prose ul,.prose ol{margin:0 0 20px;padding-left:1.4em}
.prose li{margin-bottom:8px;color:var(--ink);opacity:.88}
.prose a{color:var(--accent-deep);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose a:hover{color:var(--ink)}
.prose strong{font-weight:600;color:var(--ink)}
.prose code{
  font-family:var(--font-mono);font-size:.88em;
  background:var(--bg-2);padding:2px 6px;border-radius:4px;
}
.prose hr{border:0;border-top:1px solid var(--line);margin:48px 0}

/* ---- TL;DR / callout ---- */
.callout{
  background:var(--accent-soft);
  border:1px solid rgba(245,162,20,.2);
  border-left:3px solid var(--accent);
  border-radius:12px;
  padding:22px 26px;margin:28px 0;
}
.callout .callout-label{
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;
  color:var(--accent-deep);text-transform:uppercase;font-weight:600;margin-bottom:6px;
}
.callout p{margin:0;color:var(--ink);opacity:.95;font-size:1rem;line-height:1.6}
.callout p + p{margin-top:10px}

.pullquote{
  font-family:var(--font-display);font-weight:400;font-style:italic;
  font-size:1.55rem;line-height:1.3;color:var(--ink);
  border-left:3px solid var(--accent);
  padding:8px 0 8px 24px;margin:36px 0;
}
.pullquote cite{
  display:block;margin-top:12px;font-style:normal;font-family:var(--font-mono);
  font-size:.72rem;letter-spacing:.1em;color:var(--ink-mute);text-transform:uppercase;
}

/* ---- Cookie table ---- */
.cookie-table{
  width:100%;border-collapse:collapse;margin:20px 0 32px;
  border:1px solid var(--line);border-radius:10px;overflow:hidden;
  background:var(--paper);
  font-size:.92rem;
}
.cookie-table thead{background:var(--bg-2)}
.cookie-table th{
  text-align:left;padding:14px 16px;
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;
  color:var(--ink-mute);text-transform:uppercase;font-weight:500;
  border-bottom:1px solid var(--line);
}
.cookie-table td{
  padding:14px 16px;border-bottom:1px solid var(--line);vertical-align:top;color:var(--ink);
}
.cookie-table tr:last-child td{border-bottom:0}
.cookie-table .pill{
  display:inline-block;padding:3px 10px;border-radius:99px;
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;
  background:var(--bg-2);color:var(--ink-mute);
}
.cookie-table .pill-fn{background:#E8F5E9;color:#2e7d32}
.cookie-table .pill-an{background:#FFF4E0;color:#996400}
.cookie-table .pill-mk{background:#FCE8EF;color:#a8336b}

/* ---- AV sticky sidenav ---- */
.av-layout{
  display:grid;grid-template-columns:260px 1fr;gap:56px;
  max-width:1080px;margin:0 auto;padding:64px 0 80px;align-items:start;
}
.av-toc{
  position:sticky;top:96px;
  border-left:1px solid var(--line);padding:4px 0 4px 20px;
  font-size:.88rem;
  max-height:calc(100vh - 120px);overflow-y:auto;
}
.av-toc .toc-label{
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;
  color:var(--accent-deep);text-transform:uppercase;margin-bottom:16px;font-weight:500;
}
.av-toc-group{margin-bottom:20px}
.av-toc-group > strong{
  display:block;font-family:var(--font-display);font-size:1.05rem;
  color:var(--ink);font-weight:400;margin-bottom:8px;
}
.av-toc a{
  display:block;padding:4px 0;color:var(--ink-mute);
  text-decoration:none;font-size:.9rem;line-height:1.35;
  border-left:2px solid transparent;margin-left:-22px;padding-left:20px;
  transition:color .15s, border-color .15s;
}
.av-toc a:hover{color:var(--ink)}
.av-toc a.active{color:var(--ink);border-left-color:var(--accent)}
.av-body{min-width:0}
.av-body .prose{max-width:none;padding:0}

.av-toc-toggle{display:none}

@media (max-width:860px){
  .av-layout{grid-template-columns:1fr;gap:0}
  .av-toc{
    position:static;top:auto;max-height:none;
    border-left:0;padding:0;margin-bottom:32px;
  }
  .av-toc-toggle{
    display:flex;align-items:center;justify-content:space-between;width:100%;
    padding:14px 18px;background:var(--paper);border:1px solid var(--line);
    border-radius:10px;cursor:pointer;font-family:var(--font-body);font-size:.95rem;
    color:var(--ink);
  }
  .av-toc-toggle::after{content:"▾";color:var(--ink-mute);transition:transform .2s}
  .av-toc[data-open="true"] .av-toc-toggle::after{transform:rotate(180deg)}
  .av-toc-inner{display:none;margin-top:16px;padding:16px;background:var(--paper);border:1px solid var(--line);border-radius:10px}
  .av-toc[data-open="true"] .av-toc-inner{display:block}
}

/* ---- 404 ---- */
.nf-wrap{
  min-height:80vh;display:flex;align-items:center;justify-content:center;
  padding:120px 0 80px;position:relative;overflow:hidden;
}
.nf-wrap::before{
  content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:
    radial-gradient(ellipse 50% 40% at 80% 20%, rgba(245,162,20,.14), transparent 60%),
    radial-gradient(ellipse 40% 35% at 20% 80%, rgba(124,92,250,.08), transparent 60%);
}
.nf-inner{text-align:center;max-width:640px;position:relative;z-index:1}
.nf-code{
  font-family:var(--font-display);font-size:clamp(6rem,18vw,14rem);line-height:.9;
  color:var(--ink);margin:0 0 24px;letter-spacing:-.05em;
}
.nf-code em{font-style:italic;color:var(--accent)}
.nf-mono{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;
  color:var(--accent-deep);text-transform:uppercase;margin-bottom:14px;
}
.nf-title{
  font-family:var(--font-display);font-size:2rem;color:var(--ink);
  margin:0 0 16px;font-weight:400;letter-spacing:-.01em;
}
.nf-sub{color:var(--ink-mute);font-size:1.05rem;line-height:1.55;margin:0 0 32px;max-width:46ch;margin-left:auto;margin-right:auto}
.nf-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---- Blog index ---- */
.blog-hero .lede{max-width:54ch}
.blog-filter{
  display:flex;gap:8px;flex-wrap:wrap;margin-top:28px;
}
.blog-filter button{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  padding:8px 16px;border-radius:99px;border:1px solid var(--line-strong);
  background:var(--paper);color:var(--ink-mute);cursor:pointer;transition:all .15s;
}
.blog-filter button:hover{color:var(--ink);border-color:var(--ink)}
.blog-filter button.active{background:var(--ink);color:#fff;border-color:var(--ink)}

.blog-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:28px;
  padding:60px 0 90px;
}
.blog-card{
  grid-column:span 4;
  background:var(--paper);border:1px solid var(--line);border-radius:16px;
  overflow:hidden;display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.blog-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-soft);
  border-color:var(--line-strong);
}
.blog-card.feat{grid-column:span 8;flex-direction:row;min-height:320px}
.blog-card.feat .bc-visual{flex:0 0 45%;min-height:auto}
.blog-card.feat .bc-body{flex:1;padding:36px 40px}

.bc-visual{
  position:relative;aspect-ratio:16/9;
  background:linear-gradient(135deg, var(--ink) 0%, var(--ink-2) 100%);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.bc-visual.v-amber{background:linear-gradient(135deg, #F5A214 0%, #D98C0E 100%)}
.bc-visual.v-navy{background:linear-gradient(135deg, #0B0F2A 0%, #1a2356 100%)}
.bc-visual.v-cream{background:linear-gradient(135deg, #F3F1EA 0%, #E8E3D1 100%)}
.bc-visual.v-violet{background:linear-gradient(135deg, #3d2d8a 0%, #6B5ACD 100%)}
.bc-visual.v-moss{background:linear-gradient(135deg, #2d4a3a 0%, #4a6b52 100%)}

.bc-mark{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);color:rgba(255,255,255,.9);
  font-size:clamp(3rem, 8vw, 5.5rem);line-height:1;letter-spacing:-.02em;
}
.bc-visual.v-cream .bc-mark{color:var(--ink)}
.bc-mark em{font-style:italic;display:block}
.bc-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size:40px 40px;
  pointer-events:none;
}
.bc-visual.v-cream .bc-grid{
  background-image:
    linear-gradient(rgba(11,15,42,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(11,15,42,.06) 1px, transparent 1px);
}

.bc-body{padding:26px 28px 28px;display:flex;flex-direction:column;flex:1;gap:14px}
.bc-meta{
  display:flex;gap:10px;align-items:center;
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;
  color:var(--ink-mute);text-transform:uppercase;
}
.bc-cat{color:var(--accent-deep);font-weight:500}
.bc-sep{opacity:.4}
.bc-title{
  font-family:var(--font-display);font-weight:400;letter-spacing:-.01em;
  font-size:1.35rem;line-height:1.2;color:var(--ink);margin:0;
}
.blog-card.feat .bc-title{font-size:1.85rem;line-height:1.15}
.bc-intro{color:var(--ink-mute);font-size:.95rem;line-height:1.55;margin:0}
.bc-more{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;
  color:var(--accent-deep);text-transform:uppercase;
  margin-top:auto;display:inline-flex;align-items:center;gap:6px;
}
.blog-card:hover .bc-more{color:var(--ink)}

@media (max-width:900px){
  .blog-card,.blog-card.feat{grid-column:span 12;flex-direction:column}
  .blog-card.feat .bc-visual{flex:none}
  .blog-card.feat .bc-body{padding:26px 28px}
  .blog-card.feat .bc-title{font-size:1.45rem}
}

/* ---- Post hero ---- */
.post-hero{
  background:var(--bg);
  padding:120px 0 56px;
  border-bottom:1px solid var(--line);
}
.post-hero .container{max-width:780px}
.post-crumb{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;
  color:var(--ink-mute);text-transform:uppercase;margin-bottom:20px;
}
.post-crumb a{color:var(--accent-deep);text-decoration:none}
.post-crumb a:hover{color:var(--ink)}
.post-crumb .sep{margin:0 8px;opacity:.5}
.post-cat{
  display:inline-block;
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;
  color:var(--accent-deep);text-transform:uppercase;font-weight:500;margin-bottom:16px;
}
.post-title{
  font-family:var(--font-display);font-weight:400;letter-spacing:-.02em;
  font-size:clamp(2rem,4.8vw,3.4rem);line-height:1.05;color:var(--ink);margin:0;
}
.post-title em{font-style:italic;color:var(--accent-deep)}
.post-meta{
  display:flex;gap:16px;flex-wrap:wrap;margin-top:28px;
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;
  color:var(--ink-mute);
}
.post-meta .sep{opacity:.4}

.post-body{padding:60px 0 40px}
.post-body .prose{padding:0}

/* ---- Post CTA box ---- */
.post-cta{
  background:var(--ink);color:#fff;
  border-radius:18px;padding:48px 44px;margin:60px 0;
  position:relative;overflow:hidden;
}
.post-cta::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.6;
  background:radial-gradient(ellipse 50% 100% at 100% 0%, rgba(245,162,20,.2), transparent 60%);
}
.post-cta-inner{position:relative;z-index:1}
.post-cta-kicker{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;
  color:var(--accent);text-transform:uppercase;margin-bottom:14px;
}
.post-cta h3{
  font-family:var(--font-display);font-weight:400;letter-spacing:-.01em;
  font-size:1.85rem;line-height:1.15;color:#fff;margin:0 0 12px;
}
.post-cta p{color:rgba(255,255,255,.75);margin:0 0 24px;font-size:1rem;line-height:1.55}
.post-cta .btn-primary{background:var(--accent);border-color:var(--accent);color:var(--ink)}
.post-cta .btn-primary:hover{background:var(--accent-deep);border-color:var(--accent-deep)}

/* ---- About Dutch Leads ---- */
.post-about{
  border-top:1px solid var(--line);
  padding:48px 0;margin-top:20px;
}
.post-about .container{max-width:780px}
.post-about-inner{
  display:grid;grid-template-columns:100px 1fr;gap:28px;align-items:center;
}
.post-about-logo{
  width:80px;height:80px;border-radius:14px;
  background:var(--ink);display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:var(--font-display);font-size:2rem;font-style:italic;
}
.post-about h4{
  font-family:var(--font-display);font-weight:400;font-size:1.2rem;
  color:var(--ink);margin:0 0 6px;letter-spacing:-.005em;
}
.post-about p{margin:0;color:var(--ink-mute);font-size:.95rem;line-height:1.55}
@media (max-width:640px){
  .post-about-inner{grid-template-columns:1fr;text-align:center}
  .post-about-logo{margin:0 auto}
}

/* ---- FAQ block (re-usable) ---- */
.post-faq{margin:56px 0}
.post-faq h2{margin-top:0}
.post-faq details{
  border-bottom:1px solid var(--line);padding:20px 0;
}
.post-faq details:first-of-type{border-top:1px solid var(--line)}
.post-faq summary{
  cursor:pointer;list-style:none;
  font-family:var(--font-display);font-weight:400;font-size:1.18rem;
  color:var(--ink);line-height:1.3;
  display:flex;justify-content:space-between;align-items:baseline;gap:20px;
}
.post-faq summary::-webkit-details-marker{display:none}
.post-faq summary::after{
  content:"+";font-family:var(--font-mono);font-size:1.2rem;
  color:var(--accent-deep);flex-shrink:0;transition:transform .2s;
}
.post-faq details[open] summary::after{transform:rotate(45deg)}
.post-faq details > p,
.post-faq details > div{
  margin-top:14px;color:var(--ink);opacity:.85;line-height:1.65;font-size:.98rem;
}

/* ---- Related posts ---- */
.post-related{
  background:var(--bg-2);padding:64px 0 80px;border-top:1px solid var(--line);
}
.post-related-head{text-align:center;margin-bottom:36px}
.post-related-head h3{
  font-family:var(--font-display);font-weight:400;letter-spacing:-.01em;
  font-size:2rem;color:var(--ink);margin:0;
}
.post-related-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  max-width:1080px;margin:0 auto;
}
@media (max-width:900px){
  .post-related-grid{grid-template-columns:1fr}
}

/* ---- Stat grid for posts ---- */
.stat-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  margin:32px 0;padding:28px;
  background:var(--bg-2);border-radius:12px;
}
.stat-grid .stat-big{
  font-family:var(--font-display);font-size:2.2rem;line-height:1;color:var(--ink);
  letter-spacing:-.01em;margin-bottom:6px;
}
.stat-grid .stat-lbl{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;
  color:var(--ink-mute);text-transform:uppercase;line-height:1.3;
}
@media (max-width:640px){
  .stat-grid{grid-template-columns:1fr}
}

/* ---- Comparison table (for posts) ---- */
.compare-simple{
  width:100%;border-collapse:collapse;margin:24px 0;
  border:1px solid var(--line);border-radius:10px;overflow:hidden;
  font-size:.94rem;
}
.compare-simple thead{background:var(--bg-2)}
.compare-simple th,.compare-simple td{
  padding:14px 16px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top;
}
.compare-simple th{
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;
  color:var(--ink-mute);text-transform:uppercase;font-weight:500;
}
.compare-simple tr:last-child td{border-bottom:0}
.compare-simple td:first-child{font-weight:500;color:var(--ink);width:26%}

/* ---- Legal pages (privacy / AV / cookies) ---- */
.legal-hero{padding-bottom:32px}
.legal-hero .post-title{font-size:clamp(2.4rem, 5vw, 4rem)}

.legal-part{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;
  color:var(--accent-deep);text-transform:uppercase;font-weight:500;
  padding:14px 18px;margin:56px 0 28px;
  background:var(--bg-2);border-radius:8px;border-left:3px solid var(--accent);
}
.legal-part:first-of-type{margin-top:0}

.prose .lead{
  font-size:1.15rem;line-height:1.55;color:var(--ink);
  padding:20px 24px;margin:0 0 40px;
  background:var(--bg-2);border-left:3px solid var(--accent);border-radius:0 10px 10px 0;
}

.legal-contact{
  margin:24px 0 8px;padding:24px 28px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:10px;
}
.legal-contact dl{
  display:grid;grid-template-columns:180px 1fr;gap:10px 24px;margin:0;
}
.legal-contact dt{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;
  color:var(--ink-mute);text-transform:uppercase;align-self:center;font-weight:500;
}
.legal-contact dd{margin:0;color:var(--ink);font-size:.98rem;align-self:center}
.legal-contact dd a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:3px}
.legal-contact dd a:hover{text-decoration-color:var(--accent)}
@media (max-width:640px){
  .legal-contact dl{grid-template-columns:1fr;gap:4px 0}
  .legal-contact dt{margin-top:10px}
  .legal-contact dt:first-child{margin-top:0}
}
