/**
 * Palette updated from client-provided neutral swatch image
 * (off-white, warm beige, muted taupe, dusty rose-brown, deep cocoa).
 */
:root {
	--cream: #f8f4f1;
	--cream-deep: #e1d7cf;
	--white: #fffdfb;
	--olive: #8f7567;
	--olive-mid: #9f8476;
	--charcoal: #5f3922;
	--charcoal-warm: #724736;
	--raspberry: #a48272;
	--raspberry-logo: #8f6f61;
	--mist: #cabbb0;

	--bg: var(--cream);
	--surface: var(--white);
	--surface-soft: var(--cream-deep);
	--text: var(--charcoal);
	--muted: color-mix(in srgb, var(--olive-mid) 72%, var(--charcoal));
	--line: color-mix(in srgb, var(--mist) 65%, var(--olive) 35%);
	--primary: var(--olive);
	--primary-dark: var(--charcoal-warm);
	--accent: var(--raspberry);
	--accent-hover: var(--raspberry-logo);
	--radius: 14px;
	--max-width: 1120px;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

body {
	margin: 0;
	font-family: "Montserrat", "Segoe UI", Roboto, Arial, sans-serif;
	background: var(--bg);
	color: var(--text);
	line-height: 1.65;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: "EB Garamond", Garamond, "Times New Roman", serif;
	font-weight: 600;
	letter-spacing: 0.01em;
}

a {
	color: inherit;
}

.wrap {
	width: min(var(--max-width), calc(100% - 2.2rem));
	margin-inline: auto;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 30;
	background: color-mix(in srgb, var(--cream) 88%, var(--white));
	backdrop-filter: blur(6px);
	border-bottom: 1px solid var(--line);
}

.header-inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 1.2rem;
	padding: 0.42rem 0;
}

.brand {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	line-height: 0;
}

.brand-logo {
	display: flex;
	align-items: center;
}

.brand-logo .custom-logo-link {
	display: flex;
	align-items: center;
	line-height: 0;
}

.brand-logo .custom-logo-link img {
	display: block;
	width: 250px;
	max-width: 250px;
	height: auto;
	object-fit: contain;
	object-position: left center;
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

.brand-name {
	font-size: 1.05rem;
	font-weight: 700;
	text-decoration: none;
	letter-spacing: 0.01em;
	color: var(--charcoal);
}

.menu {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-nav {
	justify-self: center;
}

.site-nav .menu a {
	text-decoration: none;
	color: var(--olive-mid);
	font-weight: 500;
}

.site-nav .menu a:hover,
.site-nav .menu a:focus-visible {
	color: var(--charcoal);
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.section {
	padding: clamp(3rem, 7vw, 5.6rem) 0;
}

.section-soft {
	background: var(--surface-soft);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}

.hero.hero-banner {
	position: relative;
	overflow: hidden;
	padding: 0;
	min-height: clamp(460px, 74vh, 700px);
	display: flex;
	align-items: center;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	background-color: var(--charcoal-warm);
	background-image: var(--hero-banner-image);
	background-size: cover;
	background-position: 68% 38%;
	background-repeat: no-repeat;
	background-attachment: fixed;
}

.hero-banner-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		100deg,
		color-mix(in srgb, var(--charcoal-warm) 85%, transparent) 0%,
		color-mix(in srgb, var(--charcoal-warm) 58%, transparent) 42%,
		color-mix(in srgb, var(--charcoal-warm) 24%, transparent) 100%
	);
}

.hero-banner-inner {
	position: relative;
	z-index: 1;
	width: 100%;
	padding: clamp(4.2rem, 10vw, 7rem) 0;
}

.hero.hero-banner .hero-copy {
	max-width: min(640px, 92vw);
	padding-left: clamp(0.35rem, 2.4vw, 2rem);
}

.hero.hero-banner .eyebrow {
	color: color-mix(in srgb, var(--cream) 90%, var(--mist));
}

.hero.hero-banner h1 {
	color: var(--cream);
	max-width: 18ch;
}

.hero.hero-banner .lead {
	color: color-mix(in srgb, var(--cream) 88%, var(--mist));
	max-width: 54ch;
}

.hero.hero-banner .button-secondary {
	color: var(--cream);
	border-color: color-mix(in srgb, var(--cream) 70%, transparent);
	background: color-mix(in srgb, var(--charcoal-warm) 18%, transparent);
}

.hero.hero-banner .button-secondary:hover,
.hero.hero-banner .button-secondary:focus-visible {
	color: var(--cream);
	border-color: var(--cream);
	background: color-mix(in srgb, var(--charcoal-warm) 30%, transparent);
}

.hero-grid {
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: clamp(1.5rem, 4vw, 2.75rem);
	align-items: stretch;
}

.hero-copy {
	align-self: center;
}

.hero-aside {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	min-width: 0;
}

.hero-photo {
	margin: 0;
	border-radius: var(--radius);
	overflow: hidden;
	border: 1px solid var(--line);
	aspect-ratio: 4 / 5;
	max-height: min(420px, 52vh);
	box-shadow: 0 18px 40px color-mix(in srgb, var(--charcoal) 12%, transparent);
}

.hero-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.section-intro {
	max-width: 62ch;
	color: var(--muted);
	margin: 0 0 1.5rem;
	font-size: 1.05rem;
}

.section-split {
	background: var(--surface);
}

.section-split-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: center;
}

