/* CloudLabs · shared stylesheet · v0.2.4 */
:root{
  --bg:#0a1024;--bg-2:#0f1832;--panel:#121d3a;--panel-2:#162345;
  --line:rgba(120,160,255,.14);--line-strong:rgba(120,160,255,.28);
  --ink:#e6ecff;--ink-dim:#9aa6c8;--ink-faint:#8a96b8;
  --cyan:#5fe3ff;--cyan-deep:#26b8d8;--amber:#ffb454;--rose:#ff5d7a;--green:#52e3a4;
  --body:"Inter",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}

/* Consent banner */
.consent-banner{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:9999;
  max-width:720px;margin:0 auto;
  background:rgba(15,24,50,.96);backdrop-filter:blur(12px);
  border:1px solid rgba(120,160,255,.28);border-radius:14px;
  padding:18px 20px;color:#e6ecff;
  font-family:"Inter",system-ui,sans-serif;font-size:14px;line-height:1.5;
  box-shadow:0 12px 40px rgba(0,0,0,.45);
  display:none;
}
.consent-banner.show{display:block}
.consent-banner p{margin:0 0 12px}
.consent-banner .consent-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.consent-banner button{
  font-family:"JetBrains Mono",ui-monospace,monospace;font-size:12px;font-weight:500;
  letter-spacing:.04em;text-transform:uppercase;
  padding:9px 16px;border-radius:8px;cursor:pointer;border:1px solid transparent;
}
.consent-banner .btn-accept{background:#5fe3ff;color:#0a1024}
.consent-banner .btn-accept:hover{background:#7eebff}
.consent-banner .btn-decline{background:transparent;color:#e6ecff;border-color:rgba(120,160,255,.32)}
.consent-banner .btn-decline:hover{border-color:rgba(120,160,255,.6)}
.consent-reopen{
  background:transparent;color:var(--ink-faint);border:1px solid var(--line);cursor:pointer;
  font-family:var(--mono);font-size:10px;
  letter-spacing:.08em;text-transform:uppercase;
  padding:6px 10px;border-radius:999px;display:inline-flex;
  line-height:1;align-self:center;
}
.consent-reopen:hover{color:var(--ink-dim);border-color:var(--line-strong)}

/* Skip link for keyboard/screen reader users */
.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  background:var(--cyan);color:#062032;padding:10px 18px;border-radius:0 0 8px 8px;
  text-decoration:none;font-weight:600;z-index:9999;
}
.skip-link:focus{position:fixed;left:50%;transform:translateX(-50%);width:auto;height:auto;top:0}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);font-family:var(--body);font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  min-height:100vh;
  background:
    radial-gradient(ellipse 80% 50% at 20% 0%, rgba(95,227,255,.10),transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 100%, rgba(255,93,122,.08),transparent 60%),
    linear-gradient(180deg,#0a1024 0%,#0c1330 100%);
  background-attachment:fixed;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(120,160,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(120,160,255,.05) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 100% 80% at 50% 50%,#000 30%,transparent 80%);
  z-index:0;
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.012) 0 1px,transparent 1px 3px);
  z-index:0;
}

.app{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:0 env(safe-area-inset-right) 0 env(safe-area-inset-left)}

