/* ==========================================================================
   Triggerz Blog. Bovenop assets/css/style.css.
   Hergebruikt de bestaande tokens (teal --color-mint #7DEDD3 == hsl(167 71% 71%),
   fonts, radii, ease) en de bestaande neon-glow + self-draw. Geen nieuwe
   kleurtokens: het categorie-accent is dezelfde teal, in tint verschoven via
   --cat-hue (hue van de HSL). Animaties draaien alleen met JS (body.neon-ready),
   zonder JS is alles gewoon zichtbaar.
   ========================================================================== */

.blog-page { --cat-hue: 0; }
.blog-article,
.blog-cat-section,
.related-card { --cat-accent: hsl(calc(167 + var(--cat-hue)) 71% 71%); }

/* ---- Leesvoortgangsbalk -------------------------------------------------- */
.reading-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px;
  background: transparent; z-index: 1200; pointer-events: none;
}
.reading-progress-bar {
  display: block; height: 100%; width: 0;
  background: linear-gradient(90deg, var(--color-mint-dark), var(--color-mint));
  box-shadow: 0 0 10px rgba(125, 237, 211, 0.7);
  transition: width 0.1s linear;
}

/* ---- Neon SVG ------------------------------------------------------------ */
.na-hero { width: 100%; height: auto; display: block; overflow: visible;
  filter: drop-shadow(0 0 5px hsl(calc(167 + var(--cat-hue, 0)) 71% 71% / 0.55))
          drop-shadow(0 0 16px hsl(calc(167 + var(--cat-hue, 0)) 71% 71% / 0.22)); }
.na-hero [class^="na-"] { fill: none; stroke-linecap: round; stroke-linejoin: round; }
.na-hero .na-stroke,
.na-hero .na-curve  { stroke: hsl(calc(167 + var(--cat-hue, 0)) 71% 71%); stroke-width: 2.5; }
.na-hero .na-accent { stroke: hsl(calc(167 + var(--cat-hue, 0)) 71% 71%); stroke-width: 2.5; }
.na-hero .na-soft,
.na-hero .na-grid   { stroke: rgba(245, 232, 211, 0.26); stroke-width: 1.4; }
.na-hero .na-grid   { stroke-dasharray: 3 7; }
.na-hero .na-dot,
.na-hero .na-fill   { fill: hsl(calc(167 + var(--cat-hue, 0)) 71% 71%); stroke: none; }

/* self-draw, alleen met JS actief */
body.neon-ready [data-neon] .na-hero path,
body.neon-ready [data-neon] .na-hero line,
body.neon-ready [data-neon] .na-hero polyline,
body.neon-ready [data-neon] .na-hero rect,
body.neon-ready [data-neon] .na-hero circle {
  stroke-dasharray: 1400; stroke-dashoffset: 1400;
}
body.neon-ready [data-neon].in-view .na-hero path,
body.neon-ready [data-neon].in-view .na-hero line,
body.neon-ready [data-neon].in-view .na-hero polyline,
body.neon-ready [data-neon].in-view .na-hero rect,
body.neon-ready [data-neon].in-view .na-hero circle {
  animation: blog-neon-draw 2.4s cubic-bezier(.7,0,.3,1) forwards;
}
@keyframes blog-neon-draw { to { stroke-dashoffset: 0; } }