.section-split-photo {
	margin: 0;
	border-radius: var(--radius);
	overflow: hidden;
	border: 1px solid var(--line);
	aspect-ratio: 4 / 5;
	max-height: 520px;
	box-shadow: 0 20px 48px color-mix(in srgb, var(--charcoal) 10%, transparent);
}

.section-split-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.section-split-copy p {
	color: var(--muted);
	margin: 0 0 1rem;
	max-width: 52ch;
}

.section-bio-preview {
	background: var(--surface);
}

.bio-panel {
	background: color-mix(in srgb, var(--surface) 86%, var(--cream-deep));
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: clamp(1.4rem, 4vw, 2.4rem);
	box-shadow: 0 18px 42px color-mix(in srgb, var(--charcoal) 8%, transparent);
}

.bio-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	gap: clamp(1.3rem, 4vw, 3rem);
	align-items: start;
}

.bio-intro .button {
	margin-top: 0.6rem;
}

.bio-copy p,
.about-bio p {
	color: var(--muted);
	margin: 0 0 1rem;
}

.bio-quote {
	margin: 1.4rem 0 0;
	padding: 1rem 1.1rem;
	border-left: 4px solid var(--accent);
	background: color-mix(in srgb, var(--cream) 70%, var(--surface));
	border-radius: 0 var(--radius) var(--radius) 0;
}

.bio-quote p {
	margin: 0;
	font-family: "EB Garamond", Garamond, "Times New Roman", serif;
	font-size: clamp(1.25rem, 2vw, 1.55rem);
	line-height: 1.35;
	color: var(--charcoal-warm);
}

.bio-quote--about {
	margin-top: 1.8rem;
}

.section-about-bio {
	background: var(--surface);
}

.about-bio {
	max-width: 82ch;
}

.section-testimonials {
	background: var(--surface);
}

.testimonials-heading {
	text-align: center;
	margin: 0 auto clamp(2.5rem, 6vw, 4.5rem);
}

.testimonials-heading h2 {
	margin: 0 0 0.9rem;
	font-family: "Montserrat", "Segoe UI", Roboto, Arial, sans-serif;
	font-size: clamp(2.4rem, 5vw, 3.8rem);
	font-weight: 300;
	line-height: 1;
	letter-spacing: -0.05em;
	color: #3f3f3f;
}

.testimonials-heading p {
	margin: 0;
	font-family: "Montserrat", "Segoe UI", Roboto, Arial, sans-serif;
	font-size: 0.68rem;
	font-weight: 500;
	letter-spacing: 0.55em;
	line-height: 1.4;
	text-transform: uppercase;
	color: #c7c7c7;
}

.testimonials-carousel {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: clamp(0.6rem, 2vw, 1.4rem);
}

.testimonial-nav {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.8rem;
	height: 2.8rem;
	border-radius: 50%;
	border: 1px solid var(--line);
	background: var(--surface);
	color: var(--charcoal-warm);
	font-size: 1.1rem;
	font-weight: 700;
	cursor: pointer;
}

.testimonial-nav:hover,
.testimonial-nav:focus-visible {
	border-color: var(--accent);
	color: var(--accent-hover);
}

.testimonials-viewport {
	min-width: 0;
	width: 100%;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	scrollbar-width: thin;
}

