/* Gegenereerde, samengevoegde stylesheet voor rapidcode.nl */
/* Bron: index.php (leidend), propositie, paginablokken, tekstblokken, index2, fonts, hero, hero2 */

:root {
  --primary: #0F2044;
  --primary-deep: #0A1733;
  --bg: #F8F6F1;
  --accent: #3B7A57;
  --accent-soft: #4A9E7A;
  --accent-bright: #6FCF97;
  --secondary: #EDEAE4;
  --text: #1A1A2E;
  --shadow: 0 8px 32px rgba(15, 32, 68, 0.08);
  --shadow-lg: 0 22px 60px rgba(10, 23, 51, 0.28);
  --radius: 8px;
  --maxw: 1180px;
  --success: #2D6A4F;
  --danger: #B23A48;
}

/* ===== uit index.php ===== */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg); color: var(--text); font-family: "Outfit", system-ui, sans-serif; font-weight: 400; line-height: 1.7; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
h1, h2, h3, h4, .wordmark { font-family: "Bricolage Grotesque", system-ui, sans-serif; }
h2 { font-weight: 700; font-size: clamp(1.9rem, 3.4vw, 2.6rem); line-height: 1.16; letter-spacing: -0.015em; color: var(--primary); margin: 0 0 0.5em; }
h3 { font-weight: 700; font-size: 1.35rem; line-height: 1.3; color: var(--primary); margin: 0 0 0.5em; }
p { margin: 0 0 1.15em; max-width: 64ch; }
p:last-child { margin-bottom: 0; }
.eyebrow { font-family: "Outfit", system-ui, sans-serif; font-size: 0.8rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); margin: 0 0 1.2rem; }
.lead { font-size: 1.2rem; font-weight: 500; color: rgba(26,26,46,0.82); }
section { padding: clamp(3.5rem, 7vw, 6rem) 1.5rem; }
.inner { max-width: var(--maxw); margin: 0 auto; }
.bg-warm { background: var(--bg); }
.bg-grey { background: var(--secondary); }
.bg-navy { background: var(--primary); color: var(--bg); }
.bg-deep { background: var(--primary-deep); color: var(--bg); }
.bg-green { background: var(--accent); color: #fff; }
.bg-navy .eyebrow, .bg-deep .eyebrow { color: var(--accent-bright); }
.bg-navy h2, .bg-navy h3, .bg-deep h2, .bg-deep h3 { color: #fff; }
.bg-navy p, .bg-deep p { color: rgba(248,246,241,0.82); }
.bg-green h2, .bg-green p { color: #fff; }
.section-head { margin-bottom: 3rem; max-width: 760px; }
.section-head h2 { margin-bottom: 0.3em; }
.section-head p { color: rgba(26, 26, 46, 0.72); margin: 0; font-size: 1.1rem; }
.bg-navy .section-head p, .bg-deep .section-head p { color: rgba(248,246,241,0.82); }
.section-head--center { margin-left: auto; margin-right: auto; text-align: center; }
.btn { display: inline-flex; align-items: center; gap: 0.6rem; background: var(--accent); color: var(--bg); font-family: "Outfit", system-ui, sans-serif; font-weight: 600; font-size: 0.98rem; padding: 0.9rem 1.8rem; border: none; border-radius: var(--radius); cursor: pointer; text-decoration: none; box-shadow: var(--shadow); transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease; }
.btn:hover { transform: translateY(-2px); box-shadow: 0 12px 36px rgba(15,32,68,0.18); background: var(--accent-soft); }
.btn--light { background: #fff; color: var(--primary); }
.btn--lg { font-size: 1.05rem; padding: 1.05rem 2.2rem; }
.site-head { position: sticky; top: 0; z-index: 50; background: var(--primary); border-bottom: 1px solid rgba(255,255,255,0.08); }
.site-head__bar { position: relative; max-width: var(--maxw); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; padding: 0.67rem 1.5rem; }
.brand { display: inline-flex; flex-direction: column; line-height: 1.05; text-decoration: none; }
.brand__name { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 1.75rem; color: #fff; letter-spacing: -0.01em; }
.brand__tld { color: var(--accent-bright); }
.brand__payoff { font-family: "Outfit", sans-serif; font-weight: 400; font-size: 0.54rem; letter-spacing: 0.01em; color: #fff; margin-top: 0.2rem; }
@media (min-width: 1024px) {
      .brand__name { font-size: 2.1rem; }
      .brand__payoff { font-size: 0.64rem; }
    }
.nav-toggle { display: inline-flex; flex-direction: column; justify-content: center; gap: 5px; width: 46px; height: 46px; border: none; background: transparent; cursor: pointer; padding: 0; }
.nav-toggle span { display: block; height: 2.5px; width: 26px; margin: 0 auto; background: #fff; border-radius: 2px; transition: transform 0.25s ease, opacity 0.2s ease; }
.nav-toggle.is-open span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2) { opacity: 0; }
.nav-toggle.is-open span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }
body.nav-open { overflow: hidden; }
.nav-panel { position: fixed; inset: 0; z-index: 200; background: linear-gradient(180deg, var(--primary) 0%, var(--primary-deep) 100%); color: #fff; opacity: 0; visibility: hidden; transform: scale(1.02); transition: opacity 0.3s ease, transform 0.3s ease, visibility 0s linear 0.3s; display: flex; flex-direction: column; }
.nav-panel.is-open { opacity: 1; visibility: visible; transform: scale(1); transition: opacity 0.3s ease, transform 0.3s ease, visibility 0s linear 0s; }
.nav-panel__top { display: flex; align-items: center; justify-content: space-between; padding: 0.95rem 1.5rem; max-width: var(--maxw); width: 100%; margin: 0 auto; }
.nav-panel__brand { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 2.4rem; letter-spacing: -0.01em; color: #fff; text-decoration: none; }
.nav-panel__brand .brand__tld { color: var(--accent-bright); }
.nav-close { background: transparent; border: none; width: 46px; height: 46px; display: inline-flex; align-items: center; justify-content: center; border-radius: 8px; cursor: pointer; position: relative; transition: background 0.15s ease; }
.nav-close:hover { background: rgba(255,255,255,0.1); }
.nav-close span { position: absolute; width: 26px; height: 2.5px; background: #fff; border-radius: 2px; }
.nav-close span:nth-child(1) { transform: rotate(45deg); }
.nav-close span:nth-child(2) { transform: rotate(-45deg); }
.nav-panel ul { list-style: none; margin: auto auto; padding: 1.5rem clamp(1.5rem, 7vw, 5rem); max-width: var(--maxw); width: 100%; display: flex; flex-direction: column; gap: clamp(0.4rem, 1.4vw, 0.9rem); }
.nav-panel a { display: inline-flex; align-items: center; gap: 1rem; font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; letter-spacing: -0.02em; font-size: clamp(2.2rem, 6.5vw, 4.4rem); line-height: 1.04; color: #fff; text-decoration: none; transition: color 0.15s ease, transform 0.15s ease; }
.nav-panel a::before { content: ""; flex: 0 0 auto; width: 0.42em; height: 0.42em; border-radius: 50%; border: 2px solid rgba(111,207,151,0.45); transition: background 0.15s ease, border-color 0.15s ease; }
.nav-panel a:hover { color: var(--accent-bright); transform: translateX(8px); }
.nav-panel a:hover::before { background: var(--accent-bright); border-color: var(--accent-bright); }
.code-stage { max-width: 1000px; margin: 0 auto; }
@media (min-width: 1100px) { .code-stage { max-width: 1280px; } }
@media (min-width: 1500px) { .code-stage { max-width: 1500px; } }
#ct-code { height: clamp(420px, 66vh, 640px); overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end; background: #0A0A0C; border-radius: 12px; padding: 1.6rem 1.8rem; box-shadow: 0 18px 60px rgba(15,32,68,0.22); font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 0.98rem; line-height: 1.75; color: #E6E6E6; contain: content; overflow-anchor: none; }
#ct-code .row { flex: 0 0 auto; white-space: pre-wrap; word-break: break-word; min-height: 1.75em; overflow-anchor: none; }
.t-kw { color: #C792EA; }
.t-str { color: #C3E88D; }
.t-num { color: #F78C6C; }
.t-fn { color: #82AAFF; }
.t-ty { color: #FFCB6B; }
.t-com { color: #5C6370; font-style: italic; }
.t-pun { color: #89DDFF; }
.t-op { color: #89DDFF; }
.t-ag { color: #6FCF97; font-style: italic; }
.t-file { color: #82AAFF; font-weight: 700; }
.t-sh { color: #E6E6E6; }
.ct-caret { display: inline-block; width: 9px; height: 1.05em; background: #6FCF97; vertical-align: text-bottom; margin-left: 2px; animation: ct-blink 1s steps(1) infinite; }
@keyframes ct-blink { 50% { opacity: 0; } }
.hero-wrap { position: relative; }
.hero-overlay { position: absolute; inset: 0; border-radius: 12px; pointer-events: none; background: linear-gradient(90deg, rgba(8,10,18,0.74) 0%, rgba(8,10,18,0.58) 40%, rgba(8,10,18,0.30) 74%, rgba(8,10,18,0.08) 100%), linear-gradient(0deg, rgba(8,10,18,0.30), rgba(8,10,18,0.00)); }
.hero-content { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: center; gap: 0.9rem; padding: clamp(1.8rem, 5vw, 3.6rem); pointer-events: none; }
.hero-content > * { pointer-events: auto; }
.hero-content .eyebrow { margin: 0; color: #9BF0C6; text-shadow: 0 1px 10px rgba(0,0,0,0.85), 0 0 2px rgba(0,0,0,0.6); }
.hero-title { font-family: "Bricolage Grotesque", system-ui, sans-serif; font-weight: 700; letter-spacing: -0.02em; font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1.05; margin: 0; max-width: 18ch; color: #fff; text-shadow: 0 2px 24px rgba(0,0,0,0.5); }
.hero-sub { margin: 0; max-width: 44ch; font-size: clamp(1rem, 1.6vw, 1.2rem); color: rgba(255,255,255,0.85); text-shadow: 0 1px 12px rgba(0,0,0,0.55); }
.hero-cta { align-self: flex-start; margin-top: 0.6rem; padding: 0.85rem 1.6rem; border-radius: 999px; background: var(--accent); color: #fff; font-weight: 600; font-size: 0.98rem; text-decoration: none; transition: background 0.2s ease, transform 0.2s ease; }
.hero-cta:hover { background: var(--accent-soft); transform: translateY(-1px); }
.feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: 1.8rem; }
.feature-card { background: #fff; border-radius: 14px; overflow: hidden; box-shadow: var(--shadow-lg); display: flex; flex-direction: column; border: 1px solid rgba(15,32,68,0.05); transition: transform 0.15s ease, box-shadow 0.15s ease; }
.feature-card:hover { transform: translateY(-4px); box-shadow: 0 26px 70px rgba(10,23,51,0.34); }
.feature-card__img { height: 220px; position: relative; }
.feature-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.feature-card__body { padding: 1.8rem 1.8rem 2rem; }
.feature-card__body h3 { color: var(--primary); margin-bottom: 0.4em; }
.feature-card__body p { font-size: 1rem; color: rgba(26,26,46,0.74); margin: 0; }
.media-split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: start; }
.media-split + .media-split { margin-top: clamp(2.5rem, 5vw, 4.5rem); }
.media-split--reverse .media-split__media { order: 2; }
.media-split__media { border-radius: 14px; overflow: hidden; box-shadow: var(--shadow-lg); aspect-ratio: 4 / 3; position: relative; }
.media-split__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.media-split__num { position: absolute; left: 1.1rem; top: 1.1rem; width: 2.9rem; height: 2.9rem; border-radius: 50%; background: var(--accent); color: #fff; font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 1.15rem; display: flex; align-items: center; justify-content: center; box-shadow: 0 8px 22px rgba(0,0,0,0.35); }
.media-split__body h3 { font-size: clamp(1.4rem, 2.6vw, 2rem); color: var(--primary); }
.stat-cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.8rem; }
.stat-card { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); border-radius: 14px; padding: 2.3rem 2rem; }
.stat-card strong { display: block; font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: clamp(2.8rem, 6vw, 4rem); color: var(--accent-bright); line-height: 1; letter-spacing: -0.02em; }
.stat-card h3 { color: #fff; margin: 0.7rem 0 0.7rem; }
.stat-card p { color: rgba(248,246,241,0.8); margin: 0; font-size: 1rem; }
.quote-block { display: grid; grid-template-columns: 0.8fr 1.2fr; background: #fff; border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-lg); }
.quote-block__media img { width: 100%; height: 100%; object-fit: cover; display: block; min-height: 360px; }
.quote-block__body { padding: clamp(2.2rem, 5vw, 3.6rem); }
.quote-block .q-mark { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 3.2rem; line-height: 0.6; color: var(--accent-soft); display: block; margin-bottom: 0.6rem; }
.quote-block blockquote { margin: 0; font-family: "Bricolage Grotesque", sans-serif; font-weight: 600; font-size: clamp(1.3rem, 2.2vw, 1.85rem); line-height: 1.36; color: var(--primary); letter-spacing: -0.01em; }
.quote-block cite { display: block; margin-top: 1.4rem; font-style: normal; font-family: "Inter", sans-serif; }
.quote-block cite strong { display: block; color: var(--primary); }
.quote-block cite span { color: rgba(26,26,46,0.6); font-size: 0.9rem; }
.cover-block { position: relative; border-radius: 16px; overflow: hidden; min-height: clamp(380px, 52vh, 520px); display: flex; align-items: center; box-shadow: var(--shadow-lg); }
.cover-block > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.cover-block__scrim { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(10,23,51,0.92) 0%, rgba(10,23,51,0.66) 52%, rgba(10,23,51,0.32) 100%); }
.cover-block__body { position: relative; padding: clamp(2.2rem, 5vw, 4rem); max-width: 680px; color: #fff; }
.cover-block__body .eyebrow { color: var(--accent-bright); }
.cover-block__body h2 { color: #fff; }
.cover-block__body p { color: rgba(255,255,255,0.92); }
.table-wrap { overflow-x: auto; border-radius: 14px; box-shadow: var(--shadow-lg); }
.compare { width: 100%; border-collapse: collapse; background: #fff; min-width: 520px; }
.compare th, .compare td { padding: 1.05rem 1.4rem; text-align: left; font-size: 1rem; }
.compare thead th { background: var(--primary); color: #fff; font-family: "Outfit", sans-serif; font-weight: 600; }
.compare thead th.col-hl { background: var(--accent); }
.compare tbody th { font-weight: 600; color: var(--primary); font-family: "Outfit", sans-serif; }
.compare tbody td { color: rgba(26,26,46,0.78); }
.compare tbody tr { border-top: 1px solid rgba(15,32,68,0.08); }
.compare .col-hl { background: rgba(59,122,87,0.08); color: var(--primary); font-weight: 600; }
.logos { display: flex; flex-wrap: wrap; gap: 1rem 2.6rem; align-items: center; justify-content: center; margin-bottom: 3.2rem; }
.logos span { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 1.35rem; color: #fff; opacity: 0.62; letter-spacing: -0.01em; }
.testi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.8rem; }
.testi { background: #fff; border-radius: 14px; padding: 2.1rem 2rem; box-shadow: var(--shadow-lg); }
.testi blockquote { margin: 0 0 1.3rem; font-family: "Bricolage Grotesque", sans-serif; font-weight: 600; font-size: 1.25rem; line-height: 1.42; color: var(--primary); letter-spacing: -0.01em; }
.testi cite { font-style: normal; font-family: "Inter", sans-serif; color: rgba(26,26,46,0.6); font-size: 0.9rem; }
.cta-band { text-align: center; max-width: 720px; margin: 0 auto; }
.cta-band .btn { margin-top: 1.8rem; }
@media (max-width: 820px) {
      .media-split { grid-template-columns: 1fr; }
      .media-split--reverse .media-split__media { order: 0; }
      .quote-block { grid-template-columns: 1fr; }
    }
.page-foot { padding: clamp(3rem, 6vw, 4.5rem) 1.5rem 2.5rem; font-family: "Inter", sans-serif; font-size: 0.9rem; color: rgba(248,246,241,0.7); }
.foot-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); }
.foot-brand .wordmark { font-family: "Bricolage Grotesque", sans-serif; font-size: 2rem; font-weight: 700; color: var(--bg); letter-spacing: -0.01em; display: inline-block; margin-bottom: 1rem; }
.foot-brand .brand__tld { color: var(--accent-bright); }
.foot-brand p { max-width: 40ch; color: rgba(248,246,241,0.6); margin: 0; line-height: 1.7; }
.foot-col h4 { font-family: "Outfit", sans-serif; font-size: 0.8rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-bright); margin: 0 0 1.1rem; }
.foot-col address { font-style: normal; line-height: 1.8; color: rgba(248,246,241,0.7); margin-bottom: 1rem; }
.foot-col a { color: rgba(248,246,241,0.7); text-decoration: none; transition: color 0.15s ease; }
.foot-col a:hover { color: #fff; }
.foot-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.7rem; }
.foot-bottom { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 1rem; margin-top: clamp(2.5rem, 5vw, 3.5rem); padding-top: 1.6rem; border-top: 1px solid rgba(255,255,255,0.1); font-size: 0.82rem; color: rgba(248,246,241,0.55); }
.foot-bottom a { color: rgba(248,246,241,0.55); text-decoration: none; transition: color 0.15s ease; }
.foot-bottom a:hover { color: #fff; }
@media (max-width: 720px) { .foot-grid { grid-template-columns: 1fr; } }

/* ===== uit propositie.php ===== */
h1 { font-weight: 700; font-size: clamp(2.3rem, 5vw, 3.4rem); line-height: 1.08; letter-spacing: -0.02em; color: var(--primary); margin: 0 0 0.4em; }
.page-hero { padding-top: clamp(3.5rem, 8vw, 6.5rem); padding-bottom: clamp(2.5rem, 6vw, 4.5rem); }
.page-hero .lead { margin-top: 0.4rem; }
.prose { max-width: 72ch; }
.prose p { color: rgba(26,26,46,0.82); }
.card-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: 1.6rem; }
.card-grid--two { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
.info-card { background: #fff; border-radius: 14px; padding: 1.9rem 1.9rem 2rem; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); }
.info-card h3 { margin-bottom: 0.5rem; }
.info-card p { font-size: 1rem; color: rgba(26,26,46,0.74); margin: 0; }
.duo { display: grid; grid-template-columns: 1fr 1fr; gap: 1.6rem; }
.duo-card { background: #fff; border-radius: 14px; padding: 1.9rem 1.9rem 2rem; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); }
.duo-card h3 { display: flex; align-items: center; gap: 0.6rem; }
.duo-card__yes { border-top: 4px solid var(--success); }
.duo-card__no { border-top: 4px solid #B23A48; }
.tick-list { list-style: none; margin: 1rem 0 0; padding: 0; display: flex; flex-direction: column; gap: 0.75rem; }
.tick-list li { position: relative; padding-left: 1.9rem; color: rgba(26,26,46,0.82); font-size: 1rem; line-height: 1.5; }
.tick-list li::before { position: absolute; left: 0; top: 0.05rem; font-weight: 700; font-family: "Inter", sans-serif; }
.tick-list--yes li::before { content: "✓"; color: var(--success); }
.tick-list--no li::before { content: "✕"; color: #B23A48; }
.palette { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 1.4rem; }
.swatch { background: #fff; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.swatch__color { height: 120px; }
.swatch__meta { padding: 1rem 1.1rem 1.2rem; font-family: "Inter", sans-serif; }
.swatch__name { font-weight: 600; font-size: 0.95rem; color: var(--primary); display: block; }
.swatch__hex { font-size: 0.85rem; letter-spacing: 0.04em; color: rgba(26,26,46,0.55); display: block; margin-top: 0.2rem; text-transform: uppercase; }
.swatch__hint { font-size: 0.78rem; color: rgba(26,26,46,0.55); display: block; margin-top: 0.5rem; line-height: 1.45; }
.ratio-bar { display: flex; height: 56px; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); margin-bottom: 1.2rem; }
.ratio-bar span { display: flex; align-items: center; justify-content: center; font-family: "Inter", sans-serif; font-size: 0.78rem; font-weight: 600; color: #fff; }
.ratio-legend { display: flex; flex-wrap: wrap; gap: 0.6rem 1.6rem; font-family: "Inter", sans-serif; font-size: 0.85rem; color: rgba(26,26,46,0.7); }
.ratio-legend span { display: inline-flex; align-items: center; gap: 0.5rem; }
.ratio-legend i { width: 0.85rem; height: 0.85rem; border-radius: 3px; display: inline-block; }
.font-list { display: grid; gap: 1.2rem; }
.font-row { background: #fff; border-radius: 12px; padding: 1.4rem 1.6rem; box-shadow: var(--shadow); display: flex; flex-wrap: wrap; align-items: baseline; justify-content: space-between; gap: 0.6rem; }
.font-row strong { font-family: "Inter", sans-serif; font-weight: 600; font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }
.font-row span { font-family: "Inter", sans-serif; font-size: 0.85rem; color: rgba(26,26,46,0.6); }
.chips { display: flex; flex-wrap: wrap; gap: 0.7rem; }
.chip { font-family: "Inter", sans-serif; font-size: 0.9rem; padding: 0.5rem 1rem; border-radius: 999px; background: rgba(178,58,72,0.08); color: #B23A48; border: 1px solid rgba(178,58,72,0.2); text-decoration: line-through; }
.ptable { width: 100%; border-collapse: collapse; background: #fff; min-width: 620px; }
.ptable th, .ptable td { padding: 1rem 1.3rem; text-align: left; font-size: 0.98rem; vertical-align: top; }
.ptable thead th { background: var(--primary); color: #fff; font-family: "Outfit", sans-serif; font-weight: 600; }
.ptable tbody th { font-weight: 600; color: var(--primary); font-family: "Outfit", sans-serif; white-space: nowrap; }
.ptable tbody td { color: rgba(26,26,46,0.78); }
.ptable tbody tr { border-top: 1px solid rgba(15,32,68,0.08); }
.ptable .num { font-family: "Inter", sans-serif; color: var(--accent); font-weight: 700; }
.rules { display: grid; gap: 1rem; counter-reset: rule; }
.rule { display: grid; grid-template-columns: 3rem 1fr; gap: 1.2rem; align-items: start; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 1.3rem 1.5rem; }
.rule::before { counter-increment: rule; content: counter(rule, decimal-leading-zero); font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 1.3rem; color: var(--accent-bright); line-height: 1.4; }
.rule p { margin: 0; color: rgba(248,246,241,0.86); font-size: 1rem; }
.rule strong { color: #fff; }
@media (max-width: 720px) {
      .duo { grid-template-columns: 1fr; }
      .rule { grid-template-columns: 2.2rem 1fr; gap: 0.9rem; }
    }

/* ===== uit paginablokken.php ===== */
h4 { font-weight: 700; font-size: 1.05rem; color: var(--primary); margin: 0 0 0.4em; }
a { color: var(--accent); }
.bg-navy h2, .bg-navy h3, .bg-navy h4, .bg-deep h2, .bg-deep h3, .bg-deep h4 { color: #fff; }
.kicker { display: inline-flex; align-items: center; gap: 0.6rem; font-family: "Inter", sans-serif; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); background: rgba(59,122,87,0.12); border: 1px solid rgba(59,122,87,0.3); padding: 0.4rem 0.9rem; border-radius: 999px; margin-bottom: 1.4rem; }
.block-label { font-family: "Inter", sans-serif; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(26,26,46,0.45); margin: 0 0 1rem; }
.bg-navy .block-label, .bg-deep .block-label { color: rgba(248,246,241,0.5); }
.block + .block { margin-top: clamp(3rem, 6vw, 5rem); }
.btn--ghost { background: transparent; color: var(--primary); box-shadow: none; border: 1.5px solid rgba(15,32,68,0.25); }
.btn--ghost:hover { background: rgba(15,32,68,0.04); box-shadow: none; }
figure { margin: 0; }
.credit { display: block; font-family: "Inter", sans-serif; font-size: 0.72rem; color: rgba(26,26,46,0.45); margin-top: 0.5rem; }
.bg-navy .credit, .bg-deep .credit, .cover-block .credit { color: rgba(255,255,255,0.55); }
.media-split__media figcaption { position: absolute; left: 0; right: 0; bottom: 0; padding: 0.5rem 0.9rem; background: linear-gradient(0deg, rgba(10,23,51,0.7), rgba(10,23,51,0)); color: rgba(255,255,255,0.7); font-family: "Inter", sans-serif; font-size: 0.7rem; }
.icon-card { background: #fff; border-radius: 14px; padding: 2rem 1.9rem; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); transition: transform 0.15s ease, box-shadow 0.15s ease; }
.icon-card:hover { transform: translateY(-3px); box-shadow: 0 16px 44px rgba(15,32,68,0.13); }
.icon-card .ic { width: 52px; height: 52px; border-radius: 12px; background: rgba(59,122,87,0.1); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 1.1rem; }
.icon-card svg { width: 26px; height: 26px; stroke: var(--accent); stroke-width: 1.7; fill: none; stroke-linecap: round; stroke-linejoin: round; }
.icon-card p { font-size: 1rem; color: rgba(26,26,46,0.74); margin: 0; }
.icon-card--navy .ic { background: rgba(15,32,68,0.08); }
.icon-card--navy svg { stroke: var(--primary); }
.stat-card span { display: block; margin-top: 0.6rem; color: rgba(248,246,241,0.82); font-size: 0.98rem; }
.timeline { position: relative; margin-left: 0.5rem; padding-left: 2.2rem; border-left: 2px solid rgba(15,32,68,0.14); display: flex; flex-direction: column; gap: 2.2rem; }
.timeline__item { position: relative; }
.timeline__item::before { content: ""; position: absolute; left: -2.66rem; top: 0.35rem; width: 14px; height: 14px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 4px rgba(59,122,87,0.18); }
.timeline__year { font-family: "Inter", sans-serif; font-weight: 700; font-size: 0.85rem; letter-spacing: 0.06em; color: var(--accent); }
.timeline__item h4 { margin: 0.2rem 0 0.3rem; }
.timeline__item p { margin: 0; color: rgba(26,26,46,0.74); font-size: 1rem; }
.team-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.6rem; }
.team-card { background: #fff; border-radius: 14px; padding: 2rem 1.8rem; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); text-align: center; }
.team-card .avatar { width: 76px; height: 76px; border-radius: 50%; margin: 0 auto 1.1rem; display: flex; align-items: center; justify-content: center; font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 1.7rem; color: #fff; background: linear-gradient(135deg, var(--primary), var(--accent)); }
.team-card h4 { margin-bottom: 0.15rem; }
.team-card .role { font-family: "Inter", sans-serif; font-size: 0.85rem; color: var(--accent); display: block; margin-bottom: 0.7rem; }
.team-card p { font-size: 0.92rem; color: rgba(26,26,46,0.66); margin: 0; }
.quote-band { max-width: 880px; margin: 0 auto; text-align: center; }
.quote-band .q-mark { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 3.4rem; line-height: 0.5; color: var(--accent-bright); }
.quote-band blockquote { margin: 1rem 0 1.4rem; font-family: "Bricolage Grotesque", sans-serif; font-weight: 600; font-size: clamp(1.4rem, 3vw, 2.1rem); line-height: 1.35; color: #fff; letter-spacing: -0.01em; }
.quote-band cite { font-style: normal; font-family: "Inter", sans-serif; color: rgba(248,246,241,0.7); font-size: 0.92rem; }
.check-card { background: #fff; border-radius: 16px; box-shadow: var(--shadow-lg); padding: clamp(2rem, 5vw, 3rem); border: 1px solid rgba(15,32,68,0.05); }
.check-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1rem 2rem; }
.check-list li { position: relative; padding-left: 2.1rem; color: rgba(26,26,46,0.82); line-height: 1.5; }
.check-list li::before { content: ""; position: absolute; left: 0; top: 0.15rem; width: 1.3rem; height: 1.3rem; border-radius: 50%; background: var(--success); }
.check-list li::after { content: "✓"; position: absolute; left: 0.34rem; top: 0.05rem; color: #fff; font-size: 0.8rem; font-weight: 700; font-family: "Inter", sans-serif; }
.faq { display: flex; flex-direction: column; gap: 0.9rem; max-width: 820px; }
.faq details { background: #fff; border-radius: 12px; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); overflow: hidden; }
.faq summary { list-style: none; cursor: pointer; padding: 1.2rem 1.5rem; font-family: "Bricolage Grotesque", sans-serif; font-weight: 600; font-size: 1.1rem; color: var(--primary); display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-family: "Inter", sans-serif; font-weight: 400; font-size: 1.5rem; color: var(--accent); transition: transform 0.2s ease; line-height: 1; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details p { padding: 0 1.5rem 1.3rem; margin: 0; color: rgba(26,26,46,0.76); }
.cover-block .credit { position: absolute; right: 0.9rem; bottom: 0.7rem; margin: 0; }
.legal-banner { background: #fff; border-radius: 14px; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); border-left: 4px solid var(--accent); padding: 1.5rem 1.7rem; display: flex; flex-wrap: wrap; gap: 0.6rem 2rem; align-items: center; justify-content: space-between; }
.legal-banner span { font-family: "Inter", sans-serif; font-size: 0.9rem; color: rgba(26,26,46,0.7); }
.legal-banner strong { color: var(--primary); }
.legal-layout { display: grid; grid-template-columns: 240px 1fr; gap: clamp(2rem, 5vw, 3.5rem); align-items: start; }
.toc { position: sticky; top: 90px; background: #fff; border-radius: 12px; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); padding: 1.4rem 1.5rem; }
.toc h4 { font-family: "Inter", sans-serif; font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(26,26,46,0.5); margin: 0 0 0.9rem; }
.toc ol { margin: 0; padding-left: 1.2rem; display: flex; flex-direction: column; gap: 0.55rem; }
.toc a { font-family: "Inter", sans-serif; font-size: 0.92rem; color: rgba(26,26,46,0.75); text-decoration: none; }
.toc a:hover { color: var(--accent); }
.legal-article { margin: 0 0 2.4rem; }
.legal-article h3 { display: flex; gap: 0.7rem; }
.legal-article h3 .art-num { color: var(--accent); }
.legal-article p { color: rgba(26,26,46,0.8); }
.legal-sub { counter-reset: clause; list-style: none; margin: 0.6rem 0 0; padding: 0; display: flex; flex-direction: column; gap: 0.6rem; }
.legal-sub li { position: relative; padding-left: 2.6rem; color: rgba(26,26,46,0.78); }
.legal-sub li::before { counter-increment: clause; content: counter(clause); position: absolute; left: 0; top: 0; font-family: "Inter", sans-serif; font-size: 0.78rem; font-weight: 700; color: var(--accent); background: rgba(59,122,87,0.1); border-radius: 6px; width: 1.9rem; text-align: center; padding: 0.15rem 0; }
.defs { display: grid; gap: 0; background: #fff; border-radius: 12px; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); overflow: hidden; }
.defs > div { display: grid; grid-template-columns: 200px 1fr; gap: 1.5rem; padding: 1.1rem 1.5rem; border-top: 1px solid rgba(15,32,68,0.07); }
.defs > div:first-child { border-top: none; }
.defs dt { font-weight: 600; color: var(--primary); font-family: "Outfit", sans-serif; margin: 0; }
.defs dd { margin: 0; color: rgba(26,26,46,0.76); }
@media (max-width: 820px) {
      .media-split { grid-template-columns: 1fr; }
      .media-split--reverse .media-split__media { order: 0; }
      .legal-layout { grid-template-columns: 1fr; }
      .toc { position: static; }
      .defs > div { grid-template-columns: 1fr; gap: 0.3rem; }
    }
.contact-split { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(2rem, 5vw, 3.5rem); align-items: start; }
.form-card { background: #fff; border-radius: 16px; box-shadow: var(--shadow-lg); border: 1px solid rgba(15,32,68,0.05); padding: clamp(1.8rem, 4vw, 2.6rem); }
.field { margin-bottom: 1.2rem; }
.field label { display: block; font-family: "Inter", sans-serif; font-size: 0.82rem; font-weight: 600; color: var(--primary); margin-bottom: 0.4rem; }
.field input, .field textarea, .field select { width: 100%; font-family: "Outfit", sans-serif; font-size: 1rem; color: var(--text); padding: 0.8rem 1rem; border: 1.5px solid rgba(15,32,68,0.16); border-radius: var(--radius); background: var(--bg); transition: border-color 0.15s ease, box-shadow 0.15s ease; }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(59,122,87,0.14); }
.field textarea { resize: vertical; min-height: 130px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.contact-aside { display: flex; flex-direction: column; gap: 1.2rem; }
.contact-card { background: #fff; border-radius: 14px; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); padding: 1.5rem 1.6rem; display: flex; gap: 1rem; align-items: flex-start; }
.contact-card .ic { flex: 0 0 auto; width: 44px; height: 44px; border-radius: 10px; background: rgba(59,122,87,0.1); display: inline-flex; align-items: center; justify-content: center; }
.contact-card svg { width: 22px; height: 22px; stroke: var(--accent); stroke-width: 1.7; fill: none; stroke-linecap: round; stroke-linejoin: round; }
.contact-card h4 { margin: 0 0 0.2rem; }
.contact-card p, .contact-card address { margin: 0; font-style: normal; color: rgba(26,26,46,0.74); font-size: 0.96rem; line-height: 1.6; }
.contact-card a { color: var(--accent); text-decoration: none; }
.hours { list-style: none; margin: 0; padding: 0; }
.hours li { display: flex; justify-content: space-between; gap: 1rem; padding: 0.4rem 0; border-top: 1px solid rgba(15,32,68,0.07); font-family: "Inter", sans-serif; font-size: 0.92rem; color: rgba(26,26,46,0.74); }
.hours li:first-child { border-top: none; }
.hours li span:last-child { color: var(--primary); font-weight: 600; }
@media (max-width: 820px) {
      .contact-split { grid-template-columns: 1fr; }
      .field-row { grid-template-columns: 1fr; }
    }

/* ===== uit tekstblokken.php ===== */
.bg-navy .lead, .bg-deep .lead { color: rgba(248,246,241,0.94); }
.bg-navy .block-list li, .bg-deep .block-list li { color: rgba(248,246,241,0.86); }
.bg-navy .block-list li::before, .bg-deep .block-list li::before { color: var(--accent-bright); }
.bg-green .eyebrow { color: rgba(255,255,255,0.85); }
.bg-green h2 { color: #fff; }
.bg-green p { color: rgba(255,255,255,0.92); }
.bg-navy .btn--ghost, .bg-deep .btn--ghost, .bg-green .btn--ghost { border-color: rgba(255,255,255,0.45); }
.btn--light:hover { background: #fff; }
.btn-row { display: flex; flex-wrap: wrap; gap: 1.1rem; align-items: center; margin-top: 1.8rem; }
.page-head { padding: 1.3rem 1.5rem; border-bottom: 1px solid rgba(15,32,68,0.08); }
.page-head .inner { display: flex; justify-content: flex-start; align-items: center; }
.back-link { font-family: "Inter", sans-serif; font-size: 0.85rem; font-weight: 600; color: rgba(26,26,46,0.6); text-decoration: none; }
.back-link:hover { color: var(--primary); }
.media-split__body h2 { margin-bottom: 0.25em; }
.block-list { list-style: none; padding: 0; margin: 1.6rem 0 0; display: grid; gap: 0.85rem; }
.block-list li { position: relative; padding-left: 2rem; color: rgba(26,26,46,0.84); font-weight: 500; }
.block-list li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--accent); font-weight: 700; }
.block-list li strong { font-weight: 700; }
.feature-card__metric { display: block; font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 2rem; color: var(--accent); line-height: 1; margin-bottom: 0.6rem; }
.quote-block__media { min-height: 100%; }
.quote-block .q-support { margin-top: 1.4rem; color: rgba(26,26,46,0.72); font-size: 1.02rem; }
.centered { max-width: 760px; margin: 0 auto; text-align: center; }
.centered p { margin-left: auto; margin-right: auto; }
.wide-media { margin-top: 3rem; border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-lg); aspect-ratio: 21 / 9; }
.wide-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.6rem; }
.step { background: #fff; border-radius: 14px; padding: 1.9rem 1.8rem; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); }
.step__num { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 1.05rem; width: 2.5rem; height: 2.5rem; border-radius: 50%; background: var(--accent); color: #fff; display: flex; align-items: center; justify-content: center; margin-bottom: 1.2rem; }
.step h3 { font-size: 1.2rem; color: var(--primary); }
.step p { font-size: 0.98rem; color: rgba(26,26,46,0.74); margin: 0; }
.stats-cover { position: relative; border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-lg); min-height: clamp(300px, 40vh, 400px); display: flex; align-items: center; }
.stats-cover > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.stats-cover__scrim { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(10,23,51,0.92), rgba(10,23,51,0.74)); }
.stats-cover__inner { position: relative; width: 100%; padding: clamp(2.2rem, 5vw, 3.6rem); display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 2rem; text-align: center; }
.stat-big strong { display: block; font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: clamp(2.4rem, 5vw, 3.4rem); color: #fff; line-height: 1; }
.stat-big span { display: block; margin-top: 0.6rem; color: rgba(255,255,255,0.82); font-size: 0.95rem; }
.gallery { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 190px; gap: 1rem; }
.gallery figure { margin: 0; border-radius: 12px; overflow: hidden; box-shadow: var(--shadow); }
.gallery img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gallery .g-wide { grid-column: span 2; }
.gallery .g-tall { grid-row: span 2; }
.quote-cover { position: relative; border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-lg); min-height: clamp(360px, 48vh, 480px); display: flex; align-items: center; justify-content: center; text-align: center; }
.quote-cover > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.quote-cover__scrim { position: absolute; inset: 0; background: rgba(10,23,51,0.74); }
.quote-cover__body { position: relative; max-width: 800px; padding: clamp(2rem, 5vw, 3.5rem); }
.quote-cover blockquote { margin: 0; font-family: "Bricolage Grotesque", sans-serif; font-weight: 600; font-size: clamp(1.5rem, 3vw, 2.3rem); line-height: 1.3; letter-spacing: -0.01em; color: #fff; }
.quote-cover cite { display: block; margin-top: 1.6rem; font-style: normal; font-family: "Inter", sans-serif; }
.quote-cover cite strong { display: block; color: #fff; }
.quote-cover cite span { color: rgba(255,255,255,0.75); font-size: 0.9rem; }
.cta-band .btn-row { justify-content: center; }
@media (max-width: 820px) {
      .media-split { grid-template-columns: 1fr; }
      .media-split--reverse .media-split__media { order: 0; }
      .quote-block { grid-template-columns: 1fr; }
      .wide-media { aspect-ratio: 16 / 9; }
      .gallery { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 150px; }
    }

/* ===== uit index2.php ===== */
.eyebrow, .btn { font-family: "Outfit", system-ui, sans-serif; }
.wordmark { font-weight: 700; letter-spacing: -0.01em; line-height: 1; color: var(--primary); display: inline-block; }
.wordmark--xl { font-size: clamp(3rem, 9vw, 7rem); }
.wordmark--light { color: var(--bg); }
.logo-stage { display: flex; align-items: center; justify-content: center; min-height: 340px; border-radius: 14px; box-shadow: var(--shadow); padding: 3rem; text-align: center; }
.logo-stage--white { background: #ffffff; }
.logo-stage--navy { background: var(--primary); }
.logo-caption { margin-top: 1.1rem; font-family: "Inter", sans-serif; font-size: 0.78rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(26, 26, 46, 0.55); }
.logo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; }
.logo-block { display: flex; flex-direction: column; }
.logo-block .logo-caption { text-align: center; }
.type-list { display: grid; gap: 2rem; }
.type-row { display: grid; grid-template-columns: 130px 1fr; gap: 2rem; align-items: baseline; padding-bottom: 2rem; border-bottom: 1px solid rgba(15,32,68,0.1); }
.type-row:last-child { border-bottom: none; padding-bottom: 0; }
.type-label { font-family: "Inter", sans-serif; font-size: 0.75rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); padding-top: 0.4rem; }
.type-sample p { margin: 0; }
.type-meta { font-family: "Inter", sans-serif; font-size: 0.78rem; color: rgba(26,26,46,0.5); margin-top: 0.5rem; }
.hero-demo { background: #fff; border-radius: 16px; box-shadow: var(--shadow); padding: clamp(2.5rem, 6vw, 5rem); display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 3rem; align-items: center; }
.hero-demo .eyebrow { margin-bottom: 1rem; }
.hero-demo h1 { margin-bottom: 0.5em; }
.hero-demo p { color: rgba(26,26,46,0.72); font-size: 1.1rem; }
.hero-aside { background: var(--secondary); border-radius: 12px; padding: 2rem; display: grid; gap: 1.25rem; }
.stat__num { font-family: "Inter", sans-serif; font-weight: 700; font-size: 2rem; color: var(--primary); line-height: 1; }
.stat__label { font-family: "Inter", sans-serif; font-size: 0.82rem; letter-spacing: 0.04em; color: rgba(26,26,46,0.6); margin-top: 0.3rem; }
.cta-band p { margin-left: auto; margin-right: auto; }
.icon-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 1.5rem; }
.icon-card span { display: block; margin-top: 1rem; font-family: "Inter", sans-serif; font-size: 0.8rem; letter-spacing: 0.04em; color: rgba(26,26,46,0.6); }
.page-head .wordmark { font-size: 1.4rem; }
.page-head .site { font-family: "Inter", sans-serif; font-size: 0.85rem; letter-spacing: 0.08em; color: rgba(26,26,46,0.55); }
.page-foot .wordmark { font-size: 1.2rem; margin-bottom: 0.8rem; }
.nav-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 1.1rem; margin-top: 1.2rem; }
@media (min-width: 1100px) {
      .nav-cards { grid-template-columns: repeat(5, 1fr); }
    }
.nav-card { display: flex; flex-direction: column; gap: 0.4rem; background: #fff; border-radius: 14px; padding: 1.4rem 1.4rem 1.3rem; text-decoration: none; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); transition: transform 0.15s ease, box-shadow 0.15s ease; }
.nav-card:hover { transform: translateY(-3px); box-shadow: 0 14px 40px rgba(15,32,68,0.13); }
.nav-card__eyebrow { font-family: "Inter", sans-serif; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); }
.nav-card__title { font-family: "Inter", sans-serif; font-weight: 700; font-size: 1.25rem; color: var(--primary); }
.nav-card__desc { font-size: 0.98rem; color: rgba(26,26,46,0.7); margin: 0.2rem 0 0.6rem; }
.nav-card__cta { font-family: "Inter", sans-serif; font-weight: 600; font-size: 0.9rem; color: var(--primary); }
@media (max-width: 760px) {
      .hero-demo { grid-template-columns: 1fr; }
      .type-row { grid-template-columns: 1fr; gap: 0.5rem; }
    }

/* ===== uit fonts.php ===== */
.page-head .brand { font-family: "Inter", sans-serif; font-weight: 600; letter-spacing: 0.08em; font-size: 1.4rem; color: var(--primary); }
.intro p { max-width: 64ch; color: rgba(26,26,46,0.72); font-size: 1.1rem; }
.font-card { background: #fff; border-radius: 16px; box-shadow: var(--shadow); border: 1px solid rgba(15,32,68,0.05); overflow: hidden; display: grid; grid-template-columns: 280px 1fr; }
.font-card__meta { background: var(--secondary); padding: 2rem 1.9rem; display: flex; flex-direction: column; gap: 0.6rem; }
.font-card__num { font-family: "Outfit", sans-serif; font-weight: 700; font-size: 0.8rem; letter-spacing: 0.12em; color: var(--accent); }
.font-card__name { font-family: "Outfit", sans-serif; font-weight: 700; font-size: 1.3rem; color: var(--primary); }
.font-card__combo { font-family: "Outfit", sans-serif; font-size: 0.78rem; letter-spacing: 0.04em; color: rgba(26,26,46,0.55); text-transform: uppercase; font-weight: 600; }
.font-card__desc { font-family: "Outfit", sans-serif; font-size: 0.92rem; color: rgba(26,26,46,0.7); margin-top: 0.3rem; }
.font-card__demo { padding: 2.4rem 2.2rem; display: flex; flex-direction: column; justify-content: center; gap: 1.2rem; }
.logo-test { line-height: 1; color: var(--primary); font-size: clamp(3rem, 7vw, 5.2rem); }
.sample-h { font-weight: 700; color: var(--primary); font-size: 1.6rem; line-height: 1.15; margin: 0; }
.sample-body { font-family: "Outfit", sans-serif; font-size: 1rem; color: rgba(26,26,46,0.72); margin: 0; max-width: 60ch; }
.divider { height: 1px; background: rgba(15,32,68,0.08); margin: 0.3rem 0; }
.f-unbounded { font-family: "Unbounded", sans-serif; }
.f-bricolage { font-family: "Bricolage Grotesque", sans-serif; }
.f-hanken { font-family: "Hanken Grotesk", sans-serif; }
.f-outfit { font-family: "Outfit", sans-serif; }
.f-sora { font-family: "Sora", sans-serif; }
.f-space { font-family: "Space Grotesk", sans-serif; }
.f-general { font-family: "General Sans", sans-serif; }
.body-hanken { font-family: "Hanken Grotesk", sans-serif; }
.logo-test.f-unbounded { font-weight: 600; letter-spacing: -0.01em; }
.logo-test.f-bricolage { font-weight: 700; letter-spacing: -0.01em; }
.logo-test.f-hanken { font-weight: 700; letter-spacing: -0.01em; }
.logo-test.f-outfit { font-weight: 600; }
.logo-test.f-sora { font-weight: 600; letter-spacing: -0.01em; }
.logo-test.f-space { font-weight: 700; }
.logo-test.f-general { font-weight: 600; }
.page-foot .inner { color: rgba(248,246,241,0.7); }
.page-foot .brand { font-family: "Inter", sans-serif; font-weight: 600; letter-spacing: 0.08em; font-size: 1.2rem; color: var(--bg); display: block; margin-bottom: 0.6rem; }
@media (max-width: 720px) {
      .font-card { grid-template-columns: 1fr; }
    }

/* ===== uit hero.php ===== */
h1, h2, .wordmark { font-family: "Bricolage Grotesque", system-ui, sans-serif; }
.page-intro { padding: clamp(3rem, 6vw, 4.5rem) 1.5rem 1rem; }
.page-intro .inner { max-width: var(--maxw); margin: 0 auto; }
.page-intro h1 { font-weight: 700; font-size: clamp(2rem, 4vw, 2.8rem); color: var(--primary); margin: 0 0 0.4em; letter-spacing: -0.02em; }
.page-intro p { max-width: 60ch; color: rgba(26,26,46,0.72); font-size: 1.1rem; margin: 0; }
.variant { padding: clamp(2.5rem, 5vw, 4rem) 1.5rem; }
.variant .inner { max-width: var(--maxw); margin: 0 auto; }
.variant__label { font-family: "Outfit", sans-serif; font-weight: 600; font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(26,26,46,0.5); margin: 0 0 1rem; }
.hero { position: relative; border-radius: 18px; overflow: hidden; box-shadow: var(--shadow); }
.hero h2 { margin: 0 0 0.5em; font-weight: 700; letter-spacing: -0.02em; line-height: 1.08; }
.hero p { margin: 0 0 1.8rem; }
.credit:hover { color: #fff; background: rgba(15,32,68,0.65); }
.credit--dark { color: rgba(15,32,68,0.7); background: rgba(248,246,241,0.7); }
.credit--dark:hover { color: var(--primary); background: rgba(248,246,241,0.95); }
.hero--cover { min-height: 520px; display: flex; align-items: center; justify-content: center; text-align: center; padding: clamp(2.5rem, 6vw, 5rem); }
.hero--cover .hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; z-index: 0; }
.hero--cover .hero__overlay { position: absolute; inset: 0; z-index: 1; }
.hero--cover .hero__content { position: relative; z-index: 2; max-width: 760px; color: #fff; }
.hero--cover h2 { color: #fff; font-size: clamp(2rem, 4.5vw, 3.4rem); }
.hero--cover p { color: rgba(255,255,255,0.88); font-size: 1.15rem; max-width: 60ch; margin-left: auto; margin-right: auto; }
.hero--split { display: grid; grid-template-columns: 1fr 1fr; min-height: 480px; background: #fff; }
.hero--split .hero__text { padding: clamp(2.5rem, 5vw, 4rem); display: flex; flex-direction: column; justify-content: center; }
.hero--split .hero__media { position: relative; background-size: cover; background-position: center; }
.hero--split.reverse .hero__text { order: 2; }
.hero--split.reverse .hero__media { order: 1; }
.hero--split h2 { color: var(--primary); font-size: clamp(1.8rem, 3.2vw, 2.6rem); }
.hero--split p { color: rgba(26,26,46,0.72); font-size: 1.1rem; }
.hero--split.on-grey { background: var(--secondary); }
.hero--bottom { min-height: 560px; display: flex; align-items: flex-end; padding: clamp(2.5rem, 5vw, 4rem); }
.hero--bottom .hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; z-index: 0; }
.hero--bottom .hero__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to top, rgba(15,32,68,0.85) 0%, rgba(15,32,68,0.25) 55%, rgba(15,32,68,0.05) 100%); }
.hero--bottom .hero__content { position: relative; z-index: 2; max-width: 640px; color: #fff; }
.hero--bottom h2 { color: #fff; font-size: clamp(2rem, 4vw, 3rem); }
.hero--bottom p { color: rgba(255,255,255,0.9); font-size: 1.12rem; }
.hero--light { display: grid; grid-template-columns: 1.05fr 0.95fr; min-height: 480px; background: var(--bg); border: 1px solid rgba(15,32,68,0.06); }
.hero--light .hero__text { padding: clamp(2.5rem, 5vw, 4rem); display: flex; flex-direction: column; justify-content: center; }
.hero--light .hero__media { position: relative; background-size: cover; background-position: center; }
.hero--light h2 { color: var(--primary); font-size: clamp(1.8rem, 3.4vw, 2.7rem); }
.hero--light p { color: rgba(26,26,46,0.72); font-size: 1.12rem; }
.hero--left { min-height: 540px; display: flex; align-items: center; padding: clamp(2.5rem, 5vw, 4.5rem); }
.hero--left .hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; z-index: 0; }
.hero--left .hero__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to right, rgba(15,32,68,0.9) 0%, rgba(15,32,68,0.6) 45%, rgba(15,32,68,0.15) 100%); }
.hero--left .hero__content { position: relative; z-index: 2; max-width: 620px; color: #fff; }
.hero--left h2 { color: #fff; font-size: clamp(2rem, 4vw, 3rem); }
.hero--left p { color: rgba(255,255,255,0.9); font-size: 1.12rem; }
.solid-block { padding: clamp(4rem, 9vw, 7.5rem) 1.5rem; }
.solid-block .inner { max-width: 900px; margin: 0 auto; text-align: center; color: #fff; }
.solid-block .variant__label { color: rgba(255,255,255,0.72); margin-bottom: 1.4rem; }
.solid-block h2 { font-family: "Bricolage Grotesque", sans-serif; color: #fff; font-weight: 700; letter-spacing: -0.02em; line-height: 1.08; font-size: clamp(2.2rem, 5vw, 3.6rem); margin: 0 0 0.5em; }
.solid-block p { color: rgba(255,255,255,0.92); font-size: 1.2rem; max-width: 60ch; margin: 0 auto 2rem; }
@media (max-width: 820px) {
      .hero--split, .hero--light { grid-template-columns: 1fr; }
      .hero--split .hero__media, .hero--light .hero__media { min-height: 260px; }
      .hero--split.reverse .hero__text { order: 1; }
      .hero--split.reverse .hero__media { order: 2; }
    }

/* ===== uit hero2.php ===== */
h1, .wordmark { font-family: "Bricolage Grotesque", system-ui, sans-serif; }
.intro h1 { font-weight: 700; font-size: clamp(2rem, 4vw, 2.8rem); color: var(--primary); margin: 0 0 0.4em; letter-spacing: -0.02em; }

