/*
Theme Name: Theme 2018 Refactor
Theme URI: https://www.kosmetika-nehty-terezin.cz/
Author: Refactor for development
Description: Modernized responsive theme for Kosmetika Terezin.
Version: 2.0.0
Text Domain: theme2018
*/

@font-face {
	font-family: "Dancing Script";
	src: url("fonts/DancingScript-Regular.ttf") format("truetype");
	font-display: swap;
}

:root {
	--theme-bg: #f8f2ea;
	--theme-surface: #ffffff;
	--theme-surface-soft: #fff8f2;
	--theme-primary: #7b4a29;
	--theme-primary-dark: #3f2414;
	--theme-secondary: #ff6600;
	--theme-accent: #e6c8a5;
	--theme-text: #2d241f;
	--theme-text-muted: #6d625b;
	--theme-border: rgba(63, 36, 20, 0.12);
	--theme-shadow: 0 24px 70px rgba(47, 30, 18, 0.15);
	--theme-radius: 1.5rem;
	--theme-container: 1200px;
	--site-header-height: 5.75rem;
}

html {
	scroll-behavior: smooth;
}

body {
	background:
		radial-gradient(circle at top left, rgba(230, 200, 165, 0.34), transparent 35%),
		linear-gradient(180deg, #f9f4ef 0%, #f5ede4 100%);
	color: var(--theme-text);
	display: flex;
	flex-direction: column;
	font-family: "Manrope", Arial, sans-serif;
	font-size: 1rem;
	line-height: 1.7;
	min-height: 100vh;
	min-width: 320px;
	overflow-x: hidden;
}

a {
	color: var(--theme-primary);
	text-decoration: none;
	transition: color 0.2s ease, opacity 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

a:hover,
a:focus {
	color: var(--theme-primary-dark);
}

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

p,
ul,
ol {
	margin-bottom: 1.25rem;
}

ul,
ol {
	padding-left: 1.25rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	color: var(--theme-primary-dark);
	font-family: "Cormorant Garamond", Georgia, serif;
	font-weight: 600;
	letter-spacing: 0.01em;
	line-height: 1.1;
	margin-bottom: 1rem;
}

h1 {
	font-size: clamp(2.75rem, 6vw, 5rem);
}

h2 {
	font-size: clamp(2rem, 4.4vw, 3.3rem);
}

h3 {
	font-size: clamp(1.5rem, 3vw, 2rem);
}

.container {
	max-width: var(--theme-container);
}

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

.screen-reader-text:focus {
	background-color: #f1f1f1;
	clip: auto;
	-webkit-clip-path: none;
	clip-path: none;
	color: #111827;
	display: block;
	height: auto;
	left: 1rem;
	padding: 0.75rem 1rem;
	top: 1rem;
	width: auto;
	z-index: 100000;
}

.site-main {
	flex: 1 0 auto;
	overflow: clip;
}

.site-navbar {
	background: rgba(136, 103, 15, 0.95);
	backdrop-filter: blur(16px);
	box-shadow: 0 12px 36px rgba(28, 19, 12, 0.14);
	border-bottom: 3px solid #ff6600;
	padding: 1rem 0;
}

.site-navbar .container {
	max-width: 1440px;
}

.site-brand {
	align-items: flex-start;
	display: inline-flex;
	flex-direction: column;
	gap: 0.15rem;
	flex: 0 0 auto;
	text-transform: uppercase;
}

.site-brand__eyebrow {
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.32em;
}

.site-brand__name {
	color: #ffffff;
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(1.7rem, 3vw, 2.4rem);
	font-weight: 600;
	letter-spacing: 0.04em;
	line-height: 1;
	text-transform: none;
}

.navbar-nav > li {
	list-style: none;
}

.navbar-nav {
	align-items: center;
	gap: 0.25rem;
}

.navbar-nav > li > a {
	color: rgba(255, 255, 255, 0.9);
	display: inline-flex;
	font-size: 0.88rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	padding: 0.75rem 0.7rem;
	text-transform: uppercase;
	white-space: nowrap;
}

.navbar-nav > li > a:hover,
.navbar-nav > li > a:focus,
.navbar-nav > li > a.active {
	color: #ffffff;
}

.navbar-nav .sub-menu {
	background: rgba(42, 26, 16, 0.96);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 1rem;
	box-shadow: var(--theme-shadow);
	display: none;
	left: 0;
	list-style: none;
	margin: 0;
	min-width: 14rem;
	padding: 0.75rem 0;
	position: absolute;
	top: calc(100% + 0.5rem);
}

.navbar-nav li {
	position: relative;
}

.navbar-nav li:hover > .sub-menu,
.navbar-nav li:focus-within > .sub-menu {
	display: block;
}

.navbar-nav .sub-menu a {
	color: rgba(255, 255, 255, 0.86);
	display: block;
	font-size: 0.92rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	padding: 0.55rem 1.25rem;
	text-transform: none;
}

.menu-link-icon {
	align-items: center;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	color: rgba(255, 255, 255, 0.92);
	display: inline-flex;
	font-size: 0.62rem;
	font-weight: 800;
	height: 1.15rem;
	justify-content: center;
	margin-left: 0.45rem;
	opacity: 0.78;
	transform: translateY(-0.04em);
	vertical-align: middle;
	width: 1.15rem;
}

.menu-link-icon svg {
	display: block;
	fill: currentColor;
	height: 0.72rem;
	width: 0.72rem;
}

.navbar-nav > li > a .menu-link-icon,
.navbar-nav > li > a:hover .menu-link-icon,
.navbar-nav > li > a:focus .menu-link-icon,
.navbar-nav > li > a.active .menu-link-icon {
	color: rgba(255, 255, 255, 0.92);
}

.site-social-link {
	align-items: center;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 999px;
	color: #ffffff;
	display: inline-flex;
	flex: 0 0 auto;
	height: 3rem;
	justify-content: center;
	margin-left: 0.9rem;
	transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
	width: 3rem;
}

.site-social-link svg {
	fill: currentColor;
	height: 1.2rem;
	width: 1.2rem;
}

.site-social-link:hover,
.site-social-link:focus {
	background: #ff6600;
	border-color: #ff6600;
	color: #ffffff;
	transform: translateY(-1px);
}

.hero-section,
.page-hero {
	background-color: #2f1d13;
	background-position: center;
	background-size: cover;
	color: #ffffff;
	padding-top: calc(var(--site-header-height) + 4.5rem);
	padding-bottom: 4rem;
	position: relative;
}

.hero-section {
	min-height: min(52rem, 100vh);
	padding-bottom: 5rem;
	background-position: top center;
	display: flex;
	align-items: center;
}

.hero-panel,
.hero-highlight,
.page-hero__inner,
.content-card,
.service-card {
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--theme-radius);
	box-shadow: var(--theme-shadow);
}

.hero-panel,
.hero-highlight,
.page-hero__inner {
	background: rgba(255, 248, 242, 0.08);
	backdrop-filter: blur(10px);
	padding: clamp(1.75rem, 4vw, 3rem);
}

.hero-panel--home {
	text-align: center;
}

.hero-stack {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	justify-content: center;
}

.hero-panel--home,
.hero-panel--accent {
	margin-left: auto;
	margin-right: auto;
	max-width: 52rem;
	width: 100%;
}

.page-hero__inner {
	max-width: 52rem;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}

.hero-copy p:last-child,
.page-hero__excerpt p:last-child,
.entry-content > *:last-child {
	margin-bottom: 0;
}

.hero-copy--lead {
	font-size: clamp(1.3rem, 3vw, 2rem);
	font-family: Georgia, "Times New Roman", Times, serif;
	font-weight: 600;
	font-style: italic;
	line-height: 1.35;
	text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.9);
}

