/*
Theme Name: Boekingsoftware
Theme URI: https://boekingsoftware.nl
Author: Samautomation
Description: Block-theme voor boekingsoftware.nl — onafhankelijke NL B2B-vergelijker voor boekings-/reserveringssoftware. Modern-minimal, merkkleur cobalt + functioneel groen/amber. Gegenereerd via /hallmark.
Version: 1.0.3
Requires at least: 6.5
Tested up to: 6.9
Requires PHP: 8.1
Text Domain: boekingsoftware
*/

/* ====== Component styling — token-driven (vult theme.json aan) ======
 * Hallmark · genre: modern-minimal · theme: custom (cobalt) · v1.0.0
 * Alle kleuren via --wp--preset--color--* tokens uit theme.json. */

:root {
  --bs-radius-sm: 6px;
  --bs-radius-md: 10px;
  --bs-radius-lg: 16px;
  --bs-radius-pill: 999px;
  --bs-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --bs-dur: 130ms;
  --bs-shadow-sm: 0 1px 2px oklch(40% 0.02 262 / 0.06), 0 1px 3px oklch(40% 0.02 262 / 0.05);
  --bs-shadow-md: 0 4px 12px oklch(40% 0.03 262 / 0.08), 0 2px 4px oklch(40% 0.02 262 / 0.05);
}

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; } }
body { -webkit-font-smoothing: antialiased; font-feature-settings: "ss01"; overflow-x: clip; }
:focus-visible { outline: 2px solid var(--wp--preset--color--accent); outline-offset: 2px; border-radius: var(--bs-radius-sm); }

/* ---- Header: N5 floating pill ---- */
.bs-header { position: sticky; top: 1rem; margin-top: 1rem; z-index: 100; padding-inline: 1rem; }
.bs-header__inner {
  max-width: 1140px; margin-inline: auto;
  display: flex; align-items: center; gap: 1.5rem;
  padding: 0.5rem 0.5rem 0.5rem 1rem;
  background: color-mix(in oklab, var(--wp--preset--color--paper) 84%, transparent);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--wp--preset--color--rule); border-radius: var(--bs-radius-pill);
  box-shadow: var(--bs-shadow-md);
}
.bs-brand { display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--wp--preset--font-family--display); font-weight: 600; font-size: 1.05rem; letter-spacing: -0.02em; color: var(--wp--preset--color--ink); text-decoration: none; white-space: nowrap; }
.bs-brand:hover { text-decoration: none; }
.bs-brand__mark { width: 26px; height: 26px; flex: none; }
.bs-brand__tld { font-family: var(--wp--preset--font-family--mono); font-weight: 500; color: var(--wp--preset--color--accent); }
.bs-header__nav { margin-left: auto; }
.bs-header__nav .wp-block-navigation__container { gap: 1.25rem; }
.bs-header__nav a { color: var(--wp--preset--color--ink-2); font-size: 0.9rem; font-weight: 500; text-decoration: none; }
.bs-header__nav a:hover { color: var(--wp--preset--color--ink); }
.bs-header__cta a { white-space: nowrap; font-size: 0.9rem; font-weight: 600; padding: 0.5rem 1rem; border-radius: var(--bs-radius-pill); background: var(--wp--preset--color--accent); color: var(--wp--preset--color--accent-ink) !important; text-decoration: none; transition: background var(--bs-dur) var(--bs-ease-out); }
.bs-header__cta a:hover { background: var(--wp--preset--color--accent-strong); }

/* ---- Hero ---- */
.bs-hero h1 { max-width: 16ch; }
.bs-hero .bs-hl { color: var(--wp--preset--color--accent); }
.bs-trust-note { display: flex; justify-content: center; align-items: center; gap: 0.5rem; font-size: 0.9rem; color: var(--wp--preset--color--muted); text-align: center; }
.bs-trust-note svg { color: var(--wp--preset--color--positive); flex: none; }
/* Hero CTA's gecentreerd */
.bs-hero .wp-block-buttons { justify-content: center; }

