/*
Theme Name: Aaron Thorpe Warm
Theme URI: http://localhost/aaron-thorpe/
Author: Codex
Description: A warm, premium WordPress theme for Aaron Thorpe's therapy website.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 8.0
Text Domain: aaron-thorpe-warm
*/

:root {
	--cream: #fffaf0;
	--paper: #f8f1e6;
	--sand: #dfcdb2;
	--beige: #efe2cf;
	--sage: #b8c4ab;
	--olive: #6f7657;
	--olive-dark: #4e5842;
	--charcoal: #272720;
	--soft-charcoal: #565348;
	--clay: #aa6f52;
	--line: rgba(39, 39, 32, 0.14);
	--glass: rgba(255, 250, 240, 0.78);
	--shadow: 0 26px 80px rgba(39, 39, 32, 0.16);
	--font-serif: "Cormorant Garamond", Georgia, serif;
	--font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--type-hero: clamp(3.7rem, 6vw, 6.75rem);
	--type-page-title: clamp(3.4rem, 6vw, 6.25rem);
	--type-section-title: clamp(2.55rem, 4.6vw, 4.85rem);
	--type-statement: clamp(2.15rem, 4vw, 4rem);
	--type-card-title: clamp(1.72rem, 2.4vw, 2.28rem);
	--type-feature-title: clamp(2.8rem, 5vw, 4.8rem);
	--type-pull: clamp(1.9rem, 3.5vw, 3.35rem);
	--type-lead: clamp(1.12rem, 1.65vw, 1.32rem);
	--line-display: 0.98;
	--line-heading: 1.04;
	--line-body: 1.68;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background: var(--cream);
	color: var(--charcoal);
	font-family: var(--font-sans);
	font-size: 16px;
	line-height: var(--line-body);
}

body.admin-bar .site-header {
	top: 32px;
}

a {
	color: inherit;
}

img {
	display: block;
	max-width: 100%;
}

button,
input,
textarea {
	font: inherit;
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.site-shell {
	overflow: hidden;
	background:
		radial-gradient(circle at 8% 8%, rgba(184, 196, 171, 0.45), transparent 26rem),
		linear-gradient(180deg, var(--cream), #f5eadb 46%, var(--cream));
}

.section-inner {
	width: min(1180px, calc(100% - 44px));
	margin: 0 auto;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 30;
	background: rgba(255, 250, 240, 0.86);
	border-bottom: 1px solid var(--line);
	backdrop-filter: blur(22px);
}

.nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 78px;
	gap: 24px;
}

.brand {
	text-decoration: none;
}

.brand-mark,
.eyebrow {
	color: var(--olive-dark);
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.brand-mark {
	display: block;
}

.brand-name {
	display: block;
	margin-top: 2px;
	font-family: var(--font-serif);
	font-size: clamp(1.55rem, 2.3vw, 2rem);
	font-weight: 700;
	line-height: 0.95;
}

.nav-links {
	display: flex;
	align-items: center;
	gap: clamp(12px, 2vw, 26px);
	color: var(--soft-charcoal);
	font-size: 0.93rem;
	font-weight: 700;
}

.mobile-header-actions {
	display: none;
}

.mobile-menu-toggle {
	display: none;
}

.nav-links a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

.nav-links a:not(.button):hover,
.nav-links a:not(.button):focus-visible,
.text-link:hover,
.text-link:focus-visible {
	color: var(--charcoal);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
	outline: 3px solid rgba(111, 118, 87, 0.55);
	outline-offset: 3px;
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 0 22px;
	border: 1px solid transparent;
	border-radius: 999px;
	background: var(--charcoal);
	color: var(--cream);
	font-weight: 750;
	text-decoration: none;
	transition: transform 220ms ease, box-shadow 220ms ease, background 220ms ease, border-color 220ms ease;
}

.button:hover {
	background: #171713;
	box-shadow: var(--shadow);
	transform: translateY(-2px);
}

.button.secondary {
	background: rgba(255, 250, 240, 0.46);
	border-color: rgba(39, 39, 32, 0.22);
	color: var(--charcoal);
}

.button.secondary:hover {
	background: var(--cream);
	border-color: rgba(39, 39, 32, 0.35);
}

.wp-block-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
}

.wp-block-button {
	margin: 0;
	max-width: 100%;
}

.wp-block-button.button,
.wp-block-button.secondary {
	display: block;
	min-height: 0;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	color: inherit;
	font-weight: inherit;
	box-shadow: none;
	transform: none;
	transition: none;
}

.wp-block-button.button:hover,
.wp-block-button.secondary:hover {
	background: transparent;
	box-shadow: none;
	transform: none;
}

.wp-block-button.button .wp-block-button__link,
.wp-block-button.secondary .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 0 22px;
	border: 1px solid transparent;
	border-radius: 999px;
	background: var(--charcoal);
	color: var(--cream);
	font-weight: 750;
	box-sizing: border-box;
	white-space: normal;
	text-decoration: none;
	transition: transform 220ms ease, box-shadow 220ms ease, background 220ms ease, border-color 220ms ease;
}

.wp-block-button.button .wp-block-button__link:hover,
.wp-block-button.secondary .wp-block-button__link:hover {
	background: #171713;
	box-shadow: var(--shadow);
	transform: translateY(-2px);
}

.wp-block-button.secondary .wp-block-button__link {
	background: rgba(255, 250, 240, 0.46);
	border-color: rgba(39, 39, 32, 0.22);
	color: var(--charcoal);
}

.wp-block-button.secondary .wp-block-button__link:hover {
	background: var(--cream);
	border-color: rgba(39, 39, 32, 0.35);
}

.wp-block-columns {
	margin-bottom: 0;
}

.wp-block-image,
.wp-block-video {
	margin: 0;
}

.hero-grid > .wp-block-group__inner-container,
.page-hero-grid > .wp-block-group__inner-container,
.first-call-band > .wp-block-group__inner-container,
.fit-panel > .wp-block-group__inner-container,
.section-heading > .wp-block-group__inner-container,
.gateway-grid > .wp-block-group__inner-container,
.intro-layout > .wp-block-group__inner-container,
.about-layout > .wp-block-group__inner-container,
.booking-layout > .wp-block-group__inner-container,
.faq-layout > .wp-block-group__inner-container,
.form-layout > .wp-block-group__inner-container,
.video-focus > .wp-block-group__inner-container,
.story-layout > .wp-block-group__inner-container,
.split-copy > .wp-block-group__inner-container,
.first-session-panel > .wp-block-group__inner-container,
.editorial-grid > .wp-block-group__inner-container,
.about-belief-panel > .wp-block-group__inner-container,
.feeling-grid > .wp-block-group__inner-container,
.testimonial-grid > .wp-block-group__inner-container,
.specialism-grid > .wp-block-group__inner-container,
.specialism-editorial-grid > .wp-block-group__inner-container,
.specialism-compact-grid > .wp-block-group__inner-container,
.concept-grid > .wp-block-group__inner-container,
.trust-panel > .wp-block-group__inner-container,
.trust-list > .wp-block-group__inner-container,
.faq-reassurance > .wp-block-group__inner-container,
.faq-list > .wp-block-group__inner-container,
.privacy-notice-layout > .wp-block-group__inner-container,
.privacy-notice-list > .wp-block-group__inner-container {
	display: grid;
	grid-template-columns: inherit;
	gap: inherit;
	align-items: inherit;
}