/* Header */
header{
  display:flex;align-items:center;gap:18px;padding:16px 24px 12px;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:100;
  background:rgba(10,16,36,.85);backdrop-filter:blur(14px);
}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--ink)}
.brand .word{display:flex;flex-direction:column;line-height:1}
.brand .word b{font-family:var(--body);font-weight:700;letter-spacing:.01em;font-size:30px}
.brand .word b .wm-cloud{color:var(--ink)}
.brand .word b .wm-labs{color:var(--cyan)}
.brand .word small{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;color:var(--ink-faint);margin-top:6px;text-transform:uppercase}
.spacer{flex:1}
.top-right{display:flex;align-items:center;gap:10px}
.status-dot{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;color:var(--ink-dim);letter-spacing:.1em;text-transform:uppercase}
.status-dot::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
.lang-toggle{display:inline-flex;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:999px;padding:3px;font-family:var(--mono);font-size:11px}
.lang-toggle button{appearance:none;background:transparent;color:var(--ink-dim);border:0;padding:6px 12px;border-radius:999px;cursor:pointer;letter-spacing:.1em}
.lang-toggle button[aria-pressed="true"]{background:var(--cyan);color:#062032;font-weight:600}

/* Navigation */
.nav-wrap{
  position:relative;
  border-bottom:1px solid var(--line);
}
.nav-wrap::after{
  content:"";
  position:absolute;right:0;top:0;bottom:0;width:40px;
  background:linear-gradient(90deg,transparent,rgba(10,16,36,.85));
  pointer-events:none;
  opacity:0;transition:opacity .2s;
}
.nav-wrap.has-overflow::after{opacity:1}
nav.tabs{
  display:flex;gap:2px;padding:10px 14px;
  background:rgba(10,16,36,.6);backdrop-filter:blur(10px);
  overflow-x:auto;scrollbar-width:none;
}
nav.tabs::-webkit-scrollbar{display:none}
nav.tabs a{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--ink-faint);font-family:var(--mono);font-size:13px;letter-spacing:.16em;text-transform:uppercase;
  padding:11px 16px;cursor:pointer;border-radius:6px;white-space:nowrap;
  text-decoration:none;font-weight:500;
  transition:color .15s,background .15s;
}
nav.tabs a .n{font-size:10px;color:var(--ink-faint);opacity:.6;font-weight:400}
nav.tabs a[aria-current="page"]{
  color:#062032;
  background:var(--cyan);
}
nav.tabs a[aria-current="page"] .n{color:#062032;opacity:.7}
nav.tabs a[aria-current="page"]:hover{background:#7ee9ff}
nav.tabs a:hover{color:var(--ink)}

/* Main content */
main{padding:28px 24px 40px}

/* Typography */
.eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--cyan);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--cyan)}

h1,h2,h3{font-family:var(--body);letter-spacing:-.02em;line-height:1.1}
h1{font-size:clamp(28px,5.4vw,52px);font-weight:300;line-height:1.08}
h1 .l1{display:block;font-size:.55em;font-style:italic;color:var(--ink-dim);font-weight:300;letter-spacing:.005em;margin-bottom:6px}
h1 .l2{display:block;color:var(--ink);font-weight:600;white-space:nowrap}
h1 .l2 em{font-style:italic;color:var(--cyan);font-weight:600}
h1 .l3{display:block;font-size:.55em;color:var(--ink-dim);font-weight:300;margin-top:8px}
h2{font-size:clamp(22px,4.2vw,34px);font-weight:600;margin-bottom:10px}
h3{font-size:16px;font-weight:600;letter-spacing:-.01em}
p{color:var(--ink-dim);line-height:1.65;font-size:15px}
p strong{color:var(--ink);font-weight:600}
.lede{font-size:clamp(15px,1.8vw,17px);color:var(--ink);max-width:62ch;line-height:1.6;margin-top:14px}
.muted{color:var(--ink-faint)}
.accent{color:var(--cyan)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:999px;border:1px solid var(--line-strong);background:rgba(255,255,255,.03);color:var(--ink);text-decoration:none;font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .2s}
.btn:hover{background:rgba(95,227,255,.08);border-color:var(--cyan)}
.btn.primary{background:var(--cyan);color:#062032;border-color:var(--cyan);font-weight:600}
.btn.primary:hover{background:#7ee9ff}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(3px)}

/* Cards & grid */
.services{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:18px}
.card{border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,0));border-radius:12px;padding:18px;position:relative;overflow:hidden;transition:border-color .2s,transform .2s}
.card:hover{border-color:var(--line-strong)}
.card .tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;color:var(--cyan);text-transform:uppercase;margin-bottom:10px}
.card h3{margin-bottom:8px;color:var(--ink)}
.card p{font-size:13.5px}
.card .ix{position:absolute;top:14px;right:14px;font-family:var(--mono);font-size:10px;color:var(--ink-faint)}

