/* main.css — MKTmedianet Starter

   CSS-only tokens live here. Colors, font-sizes, spacing, shadows and radius
   are defined in theme.json and available as --wp--preset--* or --wp--custom--.

   Table of contents:
   1. CSS-only tokens (:root)
   2. WordPress core utilities
   3. Global styles & typography
   4. Links
   5. Buttons (.btn, .btn--)
   6. Images & media
   7. Header & navbar
   8. Footer
   9. Header section component
   10. Accessibility
   11. Media queries
*/

/* 1. CSS-only tokens
   Tokens that cannot be defined in theme.json.
   Use --wp--preset--* or --wp--custom--* for colors, sizes, spacing, shadows and radius. */

:root {
	/* font aliases */
	--font-body: var(--wp--preset--font-family--primary);
	--font-heading: var(--wp--preset--font-family--primary);
	--font-display: var(--wp--preset--font-family--secondary);
	--font-mono: var(--wp--preset--font-family--monospace);

	/* layout — fluid values via clamp() */
	--flow-space: 1.5625rem;
	--column-gap: clamp(2.5rem, 2.5vw + 1.75rem, 3.75rem);
	--box-spacing: clamp(1rem, 2.5vw + 0.25rem, 2.25rem);
	--container-spacing: clamp(1rem, 2.5vw + 0.25rem, 2.25rem);
	--component-spacing: clamp(3rem, 6.5vw + 1.05rem, 6.25rem);

	/* font weights */
	--fw-regular: 400;
	--fw-medium: 500;
	--fw-semibold: 600;
	--fw-bold: 700;

	/* line heights */
	--lh-tight: 1.2;
	--lh-base: 1.6;
	--lh-relaxed: 1.8;

	/* letter spacing */
	--ls-base: 0;
	--ls-wide: 0.02em;
	--ls-wider: 0.03em;
	--ls-btn: 0.0225rem;

	/* status / feedback colors — not in theme.json palette */
	--color-success-50: #f0fdf4;
	--color-success-100: #dcfce7;
	--color-success-200: #bbf7d0;
	--color-success-300: #86efac;
	--color-success-400: #4ade80;
	--color-success-500: #22c55e;
	--color-success-600: #16a34a;
	--color-success-700: #15803d;
	--color-success-800: #166534;
	--color-success-900: #14532d;
	--color-success-950: #052e16;
	--color-success: var(--color-success-500);
	--color-success-light: var(--color-success-100);
	--color-success-dark: var(--color-success-700);

	--color-warning-50: #fffbeb;
	--color-warning-100: #fef3c7;
	--color-warning-200: #fde68a;
	--color-warning-300: #fcd34d;
	--color-warning-400: #fbbf24;
	--color-warning-500: #f59e0b;
	--color-warning-600: #d97706;
	--color-warning-700: #b45309;
	--color-warning-800: #92400e;
	--color-warning-900: #78350f;
	--color-warning-950: #451a03;
	--color-warning: var(--color-warning-500);
	--color-warning-light: var(--color-warning-100);
	--color-warning-dark: var(--color-warning-700);

	--color-error-50: #fef2f2;
	--color-error-100: #fee2e2;
	--color-error-200: #fecaca;
	--color-error-300: #fca5a5;
	--color-error-400: #f87171;
	--color-error-500: #ef4444;
	--color-error-600: #dc2626;
	--color-error-700: #b91c1c;
	--color-error-800: #991b1b;
	--color-error-900: #7f1d1d;
	--color-error-950: #450a0a;
	--color-error: var(--color-error-500);
	--color-error-light: var(--color-error-100);
	--color-error-dark: var(--color-error-700);

	--color-info-50: #f0f9ff;
	--color-info-100: #e0f2fe;
	--color-info-200: #bae6fd;
	--color-info-300: #7dd3fc;
	--color-info-400: #38bdf8;
	--color-info-500: #0ea5e9;
	--color-info-600: #0284c7;
	--color-info-700: #0369a1;
	--color-info-800: #075985;
	--color-info-900: #0c4a6e;
	--color-info-950: #082f49;
	--color-info: var(--color-info-500);
	--color-info-light: var(--color-info-100);
	--color-info-dark: var(--color-info-700);

	/* transitions */
	--transition-btn:
		background-color var(--wp--custom--motion--duration--base)
			var(--wp--custom--motion--easing--standard),
		color var(--wp--custom--motion--duration--base)
			var(--wp--custom--motion--easing--standard),
		border-color var(--wp--custom--motion--duration--base)
			var(--wp--custom--motion--easing--standard),
		transform var(--wp--custom--motion--duration--fast)
			var(--wp--custom--motion--easing--standard);

	/* component radius aliases */
	--border-radius-input-form: var(--wp--custom--radius--4);
	--border-radius-button-sm: var(--wp--custom--radius--4);
	--border-radius-button-md: var(--wp--custom--radius--4);
	--border-radius-button-lg: var(--wp--custom--radius--4);

	/* z-index scale */
	--z-below: -1;
	--z-base: 0;
	--z-dropdown: 1000;
	--z-sticky: 1100;
	--z-overlay: 1200;
	--z-modal: 1300;
	--z-popover: 1400;
	--z-tooltip: 1500;
}

/* 2. WordPress core utilities */

.alignnone {
	margin: 5px 20px 20px 0;
}

.aligncenter,
div.aligncenter {
	display: block;
	margin: 5px auto 5px auto;
}

.alignright {
	float: right;
	margin: 5px 0 20px 20px;
}

.alignleft {
	float: left;
	margin: 5px 20px 20px 0;
}

a img.alignright {
	float: right;
	margin: 5px 0 20px 20px;
}

a img.alignnone {
	margin: 5px 20px 20px 0;
}

a img.alignleft {
	float: left;
	margin: 5px 20px 20px 0;
}

a img.aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.wp-caption {
	background: var(--wp--preset--color--white);
	border: 1px solid var(--wp--preset--color--border);
	max-width: 96%;
	padding: 5px 3px 10px;
	text-align: center;
}

.wp-caption.alignnone {
	margin: 5px 20px 20px 0;
}

.wp-caption.alignleft {
	margin: 5px 20px 20px 0;
}

.wp-caption.alignright {
	margin: 5px 0 20px 20px;
}

.wp-caption img {
	border: 0 none;
	height: auto;
	margin: 0;
	max-width: 98.5%;
	padding: 0;
	width: auto;
}