.hero-copy--lead p,
.hero-copy--secondary p,
.page-hero__excerpt,
.page-hero__inner h1 {
	overflow-wrap: break-word;
	word-break: normal;
	hyphens: auto;
}

.hero-copy--lead h1,
.hero-copy--lead h2,
.hero-copy--lead h3,
.hero-copy--accent h1,
.hero-copy--accent h2,
.hero-copy--accent h3 {
	color: #ffffff;
}

.hero-copy--accent {
	color: rgba(255, 255, 255, 0.9);
	font-size: 1.05rem;
	margin-top: 1.5rem;
}

.hero-panel--accent {
	background: rgba(255, 248, 242, 0.08);
	backdrop-filter: blur(10px);
	border-color: rgba(255, 255, 255, 0.08);
	padding: 1rem 1.5rem;
}

.hero-copy--secondary {
	font-family: Georgia, "Times New Roman", Times, serif;
	font-size: clamp(1.35rem, 2.7vw, 2rem);
	font-weight: 600;
	font-style: italic;
	line-height: 1.3;
	text-align: center;
	text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.9);
}

.hero-copy--secondary h1,
.hero-copy--secondary h2,
.hero-copy--secondary h3,
.hero-copy--secondary p {
	color: #ffffff;
	margin-bottom: 0;
}