/* Method steps */
.method{display:grid;grid-template-columns:1fr;gap:10px;margin-top:18px}
.step{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:14px 16px;border:1px solid var(--line);background:rgba(255,255,255,.02);border-radius:10px;align-items:start}
.step .num{font-family:var(--mono);font-size:22px;font-weight:300;color:var(--cyan);line-height:1;min-width:38px}
.step h3{margin-bottom:4px}
.step p{font-size:13.5px}

/* Findings */
.findings-nav{display:flex;align-items:center;gap:6px;margin-top:14px;flex-wrap:wrap}
.findings-nav .pills{display:flex;gap:6px;flex-wrap:wrap;flex:1;min-width:0}
.findings-nav .pill-btn{appearance:none;background:rgba(255,255,255,.02);border:1px solid var(--line);color:var(--ink-dim);font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;padding:7px 11px;border-radius:999px;cursor:pointer;transition:all .15s;white-space:nowrap}
.findings-nav .pill-btn:hover{color:var(--ink);border-color:var(--line-strong)}
.findings-nav .pill-btn[aria-current="true"]{background:rgba(95,227,255,.12);border-color:var(--cyan);color:var(--cyan)}
.findings-nav .arrows{display:flex;gap:4px;margin-left:auto}
.findings-nav .arrow-btn{appearance:none;background:rgba(255,255,255,.02);border:1px solid var(--line);color:var(--ink-dim);width:32px;height:32px;border-radius:999px;cursor:pointer;display:grid;place-items:center;transition:all .15s;font-size:14px}
.findings-nav .arrow-btn:hover{color:var(--cyan);border-color:var(--cyan)}
.findings-nav .arrow-btn:disabled{opacity:.3;cursor:not-allowed}
.findings-stage{position:relative;margin-top:14px}
.finding-card{border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0));border-radius:12px;padding:18px 20px;display:none;animation:fadeIn .25s ease}
.finding-card.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.finding-head{display:flex;justify-content:space-between;align-items:start;gap:14px;padding-bottom:10px;border-bottom:1px solid var(--line);margin-bottom:12px}
.finding-head .id{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--ink-faint);text-transform:uppercase}
.finding-head h3{margin-top:4px;font-size:18px;color:var(--ink)}
.chip{font-family:var(--mono);font-size:10px;letter-spacing:.18em;font-weight:600;padding:5px 10px;border-radius:4px;text-transform:uppercase;white-space:nowrap}
.chip.hoog{background:rgba(255,93,122,.15);color:#ff8aa0;border:1px solid rgba(255,93,122,.4)}
.chip.middel{background:rgba(255,180,84,.15);color:#ffc97a;border:1px solid rgba(255,180,84,.4)}
.chip.laag{background:rgba(95,227,255,.12);color:var(--cyan);border:1px solid rgba(95,227,255,.4)}
.chip.geen{background:rgba(82,227,164,.12);color:var(--green);border:1px solid rgba(82,227,164,.4)}
.finding-body p{font-size:13.5px;margin-bottom:8px;color:var(--ink-dim);line-height:1.6}
.finding-body .lbl{font-style:italic;font-weight:600;color:var(--ink);margin-right:6px}
.risk-legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.pill{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--ink-dim);text-transform:uppercase;border:1px solid var(--line);padding:3px 8px;border-radius:999px;display:inline-block}

/* Engagement */
.price-row{display:flex;align-items:baseline;gap:12px;margin-top:8px;flex-wrap:wrap}
.price-row .big{font-family:var(--body);font-size:42px;font-weight:700;color:var(--ink)}
.price-row .unit{font-family:var(--mono);font-size:12px;color:var(--ink-dim);letter-spacing:.1em;text-transform:uppercase}
.vat-note{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;color:var(--green);letter-spacing:.16em;text-transform:uppercase;border:1px solid rgba(82,227,164,.4);background:rgba(82,227,164,.08);padding:4px 9px;border-radius:4px;margin-top:6px}
.vat-note::before{content:"+";font-weight:700}
.blocks{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:18px}
.block{border:1px solid var(--line);background:rgba(255,255,255,.02);border-radius:10px;padding:14px 10px;text-align:center}
.block .h{font-family:var(--body);font-size:30px;color:var(--cyan);font-weight:700;line-height:1}
.block .l{font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--ink-faint);margin-top:6px;text-transform:uppercase}
.block .d{font-size:11.5px;color:var(--ink-dim);margin-top:8px;line-height:1.35}
.terms{margin-top:18px;display:grid;grid-template-columns:1fr;gap:10px}
.term{display:flex;gap:10px;font-size:13px;color:var(--ink-dim);padding:10px 0;border-top:1px dashed var(--line);line-height:1.55}
.term .k{font-family:var(--mono);font-size:10px;color:var(--cyan);letter-spacing:.14em;text-transform:uppercase;min-width:110px;padding-top:2px;flex-shrink:0}

