:root {
	--color-ink: #221c17;
	--color-muted: #70655c;
	--color-line: #e5dbcf;
	--color-cream: #fbf7f0;
	--color-ivory: #fffdf8;
	--color-sand: #d8b98f;
	--color-clay: #8e5f48;
	--color-charcoal: #171412;
	--shadow-soft: 0 24px 70px rgba(34, 28, 23, 0.12);
	--radius-large: 30px;
	--radius-medium: 18px;
	--container: 1180px;
	--site-gutter: clamp(6px, 0.8vw, 10px);
	--font-serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
	--font-sans: "Inter", ui-sans-serif, system-ui, sans-serif;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background: var(--color-ivory);
	color: var(--color-ink);
	font-family: var(--font-sans);
	font-size: 16px;
	line-height: 1.65;
}

body.admin-bar .site-header {
	top: 32px;
}

a {
	color: inherit;
	text-decoration: none;
}

a:hover {
	color: var(--color-clay);
}

img {
	display: block;
	height: auto;
	max-width: 100%;
}

h1,
h2,
h3,
p {
	margin-top: 0;
}

h1,
h2,
h3 {
	color: var(--color-ink);
	font-family: var(--font-serif);
	font-weight: 500;
	letter-spacing: -0.035em;
	line-height: 1.05;
}

h1 {
	font-size: clamp(3.3rem, 7vw, 6.8rem);
	margin-bottom: 28px;
}

h2 {
	font-size: clamp(2.2rem, 4vw, 4.5rem);
	margin-bottom: 22px;
}

h3 {
	font-size: 1.5rem;
	margin-bottom: 12px;
}

p {
	color: var(--color-muted);
	margin-bottom: 18px;
}

.container {
	margin: 0 auto;
	max-width: none;
	padding: 0 var(--site-gutter);
	width: 100%;
}

.section {
	padding: 56px 0;
}

.skip-link {
	background: var(--color-charcoal);
	color: #fff;
	left: 16px;
	padding: 10px 16px;
	position: absolute;
	top: -48px;
	z-index: 1000;
}

.skip-link:focus {
	top: 16px;
}

.site-header {
	backdrop-filter: blur(18px);
	background: rgba(255, 253, 248, 0.88);
	border-bottom: 1px solid rgba(229, 219, 207, 0.75);
	position: sticky;
	top: 0;
	z-index: 100;
}

.header-inner {
	align-items: center;
	display: grid;
	gap: 28px;
	grid-template-columns: 1fr auto 1fr;
	min-height: 86px;
}

.brand {
	align-items: center;
	display: inline-flex;
	gap: 12px;
	justify-self: start;
	min-width: max-content;
}

.primary-nav {
	justify-self: center;
	margin-left: 0;
}

.header-actions {
	justify-self: end;
}

.brand-mark {
	align-items: center;
	background: var(--color-charcoal);
	border-radius: 999px;
	color: #fff;
	display: inline-flex;
	font-family: Georgia, "Times New Roman", serif;
	height: 48px;
	justify-content: center;
	letter-spacing: -0.05em;
	width: 48px;
}

.brand-text {
	display: grid;
	line-height: 1.2;
}

