/*
 * tokens-base.css
 * Paraplu-laag (InstantStack). Universele tokens die op elke pagina geladen worden.
 * Plugin-specifieke kleuren/blobs/gradients staan in tokens-{plugin}.css.
 *
 * Bron van waarheid:
 *   - bricks_global_settings.container.width = 1300
 *   - bricks_global_settings.section.padding = 30/15/30/15 (mobile_portrait 10/15/10/15)
 *   - Bricks default breakpoints (max-width): 991, 767, 478
 *   - Fonts: Space Grotesk (custom_font_23 = body/H2), Bricolage Grotesque (custom_font_15 = H1/H3)
 */

:root {
	/* Typografie */
	--font-display: "Bricolage Grotesque", system-ui, -apple-system, "Segoe UI", sans-serif;
	--font-body: "Space Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;

	--fs-h1: 36px;
	--fs-h2: 36px;
	--fs-h3: 24px;
	--fs-body: 16px;
	--fs-small: 14px;
	--fs-eyebrow: 13px;

	--lh-tight: 1.15;
	--lh-snug: 1.35;
	--lh-normal: 1.55;

	/* Spacing-scale (4px-grid) */
	--space-1: 4px;
	--space-2: 8px;
	--space-3: 12px;
	--space-4: 16px;
	--space-5: 24px;
	--space-6: 32px;
	--space-7: 48px;
	--space-8: 64px;
	--space-9: 96px;

	/* Layout */
	--container-width: 1300px;
	--container-pad-x: 15px;
	--section-pad-y: 30px;
	--section-pad-y-mobile: 10px;

	/* Vorm */
	--radius-sm: 6px;
	--radius-md: 10px;
	--radius-lg: 16px;
	--radius-pill: 999px;

	/* Borders / shadows */
	--border-width: 2px;
	--shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.18);
	--shadow-md: 0 8px 24px rgba(0, 0, 0, 0.25);
	--shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.35);

	/* Transities */
	--ease: cubic-bezier(0.4, 0, 0.2, 1);
	--dur-fast: 120ms;
	--dur-base: 200ms;
	--dur-slow: 320ms;

	/* Z-index schaal */
	--z-header: 100;
	--z-overlay: 500;
	--z-modal: 1000;

	/* Header */
	--header-height: 68px;
	--header-height-scrolled: 58px;

	/* Default brand-tokens (worden door tokens-instantfilter.css overschreven binnen plugin-context). */
	--brand-primary: #5010B8;
	--brand-secondary: #2F0A60;
	--brand-deep: #0D0128;

	/* Signature merk-gradient. Bron: Bricks page-content op /instantfilter (klassen
	 * .gradient, .btn-primary, .btn-secondary). Wordt op tekst-spans, primaire CTA's
	 * en als gradient-border van secundaire CTA's gebruikt. */
	--grad-from: #80e861;
	--grad-to: #00b2ff;
	--grad-text-fg: #180632; /* donkere voorgrondkleur voor labels op gradient bg */
	--brand-gradient: linear-gradient(90deg, var(--grad-from), var(--grad-to));
	--brand-gradient-soft: linear-gradient(135deg, rgba(122, 232, 94, 0.15), rgba(0, 178, 255, 0.15));
	--brand-gradient-border: linear-gradient(to right bottom, rgba(122, 232, 94, 0.4), rgba(0, 178, 255, 0.4));

	--text: #ffffff;
	--text-muted: rgba(255, 255, 255, 0.72);
	--text-subtle: rgba(255, 255, 255, 0.55);
	--surface: var(--brand-secondary);
	--surface-elev: rgba(255, 255, 255, 0.04);
	--surface-elev-2: rgba(255, 255, 255, 0.07);
	--border: rgba(255, 255, 255, 0.12);
	--border-strong: rgba(255, 255, 255, 0.22);

	color-scheme: dark;
}

/* ---------- Signature gradient utilities ----------
 * Hergebruik dit over alle merken/sub-merken zolang --brand-gradient gezet is.
 * Voor sub-merken kan je --grad-from/--grad-to overriden in tokens-{plugin}.css.
 */

.is-grad {
	background: var(--brand-gradient);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

.is-grad-bg {
	background: var(--brand-gradient);
}

.is-grad-bg-soft {
	background: var(--brand-gradient-soft);
}

/* Glassy element met gradient border via mask-trick. */
.is-grad-border {
	position: relative;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid transparent;
	border-radius: inherit;
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
}

.is-grad-border::before {
	content: "";
	position: absolute;
	inset: 0;
	padding: 1px;
	border-radius: inherit;
	background: var(--brand-gradient);
	-webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
}

/* Basis typografie */
html {
	scroll-behavior: smooth;
}

body.is-instant {
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: var(--lh-normal);
	color: var(--text);
	background-color: var(--brand-deep);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body.is-instant h1,
body.is-instant .is-h1 {
	font-family: var(--font-display);
	font-size: var(--fs-h1);
	font-weight: 700;
	line-height: var(--lh-tight);
	color: var(--text);
	margin: 0 0 var(--space-4);
}

body.is-instant h2,
body.is-instant .is-h2 {
	font-family: var(--font-body);
	font-size: var(--fs-h2);
	font-weight: 700;
	line-height: var(--lh-tight);
	color: var(--text);
	margin: 0 0 var(--space-4);
}

body.is-instant h3,
body.is-instant .is-h3 {
	font-family: var(--font-display);
	font-size: var(--fs-h3);
	font-weight: 600;
	line-height: var(--lh-snug);
	color: var(--text);
	margin: 0 0 var(--space-3);
}

body.is-instant h4 {
	font-family: var(--font-body);
	font-size: 18px;
	font-weight: 600;
	line-height: var(--lh-snug);
	margin: 0 0 var(--space-3);
}

body.is-instant a {
	color: inherit;
	text-decoration: none;
	transition: color var(--dur-base) var(--ease);
}

body.is-instant a:hover {
	color: var(--text);
	opacity: 0.85;
}

body.is-instant p {
	margin: 0 0 var(--space-4);
}

body.is-instant ul,
body.is-instant ol {
	margin: 0 0 var(--space-4);
	padding-left: var(--space-5);
}

body.is-instant img {
	max-width: 100%;
	height: auto;
	display: block;
}

body.is-instant ::selection {
	background: var(--brand-primary);
	color: #fff;
}

/* Bricks default breakpoints: 991 / 767 / 478 (max-width). */
@media (max-width: 991px) {
	:root {
		--fs-h1: 34px;
	}
}

@media (max-width: 767px) {
	:root {
		--fs-h1: 32px;
		--fs-h2: 32px;
	}
}

@media (max-width: 478px) {
	:root {
		--fs-h1: 30px;
		--fs-h2: 30px;
		--fs-h3: 22px;
		--section-pad-y: 10px;
	}
}

/* Reduced-motion ondersteuning */
@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}