.wp-caption p.wp-caption-text {
	font-size: var(--wp--preset--font-size--12);
	line-height: 17px;
	margin: 0;
	padding: 0 4px 5px;
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: var(--wp--preset--color--bg-secondary);
	clip: auto !important;
	clip-path: none;
	color: var(--wp--preset--color--text);
	display: block;
	font-size: 1em;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* 3. Global styles & typography */

body {
	font-family: var(--font-body);
	font-size: var(--wp--preset--font-size--16);
	line-height: var(--lh-relaxed);
	color: var(--wp--preset--color--text);
	background-color: var(--wp--preset--color--bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.wp-site-blocks {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

.wp-site-blocks > main,
.wp-site-blocks > .wp-block-post-content {
	flex: 1 0 auto;
}

main {
	margin-block-start: 0;
}

.home-main,
.legal-main,
.cpt-archive-main,
.archive-main,
.blog-main,
.search-main,
.single-main {
	margin-top: var(--wp--preset--spacing--64);
	margin-bottom: var(--wp--preset--spacing--80);
}

footer.wp-block-template-part {
	margin-block-start: 0;
}

.container {
	margin-inline: auto;
	padding-left: var(--wp--preset--spacing--16);
	padding-right: var(--wp--preset--spacing--16);
	width: 100%;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: var(--font-heading);
	color: var(--wp--preset--color--text-heading);
	line-height: var(--lh-tight);
	margin-top: 0;
	margin-bottom: var(--wp--preset--spacing--24);
}

p {
	margin-top: 0;
	margin-bottom: 1em;
}

ul,
ol {
	margin-top: 0;
	margin-bottom: var(--wp--preset--spacing--8);
	padding-left: var(--wp--preset--spacing--12);
}

li {
	margin-bottom: var(--wp--preset--spacing--4);
}

li:last-child {
	margin-bottom: 0;
}

strong {
	font-weight: var(--fw-semibold);
}

.wp-block-list {
	padding-left: var(--wp--preset--spacing--24) !important;
}

.wp-block-list li::marker {
	color: var(--wp--preset--color--primary);
}

/* 4. Links */

a {
	color: var(--wp--preset--color--accent);
	text-decoration: none;
	transition: color var(--wp--custom--motion--duration--base)
		var(--wp--custom--motion--easing--standard);
}

a:hover {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
}

a:focus {
	outline: none;
	outline-offset: 0;
}

a:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary);
	outline-offset: 2px;
}

/* 5. Buttons (.btn, .btn--*) */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 1.5rem;
	font-weight: var(--fw-medium);
	font-size: var(--wp--preset--font-size--16);
	line-height: 1.5;
	text-decoration: none;
	border: 2px solid transparent;
	border-radius: var(--wp--custom--radius--4);
	cursor: pointer;
	transition: var(--transition-btn);
	white-space: nowrap;
	user-select: none;

	&:disabled {
		opacity: 0.6;
		cursor: not-allowed;
		pointer-events: none;
	}
	&:hover {
		text-decoration: none;
	}
	&:active {
		transform: translateY(1px);
		pointer-events: none;
	}
	&:focus {
		outline: 2px solid transparent;
	}
	&:focus-visible {
		outline: 2px solid var(--wp--preset--color--primary);
		outline-offset: 2px;
	}
}

.btn--sm {
	padding: 0.5rem 1rem;
	font-size: var(--wp--preset--font-size--14);
}

.btn--md {
	padding: 0.75rem 1.5rem;
	font-size: var(--wp--preset--font-size--16);
}

.btn--lg {
	padding: 1rem 2rem;
	font-size: var(--wp--preset--font-size--18);
}

/* Default: dark */
.btn--default {
	background-color: var(--wp--preset--color--text);
	color: var(--wp--preset--color--white);
	border-color: var(--wp--preset--color--text);
}

.btn--default:hover {
	background-color: var(--wp--preset--color--text-body);
	border-color: var(--wp--preset--color--text-body);
	color: var(--wp--preset--color--white);
	transform: translateY(-1px);
}

.btn--default:focus {
	background-color: var(--wp--preset--color--text);
	border-color: var(--wp--preset--color--text);
	color: var(--wp--preset--color--white);
}

.btn--default:disabled {
	background-color: var(--wp--preset--color--text-muted);
	border-color: var(--wp--preset--color--text-muted);
	color: var(--wp--preset--color--border);
	cursor: not-allowed;
}

/* Primary: brand color */
.btn--primary {
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
	border-color: var(--wp--preset--color--primary);
}

.btn--primary:hover,
.btn--primary:focus {
	background-color: var(--wp--preset--color--primary-dark);
	border-color: var(--wp--preset--color--primary-dark);
	color: var(--wp--preset--color--white);
	transform: translateY(-1px);
}

/* Secondary: accent color */
.btn--secondary {
	background-color: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--white);
	border-color: var(--wp--preset--color--accent);
}

.btn--secondary:hover,
.btn--secondary:focus {
	background-color: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
	transform: translateY(-1px);
}

/* Outline: bordered, transparent background */
.btn--outline {
	background-color: transparent;
	color: var(--wp--preset--color--text);
	border-color: var(--wp--preset--color--text);
}

.btn--outline:hover,
.btn--outline:focus {
	background-color: var(--wp--preset--color--bg-secondary);
	border-color: var(--wp--preset--color--text-body);
	color: var(--wp--preset--color--text-body);
	transform: translateY(-1px);
	outline: none;
}

/* Outline primary */
.btn--outline-primary {
	background-color: transparent;
	color: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
}

.btn--outline-primary:hover,
.btn--outline-primary:focus {
	background-color: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
	transform: translateY(-1px);
	outline: none;
}

/* Outline secondary */
.btn--outline-secondary {
	background-color: transparent;
	color: var(--wp--preset--color--accent);
	border-color: var(--wp--preset--color--accent);
}

.btn--outline-secondary:hover,
.btn--outline-secondary:focus {
	background-color: var(--wp--preset--color--accent);
	border-color: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--white);
	transform: translateY(-1px);
}

.btn--outline:disabled,
.btn--outline-primary:disabled,
.btn--outline-secondary:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	background-color: transparent;
	color: var(--wp--preset--color--text-muted);
	border-color: var(--wp--preset--color--text-muted);
}

/* Light: white background for use over dark/image backgrounds */
.btn--light {
	background-color: var(--wp--preset--color--white);
	color: var(--wp--preset--color--text-heading);
	border-color: var(--wp--preset--color--white);
}

.btn--light:hover,
.btn--light:focus-visible {
	background-color: var(--wp--preset--color--bg-secondary);
	color: var(--wp--preset--color--text-heading);
	border-color: var(--wp--preset--color--text-heading);
}

/* Transparent: for dark backgrounds */
.btn--transparent {
	background-color: transparent;
	color: var(--wp--preset--color--white);
	border: 2px solid var(--wp--preset--color--white);
}

.btn--transparent:hover,
.btn--transparent:focus {
	background-color: rgba(255, 255, 255, 0.1);
	color: var(--wp--preset--color--white);
	border-color: var(--wp--preset--color--white);
	backdrop-filter: blur(0.25rem);
	transform: translateY(-1px);
	outline: none;
}

/* Ghost: minimal, no border */
.btn--ghost {
	background-color: transparent;
	color: var(--wp--preset--color--text);
	border-color: transparent;
	padding: 0;
}

.btn--ghost:hover,
.btn--ghost:focus {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
	outline: none;
}