/* About */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:24px;margin-top:14px;align-items:start}
.portrait{position:relative;border:1px solid var(--line-strong);border-radius:12px;padding:22px;background:linear-gradient(180deg,rgba(95,227,255,.06),rgba(95,227,255,0))}
.portrait .pic{width:128px;height:128px;border-radius:50%;overflow:hidden;border:2px solid var(--cyan);box-shadow:0 0 0 4px rgba(95,227,255,.10),0 18px 40px -16px rgba(95,227,255,.5);margin:0 auto 14px;display:block;background:#06091a}
.portrait .pic img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.02) contrast(1.02)}
.portrait .badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;color:var(--cyan);text-transform:uppercase;border:1px solid rgba(95,227,255,.4);border-radius:4px;padding:4px 8px}
.portrait .center{text-align:center}
.portrait .name{font-family:var(--body);font-size:26px;font-weight:700;margin-top:10px;line-height:1.1}
.portrait .role{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--ink-dim);text-transform:uppercase;margin-top:6px}
.portrait .meta{margin-top:18px;display:grid;grid-template-columns:auto 1fr;gap:6px 12px;font-size:13px}
.portrait .meta .k{font-family:var(--mono);font-size:10px;color:var(--ink-faint);letter-spacing:.14em;text-transform:uppercase;padding-top:3px}
.portrait .meta .v{color:var(--ink)}
.portrait a{color:var(--cyan);text-decoration:none;border-bottom:1px dotted var(--cyan)}
.bio p{font-size:14px;margin-bottom:10px;line-height:1.65}
.bio .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.bio .tag{font-family:var(--mono);font-size:10.5px;border:1px solid var(--line);padding:4px 9px;border-radius:999px;color:var(--ink-dim);letter-spacing:.08em}
.bio h3{margin-top:14px;margin-bottom:6px;font-size:14px;color:var(--cyan);font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-weight:500}

/* Book / form */
.book-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:14px;align-items:start}
.form{border:1px solid var(--line);background:rgba(255,255,255,.02);border-radius:12px;padding:18px;display:flex;flex-direction:column}
.form label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--ink-faint);text-transform:uppercase;margin-bottom:6px}
.form .field{margin-bottom:12px}
.form input,.form select,.form textarea{width:100%;background:rgba(0,0,0,.25);border:1px solid var(--line);border-radius:6px;padding:10px 12px;color:var(--ink);font-family:var(--body);font-size:14px;outline:none;transition:border-color .15s}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--cyan)}
.form textarea{resize:vertical;min-height:70px}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-actions{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap}
.calendar-card{border:1px solid var(--line);background:rgba(255,255,255,.02);border-radius:12px;padding:18px;display:flex;flex-direction:column}
.calendar-card .cal-frame{border-radius:8px;overflow:hidden;margin-top:12px;border:1px solid var(--line);background:#fff;height:600px;position:relative}
.calendar-card .cal-frame iframe{width:100%;height:100%;border:0;display:block}

/* Home specific */
.home-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:28px;align-items:center;min-height:calc(100vh - 220px)}
.home-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:22px;max-width:480px}
.stat{border:1px solid var(--line);background:rgba(255,255,255,.02);border-radius:10px;padding:12px 14px}
.stat .n{font-family:var(--body);font-size:28px;font-weight:700;color:var(--ink);line-height:1}
.stat .l{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-top:6px;line-height:1.4}
.cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.hero-visual{position:relative;height:100%;min-height:300px;display:grid;place-items:center}
.cluster-frame{position:relative;width:100%;max-width:520px;aspect-ratio:1;border-radius:18px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 30px 90px -30px rgba(95,227,255,.4),inset 0 1px 0 rgba(255,255,255,.05);background:#06091a}
.cluster-frame .photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.05) contrast(1.05)}
.cluster-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,16,36,.05) 0%,rgba(10,16,36,.55) 100%),radial-gradient(ellipse 80% 40% at 50% 100%,rgba(95,227,255,.18),transparent 70%);pointer-events:none}
.chip-overlay{position:absolute;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--ink);text-transform:uppercase;background:rgba(10,16,36,.78);padding:6px 10px;border:1px solid var(--line-strong);border-radius:5px;backdrop-filter:blur(8px);display:inline-flex;align-items:center;gap:7px;z-index:2}
.chip-overlay::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.chip-overlay.tl{top:14px;left:14px}
.chip-overlay.tr{top:14px;right:14px}
.chip-overlay.bl{bottom:14px;left:14px}
.chip-overlay.br{bottom:14px;right:14px}
.chip-overlay.amber::before{background:var(--amber);box-shadow:0 0 8px var(--amber)}