/* fade-in op scroll, alleen met JS actief */
body.neon-ready [data-animate] { opacity: 0; transform: translateY(22px);
  transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
body.neon-ready [data-animate].in-view { opacity: 1; transform: none; }

/* ---- Kruimelpad ---------------------------------------------------------- */
.blog-breadcrumb {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  font-size: 0.85rem; color: var(--color-text-muted); padding: 110px 0 0;
}
.blog-index-hero .blog-breadcrumb { padding-top: 0; margin-bottom: 26px; }
.blog-breadcrumb a { color: var(--color-text-dim); text-decoration: none; }
.blog-breadcrumb a:hover { color: var(--color-mint); }

/* ---- Index-hero ---------------------------------------------------------- */
.blog-index-hero { position: relative; overflow: hidden; padding: 150px 0 70px; }
.blog-index-hero-bg {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(60% 80% at 78% 18%, rgba(125, 237, 211, 0.16), transparent 60%),
    radial-gradient(40% 60% at 12% 90%, rgba(125, 237, 211, 0.08), transparent 60%);
}
.blog-index-hero-bg::after {
  content: ""; position: absolute; inset: 0;
  background-image: linear-gradient(rgba(245,241,235,0.04) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(245,241,235,0.04) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: radial-gradient(70% 70% at 70% 30%, #000, transparent 75%);
}
.blog-index-hero-inner {
  position: relative; display: grid;
  grid-template-columns: 1.05fr 0.95fr; gap: 50px; align-items: center;
}
.blog-index-eyebrow {
  display: inline-block; font-family: var(--font-display); font-size: 0.78rem;
  font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--color-mint); margin-bottom: 18px;
}
.blog-index-hero-text h1 {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(2.4rem, 6vw, 4.2rem); line-height: 1.04;
  color: var(--color-cream); margin: 0 0 20px;
}
.blog-index-hero-text p {
  color: var(--color-text-dim); font-size: 1.12rem; line-height: 1.7;
  max-width: 46ch; margin: 0;
}
.blog-index-hero-art { position: relative; display: flex; justify-content: center; align-items: center; }
.blog-index-hero-art .na-hero { width: 100%; max-width: 560px; margin: 0 auto; }

/* ---- Categorie-secties --------------------------------------------------- */
.blog-index-body { padding-bottom: 90px; }
.blog-cat-section { margin-top: 70px; }
.blog-cat-section:first-child { margin-top: 30px; }
.blog-cat-head { display: flex; align-items: center; gap: 18px; margin-bottom: 30px; }
.blog-cat-head h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(1.4rem, 3vw, 1.9rem); color: var(--color-cream);
  margin: 0; white-space: nowrap;
}
.blog-cat-line {
  flex: 1; height: 1px;
  background: linear-gradient(90deg,
    hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.9), transparent);
  box-shadow: 0 0 8px hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.5);
}

/* ---- Kaarten ------------------------------------------------------------- */
.blog-card-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px;
}
.blog-card {
  --cat-accent: hsl(calc(167 + var(--cat-hue)) 71% 71%);
  display: flex; flex-direction: column; position: relative;
  background: var(--color-bg-soft); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); overflow: hidden; text-decoration: none;
  transition: transform 0.32s var(--ease), border-color 0.32s var(--ease),
              box-shadow 0.32s var(--ease);
}
.blog-card:hover {
  transform: translateY(-8px);
  border-color: hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.55);
  box-shadow: 0 18px 50px -24px hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.6);
}
.blog-card-art {
  padding: 30px 30px 6px;
  background: radial-gradient(120% 90% at 82% 0%,
    hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.10), transparent 62%);
}
.blog-card-art .na-hero { max-width: 200px; margin: 0 auto; }
.blog-card-body { padding: 16px 30px 30px; display: flex; flex-direction: column; gap: 11px; flex: 1; }
.blog-card-cat {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  color: hsl(calc(167 + var(--cat-hue)) 71% 71%);
}
.blog-card h3 {
  font-family: var(--font-display); font-size: 1.22rem; font-weight: 700;
  line-height: 1.3; color: var(--color-cream); margin: 0;
}
.blog-card p { color: var(--color-text-dim); font-size: 0.95rem; line-height: 1.6; margin: 0; }
.blog-card-meta { margin-top: auto; color: var(--color-text-muted); font-size: 0.82rem; padding-top: 6px; }