.btn--ghost:has(svg):hover,
.btn--ghost:has(svg):focus {
	color: var(--wp--preset--color--primary);
	text-decoration: none;
	outline: none;
}

/* 6. Images & media */

img {
	max-width: 100%;
	height: auto;
}

figure {
	margin: 0;
}

figcaption {
	font-size: var(--wp--preset--font-size--14);
	color: var(--wp--preset--color--text-muted);
	margin-top: var(--wp--preset--spacing--4);
	text-align: center;
}

video,
iframe,
embed,
object {
	max-width: 100%;
	height: auto;
}

/* 7. Header & navbar */

.site-header {
	background-color: var(--wp--preset--color--bg);
	position: relative;
	z-index: var(--z-sticky);
	box-shadow: rgba(17, 17, 26, 0.1) 0px 0px 16px;
}

/* Sticky wrapper — scroll behavior via JS-applied modifier classes */
.wp-block-template-part:has(.site-header) {
	position: sticky;
	top: 0;
	z-index: var(--z-sticky);
	transition:
		transform var(--wp--custom--motion--duration--slow) ease,
		box-shadow var(--wp--custom--motion--duration--slow) ease;
}

.wp-block-template-part:has(.site-header--hidden) {
	transform: translateY(-100%);
}

.wp-block-template-part:has(.site-header--scrolled) {
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

/* Transparent header: must be fixed so the JS hide/reveal mechanism works */
.wp-block-template-part:has(.site-header--color-transparent) {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: var(--z-sticky);
}

.site-header__bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-block: var(--wp--preset--spacing--16);
	gap: var(--wp--preset--spacing--24);
}

.site-header__brand {
	flex-shrink: 0;
}

.site-header .wp-block-site-logo a,
.site-header .wp-block-site-logo img {
	max-height: 40px;
	height: auto;
	width: auto;
	display: block;
}

.site-header__nav .wp-block-navigation__container {
	gap: var(--wp--preset--spacing--24);
}

.site-header__nav .wp-block-navigation-item {
	margin-bottom: 0;
}

.site-header__nav .wp-block-navigation-item__content {
	font-size: var(--wp--preset--font-size--16);
	font-weight: var(--fw-medium);
	line-height: 1.5;
	color: var(--wp--preset--color--text-body);
	text-decoration: none;
	transition: color var(--wp--custom--motion--duration--base)
		var(--wp--custom--motion--easing--standard);
}

.site-header__nav .wp-block-navigation-item__content:hover,
.site-header__nav .wp-block-navigation-item__content:focus {
	color: var(--wp--preset--color--primary);
	text-decoration: none;
}

.site-header__nav
	.wp-block-navigation-item.current-menu-item
	> .wp-block-navigation-item__content {
	color: var(--wp--preset--color--primary);
	font-weight: var(--fw-semibold);
	position: relative;
}

.site-header__nav
	.wp-block-navigation-item.current-menu-item
	> .wp-block-navigation-item__content::before {
	content: "";
	position: absolute;
	inset: -3px -8px;
	background-color: var(--wp--preset--color--primary);
	opacity: 0.07;
	border-radius: var(--wp--custom--radius--4);
	pointer-events: none;
}

.site-header__nav .wp-block-navigation__responsive-container-open {
	color: var(--wp--preset--color--text);
}

.site-header__nav .wp-block-navigation__responsive-container.is-menu-open {
	background-color: var(--wp--preset--color--bg);
	padding: var(--wp--preset--spacing--24);
}

.site-header__nav
	.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation-item__content {
	font-size: var(--wp--preset--font-size--18);
	padding-block: var(--wp--preset--spacing--8);
}

/* Color: dark */
.site-header--color-dark {
	background-color: var(--wp--preset--color--bg-dark);
}

.site-header--color-dark
	.wp-block-navigation__container
	> .wp-block-navigation-item
	> .wp-block-navigation-item__content,
.site-header--color-dark
	.wp-block-navigation__container
	> .wp-block-navigation-item
	> .wp-block-navigation__submenu-icon {
	color: rgba(255, 255, 255, 0.85);
}

.site-header--color-dark
	.wp-block-navigation__container
	> .wp-block-navigation-item
	> .wp-block-navigation-item__content:hover,
.site-header--color-dark
	.wp-block-navigation__container
	> .wp-block-navigation-item
	> .wp-block-navigation-item__content:focus {
	color: var(--wp--preset--color--white);
}

.site-header--color-dark .wp-block-navigation__responsive-container-open {
	color: var(--wp--preset--color--white);
}

/* Color: transparent */
.site-header--color-transparent {
	background-color: transparent;
}

.site-header--color-transparent
	.wp-block-navigation__container
	> .wp-block-navigation-item
	> .wp-block-navigation-item__content,
.site-header--color-transparent
	.wp-block-navigation__container
	> .wp-block-navigation-item
	> .wp-block-navigation__submenu-icon {
	color: rgba(255, 255, 255, 0.85);
}

.site-header--color-transparent
	.wp-block-navigation__container
	> .wp-block-navigation-item
	> .wp-block-navigation-item__content:hover,
.site-header--color-transparent
	.wp-block-navigation__container
	> .wp-block-navigation-item
	> .wp-block-navigation-item__content:focus {
	color: var(--wp--preset--color--white);
}

.site-header--color-transparent
	.wp-block-navigation__responsive-container-open {
	color: var(--wp--preset--color--white);
}

/* Mobile overlay reverts to light background and text */
.site-header--color-transparent
	.wp-block-navigation__responsive-container.is-menu-open {
	background-color: var(--wp--preset--color--bg);
}

.site-header--color-transparent
	.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation-item__content {
	color: var(--wp--preset--color--text-body);
}

/* When scrolled past threshold, restore solid background */
.site-header--color-transparent.site-header--scrolled {
	background-color: var(--wp--preset--color--bg) !important;
	transition: background-color var(--wp--custom--motion--duration--slow) ease;
}

/* Hero / pageheader offset so content isn't hidden behind the fixed header */
.wp-block-template-part:has(.site-header--color-transparent) + * .hero,
.wp-block-template-part:has(.site-header--color-transparent) + * .pageheader {
	padding-top: 5rem;
}

/* Layout: centered — logo | nav | actions in a 3-column grid */
.site-header--layout-centered .site-header__bar {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
}

.site-header--layout-centered .site-header__brand {
	justify-self: start;
}

.site-header--layout-centered .site-header__nav {
	justify-self: center;
}

.site-header--layout-centered .header-cta {
	display: flex;
	justify-self: end;
}

/* Layout: stacked — logo on top row, nav on second row, both centered */
.site-header--layout-stacked .site-header__bar {
	flex-direction: column;
	align-items: center;
	gap: var(--wp--preset--spacing--12);
}

/* 7a. Desktop dropdown — visual only
   WP handles positioning and show/hide; we style appearance only.
   Scoped to desktop to avoid affecting the mobile overlay. */

