/*
Theme Name: HTC
Theme URI: https://example.com/htc
Author: HTC
Description: Minimal hybrid block-first theme scaffold for HTC.
Version: 0.1.0
Requires at least: 6.5
Tested up to: 6.8
Requires PHP: 8.0
Text Domain: htc
*/

@font-face {
	font-display: swap;
	font-family: "HTC Editorial";
	font-style: normal;
	font-weight: 300 700;
	src: url("../twentytwentythree/assets/fonts/source-serif-pro/SourceSerif4Variable-Rom") format("woff2");
}

@font-face {
	font-display: swap;
	font-family: "HTC Sans";
	font-style: normal;
	font-weight: 400;
	src: url("../twentytwentythree/assets/fonts/dm-sans/DMSans-Regular.woff2") format("woff2");
}

@font-face {
	font-display: swap;
	font-family: "HTC Sans";
	font-style: normal;
	font-weight: 700;
	src: url("../twentytwentythree/assets/fonts/dm-sans/DMSans-Bold.woff2") format("woff2");
}

:root {
	--htc-color-navy: #0d1b2a;
	--htc-color-navy-soft: #13283d;
	--htc-color-stone: #f8f5f0;
	--htc-color-stone-deep: #eee7dc;
	--htc-color-gold: #c9a84c;
	--htc-color-gold-deep: #b28d34;
	--htc-color-text: #1a1a1a;
	--htc-color-muted: #626a70;
	--htc-color-subtle: #e5e0d8;
	--htc-color-white: #ffffff;
	--htc-space-2xs: 0.5rem;
	--htc-space-xs: 0.75rem;
	--htc-space-sm: 1rem;
	--htc-space-md: 1.5rem;
	--htc-space-lg: 2rem;
	--htc-space-xl: 3rem;
	--htc-space-2xl: 4.5rem;
	--htc-space-3xl: 6rem;
	--htc-radius: 8px;
	--htc-radius-sm: 6px;
	--htc-shadow-card: 0 18px 45px rgba(13, 27, 42, 0.08);
	--htc-shadow-soft: 0 10px 30px rgba(13, 27, 42, 0.06);
	--htc-serif: "HTC Editorial", "Cormorant Garamond", "Libre Baskerville", Georgia, serif;
	--htc-sans: "HTC Sans", "DM Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
	--htc-content-max: 1200px;
	--htc-content-gutter: clamp(1rem, 4vw, 2.5rem);
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	background: var(--htc-color-stone);
	color: var(--htc-color-text);
	font-family: var(--htc-sans);
	line-height: 1.65;
	overflow-x: hidden;
}

a {
	color: var(--htc-color-navy);
}

a:hover,
a:focus {
	color: var(--htc-color-navy-soft);
}

.wp-block-group {
	padding-left: var(--htc-space-sm);
	padding-right: var(--htc-space-sm);
}

.htc-site-header {
	position: sticky;
	top: 0;
	z-index: 20;
	background: rgba(255, 255, 255, 0.96);
	border-bottom: 1px solid var(--htc-color-subtle);
	backdrop-filter: blur(12px);
}

.htc-site-header__inner {
	align-items: center;
	min-height: 78px;
	gap: var(--htc-space-sm);
	justify-content: space-between;
}

.htc-site-logo {
	margin: 0;
	max-width: 150px;
}

.htc-site-logo img {
	display: block;
	height: auto;
	width: 100%;
}

.htc-site-header__actions {
	align-items: center;
	gap: var(--htc-space-sm);
	justify-content: flex-end;
	margin-left: auto;
	min-width: 0;
}

.htc-primary-nav {
	flex: 1 1 auto;
	min-width: 0;
}

.htc-primary-nav .wp-block-navigation__container {
	column-gap: clamp(0.55rem, 1.1vw, 1.15rem);
	row-gap: var(--htc-space-2xs);
}

.htc-primary-nav .wp-block-navigation-item__content {
	color: var(--htc-color-navy);
	font-size: clamp(0.8rem, 0.74rem + 0.22vw, 0.9rem);
	font-weight: 700;
	letter-spacing: -0.01em;
	line-height: 1.2;
	text-decoration: none;
	white-space: nowrap;
}

.htc-primary-nav .wp-block-navigation-item__content:hover,
.htc-primary-nav .wp-block-navigation-item__content:focus {
	color: var(--htc-color-gold-deep);
}

.htc-header-cta {
	flex: 0 0 auto;
	margin: 0;
}

.htc-header-cta .wp-block-button {
	width: auto;
}

.htc-header-cta .wp-block-button__link {
	display: inline-flex;
	min-width: max-content;
	text-align: center;
	white-space: nowrap;
	width: auto;
}

.htc-header-cta .wp-block-button__link,
.htc-section .wp-block-button__link,
.htc-page .wp-block-button__link {
	background: var(--htc-color-gold);
	border: 1px solid var(--htc-color-gold);
	border-radius: var(--htc-radius-sm);
	color: var(--htc-color-navy);
	display: inline-flex;
	font-size: 0.96rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1.2;
	padding: 0.95rem 1.35rem;
	text-decoration: none;
	transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.htc-section .wp-block-button {
	width: 100%;
}

.htc-page .wp-block-button {
	width: 100%;
}

.htc-section .wp-block-button__link,
.htc-page .wp-block-button__link {
	display: block;
	text-align: center;
	width: 100%;
}

.htc-header-cta .wp-block-button__link:hover,
.htc-header-cta .wp-block-button__link:focus,
.htc-section .wp-block-button__link:hover,
.htc-section .wp-block-button__link:focus,
.htc-page .wp-block-button__link:hover,
.htc-page .wp-block-button__link:focus {
	background: var(--htc-color-gold-deep);
	border-color: var(--htc-color-gold-deep);
	color: var(--htc-color-navy);
	transform: translateY(-1px);
}

.htc-header-cta .is-style-outline .wp-block-button__link,
.htc-section .is-style-outline .wp-block-button__link,
.htc-page .is-style-outline .wp-block-button__link {
	background: transparent;
	border-color: currentcolor;
	color: var(--htc-color-navy);
}

.htc-page-hero .is-style-outline .wp-block-button__link,
.htc-site-header--reduced .is-style-outline .wp-block-button__link {
	color: var(--htc-color-navy);
}

.htc-home {
	padding: 0;
	background: #060d15;
}

.htc-page {
	padding-bottom: var(--htc-space-2xl);
	padding-left: 0;
	padding-right: 0;
}

/* Inner pages: one aligned content column (homepage uses full-bleed .htc-home instead). */
body:not(.home) .htc-page .wp-block-group {
	padding-left: 0;
	padding-right: 0;
}

body:not(.home) .htc-page > .htc-page-hero,
body:not(.home) .htc-page > .htc-template-section,
body:not(.home) .htc-page > .htc-page-content-shell,
body:not(.home) .htc-page > .htc-section,
body:not(.home) .htc-page > .htc-split,
body:not(.home) .htc-page > .htc-v3-faq,
body:not(.home) .htc-page > .wp-block-group.alignfull,
body:not(.home) .htc-page > .wp-block-group {
	box-sizing: border-box;
	margin-left: auto;
	margin-right: auto;
	max-width: var(--htc-content-max);
	padding-left: var(--htc-content-gutter);
	padding-right: var(--htc-content-gutter);
	width: 100%;
}

body:not(.home) .htc-site-header,
body:not(.home) .htc-site-header .wp-block-group {
	padding-left: 0;
	padding-right: 0;
}

body:not(.home) .htc-site-header__inner {
	box-sizing: border-box;
	margin-left: auto;
	margin-right: auto;
	max-width: var(--htc-content-max);
	padding-left: var(--htc-content-gutter);
	padding-right: var(--htc-content-gutter);
	width: 100%;
}

body:not(.home) .htc-site-footer,
body:not(.home) .htc-site-footer .wp-block-group {
	padding-left: 0;
	padding-right: 0;
}

body:not(.home) .htc-site-footer__inner {
	box-sizing: border-box;
	margin-left: auto;
	margin-right: auto;
	max-width: var(--htc-content-max);
	padding-left: var(--htc-content-gutter);
	padding-right: var(--htc-content-gutter);
	width: 100%;
}

/* WordPress constrained layout indents block children — keep inner-page copy aligned. */
body:not(.home) .htc-page .is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
	margin-left: 0;
	margin-right: 0;
	max-width: none;
}

body:not(.home) .htc-template-section > * {
	margin-left: 0;
	margin-right: 0;
	max-width: none;
}

.htc-section {
	margin-bottom: var(--htc-space-2xl);
}

.htc-section h1,
.htc-section h2,
.htc-section h3,
.htc-page h1,
.htc-page h2,
.htc-page h3,
.htc-site-footer h3 {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.04;
	margin-top: 0;
}

.htc-section h1 {
	font-size: clamp(2.75rem, 9vw, 4.75rem);
	margin-bottom: var(--htc-space-md);
	max-width: 11ch;
}

.htc-page h1,
.htc-page-title {
	font-size: clamp(2.5rem, 8vw, 4.3rem);
	line-height: 1.04;
	margin: 0 0 var(--htc-space-md);
	max-width: 12ch;
}

.htc-section h2 {
	font-size: clamp(2rem, 6vw, 3.35rem);
	margin-bottom: var(--htc-space-md);
	max-width: 13ch;
}

.htc-section h3 {
	font-size: clamp(1.4rem, 4vw, 1.75rem);
	margin-bottom: var(--htc-space-xs);
}

.htc-section p {
	max-width: 66ch;
}

.htc-page-hero {
	background: var(--htc-color-navy);
	border-radius: var(--htc-radius);
	box-sizing: border-box;
	color: var(--htc-color-white);
	margin-bottom: var(--htc-space-xl);
	margin-top: var(--htc-space-lg);
	overflow: hidden;
	padding-bottom: var(--htc-space-2xl);
	padding-top: var(--htc-space-2xl);
	position: relative;
}

body:not(.home) .htc-page-hero {
	margin-top: var(--htc-space-md);
}