/* ---- Artikel-hero -------------------------------------------------------- */
.blog-article { position: relative; }
.blog-article .blog-hero {
  position: relative; display: grid;
  grid-template-columns: 1fr minmax(240px, 420px); gap: 50px; align-items: center;
  padding: 44px 0 50px; margin-bottom: 50px;
  border-bottom: 1px solid var(--color-border);
}
.blog-hero-glow {
  position: absolute; right: -6%; top: 50%; transform: translateY(-50%);
  width: 520px; height: 520px; pointer-events: none; z-index: 0;
  background: radial-gradient(circle, hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.12), transparent 62%);
}
.blog-hero-text { position: relative; z-index: 1; }
.blog-hero-text h1 {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(2rem, 4.4vw, 3.2rem); line-height: 1.08;
  color: var(--color-cream); margin: 18px 0 0;
}
.blog-tag {
  display: inline-block; font-family: var(--font-display); font-size: 0.72rem;
  font-weight: 700; letter-spacing: 0.13em; text-transform: uppercase;
  color: hsl(calc(167 + var(--cat-hue)) 71% 71%); text-decoration: none;
  padding: 6px 15px; border: 1px solid hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.5);
  border-radius: var(--radius-pill);
}
.blog-tag:hover { background: hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.08); }
.blog-meta {
  display: flex; flex-wrap: wrap; gap: 10px; align-items: center;
  margin-top: 18px; color: var(--color-text-muted); font-size: 0.9rem;
}
.blog-hero-art { position: relative; z-index: 1; }
.blog-hero-art .na-hero { max-width: 420px; margin-left: auto; }

/* ---- Artikel-layout: inhoudsopgave + body -------------------------------- */
.blog-layout { display: grid; grid-template-columns: 230px minmax(0, 1fr); gap: 56px; align-items: start; }
.blog-layout > .blog-body { max-width: 720px; }
.blog-layout:not(:has(.blog-toc)) { grid-template-columns: minmax(0, 1fr); justify-items: center; }

.blog-toc { position: sticky; top: 96px; align-self: start; }
.blog-toc-inner { border-left: 1px solid var(--color-border-strong); padding-left: 20px; }
.blog-toc-title {
  font-family: var(--font-display); font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-text-muted);
  margin: 0 0 14px;
}
.blog-toc ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.blog-toc a {
  color: var(--color-text-dim); text-decoration: none; font-size: 0.9rem; line-height: 1.4;
  display: block; transition: color 0.2s var(--ease);
}
.blog-toc a:hover { color: var(--color-cream); }
.blog-toc a.active { color: var(--color-mint); font-weight: 600; }

/* ---- Artikel-body -------------------------------------------------------- */
.blog-body { color: var(--color-text-dim); font-size: 1.06rem; line-height: 1.78; }
.blog-body > h2 {
  position: relative; font-family: var(--font-display); font-weight: 700;
  font-size: clamp(1.45rem, 2.7vw, 1.95rem); line-height: 1.2; color: var(--color-cream);
  margin: 52px 0 18px; padding-top: 30px; scroll-margin-top: 90px;
}
.blog-body > h2::before {
  content: ""; position: absolute; top: 0; left: 0; width: 56px; height: 2px;
  background: hsl(calc(167 + var(--cat-hue)) 71% 71%);
  box-shadow: 0 0 10px hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.7);
}
.blog-body > h2:first-child { margin-top: 0; padding-top: 0; }
.blog-body > h2:first-child::before { display: none; }
.blog-body h3 {
  font-family: var(--font-display); font-weight: 700; font-size: 1.22rem;
  color: var(--color-cream); margin: 34px 0 12px;
}
.blog-body p { margin: 0 0 20px; }
.blog-body a {
  color: hsl(calc(167 + var(--cat-hue)) 71% 71%); text-decoration: underline;
  text-underline-offset: 3px; text-decoration-color: hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.5);
}
.blog-body a:hover { text-decoration-color: hsl(calc(167 + var(--cat-hue)) 71% 71%); }
.blog-body ul, .blog-body ol { margin: 0 0 22px; padding-left: 22px; }
.blog-body li { margin: 0 0 10px; }
.blog-body strong { color: var(--color-cream-soft); font-weight: 600; }
.blog-body blockquote {
  margin: 28px 0; padding: 6px 0 6px 22px;
  border-left: 2px solid hsl(calc(167 + var(--cat-hue)) 71% 71%);
  color: var(--color-cream-soft); font-style: italic;
}