@media (min-width: 48rem) {
	.site-header__nav .wp-block-navigation__submenu-container {
		border: 1px solid var(--wp--preset--color--border);
		box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
		min-width: 220px;
		background: var(--wp--preset--color--white);
	}

	.site-header__nav
		.wp-block-navigation__submenu-container
		.wp-block-navigation-item__content {
		font-size: var(--wp--preset--font-size--14);
		text-transform: none;
		letter-spacing: normal;
		padding: 0.5rem 1.25rem;
	}

	.site-header__nav
		.wp-block-navigation-submenu
		li.wp-block-navigation-item:hover {
		background: var(--wp--preset--color--bg-secondary);
		color: var(--wp--preset--color--primary);
	}
}

/* 7b. Mega-menu
   Add class "mega-menu" to a top-level nav item via:
   Editor del sitio > Navigation > item > Avanzado > Clases CSS adicionales */

.site-header__nav .wp-block-navigation-item.mega-menu {
	position: static;
}

.site-header__nav .mega-menu > .wp-block-navigation__submenu-container {
	left: 0;
	right: 0;
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	border-radius: var(--wp--custom--radius--8);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
	padding: 2rem;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 2rem;
}

.site-header__nav
	.mega-menu
	> .wp-block-navigation__submenu-container
	> .wp-block-navigation-item {
	display: block;
}

.site-header__nav
	.mega-menu
	> .wp-block-navigation__submenu-container
	> .wp-block-navigation-item
	> .wp-block-navigation-item__content {
	display: block;
	font-size: var(--wp--preset--font-size--14);
	font-weight: var(--fw-semibold);
	color: var(--wp--preset--color--text-heading);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 0 0 0.625rem;
	margin-bottom: 0.625rem;
	border-bottom: 1px solid var(--wp--preset--color--border);
}

.site-header__nav
	.mega-menu
	.wp-block-navigation__submenu-container
	.wp-block-navigation__submenu-container {
	position: static !important;
	display: flex !important;
	flex-direction: column;
	height: auto !important;
	width: 100% !important;
	min-width: 0 !important;
	opacity: 1 !important;
	visibility: visible !important;
	overflow: visible !important;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	padding: 0;
	background: transparent;
}

.site-header__nav
	.mega-menu
	.wp-block-navigation__submenu-container
	.wp-block-navigation-item__content {
	padding: 0.25rem 0;
	font-size: var(--wp--preset--font-size--14);
}

.site-header__nav
	.mega-menu
	.wp-block-navigation__submenu-container
	.wp-block-navigation-item__content:hover {
	background: transparent;
	color: var(--wp--preset--color--primary);
}

.site-header__nav
	.mega-menu
	.wp-block-navigation__submenu-container
	.has-child
	> .wp-block-navigation-item__content {
	font-weight: var(--fw-semibold);
	color: var(--wp--preset--color--text-heading);
	margin-top: 0.75rem;
	padding-bottom: 0.125rem;
}

.site-header__nav .mega-menu .wp-block-navigation__submenu-icon {
	display: none;
}

