/**
 * Main Stylesheet — Tabweb Theme
 *
 * BEM methodologie met tw- prefix.
 *
 * @package Tabweb
 * @since   1.0.0
 */

/* ==========================================================================
   Custom Properties
   ========================================================================== */
:root { /* Kleuren — worden overschreven door SCF Kleuren opties */ --clr-primary: var(--wp--preset--color--primary, #dcebe1); --clr-primary-20: rgba(44, 95, 78, 0.15); --clr-secondary: var(--wp--preset--color--secondary, #2c5f4e); --clr-accent: var(--wp--preset--color--accent, #d4a74a); --clr-highlight: var(--wp--preset--color--highlight, #2c5f4e); --clr-heading: var(--wp--preset--color--secondary, #2c5f4e); --clr-text: var(--wp--preset--color--dark, #1a3a2e); --clr-dark: var(--wp--preset--color--dark, #1a3a2e); --clr-light: var(--wp--preset--color--light-gray, #f4f9f6); --clr-white: #ffffff; --clr-border: rgba(44, 95, 78, 0.15); --clr-contrast: var(--wp--preset--color--white, #ffffff); /* Transitie timings */ --ts-100: 1000ms; --ts-75: 750ms; --ts-50: 500ms; --ts-45: 450ms; --ts-40: 400ms; --ts-35: 350ms; --ts-30: 300ms; --ts-25: 250ms; --ts-20: 200ms; --ts-15: 150ms; --ts-duration: var(--ts-35); --ts-function: cubic-bezier(.58, .22, .2, .96); /* Schaduwen */ --tw-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06); --tw-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08); --tw-shadow-lg: 0 8px 30px rgba(0, 0, 0, 0.1); /* Radii */ --tw-radius: 0.5rem; --tw-radius-sm: 0.3rem; --tw-radius-lg: 1rem; --tw-radius-full: 50%; /* Navigatie */ --nav-bg-clr: var(--clr-white); --nav-width: 42rem; }

/* ==========================================================================
   Global Reset & Base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: 62.5%; }
body { font-size: 1.4rem; line-height: 1.6; color: var(--clr-text); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }
body.--no-scroll { overflow: hidden; }

@media (min-width: 768px) {
body { font-size: 1.6rem; }
}

@media (min-width: 992px) {
body { font-size: 1.8rem; }
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--clr-accent); transition: color var(--ts-25) var(--ts-function); }
a:hover { color: var(--clr-highlight); }

/* Headings */
h1, h2, h3, h4, h5, h6 { color: var(--clr-secondary); font-weight: 700; line-height: 1.2; letter-spacing: -0.02em; }
h1 { font-size: clamp(3.2rem, 4vw, 5.6rem); line-height: 1; }
h2 { font-size: clamp(2.4rem, 3.5vw, 4rem); line-height: 1.1; }
h3 { font-size: clamp(2rem, 3vw, 2.4rem); line-height: 1.2; }
h4 { font-size: 2.4rem; }
h5 { font-size: 1.6rem; }
h6 { font-size: 1.4rem; }
h1 strong, h2 strong, h3 strong { color: var(--clr-secondary); }
p { margin-top: 0; }

/* ==========================================================================
   Background Color Utilities — .tw-bg-clr--*
   ========================================================================== */
.tw-bg-clr--transparent { background-color: transparent; }
.tw-bg-clr--white { background-color: var(--clr-white); }
.tw-bg-clr--grey { background-color: var(--clr-light); }
.tw-bg-clr--primary { background-color: var(--clr-primary); color: var(--clr-dark); }
.tw-bg-clr--primary h1, .tw-bg-clr--primary h2, .tw-bg-clr--primary h3, .tw-bg-clr--primary h4, .tw-bg-clr--primary h5, .tw-bg-clr--primary h6 { color: var(--clr-secondary); }
.tw-bg-clr--primary a { color: var(--clr-accent); }
.tw-bg-clr--secondary { background-color: var(--clr-secondary); color: var(--clr-contrast); }
.tw-bg-clr--secondary h1, .tw-bg-clr--secondary h2, .tw-bg-clr--secondary h3, .tw-bg-clr--secondary h4, .tw-bg-clr--secondary h5, .tw-bg-clr--secondary h6 { color: var(--clr-contrast); }
.tw-bg-clr--dark { background-color: var(--clr-dark); color: var(--clr-contrast); }
.tw-bg-clr--dark h1, .tw-bg-clr--dark h2, .tw-bg-clr--dark h3, .tw-bg-clr--dark h4, .tw-bg-clr--dark h5, .tw-bg-clr--dark h6 { color: var(--clr-contrast); }

/* ==========================================================================
   Site Header — .tw-header (navigation bar)
   ========================================================================== */
.tw-header { position: relative; top: 0; left: 0; width: 100%; z-index: 1040; }
.tw-header__main { position: relative; z-index: 1040; }
.tw-header__inner { display: flex; align-items: center; justify-content: space-between; min-height: 8rem; padding-block: 1.6rem; }
.tw-header__brand { display: flex; align-items: center; flex-shrink: 0; position: relative; z-index: 1; }
.tw-header__brand a { color: inherit; text-decoration: none; display: flex; align-items: center; }
.tw-header__brand .tw-logo__image { display: block; width: auto; height: 4.8rem; max-width: 20rem; }
.tw-header__site-name { font-weight: 700; font-size: 2rem; color: var(--clr-dark); }
.tw-header__actions { display: flex; align-items: center; gap: 1.2rem; }

/* ==========================================================================
   Navigation — .tw-nav (off-canvas)
   ========================================================================== */

/* --- Toggle (hamburger) button --- */
.tw-nav__toggle { display: flex; align-items: center; justify-content: center; background: var(--clr-secondary); border: none; cursor: pointer; padding: 0; width: 4.8rem; height: 4.8rem; border-radius: var(--tw-radius); position: relative; z-index: 1045; color: var(--clr-contrast); transition: background var(--ts-25) var(--ts-function); }

/* Hide toggle when menu is open */
.tw-nav__toggle[aria-expanded="true"] { pointer-events: none; opacity: 0; }
.tw-nav__toggle svg { width: 2.4rem; height: 2.4rem; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; }
.tw-nav__toggle svg line { transition: transform var(--ts-35) var(--ts-function), opacity var(--ts-25) var(--ts-function); transform-origin: center; }
.tw-nav__toggle[aria-expanded="true"] svg .line-top { transform: rotate(45deg) translateY(0); }
.tw-nav__toggle[aria-expanded="true"] svg .line-middle { opacity: 0; }
.tw-nav__toggle[aria-expanded="true"] svg .line-bottom { transform: rotate(-45deg) translateY(0); }

/* --- Off-canvas collapse panel --- */
.tw-nav__collapse { position: fixed; top: 0; right: 0; width: min(var(--nav-width), 90vw); height: 100vh; height: 100dvh; background: var(--clr-white); z-index: 1050; display: none; flex-direction: column; transform: translate3d(100%, 0, 0); transition: transform var(--ts-45) var(--ts-function); overflow-y: auto; -webkit-overflow-scrolling: touch; }
.tw-nav__collapse.active { display: flex; transform: translate3d(0%, 0, 0); }

/* Collapse header */
.tw-nav__collapse-header { display: flex; align-items: center; justify-content: space-between; padding: 2rem 2.4rem; border-bottom: 1px solid var(--clr-border); flex-shrink: 0; }
.tw-nav__collapse-header img { display: block; height: 3.2rem; width: auto; max-width: 16rem; }
.tw-nav__close { display: flex; align-items: center; justify-content: center; width: 4rem; height: 4rem; border: none; border-radius: var(--tw-radius-full); background: var(--clr-light); color: var(--clr-dark); cursor: pointer; padding: 0; transition: background var(--ts-25) var(--ts-function); }
.tw-nav__close:hover { background: var(--clr-border); }
.tw-nav__close svg { width: 2rem; height: 2rem; }
.tw-nav__collapse-brand { font-size: 1.8rem; font-weight: 700; color: var(--clr-dark); text-decoration: none; }

/* Collapse body */
.tw-nav__collapse-body { flex: 1; padding: 1.6rem 2.4rem; overflow-y: auto; }

/* Collapse footer */
.tw-nav__collapse-footer { padding: 2rem 2.4rem; flex-shrink: 0; display: flex; flex-direction: column; gap: 1rem; border-top: 1px solid var(--clr-border); }
.tw-nav__collapse-footer .btn { width: 100%; justify-content: center; }
.tw-nav__contact-link { display: flex; align-items: center; gap: 0.8rem; color: var(--clr-text); text-decoration: none; font-size: 1.4rem; }
.tw-nav__contact-link svg { flex-shrink: 0; opacity: 0.5; }

/* --- Menu items within collapse --- */
.tw-nav__list { list-style: none; margin: 0; padding: 0; }
.tw-nav__item:last-child { border-bottom: none; }
.tw-nav__link { display: block; color: var(--clr-dark); text-decoration: none; padding: 1.2rem 0; font-size: 1.7rem; font-weight: 600; transition: color var(--ts-25) var(--ts-function); }
.tw-nav__link:hover, .tw-nav__link:focus-visible { color: var(--clr-secondary); }
.tw-nav__item--active > .tw-nav__link { color: var(--clr-secondary); }

/* --- Submenu toggle --- */
.tw-nav__item--has-children { position: relative; }
.tw-nav__submenu-toggle { position: absolute; right: 0; top: 0; background: none; border: none; color: var(--clr-text); cursor: pointer; width: 3.8rem; height: 4.8rem; display: flex; align-items: center; justify-content: center; transition: transform var(--ts-25) var(--ts-function); }
.tw-nav__submenu-toggle[aria-expanded="true"] { transform: rotate(180deg); }
.tw-nav__submenu-icon { font-size: 1rem; line-height: 1; }

/* --- Submenu (dropdown) --- */
.tw-nav .sub-menu { list-style: none; margin: 0; padding: 0 0 0.8rem 1.6rem; display: none; }
.tw-nav .sub-menu.is-open { display: block; }
.tw-nav__item--sub { display: block; }
.tw-nav__link--sub { display: block; color: var(--clr-text); text-decoration: none; padding: 0.8rem 0; font-size: 1.5rem; font-weight: 500; transition: color var(--ts-25) var(--ts-function); }
.tw-nav__link--sub:hover, .tw-nav__link--sub:focus-visible { color: var(--clr-secondary); }

/* --- Backdrop --- */
.tw-backdrop { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.35); z-index: 1030; opacity: 0; transition: opacity var(--ts-35) var(--ts-function); pointer-events: none; }
.tw-backdrop.active { opacity: 1; pointer-events: auto; }

/* --- Desktop nav (>= 992px) --- */

@media (min-width: 992px) {
.tw-header__brand .tw-logo__image { height: 6.4rem; }
.tw-nav__toggle { display: none; }
.tw-nav__collapse { position: static; width: auto; height: auto; background: transparent; display: flex; flex-direction: row; align-items: center; transform: none; overflow: visible; transition: none; }
.tw-nav__collapse-header, .tw-nav__collapse-footer { display: none; }
.tw-nav__close { display: none; }
.tw-nav__collapse-body { padding: 0; overflow: visible; }
.tw-nav__list { display: flex; align-items: center; gap: 0.4rem; }
.tw-nav__item { border-bottom: none; position: relative; }
.tw-nav__link { display: inline-block; padding: 0.8rem 1.2rem; font-size: 1.8rem; color: var(--clr-dark); white-space: nowrap; position: relative; }
.tw-nav__item--has-children > .tw-nav__link { padding-right: 0.4rem; }
.tw-header .tw-nav__link::after { content: none; }
.tw-header .tw-nav__link:hover, .tw-header .tw-nav__link:focus-visible, .tw-header .tw-nav__item--active > .tw-nav__link { color: var(--clr-secondary); }
.tw-nav__link:hover, .tw-nav__link:focus-visible { }
.tw-nav__item--has-children { display: flex; align-items: center; }
.tw-nav__submenu-toggle { position: static; width: auto; height: auto; padding: 0.2rem 0.2rem 0.2rem 0; color: var(--clr-secondary); transition: transform var(--ts-25) var(--ts-function); }
.tw-nav__submenu-icon { width: 1.8rem; height: 1.8rem; display: block; }
.tw-nav__item--has-children:hover > .tw-nav__submenu-toggle, .tw-nav__submenu-toggle[aria-expanded="true"] { transform: rotate(180deg); }
.tw-nav .sub-menu { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(-0.4rem); min-width: 24rem; background: var(--clr-white); border-radius: var(--tw-radius); box-shadow: 0 8px 30px rgba(26, 58, 46, 0.12); padding: 0.6rem 0; display: block; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity var(--ts-25) var(--ts-function), transform var(--ts-25) var(--ts-function), visibility 0s linear var(--ts-25); z-index: 100; }
.tw-nav__item--has-children:hover > .sub-menu, .tw-nav .sub-menu.is-open { opacity: 1; visibility: visible; pointer-events: auto; transform: translateX(-50%) translateY(0); transition: opacity var(--ts-25) var(--ts-function), transform var(--ts-25) var(--ts-function), visibility 0s linear 0s; }
.tw-nav .sub-menu .sub-menu { top: 0; left: 100%; transform: translateX(0) translateY(-0.4rem); }
.tw-nav__item--sub + .tw-nav__item--sub { border-top: 1px solid var(--clr-border); }
.tw-nav__link--sub { display: block; padding: 1rem 2rem; font-size: 1.5rem; color: var(--clr-dark); text-decoration: none; transition: color var(--ts-20) var(--ts-function); }
.tw-nav__link--sub:hover, .tw-nav__link--sub:focus-visible { color: var(--clr-secondary); }
.tw-backdrop { display: none; }
}

/* Logo wrapper: show primary (dark) by default */
.tw-logo-wrapper--primary { display: block; }
.tw-logo-wrapper--secondary { display: none; }

/* Footer nav variant */
.tw-nav--footer .tw-nav__list { flex-direction: column; align-items: flex-start; gap: 0.2rem; }
.tw-nav--footer .tw-nav__link { color: var(--clr-text); font-size: 1.5rem; padding: 0.5rem 0; &:hover { opacity: .8; } }
.tw-nav--footer .tw-nav__link:hover, .tw-nav--footer .tw-nav__link:focus-visible { color: var(--clr-secondary); }

@media (max-width: 1199.98px) {
.tw-nav--footer .tw-nav__list { position: static; width: auto; height: auto; background: transparent; box-shadow: none; padding: 0; transform: none; overflow: visible; }
}

/* ==========================================================================
   Site Footer — .tw-footer
   ========================================================================== */
.tw-footer { position: relative; margin-top: auto; background: var(--clr-light); color: var(--clr-dark); padding-top: 4.8rem; padding-bottom: 2rem; }

@media (min-width: 992px) {
.tw-footer { padding-top: 6rem; }
}

/* Footer achtergrondstijlen — overrides verwijderd, lichtgrijs is standaard */
.tw-footer__grid { display: grid; grid-template-columns: 2fr 1.5fr 1fr 1fr; gap: 4rem 3rem; }

@media (max-width: 767.98px) {
.tw-footer__grid { grid-template-columns: 1fr; gap: 3rem; }
}

/* Headings */
.tw-footer__heading { margin-top: 0; margin-bottom: .8rem; }

/* Brand / logo */
.tw-footer__brand { text-decoration: none; color: inherit; margin-bottom: 1.2rem; transition: opacity var(--ts-25) var(--ts-function); }
.tw-footer__brand:hover { opacity: 0.8; }
.tw-footer__brand--text { font-size: 2.4rem; font-weight: 800; }
.tw-footer__brand img { max-height: 90px; width: auto; }

/* Footer text */
.tw-footer__text { color: var(--clr-text); font-size: 1.5rem; line-height: 1.7; margin-bottom: 0; max-width: 32rem; }
.tw-footer__text p { margin: 0; }

/* Footer contact list */
.tw-footer__contact { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 1.2rem; }
.tw-footer__contact--horizontal { flex-direction: row; gap: 2.4rem; align-items: center; }

@media (max-width: 767.98px) {
.tw-footer__contact--horizontal { flex-direction: column; align-items: flex-start; gap: 1.2rem; }
}
.tw-footer__contact-item { display: flex; align-items: center; gap: 1.2rem; color: var(--clr-text); font-size: 1.5rem; line-height: 1.5; }
.tw-footer__contact-icon { flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: var(--clr-secondary); }
.tw-footer__contact-item a { color: var(--clr-text); text-decoration: none; transition: color var(--ts-25) var(--ts-function); }
.tw-footer__contact-item a:hover { color: var(--clr-secondary); }

/* Footer social list */
.tw-social__list--footer { list-style: none; margin: 0; padding: 0; display: flex; gap: 0.8rem; }
.tw-social__list--footer .tw-social__link { display: inline-flex; align-items: center; justify-content: center; width: 4rem; height: 4rem; border-radius: var(--tw-radius-full); background: var(--clr-white); color: var(--clr-dark); box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06); text-decoration: none; transition: background var(--ts-25) var(--ts-function), color var(--ts-25) var(--ts-function), transform var(--ts-25) var(--ts-function); }
.tw-social__list--footer .tw-social__link:hover { background: var(--clr-secondary); color: var(--clr-contrast); }
.tw-social__list--footer .tw-social__link svg { width: 1.8rem; height: 1.8rem; }

