/* ==========================================================================
   RaadScope, gedeelde stylesheet voor de subpagina's (zelfde look als de home)
   Tokens en componenten afgeleid van index.html. Fonts lokaal uit ../fonts.
   ========================================================================== */

/* ---------- Lettertypen (lokaal, SIL OFL) ---------- */
@font-face{ font-family:'Newsreader'; font-style:normal; font-weight:400 600; font-display:swap;
  src:url(../fonts/newsreader-latin-f24c3215.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face{ font-family:'Newsreader'; font-style:italic; font-weight:400 600; font-display:swap;
  src:url(../fonts/newsreader-latin-97c9a2c1.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face{ font-family:'IBM Plex Sans'; font-style:normal; font-weight:400 700; font-stretch:100%; font-display:swap;
  src:url(../fonts/ibmplexsans-latin-868a235a.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face{ font-family:'IBM Plex Mono'; font-style:normal; font-weight:400; font-display:swap;
  src:url(../fonts/ibmplexmono-latin-e2661bcc.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }

:root{
  --ink:#0d1b2a; --ink-soft:#33425a; --muted:#5c6a7e; --line:#e1e6ee; --line-soft:#edf0f6;
  --paper:#f3f6fb; --white:#ffffff;
  --blue-900:#0e2a50; --blue-800:#143a6b; --blue-700:#1b4d8f; --blue-600:#2563ad; --blue-500:#3b82d6; --blue-100:#e3edfb; --blue-50:#eff5ff;
  --green-700:#156b48; --green-600:#1b855a; --green-100:#e0f1e8; --hl:#fbe7b3;
  --radius:14px; --radius-sm:9px;
  --shadow-sm:0 1px 2px rgba(13,27,42,.05), 0 1px 1px rgba(13,27,42,.04);
  --shadow-md:0 14px 38px -22px rgba(14,42,80,.45), 0 2px 8px -4px rgba(14,42,80,.12);
  --shadow-lg:0 40px 80px -40px rgba(14,42,80,.45), 0 10px 28px -18px rgba(14,42,80,.22);
  --ff-display:"Newsreader", Georgia, "Times New Roman", serif;
  --ff-sans:"IBM Plex Sans", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --ff-mono:"IBM Plex Mono", ui-monospace, Menlo, Consolas, monospace;
  --maxw:1160px;
}
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; font-family:var(--ff-sans); color:var(--ink); background:var(--paper); line-height:1.62; font-size:17px; font-weight:450; -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(1100px 520px at 78% -8%, rgba(37,99,173,.10), transparent 60%), radial-gradient(820px 480px at -6% 4%, rgba(27,133,90,.07), transparent 55%); }
img,svg{ display:block; max-width:100%; }
a{ color:var(--blue-700); text-decoration:none; }
a:hover{ color:var(--blue-600); }
h1,h2,h3,h4{ font-family:var(--ff-display); color:var(--ink); font-weight:500; letter-spacing:-.012em; line-height:1.14; margin:0; }
p{ margin:0; }
:focus-visible{ outline:3px solid var(--blue-500); outline-offset:3px; border-radius:6px; }
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:24px; }
.skip{ position:absolute; left:14px; top:-60px; z-index:200; background:var(--blue-800); color:#fff; padding:11px 16px; border-radius:8px; transition:top .18s ease; font-weight:600; }
.skip:focus{ top:14px; color:#fff; }

/* ---------- Knoppen ---------- */
.btn{ display:inline-flex; align-items:center; gap:.6em; font-family:var(--ff-sans); font-weight:600; font-size:16px; line-height:1; padding:14px 22px; border-radius:10px; border:1px solid transparent; cursor:pointer; transition:transform .14s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease; white-space:nowrap; }
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--blue-800); color:#fff; box-shadow:var(--shadow-md); }
.btn-primary:hover{ background:var(--blue-700); color:#fff; transform:translateY(-2px); }
.btn-ghost{ background:var(--white); color:var(--blue-800); border-color:var(--line); box-shadow:var(--shadow-sm); }
.btn-ghost:hover{ border-color:var(--blue-500); color:var(--blue-700); transform:translateY(-2px); }
.btn-lg{ padding:16px 28px; font-size:17px; }
.btn-white{ background:#fff; color:var(--blue-900); }
.btn-white:hover{ background:#f1f5fb; color:var(--blue-900); transform:translateY(-2px); }
.btn-light{ background:rgba(255,255,255,.12); color:#fff; border-color:rgba(255,255,255,.32); }
.btn-light:hover{ background:rgba(255,255,255,.2); color:#fff; }

/* ---------- Header / nav ---------- */
.site-header{ position:sticky; top:0; z-index:100; background:rgba(243,246,251,.82); backdrop-filter:saturate(140%) blur(10px); -webkit-backdrop-filter:saturate(140%) blur(10px); border-bottom:1px solid transparent; transition:border-color .25s ease, box-shadow .25s ease; }
.site-header.scrolled{ border-bottom-color:var(--line); box-shadow:0 8px 24px -22px rgba(14,42,80,.6); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:24px; height:72px; }
.brand{ display:inline-flex; align-items:center; gap:11px; color:var(--ink); font-weight:700; }
.brand:hover{ color:var(--ink); }
.brand .mark{ width:34px; height:34px; flex:0 0 auto; color:var(--blue-700); }
.brand .word{ font-family:var(--ff-display); font-size:23px; font-weight:600; letter-spacing:-.02em; }
.brand .word b{ color:var(--blue-700); font-weight:600; }
.nav-links{ display:flex; align-items:center; gap:6px; list-style:none; margin:0; padding:0; }
.nav-links a{ color:var(--ink-soft); font-weight:500; font-size:15.5px; padding:9px 13px; border-radius:8px; transition:background .16s ease, color .16s ease; }
.nav-links a:hover{ color:var(--blue-800); background:rgba(37,99,173,.08); }
.nav-links a[aria-current="page"]{ color:var(--blue-800); background:rgba(37,99,173,.1); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.hamburger{ display:none; width:46px; height:42px; align-items:center; justify-content:center; background:var(--white); border:1px solid var(--line); border-radius:10px; cursor:pointer; color:var(--ink); }
.hamburger svg{ width:22px; height:22px; }
.mobile-menu{ display:none; }

/* ---------- Tekst-helpers ---------- */
.eyebrow{ display:inline-flex; align-items:center; gap:9px; font-family:var(--ff-mono); font-size:12.5px; font-weight:500; letter-spacing:.13em; text-transform:uppercase; color:var(--blue-700); background:var(--blue-50); border:1px solid var(--blue-100); padding:6px 12px; border-radius:999px; }
.eyebrow.green{ color:var(--green-700); background:var(--green-100); border-color:#cfe9da; }
.eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:currentColor; }
.pad{ padding-block:clamp(48px,7vw,84px); }
.divider{ border:0; height:1px; background:linear-gradient(90deg, transparent, var(--line), transparent); margin:0; }

/* ---------- Subhero ---------- */
.subhero{ padding-top:clamp(36px,5vw,64px); padding-bottom:clamp(24px,3vw,40px); }
.subhero .eyebrow{ margin-bottom:18px; }
.subhero h1{ font-size:clamp(32px,4.6vw,52px); line-height:1.08; letter-spacing:-.02em; max-width:16em; }
.subhero .lead{ margin-top:20px; font-size:clamp(17.5px,1.5vw,20px); color:var(--ink-soft); max-width:40em; }
.subhero .actions{ margin-top:28px; display:flex; flex-wrap:wrap; gap:14px; }
.breadcrumb{ font-size:14px; color:var(--muted); margin-bottom:20px; }
.breadcrumb a{ color:var(--muted); } .breadcrumb a:hover{ color:var(--blue-700); }

/* ---------- Prose / content ---------- */
.prose{ max-width:46em; }
.prose h2{ font-size:clamp(24px,2.6vw,32px); margin-top:40px; }
.prose h3{ font-size:20px; margin-top:28px; }
.prose p{ margin-top:14px; color:var(--ink-soft); font-size:17.5px; }
.prose ul{ margin-top:14px; padding-left:0; list-style:none; display:flex; flex-direction:column; gap:11px; }
.prose ul li{ display:flex; gap:12px; align-items:flex-start; color:var(--ink-soft); font-size:17px; }
.prose ul li::before{ content:""; flex:0 0 auto; width:22px; height:22px; margin-top:1px; border-radius:50%; background:var(--green-100) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23156b48' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/14px no-repeat; }

/* ---------- Kaarten ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:40px; }
.cards.two{ grid-template-columns:repeat(2,1fr); }
.card{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:26px; box-shadow:var(--shadow-sm); }
.card h3{ font-size:20px; }
.card p{ margin-top:10px; color:var(--ink-soft); font-size:15.5px; }
.card .num{ font-family:var(--ff-mono); font-size:13px; color:var(--blue-600); }

/* ---------- Voorbeeld-resultaat ---------- */
.example{ margin-top:36px; background:#fff; border:1px solid var(--line); border-left:3px solid var(--blue-600); border-radius:12px; padding:18px 20px; box-shadow:var(--shadow-md); max-width:640px; }
.example .head{ display:flex; flex-wrap:wrap; align-items:center; gap:10px; }
.example .av{ width:30px; height:30px; border-radius:50%; display:grid; place-items:center; color:#fff; font-size:12.5px; font-weight:600; }
.example .who{ font-weight:600; font-size:14.5px; }
.example .party{ font-size:12px; color:var(--ink-soft); background:var(--paper); border:1px solid var(--line); border-radius:999px; padding:2px 9px; display:inline-flex; align-items:center; gap:6px; }
.example .party .pd{ width:8px; height:8px; border-radius:50%; }
.example .tc{ margin-left:auto; font-family:var(--ff-mono); font-size:12px; color:var(--blue-700); }
.example .meet{ margin-top:6px; font-size:12.5px; color:var(--muted); }
.example .snip{ margin-top:8px; font-size:14.5px; color:var(--ink-soft); }
.example mark{ background:var(--hl); color:var(--ink); padding:0 2px; border-radius:3px; font-weight:600; }

/* ---------- Prijskaarten ---------- */
.plans{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:40px; align-items:start; }
.plan{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:28px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.plan.featured{ border:1.5px solid var(--blue-600); box-shadow:var(--shadow-lg); }
.plan .pname{ font-family:var(--ff-display); font-size:23px; font-weight:600; }
.plan .ptag{ margin-top:6px; color:var(--muted); font-size:14.5px; min-height:40px; }
.plan .price{ margin-top:16px; padding-top:16px; border-top:1px solid var(--line); font-family:var(--ff-display); font-size:21px; color:var(--blue-800); }
.plan .price small{ display:block; font-family:var(--ff-sans); font-size:13px; color:var(--muted); margin-top:4px; }
.plan ul{ list-style:none; margin:20px 0 24px; padding:0; display:flex; flex-direction:column; gap:11px; }
.plan li{ display:flex; gap:11px; font-size:15px; color:var(--ink-soft); }
.plan li::before{ content:""; flex:0 0 auto; width:20px; height:20px; border-radius:50%; background:var(--green-100) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23156b48' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/13px no-repeat; }
.plan .btn{ margin-top:auto; justify-content:center; }

/* ---------- CTA-band ---------- */
.cta-band{ padding-block:clamp(48px,7vw,84px); }
.cta-box{ position:relative; overflow:hidden; background:linear-gradient(155deg, var(--blue-800), var(--blue-900) 70%); border-radius:24px; padding:clamp(36px,5vw,60px); color:#fff; text-align:center; box-shadow:var(--shadow-lg); }
.cta-box::before{ content:""; position:absolute; inset:0; pointer-events:none; opacity:.8; background:radial-gradient(520px 280px at 84% -20%, rgba(59,130,214,.5), transparent 60%), radial-gradient(460px 260px at 6% 120%, rgba(27,133,90,.42), transparent 60%); }
.cta-box>*{ position:relative; }
.cta-box h2{ color:#fff; font-size:clamp(26px,3.4vw,40px); margin-top:8px; }
.cta-box p{ color:#cdddf0; margin:16px auto 0; max-width:38em; font-size:18px; }
.cta-box .actions{ margin-top:28px; display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }

/* ---------- Footer ---------- */
.site-footer{ background:#0a1f3d; color:#9fb6d4; padding-block:56px 30px; margin-top:20px; }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:34px; }
.footer-brand .brand .word{ color:#fff; } .footer-brand .brand .word b{ color:#7fb0ec; } .footer-brand .brand .mark{ color:#7fb0ec; }
.footer-brand p{ margin-top:16px; max-width:30em; font-size:14.5px; color:#8ea7c6; }
.footer-col h4{ font-family:var(--ff-sans); font-size:13px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:#cfe0f4; }
.footer-col ul{ list-style:none; margin:16px 0 0; padding:0; display:flex; flex-direction:column; gap:11px; }
.footer-col a{ color:#9fb6d4; font-size:14.5px; } .footer-col a:hover{ color:#fff; }
.footer-bottom{ margin-top:44px; padding-top:22px; border-top:1px solid rgba(255,255,255,.1); display:flex; flex-wrap:wrap; gap:12px 24px; align-items:center; justify-content:space-between; font-size:13.5px; color:#7e98ba; }
.footer-bottom .dom{ font-family:var(--ff-mono); }

/* ---------- Responsive ---------- */
@media (max-width:1000px){ .cards{ grid-template-columns:repeat(2,1fr); } .plans{ grid-template-columns:1fr; max-width:520px; margin-inline:auto; } .footer-grid{ grid-template-columns:1fr 1fr; gap:30px; } }
@media (max-width:720px){
  .nav-links, .nav-cta .btn{ display:none; }
  .hamburger{ display:inline-flex; }
  .cards, .cards.two{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
  .mobile-menu{ display:none; position:fixed; inset:72px 0 0; z-index:90; background:var(--paper); padding:24px; flex-direction:column; gap:6px; border-top:1px solid var(--line); overflow:auto; }
  body.nav-open .mobile-menu{ display:flex; }
  body.nav-open{ overflow:hidden; }
  .mobile-menu a{ padding:14px 12px; border-radius:10px; font-size:18px; color:var(--ink); font-weight:500; }
  .mobile-menu .btn{ margin-top:14px; justify-content:center; }
}