/* 7c. Mobile overlay — accordion behavior
   WP core forces submenus visible and hides toggle icons in the mobile overlay.
   We override both to create accordion UX. */

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content {
	gap: 0;
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	> .wp-block-navigation__container {
	width: 100%;
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	.has-child {
	flex-direction: row !important;
	flex-wrap: wrap !important;
	align-items: stretch !important;
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	.has-child
	> .wp-block-navigation-item__content {
	flex: 1;
	min-width: 0;
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	.has-child
	> .wp-block-navigation__submenu-container {
	flex-basis: 100% !important;
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	.wp-block-navigation__submenu-icon {
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: auto;
	padding: 0;
	cursor: pointer;
	flex-shrink: 0;
	color: var(--wp--preset--color--text-muted);
	transition: color var(--wp--custom--motion--duration--base) ease;
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	.wp-block-navigation__submenu-icon
	svg {
	width: 0.75rem;
	height: 0.75rem;
	stroke: currentColor;
	transition: transform 0.25s ease;
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation-submenu__toggle[aria-expanded="true"]
	.wp-block-navigation__submenu-icon
	svg {
	transform: rotate(180deg);
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	.has-child
	.wp-block-navigation__submenu-container {
	height: 0 !important;
	overflow: hidden !important;
	opacity: 0 !important;
	visibility: hidden !important;
	padding: 0 !important;
	border: 0 !important;
	box-shadow: none !important;
	transition: opacity var(--wp--custom--motion--duration--base) ease;
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	.wp-block-navigation-submenu__toggle[aria-expanded="true"]
	~ .wp-block-navigation__submenu-container {
	height: auto !important;
	overflow: visible !important;
	opacity: 1 !important;
	visibility: visible !important;
	padding: 0.25rem 0 0.5rem 0 !important;
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	> .wp-block-navigation__container
	> .wp-block-navigation-item {
	border-bottom: 1px solid var(--wp--preset--color--border);
	width: 100%;
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	> .wp-block-navigation__container
	> .wp-block-navigation-item
	> .wp-block-navigation-item__content {
	font-size: var(--wp--preset--font-size--16);
	padding: 1rem 0;
	color: var(--wp--preset--color--text-heading);
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	.wp-block-navigation__submenu-container
	> .wp-block-navigation-item
	> .wp-block-navigation-item__content {
	font-size: var(--wp--preset--font-size--16);
	font-weight: var(--fw-medium);
	padding: 0.625rem 0 0.625rem 1rem;
	color: var(--wp--preset--color--text-heading);
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	.wp-block-navigation__submenu-container
	.wp-block-navigation__submenu-container
	.wp-block-navigation-item__content {
	font-size: var(--wp--preset--font-size--14);
	font-weight: var(--fw-medium);
	padding: 0.5rem 0 0.5rem 1rem;
	color: var(--wp--preset--color--text-body);
}

.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__responsive-container-content
	.wp-block-navigation__submenu-container
	.wp-block-navigation-submenu__toggle[aria-expanded="true"]
	~ .wp-block-navigation__submenu-container {
	max-height: 40vh !important;
	overflow-y: auto !important;
	overscroll-behavior: contain;
	-webkit-overflow-scrolling: touch;
	background-color: var(--wp--preset--color--bg-secondary) !important;
	border-radius: var(--wp--custom--radius--8) !important;
	padding: 0.5rem 0 !important;
	margin-inline: 0.5rem;
}

/* Header CTA buttons (visible in centered layout) */

.header-cta {
	display: none;
	align-items: center;
	gap: 0.5rem;
	flex-shrink: 0;
}

.header-cta__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.5rem 1.25rem;
	font-size: var(--wp--preset--font-size--14);
	font-weight: var(--fw-medium);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	border: 2px solid transparent;
	border-radius: var(--wp--custom--radius--4);
	white-space: nowrap;
	transition:
		background-color var(--wp--custom--motion--duration--base) ease,
		color var(--wp--custom--motion--duration--base) ease,
		border-color var(--wp--custom--motion--duration--base) ease;
	cursor: pointer;
}

.header-cta__btn:hover {
	text-decoration: none;
}

.header-cta__btn--primary {
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
	border-color: var(--wp--preset--color--primary);
}

.header-cta__btn--primary:hover {
	background-color: var(--wp--preset--color--primary-dark);
	border-color: var(--wp--preset--color--primary-dark);
	color: var(--wp--preset--color--white);
}

.header-cta__btn--secondary {
	background-color: transparent;
	color: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
}

.header-cta__btn--secondary:hover {
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
}

.header-cta__btn--ghost {
	background-color: transparent;
	color: var(--wp--preset--color--text-body);
	border-color: var(--wp--preset--color--border);
}

.header-cta__btn--ghost:hover {
	background-color: var(--wp--preset--color--border);
	color: var(--wp--preset--color--text-heading);
}

/* Color: dark — mobile overlay + CTA overrides */

.site-header--color-dark
	.wp-block-navigation__responsive-container.is-menu-open {
	background-color: var(--wp--preset--color--bg);
}

.site-header--color-dark .header-cta__btn--ghost {
	color: rgba(255, 255, 255, 0.85);
	border-color: rgba(255, 255, 255, 0.3);
}

.site-header--color-dark .header-cta__btn--ghost:hover {
	color: var(--wp--preset--color--white);
	background-color: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.5);
}

.site-header--color-dark .header-cta__btn--secondary {
	color: var(--wp--preset--color--white);
	border-color: var(--wp--preset--color--white);
}

.site-header--color-dark .header-cta__btn--secondary:hover {
	background-color: var(--wp--preset--color--white);
	color: var(--wp--preset--color--primary-dark);
}

/* Color: transparent — mobile overlay submenu icon + CTA overrides */

.site-header--color-transparent
	.wp-block-navigation__responsive-container.is-menu-open
	.wp-block-navigation__submenu-icon {
	color: var(--wp--preset--color--text-muted);
}

.site-header--color-transparent .header-cta__btn--ghost {
	color: rgba(255, 255, 255, 0.85);
	border-color: rgba(255, 255, 255, 0.3);
}

.site-header--color-transparent .header-cta__btn--ghost:hover {
	color: var(--wp--preset--color--white);
	background-color: rgba(255, 255, 255, 0.1);
}

.site-header--color-transparent .header-cta__btn--secondary {
	color: var(--wp--preset--color--white);
	border-color: var(--wp--preset--color--white);
}

.site-header--color-transparent .header-cta__btn--secondary:hover {
	background-color: var(--wp--preset--color--white);
	color: var(--wp--preset--color--primary-dark);
}

/* Stacked + transparent: taller offset on desktop */

@media (min-width: 48rem) {
	.wp-block-template-part:has(
			.site-header--layout-stacked.site-header--color-transparent
		)
		+ *
		.hero,
	.wp-block-template-part:has(
			.site-header--layout-stacked.site-header--color-transparent
		)
		+ *
		.pageheader {
		padding-top: 10rem;
	}

	/* Centered layout: show CTA on desktop */
	.site-header--layout-centered .header-cta {
		display: flex;
	}

	/* Stacked: larger logo on desktop */
	.site-header--layout-stacked .wp-block-site-logo a,
	.site-header--layout-stacked .wp-block-site-logo img {
		max-height: 3.5rem;
	}
}

/* Mobile: stacked + centered revert to classic flex */
@media (max-width: 47.999rem) {
	.site-header--layout-centered .site-header__bar,
	.site-header--layout-stacked .site-header__bar {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
	}

	.site-header--layout-centered .header-cta,
	.site-header--layout-stacked .header-cta {
		display: none;
	}
}

/* 8. Footer */

.site-footer {
	flex-shrink: 0;
	background-color: var(--wp--preset--color--bg-secondary);
	padding: var(--wp--preset--spacing--48) 0 var(--wp--preset--spacing--32);
}

.site-footer a {
	color: var(--wp--preset--color--text-body);
	text-decoration: none;
	transition: color var(--wp--custom--motion--duration--base)
		var(--wp--custom--motion--easing--standard);
}

.site-footer a:hover,
.site-footer a:focus {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
}

.site-footer__top {
	margin-bottom: var(--wp--preset--spacing--32);
}

.site-footer__columns {
	gap: var(--wp--preset--spacing--32);
}

.site-footer__col--brand .wp-block-site-logo img {
	max-height: 80px;
	height: auto;
	width: auto;
}

.site-footer__tagline {
	color: var(--wp--preset--color--text-muted);
	margin-top: var(--wp--preset--spacing--12);
	line-height: 1.5;
}

.site-footer__title {
	color: var(--wp--preset--color--text);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-weight: var(--fw-semibold);
	font-size: var(--wp--preset--font-size--14);
	margin-bottom: var(--wp--preset--spacing--12);
}

.site-footer__nav,
.footer-contact {
	margin-block-start: var(--wp--preset--spacing--16);
}

.site-footer__nav .wp-block-navigation-item__content {
	font-size: var(--wp--preset--font-size--14);
	font-weight: var(--fw-regular);
	color: var(--wp--preset--color--text-body);
}

.site-footer__nav .wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--primary);
}

.site-footer__bottom {
	border-top: 1px solid var(--wp--preset--color--border);
	margin-top: var(--wp--preset--spacing--32);
	padding-top: var(--wp--preset--spacing--16);
	gap: var(--wp--preset--spacing--16);
}

.site-footer__bottom .footer-credits {
	font-size: var(--wp--preset--font-size--12);
	color: var(--wp--preset--color--text-muted);
	margin: 0;
}

.site-footer__legal .wp-block-navigation-item__content {
	font-size: var(--wp--preset--font-size--12);
	color: var(--wp--preset--color--text-muted);
}

.site-footer__legal .wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--primary);
}

@media (max-width: 768px) {
	.site-footer__columns {
		flex-direction: column;
	}

	.site-footer__bottom {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--wp--preset--spacing--12);
	}
}

@media (min-width: 48rem) {
	.site-footer {
		padding: var(--wp--preset--spacing--64) 0 var(--wp--preset--spacing--32);
	}
}

/* Logo size modifiers */

.site-footer--logo-sm .wp-block-site-logo img {
	height: 2.5rem;
	width: auto;
}

.site-footer--logo-md .wp-block-site-logo img {
	height: 4rem;
	width: auto;
}

.site-footer--logo-lg .wp-block-site-logo img {
	height: 5.5rem;
	width: auto;
}

/* Footer brand component */

.footer-brand {
	margin-top: 0.75rem;
}

.footer-brand__tagline {
	margin: 0;
	font-size: var(--wp--preset--font-size--14);
	line-height: 1.6;
	color: var(--wp--preset--color--text-muted);
}

.footer-brand__cta {
	display: inline-flex;
	align-items: center;
	margin-top: 0.75rem;
	padding: 0.5rem 1.25rem;
	font-size: var(--wp--preset--font-size--14);
	font-weight: var(--fw-medium);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	border: 2px solid var(--wp--preset--color--primary);
	border-radius: var(--wp--custom--radius--4);
	color: var(--wp--preset--color--primary);
	transition:
		background-color var(--wp--custom--motion--duration--base) ease,
		color var(--wp--custom--motion--duration--base) ease;
}

.site-footer .footer-brand__cta:hover {
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
	text-decoration: none;
}

.footer-brand__social {
	display: flex;
	gap: 0.625rem;
	margin-top: 1rem;
}

.footer-brand__social-link {
	display: flex;
	color: var(--wp--preset--color--text-muted);
	transition: color var(--wp--custom--motion--duration--base) ease;
}

.footer-brand__social-link:hover {
	color: var(--wp--preset--color--primary);
	text-decoration: none;
}

.footer-brand__icon svg {
	width: 1.25rem;
	height: 1.25rem;
	display: block;
}

/* Legal nav */
.site-footer__legal li {
	margin-bottom: 0;
}

/* 8a. Layout: centered — logo, tagline, social, credits all centered */

.site-footer--layout-centered .site-footer__top {
	text-align: center;
}

.site-footer--layout-centered .site-footer__columns {
	flex-direction: column;
	align-items: center;
}

.site-footer--layout-centered .site-footer__col--nav,
.site-footer--layout-centered .site-footer__col--contact {
	display: none;
}

.site-footer--layout-centered .site-footer__col--brand {
	display: flex;
	flex-direction: column;
	align-items: center;
	max-width: 28rem;
}

.site-footer--layout-centered .footer-brand {
	text-align: center;
}

.site-footer--layout-centered .footer-brand__social {
	justify-content: center;
}

.site-footer--layout-centered .site-footer__bottom {
	justify-content: center;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
}

/* 8b. Layout: minimal — credits + legal in a single line */

.site-footer--layout-minimal .site-footer__top {
	display: none;
}

.site-footer--layout-minimal {
	padding: 1rem 0;
}

.site-footer--layout-minimal .site-footer__bottom {
	border-top: none;
	margin-top: 0;
	padding-top: 0;
}

/* 8c. Color: dark */

.site-footer--color-dark {
	background-color: var(--wp--preset--color--bg-dark);
	color: rgba(255, 255, 255, 0.75);
}

.site-footer--color-dark a {
	color: rgba(255, 255, 255, 0.75);
}

.site-footer--color-dark a:hover,
.site-footer--color-dark a:focus {
	color: var(--wp--preset--color--white);
}

.site-footer--color-dark .site-footer__title {
	color: var(--wp--preset--color--white);
}

.site-footer--color-dark .site-footer__nav .wp-block-navigation-item__content {
	color: rgba(255, 255, 255, 0.75);
}

.site-footer--color-dark
	.site-footer__nav
	.wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--white);
}

.site-footer--color-dark .footer-brand__tagline,
.site-footer--color-dark .site-footer__tagline {
	color: rgba(255, 255, 255, 0.6);
}

.site-footer--color-dark .footer-brand__social-link {
	color: rgba(255, 255, 255, 0.6);
}

.site-footer--color-dark .footer-brand__social-link:hover {
	color: var(--wp--preset--color--white);
}

.site-footer--color-dark .footer-brand__cta {
	color: var(--wp--preset--color--white);
	border-color: rgba(255, 255, 255, 0.3);
}

.site-footer--color-dark .footer-brand__cta:hover {
	background-color: var(--wp--preset--color--white);
	color: var(--wp--preset--color--primary-dark);
	border-color: var(--wp--preset--color--white);
}

.site-footer--color-dark .site-footer__bottom {
	border-color: rgba(255, 255, 255, 0.15);
}

.site-footer--color-dark .footer-credits,
.site-footer--color-dark
	.site-footer__legal
	.wp-block-navigation-item__content {
	color: rgba(255, 255, 255, 0.5);
}

.site-footer--color-dark
	.site-footer__legal
	.wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--white);
}

/* 8d. Color: primary */

.site-footer--color-primary {
	background-color: var(--wp--preset--color--primary);
	color: rgba(255, 255, 255, 0.8);
}

.site-footer--color-primary a {
	color: rgba(255, 255, 255, 0.8);
}

.site-footer--color-primary a:hover {
	color: var(--wp--preset--color--white);
}

.site-footer--color-primary .site-footer__title {
	color: var(--wp--preset--color--white);
}

.site-footer--color-primary
	.site-footer__nav
	.wp-block-navigation-item__content {
	color: rgba(255, 255, 255, 0.8);
}

.site-footer--color-primary
	.site-footer__nav
	.wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--white);
}

