:root {
	--jea-pearl: #fffaf7;
	--jea-lace: #f9efec;
	--jea-blush: #f6d9d7;
	--jea-rose: #9d5757;
	--jea-mauve: #8d656c;
	--jea-charcoal: #322b2d;
	--jea-sage: #d8ded2;
	--jea-gold: #b89b68;
	--jea-shadow: 0 22px 70px rgba(50, 43, 45, 0.13);
	--jea-radius: 8px;
}

html {
	scroll-behavior: smooth;
}

body {
	background:
		linear-gradient(180deg, rgba(255, 250, 247, 0.96), rgba(249, 239, 236, 0.72)),
		var(--jea-pearl);
	color: var(--jea-charcoal);
	font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	line-height: 1.6;
}

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

a {
	transition: color 180ms ease, opacity 180ms ease, transform 180ms ease;
}

a:hover {
	color: var(--jea-mauve);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
	outline: 3px solid var(--jea-gold);
	outline-offset: 4px;
}

.skip-link {
	position: fixed;
	top: 1rem;
	left: 1rem;
	z-index: 1100;
	padding: 0.85rem 1rem;
	background: var(--jea-charcoal);
	border-radius: var(--jea-radius);
	color: #fff;
	font-weight: 800;
	text-decoration: none;
}

.skip-link:focus,
.skip-link:focus-visible {
	clip: auto !important;
	width: auto;
	height: auto;
	overflow: visible;
	color: #fff;
}

.site-main:focus {
	outline: none;
}

.wp-site-blocks {
	overflow-x: clip;
}

.site-header {
	background: rgba(255, 250, 247, 0.92);
	border-bottom: 1px solid rgba(141, 101, 108, 0.14);
	backdrop-filter: blur(14px);
}

.header-inner {
	min-height: 82px;
	gap: 1rem;
	padding-top: 0.85rem;
	padding-bottom: 0.85rem;
}

.brand-lockup {
	gap: 0.75rem;
}

.site-brand-name a,
.footer-brand a {
	color: var(--jea-charcoal);
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.65rem;
	font-weight: 600;
	line-height: 1;
}

.primary-navigation a,
.footer-navigation a {
	color: var(--jea-charcoal);
	font-size: 0.9rem;
	font-weight: 700;
	text-transform: uppercase;
}

.primary-navigation a {
	letter-spacing: 0;
}

