/*
Theme Name: Gutenberg Lab VVM
Theme URI: https://example.com
Author: Christos
Description: A Gutenberg lab theme for porting the VVM site system.
Version: 0.1.36
Requires at least: 6.6
Tested up to: 6.7
Requires PHP: 8.1
Text Domain: gutenberg-lab-vvm
*/

:root {
	--vvm-scrollbar-width: 0px;
}

html.vvm-has-scrollbar {
	/*
	 * Core Navigation locks the page by setting `html.has-modal-open` to
	 * overflow hidden. Keeping a stable gutter prevents the centered header and
	 * page sections from shifting when the browser scrollbar disappears.
	 */
	scrollbar-gutter: stable;
}

body {
	margin: 0;
	background: #ffffff;
}

/*
 * Elfsight renders the chat UI inside a shadow root. The shadow tree inherits
 * from this host element, so set the host font to avoid the site's serif
 * display family leaking into the widget.
 */
.elfsight-app-00ed413b-b198-48a2-a248-4560584516e6,
.elfsight-app-5f976442-bb60-49fe-837c-7c24128cac9d,
.eapps-all-in-one-chat-00ed413b-b198-48a2-a248-4560584516e6-custom-css-root,
.eapps-all-in-one-chat-5f976442-bb60-49fe-837c-7c24128cac9d-custom-css-root {
	font-family: "TT Norms", system-ui, -apple-system, "Segoe UI", sans-serif !important;
}

@supports not (scrollbar-gutter: stable) {
	html.has-modal-open.vvm-has-scrollbar body {
		padding-inline-end: var(--vvm-scrollbar-width);
	}

	html.has-modal-open.vvm-has-scrollbar .vvm-header {
		right: var(--vvm-scrollbar-width);
	}
}

/*
 * Single villa pages sit on a warmer canvas so transparent sections and block
 * gaps inherit the Barbados Escapes detail-page background instead of white.
 */
body.single-villa {
	background: #f6f0e6;
}

body.single-villa .wp-block-post-content > :where(:not(.alignfull)) {
	max-inline-size: min(100%, 1280px);
	margin-inline: auto;
}

/*
 * Home - Option 1 uses the image-backed two-up carousel as a hero-like villa
 * card. Keep the title/action bright, but soften the supporting amenity row.
 */
body.page-id-555 .vvm-two-up-carousel .vvm-two-up-carousel__amenities__icon,
body.page-id-555 .vvm-two-up-carousel .vvm-two-up-carousel__amenities__label {
	color: rgba(255, 253, 247, 0.72);
}

.wp-site-blocks {
	padding-top: 0;
	--wp--style--block-gap: 0;
}

.wp-site-blocks > * {
	margin-block-start: 0;
}

/*
 * Young Estates uses tight, deliberate heading spacing instead of relying on
 * browser defaults. Setting the rhythm here keeps post content, patterns, and
 * template parts visually aligned with the shared type scale from theme.json.
 */
.wp-site-blocks :where(h1, h2, h3, h4, h5, h6) {
	margin-top: 0;
}

.wp-site-blocks :where(h1) {
	margin-bottom: 0.9375rem;
}

.wp-site-blocks :where(h2, h3) {
	margin-bottom: 0;
}

.wp-site-blocks :where(h4, .h4) {
	margin-top: 0;
	margin-bottom: 1rem;
}

.wp-site-blocks :where(h6) {
	margin-top: 1.875rem;
	margin-bottom: 1.25rem;
}

/*
 * Heading utility classes let editors keep the correct semantic heading level
 * while borrowing another heading's visual style, e.g. an H2 styled like H4.
 */
.wp-site-blocks :where(.h1, .h2, .h3, .h5, .h6) {
	font-family: var(--wp--preset--font-family--display-serif);
	font-weight: 400;
	line-height: 1.3;
	letter-spacing: normal;
	text-transform: none;
	color: var(--wp--preset--color--dark-green);
}

.wp-site-blocks :where(.h1) {
	font-size: var(--wp--preset--font-size--five-xl);
}

.wp-site-blocks :where(.h2) {
	font-size: var(--wp--preset--font-size--four-xl);
}

.wp-site-blocks :where(.h3) {
	font-size: var(--wp--preset--font-size--three-xl);
}

.wp-site-blocks :where(.h4) {
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: clamp(0.6875rem, 0.66rem + 0.18vw, 0.75rem);
	font-weight: 400;
	letter-spacing: 0.34em;
	line-height: 1rem;
	text-transform: uppercase;
	color: var(--wp--preset--color--dark-green);
}

.wp-site-blocks :where(.h5) {
	font-size: var(--wp--preset--font-size--heading-sm);
}

.wp-site-blocks :where(.h6) {
	font-size: var(--wp--preset--font-size--xl);
	font-weight: 400;
	letter-spacing: 0.0625rem;
	line-height: 1;
}

/*
 * theme.json root padding only applies cleanly to direct children of
 * .wp-site-blocks. Our file/DB templates wrap page content in <main>, so we
 * recreate that gutter here and let alignfull sections cancel it back out.
 */
.wp-site-blocks > main.wp-block-group,
.wp-site-blocks > .wp-block-group > main.wp-block-group {
	padding-inline: var(--wp--custom--layout--gutter-current);
}

/*
 * The <main> wrapper above already reapplies the root gutter. When its direct
 * child also receives Gutenberg's has-global-padding class, the page ends up
 * with a doubled inline gutter and alignfull sections never truly bleed out.
 */
.wp-site-blocks > main.wp-block-group > .has-global-padding,
.wp-site-blocks > .wp-block-group > main.wp-block-group > .has-global-padding {
	padding-inline: 0;
}

.wp-site-blocks > main.wp-block-group > .alignfull,
.wp-site-blocks > .wp-block-group > main.wp-block-group > .alignfull,
.wp-site-blocks > main.wp-block-group > .has-global-padding > .alignfull,
.wp-site-blocks
	> .wp-block-group
	> main.wp-block-group
	> .has-global-padding
	> .alignfull,
.wp-site-blocks > main.wp-block-group > .wp-block-post-content > .alignfull,
.wp-site-blocks
	> .wp-block-group
	> main.wp-block-group
	> .wp-block-post-content
	> .alignfull {
	margin-inline: calc(var(--wp--custom--layout--gutter-current) * -1);
}

/*
 * The split-content block's edge mode uses a viewport-wide breakout. On
 * desktop, `100vw` includes the scrollbar width, so the section bleeds by a
 * few pixels and creates a horizontal scrollbar. Front-end JS keeps
 * --vvm-scrollbar-width updated with the real scrollbar width so the breakout
 * still reaches the viewport edge without overshooting it.
 */
body .wp-site-blocks .wp-block-gutenberg-lab-blocks-split-content.split-content--edge {
	inline-size: calc(100vw - var(--vvm-scrollbar-width)) !important;
	max-inline-size: calc(100vw - var(--vvm-scrollbar-width)) !important;
	margin-inline: calc(50% - 50vw + (var(--vvm-scrollbar-width) / 2)) !important;
	overflow-x: clip;
}

body .wp-site-blocks .wp-block-gutenberg-lab-blocks-split-content.split-content--edge .split-content__grid {
	inline-size: 100% !important;
	max-inline-size: 100% !important;
	margin-inline: 0 !important;
}

.wp-site-blocks > .wp-block-template-part,
.wp-site-blocks > .wp-block-template-part > .vvm-header {
	margin-block-end: 0;
}