.site-footer--color-primary .footer-brand__tagline,
.site-footer--color-primary .site-footer__tagline {
	color: rgba(255, 255, 255, 0.7);
}

.site-footer--color-primary .footer-brand__social-link {
	color: rgba(255, 255, 255, 0.7);
}

.site-footer--color-primary .footer-brand__social-link:hover {
	color: var(--wp--preset--color--white);
}

.site-footer--color-primary .footer-brand__cta {
	color: var(--wp--preset--color--white);
	border-color: rgba(255, 255, 255, 0.4);
}

.site-footer--color-primary .footer-brand__cta:hover {
	background-color: var(--wp--preset--color--white);
	color: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--white);
}

.site-footer--color-primary .site-footer__bottom {
	border-color: rgba(255, 255, 255, 0.2);
}

.site-footer--color-primary .footer-credits,
.site-footer--color-primary
	.site-footer__legal
	.wp-block-navigation-item__content {
	color: rgba(255, 255, 255, 0.5);
}

.site-footer--color-primary
	.site-footer__legal
	.wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--white);
}

/* 9. Header section component */

.header-section {
	text-align: center;
	margin-bottom: 2rem;
}

.header-section__tagline {
	font-size: var(--wp--preset--font-size--14);
	font-weight: var(--fw-semibold);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--wp--preset--color--text-tagline);
	margin: 0 0 0.5rem 0;
}

.header-section__title {
	font-size: var(--wp--preset--font-size--40);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
	margin: 0 0 1rem 0;
	color: var(--wp--preset--color--text-heading);
	text-wrap: balance;
}

.header-section__description {
	font-size: var(--wp--preset--font-size--16);
	line-height: var(--lh-base);
	color: var(--wp--preset--color--text-body);
	margin: 0;
	max-width: 90%;
	margin-inline: auto;
}

/* Tagline below title: subtitle style */
.header-section__title + .header-section__tagline {
	font-size: var(--wp--preset--font-size--16);
	font-weight: var(--fw-medium);
	text-transform: none;
	letter-spacing: normal;
	color: var(--wp--preset--color--text-muted);
	margin: -0.5rem 0 1rem;
	text-wrap: balance;
}