.cred-strip > .wp-block-group__inner-container,
.home-video-caption > .wp-block-group__inner-container,
.next-panel > .wp-block-group__inner-container {
	display: flex;
	flex-wrap: wrap;
	align-items: inherit;
	justify-content: inherit;
	gap: inherit;
	width: 100%;
}

.home-video-caption > .wp-block-group__inner-container {
	flex-wrap: nowrap;
}

.gateway-card > .wp-block-group__inner-container,
.specialism-card.feature > .wp-block-group__inner-container {
	min-height: inherit;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	height: 100%;
}

.specialism-card.feature > .wp-block-group__inner-container {
	justify-content: flex-end;
}

.booking-panel > .wp-block-group__inner-container,
.privacy-card > .wp-block-group__inner-container,
.booking-mini > .wp-block-group__inner-container,
.editorial-card > .wp-block-group__inner-container,
.feeling-card > .wp-block-group__inner-container,
.specialism-card > .wp-block-group__inner-container,
.testimonial-card > .wp-block-group__inner-container,
.concept-card > .wp-block-group__inner-container,
.reflection-band > .wp-block-group__inner-container,
.pull-quote-panel > .wp-block-group__inner-container,
.approach-statement > .wp-block-group__inner-container,
.arrival-inner > .wp-block-group__inner-container {
	display: contents;
}

.hero {
	position: relative;
	min-height: calc(100vh - 78px);
	display: grid;
	align-items: center;
	padding: 78px 0 66px;
	isolation: isolate;
	background:
		radial-gradient(circle at 78% 28%, rgba(184, 196, 171, 0.38), transparent 26rem),
		radial-gradient(circle at 8% 92%, rgba(223, 205, 178, 0.5), transparent 24rem),
		linear-gradient(120deg, rgba(255, 250, 240, 0.98), rgba(248, 241, 230, 0.9));
}

.video-led-hero {
	min-height: calc(100vh - 78px);
	padding: clamp(56px, 7vw, 96px) 0 clamp(58px, 8vw, 100px);
	background:
		radial-gradient(circle at 76% 24%, rgba(184, 196, 171, 0.42), transparent 27rem),
		radial-gradient(circle at 10% 92%, rgba(223, 205, 178, 0.42), transparent 24rem),
		linear-gradient(180deg, #fffaf0 0%, #f8f1e6 72%, #fffaf0 100%);
}

.hero::after {
	content: "";
	position: absolute;
	inset: auto 0 0;
	height: 170px;
	background: linear-gradient(180deg, transparent, var(--cream));
	z-index: -1;
}

.video-led-hero::after {
	height: 120px;
}

.editorial-video-hero {
	grid-template-columns: minmax(0, 0.78fr) minmax(420px, 0.72fr);
	gap: clamp(40px, 5.8vw, 78px);
}

.home-video-stage {
	position: relative;
	width: 100%;
	max-width: 540px;
	justify-self: end;
}

.home-video-stage::before {
	content: "";
	position: absolute;
	inset: 9% -4% -7%;
	z-index: -1;
	border-radius: 999px;
	background: radial-gradient(circle, rgba(111, 118, 87, 0.18), transparent 65%);
	filter: blur(18px);
}

.home-video-frame {
	position: relative;
	overflow: hidden;
	border: 1px solid rgba(39, 39, 32, 0.14);
	border-radius: 12px;
	background: var(--charcoal);
	box-shadow: 0 34px 100px rgba(39, 39, 32, 0.22);
	transition: transform 260ms ease, box-shadow 260ms ease;
}

.home-video-frame video {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 5;
	min-height: 590px;
	max-height: 74vh;
	object-fit: cover;
	background: var(--charcoal);
	filter: saturate(0.86) contrast(0.95) sepia(0.08);
}

.home-video-frame:hover {
	box-shadow: 0 40px 120px rgba(39, 39, 32, 0.26);
	transform: translateY(-3px);
}

.home-video-frame:hover .custom-play-overlay {
	opacity: 0.98;
	transform: translate(-50%, -50%) scale(1.04);
}

.custom-play-overlay {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 4;
	width: 66px;
	height: 66px;
	display: grid;
	place-items: center;
	border: 1px solid rgba(255, 250, 240, 0.7);
	border-radius: 50%;
	background: rgba(255, 250, 240, 0.72);
	box-shadow: 0 0 0 12px rgba(255, 250, 240, 0.12);
	transform: translate(-50%, -50%);
	transition: opacity 220ms ease, transform 220ms ease, visibility 220ms ease;
	cursor: pointer;
}

.custom-play-overlay span {
	display: block;
	width: 0;
	height: 0;
	margin-left: 6px;
	border-top: 10px solid transparent;
	border-bottom: 10px solid transparent;
	border-left: 17px solid var(--charcoal);
}

.home-video-frame.is-playing .custom-play-overlay {
	opacity: 0;
	visibility: hidden;
	transform: translate(-50%, -50%) scale(0.92);
}

.home-video-caption {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	margin-top: 18px;
	padding: 16px 0 0;
	border-top: 1px solid rgba(39, 39, 32, 0.16);
	border-radius: 8px;
	color: var(--charcoal);
}

.home-video-caption span,
.home-video-caption h2 {
	flex: 0 0 auto;
	margin: 0;
	font-family: var(--font-serif);
	font-size: clamp(1.45rem, 2.4vw, 2rem);
	font-weight: 700;
	line-height: 1;
}

.home-video-caption p {
	max-width: 580px;
	margin: 0;
	color: var(--soft-charcoal);
	font-size: 0.94rem;
}

.ambient-word {
	position: absolute;
	z-index: -1;
	color: rgba(39, 39, 32, 0.045);
	font-family: var(--font-serif);
	font-size: clamp(6rem, 14vw, 15rem);
	font-weight: 700;
	line-height: 0.8;
	pointer-events: none;
	animation: drift 12s ease-in-out infinite alternate;
}

.video-led-hero .ambient-word {
	color: rgba(39, 39, 32, 0.035);
}

.word-one {
	top: 8%;
	left: 4%;
}

.word-two {
	right: 3%;
	bottom: 12%;
	animation-delay: 900ms;
}

.word-three {
	left: 38%;
	bottom: 4%;
	animation-delay: 1600ms;
}

.hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.78fr) minmax(420px, 0.72fr);
	gap: clamp(40px, 5.8vw, 78px);
	align-items: center;
}