/* ---- Buttons (secondary outline) ---- */
.bs-btn-secondary a, a.bs-btn-secondary { background: transparent !important; color: var(--wp--preset--color--ink) !important; border: 1px solid var(--wp--preset--color--rule-2) !important; }
.bs-btn-secondary a:hover, a.bs-btn-secondary:hover { border-color: var(--wp--preset--color--ink) !important; }

/* ---- Branche cards ---- */
.bs-branche-card { display: flex; flex-direction: column; gap: 0.75rem; padding: 1.5rem; background: var(--wp--preset--color--paper-3); border: 1px solid var(--wp--preset--color--rule); border-radius: var(--bs-radius-md); text-decoration: none; transition: transform var(--bs-dur) var(--bs-ease-out), border-color var(--bs-dur) var(--bs-ease-out); height: 100%; }
.bs-branche-card:hover { transform: translateY(-2px); border-color: var(--wp--preset--color--accent); text-decoration: none; }
.bs-branche-card .bs-ico { width: 32px; height: 32px; color: var(--wp--preset--color--accent); }
.bs-branche-card h3 { color: var(--wp--preset--color--ink); hyphens: auto; }
.bs-branche-card p { font-size: 0.9rem; color: var(--wp--preset--color--ink-2); margin: 0; }
.bs-branche-card .bs-go { font-size: 0.9rem; font-weight: 600; color: var(--wp--preset--color--accent); margin-top: auto; }
.bs-branche-card.is-soon { opacity: 0.72; }
.bs-branche-card.is-soon .bs-go { color: var(--wp--preset--color--muted); }

/* ---- Comparison table ---- */
.bs-sample-banner { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; color: var(--wp--preset--color--warning-ink); background: var(--wp--preset--color--warning-soft); border: 1px solid oklch(80% 0.08 75); padding: 0.75rem 1rem; border-radius: var(--bs-radius-sm); }
.bs-table-scroll { overflow-x: auto; border: 1px solid var(--wp--preset--color--rule-2); border-radius: var(--bs-radius-md); background: var(--wp--preset--color--paper); }
.bs-cmp { width: 100%; border-collapse: collapse; min-width: 640px; font-size: 0.9rem; }
.bs-cmp th, .bs-cmp td { text-align: left; padding: 1rem; border-bottom: 1px solid var(--wp--preset--color--rule); }
.bs-cmp thead th { font-family: var(--wp--preset--font-family--display); font-weight: 600; color: var(--wp--preset--color--ink); background: var(--wp--preset--color--paper-3); }
.bs-cmp tbody tr:last-child td { border-bottom: none; }
.bs-cmp tbody tr.is-winner { background: var(--wp--preset--color--accent-soft); }
.bs-cmp .bs-toolname { font-weight: 600; color: var(--wp--preset--color--ink); display: flex; align-items: center; gap: 0.5rem; }
.bs-cmp .bs-price { font-family: var(--wp--preset--font-family--mono); font-variant-numeric: tabular-nums; color: var(--wp--preset--color--ink); white-space: nowrap; }
.bs-yes { color: var(--wp--preset--color--positive); font-weight: 600; }
.bs-no  { color: var(--wp--preset--color--warning); font-weight: 600; }
.bs-cmp a { font-weight: 600; white-space: nowrap; }
.bs-peildatum { font-size: 0.8rem; color: var(--wp--preset--color--muted); }

/* ---- Badges ---- */
.bs-badge { display: inline-flex; align-items: center; gap: 0.25rem; font-size: 0.8rem; font-weight: 600; padding: 0.25rem 0.75rem; border-radius: var(--bs-radius-pill); }
.bs-badge svg { width: 14px; height: 14px; }
.bs-badge--best    { background: var(--wp--preset--color--positive-soft); color: var(--wp--preset--color--positive-ink); }
.bs-badge--free    { background: var(--wp--preset--color--accent-soft);   color: var(--wp--preset--color--accent-strong); }
.bs-badge--small   { background: var(--wp--preset--color--paper-3);       color: var(--wp--preset--color--ink-2); border: 1px solid var(--wp--preset--color--rule-2); }
.bs-badge--warning { background: var(--wp--preset--color--warning-soft);  color: var(--wp--preset--color--warning-ink); }