.brand-text strong {
	font-size: 1rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.brand-text small {
	color: var(--color-muted);
	font-size: 0.78rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.menu {
	align-items: center;
	display: flex;
	gap: 28px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.menu a {
	color: var(--color-muted);
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.header-cta,
.button {
	align-items: center;
	border-radius: 999px;
	display: inline-flex;
	gap: 8px;
	font-size: 0.82rem;
	font-weight: 800;
	justify-content: center;
	letter-spacing: 0.12em;
	min-height: 50px;
	padding: 0 22px;
	text-transform: uppercase;
	transition: background 180ms ease, color 180ms ease, transform 180ms ease, border-color 180ms ease;
}

.header-cta,
.button-primary {
	background: var(--color-charcoal);
	color: #fff;
}

.button-secondary {
	border: 1px solid var(--color-line);
	color: var(--color-ink);
}

.header-cta:hover,
.button:hover {
	transform: translateY(-2px);
}

.header-cta:hover,
.button-primary:hover {
	background: var(--color-clay);
	color: #fff;
}

.button-secondary:hover {
	border-color: var(--color-clay);
	color: var(--color-clay);
}

.hero {
	background:
		radial-gradient(circle at 74% 15%, rgba(216, 185, 143, 0.3), transparent 30%),
		linear-gradient(135deg, var(--color-cream), #fff 52%, #f5eadc);
	overflow: hidden;
	padding: 110px 0 86px;
}

.hero-grid {
	align-items: start;
	display: grid;
	gap: 72px;
	grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.75fr);
}

.hero-lead {
	font-size: clamp(1.28rem, 2.6vw, 1.55rem);
	max-width: 860px;
}

.eyebrow {
	color: var(--color-clay);
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.18em;
	margin-bottom: 18px;
	text-transform: uppercase;
}

.hero-actions,
.contact-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin: 34px 0;
}

.hero-highlights {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.hero-highlights li {
	background: rgba(255, 255, 255, 0.72);
	border: 1px solid var(--color-line);
	border-radius: 999px;
	color: var(--color-muted);
	font-size: 0.88rem;
	padding: 8px 14px;
}

.hero-card {
	display: grid;
	gap: 0;
	position: relative;
}

.photo-card {
	background-position: center center;
	background-size: cover;
}

.fabric-card {
	align-items: flex-end;
	background:
		linear-gradient(135deg, rgba(23, 20, 18, 0.05), rgba(23, 20, 18, 0.35)),
		repeating-linear-gradient(45deg, #d9c3aa 0, #d9c3aa 8px, #c3a47f 8px, #c3a47f 10px);
	border-radius: var(--radius-large);
	box-shadow: var(--shadow-soft);
	display: flex;
	min-height: 420px;
	overflow: hidden;
	padding: 28px;
	position: relative;
}

.fabric-card::after {
	border: 1px solid rgba(255, 255, 255, 0.55);
	border-radius: 24px;
	content: "";
	inset: 18px;
	position: absolute;
}

.fabric-card span {
	background: rgba(255, 253, 248, 0.9);
	border-radius: 999px;
	color: var(--color-ink);
	font-size: 0.84rem;
	font-weight: 800;
	letter-spacing: 0.14em;
	padding: 12px 18px;
	text-transform: uppercase;
	z-index: 1;
}

.fabric-card-large {
	min-height: 540px;
}

.hero-card-panel {
	background: var(--color-charcoal);
	border-radius: 24px;
	box-shadow: var(--shadow-soft);
	color: #fff;
	justify-self: center;
	margin-top: -72px;
	max-width: calc(100% - 64px);
	padding: 28px;
	position: relative;
	width: 100%;
	z-index: 3;
}

.hero-card-panel p {
	color: rgba(255, 255, 255, 0.74);
	margin: 0;
}

.hero-card-panel .panel-label {
	color: #fff;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.45rem;
	line-height: 1.15;
	margin-bottom: 12px;
}

.intro-strip {
	padding: 0;
}

.intro-strip-inner {
	align-items: center;
	background: var(--color-charcoal);
	border-radius: 0 0 var(--radius-large) var(--radius-large);
	display: flex;
	gap: 24px;
	justify-content: space-between;
	padding: 30px 36px;
}

.intro-strip p {
	color: rgba(255, 255, 255, 0.74);
	font-size: 1.08rem;
	margin: 0;
	max-width: 820px;
}

.intro-strip a {
	color: var(--color-sand);
	font-weight: 800;
	min-width: max-content;
}

.section-heading {
	margin-bottom: 46px;
	max-width: 820px;
}

.section-heading p:last-child {
	font-size: 1.08rem;
}

/* Swiper Services */
.services-swiper {
	padding-bottom: 24px;
	overflow: hidden;
	position: relative;
}

.swiper-slide {
	height: auto;
}

.service-card {
	height: 100%;
}

.swiper-nav-wrapper {
	align-items: center;
	display: flex;
	gap: 24px;
	justify-content: center;
	margin-top: 42px;
	position: relative;
}

.swiper-nav-wrapper .swiper-button-prev,
.swiper-nav-wrapper .swiper-button-next {
	color: var(--color-charcoal);
	height: 44px;
	margin: 0;
	position: static;
	width: 44px;
}

.swiper-nav-wrapper .swiper-button-prev::after,
.swiper-nav-wrapper .swiper-button-next::after {
	font-size: 1.4rem;
	font-weight: bold;
}

.swiper-nav-wrapper .swiper-pagination {
	position: static;
	width: auto;
}

.swiper-pagination-bullet-active {
	background: var(--color-charcoal) !important;
}

.service-card,
.process-list article,
.contact-card {
	background: #fff;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-medium);
	box-shadow: 0 16px 42px rgba(34, 28, 23, 0.06);
	padding: 30px;
}

.service-card {
	overflow: hidden;
	padding: 0;
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.service-card:hover {
	box-shadow: 0 24px 64px rgba(34, 28, 23, 0.12);
	transform: translateY(-4px);
}

.service-media {
	align-items: flex-start;
	background-color: var(--color-charcoal);
	background-position: center;
	background-size: cover;
	display: flex;
	min-height: 240px;
	padding: 20px;
}

.service-media-2 {
	background:
		linear-gradient(135deg, rgba(23, 20, 18, 0.1), rgba(23, 20, 18, 0.42)),
		radial-gradient(circle at 20% 20%, #e7d7c4, transparent 24%),
		linear-gradient(135deg, #b89a78, #f2e7d8);
}

.service-media-3 {
	background:
		linear-gradient(135deg, rgba(23, 20, 18, 0.12), rgba(23, 20, 18, 0.42)),
		repeating-linear-gradient(90deg, #c7a27d 0, #c7a27d 8px, #ead8c4 8px, #ead8c4 18px);
}

.service-media-4 {
	background:
		linear-gradient(135deg, rgba(23, 20, 18, 0.08), rgba(23, 20, 18, 0.4)),
		linear-gradient(160deg, #efe3d4, #b8846a);
}

.service-media-5 {
	background:
		linear-gradient(135deg, rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0.54)),
		repeating-linear-gradient(135deg, #5a4637 0, #5a4637 10px, #1f1915 10px, #1f1915 14px);
}

.service-media-6 {
	background:
		linear-gradient(135deg, rgba(23, 20, 18, 0.1), rgba(23, 20, 18, 0.44)),
		radial-gradient(circle at 70% 25%, #f5eadc, transparent 22%),
		linear-gradient(135deg, #9b745d, #dbc2a6);
}

.service-media span {
	background: rgba(255, 253, 248, 0.9);
	border-radius: 999px;
	color: var(--color-ink);
	margin: 0;
	padding: 9px 12px;
}

.service-content {
	padding: 28px;
}

.service-card p,
.process-list p {
	margin-bottom: 0;
}

.featured-card {
	background: var(--color-charcoal);
	border-color: var(--color-charcoal);
}

.featured-card h3,
.featured-card span {
	color: #fff;
}

.featured-card p {
	color: rgba(255, 255, 255, 0.72);
}

.featured-card .service-media span {
	background: rgba(255, 255, 255, 0.92);
	color: var(--color-charcoal);
}

.split-section,
.process-section {
	background: var(--color-cream);
}

.split-grid,
.contact-grid,
.seo-grid {
	align-items: center;
	display: grid;
	gap: 42px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.image-panel {
	position: relative;
}

.image-panel .fabric-card {
	min-height: 520px;
}

.image-panel-caption {
	background: #fff;
	border: 1px solid var(--color-line);
	border-radius: 20px;
	bottom: 28px;
	box-shadow: var(--shadow-soft);
	color: var(--color-muted);
	max-width: 320px;
	padding: 22px;
	position: absolute;
	right: -28px;
}

.split-copy p {
	font-size: 1.05rem;
}

.stats-row {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-top: 34px;
}

.stats-row div {
	background: #fff;
	border: 1px solid var(--color-line);
	border-radius: 18px;
	padding: 22px;
}

.stats-row strong,
.stats-row span {
	display: block;
}

.stats-row strong {
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.28rem;
	font-weight: 500;
}

.stats-row span {
	color: var(--color-muted);
	font-size: 0.94rem;
	margin-top: 5px;
}

.why-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.why-item {
	border-bottom: 1px solid var(--color-line);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.32rem;
	line-height: 1.25;
	padding: 24px 0;
}

.why-item::before {
	color: var(--color-clay);
	content: "Made with care";
	display: block;
	font-family: Inter, ui-sans-serif, system-ui, sans-serif;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.14em;
	margin-bottom: 10px;
	text-transform: uppercase;
}

.process-list {
	display: grid;
	gap: 0;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	position: relative;
}

.process-list::before {
	background: var(--color-line);
	content: "";
	height: 1px;
	left: 0;
	position: absolute;
	right: 0;
	top: 52px;
}

.process-list article {
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	padding: 0 18px 0 0;
	position: relative;
}

.process-list article::before {
	background: var(--color-charcoal);
	border: 5px solid var(--color-cream);
	border-radius: 999px;
	content: "";
	height: 16px;
	left: 0;
	position: absolute;
	top: 44px;
	width: 16px;
	z-index: 1;
}

.process-list article h3 {
	font-size: 1.28rem;
	margin-top: 52px;
}

.seo-section {
	background: var(--color-charcoal);
}

.seo-section h2 {
	color: #fff;
}

.seo-section p {
	color: rgba(255, 255, 255, 0.7);
}

.seo-section .eyebrow {
	color: var(--color-sand);
}

.contact-section {
	background:
		radial-gradient(circle at 0 0, rgba(216, 185, 143, 0.26), transparent 30%),
		var(--color-ivory);
}

.contact-card {
	display: grid;
	font-style: normal;
	gap: 10px;
}

.contact-visual {
	display: grid;
	gap: 18px;
	grid-template-columns: 0.8fr 1.2fr;
	position: relative;
}

.contact-photo,
.contact-map,
.contact-card {
	box-shadow: var(--shadow-soft);
}

.contact-photo {
	align-items: flex-end;
	background:
		linear-gradient(135deg, rgba(23, 20, 18, 0.12), rgba(23, 20, 18, 0.5)),
		repeating-linear-gradient(45deg, #d9c3aa 0, #d9c3aa 9px, #b8866d 9px, #b8866d 13px);
	border-radius: var(--radius-medium);
	display: flex;
	min-height: 230px;
	padding: 20px;
}

.contact-photo span {
	background: rgba(255, 253, 248, 0.92);
	border-radius: 999px;
	color: var(--color-ink);
	font-size: 0.74rem;
	font-weight: 900;
	letter-spacing: 0.14em;
	padding: 10px 14px;
	text-transform: uppercase;
}

.contact-map {
	border: 1px solid var(--color-line);
	border-radius: var(--radius-medium);
	min-height: 230px;
	overflow: hidden;
}

.contact-map iframe {
	border: 0;
	display: block;
	height: 100%;
	min-height: 230px;
	width: 100%;
}

.contact-visual .contact-card {
	grid-column: 1 / -1;
}

.contact-card strong {
	font-family: Georgia, "Times New Roman", serif;
	font-size: 2rem;
	font-weight: 500;
	margin-bottom: 8px;
}

.contact-card span,
.contact-card a {
	color: var(--color-muted);
}

.site-footer {
	background: var(--color-charcoal);
	color: #fff;
	padding: 72px 0 28px;
}

.footer-grid {
	display: grid;
	gap: 42px;
	grid-template-columns: 1.2fr 1fr 1fr;
}

.footer-brand {
	color: #fff;
	display: inline-block;
	font-family: var(--font-serif);
	font-size: 2rem;
	margin-bottom: 14px;
}

.site-footer h2 {
	color: #fff;
	font-family: Inter, ui-sans-serif, system-ui, sans-serif;
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.14em;
	margin-bottom: 16px;
	text-transform: uppercase;
}

.site-footer p,
.site-footer a {
	color: rgba(255, 255, 255, 0.68);
}

.site-footer a:hover {
	color: var(--color-sand);
}

.footer-bottom {
	align-items: center;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	display: flex;
	justify-content: space-between;
	margin-top: 56px;
	padding-top: 24px;
}

.footer-bottom p {
	margin: 0;
}

@media (max-width: 980px) {
	body.admin-bar .site-header {
		top: 0;
	}

	.header-inner {
		align-items: flex-start;
		flex-wrap: wrap;
		padding-bottom: 18px;
		padding-top: 18px;
	}

	.primary-nav {
		flex-basis: 100%;
		margin-left: 0;
		order: 3;
		overflow-x: auto;
	}

	.menu {
		gap: 18px;
		width: max-content;
	}

	.hero-grid,
	.split-grid,
	.contact-grid,
	.seo-grid {
		grid-template-columns: 1fr;
	}

	.hero-card-panel {
		max-width: calc(100% - 48px);
	}

	.why-grid,
	.footer-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.process-list {
		gap: 18px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.process-list::before {
		display: none;
	}

	.process-list article {
		background: #fff;
		border: 1px solid var(--color-line);
		border-radius: var(--radius-medium);
		box-shadow: 0 16px 42px rgba(34, 28, 23, 0.06);
		padding: 30px;
	}

	.process-list article::before {
		display: none;
	}

	.process-list article h3 {
		margin-top: 0;
	}
}

@media (max-width: 680px) {
	.container {
		padding: 0 18px;
	}

	.section {
		padding: 32px 0;
	}

	.hero {
		padding-top: 72px;
	}

	h1 {
		font-size: clamp(2.7rem, 15vw, 4.6rem);
	}

	.intro-strip-inner {
		align-items: flex-start;
		border-radius: 0 0 22px 22px;
		flex-direction: column;
		padding: 26px;
	}

	.why-grid,
	.process-list,
	.footer-grid,
	.stats-row {
		grid-template-columns: 1fr;
	}

	.service-media {
		min-height: 210px;
	}

	.contact-visual {
		grid-template-columns: 1fr;
	}

	.hero-card-panel,
	.image-panel-caption {
		max-width: none;
	}

	.hero-card-panel {
		margin: -52px 18px 0;
		width: auto;
	}

	.fabric-card-large,
	.image-panel .fabric-card {
		min-height: 470px;
	}

	.footer-bottom {
		align-items: flex-start;
		flex-direction: column;
		gap: 12px;
	}
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	.header-cta,
	.button {
		transition: none;
	}
}

/* Production-lab redesign */
body {
	background:
		linear-gradient(rgba(34, 28, 23, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(34, 28, 23, 0.035) 1px, transparent 1px),
		#f6f0e8;
	background-size: 44px 44px;
}

.site-header {
	background: rgba(246, 240, 232, 0.92);
}

.hero {
	background:
		radial-gradient(circle at 92% 8%, rgba(142, 95, 72, 0.18), transparent 26%),
		linear-gradient(135deg, rgba(255, 253, 248, 0.9), rgba(244, 234, 220, 0.72));
	border-bottom: 1px solid var(--color-line);
	padding: 96px 0 72px;
}

.hero-grid {
	align-items: stretch;
	grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr);
}

.hero-copy {
	align-self: center;
	justify-self: center;
}

.hero-card {
	align-self: stretch;
	display: grid;
	grid-template-rows: 1fr auto;
	min-height: 620px;
}

.lab-photo {
	background-color: #d8b98f;
	background-position: center;
	background-size: cover;
	border: 1px solid rgba(34, 28, 23, 0.08);
	border-radius: 34px;
	box-shadow: 0 30px 80px rgba(34, 28, 23, 0.14);
	min-height: 420px;
	overflow: hidden;
	position: relative;
}

.lab-photo::after {
	background:
		linear-gradient(135deg, rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0.32)),
		linear-gradient(0deg, rgba(34, 28, 23, 0.08), transparent 45%);
	content: "";
	inset: 0;
	position: absolute;
}

.hero-photo {
	min-height: 560px;
}

.lab-photo-meta {
	background: rgba(255, 253, 248, 0.92);
	border-radius: 22px;
	bottom: 24px;
	box-shadow: 0 20px 50px rgba(34, 28, 23, 0.12);
	left: 24px;
	padding: 18px 20px;
	position: absolute;
	right: 24px;
	z-index: 2;
}

.lab-photo-meta span,
.lab-photo-meta strong {
	display: block;
}

.lab-photo-meta span {
	color: var(--color-clay);
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.16em;
	margin-bottom: 6px;
	text-transform: uppercase;
}

.lab-photo-meta strong {
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.55rem;
	font-weight: 500;
	line-height: 1.08;
}

.hero-card-panel {
	align-self: end;
	justify-self: end;
	margin: -86px 28px 0 auto;
	max-width: 420px;
	width: auto;
}

.intro-strip-inner {
	border-radius: 28px;
	margin-top: 26px;
}

.services-grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.service-card {
	background: rgba(255, 253, 248, 0.86);
	border: 1px solid rgba(34, 28, 23, 0.08);
	border-radius: 28px;
	box-shadow: 0 20px 55px rgba(34, 28, 23, 0.08);
	display: grid;
	grid-template-columns: 210px minmax(0, 1fr);
	min-height: 230px;
	overflow: hidden;
	padding: 0;
}

.service-media {
	align-items: flex-start;
	background-color: #d8b98f;
	background-position: center;
	background-size: cover;
	display: flex;
	min-height: 100%;
	padding: 18px;
	position: relative;
}

.service-media::after {
	background: linear-gradient(135deg, rgba(34, 28, 23, 0.02), rgba(34, 28, 23, 0.28));
	content: "";
	inset: 0;
	position: absolute;
}

.service-media span {
	background: #fffdf8;
	border-radius: 999px;
	color: var(--color-ink);
	font-weight: 900;
	letter-spacing: 0.14em;
	margin: 0;
	padding: 9px 12px;
	position: relative;
	z-index: 1;
}

.service-content {
	align-self: center;
	padding: 30px;
}

.featured-card {
	background: var(--color-charcoal);
}

.featured-card .service-content h3,
.featured-card .service-content p {
	color: #fff;
}

.featured-card .service-content p {
	opacity: 0.76;
}

.split-section,
.process-section {
	background:
		linear-gradient(rgba(34, 28, 23, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(34, 28, 23, 0.035) 1px, transparent 1px),
		#efe5da;
	background-size: 44px 44px;
}

.about-photo {
	min-height: 600px;
}

.why-grid {
	gap: 1px;
	overflow: hidden;
	border: 1px solid var(--color-line);
	border-radius: 28px;
}

.why-item {
	background: rgba(255, 253, 248, 0.82);
	border: 0;
	font-size: 1.18rem;
	min-height: 168px;
	padding: 28px;
}

.process-list {
	background: rgba(255, 253, 248, 0.76);
	border: 1px solid var(--color-line);
	border-radius: 28px;
	display: grid;
	gap: 1px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	overflow: hidden;
}

.process-list::before,
.process-list article::before {
	display: none;
}

.process-list article {
	background: #fffdf8;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	padding: 34px;
}

.process-list article h3 {
	font-size: 1.34rem;
	margin-top: 0;
}

.seo-section {
	background:
		radial-gradient(circle at 90% 20%, rgba(216, 185, 143, 0.22), transparent 24%),
		var(--color-charcoal);
}

.contact-grid {
	align-items: start;
}

.contact-visual {
	display: grid;
	gap: 24px;
	grid-template-columns: 1fr;
	position: relative;
}

.contact-map {
	border: 1px solid var(--color-line);
	border-radius: 28px;
	box-shadow: var(--shadow-soft);
	min-height: 480px;
	overflow: hidden;
	width: 100%;
}

.contact-map iframe {
	border: 0;
	display: block;
	height: 100%;
	min-height: 480px;
	width: 100%;
}

.contact-visual .contact-card {
	background: #fff;
	border-radius: 20px;
	box-shadow: 0 24px 60px rgba(34, 28, 23, 0.15);
	padding: 32px 42px;
	width: 100%;
	max-width: none;
}

@media (max-width: 980px) {
	.hero-grid {
		grid-template-columns: 1fr;
	}

	.hero-card {
		min-height: auto;
	}

	.hero-photo,
	.about-photo {
		min-height: 460px;
	}

	.services-grid,
	.process-list {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 680px) {
	.hero {
		padding: 64px 0 56px;
	}

	.service-card {
		grid-template-columns: 1fr;
	}

	.service-media {
		min-height: 240px;
	}

	.hero-card-panel {
		margin: -62px 16px 0;
		max-width: none;
	}

	.contact-visual {
		grid-template-columns: 1fr;
	}
	.contact-map,
	.contact-map iframe {
		min-height: 320px;
	}
	.contact-visual .contact-card {
		padding: 24px;
	}
}

/* Refinement: full hero image and reference-style icon/process sections */
.hero-photo {
	align-items: center;
	background:
		linear-gradient(135deg, rgba(255, 253, 248, 0.72), rgba(216, 185, 143, 0.28)),
		#efe5da;
	display: flex;
	justify-content: center;
	min-height: 560px;
	padding: 18px;
}

.hero-photo::after {
	display: none;
}

.hero-photo img {
	border-radius: 24px;
	display: block;
	height: 100%;
	max-height: 524px;
	max-width: 100%;
	object-fit: contain;
	width: 100%;
}

.hero-card-panel {
	margin-top: 18px;
	max-width: none;
	width: 100%;
}

.why-section {
	background:
		radial-gradient(ellipse at 12% 0%, rgba(216, 185, 143, 0.34), transparent 32%),
		linear-gradient(rgba(34, 28, 23, 0.026) 1px, transparent 1px),
		linear-gradient(90deg, rgba(34, 28, 23, 0.026) 1px, transparent 1px),
		#faf6ef;
	background-size: auto, 44px 44px, 44px 44px, auto;
	overflow: hidden;
	position: relative;
}

.why-section::before,
.process-section::before {
	background: #ded1c3;
	border-radius: 45% 55% 52% 48%;
	content: "";
	height: 120px;
	position: absolute;
	right: -38px;
	top: -44px;
	transform: rotate(-8deg);
	width: 360px;
}

.why-section .section-heading,
.process-section .section-heading {
	margin-left: auto;
	margin-right: auto;
	max-width: 860px;
	text-align: center;
}

.why-grid {
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	counter-reset: why-item;
	display: grid;
	gap: 48px 54px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin: 22px auto 0;
	max-width: 980px;
	overflow: visible;
}

.why-item {
	background: transparent;
	border: 0;
	counter-increment: why-item;
	font-family: Inter, ui-sans-serif, system-ui, sans-serif;
	font-size: 1rem;
	line-height: 1.42;
	min-height: auto;
	padding: 0;
	text-align: center;
}

.why-item::before {
	align-items: center;
	background: #fffdf8;
	border: 1.5px solid var(--color-charcoal);
	border-radius: 999px;
	box-shadow: 0 16px 42px rgba(34, 28, 23, 0.08);
	color: var(--color-clay);
	content: counter(why-item, decimal-leading-zero);
	display: inline-flex;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.35rem;
	font-weight: 600;
	height: 96px;
	justify-content: center;
	letter-spacing: 0;
	margin: 0 auto 18px;
	text-transform: none;
	width: 96px;
}

.process-section {
	overflow: hidden;
	position: relative;
}

.process-list {
	background: transparent;
	border: 0;
	border-radius: 0;
	display: grid;
	gap: 42px 34px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	overflow: visible;
	position: relative;
}

.process-list article {
	background: transparent;
	border: 0;
	box-shadow: none;
	padding: 0;
	position: relative;
	text-align: center;
}

.process-list article::before {
	background:
		radial-gradient(circle at 50% 42%, rgba(255, 253, 248, 0.82), rgba(216, 185, 143, 0.62)),
		linear-gradient(135deg, rgba(142, 95, 72, 0.18), rgba(255, 253, 248, 0.6));
	border: 1.5px solid rgba(34, 28, 23, 0.46);
	border-radius: 999px;
	box-shadow: inset 0 0 0 8px rgba(255, 253, 248, 0.58), 0 18px 44px rgba(34, 28, 23, 0.09);
	content: "";
	display: block;
	height: 116px;
	margin: 0 auto 20px;
	position: static;
	width: 116px;
}

.process-list article::after {
	border-top: 2px dashed rgba(34, 28, 23, 0.42);
	content: "";
	left: calc(50% + 68px);
	position: absolute;
	top: 58px;
	width: calc(100% - 92px);
}

.process-list article:nth-child(4)::after,
.process-list article:last-child::after {
	display: none;
}

.process-list span {
	background: var(--color-charcoal);
	border-radius: 999px;
	box-shadow: 0 12px 28px rgba(34, 28, 23, 0.24);
	color: #fff;
	display: inline-flex;
	font-size: 0.98rem;
	font-weight: 800;
	justify-content: center;
	letter-spacing: 0.08em;
	margin: 0 auto 14px;
	min-width: 92px;
	padding: 9px 18px;
	text-transform: uppercase;
}

.process-list h3 {
	font-family: Inter, ui-sans-serif, system-ui, sans-serif;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0;
	margin: 0 0 8px;
}

.process-list p {
	font-size: 0.92rem;
	line-height: 1.45;
}

@media (max-width: 980px) {
	.why-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.process-list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.process-list article:nth-child(2n)::after {
		display: none;
	}
}

@media (max-width: 680px) {
	.hero-photo {
		min-height: 420px;
	}

	.hero-photo img {
		max-height: 390px;
	}

	.why-grid,
	.process-list {
		grid-template-columns: 1fr;
	}

	.process-list article::after {
		display: none;
	}
}

/* Final simplified direction: fewer blocks, calmer editorial layout */
.hero {
	padding: 86px 0 68px;
}

.hero-grid {
	gap: 60px;
	grid-template-columns: minmax(0, 1fr) minmax(360px, 0.9fr);
}

.hero-photo {
	background: #efe5da;
	box-shadow: 0 28px 70px rgba(34, 28, 23, 0.12);
	min-height: 500px;
	padding: 14px;
}

.hero-photo img {
	background: #fffdf8;
	border-radius: 22px;
	max-height: 470px;
	object-fit: contain;
}

.hero-card-panel {
	background: rgba(23, 20, 18, 0.94);
	margin-top: 16px;
	max-width: 100%;
	padding: 24px;
}

.services-editorial {
	background: rgba(255, 253, 248, 0.78);
	border: 1px solid rgba(34, 28, 23, 0.08);
	border-radius: 34px;
	display: grid;
	gap: 0;
	grid-template-columns: minmax(320px, 0.86fr) minmax(0, 1.14fr);
	overflow: hidden;
}

.services-visual {
	align-items: flex-end;
	background-color: #d8b98f;
	background-position: center;
	background-size: cover;
	display: flex;
	min-height: 680px;
	padding: 28px;
	position: relative;
}

.services-visual::after {
	background: linear-gradient(180deg, transparent 32%, rgba(23, 20, 18, 0.58));
	content: "";
	inset: 0;
	position: absolute;
}

.services-visual span {
	background: rgba(255, 253, 248, 0.92);
	border-radius: 999px;
	color: var(--color-ink);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.14em;
	padding: 12px 16px;
	position: relative;
	text-transform: uppercase;
	z-index: 1;
}

.services-list {
	display: grid;
}

.services-list article {
	align-items: start;
	border-bottom: 1px solid rgba(34, 28, 23, 0.08);
	display: grid;
	gap: 24px;
	grid-template-columns: 52px minmax(0, 1fr);
	padding: 22px var(--site-gutter);
}

.services-list article:last-child {
	border-bottom: 0;
}

.services-list span {
	color: var(--color-clay);
	font-size: 0.82rem;
	font-weight: 900;
	letter-spacing: 0.14em;
	margin-top: 6px;
}

.services-list h3 {
	font-size: 1.38rem;
	margin-bottom: 8px;
}

.services-list p {
	margin-bottom: 0;
}

.why-section {
	background:
		linear-gradient(rgba(34, 28, 23, 0.026) 1px, transparent 1px),
		linear-gradient(90deg, rgba(34, 28, 23, 0.026) 1px, transparent 1px),
		#faf6ef;
	background-size: 44px 44px;
}

.why-section::before,
.process-section::before {
	display: none;
}

.why-section .section-heading,
.process-section .section-heading {
	margin-left: 0;
	margin-right: 0;
	max-width: 780px;
	text-align: left;
}

.why-list {
	border-bottom: 1px solid rgba(34, 28, 23, 0.12);
	border-top: 1px solid rgba(34, 28, 23, 0.12);
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-top: 36px;
}

.why-list .why-item {
	align-items: center;
	background: transparent;
	border: 0;
	border-bottom: 1px solid rgba(34, 28, 23, 0.08);
	display: flex;
	font-family: Inter, ui-sans-serif, system-ui, sans-serif;
	font-size: 1.02rem;
	line-height: 1.45;
	min-height: 92px;
	padding: 24px 28px 24px 0;
	text-align: left;
}

.why-list .why-item:nth-last-child(-n + 2) {
	border-bottom: 0;
}

.why-list .why-item::before {
	background: var(--color-charcoal);
	border: 0;
	border-radius: 999px;
	box-shadow: none;
	content: "";
	display: inline-block;
	flex: 0 0 auto;
	height: 9px;
	margin: 0 16px 0 0;
	width: 9px;
}

.process-flow {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 42px;
}

.process-flow article {
	background: rgba(255, 253, 248, 0.84);
	border-left: 3px solid var(--color-charcoal);
	border-radius: 0 24px 24px 0;
	padding: 30px;
}

.process-flow span {
	color: var(--color-clay);
	display: inline-block;
	font-size: 0.8rem;
	font-weight: 900;
	letter-spacing: 0.14em;
	margin-bottom: 24px;
}

.process-flow h3 {
	font-size: 1.44rem;
	margin-bottom: 14px;
}

.process-flow p {
	margin-bottom: 0;
}

@media (max-width: 980px) {
	.hero-grid,
	.services-editorial {
		grid-template-columns: 1fr;
	}

	.services-visual {
		min-height: 420px;
	}

	.process-flow {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 680px) {
	.hero-photo {
		min-height: 360px;
	}

	.hero-photo img {
		max-height: 330px;
	}

	.why-list {
		grid-template-columns: 1fr;
	}

	.why-list .why-item:nth-last-child(-n + 2) {
		border-bottom: 1px solid rgba(34, 28, 23, 0.08);
	}

	.why-list .why-item:last-child {
		border-bottom: 0;
	}

	.services-list article {
		grid-template-columns: 1fr;
		padding: 24px;
	}
}

/* Hero: text left, full-height image flush right */
.hero.section {
	padding: 0;
}

.hero-layout {
	align-items: stretch;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(340px, 46vw);
	min-height: clamp(520px, 78vh, 820px);
}

.hero-copy {
	align-self: center;
	justify-self: center;
	max-width: 820px;
}

.hero-copy h1 {
	font-size: clamp(3.8rem, 7.5vw, 6.6rem);
}

.hero-copy .hero-actions {
	margin-bottom: 0;
}

.hero-media {
	margin: 0;
	min-height: 100%;
	overflow: hidden;
	padding: 0;
}

.hero-media img {
	display: block;
	height: 100%;
	min-height: clamp(520px, 78vh, 820px);
	object-fit: cover;
	object-position: center;
	width: 100%;
}

@media (max-width: 980px) {
	.hero-layout {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 680px) {
	.hero-media img {
		min-height: 360px;
	}
}

/* Why Choose Us: icon cards after Services */
.why-section {
	border-block: 0;
	padding: 88px 0;
}

.why-heading {
	margin-inline: auto;
	text-align: center;
}

.why-heading h2 {
	font-size: clamp(2.4rem, 4.5vw, 3.6rem);
}

.why-cards {
	display: grid;
	gap: 52px 36px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 56px;
}

.why-card {
	align-items: center;
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	display: flex;
	flex-direction: column;
	gap: 18px;
	min-height: auto;
	padding: 0;
	text-align: center;
}

.why-card:hover {
	box-shadow: none;
	transform: none;
}

.why-icon {
	display: block;
	flex: 0 0 auto;
	height: 112px;
	object-fit: contain;
	width: 112px;
}

.why-card p {
	color: var(--color-muted);
	font-size: 1.28rem;
	font-weight: 400;
	line-height: 1;
	margin: 0 auto;
	max-width: 300px;
}

@media (max-width: 980px) {
	.why-cards {
		gap: 40px 28px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 680px) {
	.why-section {
		padding: 72px 0;
	}

	.why-cards {
		gap: 36px;
		grid-template-columns: 1fr;
	}

	.why-icon {
		height: 96px;
		width: 96px;
	}
}

/* Unified horizontal gutters across all sections */
.hero-copy {
	justify-self: center;
	max-width: 640px;
	width: min(92%, 640px);
}

@media (min-width: 981px) {
	.hero-copy {
		padding: clamp(48px, 7vw, 88px) clamp(18px, 3vw, 42px);
	}
}

/* Main section containers: consistent side gutters */
.section {
	padding-inline: 0;
}

.container,
.section > .container {
	margin-inline: auto;
	max-width: none;
	padding-inline: var(--site-gutter);
	width: 100%;
}

.intro-strip .container.intro-strip-inner {
	border-radius: 28px;
	margin: 10px auto 0;
	max-width: var(--container);
	padding: 20px 28px;
	width: calc(100% - 20px);
}

.section-heading {
	margin-left: clamp(10px, 2vw, 28px);
	margin-right: auto;
	max-width: 820px;
	text-align: left;
}

#services .section-heading,
.why-section .section-heading,
.process-section .section-heading {
	margin-left: auto;
	margin-right: auto;
	max-width: 860px;
	text-align: center;
}

#services .section-heading .eyebrow,
#services .section-heading h2,
#services .section-heading p,
.why-section .section-heading .eyebrow,
.why-section .section-heading h2,
.why-section .section-heading p,
.process-section .section-heading .eyebrow,
.process-section .section-heading h2,
.process-section .section-heading p {
	margin-left: auto;
	margin-right: auto;
}

#services .section-heading p {
	max-width: 720px;
}


.split-grid,
.contact-grid,
.seo-grid {
	gap: clamp(20px, 3vw, 42px);
	margin-inline: auto;
	max-width: 1320px;
	padding-inline: clamp(12px, 2vw, 28px);
}

.split-copy,
.contact-section .contact-grid > div:first-child,
.seo-grid > div{
	padding-left: clamp(20px, 2vw, 42px);
}


.image-panel,
.contact-visual {
	padding-inline: clamp(4px, 0.8vw, 12px);
}

@media (max-width: 680px) {
	.intro-strip .container.intro-strip-inner {
		align-items: flex-start;
		flex-direction: column;
		padding: 18px;
		width: calc(100% - 12px);
	}
}

#services .services-editorial {
	margin-inline: 0;
}

#services .services-list article {
	gap: 12px;
	grid-template-columns: 34px minmax(0, 1fr);
	padding: 10px var(--site-gutter);
}

#services .services-visual {
	padding: var(--site-gutter);
}

/* Process: 4 steps top row, 2 centered bottom row */
.process-flow {
	display: grid;
	gap: 64px 32px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin: 64px auto 0;
	max-width: 1200px;
	padding-inline: clamp(12px, 2vw, 28px);
}

.process-step {
	align-items: center;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
	display: flex;
	flex-direction: column;
	padding: 0 !important;
	position: relative;
	text-align: center;
	z-index: 1;
}

.process-step:nth-child(5) {
	grid-column: 2;
}

.process-step:nth-child(6) {
	grid-column: 3;
}

/* Dashed line through center of STEP badge */
.process-step:nth-child(-n+3)::after,
.process-step:nth-child(5)::after {
	border-top: 2px dashed rgba(34, 28, 23, 0.4);
	content: "";
	left: 50%;
	position: absolute;
	top: 28px;
	width: calc(100% + 32px);
	z-index: 0;
}

.process-step-badge {
	align-items: center;
	background: #391c14;
	border-radius: 999px;
	color: #fff;
	display: flex;
	font-family: Inter, ui-sans-serif, system-ui, sans-serif;
	font-size: clamp(0.95rem, 1.4vw, 1.15rem);
	font-weight: 600;
	height: 56px;
	justify-content: center;
	letter-spacing: 0.08em;
	margin-bottom: 28px;
	padding: 0 28px;
	position: relative;
	white-space: nowrap;
	z-index: 2;
}

.process-icon {
	align-items: center;
	background: #efe9e0;
	border: 3px solid #fff;
	border-radius: 50%;
	box-shadow: 0 0 0 1px rgba(34, 28, 23, 0.2);
	color: var(--color-ink);
	display: flex;
	height: 140px;
	justify-content: center;
	margin-bottom: 24px;
	transform: none;
	width: 140px;
}

.process-icon svg {
	display: block;
	height: 56px;
	transform: none;
	width: 56px;
}

.process-copy {
	max-width: 280px;
	padding-left: 0;
}

.process-copy h3 {
	font-size: clamp(1.1rem, 1.5vw, 1.25rem);
	margin-bottom: 12px;
}

.process-copy p {
	color: var(--color-muted);
	font-size: clamp(0.95rem, 1.2vw, 1.05rem);
	line-height: 1.45;
	margin: 0;
}

@media (max-width: 980px) {
	.process-flow {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.process-step:nth-child(5),
	.process-step:nth-child(6) {
		grid-column: auto;
	}
	.process-step:nth-child(-n+3)::after,
	.process-step:nth-child(5)::after {
		display: none;
	}
	.process-step:nth-child(odd):not(:nth-child(5))::after {
		border-top: 2px dashed rgba(34, 28, 23, 0.4);
		content: "";
		display: block;
		left: 50%;
		position: absolute;
		top: 28px;
		width: calc(100% + 32px);
		z-index: 0;
	}
}

.process-icon-wrap,
.process-step-title,
.process-overlay {
	display: none;
}

@media (max-width: 680px) {
	.process-flow {
		display: flex;
		flex-direction: column;
		gap: 28px;
		margin: 40px auto 0;
		padding: 0;
		width: min(100%, 320px);
	}

	.process-step {
		align-items: center;
		background: transparent !important;
		border: 0 !important;
		box-shadow: none !important;
		cursor: default;
		display: flex;
		flex-direction: column;
		height: auto;
		padding: 0 !important;
		position: relative;
		width: auto;
	}

	.process-step-badge {
		background: #391c14;
		border-radius: 999px;
		color: #fff;
		font-size: 0.8rem;
		font-weight: 600;
		height: auto;
		letter-spacing: 0.08em;
		margin-bottom: 14px;
		padding: 8px 18px;
		position: relative;
		top: auto;
		white-space: nowrap;
		z-index: 2;
	}

	.process-icon-wrap,
	.process-step-title {
		display: block;
	}

	.process-step-title {
		font-size: 0.95rem;
		line-height: 1.3;
		margin: 12px 0 0;
		max-width: 150px;
		text-align: center;
	}

	.process-copy {
		display: none;
	}

	.process-icon-wrap {
		cursor: pointer;
		position: relative;
	}

	.process-icon {
		background: #efe9e0;
		border: 3px solid #fff;
		border-radius: 50%;
		box-shadow: 0 0 0 1px rgba(34, 28, 23, 0.2);
		height: 110px;
		margin-bottom: 0;
		position: relative;
		transform: none;
		width: 110px;
		z-index: 2;
	}

	.process-icon svg {
		height: 44px;
		width: 44px;
	}

	.process-overlay {
		background: transparent;
		border-radius: 0;
		display: block;
		max-width: 148px;
		opacity: 0;
		padding: 0;
		pointer-events: none;
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		transition: opacity 0.25s ease;
		visibility: hidden;
		width: max-content;
		z-index: 3;
	}

	.process-overlay p {
		color: var(--color-ink);
		font-size: 0.78rem;
		font-weight: 500;
		line-height: 1.45;
		margin: 0;
	}

	.process-step:nth-child(odd) .process-overlay {
		left: calc(100% + 14px);
		right: auto;
		text-align: left;
	}

	.process-step:nth-child(even) .process-overlay {
		left: auto;
		right: calc(100% + 14px);
		text-align: right;
	}

	.process-step.is-active {
		z-index: 4;
	}

	.process-step.is-active .process-overlay {
		opacity: 1;
		pointer-events: auto;
		visibility: visible;
	}

	.process-step:nth-child(odd) {
		align-self: flex-start;
	}

	.process-step:nth-child(even) {
		align-self: flex-end;
	}

	.process-step::after {
		display: none !important;
	}

	.process-step:nth-child(odd):not(:last-child)::before {
		border-top: 2px dashed rgba(34, 28, 23, 0.4);
		content: "";
		left: 50%;
		position: absolute;
		top: 50%;
		transform: rotate(45deg);
		transform-origin: 0 0;
		width: 240px;
		z-index: -1;
	}

	.process-step:nth-child(even):not(:last-child)::before {
		border-top: 2px dashed rgba(34, 28, 23, 0.4);
		content: "";
		position: absolute;
		right: 50%;
		top: 50%;
		transform: rotate(-45deg);
		transform-origin: 100% 0;
		width: 240px;
		z-index: -1;
	}
}

/* Contact: details left, map right — no card block */
.contact-section .contact-grid {
	align-items: start;
	gap: clamp(24px, 4vw, 48px);
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
}

.contact-details {
	display: grid;
	font-style: normal;
	gap: 8px;
	margin-top: 32px;
}

.contact-details strong {
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.2rem;
	font-weight: 500;
}

.contact-details span,
.contact-details a {
	color: var(--color-muted);
	display: block;
	font-size: 1rem;
}

.contact-section .contact-map {
	border: 1px solid var(--color-line);
	border-radius: 28px;
	box-shadow: var(--shadow-soft);
	min-height: 420px;
	overflow: hidden;
	width: 100%;
}

.contact-section .contact-map iframe {
	border: 0;
	display: block;
	height: 100%;
	min-height: 420px;
	width: 100%;
}

@media (max-width: 980px) {
	.contact-section .contact-grid {
		grid-template-columns: 1fr;
	}
	.contact-section .contact-map,
	.contact-section .contact-map iframe {
		min-height: 320px;
	}
}

/* Hero: photo background + centered text on tablet & mobile */
@media (max-width: 980px) {
	.hero.section {
		padding: 0;
	}

	.hero.section .hero-layout {
		align-items: stretch !important;
		background-image: var(--hero-bg) !important;
		background-position: center top;
		background-repeat: no-repeat;
		background-size: cover;
		display: flex !important;
		flex-direction: column;
		grid-template-columns: none !important;
		justify-content: center !important;
		min-height: clamp(500px, 92vh, 860px) !important;
		position: relative;
	}

	.hero.section .hero-layout::before {
		background: linear-gradient(
			180deg,
			rgba(255, 253, 248, 0.35) 0%,
			rgba(255, 253, 248, 0.72) 55%,
			rgba(255, 253, 248, 0.96) 100%
		);
		content: "";
		inset: 0;
		pointer-events: none;
		position: absolute;
		z-index: 0;
	}

	.hero.section .hero-media {
		display: none !important;
	}

	.hero.section .hero-copy {
		align-self: center !important;
		justify-self: center !important;
		margin: 0;
		max-width: 100%;
		padding: clamp(16px, 4vh, 28px) var(--site-gutter) clamp(20px, 4vw, 28px) !important;
		position: relative;
		text-align: center !important;
		width: 100%;
		z-index: 1;
	}

	.hero.section .hero-copy .eyebrow {
		margin-bottom: 12px;
	}

	.hero.section .hero-copy h1 {
		font-size: clamp(2.55rem, 10.5vw, 3.75rem);
		line-height: 1.06;
		margin-bottom: 14px;
	}

	.hero.section .hero-copy .eyebrow,
	.hero.section .hero-copy h1,
	.hero.section .hero-copy .hero-lead {
		margin-left: auto;
		margin-right: auto;
		text-align: center;
	}

	.hero.section .hero-copy .hero-actions {
		justify-content: center;
		margin-top: 18px;
	}

	.hero.section .hero-copy .hero-lead {
		font-size: clamp(1.12rem, 4.2vw, 1.32rem);
		line-height: 1.55;
		margin-inline: auto;
		max-width: 36em;
	}
}

@media (max-width: 980px) {
	.section {
		padding: 56px 0;
	}

	.why-section {
		padding: 56px 0;
	}

	.intro-strip-inner {
		padding: 20px 22px;
	}
}

@media (max-width: 680px) {
	.section {
		padding: 48px 0;
	}

	.hero.section .hero-layout {
		min-height: clamp(360px, 56vh, 480px) !important;
	}

	.why-section {
		padding: 48px 0;
	}

	.why-cards {
		gap: 32px 24px;
		margin-top: 36px;
	}
}

/* Header actions + WhatsApp green */
.header-actions {
	align-items: center;
	display: flex;
	flex-shrink: 0;
	gap: 12px;
}

.header-cta--whatsapp,
.button-whatsapp {
	background: #25d366;
	color: #fff;
}

.header-cta--whatsapp:hover,
.button-whatsapp:hover {
	background: #1da851;
	color: #fff;
}

.button-icon {
	display: inline-flex;
	flex-shrink: 0;
	line-height: 0;
}

.button-icon svg {
	height: 18px;
	width: 18px;
}

.nav-toggle {
	align-items: center;
	background: transparent;
	border: 1px solid var(--color-line);
	border-radius: 12px;
	cursor: pointer;
	display: none;
	flex-direction: column;
	gap: 5px;
	height: 44px;
	justify-content: center;
	padding: 0;
	width: 44px;
}

.nav-toggle__bar {
	background: var(--color-ink);
	border-radius: 999px;
	display: block;
	height: 2px;
	width: 18px;
}

.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;
}

body.nav-open {
	overflow: hidden;
}

.contact-lead {
	color: var(--color-muted);
	font-size: 1.05rem;
	line-height: 1.6;
	margin: 0;
	max-width: 34ch;
}

.contact-section .contact-actions {
	margin-top: 24px;
}

@media (min-width: 981px) {
	.nav-toggle {
		display: none;
	}

	.primary-nav {
		display: block;
	}

	.nav-whatsapp {
		display: none;
	}
}

/* Mobile header: burger menu */
@media (max-width: 980px) {
	.header-inner {
		align-items: center;
		display: flex;
		flex-wrap: wrap;
		gap: 12px;
		grid-template-columns: none;
		min-height: 72px;
		padding-bottom: 14px;
		padding-top: 14px;
		position: relative;
	}

	.brand {
		flex: 1;
		min-width: 0;
	}

	.header-actions {
		margin-left: auto;
	}

	.header-cta--whatsapp {
		display: none;
	}

	.nav-toggle {
		display: inline-flex;
	}

	.primary-nav {
		background: rgba(246, 240, 232, 0.98);
		border: 1px solid var(--color-line);
		border-radius: 18px;
		box-shadow: var(--shadow-soft);
		display: none;
		flex-basis: 100%;
		margin-left: 0;
		margin-top: 4px;
		order: 3;
		padding: 18px 20px;
		width: 100%;
	}

	body.nav-open .primary-nav {
		display: block;
	}

	.menu {
		align-items: stretch;
		flex-direction: column;
		gap: 0;
		width: 100%;
	}

	.menu li {
		border-top: 1px solid var(--color-line);
	}

	.menu li:first-child {
		border-top: 0;
	}

	.menu a {
		display: block;
		padding: 14px 4px;
	}

	.nav-whatsapp {
		display: inline-flex;
		justify-content: center;
		margin-top: 16px;
		width: 100%;
	}
}

@media (max-width: 680px) {
	.seo-grid > p {
		padding-right: 0;
	}
}

/* Logo in header */
.brand-logo {
	border-radius: 50%;
	display: block;
	height: 52px;
	object-fit: cover;
	width: 52px;
}

/* SEO text: small left padding on all sizes */
.seo-grid > p {
	padding-left: clamp(12px, 2vw, 24px);
}

@media (max-width: 980px) {
	.seo-grid > p {
		padding-left: clamp(10px, 2vw, 16px);
		padding-right: 0;
	}
}

/* Services swiper: equal-height cards, left-aligned text */
.services-swiper .swiper-slide {
	display: flex;
	height: auto;
}

.services-swiper .service-card {
	display: flex;
	flex: 1;
	flex-direction: column;
	grid-template-columns: none;
	height: 100%;
	min-height: 480px;
	width: 100%;
}

.services-swiper .service-media {
	flex-shrink: 0;
	height: 300px;
	min-height: 300px;
	padding: 0;
	width: 100%;
}

.services-swiper .service-media::after {
	display: none;
}

.services-swiper .service-content {
	align-self: stretch;
	display: flex;
	flex: 1;
	flex-direction: column;
	padding: 24px;
	text-align: left;
}

.services-swiper .service-content h3 {
	font-size: 1.25rem;
	line-height: 1.25;
	margin-bottom: 12px;
	text-align: left;
}

.services-swiper .service-content p {
	flex: 1;
	font-size: 0.95rem;
	line-height: 1.55;
	max-width: none;
	text-align: left;
}

@media (max-width: 680px) {
	.services-swiper .service-card {
		min-height: 420px;
	}

	.services-swiper .service-media {
		height: 220px;
		min-height: 220px;
	}
}

/* About: transparent Atelier label + mobile layout */
.about-mobile-intro,
.about-mobile-body {
	display: none;
}

.about-photo .lab-photo-meta {
	background: transparent;
	box-shadow: none;
}

.about-photo .lab-photo-meta span {
	color: rgba(255, 253, 248, 0.82);
}

.about-photo .lab-photo-meta strong {
	color: #fffdf8;
}

@media (max-width: 980px) {
	#about .about-desktop-head,
	#about .about-desktop-text,
	#about .split-copy {
		display: none;
	}

	#about .about-mobile-intro,
	#about .about-mobile-body {
		display: block;
	}

	#about .about-mobile-intro {
		text-align: center;
	}

	#about .about-mobile-intro .eyebrow,
	#about .about-mobile-intro h2 {
		margin-inline: auto;
	}

	#about .about-grid {
		display: flex;
		flex-direction: column;
		gap: 20px;
		padding-inline: var(--site-gutter);
	}

	#about .about-mobile-intro h2 {
		font-size: clamp(1.85rem, 7.5vw, 2.5rem);
		margin-bottom: 0;
	}

	#about .image-panel {
		margin-inline: calc(50% - 50vw);
		max-width: 100vw;
		padding-inline: 0;
		width: 100vw;
	}

	#about .about-photo {
		border: 0;
		border-radius: 0;
		box-shadow: none;
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		min-height: clamp(420px, 65vh, 560px);
		width: 100%;
	}

	#about .about-photo::after {
		background: linear-gradient(
			180deg,
			rgba(34, 28, 23, 0.05) 0%,
			rgba(34, 28, 23, 0.45) 55%,
			rgba(34, 28, 23, 0.82) 100%
		);
	}

	#about .about-mobile-body {
		padding: 0 var(--site-gutter) clamp(28px, 6vw, 40px);
		position: relative;
		z-index: 2;
	}

	#about .about-mobile-body p {
		color: rgba(255, 253, 248, 0.92);
		font-size: 1.05rem;
		line-height: 1.55;
		margin-bottom: 16px;
		padding-left: 20px;
	}

	#about .about-mobile-body p:last-child {
		margin-bottom: 0;
	}

	#about .about-photo .lab-photo-meta {
		display: none;
	}
}

/* Footer: full width, no extra side padding */
.site-footer {
	padding-inline: clamp(16px, 3vw, 40px);
}

.site-footer .container {
	margin-inline: auto;
	max-width: 1200px;
	padding-inline: 0;
	width: 100%;
}

.footer-grid {
	align-items: start;
	gap: clamp(28px, 4vw, 56px);
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.footer-grid > div:first-child {
	margin-top: -6px;
	min-width: 0;
}

.footer-grid > div:first-child .footer-brand {
	font-size: 1.85rem;
	line-height: 1.05;
	margin-bottom: 16px;
	margin-top: 0;
}

.site-footer h2 {
	line-height: 1.2;
	margin-top: 0;
}

.footer-bottom {
	margin-inline: auto;
	max-width: 1200px;
	padding-inline: 0;
	width: 100%;
}

@media (max-width: 980px) {
	.footer-grid {
		gap: 32px;
		grid-template-columns: 1fr;
		text-align: center;
	}

	.footer-bottom {
		flex-direction: column;
		gap: 12px;
		text-align: center;
	}
}