.hero-copy {
	max-width: 770px;
}

.eyebrow {
	margin: 0 0 18px;
}

h1,
h2,
h3,
blockquote {
	text-wrap: balance;
}

.hero h1,
.page-hero h1,
.section-heading h2,
.intro-copy h2,
.about-copy h2,
.booking-copy h2,
.booking-copy h1,
.trust-panel h2,
.faq-layout h2,
.editorial-card h2,
.story-marker,
.video-aside h2 {
	margin: 0;
	font-family: var(--font-serif);
	font-weight: 700;
	letter-spacing: 0;
	line-height: var(--line-display);
}

.hero h1 {
	font-size: var(--type-hero);
	max-width: 740px;
}

.page-hero h1,
.booking-copy h1 {
	font-size: var(--type-page-title);
	max-width: 980px;
}

.lead {
	max-width: 680px;
	margin: 26px 0 0;
	color: var(--soft-charcoal);
	font-size: var(--type-lead);
	line-height: 1.58;
}

.hero-actions,
.booking-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 34px;
}

.availability-note {
	max-width: 600px;
	margin: 18px 0 0;
	color: var(--olive-dark);
	font-size: 0.96rem;
	font-weight: 650;
}

.cred-strip {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 40px;
}

.cred-strip span,
.cred-strip p {
	padding: 10px 14px;
	border: 1px solid rgba(39, 39, 32, 0.12);
	border-radius: 999px;
	background: rgba(255, 250, 240, 0.66);
	color: var(--soft-charcoal);
	font-size: 0.88rem;
	font-weight: 700;
	margin: 0;
}

.hero-portrait {
	position: relative;
	min-height: 660px;
	border-radius: 46% 46% 10px 10px;
	overflow: hidden;
	box-shadow: var(--shadow);
	background: var(--sand);
}

.hero-portrait img,
.video-card img,
.about-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero-portrait img {
	filter: saturate(0.94) contrast(0.96);
	transform: scale(1.01);
	animation: slowScale 14s ease-in-out infinite alternate;
}

.portrait-caption {
	position: absolute;
	right: 24px;
	bottom: 24px;
	left: 24px;
	padding: 22px;
	border: 1px solid rgba(255, 250, 240, 0.56);
	border-radius: 8px;
	background: rgba(39, 39, 32, 0.68);
	color: var(--cream);
	backdrop-filter: blur(16px);
}

.portrait-caption span {
	display: block;
	margin-bottom: 7px;
	font-family: var(--font-serif);
	font-size: 1.7rem;
	font-weight: 700;
	line-height: 1;
}

.portrait-caption p {
	margin: 0;
	color: rgba(255, 250, 240, 0.78);
}

.section {
	padding: clamp(66px, 8.5vw, 112px) 0;
}

.page-experience {
	background: var(--cream);
}

.page-hero {
	position: relative;
	padding: clamp(64px, 9vw, 124px) 0 clamp(52px, 6.5vw, 88px);
	background:
		radial-gradient(circle at 80% 18%, rgba(184, 196, 171, 0.34), transparent 24rem),
		linear-gradient(180deg, var(--cream), var(--paper));
}

.soft-hero {
	background:
		radial-gradient(circle at 14% 18%, rgba(223, 205, 178, 0.52), transparent 25rem),
		linear-gradient(180deg, var(--paper), var(--cream));
}

.page-hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.48fr);
	gap: clamp(36px, 7vw, 88px);
	align-items: center;
}

.narrow-page {
	max-width: 960px;
}

.page-portrait {
	min-height: 520px;
	overflow: hidden;
	border-radius: 46% 46% 8px 8px;
	box-shadow: var(--shadow);
}

.page-portrait img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.arrival-moment {
	padding: clamp(32px, 5vw, 56px) 0;
	background: linear-gradient(180deg, var(--cream), var(--paper));
}

.arrival-inner {
	position: relative;
	max-width: 900px;
	text-align: center;
}

.arrival-inner::before {
	content: "";
	display: block;
	width: 86px;
	height: 86px;
	margin: 0 auto 24px;
	border: 1px solid rgba(111, 118, 87, 0.28);
	border-radius: 50%;
	background: radial-gradient(circle, rgba(184, 196, 171, 0.28), transparent 58%);
	animation: breathe 5.8s ease-in-out infinite;
}

.arrival-inner p {
	margin: 0 auto;
	max-width: 760px;
	color: var(--soft-charcoal);
	font-family: var(--font-serif);
	font-size: var(--type-pull);
	line-height: 1.08;
}

.first-call-section {
	background: linear-gradient(180deg, var(--paper), var(--cream));
	padding-top: clamp(48px, 6vw, 78px);
}

.first-call-band {
	display: grid;
	grid-template-columns: minmax(0, 0.68fr) minmax(320px, 0.72fr);
	gap: clamp(30px, 6vw, 72px);
	align-items: start;
	padding: clamp(28px, 5vw, 54px);
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(255, 250, 240, 0.76);
	box-shadow: 0 20px 70px rgba(39, 39, 32, 0.06);
}

.first-call-band h2 {
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-statement);
	line-height: var(--line-heading);
}

.first-call-steps {
	display: grid;
	gap: 18px;
}

.first-call-steps p {
	margin: 0;
	padding: 0 0 18px;
	border-bottom: 1px solid rgba(39, 39, 32, 0.12);
}

.first-call-steps p:last-child {
	padding-bottom: 0;
	border-bottom: 0;
}

.first-call-steps strong,
.first-call-steps span {
	display: block;
}

.first-call-steps strong {
	margin-bottom: 5px;
	font-family: var(--font-serif);
	font-size: 1.55rem;
	line-height: 1;
}

.first-call-steps span {
	color: var(--soft-charcoal);
}

.fit-section {
	padding-top: 0;
	background: linear-gradient(180deg, var(--cream), var(--paper));
}

.fit-panel {
	display: grid;
	grid-template-columns: minmax(0, 0.76fr) minmax(300px, 0.58fr);
	gap: clamp(32px, 6vw, 76px);
	align-items: end;
	padding: clamp(34px, 6vw, 64px) 0;
	border-top: 1px solid rgba(39, 39, 32, 0.14);
	border-bottom: 1px solid rgba(39, 39, 32, 0.14);
}