.htc-page-hero::before {
	background: linear-gradient(135deg, rgba(201, 168, 76, 0.14), rgba(255, 255, 255, 0));
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.htc-page-hero > * {
	position: relative;
	z-index: 1;
}

.htc-page-hero h1,
.htc-page-hero p {
	color: var(--htc-color-white);
}

.htc-page-standfirst {
	color: rgba(255, 255, 255, 0.78);
	font-size: clamp(1.05rem, 3vw, 1.25rem);
	line-height: 1.7;
	margin-bottom: 0;
	max-width: 42rem;
}

.htc-page-content-shell,
.htc-post-listing {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	margin-bottom: var(--htc-space-2xl);
	padding-bottom: var(--htc-space-xl);
	padding-top: var(--htc-space-xl);
}

.htc-page-content-shell > *,
.htc-post-listing > * {
	margin-left: auto;
	margin-right: auto;
	max-width: 780px;
}

.htc-page-content-shell p,
.htc-page-content-shell li {
	color: var(--htc-color-text);
	font-size: 1rem;
	line-height: 1.75;
}

.htc-page-content-shell h2,
.htc-page-content-shell h3 {
	margin-top: var(--htc-space-lg);
}

.htc-eyebrow {
	color: var(--htc-color-gold);
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	margin-bottom: var(--htc-space-sm);
	text-transform: uppercase;
}

.htc-section--hero,
.htc-section--final-cta {
	background: var(--htc-color-navy);
	border-radius: var(--htc-radius);
	color: var(--htc-color-white);
	overflow: hidden;
	padding-bottom: var(--htc-space-2xl);
	padding-top: var(--htc-space-2xl);
	position: relative;
}

.htc-section--hero::before,
.htc-section--final-cta::before {
	background: linear-gradient(135deg, rgba(201, 168, 76, 0.14), rgba(255, 255, 255, 0));
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.htc-section--hero > *,
.htc-section--final-cta > * {
	position: relative;
	z-index: 1;
}

.htc-section--hero h1,
.htc-section--final-cta h2,
.htc-section--hero a,
.htc-section--final-cta a {
	color: var(--htc-color-white);
}

.htc-section--hero h1,
.htc-section--final-cta h2 {
	color: var(--htc-color-white);
}

.htc-section--hero .wp-block-button__link,
.htc-section--final-cta .wp-block-button__link {
	background: var(--htc-color-gold);
	color: var(--htc-color-navy);
}

.htc-hero-grid {
	align-items: center;
	gap: var(--htc-space-xl);
}

.htc-hero-intro {
	color: rgba(255, 255, 255, 0.82);
	font-size: clamp(1.08rem, 3vw, 1.28rem);
	line-height: 1.65;
	margin-bottom: var(--htc-space-lg);
	max-width: 34rem;
}

.htc-hero-reassurance,
.htc-cta-note {
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.95rem;
	margin-bottom: 0;
	margin-top: var(--htc-space-md);
}

.htc-button-row {
	margin-bottom: 0;
}

.htc-proof-panel {
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--htc-radius);
	padding: var(--htc-space-md);
}

.htc-proof-panel__label,
.htc-proof-panel__meta {
	color: var(--htc-color-gold);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	margin: 0 0 var(--htc-space-xs);
	text-transform: uppercase;
}

.htc-proof-panel__title {
	color: var(--htc-color-white);
	font-family: var(--htc-serif);
	font-size: clamp(2rem, 7vw, 3rem);
	line-height: 1;
	margin: 0;
}

.htc-proof-panel__text {
	color: rgba(255, 255, 255, 0.76);
	margin: var(--htc-space-xs) 0 var(--htc-space-sm);
}

.htc-proof-panel__image,
.htc-portrait-placeholder {
	align-items: center;
	aspect-ratio: 4 / 5;
	background: linear-gradient(145deg, rgba(248, 245, 240, 0.18), rgba(201, 168, 76, 0.08));
	border: 1px dashed rgba(255, 255, 255, 0.26);
	border-radius: var(--htc-radius);
	color: rgba(255, 255, 255, 0.68);
	display: flex;
	font-size: 0.9rem;
	justify-content: center;
	margin-top: var(--htc-space-md);
	min-height: 260px;
	padding: var(--htc-space-md);
	text-align: center;
}

.htc-section-intro {
	color: var(--htc-color-muted);
	font-size: 1.05rem;
	line-height: 1.75;
	margin-bottom: var(--htc-space-lg);
	max-width: 60ch;
}

.htc-inline-list {
	display: grid;
	gap: var(--htc-space-xs);
	list-style: none;
	margin: 0;
	padding: 0;
}

.htc-inline-list li {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	padding: var(--htc-space-md);
}

.htc-inline-list span,
.htc-treatment-list span,
.htc-testimonial-card span,
.htc-result-card__label {
	color: var(--htc-color-muted);
	display: block;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.htc-inline-list strong {
	color: var(--htc-color-navy);
	display: block;
	font-size: 1.08rem;
	margin-top: var(--htc-space-2xs);
}

.htc-placeholder-card {
	background: var(--htc-color-white);
	border: 1px dashed #b9b09d;
	border-radius: var(--htc-radius);
	min-height: 120px;
	padding: var(--htc-space-md);
}

.htc-results-grid,
.htc-testimonial-grid {
	gap: var(--htc-space-md);
}

.htc-result-card,
.htc-testimonial-card,
.htc-section--treatments li {
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
}

.htc-result-card {
	padding: var(--htc-space-sm);
}

.htc-result-card__images {
	display: grid;
	gap: var(--htc-space-xs);
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.htc-result-card__images span {
	align-items: center;
	aspect-ratio: 3 / 4;
	background: var(--htc-color-stone-deep);
	border: 1px dashed #b9b09d;
	border-radius: var(--htc-radius-sm);
	color: var(--htc-color-muted);
	display: flex;
	font-size: 0.85rem;
	justify-content: center;
	padding: var(--htc-space-sm);
	text-align: center;
}

.htc-result-card__label {
	margin: var(--htc-space-sm) 0 0;
}

.htc-process-steps .wp-block-column {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	padding: var(--htc-space-lg);
}

.htc-step-number {
	color: var(--htc-color-gold);
	display: block;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	margin-bottom: var(--htc-space-sm);
}

.htc-doctor-grid {
	align-items: center;
	gap: var(--htc-space-xl);
}

.htc-section--doctor {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	padding-bottom: var(--htc-space-xl);
	padding-top: var(--htc-space-xl);
}

.htc-portrait-placeholder {
	background: linear-gradient(145deg, var(--htc-color-stone), var(--htc-color-stone-deep));
	border-color: #b9b09d;
	color: var(--htc-color-muted);
	margin-top: 0;
}

.htc-credential-line {
	align-items: flex-start;
	border-left: 3px solid var(--htc-color-gold);
	display: flex;
	flex-direction: column;
	gap: var(--htc-space-2xs);
	margin-bottom: var(--htc-space-lg);
	padding-left: var(--htc-space-sm);
}

.htc-credential-line span {
	color: var(--htc-color-muted);
	font-size: 0.95rem;
}

.htc-section--treatments ul {
	display: grid;
	gap: var(--htc-space-sm);
	list-style: none;
	margin: 0;
	padding: 0;
}

.htc-section--treatments li {
	padding: 0;
}

.htc-section--treatments li a {
	display: block;
	min-height: 100%;
	padding: var(--htc-space-md);
	text-decoration: none;
}

.htc-section--treatments li a:hover,
.htc-section--treatments li a:focus {
	background: var(--htc-color-white);
	color: var(--htc-color-navy);
}

.htc-treatment-list strong {
	color: var(--htc-color-navy);
	display: block;
	font-family: var(--htc-serif);
	font-size: 1.35rem;
	font-weight: 400;
	line-height: 1.1;
	margin-top: var(--htc-space-xs);
}

.htc-testimonial-card {
	min-height: 180px;
	padding: var(--htc-space-lg);
}

.htc-testimonial-card p {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: 1.6rem;
	line-height: 1.15;
	margin-top: 0;
}

.htc-disclaimer {
	color: var(--htc-color-muted);
	font-size: 0.9rem;
	font-style: italic;
	margin-top: var(--htc-space-md);
}

.htc-section--final-cta {
	text-align: left;
}

.htc-section--final-cta .htc-section-intro {
	color: rgba(255, 255, 255, 0.78);
}

.htc-section--private-hero {
	background: linear-gradient(135deg, var(--htc-color-stone), #fffaf2);
	border: 1px solid var(--htc-color-subtle);
	color: var(--htc-color-text);
	padding-bottom: var(--htc-space-2xl);
	padding-top: var(--htc-space-2xl);
}

.htc-section--private-hero::before {
	background: linear-gradient(135deg, rgba(201, 168, 76, 0.1), rgba(13, 27, 42, 0));
}

.htc-section--private-hero h1,
.htc-section--private-hero p,
.htc-section--private-hero a {
	color: var(--htc-color-navy);
}

.htc-section--private-hero h1 {
	font-size: clamp(2.9rem, 8vw, 5.2rem);
	max-width: 12ch;
}

.htc-section--private-hero .htc-hero-intro {
	color: var(--htc-color-text);
}

.htc-section--private-hero .htc-hero-reassurance {
	color: var(--htc-color-muted);
}

.htc-private-hero__grid {
	align-items: center;
	gap: var(--htc-space-xl);
}

.htc-credential-panel {
	background: var(--htc-color-navy);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: var(--htc-radius);
	color: var(--htc-color-white);
	padding: clamp(1.5rem, 4vw, 2.4rem);
}

.htc-credential-panel--light {
	background: var(--htc-color-stone);
	border-color: var(--htc-color-subtle);
	color: var(--htc-color-navy);
}

.htc-credential-panel__label,
.htc-credential-panel__gmc {
	color: var(--htc-color-gold);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.11em;
	margin: 0 0 var(--htc-space-xs);
	text-transform: uppercase;
}

.htc-credential-panel--light .htc-credential-panel__label,
.htc-credential-panel--light .htc-credential-panel__gmc {
	color: var(--htc-color-gold-deep);
}

.htc-credential-panel__name {
	color: inherit;
	font-family: var(--htc-serif);
	font-size: clamp(2.4rem, 7vw, 4rem);
	line-height: 1;
	margin: 0 0 var(--htc-space-xs);
}

.htc-credential-panel__role {
	color: rgba(255, 255, 255, 0.78);
	font-size: 1rem;
	margin: 0 0 var(--htc-space-md);
}

.htc-credential-panel--light .htc-credential-panel__role {
	color: var(--htc-color-muted);
}

.htc-credential-panel__facts,
.htc-authority-list {
	border-top: 1px solid rgba(255, 255, 255, 0.16);
	display: grid;
	gap: var(--htc-space-xs);
	list-style: none;
	margin: var(--htc-space-lg) 0 0;
	padding: var(--htc-space-lg) 0 0;
}

.htc-credential-panel__facts li {
	color: rgba(255, 255, 255, 0.82);
	font-size: 0.95rem;
	line-height: 1.45;
}

.htc-verification-strip {
	margin-top: calc(var(--htc-space-xl) * -0.6);
	position: relative;
	z-index: 2;
}

.htc-verification-list {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	padding: var(--htc-space-sm);
}

.htc-verification-list li {
	background: transparent;
	border: 0;
	border-radius: 0;
	border-left: 1px solid var(--htc-color-subtle);
	padding: var(--htc-space-sm);
}

.htc-verification-list li:first-child {
	border-left: 0;
}

.htc-section--reassurance {
	border-bottom: 1px solid var(--htc-color-subtle);
	border-top: 1px solid var(--htc-color-subtle);
	padding-bottom: var(--htc-space-xl);
	padding-top: var(--htc-space-xl);
}

.htc-reassurance-grid {
	align-items: start;
	gap: var(--htc-space-xl);
}

.htc-doctor-authority {
	position: relative;
}

.htc-authority-list {
	border-color: var(--htc-color-subtle);
	margin-bottom: var(--htc-space-lg);
}

.htc-authority-list li {
	color: var(--htc-color-text);
	line-height: 1.6;
	padding-left: var(--htc-space-md);
	position: relative;
}

.htc-authority-list li::before {
	background: var(--htc-color-gold);
	content: "";
	height: 6px;
	left: 0;
	position: absolute;
	top: 0.7em;
	width: 6px;
}

.htc-evidence-preview {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	padding-bottom: var(--htc-space-xl);
	padding-top: var(--htc-space-xl);
}

.htc-evidence-card {
	background: var(--htc-color-stone);
}

.htc-secondary-action {
	margin-top: var(--htc-space-lg);
}

.htc-consultation-journey {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.7), rgba(248, 245, 240, 0));
	border-top: 1px solid var(--htc-color-subtle);
	padding-top: var(--htc-space-xl);
}

.htc-journey-steps {
	display: grid;
	gap: var(--htc-space-sm);
}

.htc-journey-steps .wp-block-column {
	background: var(--htc-color-white);
	border-left: 3px solid var(--htc-color-gold);
}

.htc-pathway-list {
	grid-template-columns: 1fr;
}

.htc-pathway-list em {
	color: var(--htc-color-muted);
	display: block;
	font-size: 0.95rem;
	font-style: normal;
	line-height: 1.5;
	margin-top: var(--htc-space-sm);
}

.htc-section--faq-objections {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	padding-bottom: var(--htc-space-xl);
	padding-top: var(--htc-space-xl);
}

.htc-objection-grid {
	display: grid;
	gap: var(--htc-space-sm);
}

.htc-objection-card {
	background: var(--htc-color-stone);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	height: 100%;
	padding: var(--htc-space-lg);
}

.htc-objection-card h3 {
	font-size: clamp(1.35rem, 3vw, 1.7rem);
	margin-bottom: var(--htc-space-sm);
}

.htc-objection-card p {
	color: var(--htc-color-muted);
	margin-bottom: 0;
}

.htc-final-consultation h2 {
	max-width: 11ch;
}

.htc-site-footer {
	--wp--style--global--content-size: 1100px;
	background: var(--htc-color-navy);
	color: var(--htc-color-white);
	margin-top: var(--htc-space-xl);
	padding-bottom: var(--htc-space-xl);
	padding-top: var(--htc-space-xl);
}

.htc-site-footer__columns.wp-block-columns,
.htc-site-footer__columns {
	align-items: start;
	display: grid !important;
	flex-wrap: unset;
	gap: 1.25rem;
	grid-template-columns: 1.7fr 1fr 1.15fr 1fr 1.55fr;
}

.htc-site-footer__columns > .wp-block-column {
	flex-basis: unset !important;
	flex-grow: unset !important;
	width: auto !important;
}

.htc-site-footer a,
.htc-site-footer h3,
.htc-site-footer p,
.htc-site-footer li {
	color: var(--htc-color-white);
}

.htc-site-footer h3 {
	font-size: 1.05rem;
	letter-spacing: 0.01em;
	margin-bottom: var(--htc-space-sm);
	text-transform: uppercase;
}

.htc-site-footer p,
.htc-site-footer li {
	color: rgba(255, 255, 255, 0.78);
	font-size: 0.95rem;
	line-height: 1.65;
}

.htc-site-footer ul {
	margin: 0;
	padding-left: 0;
}

.htc-footer-brand p {
	max-width: 30rem;
}

.htc-footer-links {
	display: grid;
	gap: var(--htc-space-xs);
	list-style: none;
}

.htc-footer-links a {
	color: rgba(255, 255, 255, 0.82);
	text-decoration: none;
	text-underline-offset: 3px;
}

.htc-footer-links a:hover,
.htc-footer-links a:focus {
	color: var(--htc-color-gold);
	text-decoration: underline;
}

.htc-footer-consultation {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: var(--htc-radius);
	padding: var(--htc-space-md);
}

.htc-site-footer .wp-block-button {
	width: 100%;
}

.htc-site-footer .wp-block-button__link {
	background: var(--htc-color-gold);
	border: 1px solid var(--htc-color-gold);
	border-radius: var(--htc-radius-sm);
	box-sizing: border-box;
	color: var(--htc-color-navy);
	display: block;
	font-weight: 700;
	padding: 0.9rem 1rem;
	text-align: center;
	text-decoration: none;
	width: 100%;
}

.htc-footer-nav .wp-block-navigation__container {
	align-items: flex-start;
	gap: var(--htc-space-xs);
}

.htc-footer-nav .wp-block-navigation-item__content {
	text-decoration: underline;
	text-underline-offset: 2px;
}

.htc-site-footer__meta {
	font-size: 0.9rem;
	gap: var(--htc-space-sm);
}

.htc-template-section {
	margin-bottom: var(--htc-space-2xl);
	padding-bottom: var(--htc-space-xl);
	padding-top: var(--htc-space-xl);
}

.htc-template-section h2 {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: clamp(2rem, 6vw, 3.35rem);
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.04;
	margin: 0 0 var(--htc-space-md);
	max-width: 22ch;
}

.htc-card-grid {
	display: grid;
	gap: var(--htc-space-sm);
	margin-top: var(--htc-space-lg);
	min-width: 0;
}

.htc-card {
	background: rgba(255, 255, 255, 0.86);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	box-shadow: var(--htc-shadow-soft);
	color: var(--htc-color-text);
	display: block;
	min-height: 100%;
	min-width: 0;
	padding: var(--htc-space-lg);
	position: relative;
	text-decoration: none;
}

.htc-card::before {
	background: var(--htc-color-gold);
	content: "";
	height: 3px;
	left: var(--htc-space-lg);
	position: absolute;
	right: var(--htc-space-lg);
	top: 0;
}

.htc-card span,
.htc-feature-panel span,
.htc-keap-placeholder span {
	color: var(--htc-color-gold-deep);
	display: block;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.1em;
	margin-bottom: var(--htc-space-sm);
	text-transform: uppercase;
}

.htc-card strong,
.htc-keap-placeholder strong {
	color: var(--htc-color-navy);
	display: block;
	font-family: var(--htc-serif);
	font-size: clamp(1.45rem, 4vw, 1.95rem);
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.08;
	margin-bottom: var(--htc-space-sm);
}

.htc-card em {
	color: var(--htc-color-muted);
	display: block;
	font-style: normal;
	line-height: 1.55;
}

.htc-card__link:hover,
.htc-card__link:focus {
	border-color: rgba(201, 168, 76, 0.65);
	box-shadow: var(--htc-shadow-card);
	color: var(--htc-color-navy);
	transform: translateY(-1px);
}

.htc-card--pending {
	border-style: dashed;
	box-shadow: none;
}

.htc-split,
.htc-profile-layout,
.htc-consultation-layout {
	display: grid;
	gap: var(--htc-space-xl);
	width: 100%;
}

body:not(.home) .htc-page > .htc-v3-faq {
	margin-bottom: var(--htc-space-2xl);
}

.htc-feature-panel {
	background: var(--htc-color-navy);
	border-radius: var(--htc-radius);
	color: var(--htc-color-white);
	padding: clamp(1.5rem, 4vw, 2.5rem);
}

.htc-feature-panel h2 {
	color: var(--htc-color-white);
	margin-bottom: 0;
	max-width: 12ch;
}

.htc-copy-panel {
	align-self: center;
	min-width: 0;
}

.htc-copy-panel p {
	font-size: 1.05rem;
	line-height: 1.75;
	max-width: 66ch;
}

.htc-detail-list {
	display: grid;
	gap: var(--htc-space-xs);
	list-style: none;
	margin: var(--htc-space-lg) 0;
	padding: 0;
}

.htc-detail-list li {
	border-left: 3px solid var(--htc-color-gold);
	color: var(--htc-color-text);
	line-height: 1.55;
	padding-left: var(--htc-space-sm);
}

.htc-price-note,
.htc-microcopy {
	color: var(--htc-color-muted);
	font-size: 0.96rem;
}

.htc-placeholder-media {
	align-items: center;
	aspect-ratio: 4 / 5;
	background: linear-gradient(145deg, var(--htc-color-stone), var(--htc-color-stone-deep));
	border: 1px dashed #b9b09d;
	border-radius: var(--htc-radius);
	color: var(--htc-color-muted);
	display: flex;
	justify-content: center;
	min-height: 320px;
	padding: var(--htc-space-lg);
	text-align: center;
}

.htc-cta-panel {
	background: var(--htc-color-navy);
	border-radius: var(--htc-radius);
	color: var(--htc-color-white);
	overflow: hidden;
	position: relative;
}

.htc-cta-panel::before {
	background: linear-gradient(135deg, rgba(201, 168, 76, 0.16), rgba(255, 255, 255, 0));
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.htc-cta-panel > * {
	position: relative;
	z-index: 1;
}

.htc-cta-panel h2,
.htc-cta-panel .htc-section-intro {
	color: var(--htc-color-white);
}

.htc-cta-panel .htc-section-intro,
.htc-cta-panel .htc-cta-note {
	color: rgba(255, 255, 255, 0.78);
}

.htc-keap-placeholder,
.htc-keap-embed {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	box-shadow: var(--htc-shadow-soft);
	padding: clamp(1rem, 3vw, 1.5rem);
}

.htc-keap-embed__frame {
	border: 0;
	border-radius: calc(var(--htc-radius) - 4px);
	display: block;
	min-height: 720px;
	width: 100%;
}

.htc-keap-embed__fallback {
	color: var(--htc-color-muted);
	font-size: 0.9rem;
	line-height: 1.5;
	margin: var(--htc-space-sm) 0 0;
	text-align: center;
}

.htc-keap-embed__fallback a {
	color: var(--htc-color-navy);
	font-weight: 700;
	text-decoration: underline;
	text-decoration-color: var(--htc-color-gold);
	text-underline-offset: 3px;
}

.htc-keap-placeholder {
	border-style: dashed;
	border-color: #b9b09d;
	padding: clamp(1.5rem, 4vw, 2.25rem);
}

.htc-keap-placeholder p {
	color: var(--htc-color-muted);
	line-height: 1.6;
}

.htc-keap-placeholder a,
.htc-text-link {
	color: var(--htc-color-navy);
	font-weight: 700;
	text-decoration: underline;
	text-decoration-color: var(--htc-color-gold);
	text-decoration-thickness: 2px;
	text-underline-offset: 4px;
}

.htc-button-pair {
	display: flex;
	flex-wrap: wrap;
	gap: var(--htc-space-sm);
	margin-top: var(--htc-space-md);
}

.htc-page--consultation .htc-site-footer {
	margin-top: 0;
}

.htc-treatment-qa,
.htc-location-meta {
	list-style: none;
	margin: 1rem 0 0;
	padding: 0;
	display: grid;
	gap: 0.5rem;
	font-size: 0.95rem;
	color: var(--htc-color-muted);
}
.htc-location-meta a {
	color: var(--htc-color-navy);
	text-decoration: underline;
	text-underline-offset: 2px;
}
.htc-location-treatments {
	background: rgba(255, 255, 255, 0.54);
	border-bottom: 1px solid var(--htc-color-subtle);
	border-top: 1px solid var(--htc-color-subtle);
}

@media (min-width: 782px) {
	.wp-block-group {
		padding-left: var(--htc-space-lg);
		padding-right: var(--htc-space-lg);
	}

	.hamburger-menu {
		display: none;
	}

	.htc-inline-list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.htc-section--treatments ul {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.htc-objection-grid,
	.htc-journey-steps {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.htc-section .wp-block-button {
		width: auto;
	}

	.htc-page .wp-block-button {
		width: auto;
	}

	.htc-section .wp-block-button__link {
		display: inline-block;
		width: auto;
	}

	.htc-page .wp-block-button__link {
		display: inline-flex;
		width: auto;
	}

	.htc-page-content-shell,
	.htc-post-listing {
		padding-bottom: var(--htc-space-2xl);
		padding-top: var(--htc-space-2xl);
	}

	.htc-site-footer .wp-block-button {
		width: 100%;
	}

	.htc-site-footer .wp-block-button__link {
		box-sizing: border-box;
		display: block;
		width: 100%;
	}

	.htc-credential-line {
		align-items: center;
		flex-direction: row;
		justify-content: space-between;
	}

	.htc-card-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.htc-split,
	.htc-profile-layout,
	.htc-consultation-layout {
		grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	}
}

@media (min-width: 1024px) {
	.wp-block-group {
		padding-left: var(--htc-space-xl);
		padding-right: var(--htc-space-xl);
	}

	.htc-home {
		padding: 0;
	}

	.htc-page-hero {
		margin-top: var(--htc-space-xl);
		padding-bottom: var(--htc-space-3xl);
		padding-top: var(--htc-space-3xl);
	}

	.htc-section {
		margin-bottom: var(--htc-space-3xl);
	}

	.htc-section--hero,
	.htc-section--final-cta,
	.htc-section--doctor {
		padding-bottom: var(--htc-space-3xl);
		padding-top: var(--htc-space-3xl);
	}

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

	.htc-verification-list {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}

	.htc-section--treatments ul {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.htc-pathway-list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.htc-journey-steps {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}

	.htc-objection-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.htc-site-logo {
		max-width: 180px;
	}

	.htc-site-footer__columns {
		grid-template-columns: 1.4fr 0.85fr 1fr 1fr 1.2fr;
	}

	.htc-card-grid--treatments {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.htc-card-grid--results,
	.htc-card-grid--locations,
	.htc-card-grid--detail {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.htc-section--final-cta {
		text-align: center;
	}

	.htc-section--final-cta h2,
	.htc-section--final-cta p,
	.htc-section--final-cta .wp-block-buttons {
		margin-left: auto;
		margin-right: auto;
	}

	.htc-final-consultation h2 {
		max-width: 12ch;
	}
}

/* Tablet / small laptop — tighter header rhythm before hamburger menu */
@media (max-width: 1279px) {
	.htc-site-header__inner {
		gap: var(--htc-space-xs);
		min-height: 74px;
	}

	.htc-site-logo {
		max-width: 128px;
	}

	body:not(.home) .htc-site-logo,
	body:not(.home) .htc-site-logo--light {
		max-width: 80px;
	}

	.htc-header-cta .wp-block-button__link {
		font-size: 0.82rem;
		padding: 0.72rem 0.95rem;
	}
}

@media (max-width: 1100px) {
	.htc-primary-nav .wp-block-navigation__container {
		column-gap: 0.5rem;
	}

	.htc-primary-nav .wp-block-navigation-item__content {
		font-size: 0.8rem;
	}

	.htc-header-cta .wp-block-button__link {
		font-size: 0.78rem;
		padding: 0.68rem 0.8rem;
	}

	/* Homepage: drop centred nav earlier so links do not collide with CTA */
	.home .htc-primary-nav {
		flex: 1 1 auto;
		left: auto;
		min-width: 0;
		position: static;
		top: auto;
		transform: none;
	}
}

/* Mobile menu below 992px (horizontal nav too cramped with 7+ items) */
@media (max-width: 991px) {
	.htc-site-header__inner {
		flex-wrap: nowrap;
		min-height: 72px;
	}

	.htc-site-header__actions {
		flex-basis: auto;
		flex-shrink: 0;
		gap: var(--htc-space-xs);
	}

	/* Override WP core (shows inline nav from 600px) — hamburger only until 992px */
	.htc-primary-nav .wp-block-navigation__responsive-container:not(.is-menu-open):not(.has-modal-open) {
		display: none !important;
	}

	.htc-primary-nav .wp-block-navigation__responsive-container-open {
		display: inline-flex !important;
	}

	.htc-site-header__actions:has(.wp-block-navigation__responsive-container.is-menu-open) .htc-header-cta,
	.htc-site-header__actions:has(.wp-block-navigation__responsive-container.has-modal-open) .htc-header-cta {
		pointer-events: none;
		visibility: hidden;
	}

	.htc-primary-nav {
		flex: 0 0 auto;
		order: 2;
	}

	.htc-primary-nav .wp-block-navigation__responsive-container-open {
		align-items: center;
		border: 1px solid var(--htc-color-subtle);
		border-radius: var(--htc-radius-sm);
		color: var(--htc-color-navy);
		display: inline-flex;
		justify-content: center;
		min-height: 44px;
		min-width: 44px;
		padding: 0.55rem;
	}

	.home .htc-primary-nav .wp-block-navigation__responsive-container-open {
		border-color: rgba(255, 255, 255, 0.28);
		color: rgba(255, 255, 255, 0.92);
	}

	.htc-primary-nav .wp-block-navigation__responsive-container.is-menu-open,
	.htc-primary-nav .wp-block-navigation__responsive-container.has-modal-open {
		background: rgba(255, 255, 255, 0.98);
		border-bottom: 1px solid var(--htc-color-subtle);
		display: flex !important;
		flex-direction: column;
		inset: 72px 0 auto !important;
		max-height: calc(100vh - 72px);
		overflow-y: auto;
		padding: var(--htc-space-md) var(--htc-content-gutter);
		position: fixed !important;
		width: 100% !important;
		z-index: 100001;
	}

	.home .htc-primary-nav .wp-block-navigation__responsive-container.is-menu-open,
	.home .htc-primary-nav .wp-block-navigation__responsive-container.has-modal-open {
		background: rgba(4, 17, 29, 0.98);
		border-bottom-color: rgba(196, 160, 82, 0.22);
	}

	.htc-primary-nav .wp-block-navigation__responsive-container-content {
		padding: 0;
	}

	.htc-primary-nav .wp-block-navigation__container {
		align-items: stretch;
		flex-direction: column;
		gap: 0;
	}

	.htc-primary-nav .wp-block-navigation-item {
		border-bottom: 1px solid var(--htc-color-subtle);
		width: 100%;
	}

	.htc-primary-nav .wp-block-navigation-item:last-child {
		border-bottom: 0;
	}

	.htc-primary-nav .wp-block-navigation-item__content {
		display: block;
		font-size: 1rem;
		padding: 0.85rem 0;
		white-space: normal;
	}

	.home .htc-primary-nav .wp-block-navigation-item__content {
		color: rgba(255, 255, 255, 0.9);
	}

	.home .htc-primary-nav .wp-block-navigation-item {
		border-bottom-color: rgba(255, 255, 255, 0.12);
	}

	.htc-header-cta .wp-block-button__link {
		font-size: 0.84rem;
		padding: 0.75rem 0.85rem;
		white-space: nowrap;
	}

	.htc-verification-list li {
		border-left: 0;
		border-top: 1px solid var(--htc-color-subtle);
	}

	.htc-verification-list li:first-child {
		border-top: 0;
	}
}

@media (max-width: 520px) {
	.htc-site-logo {
		max-width: 100px;
	}

	body:not(.home) .htc-site-logo,
	body:not(.home) .htc-site-logo--light {
		max-width: 64px;
	}

	.htc-site-header__actions {
		gap: 0.4rem;
	}

	.htc-header-cta .wp-block-button__link {
		font-size: 0.72rem;
		line-height: 1.1;
		max-width: 7.5rem;
		min-width: 0;
		padding: 0.6rem 0.55rem;
		white-space: normal;
	}

	.htc-site-header--reduced .htc-header-cta .wp-block-button__link {
		max-width: 10rem;
	}

	.htc-card,
	.htc-feature-panel,
	.htc-keap-placeholder {
		padding: var(--htc-space-md);
	}
}

/* ── Homepage body background: prevent cream body colour bleeding between <main> and <footer> ── */
body.home,
body.home .wp-site-blocks {
	background: #060d15;
}

/* ── Polish fixes (Step 19 QA) ── */

/* 1. .htc-home is the main page wrapper — zero ALL side padding so alignfull v3 sections
      stretch edge-to-edge. WordPress does not apply negative-margin breakout without
      useRootPaddingAwareAlignments in theme.json, so we zero the source directly.
      Background is dark to match the v3 section palette; any inter-block gap stays dark. */
.htc-home {
	padding: 0;
	background: #060d15;
}

/* Kill WordPress default block-gap between direct children of .htc-home.
   Each v3 section manages its own internal vertical rhythm. */
.htc-home > .wp-block-group,
.htc-home > .wp-block-html {
	margin-top: 0;
	margin-bottom: 0;
}

/* alignfull groups must not inherit the global .wp-block-group side padding;
   each v3 section handles its own internal padding via .htc-v3-section or directly. */
.wp-block-group.alignfull {
	padding-left: 0;
	padding-right: 0;
}

/* 2. Header inner / actions: explicit flex — WordPress is-layout-flex variables are not
      resolving so nav items stack vertically without this. */
.htc-site-header__inner,
.htc-site-header__actions {
	display: flex;
}

/* 3. Nav container: WordPress block layout CSS variables (--navigation-layout-direction)
      are not resolving in this theme setup — force horizontal row explicitly.
      In WP 6.x, ALL nav items live inside .wp-block-navigation__responsive-container,
      so that element must remain visible on desktop. Only the hamburger button is hidden. */
.htc-primary-nav .wp-block-navigation__container {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (min-width: 992px) {
	/* Hide hamburger button — nav is always visible on desktop */
	.htc-primary-nav .wp-block-navigation__responsive-container-open,
	.htc-primary-nav.hidden-by-default .wp-block-navigation__responsive-container-open,
	.wp-block-navigation.hidden-by-default.htc-primary-nav .wp-block-navigation__responsive-container-open {
		display: none !important;
	}

	/* Ensure the container (which holds the actual items) is always shown on desktop */
	.htc-primary-nav .wp-block-navigation__responsive-container,
	.htc-primary-nav.hidden-by-default .wp-block-navigation__responsive-container,
	.wp-block-navigation.hidden-by-default.htc-primary-nav .wp-block-navigation__responsive-container {
		background: transparent !important;
		display: block !important;
		height: auto !important;
		inset: auto !important;
		max-height: none !important;
		overflow: visible !important;
		padding: 0 !important;
		position: static !important;
		visibility: visible !important;
		width: auto !important;
	}

	.htc-primary-nav .wp-block-navigation__responsive-container-content,
	.htc-primary-nav.hidden-by-default .wp-block-navigation__responsive-container-content,
	.wp-block-navigation.hidden-by-default.htc-primary-nav .wp-block-navigation__responsive-container-content {
		display: block !important;
		padding: 0 !important;
	}

	.htc-primary-nav .wp-block-navigation__responsive-container-close,
	.wp-block-navigation.hidden-by-default.htc-primary-nav .wp-block-navigation__responsive-container-close {
		display: none !important;
	}
}

/* 4. Logo: zero any background/border/padding from WordPress compiled block CSS.
      mix-blend-mode: screen on the img makes the baked-in black background transparent
      while keeping the gold crest fully opaque — no image re-export needed. */
.htc-site-logo.wp-block-image,
figure.htc-site-logo {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	padding: 0 !important;
}

.htc-site-logo img {
	mix-blend-mode: normal;
}

.home .htc-site-logo img {
	mix-blend-mode: screen;
}

/* Inner pages: transparent PNG logo on light header (no blend-mode workaround). */
body:not(.home) .htc-site-logo,
body:not(.home) .htc-site-logo--light {
	background: transparent;
	border-radius: 0;
	line-height: 0;
	padding: 0;
}

body:not(.home) .htc-site-logo img,
body:not(.home) .htc-site-logo--light img {
	mix-blend-mode: normal;
}

body:not(.home) .htc-site-logo,
body:not(.home) .htc-site-logo--light {
	max-width: 92px;
}

/* 3. Visualiser section: h2 inherits body text colour (#1a1a1a) on a dark navy
      background — force white so it's legible. */
.htc-v3-vis-header h2 {
	color: #fff;
}

/* 4. Visualiser dropzone: <label> is inline by default; flex-column centres all
      child elements and makes the upload icon / h3 / p / button stack correctly. */
.htc-v3-vis-dropzone {
	display: flex;
	flex-direction: column;
	align-items: center;
}

/* 5. Results section: heading inherits dark body colour on #060d15 background.
      Film frame text bumped to 70% opacity (was 50%) for legibility.
      Disclaimer raised to 55% (was 38%). */
.htc-v3-results-heading {
	color: #fff;
}

.htc-v3-film-text {
	color: rgba(196, 160, 82, 0.72);
}

.htc-v3-results-disclaimer {
	color: rgba(255, 255, 255, 0.55);
}

/* Approved premium homepage prototype alignment. */
.home .htc-site-header {
	background: transparent;
	border-bottom: 0;
	box-sizing: border-box;
	left: 50%;
	max-width: 100vw;
	position: fixed;
	top: 0;
	transform: translateX(-50%);
	transition: background 280ms ease, border-color 280ms ease;
	width: 100vw;
	z-index: 20;
}

.home .htc-site-header--scrolled {
	background: rgba(4, 17, 29, 0.96);
	backdrop-filter: blur(12px);
	border-bottom: 1px solid rgba(196, 160, 82, 0.18);
}

.home .htc-site-header__inner {
	min-height: 96px;
	box-sizing: border-box;
	margin-left: auto;
	margin-right: auto;
	max-width: var(--htc-content-max);
	padding-left: var(--htc-content-gutter);
	padding-right: var(--htc-content-gutter);
	width: 100%;
}

.home .htc-primary-nav .wp-block-navigation-item__content {
	color: rgba(255, 255, 255, 0.86);
	font-weight: 500;
}

.home .htc-primary-nav .wp-block-navigation-item__content:hover,
.home .htc-primary-nav .wp-block-navigation-item__content:focus {
	color: #edc482;
}

.home .htc-header-cta .wp-block-button__link {
	background: rgba(4, 17, 29, 0.24);
	border-color: rgba(237, 196, 130, 0.76);
	color: #edc482;
}

.home .htc-site-logo {
	max-width: 150px;
}

.htc-home {
	background: #060d15;
	padding: 0;
}

.htc-section--prototype-hero {
	background:
		radial-gradient(ellipse at 72% 23%, rgba(211, 163, 96, 0.16), transparent 28%),
		radial-gradient(ellipse at 19% 56%, rgba(41, 97, 135, 0.24), transparent 38%),
		radial-gradient(ellipse at 90% 55%, rgba(222, 171, 98, 0.12), transparent 30%),
		linear-gradient(110deg, #041321 0%, #061928 48%, #081927 100%);
	color: var(--htc-color-white);
	margin-bottom: 0;
	min-height: max(900px, 100vh);
	overflow-x: clip;
	overflow-y: visible;
	padding: clamp(10.5rem, 13vw, 13.75rem) clamp(1.625rem, 3.5vw, 2.375rem) clamp(3.5rem, 5vw, 4.75rem);
	position: relative;
}

.htc-section--prototype-hero::after {
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px),
		linear-gradient(rgba(255, 255, 255, 0.018) 1px, transparent 1px);
	background-size: 92px 92px;
	content: "";
	inset: 0;
	opacity: 0.18;
	pointer-events: none;
	position: absolute;
}

.htc-prototype-hero__grid {
	align-items: center;
	display: grid;
	gap: clamp(1.75rem, 4vw, 3.875rem);
	grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr);
	margin: 0 auto;
	max-width: 1450px;
	position: relative;
	z-index: 1;
}

.htc-prototype-hero__copy {
	max-width: 590px;
	min-width: 0;
}

.htc-section--prototype-hero .htc-eyebrow {
	color: #e0b269;
	letter-spacing: 0.22em;
	margin-bottom: 1.875rem;
}

.htc-section--prototype-hero h1 {
	color: rgba(255, 255, 255, 0.98);
	font-size: clamp(4.1rem, 5.85vw, 6.7rem);
	font-weight: 300;
	line-height: 0.96;
	margin-bottom: 1.5rem;
	max-width: 9ch;
	text-shadow: 0 18px 48px rgba(0, 0, 0, 0.28);
}

.htc-section--prototype-hero .htc-hero-intro {
	color: rgba(255, 255, 255, 0.78);
	font-size: clamp(1.08rem, 1.28vw, 1.22rem);
	line-height: 1.55;
	margin-bottom: 2.625rem;
	max-width: 548px;
}

.htc-hero-actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 1.125rem;
}

.htc-prototype-button {
	align-items: center;
	border-radius: 5px;
	display: inline-flex;
	font-size: 0.96rem;
	font-weight: 700;
	gap: 1rem;
	justify-content: center;
	min-height: 58px;
	padding: 1rem 1.75rem;
	text-decoration: none;
}

.htc-prototype-button--primary {
	background: linear-gradient(135deg, #f1cd8c, #d8a85f);
	box-shadow: 0 18px 44px rgba(216, 168, 95, 0.22);
	color: #061321;
	transition: background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease, color 160ms ease, transform 160ms ease;
}

.htc-prototype-button--text {
	background: rgba(4, 17, 29, 0.2);
	border: 1px solid rgba(237, 196, 130, 0.62);
	color: #edc482;
	transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.htc-prototype-button--primary:hover {
	box-shadow: 0 22px 50px rgba(216, 168, 95, 0.28);
	filter: brightness(1.03);
	transform: translateY(-1px);
}

.htc-prototype-button--text:hover {
	background: rgba(4, 17, 29, 0.35);
	border-color: rgba(237, 196, 130, 0.85);
	color: #f5d9a8;
}

.htc-prototype-button:focus-visible {
	outline: 2px solid #edc482;
	outline-offset: 3px;
}

.htc-hero-trust {
	display: grid;
	gap: 0.75rem;
	grid-template-columns: 1fr 1.15fr;
	margin-top: 2.875rem;
	max-width: 530px;
}

.htc-hero-trust span {
	align-items: center;
	background: rgba(5, 18, 31, 0.5);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 8px;
	color: rgba(255, 255, 255, 0.82);
	display: flex;
	font-size: 0.9rem;
	font-weight: 500;
	gap: 0.875rem;
	line-height: 1.25;
	min-height: 58px;
	padding: 0.875rem 1.0625rem;
}

.htc-hero-trust span::before {
	border: 1.5px solid #e0ad63;
	content: "";
	flex: 0 0 24px;
	height: 24px;
	width: 24px;
}

.htc-hero-trust span:nth-child(3),
.htc-hero-trust span:nth-child(4) {
	grid-column: 1 / -1;
}

.htc-restoration-journey-visual {
	aspect-ratio: 4 / 3;
	background: rgba(6, 17, 28, 0.5);
	border: 1px solid rgba(255, 255, 255, 0.16);
	box-shadow: 0 28px 80px rgba(0, 0, 0, 0.24);
	min-height: 520px;
	overflow: hidden;
	position: relative;
}

.htc-journey-image-stack {
	inset: 0;
	position: absolute;
}

.htc-journey-photo {
	height: 100%;
	inset: 0;
	object-fit: cover;
	opacity: 0;
	position: absolute;
	transform: scale(1.02);
	width: 100%;
}

.htc-journey-photo--one {
	animation: htc-journey-fade 16s infinite;
}

.htc-journey-photo--two {
	animation: htc-journey-fade 16s 4s infinite;
}

.htc-journey-photo--three {
	animation: htc-journey-fade 16s 8s infinite;
}

.htc-journey-photo--four {
	animation: htc-journey-fade 16s 12s infinite;
}

.htc-restoration-journey-visual::after {
	background: linear-gradient(180deg, rgba(4, 17, 29, 0.04), rgba(4, 17, 29, 0.68));
	content: "";
	inset: 0;
	position: absolute;
}

.htc-journey-card-header {
	left: 1.5rem;
	position: absolute;
	top: 1.5rem;
	z-index: 2;
}

.htc-journey-card-header span {
	background: rgba(4, 17, 29, 0.62);
	border: 1px solid rgba(237, 196, 130, 0.42);
	color: #edc482;
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.14em;
	padding: 0.65rem 0.85rem;
	text-transform: uppercase;
}

.htc-journey-stage-list {
	bottom: 1.25rem;
	display: grid;
	gap: 0.75rem;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	left: 1.25rem;
	position: absolute;
	right: 1.25rem;
	z-index: 2;
}

.htc-journey-stage-list div {
	background: rgba(5, 18, 31, 0.72);
	border: 1px solid rgba(255, 255, 255, 0.14);
	color: rgba(255, 255, 255, 0.9);
	padding: 0.85rem;
}

.htc-journey-stage-list span {
	color: #edc482;
	display: block;
	font-size: 0.75rem;
	font-weight: 800;
	margin-bottom: 0.25rem;
}

.htc-journey-stage-list strong {
	display: block;
	font-size: 0.9rem;
	line-height: 1.15;
}

@keyframes htc-journey-fade {
	0%,
	20% {
		opacity: 1;
	}

	25%,
	95% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

.htc-home .htc-verification-strip {
	background: #fffaf2;
	margin-bottom: 0;
	margin-top: 0;
	padding-bottom: clamp(3rem, 6vw, 6rem);
	padding-top: clamp(2.5rem, 5vw, 4rem);
}

.htc-home .htc-verification-list {
	background: transparent;
	border: 0;
	border-radius: 0;
	gap: 0;
	padding: 0;
}

.htc-home .htc-verification-list li {
	background: #fffaf2;
	border: 1px solid rgba(20, 31, 42, 0.14);
	border-left: 0;
	padding: clamp(1.4rem, 3vw, 2.2rem);
}

.htc-home .htc-verification-list li:first-child {
	border-left: 1px solid rgba(20, 31, 42, 0.14);
}

.htc-home .htc-evidence-preview,
.htc-home .htc-doctor-authority,
.htc-home .htc-section--faq-objections {
	background: #fffaf2;
	border: 0;
	border-radius: 0;
	padding-bottom: clamp(4rem, 8vw, 7rem);
	padding-top: clamp(4rem, 8vw, 7rem);
}

.htc-home .htc-evidence-preview {
	background: #f6f0e7;
}

.htc-home .htc-result-card,
.htc-home .htc-objection-card,
.htc-home .htc-process-steps .wp-block-column,
.htc-home .htc-section--treatments li {
	background: #fffaf2;
	border-color: rgba(20, 31, 42, 0.14);
	border-radius: 0;
	box-shadow: none;
}

.htc-home .htc-consultation-journey {
	background: #091724;
	color: var(--htc-color-white);
	margin-bottom: 0;
	padding-bottom: clamp(4rem, 8vw, 7rem);
	padding-top: clamp(4rem, 8vw, 7rem);
}

.htc-home .htc-consultation-journey h2,
.htc-home .htc-consultation-journey h3 {
	color: var(--htc-color-white);
}

.htc-home .htc-consultation-journey .htc-section-intro,
.htc-home .htc-consultation-journey p {
	color: rgba(255, 255, 255, 0.76);
}

.htc-home .htc-journey-steps .wp-block-column {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.14);
	border-left-color: #c4a052;
}

.htc-home .htc-treatment-pathways {
	background: #fffaf2;
	margin-bottom: 0;
	padding-bottom: clamp(4rem, 8vw, 7rem);
	padding-top: clamp(4rem, 8vw, 7rem);
}

.htc-home .htc-final-consultation {
	background:
		radial-gradient(ellipse at 80% 20%, rgba(196, 160, 82, 0.16), transparent 35%),
		linear-gradient(110deg, #041321 0%, #081927 100%);
	border-radius: 0;
	margin-bottom: 0;
	padding-bottom: clamp(4rem, 8vw, 7rem);
	padding-top: clamp(4rem, 8vw, 7rem);
}

@media (max-width: 1279px) {
	.home .htc-site-header {
		background: rgba(4, 17, 29, 0.86);
		left: 0;
		max-width: none;
		position: sticky;
		transform: none;
		width: 100%;
	}

	.htc-section--prototype-hero {
		min-height: auto;
		padding-top: 5rem;
	}

	.htc-prototype-hero__grid {
		grid-template-columns: 1fr;
	}

	.htc-prototype-hero__copy {
		max-width: 760px;
	}

	.htc-section--prototype-hero h1 {
		max-width: none;
	}
}

@media (max-width: 991px) {
	.home .htc-site-header__actions {
		flex-basis: auto;
	}

	.home .htc-primary-nav {
		left: auto;
		position: static;
		top: auto;
		transform: none;
	}

	.htc-section--prototype-hero h1 {
		font-size: clamp(2.55rem, 12vw, 4.7rem);
		max-width: none;
	}

	.htc-hero-trust,
	.htc-journey-stage-list {
		grid-template-columns: 1fr;
	}

	.htc-restoration-journey-visual {
		aspect-ratio: 3 / 4;
		min-height: 520px;
	}
}

@media (max-width: 520px) {
	.htc-section--prototype-hero {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.htc-hero-actions .htc-prototype-button {
		width: 100%;
	}
}

/* =============================================================
	STEP 18 POLISH — homepage layout, nav, and journey fixes
	============================================================= */

/* 1. Double-padding fix — .wp-block-group media-query rules override
		the hero's own clamp horizontal padding at 782px+ and 1024px+.
		Two-class selector (0,2,0) beats one-class (0,1,0) at any breakpoint. */
.home .htc-section--prototype-hero {
	padding-left: clamp(1.625rem, 3.5vw, 2.375rem);
	padding-right: clamp(1.625rem, 3.5vw, 2.375rem);
}

/* 2. Journey stage active indicator — synced with htc-journey-fade (16s cycle).
		Each stage highlights for the 4-second window its image is visible. */
.htc-journey-stage-list div:nth-child(1) { animation: htc-stage-active 16s 0s infinite; }
.htc-journey-stage-list div:nth-child(2) { animation: htc-stage-active 16s 4s infinite; }
.htc-journey-stage-list div:nth-child(3) { animation: htc-stage-active 16s 8s infinite; }
.htc-journey-stage-list div:nth-child(4) { animation: htc-stage-active 16s 12s infinite; }

@keyframes htc-stage-active {
	0%,
	20% {
		background: rgba(196, 160, 82, 0.22);
		border-color: rgba(196, 160, 82, 0.72);
		color: #fff;
	}

	25%,
	95% {
		background: rgba(5, 18, 31, 0.72);
		border-color: rgba(255, 255, 255, 0.14);
		color: rgba(255, 255, 255, 0.9);
	}

	100% {
		background: rgba(196, 160, 82, 0.22);
		border-color: rgba(196, 160, 82, 0.72);
		color: #fff;
	}
}

/* 3. Homepage desktop nav — centre links between logo and CTA at 1280px+.
		Absolute positioning lets the flex layout keep logo-left / CTA-right
		without disturbing the WordPress-generated flex container. */
@media (min-width: 1280px) {
	.home .htc-site-header__inner {
		position: relative;
	}

	.home .htc-primary-nav {
		left: 50%;
		position: absolute;
		top: 50%;
		transform: translate(-50%, -50%);
	}

	/* Ensure the logo and CTA don't collapse into the nav's space */
	.home .htc-site-logo {
		flex: 0 0 auto;
	}

	.home .htc-header-cta {
		flex: 0 0 auto;
	}
}

/* 4. Logo refinement on homepage — less stark white box over dark hero */
.home .htc-site-logo {
	background: rgba(255, 255, 255, 0.95);
	border-radius: 3px;
	box-shadow: 0 2px 14px rgba(0, 0, 0, 0.22);
	max-width: 130px;
	padding: 0.28rem 0.45rem;
}

/* 5. CTA panel button — cap width on mobile so it doesn't span full viewport */
@media (max-width: 781px) {
	.htc-cta-panel .wp-block-button__link {
		max-width: 100%;
		width: 100%;
	}

	/* Prevent inline treatment-page CTAs from wider-than-readable on mid screens */
	.htc-copy-panel .wp-block-button__link {
		max-width: 28rem;
	}
}

/* =============================================================
	V3 HOMEPAGE — design system
	============================================================= */

/* ── Tokens ── */
.htc-home {
	--v3-black:      #060d15;
	--v3-navy:       #0a1828;
	--v3-navy-mid:   #0e2035;
	--v3-gold:       #c4a052;
	--v3-gold-warm:  #e8c077;
	--v3-stone:      #f5f0e8;
	--v3-stone-deep: #ece5d6;
	--v3-muted:      rgba(255,255,255,0.44);
	--v3-ease:       cubic-bezier(0.16,1,0.3,1);
}

/* ── Shared section rhythm ── */
.htc-v3-section {
	padding: clamp(5rem, 10vw, 9rem) clamp(1.25rem, 4vw, 3.5rem);
	max-width: 1360px;
	margin-left: auto;
	margin-right: auto;
}
.htc-v3-eyebrow {
	display: block;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--v3-gold);
	margin-bottom: 1.75rem;
}

/* ── Page-load scan reveal (hero only) ── */
.htc-v3-scan-overlay {
	position: fixed;
	inset: 0;
	background: #060d15;
	z-index: 9000;
	pointer-events: none;
	animation: v3-overlay-out 0.55s 2.1s ease forwards;
}
.htc-v3-scan-line {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 3px;
	background: linear-gradient(90deg, transparent, rgba(196,160,82,.85) 50%, transparent);
	box-shadow: 0 0 22px rgba(196,160,82,.55);
	z-index: 9001;
	pointer-events: none;
	animation: v3-scan-sweep 1.9s 0.2s ease-in-out forwards;
}
@keyframes v3-scan-sweep {
	0%   { top: 0;     opacity: 1; }
	88%  { opacity: 1; }
	100% { top: 100vh; opacity: 0; }
}
@keyframes v3-overlay-out { to { opacity: 0; } }

/* ── V3 Hero ── */
.htc-v3-hero {
	position: relative;
	min-height: 100svh;
	display: flex;
	align-items: center;
	background: #060d15;
	overflow: hidden;
}
.htc-v3-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle, rgba(196,160,82,.2) 1px, transparent 1px),
		radial-gradient(circle, rgba(196,160,82,.08) 1px, transparent 1px),
		radial-gradient(circle, rgba(196,160,82,.04) 1.5px, transparent 1.5px);
	background-size: 32px 32px, 64px 64px, 96px 96px;
	background-position: 0 0, 16px 16px, 32px 32px;
	pointer-events: none;
}
.htc-v3-hero-halo {
	position: absolute;
	right: -14%;
	top: 50%;
	translate: 0 -50%;
	width: min(900px, 65vw);
	height: min(900px, 65vw);
	border-radius: 50%;
	background: conic-gradient(
		from 0deg,
		transparent 0%,
		rgba(196,160,82,.04) 18%,
		rgba(196,160,82,.13) 38%,
		rgba(232,192,119,.18) 50%,
		rgba(196,160,82,.09) 65%,
		rgba(196,160,82,.02) 82%,
		transparent 100%
	);
	animation: v3-halo-spin 28s linear infinite;
	pointer-events: none;
}
.htc-v3-hero-halo::after {
	content: '';
	position: absolute;
	inset: 60px;
	border-radius: 50%;
	background: conic-gradient(from 180deg, transparent 0%, rgba(196,160,82,.07) 30%, rgba(232,192,119,.13) 48%, transparent 72%);
	animation: v3-halo-spin 16s linear infinite reverse;
}
@keyframes v3-halo-spin { to { transform: rotate(360deg); } }
.htc-v3-hero-vignette {
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse 68% 78% at 28% 50%, transparent 38%, #060d15 100%);
	pointer-events: none;
	z-index: 1;
}
.htc-v3-hero-inner {
	position: relative;
	z-index: 2;
	width: 100%;
	padding: 120px clamp(1.25rem,4vw,3.5rem) 100px;
	max-width: 1360px;
	margin: 0 auto;
}
.htc-v3-hero-content { max-width: 800px; }
.htc-v3-hero-content > * {
	opacity: 0;
	transform: translateY(26px);
}
.htc-v3-hero-content > *:nth-child(1) { animation: v3-content-up .9s 2.15s var(--v3-ease) forwards; }
.htc-v3-hero-content > *:nth-child(2) { animation: v3-content-up .9s 2.3s  var(--v3-ease) forwards; }
.htc-v3-hero-content > *:nth-child(3) { animation: v3-content-up .9s 2.45s var(--v3-ease) forwards; }
.htc-v3-hero-content > *:nth-child(4) { animation: v3-content-up .9s 2.6s  var(--v3-ease) forwards; }
.htc-v3-hero-content > *:nth-child(5) { animation: v3-content-up .9s 2.75s var(--v3-ease) forwards; }
@keyframes v3-content-up { to { opacity: 1; transform: none; } }

.htc-v3-hero-label {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--v3-gold);
	margin-bottom: 1.75rem;
}
.htc-v3-hero-label::before {
	content: '';
	display: block;
	width: 30px;
	height: 1px;
	background: var(--v3-gold);
}
.htc-v3-hero-headline {
	line-height: .93;
	margin-bottom: 2rem;
}
.htc-v3-headline-plain {
	display: block;
	font-family: "DM Sans", system-ui, sans-serif;
	font-size: clamp(3.4rem, 7.5vw, 7rem);
	font-weight: 300;
	color: rgba(255,255,255,.9);
	letter-spacing: -.03em;
	line-height: .95;
}
.htc-v3-headline-italic {
	display: block;
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(4.4rem, 9.5vw, 9rem);
	font-weight: 300;
	font-style: italic;
	color: var(--v3-gold);
	letter-spacing: -.02em;
	line-height: .88;
}
.htc-v3-hero-sub {
	font-size: clamp(1rem, 1.8vw, 1.2rem);
	color: rgba(255,255,255,.56);
	max-width: 48ch;
	line-height: 1.65;
	margin-bottom: 2.25rem;
}
.htc-v3-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 2.25rem;
}
.htc-v3-chip {
	display: inline-flex;
	align-items: center;
	height: 36px;
	padding: 0 16px;
	border: 1px solid rgba(196,160,82,.26);
	border-radius: 100px;
	font-size: .8rem;
	font-weight: 500;
	color: rgba(255,255,255,.7);
	background: rgba(196,160,82,.05);
	letter-spacing: .02em;
}
.htc-v3-hero-actions {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 1.75rem;
}
.htc-v3-btn-primary {
	display: inline-flex;
	align-items: center;
	height: 56px;
	padding: 0 32px;
	border: 1px solid #c4a052;
	border-radius: 3px;
	color: #e8c077;
	font-size: .95rem;
	font-weight: 600;
	letter-spacing: .04em;
	background: transparent;
	text-decoration: none;
	position: relative;
	overflow: hidden;
	transition: color 280ms;
}
.htc-v3-btn-primary::before {
	content: '';
	position: absolute;
	inset: 0;
	background: #c4a052;
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 320ms var(--v3-ease);
	z-index: -1;
}
.htc-v3-btn-primary:hover { color: #060d15; }
.htc-v3-btn-primary:hover::before { transform: scaleX(1); }
.htc-v3-hero-trust {
	font-size: .78rem;
	color: rgba(255,255,255,.38);
}
.htc-v3-scroll-hint {
	position: absolute;
	bottom: 2.25rem;
	left: 50%;
	translate: -50% 0;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	opacity: 0;
	animation: v3-content-up .8s 3.1s ease forwards;
}
.htc-v3-scroll-hint span {
	font-size: .68rem;
	font-weight: 700;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: rgba(255,255,255,.38);
}
.htc-v3-scroll-chevron {
	width: 18px;
	height: 18px;
	border-right: 1.5px solid #c4a052;
	border-bottom: 1.5px solid #c4a052;
	transform: rotate(45deg);
	animation: v3-chevron 1.9s 3.3s ease-in-out infinite;
}
@keyframes v3-chevron {
	0%,100% { transform: rotate(45deg) translateY(-4px); opacity: .4; }
	50%      { transform: rotate(45deg) translateY(4px);  opacity: 1; }
}

/* ── V3 Marquee ── */
.htc-v3-marquee-wrap {
	overflow: hidden;
	background: #c4a052;
	padding: 13px 0;
}
.htc-v3-marquee-track {
	display: flex;
	white-space: nowrap;
	animation: v3-marquee 38s linear infinite;
}
.htc-v3-marquee-track span {
	font-family: "Courier New", monospace;
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: #060d15;
	padding: 0 2rem;
}
@keyframes v3-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* ── V3 Numbers ── */
.htc-v3-numbers {
	background: #0a1828;
}
.htc-v3-numbers-grid {
	display: grid;
	grid-template-columns: 1fr 1px 1fr 1px 1fr;
	align-items: center;
}
.htc-v3-numbers-divider {
	background: linear-gradient(to bottom, transparent, #c4a052, transparent);
	height: 120px;
	width: 1px;
	margin: auto;
}
.htc-v3-number-item {
	padding: clamp(2rem,4vw,3.5rem) clamp(1.5rem,3vw,3rem);
	text-align: center;
}
.htc-v3-number-figure {
	display: block;
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(4.5rem,9vw,9rem);
	font-weight: 300;
	line-height: 1;
	color: #c4a052;
	letter-spacing: -.03em;
	margin-bottom: .75rem;
}
.htc-v3-number-label {
	font-size: .82rem;
	font-weight: 500;
	color: rgba(255,255,255,.44);
	letter-spacing: .06em;
	text-transform: uppercase;
}

/* ── V3 Evidence rows ── */
.htc-v3-evidence { background: #060d15; }
.htc-v3-evidence-row {
	border-top: 1px solid rgba(255,255,255,.07);
	padding: clamp(4rem,8vw,7rem) clamp(1.25rem,4vw,3.5rem);
}
.htc-v3-evidence-row:last-child { border-bottom: 1px solid rgba(255,255,255,.07); }
.htc-v3-evidence-row--stone {
	background: #f5f0e8;
	border-top-color: rgba(22,32,43,.1);
}
.htc-v3-evidence-inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem,5vw,6rem);
	align-items: center;
	max-width: 1360px;
	margin: 0 auto;
}
.htc-v3-evidence-numeral {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(5rem,10vw,9rem);
	font-weight: 300;
	line-height: .85;
	color: rgba(196,160,82,.13);
	letter-spacing: -.04em;
	margin-bottom: 1.25rem;
}
.htc-v3-evidence-claim {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(1.6rem,3.2vw,2.6rem);
	font-weight: 300;
	color: #fff;
	line-height: 1.15;
}
.htc-v3-evidence-row--stone .htc-v3-evidence-numeral { color: rgba(10,24,40,.11); }
.htc-v3-evidence-row--stone .htc-v3-evidence-claim   { color: #16202b; }
.htc-v3-evidence-body {
	font-size: clamp(.95rem,1.5vw,1.1rem);
	line-height: 1.7;
	color: rgba(255,255,255,.52);
	max-width: 46ch;
}
.htc-v3-evidence-row--stone .htc-v3-evidence-body { color: rgba(22,32,43,.58); }

/* ── V3 Scroll reveal ── */
.htc-v3-reveal {
	opacity: 0;
	transform: translateY(36px);
	transition: opacity .8s var(--v3-ease), transform .8s var(--v3-ease);
}
.htc-v3-reveal.htc-v3-visible { opacity: 1; transform: none; }
.htc-v3-reveal-d1 { transition-delay: .1s; }
.htc-v3-reveal-d2 { transition-delay: .22s; }
.htc-v3-reveal-d3 { transition-delay: .34s; }

/* ── V3 Visualiser ── */
.htc-v3-vis {
	background: #0e2035;
	padding: clamp(5rem,10vw,9rem) clamp(1.25rem,4vw,3.5rem);
	position: relative;
	overflow: hidden;
}
.htc-v3-vis::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(196,160,82,.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(196,160,82,.04) 1px, transparent 1px);
	background-size: 48px 48px;
	pointer-events: none;
}
.htc-v3-vis-inner { max-width: 1360px; margin: 0 auto; }
.htc-v3-vis-header { text-align: center; margin-bottom: clamp(3rem,5vw,5rem); }
.htc-v3-vis-header h2 {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(2.4rem,5vw,4rem);
	font-weight: 300;
	line-height: 1.1;
	margin-bottom: 1rem;
}
.htc-v3-vis-header p {
	font-size: 1rem;
	color: rgba(255,255,255,.48);
	max-width: 46ch;
	margin: 0 auto;
	line-height: 1.65;
}
.htc-v3-vis-step { display: none; }
.htc-v3-vis-step.htc-v3-vis-active { display: block; }

/* Upload zone */
.htc-v3-vis-dropzone {
	position: relative;
	border: 1px dashed rgba(196,160,82,.35);
	border-radius: 8px;
	background: rgba(196,160,82,.03);
	max-width: 620px;
	margin: 0 auto;
	padding: clamp(3rem,6vw,5rem) 2rem;
	text-align: center;
	cursor: pointer;
	transition: border-color 220ms, background 220ms;
}
.htc-v3-vis-dropzone:hover, .htc-v3-vis-dropzone.htc-v3-dragging {
	border-color: #c4a052;
	background: rgba(196,160,82,.07);
}
.htc-v3-vis-dropzone input[type="file"] {
	position: absolute;
	inset: 0;
	opacity: 0;
	cursor: pointer;
	width: 100%;
	height: 100%;
}
.htc-v3-vis-upload-icon {
	width: 60px;
	height: 60px;
	margin: 0 auto 1.5rem;
	border: 1.5px solid rgba(196,160,82,.38);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}
.htc-v3-vis-dropzone h3 {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.6rem;
	font-weight: 300;
	margin-bottom: .5rem;
}
.htc-v3-vis-dropzone > p { font-size: .88rem; color: rgba(255,255,255,.42); margin-bottom: 1.75rem; }
.htc-v3-vis-browse-btn {
	display: inline-flex;
	align-items: center;
	height: 46px;
	padding: 0 26px;
	border: 1px solid rgba(196,160,82,.5);
	border-radius: 3px;
	color: #e8c077;
	font-size: .88rem;
	font-weight: 600;
	letter-spacing: .04em;
	background: transparent;
	pointer-events: none;
}
.htc-v3-vis-privacy {
	text-align: center;
	margin-top: 1.25rem;
	font-size: .74rem;
	color: rgba(255,255,255,.26);
}

/* Analysing step */
.htc-v3-vis-analyse {
	max-width: 600px;
	margin: 0 auto;
	text-align: center;
	padding: clamp(3rem,6vw,5rem) 2rem;
}
.htc-v3-vis-scan-head {
	width: 110px;
	height: 132px;
	margin: 0 auto 2rem;
	position: relative;
	border: 1px solid rgba(196,160,82,.2);
	border-radius: 55px 55px 18px 18px;
	overflow: hidden;
	background: rgba(196,160,82,.03);
}
.htc-v3-vis-beam {
	position: absolute;
	left: 0; right: 0; top: -3px;
	height: 3px;
	background: linear-gradient(90deg, transparent, #c4a052, transparent);
	box-shadow: 0 0 14px rgba(196,160,82,.6);
	animation: v3-beam 1.6s ease-in-out infinite;
}
@keyframes v3-beam {
	0%   { top: -3px; }
	100% { top: calc(100% + 3px); }
}
.htc-v3-vis-progress-bar {
	height: 2px;
	background: rgba(255,255,255,.08);
	border-radius: 2px;
	max-width: 340px;
	margin: 0 auto 2rem;
	overflow: hidden;
}
.htc-v3-vis-progress-fill {
	height: 100%;
	width: 0%;
	background: linear-gradient(90deg, #9b7530, #c4a052, #e8c077);
	border-radius: 2px;
	transition: width .4s ease;
}
.htc-v3-vis-msgs { display: flex; flex-direction: column; gap: .75rem; max-width: 340px; margin: 0 auto; }
.htc-v3-vis-msg {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: .88rem;
	color: rgba(255,255,255,.32);
	transition: color .4s;
}
.htc-v3-vis-msg::before {
	content: '';
	flex-shrink: 0;
	width: 6px; height: 6px;
	border-radius: 50%;
	background: rgba(255,255,255,.15);
	transition: background .4s;
}
.htc-v3-vis-msg.htc-v3-done { color: rgba(255,255,255,.75); }
.htc-v3-vis-msg.htc-v3-done::before { background: #c4a052; }

/* Disclaimer (used in Step 3 thank-you) */
.htc-v3-vis-disclaimer {
	font-size: .82rem;
	color: rgba(255,255,255,.4);
	line-height: 1.65;
}
.htc-v3-vis-disclaimer strong {
	display: block;
	font-weight: 600;
	color: rgba(255,255,255,.68);
	margin-bottom: 4px;
}
.htc-v3-vis-reset {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: .78rem;
	font-weight: 600;
	color: rgba(255,255,255,.42);
	letter-spacing: .06em;
	text-transform: uppercase;
	border: none;
	background: none;
	cursor: pointer;
	margin-top: .75rem;
	padding: 0;
	transition: color 200ms;
}
.htc-v3-vis-reset:hover { color: #e8c077; }

/* ── V3 Treatments — magazine list ── */
.htc-v3-treatments { background: #f5f0e8; }
.htc-v3-treatments-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	margin-bottom: clamp(3rem,5vw,5rem);
	gap: 2rem;
}
.htc-v3-treatments-header h2 {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(2.4rem,5vw,4rem);
	font-weight: 300;
	color: #16202b;
	line-height: 1.05;
	max-width: 18ch;
}
.htc-v3-treatments-note {
	font-size: .9rem;
	color: rgba(22,32,43,.52);
	max-width: 26ch;
	text-align: right;
	line-height: 1.6;
}
.htc-v3-treatment-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: clamp(1.4rem,3vw,2rem) 0;
	position: relative;
	text-decoration: none;
	color: #16202b;
}
.htc-v3-treatment-row::before {
	content: '';
	position: absolute;
	bottom: 0; left: 0;
	width: 100%; height: 1px;
	background: #ece5d6;
}
.htc-v3-treatment-row::after {
	content: '';
	position: absolute;
	bottom: 0; left: 0;
	width: 0; height: 1px;
	background: #c4a052;
	transition: width 480ms var(--v3-ease);
}
.htc-v3-treatment-row:first-of-type { border-top: 1px solid #ece5d6; }
.htc-v3-treatment-row:hover::after { width: 100%; }
.htc-v3-treatment-name {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(1.6rem,3.2vw,2.6rem);
	font-weight: 300;
	line-height: 1;
	letter-spacing: -.01em;
	transition: color 220ms;
}
.htc-v3-treatment-row:hover .htc-v3-treatment-name { color: #9b7530; }
.htc-v3-treatment-meta { display: flex; align-items: center; gap: 1.5rem; flex-shrink: 0; }
.htc-v3-treatment-cat {
	font-size: .74rem;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: rgba(22,32,43,.36);
}
.htc-v3-treatment-arrow {
	width: 40px; height: 40px;
	border: 1px solid rgba(22,32,43,.2);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
	transition: background 220ms, border-color 220ms, color 220ms, transform 280ms var(--v3-ease);
}
.htc-v3-treatment-row:hover .htc-v3-treatment-arrow {
	background: #c4a052;
	border-color: #c4a052;
	color: #060d15;
	transform: rotate(45deg);
}

/* ── V3 Surgeon ── */
.htc-v3-surgeon { background: #0e2035; }
.htc-v3-surgeon-grid {
	display: grid;
	grid-template-columns: 400px 1fr;
	gap: clamp(3rem,6vw,7rem);
	align-items: center;
}
.htc-v3-orbit {
	position: relative;
	width: 340px; height: 340px;
	margin: 0 auto;
}
.htc-v3-orbit-ring {
	position: absolute;
	border-radius: 50%;
	top: 50%; left: 50%;
	translate: -50% -50%;
}
.htc-v3-orbit-ring--outer {
	width: 340px; height: 340px;
	background: conic-gradient(#c4a052 0deg 230deg, rgba(196,160,82,.07) 230deg 360deg);
	animation: v3-orbit 22s linear infinite;
	mask-image: radial-gradient(transparent 73%, black 74%);
	-webkit-mask-image: radial-gradient(transparent 73%, black 74%);
}
.htc-v3-orbit-ring--mid {
	width: 272px; height: 272px;
	background: conic-gradient(rgba(232,192,119,.7) 0deg 295deg, rgba(196,160,82,.06) 295deg 360deg);
	animation: v3-orbit 14s linear infinite reverse;
	mask-image: radial-gradient(transparent 69%, black 70%);
	-webkit-mask-image: radial-gradient(transparent 69%, black 70%);
}
.htc-v3-orbit-ring--inner {
	width: 208px; height: 208px;
	background: conic-gradient(rgba(196,160,82,.5) 0deg 175deg, rgba(196,160,82,.05) 175deg 360deg);
	animation: v3-orbit 9s linear infinite;
	mask-image: radial-gradient(transparent 65%, black 66%);
	-webkit-mask-image: radial-gradient(transparent 65%, black 66%);
}
@keyframes v3-orbit { to { transform: rotate(360deg); } }
.htc-v3-orbit-core {
	position: absolute;
	top: 50%; left: 50%;
	translate: -50% -50%;
	text-align: center;
	width: 170px;
}
.htc-v3-orbit-name {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: 1.65rem;
	font-weight: 300;
	color: #fff;
	line-height: 1.1;
	margin-bottom: 6px;
}
.htc-v3-orbit-role {
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: #c4a052;
}
.htc-v3-surgeon-quote {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(1.7rem,3.2vw,2.7rem);
	font-weight: 300;
	font-style: italic;
	color: #fff;
	line-height: 1.3;
	margin-bottom: 1.75rem;
}
.htc-v3-surgeon-quote::before {
	content: '\201C';
	color: #c4a052;
	font-size: 3.5rem;
	line-height: 0;
	vertical-align: -.9rem;
	margin-right: 4px;
}
.htc-v3-surgeon-attr { font-size: .84rem; font-weight: 500; color: rgba(255,255,255,.44); letter-spacing: .04em; }
.htc-v3-surgeon-creds {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: clamp(3rem,5vw,5rem);
	padding-top: clamp(2rem,4vw,3.5rem);
	border-top: 1px solid rgba(255,255,255,.08);
	max-width: 1360px;
	margin-left: auto;
	margin-right: auto;
}
.htc-v3-cred-pill {
	display: inline-flex;
	align-items: center;
	height: 34px;
	padding: 0 16px;
	border: 1px solid rgba(196,160,82,.2);
	border-radius: 100px;
	font-size: .74rem;
	font-weight: 500;
	color: rgba(255,255,255,.55);
	background: rgba(196,160,82,.04);
	letter-spacing: .04em;
}

/* ── V3 Results / film frames ── */
.htc-v3-results { background: #060d15; }
.htc-v3-results-heading {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(2.4rem,5vw,4rem);
	font-weight: 300;
	line-height: 1.1;
	margin-bottom: clamp(3rem,5vw,5rem);
}
.htc-v3-film-grid {
	display: grid;
	grid-template-columns: repeat(3,1fr);
	gap: clamp(1rem,2vw,2rem);
	margin-bottom: 2rem;
}
.htc-v3-film-frame {
	position: relative;
	aspect-ratio: 16/10;
	background: #070e17;
	border: 1px solid rgba(255,255,255,.07);
	border-radius: 4px;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}
.htc-v3-film-frame::after {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 16px;
	background: repeating-linear-gradient(90deg, transparent 0, transparent 10px, rgba(255,255,255,.06) 10px, rgba(255,255,255,.06) 24px, transparent 24px, transparent 34px);
	border-bottom: 1px solid rgba(255,255,255,.05);
}
.htc-v3-film-text {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-style: italic;
	font-size: .88rem;
	color: rgba(196,160,82,.5);
	text-align: center;
	line-height: 1.6;
	padding: 1rem;
}
.htc-v3-results-disclaimer {
	font-size: .78rem;
	color: rgba(255,255,255,.38);
	line-height: 1.65;
}
.htc-v3-film-frame--ba .htc-v3-film-text { display: none; }
.htc-v3-ba-pair {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4px;
	width: 100%;
	height: 100%;
	padding: 18px 8px 8px;
	box-sizing: border-box;
}
.htc-v3-ba-pair figure {
	margin: 0;
	position: relative;
	overflow: hidden;
	border-radius: 2px;
}
.htc-v3-ba-pair img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.htc-v3-ba-pair figcaption {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 4px 6px;
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-align: center;
	color: #fff;
	background: rgba(13, 27, 42, 0.72);
}
.htc-v3-orbit-portrait {
	width: 100%;
	max-width: 200px;
	height: auto;
	object-fit: contain;
	object-position: center bottom;
	display: block;
	margin: 0 auto;
}
.htc-v3-orbit-core {
	width: 200px;
}
.htc-card-grid--clinicians .htc-clinician-card {
	display: grid;
	gap: var(--htc-space-sm);
	padding: 0;
	overflow: hidden;
}
.htc-clinician-card__photo {
	width: 100%;
	height: 220px;
	object-fit: contain;
	object-position: center bottom;
	background: linear-gradient(180deg, var(--htc-color-stone-deep), var(--htc-color-stone));
	padding: var(--htc-space-sm) var(--htc-space-sm) 0;
	box-sizing: border-box;
}
.htc-card-grid--clinicians .htc-clinician-card span,
.htc-card-grid--clinicians .htc-clinician-card strong,
.htc-card-grid--clinicians .htc-clinician-card em {
	padding-left: var(--htc-space-md);
	padding-right: var(--htc-space-md);
}
.htc-card-grid--clinicians .htc-clinician-card em {
	padding-bottom: var(--htc-space-md);
}
.htc-v3-testimonials {
	background: var(--htc-color-stone);
	color: var(--htc-color-navy);
}
.htc-v3-testimonials .htc-v3-results-heading,
.htc-v3-testimonials .htc-v3-eyebrow {
	color: var(--htc-color-navy);
}
.htc-v3-testimonials .htc-testimonial-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--htc-space-md);
}
.htc-v3-testimonials .htc-testimonial-card {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	padding: var(--htc-space-lg);
}
.htc-v3-testimonials .htc-testimonial-card p {
	font-family: var(--htc-sans);
	font-size: 0.98rem;
	line-height: 1.55;
	color: var(--htc-color-text);
}
.htc-v3-testimonials .htc-testimonial-card__stars {
	color: var(--htc-color-gold);
	font-size: 0.85rem;
	letter-spacing: 0.08em;
}
.htc-v3-testimonials .htc-testimonial-card footer {
	margin-top: var(--htc-space-md);
	font-size: 0.82rem;
	color: var(--htc-color-muted);
}
.htc-v3-testimonials .htc-testimonial-card footer strong {
	display: block;
	color: var(--htc-color-navy);
	font-size: 0.95rem;
}
@media (max-width: 960px) {
	.htc-v3-testimonials .htc-testimonial-grid { grid-template-columns: 1fr; }
}
.htc-v3-film-frame--placeholder {
	padding: 12px;
	box-sizing: border-box;
}
.htc-v3-film-frame--placeholder img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}
.htc-v3-placeholder-badge {
	position: absolute;
	left: 12px;
	bottom: 12px;
	z-index: 2;
	padding: 4px 10px;
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--htc-color-navy);
	background: rgba(248, 245, 240, 0.92);
	border: 1px solid var(--htc-color-subtle);
	border-radius: 4px;
}
.htc-result-card--placeholder .htc-result-card__images--placeholder {
	display: block;
	grid-template-columns: 1fr;
}
.htc-result-card--placeholder .htc-result-card__images--placeholder img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: contain;
	background: var(--htc-color-stone-deep);
	border-radius: var(--htc-radius-sm);
}

/* ── V3 Journey ── */
.htc-v3-journey { background: #f5f0e8; }
.htc-v3-journey-header { text-align: center; margin-bottom: clamp(3.5rem,6vw,6rem); }
.htc-v3-journey-header h2 {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(2.4rem,5vw,4rem);
	font-weight: 300;
	color: #16202b;
	line-height: 1.1;
}
.htc-v3-journey-grid {
	display: grid;
	grid-template-columns: repeat(4,1fr);
	gap: 1px;
	background: rgba(22,32,43,.12);
	border: 1px solid rgba(22,32,43,.12);
	border-radius: 6px;
	overflow: hidden;
}
.htc-v3-journey-step {
	background: #f5f0e8;
	padding: clamp(2rem,4vw,3rem) clamp(1.5rem,2.5vw,2.5rem);
	position: relative;
	transition: background 260ms;
}
.htc-v3-journey-step:hover { background: #ece5d6; }
.htc-v3-journey-num {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(3.5rem,6vw,5.5rem);
	font-weight: 300;
	color: rgba(10,24,40,.09);
	line-height: 1;
	margin-bottom: 1.25rem;
	letter-spacing: -.04em;
}
.htc-v3-journey-title {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(1.3rem,2.2vw,1.8rem);
	font-weight: 300;
	color: #16202b;
	margin-bottom: .75rem;
}
.htc-v3-journey-desc { font-size: .88rem; line-height: 1.65; color: rgba(22,32,43,.52); }
.htc-v3-journey-line {
	position: absolute;
	bottom: 0; left: 0;
	width: 0; height: 3px;
	background: #c4a052;
	transition: width 400ms var(--v3-ease);
}
.htc-v3-journey-step:hover .htc-v3-journey-line { width: 100%; }

/* ── V3 Final CTA ── */
.htc-v3-cta {
	background: #060d15;
	padding: clamp(7rem,14vw,13rem) clamp(1.25rem,4vw,3.5rem);
	text-align: center;
	position: relative;
	overflow: hidden;
}
.htc-v3-cta::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse 55% 45% at 50% 100%, rgba(196,160,82,.07) 0%, transparent 70%);
	pointer-events: none;
}
.htc-v3-cta-inner { position: relative; z-index: 1; max-width: 1360px; margin: 0 auto; }
.htc-v3-cta h2 {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(2rem,5.5vw,5rem);
	font-weight: 300;
	font-style: italic;
	color: #fff;
	line-height: 1.2;
	max-width: 22ch;
	margin: 0 auto 3rem;
}
.htc-v3-cta-chips { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; margin-top: 2rem; }
.htc-v3-cta-chips .htc-v3-chip { background: rgba(255,255,255,.04); border-color: rgba(255,255,255,.1); color: rgba(255,255,255,.42); }

/* ── V3 FAQ ── */
.htc-v3-faq { background: #0a1828; }
.htc-v3-faq-header {
	text-align: center;
	margin-bottom: clamp(3rem,6vw,5rem);
}
.htc-v3-faq-header h2 {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(2rem,4.5vw,4rem);
	font-weight: 300;
	color: #fff;
	line-height: 1.2;
	margin: 0;
}
.htc-v3-faq-header h2 em { font-style: italic; color: #c4a052; }
.htc-v3-faq-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1px;
	background: rgba(196,160,82,.12);
	border: 1px solid rgba(196,160,82,.12);
	margin-bottom: clamp(3rem,5vw,4.5rem);
}
.htc-v3-faq-item {
	background: #0a1828;
	padding: clamp(2rem,4vw,3rem);
	transition: background .25s ease;
}
.htc-v3-faq-item:hover { background: #0e2035; }
.htc-v3-faq-q {
	font-family: "Cormorant Garamond", Georgia, serif;
	font-size: clamp(1.1rem,1.8vw,1.5rem);
	font-weight: 400;
	color: #c4a052;
	margin: 0 0 1rem;
	line-height: 1.3;
}
.htc-v3-faq-a {
	font-family: "DM Sans", sans-serif;
	font-size: .88rem;
	color: rgba(255,255,255,.6);
	line-height: 1.7;
	margin: 0;
}
.htc-v3-faq-cta { text-align: center; }

/* ── Responsive ── */
@media (max-width: 1024px) {
	.htc-v3-surgeon-grid { grid-template-columns: 1fr; text-align: center; }
	.htc-v3-surgeon-creds { justify-content: center; }
	.htc-v3-treatments-header { flex-direction: column; align-items: flex-start; }
	.htc-v3-treatments-note { text-align: left; max-width: none; }
	.htc-v3-evidence-inner { grid-template-columns: 1fr; }
	.htc-v3-numbers-grid { grid-template-columns: 1fr; }
	.htc-v3-numbers-divider { width: 60px; height: 1px; }
	.htc-v3-journey-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
	.htc-v3-film-grid { grid-template-columns: 1fr; }
	.htc-v3-journey-grid { grid-template-columns: 1fr; }
	.htc-v3-hero-actions { flex-direction: column; align-items: flex-start; gap: 1.25rem; }
	.htc-v3-faq-grid { grid-template-columns: 1fr; }
}

/* Restoration visualiser — combined upload + lead form layout */
.htc-v3-vis-form-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .9rem 1rem;
	margin-top: 1.5rem;
}
.htc-v3-vis-field-full {
	grid-column: 1 / -1;
}
.htc-v3-vis-dropzone.htc-v3-vis-has-file {
	border-style: solid;
	background: rgba(196,160,82,.06);
}
.htc-v3-vis-dropzone.htc-v3-vis-has-file .htc-v3-vis-upload-icon {
	color: rgba(196,160,82,.7) !important;
}

/* Thank-you state */
.htc-v3-vis-thanks {
	text-align: center;
	padding: 3rem 2rem;
	background: rgba(6,13,21,.5);
	border: 1px solid rgba(196,160,82,.18);
	border-radius: 6px;
}
.htc-v3-vis-thanks h3 {
	font-family: 'Cormorant Garamond', serif;
	font-size: 2.2rem;
	color: rgba(196,160,82,.95);
	margin: 0 0 1rem;
}
.htc-v3-vis-thanks p {
	color: rgba(255,255,255,.7);
	font-size: 1rem;
	max-width: 520px;
	margin: 0 auto 1.25rem;
	line-height: 1.65;
}
.htc-v3-vis-thanks .htc-v3-vis-disclaimer {
	font-size: .82rem;
	color: rgba(255,255,255,.45);
}
.htc-v3-vis-thanks .htc-v3-vis-disclaimer strong {
	display: block;
	color: rgba(255,255,255,.65);
	margin-bottom: 4px;
	font-weight: 600;
}

/* Restoration visualiser — upload error message */
.htc-v3-vis-upload-error {
	margin-top: 1rem;
	padding: .9rem 1.1rem;
	background: rgba(224,138,138,.08);
	border: 1px solid rgba(224,138,138,.3);
	border-radius: 4px;
	color: #e08a8a;
	font-size: .88rem;
	line-height: 1.5;
}

/* Lead form fields (shared, used in the combined Step 1) */
.htc-v3-vis-lead-form {
	display: flex;
	flex-direction: column;
}
.htc-v3-vis-field {
	display: flex;
	flex-direction: column;
	gap: .35rem;
	font-size: .72rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: rgba(255,255,255,.55);
}
.htc-v3-vis-field input {
	background: rgba(6,13,21,.7);
	border: 1px solid rgba(196,160,82,.22);
	border-radius: 3px;
	color: #fff;
	font-size: .95rem;
	padding: .7rem .85rem;
	font-family: inherit;
	letter-spacing: normal;
	text-transform: none;
	transition: border-color .2s;
}
.htc-v3-vis-field input:focus {
	outline: none;
	border-color: rgba(196,160,82,.72);
}
.htc-v3-vis-consent {
	grid-column: 1 / -1;
	display: flex;
	gap: .6rem;
	align-items: flex-start;
	font-size: .82rem;
	color: rgba(255,255,255,.55);
	line-height: 1.5;
}
.htc-v3-vis-consent input {
	margin-top: 3px;
	accent-color: #c4a052;
}
.htc-v3-vis-lead-actions {
	grid-column: 1 / -1;
	display: flex;
	justify-content: flex-start;
	margin-top: .25rem;
}
.htc-v3-vis-lead-status {
	grid-column: 1 / -1;
	font-size: .82rem;
	color: rgba(196,160,82,.85);
	margin: 0;
	min-height: 1.2em;
}
.htc-v3-vis-lead-status.htc-v3-vis-lead-error {
	color: #e08a8a;
}
.htc-v3-vis-lead-thanks h3 {
	font-family: 'Cormorant Garamond', serif;
	font-size: 1.65rem;
	color: rgba(196,160,82,.95);
	margin: 0 0 .35rem;
}
.htc-v3-vis-lead-thanks p {
	color: rgba(255,255,255,.6);
	font-size: .95rem;
	line-height: 1.6;
	margin: 0;
}
@media (max-width: 640px) {
	.htc-v3-vis-lead-form { grid-template-columns: 1fr; }
	.htc-v3-vis-lead { padding: 1.5rem; }
}

/* ── Treatment card imagery ── */
.htc-card--treatment {
	padding: 0;
	overflow: hidden;
}

.htc-card--treatment::before {
	left: 0;
	right: 0;
}

.htc-card--treatment .htc-card__media {
	aspect-ratio: 16 / 10;
	display: block;
	object-fit: cover;
	width: 100%;
}

.htc-card--treatment .htc-card__body {
	padding: var(--htc-space-lg);
}

.htc-card--treatment .htc-card__body::before {
	display: none;
}

/* ── Treatment / about visual splits ── */
.htc-split--visual {
	align-items: center;
}

.htc-treatment-visual {
	background: var(--htc-color-stone-deep);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	line-height: 0;
	overflow: hidden;
}

.htc-treatment-visual img {
	aspect-ratio: 4 / 5;
	display: block;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.htc-about-mission .htc-treatment-visual img {
	aspect-ratio: 4 / 5;
	max-height: 520px;
}

.htc-split--visual .htc-copy-panel h2 {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: clamp(1.85rem, 5vw, 2.75rem);
	font-weight: 400;
	line-height: 1.08;
	margin: 0 0 var(--htc-space-md);
	max-width: 18ch;
}

@media (min-width: 900px) {
	.htc-split--visual {
		grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
	}

	.htc-about-mission.htc-split--visual,
	.htc-about-mission .htc-split--visual {
		grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
	}

	.htc-treatment-visual img {
		aspect-ratio: 16 / 10;
	}
}

/* ── FAQ page (light) ── */
.htc-page-faq-body {
	padding-bottom: var(--htc-space-2xl);
}

.htc-faq-jump {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.75rem;
	margin-bottom: var(--htc-space-xl);
}

.htc-faq-jump a {
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid var(--htc-color-subtle);
	border-radius: 999px;
	color: var(--htc-color-navy);
	font-size: 0.82rem;
	font-weight: 600;
	padding: 0.45rem 0.85rem;
	text-decoration: none;
}

.htc-faq-jump a:hover,
.htc-faq-jump a:focus {
	border-color: var(--htc-color-gold);
	color: var(--htc-color-gold-deep);
}

.htc-faq-section {
	margin-bottom: var(--htc-space-2xl);
	padding-top: var(--htc-space-md);
}

.htc-faq-section h2 {
	border-bottom: 1px solid var(--htc-color-subtle);
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: clamp(1.75rem, 5vw, 2.35rem);
	font-weight: 400;
	margin: 0 0 var(--htc-space-lg);
	padding-bottom: var(--htc-space-sm);
}

.htc-faq-list {
	display: grid;
	gap: var(--htc-space-md);
}

.htc-faq-item {
	background: rgba(255, 255, 255, 0.88);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	padding: var(--htc-space-md) var(--htc-space-lg);
}

.htc-faq-q {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: clamp(1.2rem, 3.5vw, 1.45rem);
	font-weight: 400;
	line-height: 1.2;
	margin: 0 0 var(--htc-space-xs);
}

.htc-faq-a {
	color: var(--htc-color-text);
	font-size: 1rem;
	line-height: 1.7;
	margin: 0;
	max-width: 72ch;
}

.htc-faq-footer-note {
	background: var(--htc-color-navy);
	border-radius: var(--htc-radius);
	color: rgba(255, 255, 255, 0.88);
	padding: var(--htc-space-lg);
}

.htc-faq-footer-note p {
	margin: 0;
	max-width: 62ch;
}

.htc-faq-footer-note a {
	color: var(--htc-color-gold);
}

/* ── Before/After system ── */
.htc-ba-single__placeholder-notice {
	margin: 0 0 1.25rem;
	padding: 0.75rem 1rem;
	background: var(--wp--preset--color--warm-stone, #f8f5f0);
	border-left: 3px solid var(--wp--preset--color--gold, #c9a84c);
	font-size: 0.875rem;
}

.htc-ba-single__nav {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--wp--preset--color--divider, #e5e0d8);
	font-size: 0.9375rem;
}

.htc-ba-category-nav__list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--htc-space-xs);
	margin: var(--htc-space-md) 0 var(--htc-space-lg);
}

.htc-ba-category-nav__link {
	border: 1px solid var(--htc-color-subtle);
	border-radius: 999px;
	color: var(--htc-color-navy);
	font-size: 0.88rem;
	font-weight: 600;
	padding: 0.45rem 0.95rem;
	text-decoration: none;
}

.htc-ba-category-nav__link.is-active,
.htc-ba-category-nav__link:hover {
	background: var(--htc-color-navy);
	border-color: var(--htc-color-navy);
	color: var(--htc-color-white);
}

.htc-ba-case-card__link {
	color: inherit;
	display: block;
	text-decoration: none;
}

.htc-ba-case-card .htc-result-card__images img {
	aspect-ratio: 3 / 4;
	border-radius: var(--htc-radius-sm);
	object-fit: cover;
	width: 100%;
}

.htc-ba-case-card__badge {
	color: var(--htc-color-muted);
	font-size: 0.75rem;
	margin: var(--htc-space-2xs) 0 0;
}

.htc-ba-single__back {
	margin-bottom: var(--htc-space-sm);
}

.htc-ba-single__facts {
	list-style: none;
	margin: var(--htc-space-md) 0;
	padding: 0;
}

.htc-ba-single__facts li {
	margin-bottom: var(--htc-space-2xs);
}

.htc-ba-single__images figure {
	margin: 0;
}

.htc-ba-single__images figcaption {
	color: var(--htc-color-muted);
	font-size: 0.78rem;
	margin-top: var(--htc-space-2xs);
	text-transform: uppercase;
}

/* Screen-reader only utility — visually hidden but readable by search engines and assistive tech */
.htc-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ─── References section ─────────────────────────────────── */
.htc-post-body .wp-block-separator {
	border: none;
	border-top: 1px solid var(--htc-color-subtle);
	margin: var(--htc-space-2xl) 0 var(--htc-space-lg);
}

.htc-post-body h2:has(+ .htc-references),
.htc-post-body h2 + .htc-references ~ h2 {
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--htc-color-muted);
	margin-bottom: var(--htc-space-sm);
}

.htc-references {
	font-size: 0.82rem;
	line-height: 1.6;
	color: var(--htc-color-muted);
	padding: var(--htc-space-xs) var(--htc-space-md);
	border-left: 2px solid var(--htc-color-subtle);
	margin-bottom: var(--htc-space-2xs) !important;
}

.htc-references strong {
	color: var(--htc-color-navy);
	margin-right: 0.4em;
}

.htc-references em {
	font-style: italic;
}

/* ─── Blog listing & single ───────────────────────────────── */
.htc-page--blog-index .htc-post-listing.htc-blog-grid {
	background: transparent;
	border: none;
	padding: 0;
	max-width: var(--htc-content-max);
}

.htc-blog-grid-inner {
	display: grid;
	gap: var(--htc-space-lg);
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 768px) {
	.htc-blog-grid-inner {
		grid-template-columns: 1fr;
	}
}

.htc-blog-card {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	box-shadow: var(--htc-shadow-soft);
	display: flex;
	flex-direction: column;
	height: 100%;
	overflow: hidden;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.htc-blog-card:hover {
	box-shadow: var(--htc-shadow-card);
	transform: translateY(-2px);
}

.htc-blog-card__image img {
	aspect-ratio: 16 / 9;
	display: block;
	object-fit: cover;
	width: 100%;
}

.htc-blog-card__title {
	font-family: var(--htc-serif);
	font-size: 1.35rem;
	font-weight: 400;
	line-height: 1.25;
	margin: var(--htc-space-md) var(--htc-space-md) var(--htc-space-xs);
}

.htc-blog-card__title a {
	color: var(--htc-color-navy);
	text-decoration: none;
}

.htc-blog-card__title a:hover {
	color: var(--htc-color-gold-deep);
}

.htc-blog-card__excerpt {
	color: var(--htc-color-muted);
	font-size: 0.95rem;
	line-height: 1.65;
	margin: 0 var(--htc-space-md) var(--htc-space-sm);
}

.htc-blog-card__excerpt a.read-more {
	color: var(--htc-color-gold-deep);
	font-weight: 600;
	text-decoration: none;
}

.htc-blog-card__date {
	color: var(--htc-color-muted);
	font-size: 0.8rem;
	margin: auto var(--htc-space-md) var(--htc-space-md);
}

.htc-blog-pagination {
	margin-top: var(--htc-space-xl);
}

/* Single post */
.htc-page--blog-single .htc-blog-hero {
	margin-bottom: var(--htc-space-md);
}

.htc-blog-hero .htc-page-standfirst {
	color: rgba(255, 255, 255, 0.88);
	font-size: 1.1rem;
	line-height: 1.65;
	margin-bottom: var(--htc-space-sm);
	max-width: 42rem;
}

.htc-blog-hero .wp-block-post-terms a,
.htc-blog-hero .wp-block-post-terms {
	color: var(--htc-color-gold);
	text-decoration: none;
}

.htc-blog-hero .htc-post-meta {
	color: rgba(255, 255, 255, 0.65);
	font-size: 0.9rem;
}

.htc-blog-featured-wrap {
	margin-bottom: var(--htc-space-lg);
}

.htc-blog-featured img,
.wp-block-post-featured-image.htc-blog-featured img {
	border-radius: var(--htc-radius);
	box-shadow: var(--htc-shadow-card);
	display: block;
	height: auto;
	max-height: 420px;
	object-fit: cover;
	width: 100%;
}

.htc-post-body--blog {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	box-shadow: var(--htc-shadow-soft);
	margin-bottom: var(--htc-space-2xl);
	padding: var(--htc-space-xl) var(--htc-space-lg);
}

.htc-blog-article {
	font-size: 1.05rem;
	line-height: 1.75;
}

.htc-blog-hero-media {
	margin: 0 0 var(--htc-space-lg);
}

.htc-blog-hero-media img {
	border-radius: var(--htc-radius);
	box-shadow: var(--htc-shadow-soft);
	display: block;
	height: auto;
	max-height: 360px;
	object-fit: cover;
	width: 100%;
}

.htc-key-takeaway {
	background: linear-gradient(135deg, rgba(13, 27, 42, 0.04), rgba(201, 168, 76, 0.12));
	border: 1px solid var(--htc-color-subtle);
	border-left: 4px solid var(--htc-color-gold);
	border-radius: var(--htc-radius-sm);
	margin: 0 0 var(--htc-space-lg);
	padding: var(--htc-space-md) var(--htc-space-lg);
}

.htc-key-takeaway-label {
	color: var(--htc-color-gold-deep);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	margin: 0 0 var(--htc-space-xs);
	text-transform: uppercase;
}

.htc-key-takeaway p {
	margin: 0 0 var(--htc-space-xs);
}

.htc-key-takeaway p:last-child {
	margin-bottom: 0;
}

.htc-post-body--blog h2 {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: 1.65rem;
	font-weight: 400;
	margin-top: var(--htc-space-xl);
}

.htc-post-body--blog h3,
.htc-myth-title {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: 1.25rem;
	font-weight: 400;
	margin-top: var(--htc-space-lg);
}

.htc-myth-truth {
	font-size: 1.05rem;
}

.htc-myth-persist {
	color: var(--htc-color-muted);
	font-size: 0.95rem;
}

.htc-table-wrap {
	margin: var(--htc-space-md) 0 var(--htc-space-lg);
	overflow-x: auto;
}

.htc-blog-table {
	border-collapse: collapse;
	font-size: 0.95rem;
	min-width: 100%;
}

.htc-blog-table th,
.htc-blog-table td {
	border-bottom: 1px solid var(--htc-color-subtle);
	padding: var(--htc-space-sm) var(--htc-space-md);
	text-align: left;
	vertical-align: top;
}

.htc-blog-table th {
	background: var(--htc-color-stone);
	color: var(--htc-color-navy);
	font-weight: 600;
}

.htc-blog-table tr:last-child td {
	border-bottom: none;
}

.htc-divider {
	border: none;
	border-top: 1px solid var(--htc-color-subtle);
	margin: var(--htc-space-xl) 0;
}

.htc-faq-heading {
	margin-bottom: var(--htc-space-md);
}

.htc-faq {
	display: flex;
	flex-direction: column;
	gap: var(--htc-space-xs);
	margin-bottom: var(--htc-space-lg);
}

.htc-faq-item {
	background: var(--htc-color-stone);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius-sm);
	padding: 0;
}

.htc-faq-item summary {
	cursor: pointer;
	font-weight: 600;
	list-style: none;
	padding: var(--htc-space-sm) var(--htc-space-md);
}

.htc-faq-item summary::-webkit-details-marker {
	display: none;
}

.htc-faq-item summary::after {
	color: var(--htc-color-gold);
	content: "+";
	float: right;
	font-weight: 700;
}

.htc-faq-item[open] summary::after {
	content: "−";
}

.htc-faq-answer {
	border-top: 1px solid var(--htc-color-subtle);
	padding: var(--htc-space-sm) var(--htc-space-md) var(--htc-space-md);
}

.htc-faq-answer p {
	color: var(--htc-color-muted);
	margin: 0;
}

.htc-blog-cta {
	margin: var(--htc-space-lg) 0;
	text-align: center;
}

.htc-blog-cta .htc-btn--gold {
	display: inline-block;
	padding: 0.85rem 1.75rem;
	text-decoration: none;
}

.htc-post-body--blog a:not(.htc-btn) {
	color: var(--htc-color-navy);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.htc-post-body--blog a:not(.htc-btn):hover {
	color: var(--htc-color-gold-deep);
}

.htc-post-body--blog ul.htc-list,
.htc-post-body--blog ol.htc-list {
	margin: var(--htc-space-sm) 0 var(--htc-space-md);
	padding-left: 1.25rem;
}

.htc-post-body--blog li {
	margin-bottom: 0.35rem;
}

.htc-blog-inline {
	margin: var(--htc-space-md) 0 var(--htc-space-lg);
}

.htc-blog-inline img {
	border-radius: var(--htc-radius-sm);
	box-shadow: var(--htc-shadow-soft);
	display: block;
	height: auto;
	width: 100%;
}

.htc-blog-inline figcaption {
	color: var(--htc-color-muted);
	font-size: 0.85rem;
	line-height: 1.5;
	margin-top: var(--htc-space-xs);
	text-align: center;
}

.htc-related-posts-section {
	margin-bottom: var(--htc-space-2xl);
	margin-top: var(--htc-space-xl);
}

.htc-related-posts-heading {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: 1.75rem;
	font-weight: 400;
	margin-bottom: var(--htc-space-md);
}

.htc-related-posts-grid {
	display: grid;
	gap: var(--htc-space-md);
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 900px) {
	.htc-related-posts-grid {
		grid-template-columns: 1fr;
	}
}

.htc-blog-card--compact .htc-blog-card__title {
	font-size: 1.1rem;
	margin-top: var(--htc-space-sm);
}

.htc-blog-card--compact .htc-blog-card__date {
	margin-top: var(--htc-space-xs);
}

/* ─── Treatment detail pages (beard / eyebrow / enriched) ── */
.htc-page--treatment-detail .htc-treatment-hero,
.htc-page--treatment-hub .htc-treatment-hero {
	margin-bottom: var(--htc-space-md);
}

.htc-page--treatment-hub .htc-treatment-foundation {
	margin-top: 0;
}

.htc-treatment-featured-wrap {
	margin-bottom: var(--htc-space-lg);
	max-width: 960px;
	margin-left: auto;
	margin-right: auto;
}

.htc-treatment-featured {
	margin: 0;
}

.htc-treatment-featured img {
	border-radius: var(--htc-radius);
	box-shadow: var(--htc-shadow-card);
	display: block;
	height: auto;
	max-height: 420px;
	object-fit: cover;
	width: 100%;
}

.htc-treatment-content-shell {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius);
	box-shadow: var(--htc-shadow-soft);
	margin-bottom: var(--htc-space-xl);
	padding: var(--htc-space-xl) var(--htc-space-lg);
}

.htc-treatment-content-shell h2,
.htc-treatment-content-shell .htc-shell-h2 {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: 1.65rem;
	font-weight: 400;
	margin-top: var(--htc-space-xl);
}

.htc-treatment-content-shell h2:first-of-type,
.htc-treatment-content-shell .htc-key-takeaway + h2 {
	margin-top: var(--htc-space-lg);
}

.htc-treatment-content-shell p,
.htc-treatment-content-shell li,
.htc-treatment-content-shell > div:not([class]) {
	color: var(--htc-color-text);
	font-size: 1.05rem;
	line-height: 1.75;
}

.htc-treatment-content-shell .htc-list > div {
	margin-bottom: 0.35rem;
	padding-left: 1.25rem;
	position: relative;
}

.htc-treatment-content-shell .htc-list > div::before {
	content: "•";
	left: 0;
	position: absolute;
}

.htc-treatment-inline {
	margin: var(--htc-space-md) 0 var(--htc-space-lg);
}

.htc-treatment-inline img {
	border-radius: var(--htc-radius-sm);
	box-shadow: var(--htc-shadow-soft);
	display: block;
	height: auto;
	width: 100%;
}

.htc-treatment-inline figcaption,
.htc-treatment-inline-caption {
	color: var(--htc-color-muted);
	font-size: 0.85rem;
	line-height: 1.5;
	margin-top: var(--htc-space-xs);
	text-align: center;
}

.htc-treatment-featured--media,
.htc-treatment-inline--media {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	display: block;
	width: 100%;
}

.htc-treatment-featured--media {
	border-radius: var(--htc-radius);
	box-shadow: var(--htc-shadow-card);
	aspect-ratio: 1200 / 630;
	max-height: 420px;
}

.htc-treatment-inline--media {
	border-radius: var(--htc-radius-sm);
	box-shadow: var(--htc-shadow-soft);
	aspect-ratio: 16 / 9;
}

.htc-related-treatments {
	margin-bottom: var(--htc-space-2xl);
}

.htc-related-treatments-heading {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: 1.75rem;
	font-weight: 400;
	margin-bottom: var(--htc-space-md);
}

.htc-related-treatments-grid {
	display: grid;
	gap: var(--htc-space-md);
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (min-width: 768px) {
	.htc-related-treatments-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

.htc-related-tile {
	background: var(--htc-color-white);
	border: 1px solid var(--htc-color-subtle);
	border-radius: var(--htc-radius-sm);
	box-shadow: var(--htc-shadow-soft);
	color: inherit;
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding: var(--htc-space-md);
	text-decoration: none;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.htc-related-tile:hover {
	box-shadow: var(--htc-shadow-card);
	transform: translateY(-2px);
}

.htc-related-tile span {
	color: var(--htc-color-gold-deep);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.htc-related-tile strong {
	color: var(--htc-color-navy);
	font-family: var(--htc-serif);
	font-size: 1.05rem;
	font-weight: 400;
	line-height: 1.3;
}

/* Floating WhatsApp CTA — opens wa.me (app on mobile, WhatsApp Web on desktop). */
.htc-whatsapp-float {
	position: fixed;
	z-index: 9998;
	right: max(1rem, env(safe-area-inset-right, 0px));
	bottom: max(1rem, env(safe-area-inset-bottom, 0px));
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.65rem 0.95rem 0.65rem 0.75rem;
	border-radius: 999px;
	background: #25d366;
	color: #fff;
	font-family: var(--htc-sans);
	font-size: 0.82rem;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.22);
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.htc-whatsapp-float:hover,
.htc-whatsapp-float:focus {
	background: #1ebe57;
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.28);
}

.htc-whatsapp-float:focus-visible {
	outline: 2px solid var(--htc-color-navy, #0d1b2a);
	outline-offset: 3px;
}

.htc-whatsapp-float__icon {
	display: flex;
	flex-shrink: 0;
	line-height: 0;
}

.htc-whatsapp-float__label {
	white-space: nowrap;
}

@media (max-width: 520px) {
	.htc-whatsapp-float__label {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}

	.htc-whatsapp-float {
		padding: 0.85rem;
		border-radius: 50%;
	}
}

@media (min-width: 992px) {
	.htc-whatsapp-float {
		right: 1.5rem;
		bottom: 1.5rem;
	}
}