.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 2rem;
}

.btn-brand {
	background: #ff6600;
	border: 0;
	border-radius: 999px;
	color: #fff;
	font-weight: 800;
	letter-spacing: 0.06em;
	padding: 0.95rem 1.6rem;
	text-transform: uppercase;
}

.btn-brand:hover,
.btn-brand:focus {
	background: #d85700;
	color: #fff;
}

.hero-highlight {
	color: rgba(255, 255, 255, 0.92);
}

.hero-highlight__eyebrow,
.section-heading__eyebrow,
.page-hero__eyebrow {
	color: var(--theme-accent);
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.24em;
	margin-bottom: 0.75rem;
	text-transform: uppercase;
}

.hero-highlight h1,
.page-hero h1 {
	color: #ffffff;
}

.services-section,
.content-section,
.map-section {
	padding: clamp(4rem, 6vw, 6rem) 0;
}

.services-section {
	position: relative;
}

.services-section::before {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.35), rgba(255, 255, 255, 0));
	content: "";
	inset: 0 0 auto;
	position: absolute;
	height: 12rem;
	pointer-events: none;
}

.section-heading {
	margin: 0 auto 2.5rem;
	max-width: 46rem;
	position: relative;
	z-index: 1;
}

.service-card {
	background: rgba(255, 255, 255, 0.72);
	border-color: var(--theme-border);
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 2rem 1.5rem;
	position: relative;
	text-align: center;
}

.service-card__icon {
	align-items: center;
	background: linear-gradient(180deg, #fffdf9 0%, #f6e6d4 100%);
	border-radius: 50%;
	display: inline-flex;
	height: 9rem;
	justify-content: center;
	margin-bottom: 1.5rem;
	margin-left: auto;
	margin-right: auto;
	padding: 1.25rem;
	width: 9rem;
}

.service-card__icon img {
	max-height: 100%;
	max-width: 100%;
	object-fit: contain;
}

.service-card h3 {
	font-size: 2rem;
	margin-bottom: 0.75rem;
}

.service-card h3 a {
	color: var(--theme-primary-dark);
}

.service-card p {
	color: var(--theme-text-muted);
	margin-bottom: 1.5rem;
}

.service-card__link {
	align-items: center;
	background: #ff6600;
	border-radius: 999px;
	color: #ffffff;
	display: inline-flex;
	font-size: 0.92rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	justify-content: center;
	margin-top: auto;
	min-width: 9rem;
	align-self: center;
	padding: 0.8rem 1.3rem;
	text-transform: uppercase;
}

.service-card__link:hover,
.service-card__link:focus {
	background: #d85700;
	color: #ffffff;
}

.btn-outline-light {
	border-width: 2px;
}

.btn-outline-light:hover,
.btn-outline-light:focus {
	background: #ff6600;
	border-color: #ff6600;
	color: #fff;
}

.content-section--soft {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.48), rgba(255, 255, 255, 0.72));
}

.content-card {
	background: var(--theme-surface);
	border-color: var(--theme-border);
	padding: clamp(1.75rem, 4vw, 3rem);
}

.content-card--narrow {
	margin: 0 auto;
	max-width: 52rem;
}

.entry-content {
	font-size: 1.05rem;
}

.entry-content,
.entry-content p,
.entry-content li,
.entry-content td,
.entry-content label {
	color: var(--theme-text);
}

.entry-content table {
	border-collapse: collapse;
	margin-bottom: 1.5rem;
	width: 100%;
}

.entry-content td,
.entry-content th {
	border-bottom: 1px solid rgba(63, 36, 20, 0.12);
	padding: 0.85rem 0.35rem;
	text-align: left;
}

.entry-content iframe {
	border: 0;
	border-radius: 1rem;
	display: block;
	max-width: 100%;
	width: 100%;
}

.entry-content .wp-block-image img,
.entry-content > p > img {
	border-radius: 1rem;
	box-shadow: 0 16px 40px rgba(47, 30, 18, 0.12);
}