/* ---- Trust band ---- */
.bs-trust { background: var(--wp--preset--color--ink); color: var(--wp--preset--color--accent-ink); }
.bs-trust h2, .bs-trust h3 { color: var(--wp--preset--color--accent-ink); }
.bs-trust p { color: oklch(82% 0.01 255); }
.bs-trust .bs-num { font-family: var(--wp--preset--font-family--mono); color: oklch(72% 0.1 258); font-size: 0.9rem; }
.bs-trust a { color: oklch(80% 0.1 258); }

/* ---- Tool cards ---- */
.bs-tool-card { padding: 2.5rem; border: 1px solid var(--wp--preset--color--rule-2); border-radius: var(--bs-radius-lg); background: var(--wp--preset--color--paper); height: 100%; }
.bs-tool-card h3 { color: var(--wp--preset--color--ink); }
.bs-tool-card p { color: var(--wp--preset--color--ink-2); font-size: 0.9rem; }

/* ---- Disclosure ---- */
.bs-disclosure { background: var(--wp--preset--color--paper-2); border-top: 1px solid var(--wp--preset--color--rule); }
.bs-disclosure p { font-size: 0.9rem; color: var(--wp--preset--color--muted); max-width: 68ch; margin-inline: auto; text-align: center; }

/* ---- Eyebrow / kicker ---- */
.bs-eyebrow { font-family: var(--wp--preset--font-family--mono); font-size: 0.8rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--wp--preset--color--muted); }
.bs-trust .bs-eyebrow { color: oklch(72% 0.04 255); }

/* ---- Footer ---- */
.bs-footer { background: var(--wp--preset--color--paper-3); border-top: 1px solid var(--wp--preset--color--rule-2); }
.bs-footer h4 { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--wp--preset--color--muted); font-family: var(--wp--preset--font-family--display); font-weight: 600; margin: 0 0 0.5rem; }
.bs-footer a { display: block; font-size: 0.9rem; color: var(--wp--preset--color--ink-2); padding: 3px 0; text-decoration: none; }
.bs-footer a:hover { color: var(--wp--preset--color--ink); }
.bs-footer__legal { font-size: 0.8rem; color: var(--wp--preset--color--muted); border-top: 1px solid var(--wp--preset--color--rule); }
.bs-footer__about p { font-size: 0.9rem; color: var(--wp--preset--color--ink-2); max-width: 34ch; }

/* ---- Page content rhythm ---- */
.bs-section-alt { background: var(--wp--preset--color--paper-2); }
.entry-content > * { margin-block: 1rem; }
.bs-prose { max-width: 68ch; margin-inline: 0; }
.has-text-align-center.bs-prose { margin-inline: auto; }

/* ---- WhatsApp bubble ---- */
.bs-wa { position: fixed; right: 20px; bottom: 20px; z-index: 200; width: 56px; height: 56px; border-radius: 999px; background: #25d366; display: flex; align-items: center; justify-content: center; box-shadow: 0 6px 18px rgba(37,211,102,0.45), 0 2px 6px rgba(0,0,0,0.15); transition: transform var(--bs-dur) var(--bs-ease-out); }
.bs-wa:hover { transform: scale(1.06); }
.bs-wa svg { width: 30px; height: 30px; fill: #fff; }
.bs-wa__label { position: absolute; right: 68px; background: var(--wp--preset--color--ink); color: #fff; font-size: 0.8rem; font-weight: 600; padding: 0.4rem 0.7rem; border-radius: 8px; white-space: nowrap; opacity: 0; pointer-events: none; transition: opacity var(--bs-dur) var(--bs-ease-out); }
.bs-wa:hover .bs-wa__label { opacity: 1; }
@media (max-width: 600px) { .bs-wa { right: 16px; bottom: 16px; } .bs-wa__label { display: none; } }
@media (prefers-reduced-motion: reduce) { .bs-wa { transition: none; } }

/* ---- Mobile ---- */
@media (max-width: 860px) {
  .bs-header__nav { display: none; }
}
@media (max-width: 600px) {
  .bs-header__inner { gap: 0.75rem; }
}