.fit-panel h2 {
	max-width: 800px;
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-section-title);
	line-height: var(--line-display);
}

.fit-copy p {
	margin: 0 0 18px;
	color: var(--soft-charcoal);
	font-size: clamp(1.04rem, 1.7vw, 1.2rem);
}

.intro-section {
	background: var(--cream);
}

.gateway-section {
	background: linear-gradient(180deg, var(--cream), #f1e4d2);
}

.gateway-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.gateway-card {
	min-height: 280px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 28px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(255, 250, 240, 0.76);
	box-shadow: 0 20px 70px rgba(39, 39, 32, 0.06);
	text-decoration: none;
	transition: transform 220ms ease, box-shadow 220ms ease, background 220ms ease;
}

.gateway-card:hover {
	background: #fffdf7;
	box-shadow: var(--shadow);
	transform: translateY(-5px);
}

.gateway-card span,
.gateway-card > p:first-child {
	color: var(--clay);
	font-size: 0.8rem;
	font-weight: 800;
	letter-spacing: 0.14em;
	margin: 0;
}

.gateway-card h3 {
	margin: auto 0 12px;
	font-family: var(--font-serif);
	font-size: var(--type-card-title);
	line-height: var(--line-heading);
}

.gateway-card p {
	margin: 0;
	color: var(--soft-charcoal);
}

.home-reflection {
	padding-top: 0;
	background: var(--cream);
}

.reflection-band {
	padding: clamp(34px, 6vw, 62px);
	border-left: 4px solid var(--olive);
	background: var(--charcoal);
	color: var(--cream);
}

.reflection-band p {
	max-width: 840px;
	margin: 0 0 26px;
	font-family: var(--font-serif);
	font-size: var(--type-statement);
	line-height: var(--line-heading);
}

.text-link {
	color: var(--olive-dark);
	font-weight: 800;
	text-decoration-thickness: 1px;
	text-underline-offset: 6px;
}

.reflection-band .text-link,
.pull-quote-panel .text-link {
	color: var(--sage);
}

.intro-layout,
.about-layout,
.booking-layout,
.faq-layout {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(350px, 0.7fr);
	gap: clamp(36px, 7vw, 88px);
	align-items: center;
}

.video-card {
	position: relative;
	min-height: auto;
	overflow: hidden;
	border-radius: 8px;
	box-shadow: var(--shadow);
	background: var(--charcoal);
}

.video-card video {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 5;
	max-height: 720px;
	object-fit: cover;
	background: var(--charcoal);
}

.large-video video {
	aspect-ratio: 4 / 5;
	max-height: 780px;
}

.video-focus {
	display: grid;
	grid-template-columns: minmax(340px, 0.58fr) minmax(0, 0.62fr);
	gap: clamp(34px, 6vw, 78px);
	align-items: center;
}

.video-aside h2 {
	font-size: var(--type-statement);
}

.video-aside p {
	color: var(--soft-charcoal);
	font-size: 1.06rem;
}

.video-aside .button {
	margin-top: 18px;
}

.video-note {
	position: absolute;
	left: 22px;
	bottom: 22px;
	z-index: 3;
	padding: 10px 14px;
	border: 1px solid rgba(255, 250, 240, 0.34);
	border-radius: 999px;
	background: rgba(39, 39, 32, 0.56);
	color: var(--cream);
	backdrop-filter: blur(14px);
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.intro-copy h2,
.about-copy h2,
.booking-copy h2,
.trust-panel h2,
.faq-layout h2,
.section-heading h2 {
	font-size: var(--type-section-title);
}

.intro-copy p,
.about-copy p,
.booking-copy p,
.section-heading p,
.faq-list p,
.trust-list span,
.concept-card p,
.specialism-card p,
.feeling-card p {
	color: var(--soft-charcoal);
	font-size: 1.04rem;
}

.script-card {
	margin-top: 30px;
	padding: 26px;
	border-left: 4px solid var(--olive);
	background: var(--paper);
}

.script-card p {
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-card-title);
	line-height: var(--line-heading);
}

.connection-section,
.about-section,
.faq-section {
	background: var(--paper);
}

.story-section,
.editorial-section,
.approach-deep,
.video-focus-section {
	background: var(--cream);
}

.editorial-section {
	background: linear-gradient(180deg, var(--cream), #eef2e7);
}

.story-layout,
.split-copy {
	display: grid;
	grid-template-columns: minmax(260px, 0.46fr) minmax(0, 0.78fr);
	gap: clamp(34px, 7vw, 88px);
	align-items: start;
}

.story-marker {
	position: sticky;
	top: 118px;
	color: var(--olive-dark);
	font-size: var(--type-statement);
}

.story-copy p,
.split-copy p {
	margin: 0 0 24px;
	color: var(--soft-charcoal);
	font-size: clamp(1.08rem, 2vw, 1.28rem);
}

.pull-quote-panel {
	margin: 34px 0;
	padding: clamp(24px, 4vw, 36px);
	border-left: 4px solid var(--olive);
	background: var(--charcoal);
	color: var(--cream);
	font-family: var(--font-serif);
	font-size: var(--type-pull);
	line-height: var(--line-heading);
}

.approach-statement {
	margin-top: 18px;
	padding: clamp(28px, 5vw, 48px);
	border-radius: 8px;
	background: var(--charcoal);
	color: var(--cream);
}

.approach-statement p {
	max-width: 880px;
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-statement);
	line-height: var(--line-heading);
}

.first-session-section {
	background: linear-gradient(180deg, var(--cream), var(--paper));
}

.first-session-panel {
	display: grid;
	grid-template-columns: minmax(0, 0.7fr) minmax(300px, 0.62fr);
	gap: clamp(32px, 6vw, 76px);
	align-items: end;
	padding: clamp(32px, 5vw, 56px);
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(255, 250, 240, 0.72);
}

.first-session-panel .eyebrow {
	grid-column: 1 / -1;
	margin-bottom: -6px;
}

.first-session-panel h2 {
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-section-title);
	line-height: var(--line-display);
}

.first-session-panel p:not(.eyebrow) {
	margin: 0 0 18px;
	color: var(--soft-charcoal);
	font-size: clamp(1.04rem, 1.7vw, 1.2rem);
}

.first-session-panel p:last-child {
	margin-bottom: 0;
}

.split-copy h2 {
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-section-title);
	line-height: var(--line-display);
}

.editorial-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.editorial-card {
	min-height: 310px;
	padding: 30px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(255, 250, 240, 0.72);
	box-shadow: 0 20px 70px rgba(39, 39, 32, 0.06);
}

.editorial-card h2 {
	font-size: var(--type-card-title);
	line-height: var(--line-heading);
}