.testimonials-list {
	display: flex;
	gap: clamp(1rem, 3vw, 1.6rem);
	align-items: stretch;
}

.testimonial-item {
	display: flex;
	flex: 0 0 100%;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
	max-width: none;
	padding: 0 0.2rem;
	text-align: center;
	scroll-snap-align: start;
}

.testimonial-quote {
	margin: 0;
	padding: 0;
}

.testimonial-quote p {
	margin: 0;
	color: #9d9d9d;
	font-size: 0.98rem;
	font-weight: 400;
	line-height: 1.58;
}

.testimonial-meta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.8rem;
	margin-top: auto;
	text-align: left;
}

.testimonial-avatar {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: #eef1f3;
	color: transparent;
	font-size: 0;
	flex: 0 0 auto;
	overflow: hidden;
}

.testimonial-avatar::before {
	content: "";
	position: absolute;
	right: -5px;
	bottom: 9px;
	width: 38px;
	height: 26px;
	border-radius: 55% 45% 50% 45%;
	background: #cbd3d9;
	transform: rotate(-28deg);
}

.testimonial-avatar::after {
	content: "";
	position: absolute;
	left: 12px;
	top: 23px;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #cbd3d9;
}

.testimonial-details p {
	margin: 0;
}

.testimonial-name {
	font-size: 0.95rem;
	font-weight: 700;
	line-height: 1.15;
	color: #3f3f3f;
}

.testimonial-role {
	margin-top: 0.25rem;
	font-size: 0.58rem;
	font-weight: 600;
	letter-spacing: 0.42em;
	line-height: 1.4;
	text-transform: uppercase;
	color: #b7b7b7;
}

.section-visual {
	position: relative;
	min-height: min(52vh, 520px);
	background-image: var(--section-visual-image);
	background-size: cover;
	background-position: center;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}

.section-visual-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		105deg,
		color-mix(in srgb, var(--charcoal-warm) 78%, transparent) 0%,
		color-mix(in srgb, var(--charcoal-warm) 35%, transparent) 45%,
		color-mix(in srgb, var(--olive) 25%, transparent) 100%
	);
}

.section-visual-inner {
	position: relative;
	z-index: 1;
	padding: clamp(3rem, 8vw, 5rem) 0;
	max-width: 34rem;
}

.section-visual-eyebrow {
	text-transform: uppercase;
	font-size: 0.78rem;
	letter-spacing: 0.14em;
	color: color-mix(in srgb, var(--cream) 92%, var(--mist));
	font-weight: 700;
	margin: 0 0 0.5rem;
}

.section-visual-title {
	color: var(--cream);
	font-size: clamp(1.85rem, 4vw, 2.75rem);
	margin: 0 0 0.75rem;
}

.section-visual-text {
	color: color-mix(in srgb, var(--cream) 88%, var(--mist));
	font-size: 1.1rem;
	margin: 0;
	max-width: 36ch;
	line-height: 1.6;
}