/* Alignment variants */
.header-section--align-center {
	text-align: center;
}

.header-section--align-left {
	text-align: left;
}

.header-section--align-left .header-section__description {
	margin-inline: 0;
}

/* Width variants */
.header-section--width-narrow {
	max-width: 66.666%;
}

.header-section--align-center.header-section--width-narrow {
	margin-inline: auto;
}

.header-section--width-full {
	max-width: 100%;
}

/* Description centered: limit width for readability */
.header-section--align-center .header-section__description {
	text-wrap: balance;
}

@media (max-width: 48rem) {
	.header-section--width-narrow {
		max-width: 100%;
	}
}

/* 10. Accessibility */

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

/* 11. Media queries */

@media (min-width: 640px) {
	.container {
		max-width: 640px;
	}

	/* Navbar hover underline animation */
	.site-header__nav
		.wp-block-navigation-link
		.wp-block-navigation-item__content {
		position: relative;
	}

	.site-header__nav
		.wp-block-navigation-link
		.wp-block-navigation-item__content::after {
		content: "";
		display: block;
		position: absolute;
		bottom: 0;
		left: 50%;
		width: 0;
		height: 2px;
		background: var(--wp--preset--color--primary);
		transition:
			width 0.3s ease,
			left 0.3s ease;
	}

	.site-header__nav
		.wp-block-navigation-link
		.wp-block-navigation-item__content:hover::after {
		width: 100%;
		left: 0;
	}

	/* Last nav item as CTA button — active when .site-header--nav-cta is set */
	.site-header--nav-cta
		.site-header__nav
		.wp-block-navigation-link:last-child
		.wp-block-navigation-item__content::after {
		display: none;
	}

	.site-header--nav-cta
		.site-header__bar
		.wp-block-navigation
		.wp-block-navigation-link:last-child
		a {
		display: flex;
		align-items: center;
		padding: var(--wp--preset--spacing--8) var(--wp--preset--spacing--16);
		background-color: var(--wp--preset--color--primary);
		color: var(--wp--preset--color--white);
		font-weight: var(--fw-medium);
		font-size: var(--wp--preset--font-size--14);
		line-height: 1.5;
		border-radius: var(--wp--custom--radius--4);
		transition: background-color var(--wp--custom--motion--duration--base)
			var(--wp--custom--motion--easing--standard);
	}

	.site-header--nav-cta
		.site-header__bar
		.wp-block-navigation
		.wp-block-navigation-link:last-child
		a:hover,
	.site-header--nav-cta
		.site-header__bar
		.wp-block-navigation
		.wp-block-navigation-link:last-child
		a:focus {
		background-color: var(--wp--preset--color--primary-dark);
		color: var(--wp--preset--color--white);
		text-decoration: none;
	}

	.site-header--nav-cta
		.site-header__bar
		.wp-block-navigation
		.wp-block-navigation-link:last-child
		a:focus-visible {
		outline: 2px solid var(--wp--preset--color--accent);
		outline-offset: 2px;
	}
}

@media (min-width: 768px) {
	.container {
		max-width: 768px;
	}

	.btn--mobile-full {
		width: 100%;
	}

	.btn {
		padding: 0.5rem 1.5rem;
	}

	/* Hide hamburger, show full nav */
	.wp-block-navigation__responsive-container-open:not(.always-shown) {
		display: none !important;
	}
	.wp-block-navigation__responsive-container:not(.hidden-by-default):not(
			.is-menu-open
		) {
		display: block !important;
	}
}

@media (min-width: 1024px) {
	.container {
		max-width: 1024px;
	}
}

@media (min-width: 1280px) {
	.container {
		max-width: 1280px;
	}
}

@media (min-width: 1536px) {
	.container {
		max-width: 1536px;
	}
}

/* 12. Error 404 */

.error-404__main {
	padding-top: var(--wp--preset--spacing--64);
	padding-bottom: var(--wp--preset--spacing--64);
}

.error-404__title {
	margin-bottom: var(--wp--preset--spacing--16);
}

.error-404__text {
	font-size: var(--wp--preset--font-size--16);
	line-height: 1.6;
	color: var(--wp--preset--color--text-body);
	text-wrap: balance;
	margin-bottom: var(--wp--preset--spacing--16);
}

.wp-block-search__inside-wrapper {
	margin-bottom: var(--wp--preset--spacing--32);
}

.error-404__search button {
	transition: opacity var(--wp--custom--motion--duration--base) ease;
}

.error-404__search button:hover {
	opacity: 0.8;
}

.error-404__btn a {
	background-color: var(--wp--preset--color--white);
	border: 2px solid var(--wp--preset--color--primary);
	color: var(--wp--preset--color--primary);
	transition: transform var(--wp--custom--motion--duration--base) ease;
}

.error-404__btn a:hover {
	transform: scale(0.98);
	text-decoration: none;
}

/* 13. Scroll-to-top */

.scroll-top {
	position: fixed;
	bottom: 1.75rem;
	left: 1.75rem;
	z-index: var(--z-sticky);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	padding: 0;
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
	opacity: 0;
	visibility: hidden;
	transform: translateY(0.5rem);
	transition:
		opacity 0.25s ease,
		transform 0.25s ease,
		visibility 0s linear 0.25s,
		background-color var(--wp--custom--motion--duration--base) ease;
}

.scroll-top--visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	transition:
		opacity 0.25s ease,
		transform 0.25s ease,
		visibility 0s linear 0s,
		background-color var(--wp--custom--motion--duration--base) ease;
}

.scroll-top:hover {
	background-color: var(--wp--preset--color--primary-dark);
}

.scroll-top:focus-visible {
	outline: 2px solid var(--wp--preset--color--accent);
	outline-offset: 3px;
}

/* 14. Float CTA (call + WhatsApp) */

.float-cta {
	position: fixed;
	bottom: 1.75rem;
	right: 1.75rem;
	z-index: var(--z-overlay);
	display: flex;
	flex-direction: column;
	align-items: end;
	gap: 0.75rem;
}

.float-cta__btn {
	width: 3rem;
	height: 3rem;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	color: #fff;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18);
	transition:
		transform var(--wp--custom--motion--duration--base) ease,
		box-shadow var(--wp--custom--motion--duration--base) ease;
}

.float-cta__btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.24);
	color: #fff;
}

.float-cta__btn:focus-visible {
	outline: 2px solid var(--wp--preset--color--accent);
	outline-offset: 3px;
}

.float-cta__btn--call {
	background-color: var(--wp--preset--color--primary);
}

.float-cta__btn--whatsapp {
	background-color: #25d366;
}

@media (prefers-reduced-motion: reduce) {
	.float-cta__btn {
		transition: none;
	}
}

/* 15. Float booking — pill trigger + panel popup */