.editorial-card p {
	margin: 18px 0 0;
	color: var(--soft-charcoal);
}

.about-belief-section {
	padding-top: 0;
	background: linear-gradient(180deg, #eef2e7, var(--cream));
}

.about-belief-panel {
	display: grid;
	grid-template-columns: minmax(0, 0.72fr) minmax(300px, 0.58fr);
	gap: clamp(32px, 6vw, 76px);
	align-items: end;
	padding: clamp(34px, 6vw, 64px);
	border-radius: 8px;
	background: var(--charcoal);
	color: var(--cream);
}

.about-belief-panel .eyebrow {
	color: var(--sage);
}

.about-belief-panel h2 {
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-section-title);
	line-height: var(--line-display);
}

.about-belief-panel p:not(.eyebrow) {
	margin: 0 0 18px;
	color: rgba(255, 250, 240, 0.76);
	font-size: clamp(1.04rem, 1.7vw, 1.2rem);
}

.about-belief-panel p:last-child {
	margin-bottom: 0;
}

.section-heading {
	display: grid;
	grid-template-columns: minmax(0, 0.86fr) minmax(280px, 0.48fr);
	gap: 44px;
	align-items: end;
	margin-bottom: 46px;
}

.section-heading.narrow {
	display: block;
	max-width: 900px;
}

.section-heading.narrow p:last-child {
	max-width: 760px;
}

.feeling-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.connection-section .feeling-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.feeling-card,
.specialism-card,
.testimonial-card,
.concept-card,
.booking-panel,
.trust-panel,
.faq-list details {
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(255, 250, 240, 0.72);
	box-shadow: 0 20px 70px rgba(39, 39, 32, 0.06);
}

.feeling-card {
	min-height: 250px;
	padding: 28px;
}

.feeling-card span,
.feeling-card > p:first-child {
	display: block;
	margin-bottom: 52px;
	color: var(--clay);
	font-weight: 800;
}

.feeling-card h3,
.specialism-card h3,
.concept-card h3 {
	margin: 0 0 11px;
	font-family: var(--font-serif);
	font-size: var(--type-card-title);
	line-height: var(--line-heading);
}

.feeling-card p,
.specialism-card p,
.concept-card p {
	margin: 0;
}

.testimonial-section {
	background: linear-gradient(180deg, var(--cream), #efe3d3);
}

.testimonial-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.08fr) minmax(0, 0.8fr);
	gap: 18px;
	align-items: stretch;
}

.spacious-testimonials {
	align-items: start;
}

.testimonial-card {
	margin: 0;
	padding: 30px;
	background: rgba(255, 250, 240, 0.78);
}

.testimonial-card.featured {
	background: var(--charcoal);
	color: var(--cream);
	transform: translateY(-18px);
}

.testimonial-card blockquote {
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-pull);
	line-height: 1.08;
}