.card--media {
	padding: 0;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.card--media .card-body {
	padding: 1.1rem 1.15rem 1.25rem;
	flex: 1;
}

.card-photo {
	aspect-ratio: 4 / 3;
	background: var(--cream-deep);
}

/* Keep service card images visually consistent in the 4-column services row. */
.cards.four .card-photo {
	aspect-ratio: auto;
	height: 320px;
}

.cards.four .card-photo img {
	height: 100%;
}

.card-photo--short {
	aspect-ratio: 3 / 2;
}

.card-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.card--media h3 {
	margin-top: 0;
}

.updates-placeholder-note {
	margin: 1rem 0 0;
	font-size: 0.95rem;
	color: var(--muted);
}

.section-about-hero {
	padding-top: clamp(1.5rem, 4vw, 2.5rem);
	padding-bottom: 0;
}

.page-hero-photo {
	margin: 0;
	border-radius: var(--radius);
	overflow: hidden;
	border: 1px solid var(--line);
	aspect-ratio: 21 / 9;
	max-height: 420px;
	box-shadow: 0 16px 40px color-mix(in srgb, var(--charcoal) 10%, transparent);
}

.page-hero-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

h1,
h2,
h3,
h4 {
	font-family: "EB Garamond", Garamond, "Times New Roman", serif;
	line-height: 1.22;
	letter-spacing: -0.02em;
	font-weight: 600;
	margin: 0 0 0.8rem;
	color: var(--charcoal-warm);
}

h1 {
	font-size: clamp(2rem, 4.8vw, 3.6rem);
	font-weight: 700;
}

h2 {
	font-size: clamp(1.6rem, 3vw, 2.5rem);
	font-weight: 600;
}

h3,
h4 {
	font-weight: 600;
}

.lead {
	font-size: 1.08rem;
	color: var(--muted);
	max-width: 62ch;
}

.eyebrow {
	text-transform: uppercase;
	font-size: 0.78rem;
	letter-spacing: 0.14em;
	color: var(--accent);
	font-weight: 700;
}

.hero-card,
.card,
.booking-placeholder {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 1.2rem 1.2rem 1.3rem;
}

.cards {
	display: grid;
	gap: 1rem;
}

.cards.four {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.cards.three {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cards.two {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-bottom: 1rem;
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.65rem 1rem;
	border-radius: 999px;
	text-decoration: none;
	font-weight: 600;
	border: 1px solid transparent;
}

.button-primary {
	background: var(--olive);
	color: var(--cream);
}

.button-primary:hover,
.button-primary:focus-visible {
	background: var(--charcoal-warm);
	color: var(--cream);
}

.button-secondary {
	background: transparent;
	border-color: color-mix(in srgb, var(--olive) 45%, var(--line));
	color: var(--charcoal);
}

.button-secondary:hover,
.button-secondary:focus-visible {
	border-color: var(--accent);
	color: var(--charcoal-warm);
}

.hero-actions {
	display: flex;
	gap: 0.65rem;
	flex-wrap: wrap;
	margin-top: 1.4rem;
}

.prose {
	max-width: 74ch;
}

body.blog .site-main {
	overflow-x: clip;
}

.blog-archive {
	max-width: var(--max-width);
	width: 100%;
}

.blog-archive h1 {
	margin-bottom: 1.4rem;
}

.blog-archive .cards.three {
	width: 100%;
	max-width: 100%;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.blog-archive .card {
	min-width: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.blog-archive .card-thumb {
	display: block;
	margin: 0;
	flex: 0 0 auto;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	line-height: 0;
}

.blog-archive .card-thumb img,
.blog-archive .card-thumb .blog-card-image {
	width: 100% !important;
	height: 100% !important;
	max-width: 100% !important;
	object-fit: cover;
	display: block;
}

.blog-archive .card h2 {
	margin: 0;
	padding: 1rem 1.2rem 0.5rem;
	font-size: clamp(1rem, 1.6vw, 1.2rem);
	line-height: 1.3;
}

.blog-archive .card p {
	margin: 0;
	padding: 0 1.2rem 1.2rem;
}

.blog-archive .card h2 a {
	word-break: break-word;
}

.single-post-featured-image {
	width: 100%;
	height: auto;
	display: block;
	margin: 0 0 1.25rem;
	border-radius: 0.35rem;
}

.prose h1 {
	margin-bottom: 1.4rem;
}

.site-footer {
	background: var(--charcoal);
	color: var(--cream);
	border-top: 3px solid var(--accent);
	padding-top: 2.2rem;
}

.site-footer h3,
.site-footer h4 {
	color: var(--cream);
}

.site-footer a {
	color: var(--mist);
}

.site-footer a:hover,
.site-footer a:focus-visible {
	color: var(--cream);
}

.site-footer .menu a {
	color: var(--mist);
}

.footer-grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1.2fr 1fr 1fr;
}

.footer-grid ul {
	margin: 0;
	padding-left: 1.1rem;
}

.footer-bottom {
	border-top: 1px solid color-mix(in srgb, var(--olive-mid) 55%, transparent);
	margin-top: 1rem;
	padding: 0.8rem 0 1.4rem;
	font-size: 0.92rem;
	color: color-mix(in srgb, var(--cream) 78%, var(--mist));
}

.prose a {
	color: var(--olive-mid);
	text-decoration: underline;
	text-underline-offset: 0.18em;
}

.prose a:hover,
.prose a:focus-visible {
	color: var(--accent);
}

.header-actions {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	justify-self: end;
	grid-column: 3;
	grid-row: 1;
}

.brand {
	grid-column: 1;
	grid-row: 1;
}

.site-nav {
	grid-column: 2;
	grid-row: 1;
}

.menu-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	padding: 0;
	border: 1px solid var(--line);
	border-radius: 10px;
	background: var(--surface);
	color: var(--charcoal);
	cursor: pointer;
}

.menu-toggle:hover,
.menu-toggle:focus-visible {
	border-color: var(--accent);
	color: var(--charcoal-warm);
}

.menu-toggle-bars {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 18px;
}

.menu-toggle-bar {
	display: block;
	width: 100%;
	height: 2px;
	border-radius: 2px;
	background: currentColor;
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(2) {
	opacity: 0;
}

.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

body.nav-open {
	overflow: hidden;
}

.header-cta.button-primary {
	background: var(--accent);
	color: var(--cream);
}

.header-cta.button-primary:hover,
.header-cta.button-primary:focus-visible {
	background: var(--accent-hover);
	color: var(--cream);
}

.header-cta--menu {
	display: none;
}

@media (max-width: 1024px) {
	.cards.four {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 860px) {
	.hero.hero-banner {
		background-attachment: scroll;
		background-position: 62% 34%;
		min-height: clamp(400px, 66vh, 560px);
	}

	.hero-banner-inner {
		padding: clamp(3.2rem, 10vw, 4.6rem) 0;
	}

	.hero.hero-banner .hero-copy {
		padding-left: 0;
	}

	.header-inner {
		grid-template-columns: 1fr auto;
	}

	.brand {
		grid-column: 1;
	}

	.header-actions {
		grid-column: 2;
	}

	.menu-toggle {
		display: inline-flex;
	}

	.header-actions .header-cta--desktop {
		display: none;
	}

	.header-cta--menu {
		display: inline-flex;
		margin-top: 0.85rem;
		width: 100%;
		justify-content: center;
	}

	.site-nav {
		grid-column: 1 / -1;
		grid-row: 2;
		display: none;
		justify-self: stretch;
		width: 100%;
		padding: 0.35rem 0 0.5rem;
		border-top: 1px solid var(--line);
	}

	.site-nav.is-open {
		display: block;
	}

	.site-nav .menu {
		flex-direction: column;
		flex-wrap: nowrap;
		align-items: flex-start;
		gap: 0.35rem;
	}

	.site-nav .menu a {
		display: block;
		padding: 0.45rem 0;
		width: 100%;
	}

	.brand-logo .custom-logo-link img {
		max-width: min(400px, 88vw);
		max-height: 2.65rem;
	}

	.hero-grid,
	.section-split-grid,
	.bio-grid,
	.cards.three,
	.cards.two,
	.footer-grid {
		grid-template-columns: 1fr;
	}

	.testimonials-carousel {
		grid-template-columns: 1fr;
	}

	.testimonial-nav {
		display: none;
	}

	.hero-photo {
		max-height: none;
		aspect-ratio: 16 / 10;
	}

	.section-split-photo {
		max-height: 380px;
		order: -1;
	}
}

@media (max-width: 620px) {
	.cards.four {
		grid-template-columns: 1fr;
	}
}

/* Booking widget brand override (Amelia) */
:root {
	--booking-brand: #7a5040;
	--booking-brand-hover: #684437;
}

.amelia-v2-booking .am-button,
.amelia-v2-booking .am-btn,
#amelia-container .am-button,
#amelia-container .am-btn,
.amelia-app-booking .am-button,
.amelia-app-booking .am-btn,
.amelia-booking .am-button,
.amelia-booking .am-btn {
	background-color: var(--booking-brand) !important;
	border-color: var(--booking-brand) !important;
	color: #fff !important;
}

.amelia-v2-booking .am-button:hover,
.amelia-v2-booking .am-button:focus-visible,
.amelia-v2-booking .am-btn:hover,
.amelia-v2-booking .am-btn:focus-visible,
#amelia-container .am-button:hover,
#amelia-container .am-button:focus-visible,
#amelia-container .am-btn:hover,
#amelia-container .am-btn:focus-visible,
.amelia-app-booking .am-button:hover,
.amelia-app-booking .am-button:focus-visible,
.amelia-app-booking .am-btn:hover,
.amelia-app-booking .am-btn:focus-visible,
.amelia-booking .am-button:hover,
.amelia-booking .am-button:focus-visible,
.amelia-booking .am-btn:hover,
.amelia-booking .am-btn:focus-visible {
	background-color: var(--booking-brand-hover) !important;
	border-color: var(--booking-brand-hover) !important;
	color: #fff !important;
}