.entry-content form,
.entry-content .wpcf7 {
	margin-top: 1.5rem;
}

.entry-content input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
.entry-content textarea,
.entry-content select {
	appearance: none;
	background: #fffdfa;
	border: 1px solid rgba(123, 74, 41, 0.2);
	border-radius: 0.95rem;
	box-shadow: inset 0 1px 2px rgba(47, 30, 18, 0.04);
	color: var(--theme-text);
	font-size: 1rem;
	padding: 0.95rem 1rem;
	width: 100%;
}

.entry-content textarea {
	min-height: 10rem;
	resize: vertical;
}

.entry-content input:focus,
.entry-content textarea:focus,
.entry-content select:focus {
	border-color: rgba(123, 74, 41, 0.55);
	box-shadow: 0 0 0 0.22rem rgba(216, 161, 103, 0.2);
	outline: 0;
}

.entry-content .wpcf7-submit,
.entry-content input[type="submit"],
.entry-content button[type="submit"] {
	background: #ff6600;
	border: 0;
	border-radius: 999px;
	color: #ffffff;
	cursor: pointer;
	font-size: 0.95rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	padding: 1rem 1.6rem;
	text-transform: uppercase;
	width: auto;
}

.entry-content .wpcf7-submit:hover,
.entry-content .wpcf7-submit:focus,
.entry-content input[type="submit"]:hover,
.entry-content input[type="submit"]:focus,
.entry-content button[type="submit"]:hover,
.entry-content button[type="submit"]:focus {
	background: #d85700;
}

.entry-content .wpcf7-spinner {
	display: block;
	margin-top: 0.75rem;
}

.entry-content .wpcf7-not-valid-tip {
	color: #a12626;
	font-size: 0.92rem;
	margin-top: 0.35rem;
}

.entry-content .wpcf7-response-output {
	border-radius: 1rem;
	margin: 1.25rem 0 0;
	padding: 0.9rem 1rem;
}

.price-page-intro {
	color: var(--theme-text-muted);
	font-size: 1.05rem;
	margin-bottom: 2rem;
}