/* Grid helpers */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* Social proof */
.social-proof{margin-top:40px;padding-top:28px;border-top:1px solid var(--line)}
.social-proof .sp-label{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:16px}
.logo-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.logo-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:rgba(255,255,255,.03);border-radius:8px;padding:10px 16px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim)}
.logo-pill .lp-icon{width:18px;height:18px;border-radius:3px;background:var(--line-strong);flex-shrink:0}
.testimonial{margin-top:28px;border:1px solid var(--line);background:rgba(255,255,255,.02);border-radius:12px;padding:20px 22px;max-width:72ch}
.testimonial blockquote{font-size:15px;line-height:1.7;color:var(--ink-dim);font-style:italic;quotes:"\201C""\201D"}
.testimonial blockquote::before{content:open-quote;color:var(--cyan);font-size:24px;line-height:0;vertical-align:-.4em;margin-right:4px}
.testimonial cite{display:block;margin-top:12px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-style:normal}

/* ── Scroll animations ─────────────────────────────────────── */
/* Elements start invisible; JS adds .is-visible when in view */
.anim-fade{opacity:0;transition:opacity .55s ease,transform .55s ease}
.anim-fade.is-visible{opacity:1;transform:none!important}

/* Fade up (default) */
.anim-up{transform:translateY(28px)}
/* Fade in from left */
.anim-left{transform:translateX(-28px)}
/* Fade in from right */
.anim-right{transform:translateX(28px)}
/* Scale up slightly */
.anim-scale{transform:scale(.94)}

/* Staggered children: each child gets a delay via --i */
.anim-stagger > *{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .45s ease,transform .45s ease;
  transition-delay:calc(var(--i,0) * 80ms);
}
.anim-stagger.is-visible > *{opacity:1;transform:none}

/* Hero cluster frame entrance */
.cluster-frame{
  animation:clusterIn .9s cubic-bezier(.16,1,.3,1) both;
}
@keyframes clusterIn{
  from{opacity:0;transform:scale(.92) translateY(16px)}
  to{opacity:1;transform:none}
}

/* Stat counter (number animates up) */
.stat .n{transition:color .3s}

/* Page entrance — main fades in on load */
main{animation:pageIn .45s ease both}
@keyframes pageIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:none}
}

/* ── End scroll animations ─────────────────────────────────── */

/* Footer */
footer{border-top:1px solid var(--line);padding:16px 24px;font-family:var(--mono);font-size:11px;color:var(--ink-faint);letter-spacing:.08em;display:flex;gap:16px;flex-wrap:wrap;align-items:center}
footer a{color:var(--ink-faint);text-decoration:none}
footer a:hover{color:var(--ink-dim)}
.brand-version{font-size:9.5px;opacity:.6}