.testimonial-card figcaption {
	margin-top: 24px;
	color: var(--olive-dark);
	font-size: 0.85rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.testimonial-card.featured figcaption {
	color: rgba(255, 250, 240, 0.66);
}

.specialisms-section {
	background: linear-gradient(180deg, var(--cream), #f4eadb);
}

.specialism-note {
	max-width: 760px;
	margin: 0 0 34px;
	padding: 0 0 24px;
	border-bottom: 1px solid rgba(39, 39, 32, 0.14);
}

.specialism-note p {
	margin: 0;
	color: var(--soft-charcoal);
	font-family: var(--font-serif);
	font-size: var(--type-pull);
	line-height: 1.08;
}

.specialism-grid,
.concept-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.specialism-editorial-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(0, 0.95fr);
	gap: 16px;
	align-items: stretch;
}

.specialism-compact-grid {
	grid-column: 1 / -1;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.specialism-card,
.concept-card {
	min-height: 210px;
	padding: 28px;
	transition: transform 220ms ease, background 220ms ease, box-shadow 220ms ease;
}

.specialism-card.feature {
	min-height: 360px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: clamp(30px, 5vw, 52px);
	background: var(--charcoal);
	color: var(--cream);
}

.specialism-card.feature.muted {
	background: var(--olive-dark);
}

.specialism-card.feature span,
.specialism-card.feature > p:first-child {
	margin-bottom: auto;
	color: var(--sage);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.specialism-card.feature h3 {
	font-size: var(--type-feature-title);
}

.specialism-card.feature p {
	max-width: 560px;
	color: rgba(255, 250, 240, 0.76);
	font-size: clamp(1.06rem, 1.8vw, 1.22rem);
}

.specialism-card:hover,
.concept-card:hover {
	background: #fffdf7;
	box-shadow: var(--shadow);
	transform: translateY(-5px);
}

.specialism-card.feature:hover {
	background: #1f1f1a;
	box-shadow: 0 34px 100px rgba(39, 39, 32, 0.18);
}

.specialism-card.feature.muted:hover {
	background: #46503c;
}

.about-layout {
	grid-template-columns: minmax(320px, 0.55fr) minmax(0, 0.85fr);
}

.about-image {
	position: relative;
	min-height: 610px;
	overflow: hidden;
	border-radius: 8px;
	box-shadow: var(--shadow);
}

.about-image::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 44%, rgba(39, 39, 32, 0.28));
}

.about-copy p {
	margin: 22px 0 0;
}

.about-signature {
	margin-top: 34px;
	font-family: var(--font-serif);
	font-size: var(--type-card-title);
	color: var(--olive-dark);
}

.booking-section {
	background:
		linear-gradient(90deg, rgba(39, 39, 32, 0.92), rgba(39, 39, 32, 0.78)),
		url("assets/quiet-room.png") center / cover no-repeat;
	color: var(--cream);
}

.booking-hero {
	background:
		linear-gradient(90deg, rgba(39, 39, 32, 0.92), rgba(39, 39, 32, 0.76)),
		url("assets/quiet-room.png") center / cover no-repeat;
	color: var(--cream);
}

.booking-hero .lead {
	color: rgba(255, 250, 240, 0.78);
}

.booking-hero .eyebrow {
	color: var(--sage);
}

.booking-copy p {
	color: rgba(255, 250, 240, 0.76);
}

.booking-section .eyebrow {
	color: var(--sage);
}

.booking-section .button {
	background: var(--sage);
	color: var(--charcoal);
}

.booking-section .button.secondary {
	background: transparent;
	border-color: rgba(255, 250, 240, 0.42);
	color: var(--cream);
}

.booking-panel {
	padding: 28px;
	background: rgba(255, 250, 240, 0.92);
	color: var(--charcoal);
}

.booking-mini {
	padding: 0 0 20px;
	margin-bottom: 20px;
	border-bottom: 1px solid rgba(39, 39, 32, 0.12);
}

.booking-mini span {
	display: block;
	margin-bottom: 12px;
	color: var(--clay);
	font-size: 0.8rem;
	font-weight: 800;
	letter-spacing: 0.14em;
}

.booking-mini h3 {
	margin: 0 0 8px;
	font-family: var(--font-serif);
	font-size: var(--type-card-title);
	line-height: var(--line-heading);
}

.booking-mini p {
	margin: 0;
	color: var(--soft-charcoal);
}

.booking-panel .button {
	width: 100%;
	margin-top: 18px;
}

.form-section {
	background: linear-gradient(180deg, var(--cream), #eef2e7 58%, var(--paper));
}

.form-layout {
	display: grid;
	grid-template-columns: minmax(280px, 0.48fr) minmax(0, 0.82fr);
	gap: clamp(34px, 7vw, 88px);
	align-items: start;
}

.form-intro {
	position: sticky;
	top: 120px;
}

.form-intro h2 {
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-section-title);
	line-height: var(--line-display);
}

.form-intro > p {
	color: var(--soft-charcoal);
	font-size: 1.06rem;
}

.privacy-card {
	margin-top: 28px;
	padding: 24px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(255, 250, 240, 0.78);
}

.privacy-card + .privacy-card {
	margin-top: 16px;
}

.privacy-card strong {
	display: block;
	margin-bottom: 8px;
	font-family: var(--font-serif);
	font-size: clamp(1.45rem, 2vw, 1.72rem);
	line-height: var(--line-heading);
}

.privacy-card p {
	margin: 0;
	color: var(--soft-charcoal);
}

.support-note {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid rgba(39, 39, 32, 0.14);
}

.support-note strong {
	display: block;
	margin-bottom: 7px;
	color: var(--charcoal);
	font-size: 0.86rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.support-note p {
	margin: 0;
	color: var(--soft-charcoal);
	font-size: 0.95rem;
}

.contact-form-shell {
	padding: clamp(24px, 4vw, 42px);
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(255, 250, 240, 0.9);
	box-shadow: var(--shadow);
}

.form-notice {
	margin-bottom: 24px;
	padding: 20px 22px;
	border-radius: 8px;
}

.form-notice strong {
	display: block;
	margin-bottom: 6px;
	font-family: var(--font-serif);
	font-size: 1.65rem;
	line-height: 1;
}

.form-notice p {
	margin: 0;
}

.form-notice ol {
	margin: 14px 0 0;
	padding-left: 1.25rem;
}

.form-notice li + li {
	margin-top: 4px;
}

.form-notice .notice-small {
	margin-top: 14px;
	color: inherit;
	font-size: 0.92rem;
}

.form-notice.success {
	border: 1px solid rgba(111, 118, 87, 0.28);
	background: rgba(184, 196, 171, 0.22);
	color: var(--olive-dark);
}

.form-notice.error {
	border: 1px solid rgba(170, 111, 82, 0.34);
	background: rgba(170, 111, 82, 0.1);
	color: #704431;
}

.contact-form {
	display: grid;
	gap: 22px;
}

.form-row.two-columns {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.field label,
.consent-field {
	display: block;
	color: var(--charcoal);
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.field label span {
	color: var(--soft-charcoal);
	font-weight: 700;
	letter-spacing: 0;
	text-transform: none;
}

.field input,
.field select,
.field textarea {
	width: 100%;
	margin-top: 9px;
	border: 1px solid rgba(39, 39, 32, 0.18);
	border-radius: 8px;
	background: #fffdf7;
	color: var(--charcoal);
	padding: 15px 16px;
	outline: none;
	transition: border-color 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.field textarea {
	resize: vertical;
	min-height: 130px;
}

.field input:focus,
.field select:focus,
.field textarea:focus,
.consent-field input:focus {
	border-color: var(--olive);
	box-shadow: 0 0 0 4px rgba(184, 196, 171, 0.28);
	background: var(--cream);
}

.consent-field {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	padding: 18px;
	border: 1px solid rgba(39, 39, 32, 0.14);
	border-radius: 8px;
	background: rgba(248, 241, 230, 0.72);
	line-height: 1.45;
	text-transform: none;
	letter-spacing: 0;
}

.consent-field input {
	width: 20px;
	height: 20px;
	margin-top: 2px;
	accent-color: var(--olive);
	flex: 0 0 auto;
}

.consent-field a {
	color: var(--olive-dark);
	text-underline-offset: 4px;
}

.form-submit {
	width: 100%;
	min-height: 56px;
	border: 0;
	cursor: pointer;
}

.form-helper {
	margin: -4px 0 0;
	color: var(--soft-charcoal);
	font-size: 0.92rem;
}

.honeypot {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}

.trust-section {
	background: var(--cream);
}

.trust-panel {
	display: grid;
	grid-template-columns: minmax(0, 0.46fr) minmax(0, 0.8fr);
	gap: 44px;
	padding: clamp(28px, 5vw, 52px);
	background: var(--charcoal);
	color: var(--cream);
}

.trust-panel .eyebrow {
	color: var(--sage);
}

.trust-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 22px;
}

.trust-list p {
	margin: 0;
	padding-top: 18px;
	border-top: 1px solid rgba(255, 250, 240, 0.22);
}

.trust-list strong,
.trust-list span {
	display: block;
}

.trust-list strong {
	margin-bottom: 8px;
	font-size: 1rem;
}

.trust-list span {
	color: rgba(255, 250, 240, 0.68);
}

.faq-layout {
	align-items: start;
}

.faq-list {
	display: grid;
	gap: 14px;
}

.standalone-faq {
	max-width: 900px;
}

.faq-reassurance {
	display: grid;
	grid-template-columns: minmax(0, 0.78fr) minmax(280px, 0.46fr);
	gap: clamp(28px, 5vw, 68px);
	align-items: end;
	max-width: 1040px;
	margin-bottom: 34px;
	padding: clamp(28px, 5vw, 52px);
	border-radius: 8px;
	background: var(--charcoal);
	color: var(--cream);
}

.faq-reassurance .eyebrow {
	color: var(--sage);
	grid-column: 1 / -1;
	margin-bottom: -8px;
}

.faq-reassurance h2 {
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-section-title);
	line-height: var(--line-display);
}

.faq-reassurance p:last-child {
	margin: 0;
	color: rgba(255, 250, 240, 0.76);
	font-size: clamp(1.02rem, 1.8vw, 1.18rem);
}

.faq-list details {
	padding: 22px 24px;
}

.faq-list summary {
	cursor: pointer;
	font-family: var(--font-serif);
	font-size: clamp(1.45rem, 2vw, 1.72rem);
	font-weight: 700;
	line-height: var(--line-heading);
}

.faq-list p {
	margin: 16px 0 0;
}

.concept-section {
	background: linear-gradient(180deg, var(--cream), #ebe0ce);
}

.concept-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.concept-card {
	background: rgba(255, 250, 240, 0.62);
}

.privacy-notice-section {
	background: var(--paper);
}

.privacy-notice-layout {
	display: grid;
	grid-template-columns: minmax(240px, 0.44fr) minmax(0, 0.86fr);
	gap: clamp(32px, 6vw, 76px);
	align-items: start;
}

.privacy-intro {
	position: sticky;
	top: 118px;
}

.privacy-intro p {
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-pull);
	line-height: var(--line-heading);
}

.privacy-notice-list {
	display: grid;
	gap: 16px;
}

.privacy-notice-card {
	padding: clamp(24px, 4vw, 34px);
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(255, 250, 240, 0.78);
	box-shadow: 0 20px 70px rgba(39, 39, 32, 0.05);
}

.privacy-notice-card h2 {
	margin: 0 0 12px;
	font-family: var(--font-serif);
	font-size: var(--type-card-title);
	line-height: var(--line-heading);
}

.privacy-notice-card p {
	margin: 0;
	color: var(--soft-charcoal);
}

.page-next {
	padding: clamp(56px, 8vw, 96px) 0;
	background: var(--paper);
}

.next-panel {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 28px;
	padding: 30px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--cream);
}

.next-panel p {
	max-width: 660px;
	margin: 0;
	font-family: var(--font-serif);
	font-size: var(--type-pull);
	line-height: var(--line-heading);
}

.site-footer {
	padding: 34px 0;
	background: #191a16;
	color: rgba(255, 250, 240, 0.72);
	font-size: 0.94rem;
}

.footer-grid {
	display: grid;
	grid-template-columns: minmax(240px, 0.8fr) minmax(260px, 1fr) minmax(220px, 0.7fr);
	gap: 30px;
	align-items: start;
}

.footer-brand {
	display: block;
	margin-bottom: 8px;
	color: var(--cream);
	font-family: var(--font-serif);
	font-size: 1.8rem;
	line-height: 1;
}

.footer-grid p {
	margin: 0;
}

.footer-links {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 18px;
}

.footer-links a {
	color: rgba(255, 250, 240, 0.78);
	text-decoration: none;
}

.footer-links a:hover {
	color: var(--cream);
}

.reveal {
	animation: riseIn 760ms ease both;
}

@keyframes riseIn {
	from {
		opacity: 0;
		transform: translateY(22px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes slowScale {
	from {
		transform: scale(1.01);
	}
	to {
		transform: scale(1.06);
	}
}

@keyframes drift {
	from {
		transform: translate3d(0, 0, 0);
	}
	to {
		transform: translate3d(0, -18px, 0);
	}
}

@keyframes breathe {
	0%,
	100% {
		transform: scale(0.92);
		opacity: 0.56;
	}
	50% {
		transform: scale(1.1);
		opacity: 1;
	}
}

@media (prefers-reduced-motion: reduce) {
	* {
		animation-duration: 1ms !important;
		scroll-behavior: auto !important;
		transition-duration: 1ms !important;
	}
}

@media (max-width: 1080px) {
	.intro-layout,
	.about-layout,
	.booking-layout,
	.form-layout,
	.faq-layout,
	.first-call-band,
	.fit-panel,
	.first-session-panel,
	.faq-reassurance,
	.about-belief-panel,
	.privacy-notice-layout,
	.page-hero-grid,
	.video-focus,
	.story-layout,
	.split-copy,
	.trust-panel,
	.section-heading {
		grid-template-columns: 1fr;
	}

	.hero {
		min-height: auto;
	}

	.hero-portrait {
		min-height: 520px;
		border-radius: 8px;
	}

	.feeling-grid,
	.specialism-grid,
	.specialism-compact-grid,
	.concept-grid,
	.gateway-grid,
	.editorial-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.story-marker {
		position: static;
	}

	.form-intro {
		position: static;
	}

	.privacy-intro {
		position: static;
	}

	.footer-grid {
		grid-template-columns: 1fr;
	}

	.testimonial-grid {
		grid-template-columns: 1fr;
	}

	.testimonial-card.featured {
		transform: none;
	}
}

@media (max-width: 920px) {
	.hero-grid {
		grid-template-columns: 1fr;
	}

	.home-video-caption {
		align-items: flex-start;
		flex-direction: column;
		gap: 8px;
	}

	.home-video-stage {
		max-width: 680px;
		justify-self: start;
	}

	.home-video-frame video {
		min-height: 520px;
		max-height: none;
	}
}

@media (max-width: 760px) {
	:root {
		--type-hero: clamp(2.85rem, 12vw, 4.05rem);
		--type-page-title: clamp(2.65rem, 11vw, 3.75rem);
		--type-section-title: clamp(2.1rem, 8.8vw, 3.15rem);
		--type-statement: clamp(1.95rem, 8.4vw, 2.85rem);
		--type-card-title: clamp(1.55rem, 7vw, 2rem);
		--type-feature-title: clamp(2.4rem, 11vw, 3.55rem);
		--type-pull: clamp(1.85rem, 8vw, 2.75rem);
		--type-lead: 1.04rem;
		--line-display: 1.03;
		--line-heading: 1.08;
	}

	body.admin-bar .site-header {
		top: 46px;
	}

	.section-inner {
		width: min(100% - 30px, 1180px);
	}

	.nav {
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto;
		align-items: center;
		min-height: 72px;
		padding: 10px 0;
		gap: 12px;
	}

	.brand-mark {
		font-size: 0.58rem;
		letter-spacing: 0.08em;
	}

	.brand-name {
		font-size: 1.28rem;
	}

	.mobile-header-actions {
		display: flex;
		align-items: center;
		gap: 6px;
	}

	.mobile-quick-call {
		min-height: 38px;
		padding: 0 12px;
		font-size: 0.78rem;
	}

	.mobile-menu-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-height: 38px;
		padding: 0 11px;
		border: 1px solid rgba(39, 39, 32, 0.18);
		border-radius: 999px;
		background: rgba(255, 250, 240, 0.78);
		color: var(--charcoal);
		font-size: 0.78rem;
		font-weight: 800;
		cursor: pointer;
	}

	.nav-links {
		display: none;
		grid-column: 1 / -1;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		width: 100%;
		gap: 7px;
		padding: 8px 0 0;
		overflow: visible;
		font-size: 0.82rem;
	}

	.nav-links.is-open {
		display: grid;
	}

	.nav-links a:not(.button) {
		min-height: 38px;
		padding: 0 10px;
		border: 1px solid rgba(39, 39, 32, 0.12);
		border-radius: 999px;
		background: rgba(255, 250, 240, 0.58);
	}

	.nav-links .button {
		display: none;
		min-height: 38px;
		padding: 0 10px;
		font-size: 0.82rem;
	}

	.hero {
		padding: 38px 0 36px;
	}

	.hero h1 {
		font-size: var(--type-hero);
		line-height: var(--line-display);
	}

	.page-hero h1,
	.booking-copy h1 {
		font-size: var(--type-page-title);
		line-height: var(--line-display);
	}

	.hero h1,
	.page-hero h1,
	.section-heading h2,
	.intro-copy h2,
	.about-copy h2,
	.booking-copy h2,
	.booking-copy h1,
	.trust-panel h2,
	.faq-layout h2,
	.editorial-card h2,
	.story-marker,
	.video-aside h2 {
		line-height: 1.02;
	}

	.lead {
		margin-top: 18px;
		font-size: var(--type-lead);
		line-height: 1.56;
	}

	.hero-actions,
	.booking-actions {
		gap: 10px;
		margin-top: 24px;
	}

	.hero-actions .button {
		width: 100%;
		min-height: 48px;
	}

	.hero-actions .wp-block-button.button,
	.booking-actions .wp-block-button.button {
		width: 100%;
	}

	.hero-actions .wp-block-button.button .wp-block-button__link,
	.booking-actions .wp-block-button.button .wp-block-button__link {
		width: 100%;
	}

	.hero-actions .button.secondary {
		width: auto;
		min-height: 42px;
		padding: 0 16px;
	}

	.hero-actions .wp-block-button.secondary .wp-block-button__link {
		min-height: 42px;
		padding: 0 16px;
	}

	.availability-note {
		margin-top: 14px;
		font-size: 0.92rem;
	}

	.cred-strip {
		gap: 7px;
		margin-top: 20px;
	}

	.cred-strip span,
	.cred-strip p {
		padding: 8px 10px;
		font-size: 0.78rem;
	}

	.video-led-hero {
		padding-top: 30px;
	}

	.home-video-frame video {
		aspect-ratio: 4 / 5;
		min-height: 360px;
		max-height: none;
	}

	.home-video-caption {
		border-radius: 0;
	}

	.hero-portrait,
	.video-card,
	.about-image {
		min-height: 340px;
	}

	.video-card video {
		aspect-ratio: 4 / 5;
	}

	.ambient-word {
		display: none;
	}

	.section {
		padding: 54px 0;
	}

	.page-hero {
		padding: 52px 0 42px;
	}

	.arrival-moment {
		padding: 28px 0;
	}

	.arrival-inner::before {
		width: 58px;
		height: 58px;
		margin-bottom: 16px;
	}

	.arrival-inner p,
	.first-call-band h2,
	.fit-panel h2,
	.first-session-panel h2,
	.faq-reassurance h2,
	.about-belief-panel h2,
	.next-panel p,
	.reflection-band p {
		line-height: var(--line-heading);
	}

	.feeling-grid,
	.specialism-grid,
	.specialism-editorial-grid,
	.specialism-compact-grid,
	.concept-grid,
	.gateway-grid,
	.editorial-grid,
	.trust-list {
		grid-template-columns: 1fr;
	}

	.specialism-card.feature {
		min-height: 300px;
	}

	.fit-panel,
	.first-session-panel,
	.faq-reassurance,
	.about-belief-panel,
	.privacy-notice-layout {
		grid-template-columns: 1fr;
	}

	.form-row.two-columns {
		grid-template-columns: 1fr;
	}

	.next-panel {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* Gutenberg visual editing keeps content editable, but Group blocks add an
   inner wrapper. These rules put the original art-directed layouts back on
   that wrapper so the frontend keeps the premium composition. */
.hero-grid,
.page-hero-grid,
.first-call-band,
.fit-panel,
.section-heading,
.gateway-grid,
.intro-layout,
.about-layout,
.booking-layout,
.faq-layout,
.form-layout,
.video-focus,
.story-layout,
.split-copy,
.first-session-panel,
.editorial-grid,
.about-belief-panel,
.feeling-grid,
.testimonial-grid,
.specialism-grid,
.specialism-editorial-grid,
.specialism-compact-grid,
.concept-grid,
.trust-panel,
.trust-list,
.faq-reassurance,
.faq-list,
.privacy-notice-layout,
.privacy-notice-list {
	display: block;
}

.hero-grid > .wp-block-group__inner-container,
.page-hero-grid > .wp-block-group__inner-container,
.first-call-band > .wp-block-group__inner-container,
.fit-panel > .wp-block-group__inner-container,
.section-heading > .wp-block-group__inner-container,
.gateway-grid > .wp-block-group__inner-container,
.intro-layout > .wp-block-group__inner-container,
.about-layout > .wp-block-group__inner-container,
.booking-layout > .wp-block-group__inner-container,
.faq-layout > .wp-block-group__inner-container,
.form-layout > .wp-block-group__inner-container,
.video-focus > .wp-block-group__inner-container,
.story-layout > .wp-block-group__inner-container,
.split-copy > .wp-block-group__inner-container,
.first-session-panel > .wp-block-group__inner-container,
.editorial-grid > .wp-block-group__inner-container,
.about-belief-panel > .wp-block-group__inner-container,
.feeling-grid > .wp-block-group__inner-container,
.testimonial-grid > .wp-block-group__inner-container,
.specialism-grid > .wp-block-group__inner-container,
.specialism-editorial-grid > .wp-block-group__inner-container,
.specialism-compact-grid > .wp-block-group__inner-container,
.concept-grid > .wp-block-group__inner-container,
.trust-panel > .wp-block-group__inner-container,
.trust-list > .wp-block-group__inner-container,
.faq-reassurance > .wp-block-group__inner-container,
.faq-list > .wp-block-group__inner-container,
.privacy-notice-layout > .wp-block-group__inner-container,
.privacy-notice-list > .wp-block-group__inner-container {
	display: grid;
	grid-template-columns: inherit;
	gap: inherit;
	align-items: inherit;
	width: 100%;
}

.cred-strip,
.home-video-caption,
.next-panel {
	display: block;
}

.cred-strip > .wp-block-group__inner-container,
.home-video-caption > .wp-block-group__inner-container,
.next-panel > .wp-block-group__inner-container {
	display: flex;
	flex-wrap: wrap;
	align-items: inherit;
	justify-content: inherit;
	gap: inherit;
	width: 100%;
}

.home-video-caption > .wp-block-group__inner-container {
	flex-wrap: nowrap;
}