.price-person {
	background: linear-gradient(180deg, #fffdfa 0%, #fff6ee 100%);
	border: 1px solid rgba(123, 74, 41, 0.12);
	border-radius: 1.25rem;
	box-shadow: 0 12px 30px rgba(47, 30, 18, 0.06);
	margin-bottom: 2rem;
	overflow: hidden;
}

.price-person__header {
	background: linear-gradient(135deg, rgba(136, 103, 15, 0.95), rgba(123, 74, 41, 0.92));
	color: #fff;
	padding: 1.2rem 1.4rem;
}

.price-person__header h2,
.price-person__header p {
	color: #fff;
	margin: 0;
}

.price-person__header h2 {
	font-size: clamp(1.8rem, 3vw, 2.4rem);
}

.price-person__role {
	font-size: 0.95rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin-top: 0.25rem;
	opacity: 0.92;
	text-transform: uppercase;
}

.price-person__contact {
	margin-top: 0.45rem;
}

.price-person__contact,
.price-person__contact a {
	color: rgba(255, 255, 255, 0.92);
	font-size: 1rem;
	font-weight: 700;
}

.price-person__contact a {
	text-decoration: underline;
	text-underline-offset: 0.16em;
}

.price-person__body {
	padding: 1.25rem 1.4rem 1.5rem;
}

.price-group {
	margin-bottom: 1.5rem;
}

.price-group:last-child {
	margin-bottom: 0;
}

.price-group h3 {
	font-size: 1.45rem;
	margin-bottom: 0.85rem;
}

.price-note {
	color: var(--theme-text-muted);
	font-size: 0.94rem;
	margin-top: 0.8rem;
}

.price-list {
	margin: 0;
}

.price-list tr:first-child td,
.price-list tr:first-child th {
	border-top: 1px solid rgba(63, 36, 20, 0.12);
}

.price-list td,
.price-list th {
	padding: 0.9rem 0.2rem;
	vertical-align: top;
}

.price-list td:last-child,
.price-list th:last-child {
	color: var(--theme-primary-dark);
	font-weight: 800;
	text-align: right;
	white-space: nowrap;
	width: 1%;
}

.price-list--compact td,
.price-list--compact th {
	padding-top: 0.65rem;
	padding-bottom: 0.65rem;
}

.service-price-box {
	background: linear-gradient(180deg, #fffdfa 0%, #fff6ee 100%);
	border: 1px solid rgba(123, 74, 41, 0.12);
	border-radius: 1.25rem;
	box-shadow: 0 12px 30px rgba(47, 30, 18, 0.06);
	margin-top: 2rem;
	padding: 1.35rem 1.4rem;
}

.service-price-box h2 {
	font-size: clamp(1.75rem, 3vw, 2.2rem);
	margin-bottom: 1rem;
}

.service-price-box h3 {
	font-size: 1.3rem;
	margin-bottom: 0.8rem;
}

.service-price-box__contact {
	color: var(--theme-text-muted);
	font-weight: 700;
	margin-bottom: 1rem;
}

.service-price-box__contact a {
	color: var(--theme-primary);
	text-decoration: underline;
	text-underline-offset: 0.16em;
}

.gallery-facebook {
	background: linear-gradient(180deg, #fffdfa 0%, #fff6ee 100%);
	border: 1px solid rgba(123, 74, 41, 0.12);
	border-radius: 1.25rem;
	box-shadow: 0 12px 30px rgba(47, 30, 18, 0.06);
	padding: 1.35rem 1.4rem;
}

.gallery-facebook p {
	margin: 0;
}

.gallery-facebook a {
	color: #7b4a29;
	font-size: 1.05rem;
	font-weight: 800;
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 0.18em;
}

.gallery-facebook a:hover,
.gallery-facebook a:focus {
	color: #d85700;
}

.map-section {
	padding-bottom: 0;
}

.map-section--page {
	padding-top: 0;
}

.map-embed {
	margin-top: 2rem;
}

.map-embed iframe {
	display: block;
	min-height: 28rem;
	width: 100%;
}

.site-footer {
	background: #241200;
	border-top: 5px solid #663300;
	color: rgba(255, 255, 255, 0.78);
	margin-top: auto;
	padding: 2rem 0;
}

.site-footer a {
	color: #ffffff;
}

.dancing-script {
	font-family: "Dancing Script", cursive;
	font-size: 150%;
	line-height: 1;
	text-decoration: none;
}

.site-footer__content {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem 1.5rem;
	justify-content: space-between;
}

.site-footer__brand,
.site-footer__meta {
	margin: 0;
}

.site-footer__brand {
	color: #ffffff;
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.6rem;
	font-weight: 600;
}

.site-footer__meta a {
	text-decoration: none;
}

.site-footer__meta a:hover,
.site-footer__meta a:focus {
	color: #ffcf9e;
}

@media (max-width: 991.98px) {
	.site-navbar {
		padding: 0.85rem 0;
	}

	.site-navbar .container {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.navbar-collapse {
		background: rgba(42, 26, 16, 0.96);
		border: 1px solid rgba(255, 255, 255, 0.08);
		border-radius: 1.25rem;
		margin-top: 1rem;
		padding: 1rem;
	}

	.navbar-nav .sub-menu {
		border: 0;
		box-shadow: none;
		display: block;
		margin-left: 0.75rem;
		margin-top: 0.25rem;
		padding: 0;
		position: static;
	}

	.navbar-nav > li > a,
	.navbar-nav .sub-menu a {
		padding-left: 0;
		padding-right: 0;
	}

	.menu-link-icon {
		margin-left: 0.3rem;
	}

	.hero-section,
	.page-hero {
		padding-top: calc(var(--site-header-height) + 3rem);
		padding-bottom: 3rem;
	}

	.hero-section {
		min-height: auto;
		display: block;
	}

	.page-hero__inner,
	.hero-panel--home,
	.hero-panel--accent {
		max-width: 100%;
	}

	.service-card {
		padding: 1.75rem 1.25rem;
	}
}

@media (max-width: 1199.98px) {
	.site-navbar {
		padding: 0.85rem 0;
	}

	.navbar-collapse {
		background: rgba(136, 103, 15, 0.98);
		border: 1px solid rgba(255, 255, 255, 0.08);
		border-radius: 1.25rem;
		margin-top: 1rem;
		padding: 1rem;
	}

	.navbar-nav .sub-menu {
		border: 0;
		box-shadow: none;
		display: block;
		margin-left: 0.75rem;
		margin-top: 0.25rem;
		padding: 0;
		position: static;
	}

	.navbar-nav > li > a,
	.navbar-nav .sub-menu a {
		padding-left: 0;
		padding-right: 0;
	}

	.site-social-link {
		margin-left: 0;
		margin-top: 0.75rem;
	}
}

@media (min-width: 1200px) {
	.site-brand {
		margin-right: 1.25rem;
		max-width: 18rem;
	}

	.site-brand__eyebrow {
		font-size: 0.62rem;
		letter-spacing: 0.24em;
	}

	.site-brand__name {
		font-size: 2rem;
	}

	.navbar-collapse {
		display: flex;
		flex-basis: auto;
		flex-grow: 1;
		justify-content: flex-end;
	}

	.navbar-nav {
		align-items: center;
		display: flex;
		flex-direction: row;
		flex-wrap: nowrap;
		justify-content: flex-end;
		width: 100%;
	}

	.navbar-nav > li {
		display: flex;
		flex: 0 0 auto;
	}
}

@media (max-width: 767.98px) {
	body {
		font-size: 0.98rem;
	}

	h1 {
		font-size: clamp(2rem, 10vw, 3rem);
		line-height: 1.05;
	}

	h2 {
		font-size: clamp(1.7rem, 8vw, 2.35rem);
	}

	h3 {
		font-size: clamp(1.35rem, 6.5vw, 1.75rem);
	}

	.site-brand__eyebrow {
		font-size: 0.58rem;
		letter-spacing: 0.2em;
	}

	.site-brand__name {
		font-size: 1.5rem;
	}

	.hero-section,
	.page-hero {
		padding-top: 9.5rem;
		padding-bottom: 2.5rem;
	}

	.hero-panel,
	.hero-highlight,
	.page-hero__inner,
	.content-card,
	.service-card {
		border-radius: 1.15rem;
	}

	.hero-panel,
	.page-hero__inner {
		padding: 1.4rem 1.15rem;
	}

	.hero-stack {
		gap: 0.75rem;
	}

	.hero-copy--lead {
		font-size: clamp(0.96rem, 4.8vw, 1.25rem);
		line-height: 1.3;
	}

	.hero-copy--secondary {
		font-size: clamp(0.98rem, 4.6vw, 1.2rem);
		line-height: 1.25;
	}

	.page-hero__eyebrow,
	.section-heading__eyebrow {
		font-size: 0.72rem;
		letter-spacing: 0.18em;
	}

	.page-hero__inner h1 {
		margin-bottom: 0.75rem;
	}

	.content-section,
	.services-section,
	.map-section {
		padding: 3rem 0;
	}

	.content-card {
		padding: 1.35rem 1rem;
	}

	.entry-content {
		font-size: 1rem;
	}

	.entry-content table,
	.entry-content tbody,
	.entry-content tr,
	.entry-content td,
	.entry-content th {
		display: block;
		width: 100%;
	}

	.entry-content td,
	.entry-content th {
		padding-left: 0;
		padding-right: 0;
	}

	.hero-actions {
		flex-direction: column;
	}

	.hero-actions .btn {
		width: 100%;
	}

	.map-embed iframe {
		min-height: 20rem;
	}

	.site-footer__content {
		align-items: flex-start;
		flex-direction: column;
	}
}

@media (max-width: 399.98px) {
	.site-navbar {
		padding: 0.75rem 0;
	}

	.site-brand__eyebrow {
		font-size: 0.54rem;
		letter-spacing: 0.16em;
	}

	.site-brand__name {
		font-size: 1.32rem;
	}

	.hero-section,
	.page-hero {
		padding-top: 10.25rem;
	}

	.hero-panel,
	.page-hero__inner {
		padding: 1.15rem 0.95rem;
	}

	.hero-copy--lead {
		font-size: 0.92rem;
		line-height: 1.25;
	}

	.hero-copy--secondary {
		font-size: 0.95rem;
		line-height: 1.22;
	}
}

@media (min-width: 768px) and (max-width: 1199.98px) {
	.hero-section,
	.page-hero {
		padding-top: calc(var(--site-header-height) + 2.75rem);
	}

	.hero-panel--home,
	.hero-panel--accent,
	.page-hero__inner {
		max-width: 44rem;
	}

	.hero-copy--lead {
		font-size: clamp(1.2rem, 3.2vw, 1.7rem);
	}

	.hero-copy--secondary {
		font-size: clamp(1.15rem, 2.8vw, 1.55rem);
	}

	.service-card h3 {
		font-size: 1.7rem;
	}
}