/* ---- Pull-quote / kernpunt ----------------------------------------------- */
.pull-quote {
  position: relative; margin: 44px 0; padding: 32px 34px;
  background: linear-gradient(135deg, hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.07), transparent);
  border: 1px solid hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.3);
  border-radius: var(--radius-md);
}
.pull-quote p {
  font-family: var(--font-display); font-size: clamp(1.2rem, 2.4vw, 1.5rem);
  font-weight: 700; line-height: 1.4; color: var(--color-cream); margin: 0;
}
.pull-quote-mark {
  position: absolute; top: -16px; left: 26px; width: 34px; height: 34px;
  border-radius: 50%; background: var(--color-bg);
  border: 1px solid hsl(calc(167 + var(--cat-hue)) 71% 71%);
  box-shadow: 0 0 16px hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.5);
}
.pull-quote-mark::after {
  content: "\201C"; position: absolute; left: 0; right: 0; top: 6px; text-align: center;
  font-family: var(--font-display); font-size: 1.5rem; line-height: 1;
  color: hsl(calc(167 + var(--cat-hue)) 71% 71%);
}

/* ---- Gerelateerd + CTA --------------------------------------------------- */
.blog-related { max-width: 1100px; margin: 80px auto 0; padding-top: 50px; border-top: 1px solid var(--color-border); }
.blog-related-title { font-family: var(--font-display); font-weight: 700; font-size: 1.6rem; color: var(--color-cream); margin: 0 0 26px; }
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.related-card {
  display: block; position: relative; padding: 0 0 22px;
  background: var(--color-bg-soft); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); overflow: hidden; text-decoration: none;
  transition: transform 0.26s var(--ease), border-color 0.26s var(--ease);
}
.related-card:hover { transform: translateY(-5px); border-color: hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.5); }
.related-card-art {
  padding: 22px 22px 4px;
  background: radial-gradient(120% 90% at 82% 0%, hsl(calc(167 + var(--cat-hue)) 71% 71% / 0.10), transparent 62%);
}
.related-card-art .na-hero { max-width: 150px; margin: 0 auto; }
.related-card .related-cat {
  display: block; padding: 12px 22px 0; font-size: 0.68rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase; color: hsl(calc(167 + var(--cat-hue)) 71% 71%);
}
.related-card h3 {
  font-family: var(--font-display); font-size: 1.0rem; font-weight: 700;
  color: var(--color-cream); margin: 8px 0 0; padding: 0 22px; line-height: 1.34;
}
.blog-cta {
  margin-top: 44px; padding: 36px; background: var(--color-surface);
  border: 1px solid var(--color-border-strong); border-radius: var(--radius-lg);
  display: flex; flex-wrap: wrap; gap: 22px 30px; align-items: center; justify-content: space-between;
  position: relative; overflow: hidden;
}
.blog-cta::before {
  content: ""; position: absolute; right: -40px; top: -40px; width: 220px; height: 220px;
  background: radial-gradient(circle, var(--color-mint), transparent 62%); opacity: 0.10; pointer-events: none;
}
.blog-cta-eyebrow { font-family: var(--font-display); font-size: 0.7rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-mint); }
.blog-cta-text h3 { font-family: var(--font-display); font-size: 1.35rem; color: var(--color-cream); margin: 8px 0 6px; }
.blog-cta-text p { margin: 0; color: var(--color-text-dim); font-size: 0.95rem; }
.blog-cta .btn { position: relative; z-index: 1; }

/* ---- Responsief ---------------------------------------------------------- */
@media (max-width: 1000px) {
  .blog-layout { grid-template-columns: minmax(0, 1fr); gap: 0; }
  .blog-toc { display: none; }
  .blog-card-grid, .related-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .blog-index-hero { padding: 130px 0 50px; }
  .blog-index-hero-inner { grid-template-columns: 1fr; gap: 30px; }
  .blog-index-hero-art { order: -1; }
  .blog-index-hero-art .na-hero { max-width: 360px; margin: 0 auto; }
  .blog-article .blog-hero { grid-template-columns: 1fr; gap: 26px; padding-top: 30px; }
  .blog-hero-art .na-hero { max-width: 320px; margin: 0 auto; }
  .blog-card-grid, .related-grid { grid-template-columns: 1fr; }
  .blog-cta { flex-direction: column; align-items: flex-start; }
}

@media (prefers-reduced-motion: reduce) {
  body.neon-ready [data-animate] { opacity: 1 !important; transform: none !important; transition: none; }
  body.neon-ready [data-neon] .na-hero * { stroke-dashoffset: 0 !important; animation: none !important; }
  .blog-card, .related-card, .reading-progress-bar { transition: none; }
}