.wp-block-button__link,
.wp-element-button {
	border: 1px solid transparent;
	border-radius: 999px;
	font-size: 0.82rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0;
	min-height: 44px;
	padding: 0.75rem 1.15rem;
	transition: background 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.wp-block-button__link:hover,
.wp-element-button:hover {
	transform: translateY(-2px);
	box-shadow: 0 14px 30px rgba(50, 43, 45, 0.16);
}

.btn-primary-soft .wp-block-button__link {
	background: var(--jea-charcoal);
	color: var(--jea-pearl);
}

.btn-primary-soft .wp-block-button__link:hover {
	background: var(--jea-mauve);
	color: #fff;
}

.btn-outline-soft .wp-block-button__link {
	background: rgba(255, 250, 247, 0.82);
	border-color: rgba(50, 43, 45, 0.24);
	color: var(--jea-charcoal);
}

.eyebrow {
	color: var(--jea-mauve);
	font-size: 0.78rem;
	font-weight: 800;
	text-transform: uppercase;
}

.hero-section {
	position: relative;
	display: flex;
	align-items: center;
	overflow: hidden;
	min-height: calc(100vh - 1px);
	isolation: isolate;
}

.hero-section .wp-block-cover__image-background {
	position: absolute;
	inset: 0;
	z-index: -2;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero-section .wp-block-cover__background {
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		linear-gradient(90deg, rgba(50, 43, 45, 0.66), rgba(50, 43, 45, 0.34) 48%, rgba(50, 43, 45, 0.2)),
		linear-gradient(180deg, rgba(50, 43, 45, 0.12), rgba(50, 43, 45, 0.45));
	content: "";
	pointer-events: none;
}

.hero-section::after {
	display: none;
}

.hero-section .wp-block-cover__inner-container {
	position: relative;
	z-index: 1;
	width: 100%;
}

.hero-content {
	position: relative;
	z-index: 2;
	max-width: 760px;
	padding-top: 5rem;
	padding-bottom: 7rem;
	color: var(--jea-pearl);
}

.hero-content h1 {
	max-width: 10ch;
	margin-bottom: 1rem;
	font-family: "Cormorant Garamond", Georgia, serif;
	text-wrap: balance;
}

.hero-content .eyebrow {
	color: rgba(255, 250, 247, 0.9);
}

.hero-lede {
	max-width: 650px;
	margin-bottom: 1.75rem;
	color: rgba(255, 250, 247, 0.94);
}

.hero-actions {
	gap: 0.8rem;
}

.hero-actions .btn-primary-soft .wp-block-button__link {
	background: var(--jea-pearl);
	color: var(--jea-charcoal);
}

.hero-actions .btn-primary-soft .wp-block-button__link:hover {
	background: #fff;
	color: var(--jea-mauve);
}

.hero-actions .btn-outline-soft .wp-block-button__link {
	background: rgba(50, 43, 45, 0.24);
	border-color: rgba(255, 250, 247, 0.76);
	color: var(--jea-pearl);
}

.circle-nav-section {
	position: relative;
	margin-top: -3.5rem;
	background: var(--jea-pearl);
}

.circle-nav-grid {
	position: relative;
	z-index: 2;
}

.circle-photo-link {
	display: grid;
	justify-items: center;
	gap: 0.9rem;
	color: var(--jea-charcoal);
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.2rem;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
}

.circle-photo-link span {
	text-decoration: underline;
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.18em;
}

.circle-photo-link img {
	width: min(150px, 38vw);
	aspect-ratio: 1;
	border: 8px solid #fff;
	border-radius: 50%;
	box-shadow: var(--jea-shadow);
	object-fit: cover;
	transition: transform 240ms ease, box-shadow 240ms ease;
}

.circle-photo-link:hover {
	color: var(--jea-mauve);
	transform: translateY(-3px);
}

.circle-photo-link:hover img {
	box-shadow: 0 28px 80px rgba(141, 101, 108, 0.24);
	transform: scale(1.04);
}

.collection-section,
.love-notes-section {
	background: var(--jea-pearl);
}

.collection-section > .wp-block-columns {
	max-width: 1180px;
	margin-right: auto;
	margin-left: auto;
	padding-right: 1.5rem;
	padding-left: 1.5rem;
}

.boutique-image img {
	aspect-ratio: 4 / 5;
	border-radius: var(--jea-radius);
	box-shadow: var(--jea-shadow);
	object-fit: cover;
}

.love-notes-section {
	background: linear-gradient(180deg, var(--jea-pearl), var(--jea-lace));
}

.love-notes-slider {
	padding: 1rem 0 3rem;
}

.love-note-card {
	height: auto;
	min-height: 275px;
	padding: 2rem;
	background: rgba(255, 255, 255, 0.76);
	border: 1px solid rgba(141, 101, 108, 0.16);
	border-radius: var(--jea-radius);
	box-shadow: 0 18px 50px rgba(50, 43, 45, 0.08);
}

.love-note-card blockquote {
	margin: 0;
}

.love-note-card p {
	color: rgba(50, 43, 45, 0.82);
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.45rem;
	line-height: 1.35;
}

.love-note-card h3 {
	margin: 1.25rem 0 0.2rem;
	font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-size: 0.9rem;
	font-weight: 800;
	text-transform: uppercase;
}

.love-note-card span {
	color: var(--jea-mauve);
	font-size: 0.9rem;
}

.swiper-pagination-bullet-active {
	background: var(--jea-mauve);
}

.swiper-pagination-bullet {
	width: 14px;
	height: 14px;
}

.appointment-cta {
	max-width: 980px;
	margin-top: 2rem;
	margin-right: auto;
	margin-bottom: 2rem;
	margin-left: auto;
	padding-right: 1.5rem;
	padding-left: 1.5rem;
	background: var(--jea-charcoal);
	border-radius: var(--jea-radius);
	color: var(--jea-pearl);
}

.appointment-cta h2,
.appointment-cta p {
	color: inherit;
}

.appointment-cta .wp-block-button__link {
	background: var(--jea-pearl);
	color: var(--jea-charcoal);
}

.page-template {
	min-height: 60vh;
}

.page-template h1 {
	margin-bottom: 2rem;
	text-align: center;
}

.page-featured-image img {
	width: 100%;
	max-height: 540px;
	border-radius: var(--jea-radius);
	box-shadow: var(--jea-shadow);
	object-fit: cover;
}

.site-footer {
	padding-top: 4rem;
	padding-bottom: 2rem;
	border-top: 1px solid rgba(141, 101, 108, 0.15);
}

.footer-grid {
	gap: 2rem;
}

.footer-bottom {
	margin-top: 2.5rem;
	padding-top: 1.25rem;
	border-top: 1px solid rgba(141, 101, 108, 0.14);
	color: rgba(50, 43, 45, 0.72);
}

@media (max-width: 781px) {
	.header-inner {
		justify-content: center;
	}

	.primary-navigation {
		order: 3;
		width: 100%;
		justify-content: center;
	}

	.header-cta {
		display: none;
	}

	.hero-content {
		padding-top: 4rem;
		padding-bottom: 5rem;
		text-align: center;
	}

	.hero-content h1 {
		max-width: none;
	}

	.hero-actions {
		justify-content: center;
	}

	.circle-nav-section {
		margin-top: 0;
	}

	.appointment-cta {
		margin-right: 1rem;
		margin-left: 1rem;
	}
}

@media (max-width: 575px) {
	.site-brand-name a {
		font-size: 1.35rem;
	}

	.hero-section {
		min-height: 560px;
	}

	.circle-photo-link img {
		width: min(132px, 42vw);
		border-width: 6px;
	}

	.love-note-card {
		padding: 1.5rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: 0.01ms !important;
	}

	.wp-block-button__link:hover,
	.wp-element-button:hover,
	.circle-photo-link:hover,
	.circle-photo-link:hover img {
		transform: none;
	}
}

@media (forced-colors: active) {
	a:focus-visible,
	button:focus-visible,
	input:focus-visible,
	select:focus-visible,
	textarea:focus-visible,
	[tabindex]:focus-visible {
		outline-color: Highlight;
	}

	.wp-block-button__link,
	.wp-element-button,
	.circle-photo-link img,
	.love-note-card,
	.appointment-cta {
		border: 1px solid CanvasText;
		box-shadow: none;
	}
}