.wp-site-blocks main p a:not(.wp-element-button),
.wp-site-blocks main li a:not(.wp-element-button),
.wp-site-blocks main .has-xs-font-size a:not(.wp-element-button) {
	color: var(--wp--preset--color--dark-green, #1e3d2f);
	text-decoration-line: underline;
	text-decoration-color: currentColor;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.14em;
	transition:
		color 0.2s ease,
		text-decoration-color 0.2s ease,
		text-decoration-thickness 0.2s ease,
		text-underline-offset 0.2s ease;
}

.wp-site-blocks main p a:not(.wp-element-button):hover,
.wp-site-blocks main p a:not(.wp-element-button):focus-visible,
.wp-site-blocks main li a:not(.wp-element-button):hover,
.wp-site-blocks main li a:not(.wp-element-button):focus-visible,
.wp-site-blocks main .has-xs-font-size a:not(.wp-element-button):hover,
.wp-site-blocks main .has-xs-font-size a:not(.wp-element-button):focus-visible {
	color: var(--wp--preset--color--gold, #c4922a);
	text-decoration-thickness: 2px;
	text-underline-offset: 0.2em;
}

/*
 * Utility list for the villa detail "yellow dots" pattern used on dark
 * surfaces. Editors can apply the `list-yellow-dots` class to a List block.
 */
.wp-site-blocks :where(ul.list-yellow-dots, ol.list-yellow-dots) {
	margin: 2rem 0 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	font-size: 0.875rem;
	line-height: 1.75;
	color: rgba(245, 236, 215, 0.88);
}

.wp-site-blocks :where(ul.list-yellow-dots, ol.list-yellow-dots) li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
}

.wp-site-blocks :where(ul.list-yellow-dots, ol.list-yellow-dots) li::before {
	content: "";
	display: block;
	width: 0.5rem;
	height: 0.5rem;
	/* Half the 1.75 line box minus half the dot keeps the marker centered. */
	margin-top: calc(0.875em - 0.25rem);
	border-radius: 999px;
	background: var(--wp--preset--color--gold, #c4922a);
	flex: 0 0 0.5rem;
}

/*
 * Structured numbered list utility for amenity/facts content. Editors can add
 * `list-numbered-light` or `list-numbered-dark` to a List block and reuse the
 * same spacing/number treatment on light or dark surfaces.
 */
.wp-site-blocks :where(.list-numbered-light, .list-numbered-dark) {
	--vvm-numbered-list-text: rgb(30 61 47 / 0.82);
	--vvm-numbered-list-rule: rgb(196 146 42 / 0.22);
	--vvm-numbered-list-number: var(--wp--preset--color--gold, #c4922a);
	margin: 0;
	padding: 0;
	list-style: none;
	counter-reset: vvm-numbered-list;
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: clamp(1rem, 0.96rem + 0.18vw, 1.125rem);
	font-weight: 400;
	line-height: 1.55;
	color: var(--vvm-numbered-list-text);
}

.wp-site-blocks :where(.list-numbered-light) {
	--vvm-numbered-list-text: rgb(30 61 47 / 0.82);
	--vvm-numbered-list-rule: rgb(196 146 42 / 0.22);
}

.wp-site-blocks :where(.list-numbered-dark) {
	--vvm-numbered-list-text: rgb(245 236 215 / 0.88);
	--vvm-numbered-list-rule: rgb(245 236 215 / 0.12);
}

.wp-site-blocks :where(.list-numbered-light, .list-numbered-dark) > li {
	counter-increment: vvm-numbered-list;
	display: grid;
	grid-template-columns: minmax(2rem, auto) minmax(0, 1fr);
	align-items: baseline;
	column-gap: clamp(0.75rem, 1.2vw, 1.125rem);
	padding-block: clamp(1.25rem, 2vw, 1.625rem);
	border-bottom: 1px solid var(--vvm-numbered-list-rule);
}

.wp-site-blocks :where(.list-numbered-light, .list-numbered-dark) > li::before {
	content: counter(vvm-numbered-list, decimal-leading-zero);
	color: var(--vvm-numbered-list-number);
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.75rem;
	font-weight: 400;
	letter-spacing: 0.3em;
	line-height: inherit;
	font-variant-numeric: tabular-nums;
}

.wp-site-blocks :where(.list-numbered-light, .list-numbered-dark) > li > p {
	margin: 0;
}

/*
 * Table utility that mirrors the villa detail travel-times treatment. Use
 * explicit selectors here because Gutenberg core ships a stronger `.wp-block-
 * table td, .wp-block-table th` border rule that `:where()` will not beat.
 */
.wp-site-blocks figure.wp-block-table.table-singe-border-bottom,
.wp-site-blocks figure.wp-block-table.table-single-border-bottom {
	margin-block: 0;
}

.wp-site-blocks figure.wp-block-table.table-singe-border-bottom table,
.wp-site-blocks figure.wp-block-table.table-single-border-bottom table,
.wp-site-blocks table.table-singe-border-bottom,
.wp-site-blocks table.table-single-border-bottom {
	width: 100%;
	margin: 0;
	border: 0;
	border-collapse: collapse;
	border-spacing: 0;
	table-layout: auto;
	background: transparent;
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.55;
	color: rgb(30 61 47 / 0.88);
}

.wp-site-blocks figure.wp-block-table.table-singe-border-bottom td,
.wp-site-blocks figure.wp-block-table.table-singe-border-bottom th,
.wp-site-blocks figure.wp-block-table.table-single-border-bottom td,
.wp-site-blocks figure.wp-block-table.table-single-border-bottom th,
.wp-site-blocks table.table-singe-border-bottom td,
.wp-site-blocks table.table-singe-border-bottom th,
.wp-site-blocks table.table-single-border-bottom td,
.wp-site-blocks table.table-single-border-bottom th {
	padding: 1.125rem 0;
	border: 0;
	background: transparent;
	vertical-align: middle;
}

.wp-site-blocks figure.wp-block-table.table-singe-border-bottom tr > *,
.wp-site-blocks figure.wp-block-table.table-single-border-bottom tr > *,
.wp-site-blocks table.table-singe-border-bottom tr > *,
.wp-site-blocks table.table-single-border-bottom tr > * {
	border-bottom: 1px solid rgb(30 61 47 / 0.12);
}

.wp-site-blocks figure.wp-block-table.table-singe-border-bottom table > :last-child > tr:last-child > *,
.wp-site-blocks figure.wp-block-table.table-single-border-bottom table > :last-child > tr:last-child > *,
.wp-site-blocks table.table-singe-border-bottom > :last-child > tr:last-child > *,
.wp-site-blocks table.table-single-border-bottom > :last-child > tr:last-child > * {
	border-bottom: 0;
}

.wp-site-blocks figure.wp-block-table.table-singe-border-bottom th,
.wp-site-blocks figure.wp-block-table.table-single-border-bottom th,
.wp-site-blocks table.table-singe-border-bottom th,
.wp-site-blocks table.table-single-border-bottom th {
	font-weight: 400;
	text-align: left;
	color: inherit;
}

.wp-site-blocks figure.wp-block-table.table-singe-border-bottom tr > :first-child,
.wp-site-blocks figure.wp-block-table.table-single-border-bottom tr > :first-child,
.wp-site-blocks table.table-singe-border-bottom tr > :first-child,
.wp-site-blocks table.table-single-border-bottom tr > :first-child {
	padding-right: 1.5rem;
}

.wp-site-blocks figure.wp-block-table.table-singe-border-bottom tr > :last-child:not(:first-child),
.wp-site-blocks figure.wp-block-table.table-single-border-bottom tr > :last-child:not(:first-child),
.wp-site-blocks table.table-singe-border-bottom tr > :last-child:not(:first-child),
.wp-site-blocks table.table-single-border-bottom tr > :last-child:not(:first-child) {
	width: 1%;
	padding-left: 1.5rem;
	text-align: right;
	white-space: nowrap;
	font-size: 0.875rem;
	letter-spacing: 0.34em;
	text-transform: uppercase;
	color: rgb(196 146 42 / 0.88);
}

/*
 * Villa bedroom level cards. This stays in the theme because the section is
 * authored with native Gutenberg blocks while the visual system is site-wide.
 */
.wp-site-blocks .vvm-bedroom-levels {
	--vvm-bedroom-levels-ink: var(--wp--preset--color--dark-green, #173528);
	--vvm-bedroom-levels-muted: rgb(23 53 40 / 0.66);
	--vvm-bedroom-levels-gold: var(--wp--preset--color--gold, #c4922a);
	--vvm-bedroom-levels-rule: rgb(23 53 40 / 0.13);
	--vvm-bedroom-levels-card: #fffdf8;
	--vvm-bedroom-levels-soft: #f7f1e7;
	margin-block-start: clamp(2rem, 4vw, 3rem);
	padding-block: clamp(1.5rem, 3vw, 2rem);
	border-block: 1px solid var(--vvm-bedroom-levels-rule);
	color: var(--vvm-bedroom-levels-ink);
}

.wp-site-blocks .vvm-bedroom-levels__nav {
	align-items: stretch;
	gap: 0.625rem;
	margin: 0 0 clamp(1.2rem, 1.8vw, 1.45rem);
	padding-bottom: 0;
	border-bottom: 1px solid var(--vvm-bedroom-levels-rule);
}

.wp-site-blocks .vvm-bedroom-levels__nav .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2.875rem;
	padding: 0.875rem clamp(1.1rem, 1.45vw, 1.35rem);
	border: 1px solid transparent !important;
	border-radius: 0 !important;
	background: #efe8dc !important;
	color: var(--vvm-bedroom-levels-muted) !important;
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.69rem;
	font-weight: 400;
	letter-spacing: 0.32em;
	line-height: 1;
	text-transform: uppercase;
	text-decoration: none;
	white-space: nowrap;
}

.wp-site-blocks .vvm-bedroom-levels__nav .wp-block-button__link::before,
.wp-site-blocks .vvm-bedroom-levels__nav .wp-block-button__link::after {
	/* These tabs reuse core Button blocks, but should not inherit the global
	 * branded button gradient layer. */
	content: none !important;
	display: none !important;
}

.wp-site-blocks .vvm-bedroom-levels__nav .wp-block-button__link:hover,
.wp-site-blocks .vvm-bedroom-levels__nav .wp-block-button__link:focus-visible {
	box-shadow: none !important;
	transform: none !important;
}

.wp-site-blocks .vvm-bedroom-levels__nav-button.is-active .wp-block-button__link {
	border-color: var(--vvm-bedroom-levels-rule) !important;
	border-top: 2px solid var(--vvm-bedroom-levels-gold) !important;
	background: var(--vvm-bedroom-levels-card) !important;
	box-shadow: none !important;
	color: var(--vvm-bedroom-levels-ink) !important;
}

.wp-site-blocks .vvm-bedroom-levels__grid {
	display: grid;
	grid-template-columns: minmax(18rem, 1.4fr) repeat(3, minmax(0, 1fr));
	gap: clamp(0.75rem, 1.15vw, 1.125rem);
	align-items: stretch;
	margin: 0;
}

.wp-site-blocks .vvm-bedroom-levels__panel {
	display: none;
}

.wp-site-blocks .vvm-bedroom-levels__panel.is-active {
	display: grid;
}

.wp-site-blocks .vvm-bedroom-levels__card {
	position: relative;
	box-sizing: border-box;
	min-height: clamp(17.5rem, 23vw, 21rem);
	margin: 0;
	padding: 1rem;
	border: 1px solid var(--vvm-bedroom-levels-rule);
	background: var(--vvm-bedroom-levels-card);
}

.wp-site-blocks .vvm-bedroom-levels__intro-card {
	background: #fbf8f2;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-bedroom-levels__room-card {
	display: block;
}

.wp-site-blocks .vvm-bedroom-levels__eyebrow,
.wp-site-blocks .vvm-bedroom-levels__hint,
.wp-site-blocks .vvm-bedroom-levels__room-count,
.wp-site-blocks .vvm-bedroom-levels__chip,
.wp-site-blocks .vvm-bedroom-levels__badge {
	font-family: var(--wp--preset--font-family--refined-sans);
	font-weight: 400;
	letter-spacing: 0.24em;
	line-height: 1.15;
	text-transform: uppercase;
}

.wp-site-blocks .vvm-bedroom-levels__eyebrow {
	margin: 0 0 0.65rem;
	color: var(--vvm-bedroom-levels-gold);
	font-size: 0.68rem;
}

.wp-site-blocks .vvm-bedroom-levels__copy {
	margin: 0.9rem 0 0;
	color: var(--vvm-bedroom-levels-muted);
	font-size: 1rem;
	line-height: 1.55;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-bedroom-levels__title {
	/* Keep the room title visually aligned with the theme H5 scale,
	 * even when Gutenberg outputs another heading level/class. */
	margin: 0;
	color: var(--vvm-bedroom-levels-ink, var(--wp--preset--color--dark-green));
	font-family: var(--wp--preset--font-family--display-serif);
	font-size: 24px;
	font-weight: 400;
	letter-spacing: normal;
	line-height: 1.3;
	text-transform: none;
}

.wp-site-blocks .vvm-bedroom-levels__room-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	width: max-content;
	margin: 1.05rem 0 0;
	min-height: 1.8rem;
	padding: 0.35rem 0.65rem;
	border: 1px solid var(--vvm-bedroom-levels-rule);
	background: #ffffff;
	color: var(--vvm-bedroom-levels-muted);
	font-size: 0.62rem;
}

.wp-site-blocks .vvm-bedroom-levels__divider {
	margin-block: clamp(1.15rem, 2vw, 1.5rem) 0.9rem;
	border: 0;
	height: 1px;
	background: var(--vvm-bedroom-levels-rule);
	color: transparent;
	opacity: 1;
}

.wp-site-blocks .vvm-bedroom-levels__hint {
	max-width: 28ch;
	margin: 0;
	color: rgb(23 53 40 / 0.54);
	font-size: 0.62rem;
	line-height: 1.45;
}

.wp-site-blocks .vvm-bedroom-levels__badge {
	position: absolute;
	top: clamp(1.1rem, 1.5vw, 1.35rem);
	right: clamp(1.1rem, 1.5vw, 1.35rem);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	inline-size: max-content;
	max-inline-size: 100%;
	min-height: 1.75rem;
	margin: 0;
	padding: 0.3rem 0.7rem;
	border: 1px solid var(--vvm-bedroom-levels-rule);
	border-radius: 999px;
	background: #ffffff;
	color: var(--vvm-bedroom-levels-muted);
	font-size: 0.56rem;
	text-align: center;
	text-indent: 0.24em;
	white-space: normal;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-bedroom-levels__chips .vvm-bedroom-levels__badge {
	position: static;
	flex: 0 0 auto;
	float: none;
	margin: 0;
}

/* Room titles should use the full card width because the badge now lives with the chips. */
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-bedroom-levels__room-card .vvm-bedroom-levels__title {
	min-width: 0;
	max-width: none;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-bedroom-levels__room-card .vvm-bedroom-levels__chips,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-bedroom-levels__room-card .vvm-bedroom-levels__copy {
	max-width: none;
}

.wp-site-blocks .vvm-bedroom-levels__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 0.38rem 0.42rem;
	margin-block-start: 0.85rem;
}

.wp-site-blocks .vvm-bedroom-levels__chip {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	width: max-content;
	margin: 0;
	min-height: 1.6rem;
	padding: 0.28rem 0.55rem;
	border: 1px solid var(--vvm-bedroom-levels-rule);
	border-radius: 999px;
	background: var(--vvm-bedroom-levels-soft);
	color: rgb(23 53 40 / 0.58);
	font-size: 0.56rem;
	line-height: 1.15;
}

.wp-site-blocks .vvm-bedroom-levels__chip--bed {
	border-color: var(--vvm-bedroom-levels-ink);
	background: var(--vvm-bedroom-levels-ink);
	color: #f7f1e7;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities {
	--vvm-villa-amenities-ink: var(--wp--preset--color--dark-green, #173528);
	--vvm-villa-amenities-muted: rgb(23 53 40 / 0.66);
	--vvm-villa-amenities-gold: var(--wp--preset--color--gold, #c4922a);
	--vvm-villa-amenities-rule: rgb(23 53 40 / 0.12);
	--vvm-villa-amenities-card: #fffdf8;
	--vvm-villa-amenities-soft: #f7f1e7;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(1rem, 2vw, 1.6rem);
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__card {
	box-sizing: border-box;
	margin: 0;
	padding: clamp(1.5rem, 2.25vw, 2.15rem);
	border: 1px solid var(--vvm-villa-amenities-rule);
	border-top: 2px solid var(--vvm-villa-amenities-gold);
	background: var(--vvm-villa-amenities-card);
	box-shadow: 0 18px 40px rgb(23 53 40 / 0.04);
	color: var(--vvm-villa-amenities-ink);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__card--dark {
	--vvm-villa-amenities-muted: rgb(247 241 231 / 0.68);
	--vvm-villa-amenities-rule: rgb(247 241 231 / 0.12);
	background: linear-gradient(180deg, #153c2c 0%, #082319 100%);
	box-shadow: none;
	color: #f7f1e7;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__header {
	display: grid;
	grid-template-columns: minmax(0, 1fr) max-content;
	gap: clamp(1rem, 2vw, 1.5rem);
	align-items: start;
	margin: 0;
	padding-bottom: clamp(1.1rem, 1.8vw, 1.45rem);
	border-bottom: 1px solid var(--vvm-villa-amenities-rule);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__intro {
	display: grid;
	gap: 0.6rem;
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__intro > * {
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__eyebrow,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__chip,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__index {
	font-family: var(--wp--preset--font-family--refined-sans);
	font-weight: 400;
	letter-spacing: 0.24em;
	line-height: 1.15;
	text-transform: uppercase;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__eyebrow {
	color: var(--vvm-villa-amenities-gold);
	font-size: 0.68rem;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__card--dark .wp-block-heading {
	color: #f7f1e7;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__copy {
	color: var(--vvm-villa-amenities-muted);
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.95rem;
	line-height: 1.7;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__chips {
	/* display: grid; */
	display: none;
	grid-template-columns: repeat(2, min-content);
	gap: 0.45rem;
	justify-content: end;
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__chip {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	min-height: 2.45rem;
	min-inline-size: 4.85rem;
	margin: 0;
	padding: 0.55rem 0.7rem;
	border: 1px solid var(--vvm-villa-amenities-rule);
	background: rgb(255 255 255 / 0.42);
	color: var(--vvm-villa-amenities-muted);
	font-size: 0.58rem;
	text-align: center;
	text-wrap: balance;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__card--dark .vvm-villa-amenities__chip {
	background: rgb(255 255 255 / 0.06);
	color: rgb(247 241 231 / 0.72);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__list {
	display: grid;
	margin: 0;
	padding-top: clamp(1.1rem, 1.8vw, 1.45rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__row {
	display: grid;
	grid-template-columns: 3.2rem minmax(0, 1fr);
	gap: 1.1rem;
	align-items: center;
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__index,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__item {
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__index {
	color: var(--vvm-villa-amenities-gold);
	font-size: 0.62rem;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities--show-numbers .vvm-villa-amenities__list {
	counter-reset: vvm-villa-amenity-number;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities--show-numbers .vvm-villa-amenities__row {
	counter-increment: vvm-villa-amenity-number;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities--show-numbers .vvm-villa-amenities__index {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	color: transparent;
	font-size: 0;
	line-height: 1;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities--show-numbers .vvm-villa-amenities__index::before {
	content: counter(vvm-villa-amenity-number, decimal-leading-zero);
	color: var(--vvm-villa-amenities-gold);
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.94rem;
	font-weight: 400;
	letter-spacing: 0.24em;
	line-height: 1.55;
	text-transform: uppercase;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules):not(.vvm-villa-amenities--show-numbers) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	color: transparent;
	font-size: 0;
	line-height: 1;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules):not(.vvm-villa-amenities--show-numbers) .vvm-villa-amenities__index::before {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background: var(--vvm-villa-amenities-gold);
	-webkit-mask: var(--vvm-villa-amenity-icon) center / 145% 145% no-repeat;
	mask: var(--vvm-villa-amenity-icon) center / 145% 145% no-repeat;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(1) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/aircon.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(2) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/ceiling-fan.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(3) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/tv.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(4) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/closet.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(5) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/bathtub.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(6) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/media-room.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(7) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/cooking-pot.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(8) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/hair-dryer.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(9) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/bed.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(10) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/breakfast-bar.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(11) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/dishwasher.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(12) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/telephone.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card:not(.vvm-villa-amenities__card--dark) .vvm-villa-amenities__row:nth-child(13) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/wifi.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card--dark .vvm-villa-amenities__row:nth-child(1) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/infinity-pool.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card--dark .vvm-villa-amenities__row:nth-child(2) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/lounge-chair.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card--dark .vvm-villa-amenities__row:nth-child(3) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/bbq.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card--dark .vvm-villa-amenities__row:nth-child(4) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/cafe-table.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card--dark .vvm-villa-amenities__row:nth-child(5) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/tropical.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card--dark .vvm-villa-amenities__row:nth-child(6) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/car.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card--dark .vvm-villa-amenities__row:nth-child(7) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/temple.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card--dark .vvm-villa-amenities__row:nth-child(8) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/gym.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card--dark .vvm-villa-amenities__row:nth-child(9) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/tennis.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules) .vvm-villa-amenities__card--dark .vvm-villa-amenities__row:nth-child(10) .vvm-villa-amenities__index {
	--vvm-villa-amenity-icon: url("assets/icons/martin.svg");
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__item {
	color: var(--vvm-villa-amenities-muted);
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.94rem;
	line-height: 1.55;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__card--dark .vvm-villa-amenities__item {
	color: rgb(247 241 231 / 0.72);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules {
	grid-template-columns: minmax(0, 1fr);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules > .wp-block-group {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(1rem, 2vw, 1.6rem);
	align-items: stretch;
	width: 100%;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules > .wp-block-group > .vvm-villa-amenities__card {
	width: 100%;
	max-width: none;
	min-width: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules > .wp-block-group > .vvm-villa-amenities__card > .wp-block-image {
	height: 100%;
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules > .wp-block-group > .vvm-villa-amenities__card > .wp-block-image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules__list {
	border: 1px solid var(--vvm-villa-amenities-rule);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules__row {
	display: block;
	margin: 0;
	padding: 0;
	border: 0;
	background: #fbf8f2;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules__row .vvm-villa-amenities__item {
	/*
	 * The rule text is editor-managed as one Paragraph block:
	 * <strong>Label</strong> Value. Grid lets the label behave like a first
	 * table column without changing this into a real table.
	 */
	display: grid;
	grid-template-columns: minmax(8.5rem, 0.42fr) minmax(0, 1fr);
	column-gap: clamp(1rem, 2vw, 1.35rem);
	align-items: baseline;
	margin: 0;
	/* Paragraph blocks carry saved padding tokens; the compact table row rhythm should win here. */
	padding-block: 10px !important;
	padding-inline: 1.35rem;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules__row:nth-of-type(even) {
	background: #ffffff;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules__row .vvm-villa-amenities__item strong {
	color: var(--wp--preset--color--dark-green);
	font-weight: 700;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews {
	grid-template-columns: minmax(0, 1fr);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews .vvm-villa-amenities__card {
	/* Reviews keep the shared dark-card class in markup, but this section should read like a light amenities card. */
	--vvm-villa-amenities-muted: rgb(23 53 40 / 0.66);
	--vvm-villa-amenities-rule: rgb(23 53 40 / 0.12);
	padding: clamp(2rem, 3vw, 3rem);
	background: var(--vvm-villa-amenities-card);
	box-shadow: 0 18px 40px rgb(23 53 40 / 0.04);
	color: var(--vvm-villa-amenities-ink);
	font-family: var(--wp--preset--font-family--refined-sans);
}

.vvm-stack-tabs__panel:has(.vvm-villa-reviews) {
	/* Global villa review treatment: only the outer tab panel gets the dark surface. */
	background: var(--wp--preset--color--dark-green);
	border-color: rgb(196 146 42 / 0.35);
	color: var(--wp--preset--color--light-gold);
	box-shadow: 0 24px 56px rgb(23 53 40 / 0.12);
}

.vvm-stack-tabs__panel:has(.vvm-villa-reviews) > .vvm-stack-tabs__tab-content {
	background: var(--wp--preset--color--white);
	color: var(--wp--preset--color--dark-green);
}

.vvm-stack-tabs__panel:has(.vvm-villa-reviews) .vvm-villa-reviews {
	background-color: var(--wp--preset--color--white) !important;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews .vvm-villa-amenities__eyebrow {
	padding-left: var(--wp--preset--spacing--lg);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__list {
	display: grid;
	margin-top: clamp(1.8rem, 2.8vw, 2.4rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__review {
	display: grid;
	gap: clamp(1rem, 1.8vw, 1.35rem);
	margin: 0;
	padding: 0 0 clamp(1.8rem, 3vw, 2.4rem);
	border-bottom: 1px solid var(--vvm-villa-amenities-rule);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__review::before {
	content: "\2605\2605\2605\2605\2605";
	color: #d2a31f;
	font-size: 0.9rem;
	line-height: 1;
	letter-spacing: 0.1em;
	padding-left: var(--wp--preset--spacing--lg);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__review + .vvm-villa-reviews__review {
	padding-top: clamp(1.8rem, 3vw, 2.4rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__review:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__quote,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__copy,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__author {
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews .vvm-villa-reviews__quote {
	color: var(--vvm-villa-amenities-ink);
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: clamp(1.2rem, 1.5vw, 1.45rem);
	font-weight: 400;
	line-height: 1.45;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__copy,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__author {
	color: var(--vvm-villa-amenities-muted);
	font-family: var(--wp--preset--font-family--refined-sans);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__copy--clamped {
	display: -webkit-box;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	line-clamp: 3;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__read-more {
	justify-self: start;
	margin: -0.55rem 0 0;
	padding: 0 0 0 var(--wp--preset--spacing--lg);
	border: 0;
	background: transparent;
	color: #d2a31f;
	cursor: pointer;
	font-family: var(--wp--preset--font-family--body);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	line-height: 1.2;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.22em;
	text-transform: uppercase;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__read-more:hover,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews__read-more:focus-visible {
	color: #f0c850;
}

/*
 * Reviews stay authored as normal Gutenberg Group blocks. On the front end, JS
 * moves those review groups into this carousel shell; without JS, the original
 * stacked review list above remains intact.
 */
:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel {
	--vvm-villa-reviews-slide-gap: clamp(1.25rem, 2vw, 1.75rem);
	--vvm-villa-reviews-slide-width: 100%;
}

:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel .vvm-villa-reviews__list {
	position: relative;
	display: grid;
	gap: clamp(1rem, 1.8vw, 1.4rem);
}

:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel .vvm-villa-reviews__viewport {
	overflow: hidden;
	touch-action: pan-y;
	transition: height 0.28s ease;
}

:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel .vvm-villa-reviews__viewport,
:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel .vvm-villa-reviews__controls,
:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel .vvm-villa-reviews__status {
	margin: 0;
}

:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel .vvm-villa-reviews__track {
	display: flex;
	gap: var(--vvm-villa-reviews-slide-gap);
	align-items: flex-start;
	transition: transform 0.28s ease;
	will-change: transform;
}

:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel .vvm-villa-reviews__review {
	flex: 0 0 var(--vvm-villa-reviews-slide-width);
	inline-size: var(--vvm-villa-reviews-slide-width);
	min-width: 0;
	align-content: start;
	gap: clamp(0.75rem, 1.2vw, 1rem);
	padding: 0;
	border-bottom: 0;
}

:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel .vvm-villa-reviews__review + .vvm-villa-reviews__review {
	padding-top: 0;
}

:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel .vvm-villa-reviews__controls {
	display: flex;
	justify-content: flex-end;
	gap: 0.75rem;
}

:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel .vvm-villa-reviews__button {
	--vvm-slider-button-size: clamp(2.5rem, 3vw, 3rem);
	--vvm-slider-button-icon-size: 1rem;
}

:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel.has-carousel-overflow .vvm-villa-reviews__viewport {
	cursor: grab;
}

:where(.wp-site-blocks) .vvm-villa-reviews.is-carousel.is-dragging .vvm-villa-reviews__viewport {
	cursor: grabbing;
}

@media (min-width: 900px) {
	:where(.wp-site-blocks) .vvm-villa-reviews.is-style-vvm-reviews-three-up.is-carousel {
		--vvm-villa-reviews-slide-width: calc(
			(100% - var(--vvm-villa-reviews-slide-gap)) / 2
		);
	}

	:where(.wp-site-blocks) .vvm-villa-reviews.is-style-vvm-reviews-three-up.is-carousel .vvm-villa-reviews__quote {
		font-size: clamp(1.2rem, 1.5vw, 1.45rem);
	}
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing {
	grid-template-columns: minmax(0, 1fr);
	min-width: 0;
}

/*
 * Pair the pricing card with the enquiry form on villa detail pages.
 * The saved Gutenberg blocks stay editable; this wrapper only controls the
 * desktop composition requested by the design.
 */
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact {
	--vvm-villa-amenities-ink: var(--wp--preset--color--dark-green, #173528);
	--vvm-villa-amenities-muted: rgb(23 53 40 / 0.66);
	--vvm-villa-amenities-gold: var(--wp--preset--color--gold, #c4922a);
	--vvm-villa-amenities-rule: rgb(23 53 40 / 0.12);
	--vvm-villa-amenities-card: #fffdf8;
	--vvm-villa-amenities-soft: #f7f1e7;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(1rem, 2vw, 1.6rem);
	align-items: stretch;
	margin-top: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact > :where(.vvm-villa-pricing, .vvm-villa-contact__form-card) {
	min-width: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact > .vvm-villa-pricing {
	margin-bottom: 0 !important;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact .vvm-villa-pricing__card,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact > .vvm-villa-contact__form-card {
	height: 100%;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact .vvm-villa-pricing__header {
	grid-template-columns: minmax(0, 1fr);
	align-items: start;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact .vvm-villa-pricing__helper {
	justify-self: start;
	max-width: 34rem;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact .vvm-villa-pricing__table table {
	min-width: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact .vvm-villa-pricing__table th,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact .vvm-villa-pricing__table td {
	padding: 0.9rem 0.8rem;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact .vvm-villa-pricing__table th {
	letter-spacing: 0.18em;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact .vvm-villa-pricing__table td {
	font-size: 0.88rem;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__card {
	min-width: 0;
	padding: clamp(2rem, 3vw, 3rem);
	background: #ffffff;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__header {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(16rem, 0.9fr);
	align-items: end;
	margin: 0 0 clamp(1.5rem, 2.5vw, 2.25rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__intro {
	display: grid;
	gap: 0.6rem;
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__intro > * {
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__helper {
	justify-self: end;
	max-width: 44rem;
	margin: 0;
	color: rgb(23 53 40 / 0.52);
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.82rem;
	line-height: 1.55;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__table {
	box-sizing: border-box;
	max-width: 100%;
	margin: 0;
	border: 1px solid var(--vvm-villa-amenities-rule);
	overflow-x: auto;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__table table {
	width: 100%;
	min-width: 42rem;
	margin: 0;
	border-collapse: collapse;
	font-family: var(--wp--preset--font-family--refined-sans);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__table th,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__table td {
	border: 0;
	padding: 1rem 1.35rem;
	text-align: left;
	vertical-align: middle;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__table th {
	background: var(--vvm-villa-amenities-ink);
	color: #f7f1e7;
	font-size: 0.62rem;
	font-weight: 400;
	letter-spacing: 0.24em;
	line-height: 1.15;
	text-transform: uppercase;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__table td {
	color: var(--vvm-villa-amenities-muted);
	font-size: 0.94rem;
	line-height: 1.55;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__table tbody tr:nth-child(odd) {
	background: #fbf8f2;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__table tbody tr:nth-child(even) {
	background: #ffffff;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__terms {
	display: grid;
	gap: 1rem;
	margin: clamp(1.5rem, 2.5vw, 2rem) 0 0;
	padding: clamp(1.4rem, 2.4vw, 2rem);
	background: var(--vvm-villa-amenities-soft);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__terms > * {
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__terms-title,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__terms-copy {
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.94rem;
	line-height: 1.55;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__terms-title {
	color: var(--vvm-villa-amenities-ink);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__terms-copy {
	color: var(--vvm-villa-amenities-muted);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact {
	grid-template-columns: minmax(0, 1.08fr) minmax(24rem, 0.92fr);
	align-items: stretch;
	margin-top: clamp(1.5rem, 3vw, 2.5rem);
}

/* Once the enquiry form moves beside pricing, the remaining map card can use the full row. */
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact:not(:has(> .vvm-villa-contact__form-card)) {
	grid-template-columns: minmax(0, 1fr);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__location-card {
	display: grid;
	grid-template-rows: minmax(18rem, 0.72fr) auto;
	min-width: 0;
	margin: 0;
	background: #ffffff;
	border: 1px solid var(--vvm-villa-amenities-rule);
	box-shadow: 0 18px 40px rgb(23 53 40 / 0.04);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__location-card:has(> .vvm-villa-contact__media-slot > .vvm-villa-amenities__eyebrow) {
	align-self: stretch;
	grid-template-rows: minmax(0, 1fr);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot {
	display: grid;
	align-items: stretch;
	min-height: clamp(18rem, 34vw, 30rem);
	margin: 0;
	background:
		linear-gradient(rgb(23 53 40 / 0.055) 1px, transparent 1px),
		linear-gradient(90deg, rgb(23 53 40 / 0.055) 1px, transparent 1px),
		#dcebe7;
	background-size: 4.5rem 4.5rem;
	overflow: hidden;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot > * {
	width: 100%;
	height: 100%;
	min-height: inherit;
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot :where(img, iframe) {
	display: block;
	width: 100%;
	height: 100%;
	min-height: inherit;
	border: 0;
	object-fit: cover;
}

.js :where(.wp-site-blocks) .vvm-lazy-map {
	position: relative;
	isolation: isolate;
	cursor: pointer;
	min-height: 20rem;
}

.js :where(.wp-site-blocks) .vvm-lazy-map iframe:not([src]) {
	opacity: 0;
	pointer-events: none;
}

.js :where(.wp-site-blocks) .vvm-lazy-map:not(.is-loaded)::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background:
		linear-gradient(rgb(23 53 40 / 0.08) 1px, transparent 1px),
		linear-gradient(90deg, rgb(23 53 40 / 0.08) 1px, transparent 1px),
		#dcebe7;
	background-size: 4.5rem 4.5rem;
}

.js :where(.wp-site-blocks) .vvm-lazy-map:not(.is-loaded)::after {
	content: "View map";
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2.75rem;
	padding: 0.85rem 1.2rem;
	border: 1px solid rgb(23 53 40 / 0.18);
	background: #fbf8f2;
	color: var(--wp--preset--color--dark-green);
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.68rem;
	font-weight: 400;
	letter-spacing: 0.24em;
	line-height: 1;
	text-transform: uppercase;
	transform: translate(-50%, -50%);
}

.js :where(.wp-site-blocks) .vvm-lazy-map:focus-visible {
	outline: 2px solid var(--wp--preset--color--gold);
	outline-offset: 4px;
}

/* When editors add map text directly under the map, treat it as the location panel. */
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot:has(> .vvm-villa-amenities__eyebrow) {
	align-content: start;
	grid-template-rows: minmax(18rem, 1fr) auto auto;
	height: 100%;
	background: #ffffff;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot:has(> .vvm-villa-amenities__eyebrow) > :first-child {
	height: 100%;
	min-height: clamp(18rem, 34vw, 30rem);
}

/* The map block can save an explicit iframe height; this layout lets the card control it. */
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot:has(> .vvm-villa-amenities__eyebrow) > .wp-block-gmap-gmap-block iframe {
	height: 100% !important;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot:has(> .vvm-villa-amenities__eyebrow) > :where(.vvm-villa-amenities__eyebrow, .vvm-villa-amenities__item) {
	justify-self: stretch;
	width: auto;
	max-width: none;
	height: auto;
	min-height: 0;
	margin-right: clamp(1.5rem, 2vw, 2rem) !important;
	margin-left: clamp(1.5rem, 2vw, 2rem) !important;
	text-align: left;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot:has(> .vvm-villa-amenities__eyebrow) > .vvm-villa-amenities__eyebrow {
	margin-top: 20px;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot:has(> .vvm-villa-amenities__eyebrow) > .vvm-villa-amenities__item {
	margin-top: 0.8rem;
	margin-bottom: clamp(1.5rem, 2vw, 2rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__location {
	display: grid;
	gap: 0.8rem;
	align-content: start;
	min-height: clamp(8rem, 15vw, 14rem);
	margin: 0;
	padding: clamp(1.5rem, 2vw, 2rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__location > * {
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__form-card {
	display: grid;
	grid-template-columns: auto auto minmax(0, 1fr);
	grid-template-areas:
		"intro intro intro"
		"form form form"
		"submit whatsapp ."
		"response response response";
	column-gap: 0.75rem;
	min-width: 0;
	padding: clamp(2rem, 3.2vw, 3.2rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__intro {
	grid-area: intro;
	display: grid;
	gap: 0.6rem;
	margin: 0 0 clamp(1.5rem, 2.5vw, 2rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__intro > * {
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__form-card .wp-block-contact-form-7-contact-form-selector {
	display: contents;
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__form-card .wpcf7,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form {
	display: contents;
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form .hidden-fields-container {
	display: none;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form p {
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form__grid {
	grid-area: form;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.8rem;
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form__wide {
	grid-column: 1 / -1;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form .wpcf7-form-control-wrap {
	display: block;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form :where(input:not([type="submit"]), textarea, select) {
	box-sizing: border-box;
	width: 100%;
	min-height: 3.35rem;
	margin: 0;
	padding: 0.95rem 1rem;
	border: 1px solid rgb(247 241 231 / 0.1);
	border-radius: 0;
	background: rgb(247 241 231 / 0.08);
	color: #f7f1e7;
	color-scheme: dark;
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.82rem;
	line-height: 1.45;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form :where(input, textarea, select)::placeholder {
	color: rgb(247 241 231 / 0.45);
	opacity: 1;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form :where(input, textarea, select):focus {
	border-color: rgb(196 146 42 / 0.68);
	outline: 2px solid rgb(196 146 42 / 0.18);
	outline-offset: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form__actions,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp-row {
	margin-top: clamp(1.25rem, 2vw, 1.6rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form__actions {
	grid-area: submit;
	position: relative;
	width: max-content;
	padding-top: clamp(1.15rem, 2vw, 1.55rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp-row {
	grid-area: whatsapp;
	align-self: start;
	margin-top: 0;
	padding-top: clamp(1.15rem, 2vw, 1.55rem);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form__submit,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	box-sizing: border-box;
	min-height: 3rem;
	min-width: min(100%, 12.5rem);
	padding: 0.85rem 1.35rem;
	border-radius: 0;
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.62rem;
	font-weight: 400;
	letter-spacing: 0.24em;
	line-height: 1.15;
	text-transform: uppercase;
	text-decoration: none;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form__submit {
	border: 1px solid var(--vvm-villa-amenities-gold);
	background: var(--vvm-villa-amenities-gold);
	color: #173528;
	cursor: pointer;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp-row {
	display: flex;
	gap: 0.75rem;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp .wp-block-button__link {
	margin: 0;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp .wp-block-button__link.wp-element-button {
	border: 1px solid rgb(247 241 231 / 0.16);
	background: transparent !important;
	color: rgb(247 241 231 / 0.78) !important;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp .wp-block-button__link.wp-element-button::after {
	content: none;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp .wp-block-button__link.wp-element-button::before {
	content: "" !important;
	position: static !important;
	inset: auto !important;
	display: inline-block !important;
	flex: 0 0 auto;
	width: 1.125rem;
	height: 1.125rem;
	/* currentColor keeps the icon matched to the button text in every state. */
	background-color: currentColor;
	-webkit-mask: url("assets/icons/whatsapp.svg") center / contain no-repeat;
	mask: url("assets/icons/whatsapp.svg") center / contain no-repeat;
	opacity: 1 !important;
	transform: none !important;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form__submit:hover,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form__submit:focus-visible {
	background: #d5a23a;
	border-color: #d5a23a;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp .wp-block-button__link.wp-element-button:hover,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp .wp-block-button__link.wp-element-button:focus-visible {
	border-color: rgb(247 241 231 / 0.38);
	background: rgb(247 241 231 / 0.06) !important;
	color: #f7f1e7 !important;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form .wpcf7-spinner {
	position: absolute;
	top: calc(100% + 0.5rem);
	left: 50%;
	margin: 0;
	transform: translateX(-50%);
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form .wpcf7-not-valid-tip,
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form .wpcf7-response-output {
	color: rgb(247 241 231 / 0.72);
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.76rem;
	line-height: 1.45;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form .wpcf7-not-valid-tip {
	margin-top: 0.35rem;
}

:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form .wpcf7-response-output {
	grid-area: response;
	margin: 1rem 0 0;
	padding: 0.85rem 1rem;
	border-color: rgb(247 241 231 / 0.16);
}

/*
 * Contact Form 7 renders the response container before it has a message.
 * Hide that empty state so the styled response border does not appear as a
 * stray line under the form controls.
 */
:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form .wpcf7-response-output:empty {
	display: none;
}

@media (max-width: 1299px) {
	body.single-villa .wp-site-blocks .wp-block-post-content h2.wp-block-heading {
		font-size: 2rem;
		line-height: 1.22;
	}

	body.single-villa .wp-site-blocks .wp-block-post-content h3.wp-block-heading {
		font-size: 1.75rem;
		line-height: 1.22;
	}

	body.single-villa .wp-site-blocks .wp-block-post-content h5.wp-block-heading {
		font-size: 1.45rem;
		line-height: 1.18;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-staff.wp-block-columns {
		flex-direction: column !important;
		align-items: stretch !important;
		gap: var(--wp--preset--spacing--sm, 1rem);
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-staff.wp-block-columns > .wp-block-column {
		box-sizing: border-box;
		flex-basis: auto !important;
		width: 100%;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-staff h5.wp-block-heading {
		font-size: 1.35rem;
		line-height: 1.15;
	}
}

@media (max-width: 1180px) {
	.wp-site-blocks .vvm-bedroom-levels__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.wp-site-blocks .vvm-bedroom-levels__intro-card {
		grid-column: 1 / -1;
		min-height: auto;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities {
		grid-template-columns: minmax(0, 1fr);
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules .vvm-villa-amenities__card {
		max-width: none;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact {
		grid-template-columns: minmax(0, 1fr);
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing-contact {
		grid-template-columns: minmax(0, 1fr);
	}
}

@media (max-width: 700px) {
	.wp-site-blocks .vvm-bedroom-levels {
		margin-block-start: 2rem;
		padding-block: 1.25rem;
	}

	.wp-site-blocks .vvm-bedroom-levels__nav {
		flex-wrap: nowrap;
		overflow-x: auto;
		scrollbar-width: none;
	}

	.wp-site-blocks .vvm-bedroom-levels__nav::-webkit-scrollbar {
		display: none;
	}

	.wp-site-blocks .vvm-bedroom-levels__nav .wp-block-button__link {
		min-height: 2.75rem;
		padding-inline: 0.9rem;
		font-size: 0.64rem;
	}

	.wp-site-blocks .vvm-bedroom-levels__grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.wp-site-blocks .vvm-bedroom-levels__card {
		min-height: auto;
		padding: 1.35rem;
	}

	.wp-site-blocks .vvm-bedroom-levels__room-card .vvm-bedroom-levels__eyebrow,
	.wp-site-blocks .vvm-bedroom-levels__room-card .vvm-bedroom-levels__title {
		max-width: none;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__card {
		padding: 1.25rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-rules > .wp-block-group {
		grid-template-columns: minmax(0, 1fr);
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__header {
		grid-template-columns: minmax(0, 1fr);
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__chips {
		grid-template-columns: minmax(0, 1fr);
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities__row {
		grid-template-columns: 2.7rem minmax(0, 1fr);
		gap: 0.8rem;
		padding-block: 0.9rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities:not(.vvm-villa-contact):not(.vvm-villa-pricing):not(.vvm-villa-reviews):not(.vvm-villa-rules):not(.vvm-villa-amenities--show-numbers) .vvm-villa-amenities__index,
	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities--show-numbers .vvm-villa-amenities__index {
		width: 2.45rem;
		height: 2.45rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-amenities--show-numbers .vvm-villa-amenities__index {
		width: 2rem;
		height: 2rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-reviews .vvm-villa-amenities__card {
		padding: 1.5rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__card {
		padding: 1.5rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__header {
		grid-template-columns: minmax(0, 1fr);
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__helper {
		justify-self: start;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__table th,
	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__table td {
		padding: 0.85rem 1rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-pricing__terms {
		padding: 1.25rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__location-card {
		grid-template-rows: minmax(16rem, auto) auto;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot {
		min-height: 16rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot:has(> .vvm-villa-amenities__eyebrow) {
		grid-template-rows: minmax(16rem, auto) auto auto;
		height: auto;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__media-slot:has(> .vvm-villa-amenities__eyebrow) > :first-child {
		height: 16rem;
		min-height: 16rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__form-card {
		grid-template-columns: minmax(0, 1fr);
		grid-template-areas:
			"intro"
			"form"
			"submit"
			"whatsapp"
			"response";
		padding: 1.5rem;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__intro .wp-block-heading {
		max-width: none;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form__grid {
		grid-template-columns: minmax(0, 1fr);
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact-form__submit,
	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp .wp-block-button__link {
		width: 100%;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp-row,
	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp {
		width: 100%;
	}

	:where(.wp-site-blocks, .editor-styles-wrapper) .vvm-villa-contact__whatsapp-row {
		margin-top: 0.75rem;
	}
}

/*
 * The package archive uses split-content as a promotional band. The generic
 * block defaults are intentionally roomy, but this archive needs a tighter
 * Lake Austin-style overlap where the media only peeks above/below the card.
 */
body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-split-content.split-content--layout-overlap,
.vvm-packages-archive-promo.wp-block-gutenberg-lab-blocks-split-content.split-content--layout-overlap {
		max-inline-size: min(100%, var(--wp--style--global--content-size, 1320px));
		margin-inline: auto;
		/*
		 * The overlap card pulls visual weight back into the media column, so the
		 * whole promo band needs a slight rightward nudge to feel centered.
		 */
		--vvm-packages-archive-promo-visual-offset: clamp(1rem, 2vw, 1.75rem);
		--split-content-overlap-card-max-width: clamp(24rem, 29vw, 28rem);
		--split-content-overlap-card-padding-block: clamp(1.75rem, 3vw, 2.75rem);
		--split-content-overlap-card-padding-inline: clamp(1.25rem, 2.4vw, 2rem);
		--split-content-overlap-card-shift: clamp(0.5rem, 1vw, 1rem);
		--split-content-overlap-media-aspect-ratio: 30 / 31;
		--split-content-media-min-height: clamp(22rem, 28vw, 32rem);
		margin-top: var(--wp--preset--spacing--section-md);
		margin-bottom: var(--wp--preset--spacing--section-md);
		transform: translateX(var(--vvm-packages-archive-promo-visual-offset));
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-split-content.split-content--layout-overlap
	.split-content__grid,
.vvm-packages-archive-promo.wp-block-gutenberg-lab-blocks-split-content.split-content--layout-overlap
	.split-content__grid {
	grid-template-columns: minmax(0, 11fr) minmax(0, 9fr);
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-split-content.split-content--layout-overlap
	.split-content__content-flow,
	.vvm-packages-archive-promo.wp-block-gutenberg-lab-blocks-split-content.split-content--layout-overlap
		.split-content__content-flow {
		gap: clamp(0.75rem, 1.2vw, 1rem);
}

@media (max-width: 1023px) {
	body.post-type-archive-packages
		.wp-block-gutenberg-lab-blocks-split-content.split-content--layout-overlap,
	.vvm-packages-archive-promo.wp-block-gutenberg-lab-blocks-split-content.split-content--layout-overlap {
			transform: none;
	}
}

body.post-type-archive-packages .wp-block-gutenberg-lab-blocks-packages-display,
.vvm-packages-archive-list.wp-block-gutenberg-lab-blocks-packages-display {
	max-inline-size: min(100%, var(--wp--style--global--content-size, 1320px));
	margin-inline: auto;
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-packages-display__header,
.vvm-packages-archive-list.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-packages-display__header {
		justify-items: center;
		margin-inline: auto;
		text-align: center;
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-packages-display__intro,
.vvm-packages-archive-list.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-packages-display__intro {
		max-width: 40rem;
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-card__body,
.vvm-packages-archive-list.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-card__body {
		gap: 0.75rem;
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card {
		display: grid;
		gap: 0.65rem;
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__price-wrap,
.vvm-packages-archive-list.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__price-wrap {
		display: grid;
		gap: 0.15rem;
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__price,
.vvm-packages-archive-list.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__price {
		font-size: 1rem;
		font-weight: 700;
	}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__actions,
.vvm-packages-archive-list.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__actions {
		margin-top: 0.35rem;
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__actions,
.vvm-packages-archive-list.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__actions {
		display: block !important;
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__actions
	.wp-block-button,
.vvm-packages-archive-list.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__actions
	.wp-block-button {
		display: block !important;
		margin: 0 !important;
		width: max-content;
}

body.post-type-archive-packages
	.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__actions
	.wp-block-button
	+ .wp-block-button,
.vvm-packages-archive-list.wp-block-gutenberg-lab-blocks-packages-display
	.vvm-package-meta--card
	.vvm-package-meta__actions
	.wp-block-button
	+ .wp-block-button {
		margin-top: 0.5rem !important;
}

.vvm-header {
	/*
	 * Header chrome is color-token driven so the same markup can switch between
	 * transparent-on-hero and solid-on-scroll without duplicating selectors.
	 */
	--vvm-header-bg: var(--wp--preset--color--dark-green, #1e3d2f);
	--vvm-header-fg: var(--wp--preset--color--light-gold, #f5ecd7);
	--vvm-header-hover: var(--wp--preset--color--gold, #c4922a);
	--vvm-header-shadow: none;
	--vvm-header-logo-width: 150px;
	position: relative;
	z-index: 40;
	background-color: var(--vvm-header-bg);
	backdrop-filter: none;
	box-shadow: var(--vvm-header-shadow);
	transition:
		background-color 0.42s ease,
		backdrop-filter 0.42s ease,
		box-shadow 0.42s ease,
		color 0.3s ease,
		transform 0.42s ease;
}

/*
 * WordPress exposes the live admin-bar height as a CSS custom property when a
 * user is logged in. Reusing that value keeps the overlay and fixed header
 * states visible instead of tucking the top edge behind the toolbar.
 */
body {
	--vvm-admin-bar-offset: 0px;
}

body.admin-bar {
	--vvm-admin-bar-offset: var(--wp-admin--admin-bar--height, 32px);
}

.vvm-header__inner {
	max-width: none !important;
}

.vvm-header__inner > .vvm-header__bar {
	width: 100%;
	max-width: none !important;
}

.vvm-header__bar {
	min-height: var(--vvm-header-height, 96px);
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
	align-items: center;
	column-gap: clamp(1rem, 2vw, 2.5rem);
}

.vvm-header__utility {
	display: flex;
	align-items: center;
	gap: clamp(0.85rem, 1.6vw, 1.4rem);
	min-width: 0;
}

.vvm-header__utility--left {
	grid-column: 1;
	justify-self: start;
}

.vvm-header__utility--right {
	grid-column: 3;
	justify-self: end;
}

.vvm-header__brand {
	grid-column: 2;
	display: grid;
	justify-self: center;
	justify-items: center;
}

.vvm-header:not(.is-scrolled) .wp-block-site-logo {
	margin: 15px 0 0;
}

.vvm-header .custom-logo-link,
.vvm-header .wp-block-site-logo a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

.vvm-header .wp-block-site-logo img {
	width: min(var(--vvm-header-logo-width), 100%) !important;
	height: auto !important;
	max-width: 100%;
	max-height: none;
	object-fit: contain;
	transition:
		width 0.42s ease,
		opacity 0.3s ease,
		transform 0.42s ease;
}

.vvm-header__nav {
	margin: 0;
	color: var(--vvm-header-fg);
}

.vvm-header__nav .wp-block-navigation__responsive-container-open,
.vvm-header__nav .wp-block-navigation__responsive-container-close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	color: var(--vvm-header-fg);
	box-shadow: none;
	transition:
		color 0.2s ease,
		opacity 0.2s ease;
}

.vvm-header__nav .wp-block-navigation__responsive-container-open:hover,
.vvm-header__nav .wp-block-navigation__responsive-container-open:focus-visible,
.vvm-header__nav .wp-block-navigation__responsive-container-close:hover,
.vvm-header__nav .wp-block-navigation__responsive-container-close:focus-visible {
	color: var(--vvm-header-hover);
}

.vvm-header__contact {
	margin: 0;
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.95rem;
	font-weight: 300;
	letter-spacing: 0.16em;
	line-height: 1;
	text-transform: uppercase;
}

.vvm-header__contact a {
	color: var(--vvm-header-fg);
	text-decoration: none;
	transition:
		color 0.2s ease,
		opacity 0.2s ease;
}

.vvm-header__contact a:hover,
.vvm-header__contact a:focus-visible {
	color: var(--vvm-header-hover);
}

.vvm-header__social {
	gap: clamp(0.5rem, 1vw, 0.85rem);
	margin: 0;
}

.vvm-header__social.wp-block-social-links .wp-social-link {
	margin: 0;
	color: var(--vvm-header-fg);
	background: transparent;
	transform: none;
	transition:
		color 0.2s ease,
		opacity 0.2s ease;
}

.vvm-header__social.wp-block-social-links .wp-social-link a {
	padding: 0;
	color: inherit;
}

.vvm-header__social.wp-block-social-links .wp-social-link svg {
	width: 1.05rem;
	height: 1.05rem;
}

.vvm-header__social.wp-block-social-links .wp-social-link:hover,
.vvm-header__social.wp-block-social-links .wp-social-link:focus-within {
	color: var(--vvm-header-hover);
}

/* Shared button variants live in `assets/css/buttons.css`. */

body.vvm-has-hero-header .vvm-header {
	--vvm-header-bg: transparent;
	--vvm-header-fg: var(--wp--preset--color--light-gold, #f5ecd7);
	--vvm-header-hover: var(--wp--preset--color--gold, #c4922a);
	--vvm-header-shadow: none;
	position: fixed;
	top: var(--vvm-admin-bar-offset);
	left: 0;
	right: 0;
	inset-inline: 0;
	background-color: var(--vvm-header-bg);
	backdrop-filter: none;
	box-shadow: var(--vvm-header-shadow);
}

.vvm-header.is-scrolled {
	--vvm-header-bg: var(--wp--preset--color--dark-green, #1e3d2f);
	--vvm-header-fg: var(--wp--preset--color--light-gold, #f5ecd7);
	--vvm-header-hover: var(--wp--preset--color--gold, #c4922a);
	--vvm-header-shadow: 0 14px 40px rgba(13, 28, 22, 0.22);
	--vvm-header-logo-width: 110px;
	position: fixed;
	top: var(--vvm-admin-bar-offset);
	left: 0;
	right: 0;
	inset-inline: 0;
	background-color: var(--vvm-header-bg);
	backdrop-filter: none;
	box-shadow: var(--vvm-header-shadow);
}

body.vvm-has-hero-header .vvm-header.is-scrolled {
	--vvm-header-bg: var(--wp--preset--color--dark-green, #1e3d2f);
	--vvm-header-fg: var(--wp--preset--color--light-gold, #f5ecd7);
	--vvm-header-hover: var(--wp--preset--color--gold, #c4922a);
	--vvm-header-shadow: 0 14px 40px rgba(13, 28, 22, 0.22);
	--vvm-header-logo-width: 110px;
	position: fixed;
	background-color: var(--vvm-header-bg);
	backdrop-filter: none;
	box-shadow: var(--vvm-header-shadow);
}

.vvm-header .wp-block-navigation__responsive-container {
	padding: 0;
	position: fixed;
	inset: 0;
	z-index: 45;
	display: block !important;
	background: transparent !important;
	background-color: transparent !important;
	color: var(--wp--preset--color--dark-green, #1e3d2f) !important;
	backdrop-filter: none;
	visibility: hidden;
	pointer-events: none;
	transition: visibility 0s linear 0.34s;
}

.vvm-header .wp-block-navigation__responsive-container.has-modal-open,
.vvm-header .wp-block-navigation__responsive-container.is-menu-open {
	visibility: visible;
	pointer-events: auto;
	transition-delay: 0s;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__container,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item__content,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-submenu__toggle,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__submenu-container {
	color: var(--wp--preset--color--dark-green, #1e3d2f);
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__container {
	display: block !important;
	width: 100% !important;
	box-sizing: border-box;
	gap: 0 !important;
	row-gap: 0 !important;
	margin: 0;
	padding: 0;
	justify-content: flex-start;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__responsive-close {
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__responsive-dialog {
	/* Keep the drawer header compact while leaving room for the icon-only close control. */
	--vvm-drawer-control-size: 2.25rem;
	--vvm-drawer-header-height: 4rem;
	--vvm-drawer-header-bg: #8fa68e;
	position: fixed;
	top: 0 !important;
	left: 0;
	width: min(21rem, calc(100vw - 3.5rem));
	height: calc(100dvh - var(--vvm-admin-bar-offset)) !important;
	max-width: none;
	margin: 0;
	background: #fff;
	border-right: 4px solid rgba(30, 61, 47, 0.18);
	box-shadow: 22px 0 44px rgba(13, 28, 22, 0.18);
	overflow: hidden;
	transform: translateX(calc(-100% - 1rem));
	opacity: 0;
	transition:
		transform 0.34s cubic-bezier(0.22, 1, 0.36, 1),
		opacity 0.24s ease;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__responsive-dialog::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1;
	height: var(--vvm-drawer-header-height);
	background: var(--vvm-drawer-header-bg);
	border-bottom: 1px solid rgba(30, 61, 47, 0.14);
	pointer-events: none;
}

.vvm-header .wp-block-navigation__responsive-container.has-modal-open .wp-block-navigation__responsive-dialog,
.vvm-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-dialog {
	transform: translateX(0);
	opacity: 1;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item__content,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-submenu__toggle {
	font-size: 0.88rem;
	font-weight: 300;
	letter-spacing: 1px;
	text-transform: uppercase;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__responsive-container-content {
	box-sizing: border-box;
	height: 100%;
	overflow-y: auto;
	padding: var(--vvm-drawer-header-height) 0 0;
}

.vvm-header .wp-block-navigation__responsive-container.is-menu-open:not(.disable-default-overlay) .wp-block-navigation__responsive-container-content,
.vvm-header .wp-block-navigation__responsive-container.has-modal-open:not(.disable-default-overlay) .wp-block-navigation__responsive-container-content {
	/* Core Navigation applies its own open-menu padding; this keeps links below the custom close bar. */
	padding: var(--vvm-drawer-header-height) 0 0 !important;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__responsive-container-close {
	position: absolute;
	top: calc((var(--vvm-drawer-header-height) - var(--vvm-drawer-control-size)) / 2);
	right: var(--wp--custom--layout--gutter-current, 20px);
	left: auto;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	width: var(--vvm-drawer-control-size);
	min-width: 0;
	height: var(--vvm-drawer-control-size);
	padding: 0;
	border: 0;
	border-radius: 999px;
	background: transparent;
	color: var(--wp--preset--color--dark-green, #1e3d2f);
	font-family: var(--wp--preset--font-family--refined-sans);
	font-size: 0.68rem;
	font-weight: 300;
	letter-spacing: 0.2em;
	line-height: 1;
	text-transform: uppercase;
	white-space: nowrap;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__responsive-container-close svg {
	flex: 0 0 auto;
	margin: calc((var(--vvm-drawer-control-size) - 24px) / 2);
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__responsive-container-close::after {
	content: none;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__responsive-container-close:focus-visible {
	outline: 2px solid rgba(30, 61, 47, 0.55);
	outline-offset: 3px;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item {
	display: block;
	width: 100% !important;
	box-sizing: border-box;
	margin: 0;
	border-bottom: 1px solid rgba(30, 61, 47, 0.12);
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item > .wp-block-navigation-item__content,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item > .wp-block-navigation-submenu__toggle {
	min-height: 0;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item > .wp-block-navigation-item__content,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item > .wp-block-navigation-submenu__toggle {
	display: flex;
	align-items: center;
	width: 100% !important;
	box-sizing: border-box;
	padding: 0.875rem 2.25rem;
	background: transparent;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item.vvm-header-nav__child > .wp-block-navigation-item__content {
	padding-left: 3.15rem;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item__content:hover,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item__content:focus-visible,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-submenu__toggle:hover,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-submenu__toggle:focus-visible {
	color: var(--wp--preset--color--light-gold, #f5ecd7);
	background: rgba(30, 61, 47, 0.62);
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item__content:focus-visible,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-submenu__toggle:focus-visible {
	outline: 2px solid rgba(245, 236, 215, 0.95);
	outline-offset: -2px;
}

.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item.current-menu-item > .wp-block-navigation-item__content,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item.current-menu-ancestor > .wp-block-navigation-item__content,
.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation-item.current-page-parent > .wp-block-navigation-item__content {
	background: rgba(94, 153, 120, 0.82);
	color: var(--wp--preset--color--light-gold, #f5ecd7);
}

@media (prefers-reduced-motion: reduce) {
	.vvm-header,
	.vvm-header .wp-block-site-logo img,
	.vvm-header .wp-block-navigation__responsive-container,
	.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__responsive-dialog {
		transition: none !important;
	}
}

.vvm-atmosphere-edge {
	position: relative;
	overflow: hidden;
	--vvm-atmosphere-edge-height: clamp(8rem, 20vw, 15rem);
	--vvm-atmosphere-edge-white-solid: rgba(255, 255, 255, 1);
	--vvm-atmosphere-edge-white-soft: rgba(255, 255, 255, 0.88);
	--vvm-atmosphere-edge-white-mid: rgba(255, 255, 255, 0.56);
	--vvm-atmosphere-edge-white-light: rgba(255, 255, 255, 0.22);
	--vvm-atmosphere-edge-clear: rgba(255, 255, 255, 0);
	--vvm-atmosphere-edge-green-solid: rgba(15, 31, 24, 1);
	--vvm-atmosphere-edge-green-strong: rgba(15, 31, 24, 0.94);
	--vvm-atmosphere-edge-green-mid: rgba(30, 61, 47, 0.62);
	--vvm-atmosphere-edge-green-soft: rgba(30, 61, 47, 0.28);
	--vvm-atmosphere-edge-green-light: rgba(30, 61, 47, 0.08);
	--vvm-atmosphere-edge-green-clear: rgba(30, 61, 47, 0);
}

.vvm-atmosphere-edge::after {
	content: "";
	position: absolute;
	right: 0;
	left: 0;
	z-index: 2;
	pointer-events: none;
}

.vvm-atmosphere-edge--top::after,
.vvm-atmosphere-edge--fog-top::after {
	top: 0;
	bottom: auto;
	height: var(--vvm-atmosphere-edge-height);
	background: linear-gradient(
		180deg,
		var(--vvm-atmosphere-edge-white-solid) 0%,
		var(--vvm-atmosphere-edge-white-solid) 18%,
		var(--vvm-atmosphere-edge-white-soft) 34%,
		var(--vvm-atmosphere-edge-white-mid) 58%,
		var(--vvm-atmosphere-edge-white-light) 80%,
		var(--vvm-atmosphere-edge-clear) 100%
	);
}

.vvm-atmosphere-edge--bottom::after,
.vvm-atmosphere-edge--fog-bottom::after {
	top: auto;
	bottom: 0;
	height: var(--vvm-atmosphere-edge-height);
	background: linear-gradient(
		0deg,
		var(--vvm-atmosphere-edge-green-solid) 0%,
		var(--vvm-atmosphere-edge-green-strong) 18%,
		var(--vvm-atmosphere-edge-green-mid) 48%,
		var(--vvm-atmosphere-edge-green-soft) 72%,
		var(--vvm-atmosphere-edge-green-light) 88%,
		var(--vvm-atmosphere-edge-green-clear) 100%
	);
}

.wp-block-gutenberg-lab-blocks-media-panel.vvm-atmosphere-edge .media-panel__overlay {
	position: absolute;
	inset: 0;
	z-index: 3;
}

.wp-block-gutenberg-lab-blocks-media-panel.media-panel--dark-overlay.media-panel--overlay-style-brand-green.vvm-atmosphere-edge--fog-bottom::after {
	/* When the media panel already has the brand overlay enabled, a second
	   bottom pseudo-element creates a visible handoff line. Let the main
	   overlay own the full transition into the footer color instead. */
	content: none;
}

.wp-block-gutenberg-lab-blocks-media-panel.media-panel--dark-overlay.media-panel--overlay-style-brand-green.vvm-atmosphere-edge--fog-bottom .media-panel__overlay::before {
	background: linear-gradient(
		180deg,
		rgba(30, 61, 47, 0.85) 0%,
		rgba(30, 61, 47, 0.8) 40%,
		rgba(30, 61, 47, 0.74) 68%,
		rgba(15, 31, 24, 0.9) 88%,
		#0b1712 100%
	) !important;
}

.vvm-footer {
	--vvm-footer-bg: #0b1712;
	--vvm-footer-text: var(--wp--preset--color--light-gold, #f5ecd7);
	--vvm-footer-accent: var(--wp--preset--color--gold, #c4922a);
	position: relative;
	color: var(--vvm-footer-text);
	background: var(--vvm-footer-bg) !important;
}

.vvm-footer::before {
	display: none;
}

.vvm-footer::after {
	display: none;
}

.vvm-footer__inner {
	position: relative;
	margin: 0 auto;
}

.vvm-footer__columns {
	display: grid;
	grid-template-columns: minmax(0, 1.55fr) repeat(2, minmax(0, 1fr)) minmax(0, 1.1fr);
	gap: 80px;
	align-items: start;
	margin-bottom: 0;
}

.vvm-footer__columns > .wp-block-column {
	margin: 0 !important;
}

.vvm-footer__column {
	min-width: 0;
	color: var(--vvm-footer-text);
}

.vvm-footer__column--brand {
	max-width: 22rem;
}

.vvm-footer__column--contact {
	max-width: 18rem;
}

.vvm-footer__logo {
	margin-bottom: 1.5rem;
}

.vvm-footer__logo .custom-logo-link,
.vvm-footer__logo img {
	display: block;
}

.vvm-footer__logo img {
	width: min(100%, 18.75rem) !important;
	height: auto;
}

.vvm-footer__tagline {
	margin-top: 0;
	margin-bottom: 0;
	max-width: 18rem;
	font-size: 1rem;
	line-height: 1.6;
	opacity: 0.8;
	color: var(--vvm-footer-text);
}

.vvm-footer__eyebrow {
	margin: 0 0 1rem;
	font-family: inherit;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0.14em;
	line-height: 1.4;
	text-transform: uppercase;
	color: var(--vvm-footer-accent);
}

.vvm-footer__nav,
.vvm-footer__legal-nav {
	margin: 0;
}

.vvm-footer__nav .wp-block-navigation__container,
.vvm-footer__legal-nav .wp-block-navigation__container {
	row-gap: 0.75rem;
	column-gap: 0.75rem;
	align-items: flex-start;
}

.vvm-footer__nav .wp-block-navigation-item,
.vvm-footer__legal-nav .wp-block-navigation-item {
	margin: 0;
}

.vvm-footer__nav .wp-block-navigation-item__content,
.vvm-footer__legal-nav .wp-block-navigation-item__content {
	display: inline-block;
	padding: 0;
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.5;
	text-transform: none;
	color: var(--vvm-footer-text);
	text-decoration: none;
	font-family: "Liberation Serif", Georgia, serif;
	transition:
		color 0.3s ease,
		transform 0.3s ease,
		opacity 0.3s ease;
	transform-origin: left center;
}

.vvm-footer__nav .wp-block-navigation-item__label,
.vvm-footer__legal-nav .wp-block-navigation-item__label {
	font-family: "Liberation Serif", Georgia, serif;
}

.vvm-footer__nav .wp-block-navigation-item__content:hover,
.vvm-footer__nav .wp-block-navigation-item__content:focus-visible,
.vvm-footer__legal-nav .wp-block-navigation-item__content:hover,
.vvm-footer__legal-nav .wp-block-navigation-item__content:focus-visible {
	color: var(--vvm-footer-accent);
	transform: translateX(0.35rem);
}

.vvm-footer__nav .current-menu-item > .wp-block-navigation-item__content,
.vvm-footer__nav .current-menu-ancestor > .wp-block-navigation-item__content,
.vvm-footer__nav .wp-block-navigation-item__content[aria-current="page"] {
	color: var(--vvm-footer-accent);
	transform: translateX(0.35rem);
}

.vvm-footer__contact-list {
	margin: 0;
}

.vvm-footer__contact-item {
	display: flex;
	align-items: flex-start;
	gap: 0.875rem;
	margin: 0;
	font-size: 1rem;
	line-height: 1.65;
	letter-spacing: 0;
	color: var(--vvm-footer-text);
	font-family: "Liberation Serif", Georgia, serif;
}

.vvm-footer__contact-item + .vvm-footer__contact-item {
	margin-top: 1rem;
}

.vvm-footer__contact-icon {
	flex: 0 0 1.125rem;
	width: 1.125rem;
	height: 1.125rem;
	margin-top: 0.15rem;
	color: var(--vvm-footer-accent);
}

.vvm-footer__contact-icon svg {
	display: block;
	width: 100%;
	height: 100%;
}

.vvm-footer__contact-item a,
.vvm-footer__contact-item span:last-child {
	color: var(--vvm-footer-text);
	text-decoration: none;
	font-family: "Liberation Serif", Georgia, serif;
	transition: color 0.3s ease;
}

.vvm-footer__contact-item a:hover,
.vvm-footer__contact-item a:focus-visible {
	color: var(--vvm-footer-accent);
}

.vvm-footer__divider {
	margin-top: 40px;
	margin-bottom: 20px;
	border: 0;
	height: 1px;
	background: rgb(196 146 42 / 0.3);
	color: transparent;
	opacity: 1;
}

.vvm-footer__bottom {
	width: 100%;
	justify-content: space-between;
	align-items: center;
	gap: 0.625rem 1.25rem;
	padding-bottom: 30px;
	text-align: left;
}

.vvm-footer__copyright {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.5;
	opacity: 0.7;
	color: var(--vvm-footer-text);
}

.vvm-footer__legal-nav .wp-block-navigation__container {
	justify-content: flex-end;
	row-gap: 0.5rem;
	column-gap: 2rem;
}

.vvm-footer__legal-nav .wp-block-navigation-item__content {
	font-size: 0.875rem;
	opacity: 0.7;
	transform-origin: center;
}

.vvm-footer__legal-nav .wp-block-navigation-item__content:hover,
.vvm-footer__legal-nav .wp-block-navigation-item__content:focus-visible {
	color: var(--vvm-footer-accent);
	transform: none;
}

.js .vvm-footer .vvm-footer__motion-item {
	opacity: 0;
	transform: translate3d(0, 40px, 0);
	transition:
		opacity 0.8s ease-out,
		transform 0.8s ease-out;
}

.js .vvm-footer.is-visible .vvm-footer__motion-item {
	opacity: 1;
	transform: translate3d(0, 0, 0);
}

.js .vvm-footer .vvm-footer__motion-item--1 {
	transition-delay: 0s;
}

.js .vvm-footer .vvm-footer__motion-item--2 {
	transition-delay: 0.1s;
}

.js .vvm-footer .vvm-footer__motion-item--3 {
	transition-delay: 0.2s;
}

.js .vvm-footer .vvm-footer__motion-item--4 {
	transition-delay: 0.3s;
}

.js .vvm-footer .vvm-footer__motion-item--5 {
	transition-delay: 0.4s;
}

@media (min-width: 782px) {
	.vvm-header__utility--right {
		display: flex;
	}
}

@media (max-width: 1023px) {
	.vvm-footer__columns {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 40px;
	}
}

@media (max-width: 781px) {
	.vvm-header__bar {
		grid-template-columns: 40px minmax(0, 1fr) 40px;
		min-height: var(--vvm-header-height, 96px);
		column-gap: 0.75rem;
	}

	.vvm-header__utility {
		gap: 0;
	}

	.vvm-header__brand {
		grid-column: 2;
		justify-self: center;
	}

	.vvm-header__contact,
	.vvm-header__utility--right {
		display: none !important;
	}

	.vvm-header .wp-block-site-logo img {
		width: min(var(--vvm-header-logo-width), 100%) !important;
	}

	.vvm-header {
		--vvm-header-logo-width: 176px;
	}

	.vvm-header.is-scrolled,
	body.vvm-has-hero-header .vvm-header.is-scrolled {
		--vvm-header-logo-width: 88px;
	}

	.vvm-header__nav .wp-block-navigation__responsive-container-open {
		padding: 0;
		width: 34px;
		height: 34px;
	}

	.vvm-header .wp-block-navigation__responsive-container .wp-block-navigation__responsive-dialog {
		--vvm-drawer-control-size: 34px;
	}

	.vvm-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-dialog {
		max-width: 100%;
	}

	.vvm-footer {
		padding-top: 64px !important;
		padding-bottom: 48px !important;
	}

	.vvm-footer__columns {
		grid-template-columns: minmax(0, 1fr);
		gap: 32px;
	}

	.vvm-footer__column--brand,
	.vvm-footer__column--contact,
	.vvm-footer__tagline {
		max-width: none;
	}

	.vvm-footer__divider {
		margin-top: 48px;
		margin-bottom: 40px;
	}

	.vvm-footer__bottom {
		flex-direction: column;
		justify-content: center;
		gap: 0.5rem;
		padding-top: 0;
		padding-bottom: 0;
		text-align: center;
	}

	.vvm-footer__legal-nav .wp-block-navigation__container {
		justify-content: center;
		column-gap: 1.25rem;
	}
}

@media (min-width: 782px) {
	.vvm-footer__bottom {
		flex-direction: row;
	}
}

@media (min-width: 1024px) {
	.vvm-footer__eyebrow {
		font-size: 16px;
	}

	.vvm-footer__nav .wp-block-navigation-item__label,
	.vvm-footer__legal-nav .wp-block-navigation-item__label {
		font-size: 14px;
	}
}

.wp-block-separator.vvm-tapered-divider {
	height: 2px;
	border: 0 !important;
	background: radial-gradient(
		ellipse at center,
		rgba(196, 146, 42, 0.46) 0%,
		rgba(216, 200, 170, 0.34) 34%,
		rgba(216, 200, 170, 0.14) 58%,
		rgba(216, 200, 170, 0) 100%
	);
	opacity: 1;
}

.wp-block-separator.vvm-short-gold-divider {
	width: 88px;
	max-width: 88px;
	height: 1px;
	margin-left: 0 !important;
	margin-right: auto !important;
	border: 0 !important;
	background: var(--wp--preset--color--gold, #c4922a) !important;
	opacity: 1;
}

.wp-block-cover.vvm-viewport-bound-cover {
	--vvm-cover-viewport-max: calc(
		100vh - var(--vvm-header-height, 96px)
	);

	min-height: min(616px, var(--vvm-cover-viewport-max)) !important;
	max-height: var(--vvm-cover-viewport-max);
	overflow: hidden;
}

@supports (height: 100svh) {
	.wp-block-cover.vvm-viewport-bound-cover {
		--vvm-cover-viewport-max: calc(
			100svh - var(--vvm-header-height, 96px)
		);
	}
}