.float-cta__btn--booking {
	width: auto;
	height: auto;
	border-radius: var(--wp--custom--radius--pill);
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
	padding: var(--wp--preset--spacing--10) var(--wp--preset--spacing--24);
	font-family: var(--wp--preset--font-family--primary);
	font-size: var(--wp--preset--font-size--12);
	font-weight: var(--fw-semibold);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	white-space: nowrap;
	border: none;
	cursor: pointer;
	transition:
		background-color var(--wp--custom--motion--duration--base) ease,
		transform var(--wp--custom--motion--duration--base) ease,
		box-shadow var(--wp--custom--motion--duration--base) ease;
}

.float-cta__btn--booking:hover {
	background-color: var(--wp--preset--color--primary-dark);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.24);
	color: var(--wp--preset--color--white);
}

.float-cta__btn--booking:focus-visible {
	outline: 2px solid var(--wp--preset--color--accent);
	outline-offset: 3px;
}

.float-booking {
	position: absolute;
	bottom: calc(100% + var(--wp--preset--spacing--12));
	right: 0;
	width: 18rem;
	background-color: var(--wp--preset--color--bg);
	border-radius: var(--wp--custom--radius--8);
	box-shadow:
		0 4px 6px rgba(0, 0, 0, 0.06),
		0 12px 40px rgba(0, 0, 0, 0.14);
	padding: var(--wp--preset--spacing--24);
	opacity: 0;
	visibility: hidden;
	transform: translateY(var(--wp--preset--spacing--8));
	transition:
		opacity var(--wp--custom--motion--duration--slow)
			cubic-bezier(0.22, 1, 0.36, 1),
		transform var(--wp--custom--motion--duration--slow)
			cubic-bezier(0.22, 1, 0.36, 1),
		visibility var(--wp--custom--motion--duration--slow);
}

.float-booking.is-open {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.float-booking__close {
	position: absolute;
	top: var(--wp--preset--spacing--10);
	right: var(--wp--preset--spacing--10);
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: none;
	cursor: pointer;
	color: var(--wp--preset--color--text-muted);
	padding: var(--wp--preset--spacing--4);
	border-radius: var(--wp--custom--radius--4);
	line-height: 1;
	transition: color var(--wp--custom--motion--duration--fast) ease;
}

.float-booking__close:hover {
	color: var(--wp--preset--color--text);
}

.float-booking__title {
	font-family: var(--wp--preset--font-family--primary);
	font-size: var(--wp--preset--font-size--11);
	font-weight: var(--fw-semibold);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--wp--preset--color--text-muted);
	margin: 0 0 var(--wp--preset--spacing--16);
	padding-bottom: var(--wp--preset--spacing--12);
	border-bottom: 1px solid var(--wp--preset--color--border);
}

.float-booking__item {
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--12);
	padding: var(--wp--preset--spacing--10) 0;
	font-size: var(--wp--preset--font-size--14);
	color: var(--wp--preset--color--text);
	text-decoration: none;
	border-bottom: 1px solid var(--wp--preset--color--border);
	transition: color var(--wp--custom--motion--duration--fast) ease;
}

.float-booking__item:last-of-type {
	border-bottom: none;
}

.float-booking__item:hover {
	color: var(--wp--preset--color--primary);
}

.float-booking__item-icon {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--wp--preset--color--accent);
}

.float-booking__cta {
	display: block;
	text-align: center;
	margin-top: var(--wp--preset--spacing--16);
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
	padding: var(--wp--preset--spacing--12) var(--wp--preset--spacing--24);
	border-radius: var(--wp--custom--radius--pill);
	font-family: var(--wp--preset--font-family--primary);
	font-size: var(--wp--preset--font-size--12);
	font-weight: var(--fw-semibold);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-decoration: none;
	transition:
		background-color var(--wp--custom--motion--duration--base) ease,
		transform var(--wp--custom--motion--duration--base) ease;
}

.float-booking__cta:hover {
	background-color: var(--wp--preset--color--primary-dark);
	transform: translateY(-1px);
	color: var(--wp--preset--color--white);
}

@media (prefers-reduced-motion: reduce) {
	.float-cta__btn--booking,
	.float-booking,
	.float-booking__close,
	.float-booking__item,
	.float-booking__cta {
		transition: none;
	}
}

/* 16. Tables */

.wp-block-table {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.wp-block-table table,
.entry-content table {
	width: 100%;
	border-collapse: collapse;
	border: none;
	font-size: var(--wp--preset--font-size--14);
	line-height: 1.6;
}

.wp-block-table th,
.wp-block-table td,
.entry-content th,
.entry-content td {
	padding: 0.75rem 1rem;
	text-align: left;
	border: none;
	border-bottom: 1px solid rgba(0, 0, 0, 0.08);
	vertical-align: top;
}

.wp-block-table thead {
	border-color: var(--wp--preset--color--border);
}

.wp-block-table thead th,
.entry-content thead th {
	font-size: var(--wp--preset--font-size--12);
	font-weight: var(--fw-semibold);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--wp--preset--color--text-muted);
}

.wp-block-table tbody tr:last-child td,
.entry-content tbody tr:last-child td {
	border-bottom: none;
}

.wp-block-table tbody tr:hover td,
.entry-content tbody tr:hover td {
	background-color: var(--wp--preset--color--bg-secondary);
}

.wp-block-table tfoot td,
.entry-content tfoot td {
	font-size: var(--wp--preset--font-size--12);
	color: var(--wp--preset--color--text-muted);
	border: none;
	border-top: 1px solid rgba(0, 0, 0, 0.1);
}

/* 17. Gravity Forms */

.gform_wrapper {
	background-color: transparent !important;
	margin: 0 auto;
	padding-top: var(--wp--preset--spacing--8);
	padding-bottom: var(--wp--preset--spacing--32);
}

.gform_wrapper form {
	margin: 0 auto;
	text-align: left;
}

.gform_fields {
	row-gap: var(--wp--preset--spacing--10) !important;
}

.gform_button {
	background-color: var(--wp--preset--color--primary) !important;
	color: var(--wp--preset--color--white) !important;
	border: none;
	padding: 0.875rem 2rem;
	font-weight: var(--fw-semibold) !important;
	letter-spacing: 0.04em !important;
	text-transform: uppercase !important;
	border-radius: var(--wp--custom--radius--4) !important;
	cursor: pointer;
	width: 100% !important;
	transition: background-color var(--wp--custom--motion--duration--base) ease !important;
}

.gform_button:hover {
	background-color: var(--wp--preset--color--primary-dark) !important;
}

textarea,
.gfield input {
	border-radius: var(--wp--custom--radius--4) !important;
	border: 1px solid var(--wp--preset--color--border) !important;
}

textarea:focus,
.gfield input:focus-within {
	outline: 2px solid var(--wp--preset--color--accent);
	outline-offset: 2px;
}

.gform_confirmation_message {
	font-family: var(--wp--preset--font-family--primary);
	font-size: var(--wp--preset--font-size--16);
	font-weight: var(--fw-semibold);
	color: var(--wp--preset--color--accent);
	text-wrap: balance;
	line-height: 1.6;
}