/* Responsive */
@media(max-width:760px){
  header{padding:10px 14px;gap:10px}
  .brand .word b{font-size:20px}
  .brand .word small{display:none}
  .status-dot{display:none}
  main{padding:16px 16px 32px}
  .home-grid{grid-template-columns:1fr;gap:14px;align-items:start}
  .hero-visual{display:none}
  .home-stats{grid-template-columns:repeat(2,1fr);max-width:none;margin-top:14px;gap:6px}
  .stat{padding:9px 10px}
  .stat .n{font-size:22px}
  h1{font-size:28px}
  h2{font-size:22px}
  .lede{font-size:14px;margin-top:10px}
  p{font-size:13.5px}
  .cta-row{margin-top:14px;gap:8px}
  .btn{padding:10px 14px;font-size:11px}
  .services{grid-template-columns:1fr;gap:10px;margin-top:10px}
  .card{padding:14px}
  .step{padding:12px 14px;gap:12px}
  .step .num{font-size:18px;min-width:28px}
  .finding-card{padding:14px 16px}
  .finding-head h3{font-size:15px}
  .price-row .big{font-size:32px}
  .blocks{grid-template-columns:repeat(2,1fr);gap:6px;margin-top:12px}
  .about-grid{grid-template-columns:1fr;gap:14px}
  .portrait{padding:16px}
  .portrait .pic{width:96px;height:96px;margin-bottom:10px}
  .portrait .name{font-size:22px}
  .book-grid{grid-template-columns:1fr;gap:12px}
  .calendar-card .cal-frame{height:480px}
  nav.tabs{padding:8px 8px}
  nav.tabs a{padding:9px 11px;font-size:11px;letter-spacing:.12em}
  nav.tabs a .n{display:none}
  .grid-2{grid-template-columns:1fr}
}
@media(max-width:380px){
  h1{font-size:24px}
}

html[data-lang="en"] [lang="nl"]{display:none}
html[data-lang="nl"] [lang="en"]{display:none}

/* Code-block copy button (blog articles) */
.article .code-block{position:relative}
.article .code-block .copy-btn{
  position:absolute;top:8px;right:8px;
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(95,227,255,.08);color:var(--cyan);
  border:1px solid rgba(95,227,255,.22);border-radius:4px;
  padding:4px 9px;
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;opacity:.35;transition:opacity .15s,background .15s,border-color .15s;
}
.article .code-block:hover .copy-btn{opacity:1}
.article .code-block .copy-btn:hover{background:rgba(95,227,255,.16)}
.article .code-block .copy-btn.copied{background:rgba(95,227,255,.22);border-color:var(--cyan);opacity:1}
@media (hover:none){
  .article .code-block .copy-btn{opacity:.7}
}

/* Blog-article lede: override the global .lede max-width (62ch) so the
   lede wraps at the same right margin as the body paragraphs (75ch). */
.article .lede{max-width:none}

/* Sticky TOC sidebar (blog articles, desktop only).
   Right-anchored to the .app container's right edge (the .app is max-width:1400px
   centered). Article body keeps its natural 75ch width on the left. */
.article-toc-sticky{display:none}
@media (min-width:1200px){
  .article-toc-sticky{
    display:block;
    position:fixed;top:90px;
    right:calc(max(0px, (100vw - 1400px) / 2) + 32px);
    width:280px;max-height:calc(100vh - 130px);overflow-y:auto;
    background:rgba(15,24,50,.5);border:1px solid var(--line);border-radius:8px;
    padding:18px 22px;font-size:13.5px;z-index:5;
  }
  .article-toc-sticky .toc-title{
    font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
    color:var(--cyan);margin-bottom:10px;
  }
  .article-toc-sticky ol{
    margin:0;padding-left:22px;color:var(--ink-dim);line-height:1.5;
  }
  .article-toc-sticky li{margin-bottom:6px}
  .article-toc-sticky a{color:var(--ink-dim);text-decoration:none;border:none;transition:color .15s}
  .article-toc-sticky a:hover{color:var(--cyan)}
  .article-toc-sticky a.active{color:var(--cyan);font-weight:600}
  /* Hide the in-document TOC on desktop since the sticky one replaces it */
  .article [lang] > .toc{display:none}
}