/* Bottom bar */
.tw-footer__bottom { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 1.2rem; margin-top: 4rem; padding-top: 2rem; border-top: 1px solid rgba(0, 0, 0, 0.08); }
.tw-footer__copyright { color: rgba(0, 0, 0, 0.45); font-size: 1.4rem; margin: 0; }
.tw-footer__madeby { color: rgba(0, 0, 0, 0.45); font-size: 1.4rem; a { color: inherit; text-decoration: none; } }

@media (max-width: 767.98px) {
.tw-footer__bottom { flex-direction: column; text-align: center; }
}

/* ==========================================================================
   WhatsApp Floating Button — .tw-whatsapp
   ========================================================================== */
.tw-whatsapp { position: fixed; bottom: 2.4rem; right: 2.4rem; z-index: 900; display: flex; align-items: center; justify-content: center; width: 5.6rem; height: 5.6rem; border-radius: var(--tw-radius-full); background: #25d366; color: #fff; box-shadow: 0 4px 14px rgba(37, 211, 102, 0.4); text-decoration: none; transition: transform var(--ts-25) var(--ts-function), box-shadow var(--ts-25) var(--ts-function); }
.tw-whatsapp:hover { transform: scale(1.1); box-shadow: 0 6px 20px rgba(37, 211, 102, 0.55); color: #FFF; svg { fill: #FFF !important; } }
.tw-whatsapp svg { width: 2.8rem; height: 2.8rem; }
.admin-bar .tw-whatsapp { bottom: calc(2.4rem + 32px); }

@media (max-width: 767.98px) {
.admin-bar .tw-whatsapp { bottom: calc(2.4rem + 46px); }
}
.woocommerce-checkout .tw-whatsapp { display: none !important; }

/* ==========================================================================
   Buttons — .btn (Bootstrap-inspired)
   ========================================================================== */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.8rem; min-height: 5.2rem; padding: 0 3.2rem; border-radius: var(--tw-radius-sm); font-family: inherit; font-weight: 600; font-size: 1.6rem; line-height: 1.4; letter-spacing: -0.01em; text-align: center; text-decoration: none; white-space: nowrap; vertical-align: middle; border: 2px solid transparent; cursor: pointer; user-select: none; -webkit-user-select: none; background-color: transparent; color: inherit; transition: color var(--ts-25) var(--ts-function), background-color var(--ts-25) var(--ts-function), border-color var(--ts-25) var(--ts-function), box-shadow var(--ts-25) var(--ts-function), transform var(--ts-15) ease, opacity var(--ts-25) var(--ts-function); -webkit-appearance: none; appearance: none; }
.btn:hover { text-decoration: none; }
.btn:focus-visible { outline: 0; box-shadow: 0 0 0 3px rgba(44, 95, 78, 0.25); }
.btn:active { transform: translateY(0); }
.btn:disabled, .btn.disabled { pointer-events: none; opacity: 0.55; }
.btn svg { flex-shrink: 0; width: 1em; height: 1em; }

/* Primary */
.btn--primary { background: var(--clr-secondary); color: var(--clr-contrast); border-color: var(--clr-secondary); border-radius: 10rem; box-shadow: 0 2px 8px rgba(44, 95, 78, 0.25); }
.btn--primary:hover { background: var(--clr-secondary); border-color: var(--clr-secondary); color: var(--clr-contrast); opacity: 0.85; box-shadow: 0 4px 16px rgba(44, 95, 78, 0.3); }
.btn--primary:focus-visible { box-shadow: 0 0 0 3px rgba(44, 95, 78, 0.4); }

/* Secondary / accent */
.btn--secondary { background: var(--clr-accent); color: var(--clr-dark); border-color: var(--clr-accent); border-radius: 10rem; }
.btn--secondary:hover { background: #c4952e; border-color: #c4952e; }

/* White */
.btn--white { background: var(--clr-white); color: var(--clr-secondary); border-color: var(--clr-white); }
.btn--white:hover { background: var(--clr-light); border-color: var(--clr-light); }

/* Light */
.btn--light { background: var(--clr-light); color: var(--clr-secondary); border-color: var(--clr-light); }
.btn--light:hover { background: var(--clr-white); border-color: var(--clr-white); }

/* Outline */
.btn--outline { background: transparent; color: var(--clr-secondary); border-color: var(--clr-border); border-radius: 10rem; }
.btn--outline:hover { background: var(--clr-secondary); color: var(--clr-contrast); border-color: var(--clr-secondary); }

/* Outline white (for dark backgrounds) */
.btn--outline-white { background: transparent; color: var(--clr-contrast); border-color: rgba(255, 255, 255, 0.4); }
.btn--outline-white:hover { background: var(--clr-contrast); color: var(--clr-secondary); border-color: var(--clr-contrast); }

/* Nav CTA */
.btn--nav { min-height: 4.4rem; padding: 0 2.4rem; font-size: 1.5rem; }

/* Link variant */
.btn--link { background: transparent; border-color: transparent; color: var(--clr-accent); padding-inline: 0; min-height: auto; }
.btn--link:hover { color: var(--clr-highlight); transform: none; }

/* Size modifiers */
.btn--xs { min-height: 3.2rem; padding: 0 1.2rem; font-size: 1.2rem; gap: 0.4rem; }
.btn--sm { min-height: 4rem; padding: 0 2rem; font-size: 1.4rem; gap: 0.6rem; }
.btn--lg { min-height: 6rem; padding: 0 4rem; font-size: 1.8rem; gap: 1rem; }

/* Block (full width) */
.btn--block { display: flex; width: 100%; }

/* Icon-only */
.btn--icon { min-height: 4.4rem; width: 4.4rem; padding: 0; border-radius: var(--tw-radius-sm); }
.btn--icon.btn--sm { min-height: 3.6rem; width: 3.6rem; }
.btn--icon.btn--lg { min-height: 5.6rem; width: 5.6rem; }

/* Loading state */
.btn--loading { position: relative; color: transparent !important; pointer-events: none; }
.btn--loading::after { content: ''; position: absolute; width: 1.6rem; height: 1.6rem; border: 2px solid currentColor; border-right-color: transparent; border-radius: 50%; animation: btnSpin 0.6s linear infinite; }
@keyframes btnSpin { to { transform: rotate(360deg); } }

/* Button group */
.btn-group { display: inline-flex; gap: 0; }
.btn-group .btn { border-radius: 0; }
.btn-group .btn:first-child { border-radius: var(--tw-radius-sm) 0 0 var(--tw-radius-sm); }
.btn-group .btn:last-child { border-radius: 0 var(--tw-radius-sm) var(--tw-radius-sm) 0; }
.btn-group .btn + .btn { margin-left: -2px; }

/* Backward compat aliases */
.tw-btn { display: inline-flex; align-items: center; justify-content: center; min-height: 5.2rem; padding: 0 3.2rem; border-radius: var(--tw-radius-sm); font-weight: 600; font-size: 1.6rem; text-decoration: none; border: 2px solid transparent; cursor: pointer; transition: background var(--ts-25) var(--ts-function), color var(--ts-25) var(--ts-function), border-color var(--ts-25) var(--ts-function), transform var(--ts-15) ease; line-height: 1.4; }
.tw-btn--primary { background: var(--clr-secondary); color: var(--clr-contrast); border-color: var(--clr-secondary); border-radius: 10rem; box-shadow: 0 2px 8px rgba(44, 95, 78, 0.25); }
.tw-btn--secondary { background: var(--clr-accent); color: var(--clr-dark); border-color: var(--clr-accent); border-radius: 10rem; }
.tw-btn--outline { background: transparent; color: var(--clr-secondary); border-color: var(--clr-border); border-radius: 10rem; }
.tw-btn--ghost { background: transparent; border-color: transparent; color: var(--clr-accent); padding-inline: 0; min-height: auto; }

/* WP core button overrides */
.wp-element-button, .wp-block-button__link { transition: background var(--ts-25) var(--ts-function), color var(--ts-25) var(--ts-function), transform var(--ts-15) ease; }
.wp-element-button:hover, .wp-block-button__link:hover { transform: translateY(-1px); }
.wp-element-button:active, .wp-block-button__link:active { transform: translateY(0); }
.is-style-outline .wp-block-button__link { border-width: 2px; }
.is-style-outline .wp-block-button__link:hover { background: var(--clr-secondary); border-color: var(--clr-secondary); color: var(--clr-contrast); }

/* Button group */
.btn-group { display: flex; flex-wrap: wrap; gap: 1.2rem; align-items: center; }

/* ==========================================================================
   Section — .tw-section
   ========================================================================== */
.tw-section__header { margin-bottom: 3.2rem; }

@media (min-width: 1200px) {
.tw-section__header { margin-bottom: 6rem; }
}

/* ==========================================================================
   Forms
   ========================================================================== */
input[type="text"], input[type="email"], input[type="tel"], input[type="url"], input[type="search"], input[type="password"], input[type="number"], textarea, select { min-height: 4.8rem; padding: 0.8rem 1.6rem; border: 1px solid var(--clr-border); border-radius: var(--tw-radius); font-size: 1.6rem; color: var(--clr-text); background: var(--clr-white); transition: border-color var(--ts-25) var(--ts-function), box-shadow var(--ts-25) var(--ts-function); width: 100%; }
input:focus, textarea:focus, select:focus { border-color: var(--clr-secondary); box-shadow: 0 0 0 2px var(--clr-primary-20); outline: none; }
textarea { min-height: 12rem; resize: vertical; }

/* ==========================================================================
   Post Navigation — .tw-post-nav
   ========================================================================== */
.tw-post-nav { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1.6rem; }
.tw-post-nav a { color: var(--clr-accent); text-decoration: none; font-weight: 500; transition: color var(--ts-25) var(--ts-function); }
.tw-post-nav a:hover { color: var(--clr-highlight); }

/* ==========================================================================
   Search Block Override
   ========================================================================== */
.wp-block-search .wp-block-search__input { border-radius: var(--tw-radius); border: 1px solid var(--clr-border); padding: 1.2rem 1.6rem; transition: border-color var(--ts-25) var(--ts-function), box-shadow var(--ts-25) var(--ts-function); }
.wp-block-search .wp-block-search__input:focus { border-color: var(--clr-secondary); box-shadow: 0 0 0 2px var(--clr-primary-20); outline: none; }
.wp-block-search .wp-block-search__button { border-radius: var(--tw-radius); }

/* ==========================================================================
   Separator Override
   ========================================================================== */
.wp-block-separator { border: none; border-top: 1px solid var(--clr-border); opacity: 1; }

/* ==========================================================================
   Accessibility
   ========================================================================== */
.tw-sr-only { clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%); height: 1px; width: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; word-wrap: normal !important; }
.tw-sr-only:focus { clip: auto !important; clip-path: none; height: auto; width: auto; display: block; background: var(--clr-white); color: var(--clr-secondary); font-size: 1.6rem; padding: 1.6rem; z-index: 9999; top: 5px; left: 5px; box-shadow: var(--tw-shadow-lg); }
.tw-skip-link { position: absolute; top: -100%; left: 50%; transform: translateX(-50%); z-index: 9999; padding: 1.2rem 2.4rem; background: var(--clr-secondary); color: var(--clr-contrast); border-radius: var(--tw-radius); text-decoration: none; }
.tw-skip-link:focus { top: 0.8rem; }

/* ==========================================================================
   Page Template — .tw-page
   ========================================================================== */
.tw-page__header { padding-top: 8.4rem; background: var(--clr-secondary); color: var(--clr-contrast); padding-bottom: 4rem; text-align: center; }

@media (min-width: 992px) {
.tw-page__header { padding-top: 12rem; padding-bottom: 6rem; }
}
.tw-page__header-inner { max-width: var(--wp--style--global--wide-size, 1200px); margin-inline: auto; padding-inline: var(--wp--preset--spacing--20, 1rem); }
.tw-page__title { font-size: clamp(2.8rem, 4vw, 5.6rem); font-weight: 700; margin: 0; color: var(--clr-contrast); line-height: 1; }
.tw-page__content { max-width: var(--wp--style--global--wide-size, 1200px); margin-inline: auto; padding: var(--wp--preset--spacing--40, 2rem) var(--wp--preset--spacing--20, 1rem); }

/* ==========================================================================
   Animations
   ========================================================================== */

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

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
.tw-header, .tw-footer, .tw-nav, .tw-post-nav, .tw-backdrop { display: none !important; }
body { font-size: 12pt; color: #000; background: #fff; }
a { color: #000; text-decoration: underline; }
}

/* ==========================================================================
   404 Page
   ========================================================================== */
.tw-404 { display: flex; align-items: center; justify-content: center; min-height: 60vh; padding: 6rem 2rem; text-align: center; }
.tw-404__inner { max-width: 56rem; margin: 0 auto; }
.tw-404__title { font-size: clamp(8rem, 15vw, 16rem); font-weight: 800; line-height: 1; color: var(--clr-secondary); margin: 0 0 1.6rem; letter-spacing: -0.02em; opacity: 0.15; }
.tw-404__subtitle { font-size: clamp(2.4rem, 4vw, 3.6rem); font-weight: 700; color: var(--clr-heading); margin: 0 0 1.6rem; }
.tw-404__text { font-size: 1.8rem; color: var(--clr-text); margin: 0 0 3.2rem; line-height: 1.6; }
.tw-404__actions { margin-bottom: 3.2rem; }
.woocommerce .products ul::after, .woocommerce .products ul::before, .woocommerce ul.products::after, .woocommerce ul.products::before { content: unset !important; }
.woocommerce div.product form.cart::after, .woocommerce div.product form.cart::before { content: unset !important; }

/* ==========================================================================
   WooCommerce Notices — .woocommerce-notices-wrapper
   ========================================================================== */
.woocommerce-notices-wrapper { margin: 0 0 2.4rem; }

/* --- Base notice --- */
.woocommerce-notices-wrapper .woocommerce-message, .woocommerce-notices-wrapper .woocommerce-info, .woocommerce-notices-wrapper .woocommerce-error { display: flex; flex-wrap: wrap; align-items: center; gap: 1.2rem 1.6rem; padding: 1.4rem 2rem; border-radius: var(--tw-radius); font-size: 1.5rem; font-weight: 500; line-height: 1.5; margin: 0 0 1.2rem; border: 1px solid transparent; border-left-width: 4px; list-style: none; }

/* Verwijder WooCommerce standaard ::before icoon */
.woocommerce-notices-wrapper .woocommerce-message::before, .woocommerce-notices-wrapper .woocommerce-info::before { display: none; }

/* --- Succes notice --- */
.woocommerce-notices-wrapper .woocommerce-message { background: var(--clr-light); color: var(--clr-secondary); border-color: rgba(44, 95, 78, 0.2); border-left-color: var(--clr-secondary); }

/* --- Info notice --- */
.woocommerce-notices-wrapper .woocommerce-info { background: rgba(212, 167, 74, 0.08); color: var(--clr-dark); border-color: rgba(212, 167, 74, 0.25); border-left-color: var(--clr-accent); }

/* --- Fout notice (ul > li) --- */
.woocommerce-notices-wrapper .woocommerce-error { background: rgba(185, 28, 28, 0.06); color: #7a1a1a; border-color: rgba(185, 28, 28, 0.18); border-left-color: #b91c1c; flex-direction: column; align-items: flex-start; }
.woocommerce-notices-wrapper .woocommerce-error li { list-style: none; padding: 0; margin: 0; }

/* --- Knop binnen notice --- */
.woocommerce-notices-wrapper .woocommerce-message a.button, .woocommerce-notices-wrapper .woocommerce-info a.button, .woocommerce-notices-wrapper .woocommerce-error a.button { display: inline-flex; align-items: center; justify-content: center; min-height: 4rem; padding: 0 2rem; border-radius: 10rem; font-size: 1.4rem; font-weight: 600; line-height: 1.4; text-decoration: none; white-space: nowrap; cursor: pointer; transition: background var(--ts-25) var(--ts-function), box-shadow var(--ts-25) var(--ts-function), opacity var(--ts-25) var(--ts-function); }
.woocommerce-notices-wrapper .woocommerce-message a.button, .woocommerce-notices-wrapper .woocommerce-info a.button { background: var(--clr-secondary); color: var(--clr-contrast) !important; border: 2px solid var(--clr-secondary); box-shadow: 0 2px 8px rgba(44, 95, 78, 0.2); margin-left: auto; }
.woocommerce-notices-wrapper .woocommerce-message a.button:hover, .woocommerce-notices-wrapper .woocommerce-info a.button:hover { background: var(--clr-secondary) !important; color: var(--clr-contrast) !important; opacity: 0.85; box-shadow: 0 4px 16px rgba(44, 95, 78, 0.3); }
.woocommerce-notices-wrapper .woocommerce-error a.button { background: #b91c1c; color: #ffffff !important; border: 2px solid #b91c1c; }
.woocommerce-notices-wrapper .woocommerce-error a.button:hover { background: #b91c1c !important; color: #ffffff !important; opacity: 0.85; }
