@font-face {
	font-family: 'Source Sans 3';
	font-style: normal;
	font-weight: 200 900;
	font-display: swap;
	src: url('../fonts/source-sans-3/source-sans-3-normal-latin.woff2') format('woff2');
	unicode-range:
		U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308,
		U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
	font-family: 'Source Sans 3';
	font-style: normal;
	font-weight: 200 900;
	font-display: swap;
	src: url('../fonts/source-sans-3/source-sans-3-normal-latin-ext.woff2') format('woff2');
	unicode-range:
		U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329,
		U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113,
		U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
	font-family: 'Source Sans 3';
	font-style: normal;
	font-weight: 200 900;
	font-display: swap;
	src: url('../fonts/source-sans-3/source-sans-3-normal-cyrillic.woff2') format('woff2');
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

@font-face {
	font-family: 'Source Sans 3';
	font-style: normal;
	font-weight: 200 900;
	font-display: swap;
	src: url('../fonts/source-sans-3/source-sans-3-normal-cyrillic-ext.woff2') format('woff2');
	unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
	font-family: 'Source Sans 3';
	font-style: italic;
	font-weight: 200 900;
	font-display: swap;
	src: url('../fonts/source-sans-3/source-sans-3-italic-latin.woff2') format('woff2');
	unicode-range:
		U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308,
		U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
	font-family: 'Source Sans 3';
	font-style: italic;
	font-weight: 200 900;
	font-display: swap;
	src: url('../fonts/source-sans-3/source-sans-3-italic-latin-ext.woff2') format('woff2');
	unicode-range:
		U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329,
		U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113,
		U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
	font-family: 'Source Sans 3';
	font-style: italic;
	font-weight: 200 900;
	font-display: swap;
	src: url('../fonts/source-sans-3/source-sans-3-italic-cyrillic.woff2') format('woff2');
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

@font-face {
	font-family: 'Source Sans 3';
	font-style: italic;
	font-weight: 200 900;
	font-display: swap;
	src: url('../fonts/source-sans-3/source-sans-3-italic-cyrillic-ext.woff2') format('woff2');
	unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
	font-family: 'Noto Sans Arabic';
	font-style: normal;
	font-weight: 100 900;
	font-display: swap;
	src: url('../fonts/noto-sans-arabic/noto-sans-arabic-arabic.woff2') format('woff2');
	unicode-range:
		U+0600-06FF, U+0750-077F, U+0870-088E, U+0890-0891, U+0897-08E1, U+08E3-08FF, U+200C-200E,
		U+2010-2011, U+204F, U+2E41, U+FB50-FDFF, U+FE70-FE74, U+FE76-FEFC;
}

@font-face {
	font-family: 'Noto Sans Arabic';
	font-style: normal;
	font-weight: 100 900;
	font-display: swap;
	src: url('../fonts/noto-sans-arabic/noto-sans-arabic-latin.woff2') format('woff2');
	unicode-range:
		U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308,
		U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
	font-family: 'Noto Sans Arabic';
	font-style: normal;
	font-weight: 100 900;
	font-display: swap;
	src: url('../fonts/noto-sans-arabic/noto-sans-arabic-latin-ext.woff2') format('woff2');
	unicode-range:
		U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329,
		U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113,
		U+2C60-2C7F, U+A720-A7FF;
}

:root {
	--font-primary: 'Source Sans 3', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	--font-arabic: 'Noto Sans Arabic', Tahoma, Arial, sans-serif;
	--font: var(--font-primary);
	--text-display: clamp(2.5rem, 1.9rem + 3vw, 4rem);
	--text-h1: clamp(2.25rem, 1.8rem + 2.2vw, 3.5rem);
	--text-h2: clamp(1.75rem, 1.45rem + 1.5vw, 2.5rem);
	--text-h3: clamp(1.375rem, 1.2rem + 0.9vw, 1.875rem);
	--text-h4: clamp(1.125rem, 1.05rem + 0.4vw, 1.375rem);
	--text-section-title: clamp(1.95rem, 1.5rem + 1.85vw, 3rem);
	--text-lead: clamp(1.125rem, 1.02rem + 0.5vw, 1.375rem);
	--text-body-lg: clamp(1.0625rem, 1.02rem + 0.2vw, 1.125rem);
	--text-body: clamp(1rem, 0.97rem + 0.15vw, 1.0625rem);
	--text-small: 0.875rem;
	--measure-reading: 68ch;
	--color-body: #24384f;
	--color-muted: #5f7184;
	--color-primary: #1769aa;
	--color-primary-dark: #0d477f;
	--color-primary-bright: #2f8fd3;
	--color-primary-soft: #eaf5ff;
	--color-surface-warm: #ffffff;
	--color-surface-soft: #f6fbff;
	--color-line-soft: #d8e8f5;
	--color-trust-blue: #2f80c4;
	--color-ink-strong: #102f4f;
	--color-shadow-soft: rgba(16, 47, 79, 0.08);
	--color-whatsapp: #25d366;
	--color-whatsapp-dark: #1da851;
	--color-success: #027a48;
	--color-danger: #b42318;
	--color-gold: #c9a45c;
	--site-container-max: 1540px;
	--site-container-gutter: clamp(15px, 3.35vw, 64px);
	--public-page-max: 1320px;
	--public-content-max: 760px;
	--public-reading-max: 72ch;
	--public-section-y: clamp(52px, 6vw, 86px);
	--weight-regular: 400;
	--weight-medium: 500;
	--weight-semibold: 600;
	--weight-heading: 650;
	--weight-display: 700;
	--weight-emphasis: 750;
	--topstrip-height: 36px;
	--navbar-offset-top: var(--topstrip-height);
	--navbar-height: 78px;
	--cookie-banner-space: 7.5rem;
	--cookie-banner-space-mobile: 8.75rem;
}

html {
	font-size: 100%;
	-webkit-text-size-adjust: 100%;
	scroll-padding-top: calc(var(--navbar-offset-top) + var(--navbar-height) + 16px);
	text-size-adjust: 100%;
}

[id] {
	scroll-margin-top: calc(var(--navbar-offset-top) + var(--navbar-height) + 16px);
}

body {
	font-family: var(--font);
	font-optical-sizing: auto;
	font-weight: var(--weight-regular);
	font-style: normal;
	font-variation-settings: 'wdth' 100;
	font-size: var(--text-body);
	line-height: 1.6;
	color: var(--color-body);
	--document-height: 100vh;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

body.sh-cookie-banner-visible {
	padding-bottom: var(--cookie-banner-space);
}

.skip-link {
	background: var(--color-primary);
	border-radius: 0 0 10px 10px;
	color: #fff !important;
	font-weight: var(--weight-semibold);
	left: var(--site-container-gutter);
	padding: 10px 16px;
	position: fixed;
	text-decoration: none !important;
	top: 0;
	transform: translateY(-120%);
	transition: transform 0.18s ease;
	z-index: 10000;
}

.skip-link:focus,
.skip-link:focus-visible {
	outline: 3px solid rgba(47, 143, 211, 0.36);
	outline-offset: 3px;
	transform: translateY(0);
}

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

.container {
	max-width: var(--site-container-max);
	padding-left: var(--site-container-gutter);
	padding-right: var(--site-container-gutter);
}

a {
	color: #0067db;
}

button,
input,
select,
textarea {
	font: inherit;
}

:lang(ar),
[dir='rtl'] {
	font-family: var(--font-arabic);
	letter-spacing: normal;
}

:lang(ar) body,
[dir='rtl'] body {
	line-height: 1.75;
}

:lang(ar) h1,
:lang(ar) h2,
:lang(ar) h3,
:lang(ar) h4,
:lang(ar) h5,
:lang(ar) h6,
[dir='rtl'] h1,
[dir='rtl'] h2,
[dir='rtl'] h3,
[dir='rtl'] h4,
[dir='rtl'] h5,
[dir='rtl'] h6 {
	letter-spacing: normal;
	line-height: 1.3;
}

/* Pre-size feather icon placeholders to prevent layout shift before JS runs */
[data-feather] {
	display: inline-block;
	width: 24px;
	height: 24px;
	vertical-align: middle;
}

body.topstrip-hidden {
	--navbar-offset-top: 0px;
}

.topstrip {
	background: linear-gradient(90deg, #0d477f 0%, #1769aa 52%, #2f8fd3 100%);
	color: #fff;
	height: var(--topstrip-height);
	overflow: hidden;
	position: sticky;
	top: 0;
	transition: height 0.26s cubic-bezier(0.4, 0, 0.2, 1);
	z-index: 1002;
}

.topstrip__inner {
	align-items: center;
	display: flex;
	gap: 1rem;
	height: 100%;
	justify-content: space-between;
	margin-left: auto;
	margin-right: auto;
	max-width: var(--site-container-max);
	padding-left: var(--site-container-gutter);
	padding-right: var(--site-container-gutter);
	transform: translateY(0);
	transition:
		opacity 0.18s ease,
		transform 0.26s cubic-bezier(0.4, 0, 0.2, 1);
	width: 100%;
}

.topstrip__trust,
.topstrip__actions,
.topstrip__link {
	align-items: center;
	display: inline-flex;
}

.topstrip__trust {
	color: rgba(255, 255, 255, 0.9);
	flex: 1 1 auto;
	font-size: 0.84rem;
	font-weight: var(--weight-heading);
	gap: 0.45rem;
	letter-spacing: 0.01em;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.topstrip__actions {
	flex: 0 0 auto;
	gap: 0.25rem;
	height: 100%;
}

.topstrip__link {
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.84rem;
	font-weight: var(--weight-heading);
	gap: 0.35rem;
	height: 100%;
	padding: 0 0.55rem;
	text-decoration: none !important;
	transition:
		background-color 0.16s ease,
		color 0.16s ease;
	white-space: nowrap;
}

.topstrip__link:hover,
.topstrip__link:focus {
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
}

.topstrip__link--primary {
	color: #fff;
}

.topstrip svg {
	flex: 0 0 auto;
	height: 14px;
	stroke-width: 2.2;
	width: 14px;
}

.topstrip__dot {
	background: rgba(255, 255, 255, 0.45);
	border-radius: 999px;
	display: inline-block;
	flex: 0 0 auto;
	height: 4px;
	width: 4px;
}

.topstrip__trust-short {
	display: none;
}

.topstrip__certificate,
.topstrip__language {
	align-items: center;
	border-radius: 999px;
	color: inherit;
	display: inline-flex;
	flex: 0 0 auto;
	font-size: 0.84rem;
	font-weight: var(--weight-semibold);
	min-height: 24px;
	text-decoration: none !important;
	white-space: nowrap;
}

.topstrip__certificate {
	padding: 0 0.45rem;
}

.topstrip__certificate:hover,
.topstrip__certificate:focus {
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
}

.topstrip__language {
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.22);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18);
	color: rgba(255, 255, 255, 0.82);
	gap: 0;
	overflow: hidden;
	padding: 2px;
}

.topstrip__language a {
	align-items: center;
	border: 1px solid transparent;
	border-radius: 999px;
	color: inherit;
	display: inline-flex;
	font-size: 0.75rem;
	font-weight: var(--weight-heading);
	justify-content: center;
	line-height: 1;
	min-height: 22px;
	min-width: 30px;
	padding: 0.22rem 0.42rem;
	text-align: center;
	text-decoration: none;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease,
		color 0.18s ease;
}

.topstrip__language a:hover,
.topstrip__language a:focus {
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.2);
	color: #fff;
}

.topstrip__language a:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.75);
	outline-offset: 2px;
}

.topstrip__language a[aria-current='true'] {
	background: #fff;
	border-color: rgba(255, 255, 255, 0.78);
	box-shadow: 0 1px 4px rgba(16, 47, 79, 0.12);
	color: #1769aa;
}

body.topstrip-hidden .topstrip {
	height: 0;
}

body.topstrip-hidden .topstrip__inner {
	opacity: 0;
	transform: translateY(-8px);
}

nav.navbar {
	padding: 0 !important;
	display: flex;
	align-items: center;
	position: sticky;
	top: var(--navbar-offset-top);
	height: var(--navbar-height);
	z-index: 1001;
	background: var(--color-primary);
	transition: top 0.26s cubic-bezier(0.4, 0, 0.2, 1);
	/*    background: #00157c;*/
}

nav.navbar > .container {
	margin-left: auto;
	margin-right: auto;
	max-width: var(--site-container-max);
	width: 100%;
	padding-left: var(--site-container-gutter);
	padding-right: var(--site-container-gutter);
}

nav.navbar .logo-wrapper {
	flex: 0 0 auto;
}

nav.navbar .logo {
	height: 50px;
	width: auto;
	max-width: min(220px, 58vw);
	object-fit: contain;
	display: block;
}

.main-bar {
	background: #f8f8f8;
	color: #000 !important;
}
.main-bar svg {
	stroke: #000;
	stroke-width: 2;
	width: 18px;
}

.navbar .dropdown-menu .row {
	margin-bottom: 1rem;
}

.navbar .dropdown-menu {
	border: none;
	background-color: #fff !important;
}

.navbar-expand-lg .navbar-nav .nav-item {
	padding: 0 !important;
	height: 100%;
}
.navbar-expand-lg .navbar-nav .menu-item {
	border-bottom: 1px solid var(--color-body) !important;
}
.navbar-expand-lg .navbar-collapse {
	height: 100%;
}

.navbar-expand-lg .navbar-collapse .navbar-nav {
	height: 100%;
	align-items: center;
	margin-top: 2px;
	gap: 0;
}
.navbar-expand-lg .navbar-nav .nav-link {
	gap: 0.28rem;
	margin-inline-end: 0;
	display: inline-flex;
	justify-content: flex-start;
	align-items: center;
	color: #fff;
	border-bottom: 4px solid transparent;
	height: 100%;
	font-weight: var(--weight-medium);
	padding-inline: 0.42rem;
	transition: color 0.18s ease;
}

.navbar-expand-lg .navbar-nav .dropdown-menu a {
	border-width: 0;
}

.navbar-expand-lg .navbar-nav .dropdown-menu a:hover {
	border-width: 0;
}

.navbar-expand-lg .navbar-nav .nav-link span {
	font-size: 1rem;
	text-align: start;
	white-space: pre-line;
	color: inherit;
}

.navbar-expand-lg .navbar-nav .nav-label-short {
	display: none;
}

.navbar-expand-lg .navbar-nav .nav-link svg {
	width: 16px;
	height: 24px;
	margin-left: 0;
	transition: transform 0.18s ease;
}

.nav-mobile-disclosure {
	display: none;
}

.navbar-expand-lg .navbar-nav .nav-link:after {
	display: none;
}

.navbar-expand-lg .navbar-nav .nav-link[aria-expanded='true'] {
	color: #fff;
}

.navbar-expand-lg .navbar-nav .nav-link[aria-current='page'],
.navbar-expand-lg .navbar-nav .nav-link.active {
	color: #fff;
	font-weight: var(--weight-semibold);
}

.navbar-expand-lg .navbar-nav .dropdown.show > .nav-link svg,
.navbar-expand-lg .navbar-nav .nav-link[aria-expanded='true'] svg {
	transform: rotate(180deg);
}

.nav .nav-link {
	color: var(--color-body) !important;
}

.navbar-expand-lg .nav-item.show .dropdown-overlay {
	display: none !important;
}

.navbar-expand-lg a.navbar-call-action {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	color: #fff;
	border-bottom: 2px solid transparent;
	text-decoration: none !important;
}

.navbar-expand-lg a.navbar-call-action:hover {
	border-bottom: 2px solid #fff;
}

.navbar-toggler {
	color: #fff;
}

.navbar-mobile-cta {
	display: none;
}

.nav-mega__intro {
	display: none;
}

.nav-mega__eyebrow,
.nav-mega__group-title,
.nav-mega__group-description,
.nav-mega__description,
.nav-mega__link-note {
	margin: 0;
}

.nav-mega__eyebrow {
	color: var(--color-primary-dark);
	font-size: 0.78rem;
	font-weight: var(--weight-heading);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.nav-mega__description {
	color: var(--color-body);
	font-size: 1rem;
	line-height: 1.45;
	margin-top: 5px;
}

.nav-mega__group {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.nav-mega__group-title {
	color: var(--color-ink-strong);
	font-size: 0.92rem;
	font-weight: var(--weight-heading);
}

.nav-mega__group-description {
	color: var(--color-muted);
	font-size: 0.88rem;
	line-height: 1.4;
}

.nav-mega__link {
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.nav-mega__list {
	display: grid;
	list-style: none;
	margin: 0;
	padding: 0;
}

.nav-mega__link-label,
.nav-mega__link-note {
	display: block;
	width: 100%;
}

.nav-mega__link-note {
	color: var(--color-muted);
	font-size: 0.78rem;
	font-weight: var(--weight-medium);
	line-height: 1.25;
}

.navbar-expand-lg .navbar-nav .nav-mega__link-note {
	font-size: 0.78rem;
}

.nav-mega__link--featured {
	background: var(--color-primary-soft);
	color: var(--color-primary-dark) !important;
}

.nav-mega__group--compact .nav-mega__link {
	gap: 0;
}

.letter-box {
	display: grid;
	gap: 8px;
	grid-template-columns: repeat(auto-fill, 48px);
	margin: 0;
	margin-block-start: 0;
	padding-inline-start: 0;
}

.letter-box li {
	list-style: none;
}

.letter-box li a {
	border-radius: 50%;
	display: flex;
	width: 48px;
	height: 48px;
	justify-content: center;
	align-items: center;
	text-align: center;
	border: 1px solid #161616;
	color: #161616;
}

.letter-box li a.active {
	background: var(--color-primary);
	color: #fff;
	border: 1px solid transparent;
}

.bg-primary-gradient .letter-box li a,
.bg-primary .letter-box li a {
	color: #161616;
	border: 1px solid #161616;
	background: rgba(255, 255, 255, 0.1);
}

.bg-primary-gradient .letter-box li a.active,
.bg-primary .letter-box li a.active {
	background: var(--color-primary-dark);
	color: #fff;
}

.search-form {
	position: relative;
	border: 1px solid #333;
	border-radius: 40px;
	height: 50px;
	background: #fff;
}

.search-form svg {
	position: absolute;
	left: 16px;
	top: 50%;
	transform: translateY(-50%);
	width: 24px;
	height: 24px;
	color: #333;
}

.search-form input {
	border: none;
	outline: none;
	background: none;
	padding: 0 16px 0 48px;
	margin: 0;
	font-size: 1rem;
	width: 100%;
	height: 100%;
}

[dir='rtl'] .search-form svg {
	left: auto;
	right: 16px;
}

[dir='rtl'] .search-form input {
	padding: 0 48px 0 16px;
}

hr {
	margin: 0.6rem 0;
	border-top: 1px solid #d6d6d6;
}

hr.lg {
	margin: 1.8rem 0;
}

.section-padding {
	padding: 2.4rem 0 !important;
}

.page-loader {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	display: none;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	background: rgba(0, 0, 0, 0.75);
	z-index: 999999999;
}

[data-theme='dark'] .page-loader {
	background: rgb(132 132 132 / 75%);
}

.page-loader.active {
	display: flex;
}

.page-loader .spinner-border {
	width: 3rem;
	height: 3rem;
	color: #fff;
}

.appointment-form-status {
	border-radius: 0.25rem;
	font-size: 1rem;
	line-height: 1.5;
	min-height: 1.5rem;
}

.appointment-form-status--error {
	background: #fff1f1;
	color: #8a1f1f;
	padding: 0.75rem 1rem;
}

.appointment-form-status--success {
	background: #eef9f0;
	color: #1f6b32;
	padding: 0.75rem 1rem;
}

#appointment-form.is-submitting,
[data-appointment-form].is-submitting {
	opacity: 0.85;
}

.site-footer {
	background:
		radial-gradient(circle at 18% 0%, rgba(47, 143, 211, 0.2), transparent 32%),
		linear-gradient(135deg, #102f4f 0%, #0b345f 48%, #071f3a 100%);
	color: #fff;
	isolation: isolate;
	margin-top: auto;
	overflow: hidden;
	position: relative;
	z-index: 20;
}

.site-footer__inner {
	margin: 0 auto;
	max-width: var(--site-container-max);
	padding: clamp(48px, 6vw, 86px) var(--site-container-gutter) 28px;
	width: 100%;
}

.site-footer__top {
	display: grid;
	grid-template-columns: minmax(240px, 0.82fr) minmax(0, 1.55fr) minmax(300px, 0.83fr);
	gap: clamp(28px, 3vw, 54px);
	align-items: start;
}

.site-footer__brand {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 18px;
}

.site-footer__logo-link {
	display: inline-flex;
	text-decoration: none;
}

.site-footer__logo {
	display: block;
	height: 48px;
	width: auto;
	max-width: min(214px, 70vw);
	object-fit: contain;
}

.site-footer__description {
	color: rgba(234, 248, 244, 0.82);
	font-size: 1rem;
	line-height: 1.55;
	margin: 0;
	max-width: 330px;
}

.site-footer__health-mark {
	align-items: center;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(184, 215, 255, 0.24);
	border-radius: 8px;
	display: inline-flex;
	max-width: min(260px, 100%);
	padding: 10px 12px;
	width: min(260px, 100%);
}

.site-footer__health-mark-logo {
	display: block;
	height: auto;
	width: 100%;
}

.site-footer__cta {
	align-items: center;
	background: #1769aa;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 999px;
	box-shadow: 0 14px 34px rgba(23, 105, 170, 0.22);
	color: #fff;
	display: inline-flex;
	font-size: 0.98rem;
	font-weight: var(--weight-semibold);
	gap: 10px;
	line-height: 1;
	min-height: 46px;
	padding: 13px 18px;
	text-decoration: none !important;
	transition:
		background-color 0.16s ease,
		box-shadow 0.16s ease,
		transform 0.16s ease;
}

.site-footer__cta:hover,
.site-footer__cta:focus {
	background: #0d477f;
	box-shadow: 0 18px 40px rgba(23, 105, 170, 0.3);
	color: #fff;
	transform: translateY(-1px);
}

.site-footer__cta svg {
	flex: 0 0 auto;
	height: 18px;
	stroke-width: 2.5;
	width: 18px;
}

.site-footer__links {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(20px, 3vw, 42px);
}

.site-footer__side {
	display: grid;
	gap: 16px;
	grid-template-columns: 1fr;
}

.site-footer__link-group h3,
.site-footer__trust-panel h3 {
	color: #fff;
	font-size: 1.06rem;
	font-weight: var(--weight-semibold);
	line-height: 1.25;
	margin: 0;
}

.site-footer__link-group h3::after {
	background: linear-gradient(90deg, #1769aa, rgba(23, 105, 170, 0));
	border-radius: 999px;
	content: '';
	display: block;
	height: 2px;
	margin-top: 12px;
	width: 42px;
}

.site-footer__link-group ul,
.site-footer__trust-list,
.site-footer__social {
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-footer__link-group ul {
	display: grid;
	gap: 9px;
	margin-top: 18px;
}

.site-footer__link-group a {
	align-items: center;
	color: rgba(234, 242, 255, 0.78);
	display: inline-flex;
	font-size: 0.98rem;
	gap: 8px;
	line-height: 1.25;
	text-decoration: none;
	transition:
		color 0.16s ease,
		transform 0.16s ease;
}

.site-footer__link-group a svg {
	flex: 0 0 auto;
	height: 16px;
	stroke-width: 2.4;
	width: 16px;
}

.site-footer__link-group a:hover,
.site-footer__link-group a:focus {
	color: #fff;
	transform: translateX(2px);
}

.site-footer__trust-panel {
	background: rgba(255, 255, 255, 0.075);
	border: 1px solid rgba(184, 215, 255, 0.18);
	border-radius: 20px;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
	padding: 20px;
}

.site-footer__trust-heading {
	align-items: center;
	border-bottom: 1px solid rgba(184, 215, 255, 0.14);
	display: flex;
	gap: 12px;
	padding-bottom: 16px;
}

.site-footer__trust-icon {
	align-items: center;
	background: rgba(143, 195, 255, 0.12);
	border: 1px solid rgba(143, 195, 255, 0.22);
	border-radius: 14px;
	color: #9fd0ff;
	display: inline-flex;
	flex: 0 0 auto;
	height: 38px;
	justify-content: center;
	width: 38px;
}

.site-footer__trust-icon svg {
	height: 19px;
	width: 19px;
}

.site-footer__eyebrow {
	color: #8fc3ff;
	font-size: 0.76rem;
	font-weight: var(--weight-heading);
	letter-spacing: 0.08em;
	line-height: 1.2;
	margin: 0 0 5px;
	text-transform: uppercase;
}

.site-footer__trust-list {
	display: grid;
	gap: 10px;
	margin-top: 16px;
}

.site-footer__trust-list li,
.site-footer__contact a {
	align-items: flex-start;
	color: rgba(234, 242, 255, 0.84);
	display: flex;
	font-size: 0.95rem;
	gap: 9px;
	line-height: 1.35;
}

.site-footer__trust-list svg,
.site-footer__contact svg {
	color: #8cc8f2;
	flex: 0 0 auto;
	height: 16px;
	margin-top: 1px;
	stroke-width: 2.4;
	width: 16px;
}

.site-footer__contact {
	border-top: 1px solid rgba(184, 215, 255, 0.14);
	display: grid;
	gap: 8px;
	margin-top: 16px;
	padding-top: 14px;
}

.site-footer__contact a {
	align-items: center;
	border: 1px solid rgba(184, 215, 255, 0.14);
	border-radius: 14px;
	color: #f8fbff;
	padding: 9px 10px;
	text-decoration: none;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		color 0.16s ease,
		transform 0.16s ease;
}

.site-footer__contact a:hover,
.site-footer__contact a:focus {
	background: rgba(255, 255, 255, 0.055);
	border-color: rgba(184, 215, 255, 0.24);
	color: #fff;
	transform: translateX(2px);
}

.site-footer__office-address,
.site-footer__newsletter-copy {
	color: rgba(234, 242, 255, 0.78);
	font-size: 0.95rem;
	line-height: 1.45;
	margin: 16px 0 0;
}

.site-footer__office-address {
	font-style: normal;
}

.site-footer__newsletter-form {
	margin-top: 14px;
}

.site-footer__newsletter-panel {
	padding-top: 18px;
}

.site-footer__newsletter-panel h3::after {
	background: linear-gradient(90deg, #1769aa, rgba(23, 105, 170, 0));
	border-radius: 999px;
	content: '';
	display: block;
	height: 2px;
	margin-top: 12px;
	width: 42px;
}

.site-footer__newsletter-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 46px;
}

.site-footer__newsletter-row input,
.site-footer__newsletter-row button {
	border: 1px solid rgba(184, 215, 255, 0.2);
	min-height: 46px;
}

.site-footer__newsletter-row input {
	background: rgba(255, 255, 255, 0.08);
	border-radius: 14px 0 0 14px;
	color: #fff;
	font-size: 0.95rem;
	min-width: 0;
	padding: 0 13px;
	width: 100%;
}

.site-footer__newsletter-row input::placeholder {
	color: rgba(234, 242, 255, 0.62);
}

.site-footer__newsletter-row input:focus {
	border-color: rgba(143, 195, 255, 0.6);
	box-shadow: none;
	outline: none;
}

.site-footer__newsletter-row button {
	align-items: center;
	background: #1769aa;
	border-color: #1769aa;
	border-radius: 0 14px 14px 0;
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	justify-content: center;
	padding: 0;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		transform 0.16s ease;
}

.site-footer__newsletter-row button:hover,
.site-footer__newsletter-row button:focus {
	background: #0d477f;
	border-color: #0d477f;
}

.site-footer__newsletter-row button svg {
	height: 17px;
	stroke-width: 2.5;
	width: 17px;
}

.site-footer__proof {
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(246, 251, 255, 0.96));
	border: 1px solid rgba(184, 215, 255, 0.22);
	border-radius: 18px;
	box-shadow: 0 18px 44px rgba(16, 47, 79, 0.08);
	margin-top: clamp(34px, 5vw, 64px);
	padding: clamp(20px, 2.4vw, 30px);
}

.site-footer__proof-heading {
	align-items: center;
	display: flex;
	gap: 18px;
	justify-content: space-between;
	margin-bottom: 20px;
}

.site-footer__proof-heading a {
	align-items: center;
	background: rgba(234, 245, 255, 0.82);
	border: 1px solid rgba(189, 219, 242, 0.8);
	border-radius: 999px;
	color: var(--color-primary-dark);
	display: inline-flex;
	font-size: 0.9rem;
	font-weight: var(--weight-semibold);
	gap: 7px;
	min-height: 38px;
	padding: 0 14px;
	text-decoration: none;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		color 0.16s ease,
		transform 0.16s ease;
}

.site-footer__proof-heading a:hover,
.site-footer__proof-heading a:focus {
	background: #fff;
	border-color: rgba(23, 105, 170, 0.36);
	color: var(--color-primary-dark);
	transform: translateY(-1px);
}

.site-footer__proof-heading svg {
	height: 15px;
	stroke-width: 2.4;
	width: 15px;
}

.site-footer__partner-strip {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(6, minmax(0, 1fr));
}

.site-footer__partner-card {
	align-items: center;
	background: transparent;
	border: 0;
	border-radius: 8px;
	display: flex;
	height: 82px;
	justify-content: center;
	min-width: 0;
	padding: 14px 16px;
	text-decoration: none;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		box-shadow 0.16s ease,
		transform 0.16s ease;
}

.site-footer__partner-card:hover,
.site-footer__partner-card:focus {
	background: transparent;
	border-color: transparent;
	box-shadow: none;
	transform: translateY(-2px);
}

.site-footer__partner-card:focus-visible {
	outline: 3px solid rgba(47, 143, 211, 0.25);
	outline-offset: 3px;
}

.site-footer__partner-logo {
	display: block;
	height: 50px;
	max-width: 100%;
	object-fit: contain;
	width: 146px;
}

.site-footer__partner-logo--wide {
	width: 164px;
}

.site-footer__partner-logo--standard {
	width: 132px;
}

.site-footer__partner-logo--compact {
	width: 82px;
}

.site-footer__partner-logo--tall {
	height: 54px;
}

.site-footer__credentials {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin-top: 14px;
}

.site-footer__credential-card {
	align-items: center;
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid rgba(207, 229, 248, 0.9);
	border-radius: 8px;
	color: var(--color-body);
	display: grid;
	gap: 14px;
	grid-template-columns: 82px minmax(0, 1fr);
	min-height: 104px;
	min-width: 0;
	padding: 12px;
	text-decoration: none !important;
	text-decoration-line: none;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		box-shadow 0.16s ease,
		transform 0.16s ease;
}

.site-footer__credential-card:hover,
.site-footer__credential-card:focus {
	background: #fff;
	border-color: rgba(23, 105, 170, 0.35);
	box-shadow: 0 14px 30px rgba(16, 47, 79, 0.1);
	color: var(--color-primary-dark);
	text-decoration: none !important;
	text-decoration-line: none;
	transform: translateY(-2px);
}

.site-footer__credential-card:focus-visible {
	outline: 3px solid rgba(47, 143, 211, 0.35);
	outline-offset: 3px;
}

.site-footer__credential-media {
	align-items: center;
	aspect-ratio: 1 / 1;
	background: linear-gradient(180deg, #ffffff, rgba(234, 245, 255, 0.9));
	border: 1px solid rgba(189, 219, 242, 0.8);
	border-radius: 6px;
	display: flex;
	justify-content: center;
	overflow: hidden;
	padding: 6px;
}

.site-footer__credential-media img {
	display: block;
	height: 100%;
	max-width: 100%;
	object-fit: contain;
	width: 100%;
}

.site-footer__credential-media--badge {
	aspect-ratio: 1 / 1;
	padding: 8px;
}

.site-footer__credential-copy {
	display: grid;
	gap: 4px;
	min-width: 0;
}

.site-footer__credential-title {
	color: var(--color-ink-strong);
	font-size: 0.94rem;
	font-weight: var(--weight-heading);
	line-height: 1.18;
	text-decoration: none !important;
	text-decoration-line: none;
}

.site-footer__credential-meta {
	color: var(--color-muted);
	font-size: 0.8rem;
	font-weight: var(--weight-heading);
	line-height: 1.25;
	text-decoration: none !important;
	text-decoration-line: none;
}

.site-footer__bottom {
	align-items: center;
	border-top: 1px solid rgba(184, 215, 255, 0.16);
	color: rgba(234, 242, 255, 0.66);
	display: flex;
	gap: 18px;
	justify-content: space-between;
	margin-top: 28px;
	padding-top: 20px;
}

.site-footer__bottom p {
	margin: 0;
}

.site-footer__social {
	display: flex;
	gap: 10px;
}

.site-footer__social a {
	align-items: center;
	border: 1px solid rgba(234, 242, 255, 0.28);
	border-radius: 999px;
	color: #fff;
	display: inline-flex;
	height: 38px;
	justify-content: center;
	text-decoration: none;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		color 0.16s ease;
	width: 38px;
}

.site-footer__social a:hover,
.site-footer__social a:focus {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.46);
	color: #fff;
}

.site-footer__social svg {
	height: 17px;
	width: 17px;
}

@media screen and (max-width: 1199px) {
	.site-footer__top {
		grid-template-columns: minmax(240px, 0.82fr) minmax(0, 1.18fr);
	}

	.site-footer__side {
		grid-column: 1 / -1;
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.site-footer__partner-strip {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.site-footer__credentials {
		grid-template-columns: repeat(3, minmax(180px, 1fr));
	}
}

@media screen and (max-width: 767px) {
	.site-footer__inner {
		padding: 42px var(--site-container-gutter) 24px;
	}

	.site-footer__top,
	.site-footer__links {
		grid-template-columns: 1fr;
	}

	.site-footer__top {
		gap: 32px;
	}

	.site-footer__brand {
		gap: 16px;
	}

	.site-footer__description {
		max-width: none;
	}

	.site-footer__cta {
		justify-content: center;
		width: 100%;
	}

	.site-footer__links {
		gap: 24px;
	}

	.site-footer__side {
		grid-template-columns: 1fr;
		margin-left: -8px;
		margin-right: -8px;
		width: calc(100% + 16px);
	}

	.site-footer__link-group ul {
		gap: 8px;
		grid-template-columns: 1fr 1fr;
	}

	.site-footer__trust-panel {
		padding: 18px;
	}

	.site-footer__proof-heading,
	.site-footer__bottom {
		align-items: flex-start;
		flex-direction: column;
	}

	.site-footer__proof {
		border-radius: 14px;
		padding: 18px;
	}

	.site-footer__partner-strip {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.site-footer__credentials {
		grid-template-columns: 1fr;
	}

	.site-footer__partner-card {
		height: 74px;
		padding: 10px 12px;
	}

	.site-footer__partner-logo {
		height: 44px;
		width: 122px;
	}

	.site-footer__partner-logo--wide {
		width: 136px;
	}

	.site-footer__partner-logo--standard {
		width: 106px;
	}

	.site-footer__partner-logo--compact {
		width: 70px;
	}

	.site-footer__credential-card {
		grid-template-columns: 76px minmax(0, 1fr);
		min-height: 96px;
	}
}

@media screen and (max-width: 420px) {
	.site-footer__link-group ul {
		grid-template-columns: 1fr;
	}

	.site-footer__contact a,
	.site-footer__trust-list li {
		font-size: 0.92rem;
	}
}

.bg-primary {
	background: var(--color-primary) !important;
}

.text-primary {
	color: var(--color-primary) !important;
}

.bg-primary-gradient {
	background: #fffcfb url('../images/header-bg.svg');
	background-size: cover;
	background-position: center;
	color: #161616;
}

nav .breadcrumb {
	background: none;
	padding: 0;
	margin: 0;
	color: inherit;
}

nav .breadcrumb a,
nav .breadcrumb .active {
	color: inherit;
}

nav .breadcrumb .breadcrumb-item:not(:first-child):before {
	content: '>';
	color: inherit;
	font-weight: var(--weight-semibold);
}

nav .breadcrumb a:hover {
	color: inherit;
}

.f1 {
	font-size: 1rem;
}

.post-list {
	list-style: none;
	padding-inline-start: 0;
	margin-block-start: 0;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.post-list li {
	display: flex;
	gap: 1.25rem;
}

.post-list li .post-image img {
	aspect-ratio: 3/2;
	object-fit: cover;
	width: 14.875rem;
	height: auto;
	border-radius: 0.25rem;
}

.post-list li .post-content .post-title {
	font-size: 1.25rem;
	line-height: 1.5;
	font-weight: var(--weight-semibold);
}

.post-list li .post-content .post-title a {
	color: var(--color-body) !important;
}

.post-list li .post-content .post-meta {
	font-size: 0.875rem;
	color: #666;
}

.post-list li .post-content .post-meta span:not(:last-child):after {
	content: '|';
	margin: 0 0.5rem;
}

.tag-list {
	list-style: none;
	padding-inline-start: 0;
	margin-inline-start: 0;
	margin-left: 0;
	padding-bottom: 0;
	margin-block-start: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 0.5rem;
	margin: 1rem 0 0 0 !important;
}

.tag-list li {
	display: inline-flex;
	text-align: center;
	align-items: center;
	justify-content: center;
	padding: 0.25rem 1rem;
	border: 1px solid #8cc5ff;
	border-radius: 1.25rem;
	height: 36px;
	width: auto;
	color: var(--color-primary);
}

.tag-list li a {
	color: inherit !important;
}

.social-share {
	display: flex;
	gap: 1rem;
	list-style: none;
	padding-inline-start: 0;
	margin-block-start: 0;
}

.social-share li {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1.5px solid #fff;
	border-radius: 50%;
	width: 36px;
	height: 36px;
}

.social-share li a {
	color: #fff;
	display: block;
	line-height: 0;
	font-weight: var(--weight-semibold);
}

.social-share li a svg {
	width: 16px;
	height: 16px;
	stroke-width: 2;
}

.content-box {
	color: #080808;
	font-weight: var(--weight-regular);
}

.content-box h1 {
	font-size: clamp(32px, calc(29.33333333px + 0.74074074vw), 40px);
	line-height: clamp(40px, calc(37.33333333px + 0.74074074vw), 48px);
	font-weight: var(--weight-semibold);
	margin-bottom: 12px;
}

.content-box h2 {
	font-size: clamp(32px, calc(29.33333333px + 0.74074074vw), 40px);
	line-height: clamp(40px, calc(37.33333333px + 0.74074074vw), 48px);
	font-weight: var(--weight-medium);
	margin-bottom: 16px;
}

.content-box h3 {
	font-size: clamp(24px, calc(21.33333333px + 0.74074074vw), 32px);
	line-height: clamp(32px, calc(29.33333333px + 0.74074074vw), 40px);
	font-weight: var(--weight-medium);
	margin-bottom: 16px;
}

.content-box p {
	font-size: 18px;
	line-height: clamp(28px, calc(26.66666667px + 0.37037037vw), 32px);
	font-weight: var(--weight-regular);
	margin-bottom: 20px;
}

.content-box img {
	width: 100%;
	height: auto;
	border-radius: 8px;
	margin-bottom: 12px;
}

.content-box ul {
	margin: 0;
	padding: 0;
	margin-left: 36px;
	padding-bottom: 24px;
}

.content-box ul li {
	font-size: 18px;
	line-height: clamp(28px, calc(26.66666667px + 0.37037037vw), 32px);
	margin-bottom: 12px;
}

.content-box a.request-appointment {
	font-size: 18px;
	line-height: clamp(24px, calc(22.66666667px + 0.37037037vw), 28px);
	align-items: center;
	border-radius: 48px;
	display: inline-flex;
	font-weight: var(--weight-regular);
	height: 48px;
	padding: 12px 24px;
	text-decoration: none;
	background: var(--color-primary);
	color: #fff;
	margin-bottom: 24px;
}

.content-box pre {
	background: #f5f5f5;
	padding: 16px 8px;
	border-radius: 8px;
	margin-bottom: 24px;
	overflow-x: auto;
	scrollbar-width: thin;
}

.btn.rounded {
	border-radius: 32px !important;
	padding: 12px 24px;
}

.btn.btn-primary {
	background: var(--color-primary);
	color: #fff;
	border: 1px solid var(--color-primary);
}

.btn.btn-primary:hover {
	background: var(--color-primary-dark);
	border: 1px solid var(--color-primary-dark);
}

.btn.btn-primary:focus {
	background: var(--color-primary-dark);
	border: 1px solid var(--color-primary-dark);
}

.btn.btn-primary:active {
	background: var(--color-primary-dark);
	border: 1px solid var(--color-primary-dark);
}

.btn.btn-ghost-white {
	background: transparent;
	color: #fff;
	border: 1px solid #fff;
}

.btn.btn-ghost-white:hover {
	background: #fff;
	color: #333;
}

.btn.btn-ghost-white:focus {
	background: #fff;
	color: #333;
}

.btn.btn-ghost-white:active {
	background: #fff;
	color: #333;
}

.btn.btn-ghost-orange {
	background: transparent;
	color: #fff;
	border: 2px solid orange;
}

.btn.btn-ghost-orange:hover {
	background: #fff;
	color: #333;
}

.btn.btn-ghost-orange:focus {
	background: #fff;
	color: #333;
}

.btn.btn-ghost-orange:active {
	background: #fff;
	color: #333;
}

.btn.btn-ghost {
	background: transparent;
	color: var(--color-primary);
	border: 1px solid var(--color-primary);
}

.btn.btn-ghost:hover {
	background: var(--color-primary);
	color: #fff;
}

.btn.btn-ghost:focus {
	background: var(--color-primary);
	color: #fff;
}

.btn.btn-ghost:active {
	background: var(--color-primary);
	color: #fff;
}

.btn.btn-white {
	background: #fff;
	color: var(--color-primary);
	border: 1px solid var(--color-primary);
}

.btn.btn-white:hover {
	background: var(--color-primary);
	color: #fff;
}

.btn.btn-white:focus {
	background: var(--color-primary);
	color: #fff;
}

.btn.btn-white:active {
	background: var(--color-primary);
	color: #fff;
}

.section-with-bg {
	position: relative;
	overflow: hidden;
	width: 100%;
	min-height: clamp(320px, 31vw, 430px);
	max-height: none;
	padding: clamp(42px, 5vw, 72px) 0 clamp(46px, 5vw, 78px) !important;
	background:
		linear-gradient(
			116deg,
			rgba(255, 255, 255, 0.96) 0%,
			rgba(246, 251, 255, 0.94) 48%,
			rgba(226, 241, 252, 0.86) 100%
		),
		repeating-linear-gradient(90deg, rgba(23, 105, 170, 0.055) 0 1px, transparent 1px 72px),
		repeating-linear-gradient(0deg, rgba(23, 105, 170, 0.045) 0 1px, transparent 1px 72px) !important;
	border-bottom: 1px solid rgba(141, 190, 226, 0.48);
	color: var(--color-body);
}

.section-with-bg::before,
.section-with-bg::after {
	content: '';
	pointer-events: none;
	position: absolute;
	z-index: 0;
}

.section-with-bg::before {
	background:
		linear-gradient(
			135deg,
			rgba(23, 105, 170, 0.12),
			rgba(47, 143, 211, 0.03) 52%,
			transparent 52%
		),
		linear-gradient(315deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0) 58%);
	border-left: 1px solid rgba(141, 190, 226, 0.34);
	bottom: -18%;
	right: -7%;
	top: -16%;
	transform: skewX(-13deg);
	width: min(42vw, 520px);
}

.section-with-bg::after {
	background: linear-gradient(
		90deg,
		rgba(23, 105, 170, 0.38),
		rgba(47, 143, 211, 0.12),
		transparent
	);
	bottom: 0;
	height: 5px;
	left: 0;
	width: 100%;
}

.section-with-bg .bg-image {
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.76), rgba(255, 255, 255, 0) 45%),
		repeating-linear-gradient(135deg, rgba(23, 105, 170, 0.085) 0 1px, transparent 1px 18px);
	position: absolute;
	bottom: 0;
	opacity: 0.6;
	right: 0;
	top: 0;
	width: min(44vw, 560px);
}

.section-with-bg .container {
	position: relative;
	z-index: 1;
}

.section-with-bg .breadcrumb {
	font-weight: var(--weight-semibold);
	margin-bottom: clamp(28px, 4vw, 48px);
}

.section-with-bg .container h1 {
	color: var(--color-ink-strong);
	margin-bottom: 14px;
	max-width: var(--public-content-max);
}

.section-with-bg .container p {
	color: var(--color-muted);
	max-width: var(--public-reading-max);
}

.main-slider {
	position: relative;
	overflow: hidden;
	aspect-ratio: 1200/382;
	width: 100%;
	max-height: 600px;
}

.main-slider .main-slider-bg {
	background: var(--color-primary);
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}

.main-slider-content {
	position: relative;
	z-index: 3;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 100%;
	/*padding-top: 200px;*/
}

.main-slider-content h1 {
	font-weight: var(--weight-regular);
	font-size: 3.5rem;
	line-height: 4.5rem;
	color: #fff;
}

.main-slider-content p {
	font-size: 50px;
	line-height: 60px;
	font-weight: var(--weight-regular);
	color: #fff;
}

.btn-footer {
	width: 100%;
	height: 64px;
	border: 2px solid rgba(255, 255, 255, 0.15);
	background: transparent;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	padding: 16px 20px;
	gap: 10px;
	color: #fff;
	font-size: 1rem;
	border-radius: 8px;
}

.btn-footer:hover {
	border-color: #fff;
	color: #fff;
}

.btn-footer:focus {
	background: #fff;
	color: #333;
}

.btn-footer svg {
	color: inherit;
	width: 32px;
	height: 32px;
}

.btn-footer .chevron-icon {
	width: 16px;
	height: 16px;
	stroke-width: 2;
	margin-left: auto;
}

.footer-link-list .footer-link-heading {
	font-size: 1.25rem;
	font-weight: var(--weight-medium);
	margin-bottom: 1rem;
}
.footer-link-list .footer-link-heading:after {
	content: '';
	display: block;
	width: 40px;
	height: 2px;
	background: #fff;
	margin-top: 8px;
}

.footer-link-list ul li {
	padding: 4px 0;
}

.footer-link-list ul li a {
	color: #fff;
}

.footer-link-list + .footer-link-list {
	margin-top: 2rem;
}

footer hr {
	border-color: rgba(255, 255, 255, 0.15) !important;
}

.form-control {
	background: #fff;
	border: 1px solid #d6d6d6;
	outline: 0;
	padding: 12px 16px;
	border-radius: 8px;
	width: 100%;
	font-size: 1rem;
	color: #333;
}

select.form-control {
	padding-top: 9px !important;
	padding-bottom: 9px !important;
}

.form-control:focus {
	box-shadow: none !important;
	border-color: var(--color-primary);
}

.form-control.lg {
	min-height: 48px;
	font-size: 1rem;
	padding: 16px 20px;
}

.features-list {
	list-style: none;
	padding-inline-start: 0;
	margin-block-start: 0;
}

.features-list li a {
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	color: #000;
	font-size: 1rem;
	font-weight: var(--weight-medium);
	padding: 8px 0;
	border-bottom: 1px solid #d6d6d6;
	border-top: none;
}

.features-list li:last-child a {
	border-bottom: none;
}

.features-list li:first-child a {
	border-top: 1px solid #d6d6d6;
}

.info-list {
	list-style: none;
	padding-inline-start: 0;
	margin-block-start: 0;
}

.info-list > li {
	margin-bottom: 24px;
}

.info-list > li .title {
	font-size: 20px;
	line-height: 28px;
	font-weight: var(--weight-semibold);
	color: #080808;
	margin: 0 !important;
}

.info-list > li .description {
	font-size: 20px;
	line-height: 28px;
	font-weight: var(--weight-regular);
	color: #080808;
	margin: 0 !important;
}

.info-list > li a.description,
.info-list > li .description a {
	color: var(--color-primary);
}

.info-list > li a.description:hover,
.info-list > li .description a:hover {
	color: var(--color-primary);
	text-decoration: underline;
}

.list-flex {
	display: flex;
	gap: 0.15rem 1rem;
	flex-wrap: wrap;
	list-style: none;
	padding-inline-start: 0;
	margin-block-start: 0;
}

.list-flex.column {
	flex-direction: column;
}

.flex-gap-1 {
	gap: 1rem;
}

.pagination-wrapper .pagination {
	display: flex;
}

.pagination-wrapper .pagination li a {
	padding: 0 0.15rem;
	background: #f5f5f5;
	vertical-align: top;
	display: inline-block;
	font-size: 1rem;
	min-width: 40px;
	height: 40px;
	line-height: 2.5rem;
	cursor: pointer;
	box-sizing: border-box;
	text-align: center;
	margin: 0 0 0 0.625rem;
	color: #333;
}

.pagination-wrapper .pagination li:first-child a {
	margin-left: 0;
}

.pagination-wrapper .pagination li a.current {
	background-color: #000;
	color: #fff;
	cursor: default;
	font-weight: var(--weight-semibold);
	opacity: 0.3;
	border-radius: 0.1875rem;
	text-decoration: none !important;
}

.pagination-wrapper .pagination li a.disabled {
	cursor: not-allowed;
	opacity: 0.5;
}

.sitemap-list {
	list-style: none;
	padding-inline-start: 0;
	margin-block-start: 0;
}

.sitemap-list li a {
	color: #333;
	font-size: 1rem;
	padding: 8px 0;
	display: block;
}

.sitemap-list li a:hover {
	color: var(--color-primary);
}

.list-category-posts {
	list-style: none;
	padding-inline-start: 0;
	margin-block-start: 0;
	display: flex;
	flex-direction: column;
}

.list-category-posts a {
	color: #333;
	display: inline-block;
	padding: 0.25rem 0;
	margin: 0 0 1rem 0;
	text-decoration: none !important;
}

.list-category-posts a h4 {
	font-size: 1.5rem;
	font-weight: var(--weight-semibold);
	margin: 0;
}

.list-category-posts a p {
	font-size: 1rem;
	font-weight: var(--weight-regular);
	color: #666;
	margin: 0.25rem 0 0 0;
}

.list-category-posts a:hover h4 {
	color: var(--color-primary);
	text-decoration: underline;
}

.list-category-posts a:after {
	content: '';
	display: block;
	width: 100%;
	height: 1px;
	background: #d6d6d6;
	margin-top: 1.25rem;
}

.list-category-posts li:last-child a:after {
	display: none;
}

.border-category {
	border-bottom: 3px solid #212529 !important;
}

.view-all-button {
	border-bottom: 6px solid #8cc8f2;
	border-radius: 0;
	margin-bottom: -3px;
	border-right: 0;
}

.sticky-navbar {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: rgba(255, 255, 255, 0.75);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
	display: flex;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.02);
	transition: all 0.3s ease;
}

.sticky-navbar.is-sticky .container {
	max-width: unset;
	width: 100%;
	display: flex;
	justify-content: center;
}

.sticky-navbar .stick-navbar-items {
	align-items: center;
}

.sticky-navbar .nav {
	white-space: nowrap;
	align-items: center;
}

.sticky-navbar .nav .nav-item {
	padding: 0.35rem;
}

.sticky-navbar .nav .nav-item .nav-link {
	color: #4a5568;
	border-radius: 999px;
	font-size: 0.95rem;
	font-weight: 500;
	padding: 0.5rem 1.1rem;
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
	border: 1px solid transparent;
}

.sticky-navbar .nav .nav-item .nav-link:hover {
	background: rgba(23, 105, 170, 0.06);
	color: var(--color-primary);
}

.sticky-navbar .nav .nav-item .nav-link.active,
.sticky-navbar .nav .nav-item .nav-link[aria-expanded='true'] {
	background: var(--color-primary);
	color: #fff !important;
	box-shadow: 0 4px 12px rgba(23, 105, 170, 0.25);
}

.sticky-navbar .nav-heading {
	padding: 0.5rem;
	padding-right: 1rem;
	display: flex;
	align-items: center;
}

.sticky-navbar .nav-heading .nav-button {
	padding: 0.5rem 1.1rem;
	border-radius: 999px;
	color: var(--color-primary);
	display: flex;
	gap: 8px;
	align-items: center;
	font-size: 0.95rem;
	font-weight: 600;
	background: rgba(23, 105, 170, 0.08);
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.sticky-navbar .nav-heading .nav-button:hover {
	text-decoration: none;
	background: var(--color-primary);
	color: #fff;
	box-shadow: 0 4px 12px rgba(23, 105, 170, 0.25);
}

.sticky-navbar .nav .nav-item .dropdown-menu {
	border-radius: 12px;
	border: 1px solid rgba(0, 0, 0, 0.06);
	padding: 0.5rem 0 !important;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
}

.sticky-navbar .nav .nav-item .dropdown-menu .dropdown-item {
	padding: 0.6rem 2rem 0.6rem 1.5rem;
	color: #4a5568 !important;
	background: transparent !important;
	font-weight: 500;
	transition: all 0.2s ease;
	border-bottom: 0;
}

.sticky-navbar .nav .nav-item .dropdown-menu .dropdown-item:hover {
	color: var(--color-primary) !important;
	background: rgba(23, 105, 170, 0.06) !important;
	text-decoration: none;
}

.sticky-navbar .dropdown-toggle::after {
	display: none;
}

.sticky-navbar .dropdown-toggle svg {
	width: 16px;
	height: 16px;
	transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
	margin-left: 2px;
}

.sticky-navbar .dropdown-toggle[aria-expanded='true'] svg {
	transform: rotate(180deg);
}

.bg-dark {
	background: #102f4f !important;
}

.gap-1 {
	gap: 1rem;
}

.category-badge {
	background: #fff;
	border-radius: 1.25rem;
	font-size: 1rem;
	padding: 0.5rem 1rem;
	text-align: center;
	font-weight: var(--weight-regular);
}

.category-badge:hover {
	background: #f6fbff;
	text-decoration: none !important;
}

.section-title-bordered {
	text-transform: uppercase;
	font-size: 1.25rem;
	color: #00157c;
	font-weight: var(--weight-semibold);
	border-bottom: 1px solid #c6cedb;
	padding-bottom: 0.625rem;
	margin-bottom: 1.875rem;
}

.text-white .section-title-bordered {
	color: #fff;
	border-color: #fff;
}

.section-grid-1-3 {
	display: grid;
	grid-template-columns: 3fr 2fr;
	gap: 20px;
}

.section-grid-1-3 .left {
	border-right: 1px solid #c6cedb;
	padding-right: 3.5rem;
}

.section-grid-1-3 .right {
	display: flex;
	flex-direction: column;
	gap: 32px;
	padding-left: 3.5rem;
}

.section-grid-1-3 a {
	text-decoration: none;
	color: #fff;
}

.section-grid-1-3 a:hover {
	text-decoration: none;
	color: #e7f0fe;
}

.section-grid-1-3 .right img {
	max-width: 9rem;
	min-width: 9rem;
	height: auto;
	aspect-ratio: 4/3;
	object-fit: cover;
}

.section-grid-1-3 .right h4 {
	font-size: 1.25rem;
	max-width: 17.0625rem;
	text-transform: capitalize;
	line-height: 100%;
}

.section-grid-1-3 .right p {
	font-size: 0.875rem;
	max-width: 17.0625rem;
	line-height: 100%;
}

@media screen and (max-width: 768px) {
	.section-grid-1-3 {
		grid-template-columns: 1fr;
	}

	.section-grid-1-3 .left {
		border-right: none;
		padding-right: 0;
	}

	.section-grid-1-3 .right {
		padding-left: 0;
		display: flex;
		flex-direction: column;
		gap: 32px;
	}

	.section-grid-1-3 .right a {
		width: 100%;
		display: flex;
		flex-direction: column;
	}
	.section-grid-1-3 .right a img {
		min-width: unset;
		width: 100%;
		max-width: unset;
		aspect-ratio: 4/3;
	}

	.section-grid-1-3 .right a h4 {
		max-width: 100%;
		margin-top: 0.5rem;
	}
}

.card-featured {
	background: #fff;
	overflow: hidden;
	height: 100%;
	text-decoration: none !important;
	border: none !important;
	border-radius: 0.3125rem;
}

.card-featured .img-container {
	position: relative;
	overflow: hidden;
	height: 240px;
}

.card-featured img {
	aspect-ratio: 3/2;
	object-fit: cover;
	transition: transform 0.3s;
	overflow: hidden;
	width: 100%;
}

.card-featured img:hover {
	transform: scale(1.2);
}

.card-featured .card-body {
	color: #333;
	overflow: hidden;
	padding: 1rem;
}

.card-featured h4 {
	text-decoration: none;
	color: #1b1b1b;
	font-size: 1.5rem;
	font-weight: var(--weight-semibold);
	line-height: 2.1rem;
	text-transform: capitalize;
	margin: 0 0 0.25rem;
}

.card-featured:hover h4 {
	text-decoration: none !important;
	color: var(--color-primary);
}

.card-featured p {
	color: #4a4a4a;
	font-size: 1.125rem;
	font-weight: var(--weight-regular);
	line-height: 1.8rem;
	margin: 0;
	letter-spacing: 0;
}

.bg-light-2 {
	background: #f8f8f8 !important;
}

.newsletter-card {
	display: block;
	padding: 2.75rem 3.5rem;
	background:
		linear-gradient(90deg, rgba(16, 47, 79, 0.7), rgba(47, 143, 211, 0.7)), rgb(18, 61, 56);
	color: #fff;
	border-radius: 0.25rem;
	width: 100%;
}

.newsletter-card h2 {
	font-size: 2.5rem;
	font-weight: var(--weight-semibold);
	line-height: 3.5rem;
	margin: 0 0 0.25rem;
}
.newsletter-card p {
	font-size: 1rem;
	font-weight: var(--weight-regular);
	line-height: 1.5rem;
}

.newsletter-card .input-group input {
	padding: 0 1.5rem;
	height: 3.125rem;
	line-height: 1.4375rem;
	font-size: 1.125rem;
	border-radius: 0.3125rem 0 0 0.3125rem;
	color: #333;
}

.newsletter-card .input-group input:focus {
	box-shadow: none;
	border-color: #fff;
}

.newsletter-card .input-group button {
	background: var(--color-primary);
	color: #fff;
	border-radius: 0 0.3125rem 0.3125rem 0;
	padding: 0 1.5rem;
	height: 3.125rem;
	line-height: 1.4375rem;
	font-size: 1.125rem;
	border: none;
	cursor: pointer;
}

.newsletter-card .input-group button:hover {
	background: var(--color-primary-dark);
}

.newsletter-card .input-group button:focus {
	background: var(--color-primary-dark);
}
.newsletter-card .input-agreement-text {
	font-size: 0.75rem;
	color: #fff;
	margin-top: 0.25rem;
	display: inline-block;
}

.newsletter-card .input-agreement-text a {
	color: #fff;
	text-decoration: underline;
}

.row-gap-10 {
	row-gap: 10px;
}

.hospital-photos {
	grid-gap: 10px;
	display: grid;
	grid-template-columns: 1fr 0.5fr 0.5fr;
	position: relative;
	width: 100%;
	margin-top: 20px;
}

.hospital-photos .gallery-item-more {
	display: flex;
	justify-content: center;
	align-items: center;
	background: #fff;
	border-radius: 8px;
	height: 100%;
	width: 100%;
	position: relative;
	overflow: hidden;
}

.hospital-photos .gallery-item-more a {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	width: 100%;
	color: #333;
	font-size: 1.5rem;
	position: relative;
	text-decoration: none !important;
}

.hospital-photos .gallery-item-more a img {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
	transition: transform 0.3s;
	aspect-ratio: 1;
}

.hospital-photos .gallery-item-more a .overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.5);
	z-index: 1;
}

.hospital-photos .gallery-item-more a .text {
	position: relative;
	z-index: 2;
	color: #fff;
	font-size: 2.4rem;
	text-transform: uppercase;
}

.hospital-photos .gallery-item-more a:hover img {
	transform: scale(1.1);
}

.hospital-photos .gallery-item {
	display: block;
	margin: 0;
	padding: 0;
	position: relative;
}

.hospital-photos .gallery-item:first-child {
	grid-row: span 2;
}

.hospital-photos .gallery-item a {
	display: block;
	overflow: hidden;
	padding-bottom: 100%;
	position: relative;
	height: 100%;
	width: 100%;
	border-radius: 8px;
}

.hospital-photos .gallery-item a img {
	object-fit: cover;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	max-width: 100%;
	aspect-ratio: 1;
}

.hospital-photos-list {
	display: flex;
	position: relative;
	width: 100%;
	flex-wrap: wrap;
}

.hospital-photos-list .hospital-photo {
	position: relative;
	width: 100%;
	-webkit-box-flex: 0;
	flex-grow: 0;
	flex-shrink: 0;
	max-width: 20%;
	padding: 0px 9.6px 12px 0px;
}

.hospital-photos-list .hospital-photo .img-container {
	position: relative;
	max-width: 100%;
	width: 100%;
	height: 20rem;
	overflow: hidden;
	border-radius: 0.6rem;
	cursor: pointer;
}

.hospital-photos-list .hospital-photo .img-container .bg {
	width: 100%;
	position: absolute;
	top: 0px;
	left: 0px;
	height: 100%;
	background: linear-gradient(
			to right,
			rgb(248, 248, 248) 0%,
			rgb(255, 255, 255) 10%,
			rgb(248, 248, 248) 40%,
			rgb(248, 248, 248) 100%
		)
		no-repeat rgb(248, 248, 248);
	opacity: 0;
	transition: opacity 0.25s ease-out;
	will-change: opacity;
	border-radius: inherit;
	animation: 1.5s linear 0s infinite normal forwards running jCOzbu;
}

.hospital-photos-list .hospital-photo .img-container img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: none;
	opacity: 1;
	will-change: transform, opacity;
	border-radius: inherit;
	filter: brightness(0.95);
	transition:
		transform 0.4s ease-in-out,
		filter 0.4s,
		opacity 0.25s;
	aspect-ratio: 1;
}

.hospital-photos-list .hospital-photo .img-container img:hover {
	transform: scale(1.05);
	filter: brightness(1.05);
}

.user-tabs {
	margin-top: 0;
}
.user-tabs .nav-tabs > li > a {
	border-left: 2px solid transparent;
	border-bottom: 0;
	padding: 0.5rem 1rem;
}
.user-tabs .nav-tabs.nav-tabs-bottom > li > a.active,
.user-tabs .nav-tabs.nav-tabs-bottom > li > a.active:hover,
.user-tabs .nav-tabs.nav-tabs-bottom > li > a.active:focus {
	border-left-width: 2px;
	color: var(--color-primary-dark);
}

.nav-tabs.nav-tabs-bottom > li > a.active,
.nav-tabs.nav-tabs-bottom > li > a.active:hover,
.nav-tabs.nav-tabs-bottom > li > a.active:focus {
	background-color: #f5f5f5;
}
.nav-tabs.nav-justified {
	border-bottom: 1px solid #ddd;
}
.nav-tabs.nav-justified > li > a.active,
.nav-tabs.nav-justified > li > a.active:hover,
.nav-tabs.nav-justified > li > a.active:focus {
	border-color: transparent transparent transparent #20c0f3;
	border-left-width: 2px;
}
.nav-tabs {
	border-bottom: 0;
	position: relative;
	background-color: #fff;
	padding: 8px 0;
	border-radius: 3px;
}
.nav-tabs .nav-item {
	margin-bottom: 0;
}
.nav-tabs > li > a {
	border-width: 2px;
	border-left-color: transparent;
	font-size: 16px;
}
.nav-tabs .nav-link {
	border-width: 2px;
}
.nav-tabs > li > a:hover,
.nav-tabs > li > a:focus {
	background-color: #fafafa;
}
.nav-tabs .nav-item.show .nav-link,
.nav-tabs .nav-link.active,
.nav-tabs > li > a.active,
.nav-tabs > li > a.active:hover,
.nav-tabs > li > a.active:focus {
	border-color: transparent transparent transparent var(--color-primary-dark) !important;
	border-left-width: 2px;
}
.nav-tabs > li.open:not(.active) > a,
.nav-tabs > li.open:not(.active) > a:hover,
.nav-tabs > li.open:not(.active) > a:focus {
	background-color: #fafafa;
}
.nav-tabs.nav-tabs-solid {
	padding: 5px;
}
.nav-tabs.nav-tabs-solid.nav-tabs-rounded {
	border-radius: 5px;
}
.nav-tabs.nav-tabs-solid > li > a {
	border-left-width: 0 !important;
}
.nav-tabs-justified {
	border-bottom: 1px solid #ddd;
}
.nav-tabs-justified > li > a.active,
.nav-tabs-justified > li > a.active:hover,
.nav-tabs-justified > li > a.active:focus {
	border-width: 0 0 0 2px;
	border-left-color: #20c0f3;
}

.nav-tabs .nav-link:focus,
.nav-tabs .nav-link:hover {
	border-color: transparent !important;
}

.navbar-open {
	overflow: hidden !important;
}

.iti:not(.iti--container) {
	display: block !important;
	width: 100%;
}

.iti:not(.iti--container) .iti__selected-country-primary {
	padding-left: 14px;
}

.iti--container {
	z-index: 1060;
}

.iti--container .iti__dropdown-content {
	overflow: hidden;
	background: #fff;
	border: 1px solid var(--color-line-soft, #d8e8f5) !important;
	border-radius: 8px;
	box-shadow: 0 18px 42px rgba(16, 47, 79, 0.2);
}

.iti--container .iti__search-input {
	display: block !important;
	width: 100% !important;
	min-height: 44px;
	border: 0 !important;
	border-bottom: 1px solid var(--color-line-soft, #d8e8f5) !important;
	border-radius: 0 !important;
	padding: 10px 12px !important;
	font-size: 0.95rem !important;
	line-height: 1.35 !important;
	color: var(--color-ink-strong, #102f4f) !important;
	background-color: #fff !important;
	background-clip: padding-box !important;
	outline: 0;
}

.iti--container .iti__search-input:focus {
	box-shadow: inset 0 0 0 2px rgba(23, 105, 170, 0.14);
}

.iti--container .iti__country-list {
	max-height: min(270px, calc(100vh - 180px));
	background: #fff;
	scrollbar-width: thin;
	scrollbar-color: rgba(23, 105, 170, 0.35) transparent;
}

.iti--container .iti__country {
	min-height: 40px;
	padding: 9px 12px;
	color: var(--color-body, #24384f);
}

.iti--container .iti__country:hover,
.iti--container .iti__country.iti__highlight {
	background: var(--color-primary-soft, #eaf5ff);
}

.iti--container .iti__country-name {
	font-size: 0.92rem;
	font-weight: var(--weight-heading);
	line-height: 1.25;
}

.iti--container .iti__dial-code {
	margin-left: auto;
	color: var(--color-muted, #5f7184);
	font-size: 0.9rem;
}

.iti--fullscreen-popup.iti--container {
	z-index: 1060;
}

.iti--fullscreen-popup .iti__dropdown-content {
	border-radius: 10px;
}

.sticky-cta-box {
	position: sticky;
	top: 120px; /* Adjust based on your header height */
}

.cta-card {
	background-color: #fff;
	border-radius: 8px;
	padding: 25px 20px;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
	margin-bottom: 20px;
	border: 1px solid #eaeaea;
}



/* --- Blog Inline Form Styles --- */
.blog-lead-form {
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 24px;
    padding: 32px;
    margin: 40px 0;
    box-shadow: 0 6px 22px rgba(15, 23, 42, 0.045), inset 0 0 0 1px rgba(255, 255, 255, 0.45);
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
    overflow: hidden;
}

.blog-lead-form::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, rgba(239, 246, 255, 0.5) 0%, rgba(255, 255, 255, 0.1) 100%);
    z-index: 0;
    pointer-events: none;
}

.blog-lead-form:hover {
    transform: translateY(-4px);
    border-color: rgba(59, 130, 246, 0.2);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.07), inset 0 0 0 1px rgba(255, 255, 255, 0.55);
}

.blog-lead-form > * {
    position: relative;
    z-index: 1;
}

.blog-lead-form__header {
    display: flex;
    align-items: center;
    margin-bottom: 24px;
}

.blog-lead-form__icon {
    width: 56px;
    height: 56px;
    border-radius: 16px;
    background: linear-gradient(135deg, var(--primary) 0%, #3b82f6 100%);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-right: 20px;
    box-shadow: 0 8px 16px rgba(37, 99, 235, 0.2);
}

.blog-lead-form__icon i {
    width: 24px;
    height: 24px;
}

.blog-lead-form__title-group h3 {
    margin: 0 0 4px 0;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--dark);
    letter-spacing: -0.02em;
}

.blog-lead-form__title-group p {
    margin: 0;
    font-size: 0.95rem;
    color: var(--secondary);
    line-height: 1.4;
}

.blog-lead-form__body {
    background: rgba(255, 255, 255, 0.5);
    border-radius: 16px;
    padding: 24px;
    border: 1px solid rgba(148, 163, 184, 0.18);
}

.blog-lead-form .form-control {
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(0, 0, 0, 0.05);
    border-radius: 12px;
    padding: 12px 16px;
    height: auto;
    font-size: 0.95rem;
    color: var(--dark);
    transition: all 0.2s ease;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.02);
}

.blog-lead-form .form-control:focus {
    background: #fff;
    border-color: var(--primary);
    box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.1);
    outline: none;
}

.blog-lead-form textarea.form-control {
    resize: none;
}

.blog-lead-form .iti {
    width: 100%;
}

.blog-lead-form__submit {
    border-radius: 12px;
    padding: 14px 24px;
    font-weight: 600;
    font-size: 1rem;
    background: linear-gradient(135deg, var(--primary) 0%, #2563eb 100%);
    border: none;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.2);
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.blog-lead-form__submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(37, 99, 235, 0.3);
    background: linear-gradient(135deg, #2563eb 0%, var(--primary) 100%);
}

.blog-lead-form__submit i {
    transition: transform 0.3s ease;
}

.blog-lead-form__submit:hover i {
    transform: translateX(4px);
}

.blog-lead-form__meta {
    font-size: 0.8rem;
    color: var(--secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.8;
}

@media (max-width: 768px) {
    .blog-lead-form {
        padding: 24px;
    }

    .blog-lead-form__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .blog-lead-form__icon {
        margin-bottom: 16px;
        margin-right: 0;
    }

    .blog-lead-form__body {
        padding: 16px;
    }
}


@media (max-width: 991.98px) {
	.blog-lead-cta-inline,
	.blog-lead-cta-band,
	.blog-lead-cta-list {
		display: block;
	}

	.blog-lead-cta {
		border-radius: 20px;
		padding: 22px 18px;
	}

	.blog-lead-cta .btn {
		width: 100%;
		min-width: 0;
	}

	.blog-lead-cta__icon {
		margin-bottom: 14px;
	}

	.blog-lead-cta-band .blog-lead-cta__content p,
	.blog-lead-cta-list .blog-lead-cta__content p {
		margin-bottom: 16px;
	}

	.blog-lead-cta::after {
		right: -126px;
		top: auto;
		bottom: -98px;
		transform: none;
		width: 220px;
		height: 220px;
	}

	.blog-lead-cta-inline .blog-lead-cta__meta {
		order: 0;
	}
}

@media screen and (max-width: 321px) {
	* {
		word-break: break-all;
	}
}

@media screen and (min-width: 992px) {
	.navbar {
		padding-top: 0px;
		padding-bottom: 0px;
	}

	.navbar-expand-lg .navbar-collapse {
		justify-content: flex-end;
		min-width: 0;
	}

	.navbar-expand-lg .navbar-collapse .navbar-nav {
		flex: 0 1 auto;
		min-width: 0;
	}

	.navbar .nav-item {
		padding: 0.5rem 0.5rem;
		margin: 0 0.25rem;
	}

	.navbar-expand-lg .navbar-nav > .nav-item {
		display: flex;
		align-items: center;
	}

	.navbar .dropdown {
		position: relative;
	}

	.navbar .dropdown-menu {
		width: min(280px, calc(100vw - 32px));
		max-width: calc(100vw - 32px);
		left: 50%;
		right: auto;
		transform: translateX(-50%);
		top: calc(100% + 6px);
		margin-top: 0;
		background: #fff !important;
		border: 1px solid rgba(216, 232, 245, 0.92);
		border-radius: 12px !important;
		box-shadow: 0 22px 56px rgba(16, 47, 79, 0.16);
		max-height: calc(100vh - var(--navbar-offset-top) - var(--navbar-height));
		overscroll-behavior: contain;
		padding: 10px;
		overflow-x: hidden;
		overflow-y: auto;
	}

	.navbar .dropdown-menu.show {
		display: block;
	}

	.navbar .dropdown-menu.nav-mega--treatment-areas.nav-mega--multi-column {
		left: 50%;
		max-width: min(400px, calc(100vw - 48px));
		right: auto;
		transform: translateX(-50%);
		width: min(400px, calc(100vw - 48px));
	}

	.navbar .dropdown-menu.nav-mega--compact {
		max-width: min(400px, calc(100vw - 48px));
		width: max-content;
	}

	.navbar .dropdown-menu.nav-mega--conditions.nav-mega--multi-column,
	.navbar .dropdown-menu.nav-mega--patient-support {
		left: 50%;
		right: auto;
		transform: translateX(-50%);
		max-width: min(400px, calc(100vw - 48px));
		width: min(400px, calc(100vw - 48px));
	}

	.navbar .dropdown-menu .container {
		max-width: none;
		padding: 0 !important;
		width: 100%;
	}

	.navbar .dropdown-menu.nav-mega--treatment-areas.nav-mega--multi-column > .container,
	.navbar .dropdown-menu.nav-mega--compact > .container {
		width: auto;
	}

	.navbar .dropdown-menu .nav {
		align-items: stretch;
		flex-direction: column;
		gap: 0.25rem;
	}

	.navbar .dropdown-menu .nav-mega__list {
		align-items: flex-start;
		display: flex;
		flex-direction: column;
		list-style: none;
		margin: 0;
		padding: 0;
	}

	.navbar .dropdown-menu .nav-mega__list--multi-column {
		align-items: start;
		display: grid;
		gap: 0.25rem 10px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		width: 100%;
	}

	.navbar .dropdown-menu .nav-mega__list--compact {
		align-items: start;
		display: grid;
		gap: 0.25rem 14px;
		grid-template-columns: repeat(2, minmax(180px, 1fr));
		width: 100%;
	}

	.navbar .dropdown-menu.nav-mega--partner-facilities {
		min-width: 230px;
		padding: 10px;
	}

	.navbar .dropdown-menu.nav-mega--partner-facilities > .container {
		padding: 0 !important;
		margin: 0 !important;
		width: 100% !important;
		max-width: none !important;
	}

	.navbar .dropdown-menu.nav-mega--partner-facilities .nav-mega__list--compact {
		grid-template-columns: minmax(0, 1fr);
		width: 100%;
		margin: 0;
		padding: 0;
	}

	.navbar .dropdown-menu.nav-mega--treatment-areas.nav-mega--multi-column .nav-link,
	.navbar .dropdown-menu.nav-mega--compact .nav-link {
		min-width: 0;
		width: 100%;
	}

	.navbar .dropdown-menu .nav-link {
		align-items: flex-start;
		border-radius: 8px;
		box-sizing: border-box;
		color: #1d2d4a !important;
		display: flex;
		justify-content: center;
		font-size: 0.98rem;
		font-weight: var(--weight-heading);
		height: auto;
		line-height: 1.22;
		margin-inline-end: 0;
		min-height: 42px;
		padding: 0.4rem 0.75rem;
		position: relative;
		text-decoration: none;
		transition:
			background-color 0.16s ease,
			color 0.16s ease;
		max-width: 100%;
		width: 100%;
	}

	.navbar .dropdown-menu .nav-mega__link-label {
		font-size: inherit;
		line-height: inherit;
		overflow-wrap: anywhere;
	}

	.navbar-expand-lg .navbar-nav .dropdown-menu .menu-item {
		border-bottom: 0 !important;
		height: auto;
		max-width: 100%;
		min-width: 0;
		width: 100%;
	}

	.navbar .dropdown-menu .nav-link:hover,
	.navbar .dropdown-menu .nav-link:focus,
	.navbar .dropdown-menu .nav-link[aria-current='page'] {
		background: var(--color-primary-soft);
		color: var(--color-primary) !important;
	}

	.navbar .dropdown-menu .nav-mega__link--featured {
		background: transparent;
		color: var(--color-primary-dark) !important;
		font-weight: var(--weight-heading);
	}

	.navbar .dropdown-menu img {
		aspect-ratio: 4 / 3;
		border-radius: 10px !important;
		box-shadow: 0 18px 34px rgba(16, 47, 79, 0.16);
		height: 100%;
		max-height: 188px;
		object-fit: cover;
		width: 100%;
	}

	.navbar-expand-lg a.navbar-call-action {
		background: rgba(255, 255, 255, 0.1);
		border: 1px solid rgba(255, 255, 255, 0.24);
		border-radius: 999px;
		flex: 0 0 auto;
		font-weight: var(--weight-semibold);
		min-height: 40px;
		padding: 0.55rem 1rem;
		transition:
			background-color 0.18s ease,
			border-color 0.18s ease,
			transform 0.18s ease;
		white-space: nowrap;
	}

	.navbar-expand-lg a.navbar-call-action:hover,
	.navbar-expand-lg a.navbar-call-action:focus {
		background: #fff;
		border-color: #fff;
		color: var(--color-primary);
		transform: translateY(-1px);
	}

	.w-md-75 {
		width: 75%;
	}
}

@media screen and (min-width: 992px) and (max-width: 1440px) {
	nav.navbar > .container {
		padding-left: var(--site-container-gutter);
		padding-right: var(--site-container-gutter);
	}

	nav.navbar .logo {
		height: 44px;
		max-width: 184px;
	}

	.navbar-expand-lg .navbar-nav .nav-link {
		font-size: 0.9rem;
		padding-inline: 0.26rem;
	}

	.navbar-expand-lg .navbar-nav .nav-link span {
		font-size: 0.9rem;
	}

	.navbar-expand-lg .navbar-nav .nav-label-full {
		display: none;
	}

	.navbar-expand-lg .navbar-nav .nav-label-short {
		display: inline;
	}

	.navbar-expand-lg a.navbar-call-action {
		font-size: 0.875rem;
		margin-left: 18px;
		min-height: 38px;
		padding: 0.42rem 0.62rem;
	}

	.navbar-expand-lg a.navbar-call-action::before {
		left: -10px;
	}

	.navbar-expand-lg .navbar-nav .dropdown-menu.nav-mega .nav-mega__link-label {
		font-size: clamp(0.98rem, 0.92rem + 0.16vw, 1.08rem);
	}
}

@media screen and (min-width: 992px) and (max-width: 1199px) {
	.navbar .dropdown-menu {
		max-width: calc(100vw - 32px);
	}

	.navbar .dropdown-menu .nav-mega__list--treatments {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 1200px) {
	.main-slider-content {
		padding-top: 0 !important;
	}
}

@media screen and (max-width: 767px) {
	.main-slider {
		aspect-ratio: auto;
		min-height: 430px;
	}

	.main-slider-content {
		align-items: flex-start;
		padding: 72px 0 56px;
	}

	.main-slider-content h1 {
		font-size: 2.5rem;
		line-height: 3rem;
	}

	.main-slider-content p {
		font-size: 1.5rem;
		line-height: 2rem;
	}
}

@media screen and (max-width: 991.98px) {
	:root {
		--topstrip-height: 40px;
	}

	.cta-container .cta-title {
		font-size: 32px !important;
		margin-bottom: 10px !important;
	}
	.cta-container .lead {
		font-size: 16px !important;
	}
	.cta-container .btn {
		padding-top: 12px !important;
		padding-bottom: 12px !important;
		font-size: 18px !important;
	}
	.navbar-expand-lg .nav-item.show .dropdown-overlay {
		display: none !important;
	}
	.navbar-collapse {
		position: fixed;
		top: calc(var(--navbar-offset-top) + var(--navbar-height));
		background: #fff;
		left: 0;
		right: 0;
		bottom: auto;
		height: auto;
		max-height: calc(100vh - var(--navbar-offset-top) - var(--navbar-height) - 12px);
		max-height: calc(100dvh - var(--navbar-offset-top) - var(--navbar-height) - 12px);
		z-index: 1000;
		padding: 0 14px 14px;
		overflow-y: auto;
		border: 1px solid rgba(23, 105, 170, 0.14);
		border-top: 0;
		border-radius: 0 0 16px 16px;
		box-shadow: 0 18px 36px rgba(16, 47, 79, 0.22);
		transition: none !important;
	}

	.post-list li {
		flex-direction: column;
	}

	.post-list li .post-image img {
		width: 100%;
		height: auto;
	}

	nav.navbar .logo-wrapper {
		width: initial;
		padding: 0 10px;
	}

	.navbar-expand-lg .navbar-collapse {
		height: initial !important;
		overflow-x: hidden;
		overflow-y: auto;
	}

	.navbar-mobile-cta {
		background: transparent;
		border: 0;
		border-bottom: 1px solid #e0e8f2;
		border-radius: 0;
		display: block;
		margin: 0;
		padding: 14px 2px 12px;
	}

	.navbar-mobile-cta p {
		color: var(--color-muted);
		font-size: 0.88rem;
		line-height: 1.35;
		margin: 0 0 10px;
	}

	.navbar-mobile-cta__certificate {
		color: var(--color-primary-dark);
		display: inline-flex;
		font-size: 0.9rem;
		font-weight: var(--weight-semibold);
		margin-bottom: 0;
		text-decoration: none;
	}

	.navbar-mobile-cta__certificate:hover,
	.navbar-mobile-cta__certificate:focus {
		color: var(--color-primary);
		text-decoration: underline;
	}

	.navbar-expand-lg .navbar-collapse .navbar-nav {
		height: initial;
		align-items: flex-start;
		gap: 0;
		margin: 0;
		width: 100%;
	}

	.navbar-expand-lg .navbar-collapse > .navbar-nav > .nav-item > .nav-link {
		align-items: center;
		background: transparent;
		border: 0;
		border-bottom: 1px solid #e6edf5;
		border-radius: 0;
		box-shadow: none;
		color: #1f2937;
		display: flex;
		font-weight: var(--weight-heading);
		justify-content: space-between;
		min-height: 48px;
		padding: 0.82rem 0.12rem;
		width: 100%;
	}

	.navbar-expand-lg .navbar-collapse .dropdown.show > .nav-link {
		background: transparent;
		border-color: #cbddeb;
		color: var(--color-primary);
	}

	.navbar-expand-lg .navbar-collapse .dropdown.show > .nav-link svg {
		transform: rotate(180deg);
	}

	.navbar-expand-lg .navbar-collapse .dropdown-toggle svg {
		transition: transform 0.18s ease;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu {
		background: #f8fbfe !important;
		border: 0;
		border-bottom: 1px solid #e6edf5;
		border-radius: 0;
		box-shadow: none;
		box-sizing: border-box;
		float: none;
		margin: 0;
		max-width: 100%;
		padding: 2px 0 8px 12px;
		position: static;
		width: 100%;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu.nav-mega {
		padding: 4px 0 10px 12px;
	}

	.navbar-expand-lg .navbar-collapse .navbar-nav .dropdown-menu .container {
		padding: 0 !important;
	}

	.navbar-expand-lg .navbar-collapse .navbar-nav .dropdown-menu .container img {
		display: none;
	}

	.navbar-expand-lg .navbar-collapse .navbar-nav .dropdown-menu .container div[class*='col'] {
		margin-bottom: 0 !important;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .row {
		display: block;
		margin: 0;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav {
		align-items: stretch;
		display: grid;
		gap: 0;
		grid-template-columns: 1fr;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-mega__list {
		column-count: 1;
		display: grid;
		grid-template-columns: minmax(0, 1fr);
		width: 100%;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-mega__list .menu-item {
		margin-bottom: 0;
	}

	.navbar-expand-lg .navbar-collapse .nav-mega__intro {
		display: none;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-link {
		border-bottom: 1px solid #e1e9f1;
		border-radius: 0;
		box-shadow: none;
		color: #0d2d6c !important;
		display: flex;
		font-size: 0.96rem;
		font-weight: var(--weight-semibold);
		justify-content: flex-start;
		line-height: 1.22;
		min-height: 40px;
		padding: 0.58rem 0.12rem;
		width: 100%;
	}

	.navbar-expand-lg .navbar-collapse .nav-mega__link {
		align-items: flex-start;
		gap: 0;
	}

	.navbar-expand-lg .navbar-collapse .nav-mega__link-note {
		display: none;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-item:last-child .nav-link,
	.navbar-expand-lg
		.navbar-collapse
		.dropdown-menu
		.col-md-4:last-child
		.nav-item:last-child
		.nav-link {
		border-bottom: 0;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-link:hover,
	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-link:focus {
		color: var(--color-primary) !important;
	}

	.newsletter-card {
		padding: 20px;
	}

	.newsletter-container {
		padding: 0 !important;
	}

	.features-list {
		margin-bottom: 0 !important;
	}

	.navbar-expand-lg .navbar-nav .nav-link {
		color: #333;
		width: 100%;
		min-height: 44px;
		margin-inline-end: 0;
		padding: 0.625rem 0.25rem;
		border-bottom: 0;
		justify-content: space-between;
	}

	.navbar-expand-lg .navbar-nav .nav-link:hover,
	.navbar-expand-lg .navbar-nav .nav-link[aria-expanded='true'] {
		color: #333;
	}

	.navbar-expand-lg .navbar-nav .nav-item {
		height: auto;
		width: 100%;
	}

	.navbar-expand-lg .navbar-nav .nav-item.ml-3 {
		margin-left: 0 !important;
	}

	.navbar-expand-lg .navbar-nav .menu-item {
		border-bottom: 0 !important;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-link {
		border: none !important;
	}

	.navbar-expand-lg .navbar-collapse .btn.btn-ghost {
		align-items: center;
		background: var(--color-primary);
		border-color: var(--color-primary);
		border-radius: 8px;
		color: #fff;
		display: flex;
		font-weight: var(--weight-heading);
		justify-content: center;
		margin-top: 10px !important;
		min-height: 46px;
	}

	.navbar-expand-lg .navbar-collapse .btn.btn-ghost:hover,
	.navbar-expand-lg .navbar-collapse .btn.btn-ghost:focus {
		background: var(--color-primary-dark);
		border-color: var(--color-primary-dark);
		color: #fff;
	}

	.hospital-photos-list .hospital-photo {
		max-width: 50%;
	}
}

@media screen and (max-width: 767px) {
	.topstrip__inner {
		gap: 0.5rem;
	}

	.topstrip__trust {
		font-size: 0.8rem;
		flex: 1 1 auto;
	}

	.topstrip__actions {
		gap: 0;
	}

	.topstrip__link {
		font-size: 0.8rem;
		padding: 0 0.45rem;
	}

	.topstrip__language {
		padding: 1px;
	}

	.topstrip__language a {
		font-size: 0.7rem;
		min-height: 21px;
		min-width: 27px;
		padding: 0.18rem 0.3rem;
	}

	.topstrip__link--optional,
	.topstrip__trust-main,
	.topstrip__certificate,
	.topstrip__secondary,
	.topstrip__optional,
	.topstrip__dot {
		display: none;
	}

	.topstrip__trust-short {
		display: inline;
	}
}

@media screen and (max-width: 430px) {
	.topstrip__trust {
		max-width: calc(100vw - 128px);
	}

	.topstrip__link--primary {
		display: none;
	}

	.topstrip__link[href^='tel:'] {
		display: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.topstrip,
	.topstrip__inner,
	nav.navbar {
		transition: none;
	}
}

/* jQuery Confirm Custom Styling */
.jconfirm {
	font-family: var(--font);
}

.jconfirm .jconfirm-box {
	border-radius: 8px;
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
	border: none;
	padding: 0;
}

.jconfirm .jconfirm-box div.jconfirm-title-c {
	padding: 1.5rem 1.5rem 0.5rem;
	color: var(--color-body);
	font-weight: var(--weight-semibold);
	font-size: 1.25rem;
}

.jconfirm .jconfirm-box div.jconfirm-content-pane {
	margin-bottom: 0;
}

.jconfirm .jconfirm-box div.jconfirm-content {
	padding: 0 1.5rem;
	color: var(--color-body);
	font-size: 1rem;
}

.jconfirm .jconfirm-box div.jconfirm-buttons {
	padding: 1rem 1.5rem 1.5rem;
}

.jconfirm .jconfirm-box .jconfirm-buttons button {
	border-radius: 32px;
	padding: 8px 24px;
	font-size: 0.875rem;
	font-weight: var(--weight-medium);
	text-transform: none;
	transition: all 0.2s ease;
}

/* Type-specific styling */
.jconfirm .jconfirm-type-green .jconfirm-box {
	border-top: 4px solid #28a745;
}

.jconfirm .jconfirm-type-red .jconfirm-box {
	border-top: 4px solid #dc3545;
}

.jconfirm .jconfirm-type-orange .jconfirm-box {
	border-top: 4px solid #fd7e14;
}

.jconfirm .jconfirm-type-blue .jconfirm-box {
	border-top: 4px solid var(--color-primary);
}

/* Success alert styling */
.jconfirm .jconfirm-type-green .bi-check-circle {
	color: #28a745;
}

/* Button styling to match website */
.jconfirm .jconfirm-box .jconfirm-buttons button.btn-primary {
	background: var(--color-primary);
	border-color: var(--color-primary);
}

.jconfirm .jconfirm-box .jconfirm-buttons button.btn-primary:hover {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
}

.jconfirm .jconfirm-box .jconfirm-buttons button.btn-success {
	background: #28a745;
	border-color: #28a745;
}

.jconfirm .jconfirm-box .jconfirm-buttons button.btn-success:hover {
	background: #218838;
	border-color: #1e7e34;
}

.jconfirm .jconfirm-box .jconfirm-buttons button.btn-danger {
	background: #dc3545;
	border-color: #dc3545;
}

.jconfirm .jconfirm-box .jconfirm-buttons button.btn-danger:hover {
	background: #c82333;
	border-color: #bd2130;
}

.jconfirm .jconfirm-box .jconfirm-buttons button.btn-warning {
	background: #fd7e14;
	border-color: #fd7e14;
	color: #fff;
}

.jconfirm .jconfirm-box .jconfirm-buttons button.btn-warning:hover {
	background: #e66800;
	border-color: #d96300;
}

.jconfirm .jconfirm-box .jconfirm-buttons button.btn-light {
	background: #f8f9fa;
	border-color: #ddd;
	color: #333;
}

.jconfirm .jconfirm-box .jconfirm-buttons button.btn-light:hover {
	background: #e9ecef;
	border-color: #ccc;
}

/* Close icon */
.jconfirm .jconfirm-box .jconfirm-closeIcon {
	color: #999;
	top: 15px;
	right: 15px;
}

.jconfirm .jconfirm-box .jconfirm-closeIcon:hover {
	color: var(--color-body);
}

.jconfirm.newsletter-success-alert .jconfirm-bg {
	background: rgba(14, 34, 28, 0.4);
	backdrop-filter: blur(8px);
}

.jconfirm.newsletter-error-alert .jconfirm-bg {
	background: rgba(60, 18, 21, 0.42);
	backdrop-filter: blur(8px);
}

.jconfirm .jconfirm-box.newsletter-success-alert-modal {
	width: min(520px, calc(100vw - 32px)) !important;
	border: 1px solid rgba(31, 105, 73, 0.14);
	border-top: 0 !important;
	border-radius: 30px;
	background:
		radial-gradient(circle at top right, rgba(33, 153, 98, 0.16), transparent 36%),
		linear-gradient(180deg, #f5fbf7 0%, #ffffff 72%);
	box-shadow: 0 28px 80px rgba(17, 41, 31, 0.22);
	overflow: hidden;
}

.jconfirm .jconfirm-box.newsletter-error-alert-modal {
	width: min(520px, calc(100vw - 32px)) !important;
	border: 1px solid rgba(162, 42, 58, 0.14);
	border-top: 0 !important;
	border-radius: 30px;
	background:
		radial-gradient(circle at top right, rgba(198, 74, 92, 0.12), transparent 36%),
		linear-gradient(180deg, #fff7f7 0%, #ffffff 72%);
	box-shadow: 0 28px 80px rgba(64, 25, 30, 0.2);
	overflow: hidden;
}

.jconfirm .jconfirm-box.newsletter-success-alert-modal div.jconfirm-content-pane {
	overflow: visible;
}

.jconfirm .jconfirm-box.newsletter-error-alert-modal div.jconfirm-content-pane {
	overflow: visible;
}

.jconfirm .jconfirm-box.newsletter-success-alert-modal div.jconfirm-content {
	padding: 0 2rem;
}

.jconfirm .jconfirm-box.newsletter-error-alert-modal div.jconfirm-content {
	padding: 0 2rem;
}

.jconfirm .jconfirm-box.newsletter-success-alert-modal div.jconfirm-buttons {
	display: flex;
	justify-content: center;
	padding: 0 2rem 2rem;
}

.jconfirm .jconfirm-box.newsletter-error-alert-modal div.jconfirm-buttons {
	display: flex;
	justify-content: center;
	padding: 0 2rem 2rem;
}

.jconfirm .jconfirm-box.newsletter-success-alert-modal .jconfirm-buttons button.sh-newsletter-alert__button {
	min-width: 170px;
	padding: 14px 28px;
	border: 0;
	border-radius: 999px;
	background: linear-gradient(135deg, #0d7f56 0%, #17a36f 100%);
	box-shadow: 0 16px 30px rgba(17, 132, 88, 0.24);
	font-size: 0.95rem;
	font-weight: var(--weight-semibold);
	letter-spacing: 0.01em;
}

.jconfirm .jconfirm-box.newsletter-error-alert-modal .jconfirm-buttons button.sh-newsletter-alert__button {
	min-width: 170px;
	padding: 14px 28px;
	border: 0;
	border-radius: 999px;
	font-size: 0.95rem;
	font-weight: var(--weight-semibold);
	letter-spacing: 0.01em;
}

.jconfirm .jconfirm-box.newsletter-error-alert-modal .jconfirm-buttons button.sh-newsletter-alert__button--danger {
	background: linear-gradient(135deg, #ba344c 0%, #d54e64 100%);
	box-shadow: 0 16px 30px rgba(186, 52, 76, 0.22);
}

.jconfirm .jconfirm-box.newsletter-success-alert-modal .jconfirm-buttons button.sh-newsletter-alert__button:hover,
.jconfirm .jconfirm-box.newsletter-success-alert-modal .jconfirm-buttons button.sh-newsletter-alert__button:focus {
	transform: translateY(-1px);
	background: linear-gradient(135deg, #0b714c 0%, #149362 100%);
	box-shadow: 0 18px 36px rgba(17, 132, 88, 0.28);
}

.jconfirm .jconfirm-box.newsletter-error-alert-modal .jconfirm-buttons button.sh-newsletter-alert__button--danger:hover,
.jconfirm .jconfirm-box.newsletter-error-alert-modal .jconfirm-buttons button.sh-newsletter-alert__button--danger:focus {
	transform: translateY(-1px);
	background: linear-gradient(135deg, #a52c43 0%, #c8455b 100%);
	box-shadow: 0 18px 36px rgba(186, 52, 76, 0.26);
}

.newsletter-success-alert__panel {
	position: relative;
	padding: 2.4rem 0 1.35rem;
	text-align: center;
}

.newsletter-error-alert__panel {
	position: relative;
	padding: 2.4rem 0 1.35rem;
	text-align: center;
}

.newsletter-success-alert__panel::before,
.newsletter-success-alert__panel::after {
	content: "";
	position: absolute;
	border-radius: 999px;
	pointer-events: none;
}

.newsletter-error-alert__panel::before,
.newsletter-error-alert__panel::after {
	content: "";
	position: absolute;
	border-radius: 999px;
	pointer-events: none;
}

.newsletter-success-alert__panel::before {
	top: 12px;
	left: 12px;
	width: 86px;
	height: 86px;
	background: radial-gradient(circle, rgba(33, 153, 98, 0.18) 0%, rgba(33, 153, 98, 0) 72%);
}

.newsletter-success-alert__panel::after {
	right: 28px;
	bottom: 0;
	width: 120px;
	height: 120px;
	background: radial-gradient(circle, rgba(255, 198, 133, 0.16) 0%, rgba(255, 198, 133, 0) 74%);
}

.newsletter-error-alert__panel::before {
	top: 12px;
	left: 12px;
	width: 86px;
	height: 86px;
	background: radial-gradient(circle, rgba(213, 78, 100, 0.18) 0%, rgba(213, 78, 100, 0) 72%);
}

.newsletter-error-alert__panel::after {
	right: 28px;
	bottom: 0;
	width: 120px;
	height: 120px;
	background: radial-gradient(circle, rgba(255, 180, 169, 0.18) 0%, rgba(255, 180, 169, 0) 74%);
}

.newsletter-success-alert__badge {
	position: relative;
	z-index: 1;
	display: grid;
	place-items: center;
	width: 88px;
	height: 88px;
	margin: 0 auto 1.5rem;
	border-radius: 30px;
	background: linear-gradient(145deg, rgba(23, 163, 111, 0.18), rgba(255, 255, 255, 0.94));
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.85),
		0 20px 42px rgba(18, 120, 81, 0.18);
	color: #0d7f56;
}

.newsletter-error-alert__badge {
	position: relative;
	z-index: 1;
	display: grid;
	place-items: center;
	width: 88px;
	height: 88px;
	margin: 0 auto 1.5rem;
	border-radius: 30px;
	background: linear-gradient(145deg, rgba(213, 78, 100, 0.16), rgba(255, 255, 255, 0.96));
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.88),
		0 20px 42px rgba(186, 52, 76, 0.16);
	color: #ba344c;
}

.newsletter-success-alert__badge i {
	font-size: 2.8rem;
}

.newsletter-success-alert__badge svg {
	width: 2.85rem;
	height: 2.85rem;
	stroke: currentColor;
	stroke-width: 1.9;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.newsletter-error-alert__badge i {
	font-size: 2.8rem;
}

.newsletter-error-alert__badge svg {
	width: 2.85rem;
	height: 2.85rem;
	stroke: currentColor;
	stroke-width: 1.9;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.newsletter-success-alert__title {
	position: relative;
	z-index: 1;
	margin: 0 0 0.8rem;
	color: #173529;
	font-family: var(--font-primary);
	font-size: clamp(1.8rem, 2.8vw, 2.3rem);
	font-weight: var(--weight-semibold);
	letter-spacing: -0.03em;
	line-height: 1.05;
}

.newsletter-error-alert__title {
	position: relative;
	z-index: 1;
	margin: 0 0 0.8rem;
	color: #4b1f27;
	font-family: var(--font-primary);
	font-size: clamp(1.8rem, 2.8vw, 2.3rem);
	font-weight: var(--weight-semibold);
	letter-spacing: -0.03em;
	line-height: 1.05;
}

.newsletter-success-alert__message {
	position: relative;
	z-index: 1;
	max-width: 32ch;
	margin: 0 auto;
	color: rgba(23, 53, 41, 0.78);
	font-size: 1rem;
	line-height: 1.7;
}

.newsletter-error-alert__message {
	position: relative;
	z-index: 1;
	max-width: 32ch;
	margin: 0 auto;
	color: rgba(75, 31, 39, 0.78);
	font-size: 1rem;
	line-height: 1.7;
}

.d-markdown {
	display: none !important;
}

@media screen and (max-width: 768px) {
	.jconfirm .jconfirm-box {
		max-width: 90%;
	}

	.jconfirm .jconfirm-box.newsletter-success-alert-modal {
		border-radius: 26px;
	}

	.jconfirm .jconfirm-box.newsletter-error-alert-modal {
		border-radius: 26px;
	}
}

@media screen and (max-width: 576px) {
	.jconfirm .jconfirm-box.newsletter-success-alert-modal div.jconfirm-content {
		padding: 0 1.3rem;
	}

	.jconfirm .jconfirm-box.newsletter-error-alert-modal div.jconfirm-content {
		padding: 0 1.3rem;
	}

	.jconfirm .jconfirm-box.newsletter-success-alert-modal div.jconfirm-buttons {
		padding: 0 1.3rem 1.3rem;
	}

	.jconfirm .jconfirm-box.newsletter-error-alert-modal div.jconfirm-buttons {
		padding: 0 1.3rem 1.3rem;
	}

	.jconfirm .jconfirm-box.newsletter-success-alert-modal .jconfirm-buttons button.sh-newsletter-alert__button {
		width: 100%;
	}

	.jconfirm .jconfirm-box.newsletter-error-alert-modal .jconfirm-buttons button.sh-newsletter-alert__button {
		width: 100%;
	}

	.newsletter-success-alert__panel {
		padding: 2rem 0 1.15rem;
	}

	.newsletter-error-alert__panel {
		padding: 2rem 0 1.15rem;
	}

	.newsletter-success-alert__badge {
		width: 78px;
		height: 78px;
		margin-bottom: 1.25rem;
		border-radius: 26px;
	}

	.newsletter-error-alert__badge {
		width: 78px;
		height: 78px;
		margin-bottom: 1.25rem;
		border-radius: 26px;
	}

	.newsletter-success-alert__badge i {
		font-size: 2.4rem;
	}

	.newsletter-success-alert__badge svg {
		width: 2.45rem;
		height: 2.45rem;
	}

	.newsletter-error-alert__badge i {
		font-size: 2.4rem;
	}

	.newsletter-error-alert__badge svg {
		width: 2.45rem;
		height: 2.45rem;
	}

	.newsletter-success-alert__message {
		max-width: none;
		font-size: 0.96rem;
	}

	.newsletter-error-alert__message {
		max-width: none;
		font-size: 0.96rem;
	}
}

/* ================================================
   Homepage Lead Generation — scoped under .main-homepage
   ================================================ */

/* --- Hero overrides --- */
.main-homepage .main-slider {
	aspect-ratio: unset;
	max-height: none;
}

.main-homepage .main-slider .main-slider-bg {
	background-color: var(--color-surface-warm);
	background-image: url('../images/home-hero-bg-clear.png');
	background-image: image-set(
		url('../images/home-hero-bg-clear.webp') type('image/webp'),
		url('../images/home-hero-bg-clear.png') type('image/png')
	);
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: cover;
	filter: contrast(1.04) saturate(1.04);
}

/* Decorative hero layer intentionally disabled for a cleaner background. */
.main-homepage .main-slider .main-slider-bg::before {
	content: none;
	display: none;
}

/* Background image is already softly graded, so keep it unobstructed. */
.main-homepage .main-slider .main-slider-bg::after {
	content: none;
	display: none;
}

@media screen and (min-width: 1600px) {
	.main-homepage .main-slider .main-slider-bg {
		background-position: center bottom;
		background-size: 100% auto;
	}
}

.main-homepage .main-slider-content {
	align-items: stretch;
	justify-content: stretch;
	padding: 0;
}

.main-homepage .main-slider-content .container {
	display: block;
	padding-top: 72px;
	padding-bottom: 72px;
}

.main-homepage .main-slider-content h1 {
	font-size: 2.5rem;
	line-height: 1.25;
	font-weight: var(--weight-semibold);
	color: #102f4f;
}

.main-homepage .main-slider-content .hero-title-line {
	display: block;
}

.main-homepage .main-slider-content p.f1 {
	font-size: 1.05rem;
	line-height: 1.65;
	font-weight: var(--weight-regular);
	color: var(--color-muted);
}

.homepage-trust-bullets {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	font-size: 0.8rem;
	color: rgba(36, 59, 58, 0.72);
}

/* --- How It Works steps --- */
.homepage-step-number {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--color-primary-dark);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: var(--weight-semibold);
	font-size: 1.1rem;
	flex-shrink: 0;
	margin-bottom: 12px;
}

/* --- Trust cards --- */
.homepage-trust-card {
	background: #fff;
	border-radius: 10px;
	padding: 24px;
	height: 100%;
	box-shadow: 0 1px 6px rgba(0, 0, 0, 0.07);
}

.homepage-trust-icon {
	color: var(--color-primary);
	width: 28px;
	height: 28px;
}

/* --- Treatment category cards --- */
.homepage-treatment-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	text-decoration: none;
	color: inherit;
	background: #fff;
	border: 1px solid var(--color-line-soft);
	border-radius: 12px;
	padding: 22px 14px;
	height: 100%;
	transition:
		box-shadow 0.2s,
		transform 0.2s;
}

.homepage-treatment-card:hover {
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.1);
	transform: translateY(-3px);
	text-decoration: none;
	color: inherit;
}

.homepage-treatment-icon {
	width: 64px;
	height: 64px;
	border-radius: 16px;
	background: var(--color-primary-soft);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	margin-bottom: 14px;
	flex-shrink: 0;
}

.homepage-treatment-card h3 {
	font-size: 0.875rem;
	font-weight: var(--weight-semibold);
	color: #102f4f;
	margin-bottom: 6px;
	line-height: 1.3;
}

.homepage-treatment-card p {
	font-size: 0.75rem;
	color: #888;
	margin-bottom: 10px;
	line-height: 1.4;
	flex-grow: 1;
}

.homepage-treatment-cta {
	font-size: 0.75rem;
	color: var(--color-primary);
	font-weight: var(--weight-semibold);
	margin-top: auto;
}

/* --- Why section --- */
.homepage-why-item {
	display: flex;
	gap: 16px;
	align-items: flex-start;
}

.homepage-why-icon {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--color-primary-soft);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-primary);
}

.homepage-why-icon svg {
	width: 20px;
	height: 20px;
}

/* --- Mobile overrides --- */
@media screen and (max-width: 767px) {
	.main-homepage .main-slider-content .container {
		padding-top: 56px;
		padding-bottom: 56px;
	}

	.main-homepage .main-slider-content h1 {
		font-size: 1.8rem;
		line-height: 1.3;
	}

	.main-homepage .main-slider-content p.f1 {
		font-size: 0.95rem;
	}

	.main-homepage .hero__assurance {
		display: none;
	}

	.homepage-trust-bullets {
		gap: 8px;
		font-size: 0.75rem;
	}
}

/* --- Homepage blog section light-background overrides --- */
.main-homepage .homepage-blog .section-grid-1-3 a {
	color: #102f4f;
}
.main-homepage .homepage-blog .section-grid-1-3 a:hover {
	color: var(--color-primary);
}
.main-homepage .homepage-blog .section-grid-1-3 .right p {
	color: #555;
}

/* ================================================
   About Page - international patient guidance
   ================================================ */
.about-page {
	--about-navy: #102f4f;
	--about-blue: #1769aa;
	--about-blue-2: #1769aa;
	--about-blue-3: #2f8fd3;
	--about-light: #f6fbff;
	--about-soft: #eaf5ff;
	--about-line: #d8e8f5;
	--about-text: #24384f;
	--about-muted: #5f7184;
	color: var(--about-text);
	background: #fff;
}

.about-page .container {
	max-width: var(--site-container-max);
}

.about-hero {
	background: linear-gradient(135deg, #0d477f 0%, #1769aa 62%, #73b8e8 100%);
	color: #fff;
	padding: 42px 0 72px;
	overflow: hidden;
}

.about-breadcrumb {
	background: transparent;
	padding-left: 0;
	margin-bottom: 42px;
}

.about-breadcrumb a,
.about-breadcrumb .breadcrumb-item,
.about-breadcrumb .breadcrumb-item.active {
	color: rgba(255, 255, 255, 0.88);
}

.about-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
	color: rgba(255, 255, 255, 0.64);
}

.about-label {
	display: inline-flex;
	align-items: center;
	min-height: 32px;
	padding: 5px 14px;
	border: 1px solid rgba(255, 255, 255, 0.32);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.14);
	color: #fff;
	font-size: 0.75rem;
	font-weight: var(--weight-semibold);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.about-hero h1 {
	margin: 20px 0 18px;
	color: #fff;
	font-size: 3rem;
	line-height: 1.12;
	font-weight: var(--weight-heading);
}

.about-hero-copy {
	max-width: 760px;
	color: rgba(255, 255, 255, 0.9);
	font-size: 1.16rem;
	line-height: 1.72;
	margin-bottom: 0;
}

.about-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-top: 28px;
}

.about-btn-primary,
.about-btn-secondary {
	min-height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	padding: 12px 22px;
	font-weight: var(--weight-semibold);
	text-decoration: none !important;
	transition:
		background-color 0.2s ease,
		color 0.2s ease,
		border-color 0.2s ease,
		box-shadow 0.2s ease;
}

.about-btn-primary {
	background: var(--about-blue-2);
	border: 1px solid var(--about-blue-2);
	color: #fff !important;
	box-shadow: 0 12px 30px rgba(23, 105, 170, 0.28);
}

.about-btn-primary:hover {
	background: var(--about-navy);
	border-color: var(--about-navy);
	color: #fff !important;
}

.about-btn-secondary {
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.44);
	color: #fff !important;
}

.about-btn-secondary:hover {
	background: rgba(255, 255, 255, 0.22);
	color: #fff !important;
}

.about-btn-secondary-dark {
	background: #fff;
	border-color: var(--about-line);
	color: var(--about-blue) !important;
}

.about-btn-secondary-dark:hover {
	background: var(--about-light);
	color: var(--about-navy) !important;
}

.about-btn-primary-light {
	background: #fff;
	border-color: #fff;
	color: var(--about-blue) !important;
	box-shadow: none;
}

.about-btn-primary-light:hover {
	background: var(--about-light);
	border-color: var(--about-light);
	color: var(--about-navy) !important;
}

.about-btn-secondary-light {
	background: transparent;
	border-color: rgba(255, 255, 255, 0.5);
	color: #fff !important;
}

.about-btn-primary:focus-visible,
.about-btn-secondary:focus-visible,
.about-policy-links a:focus-visible {
	outline: 3px solid #22d3ee;
	outline-offset: 3px;
}

.about-trust-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	max-width: 760px;
	margin: 30px 0 0;
	padding: 0;
	list-style: none;
}

.about-trust-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	color: rgba(255, 255, 255, 0.9);
	line-height: 1.4;
}

.about-trust-list svg {
	width: 18px;
	height: 18px;
	flex: 0 0 18px;
	color: #d8ecff;
}

.about-hero-image-wrap {
	position: relative;
	margin: 0;
	display: flex;
	justify-content: flex-end;
}

.about-hero-image-wrap::before {
	content: '';
	position: absolute;
	inset: 10% -8% -10% 12%;
	border-radius: 24px;
	background: rgba(255, 255, 255, 0.14);
	border: 1px solid rgba(255, 255, 255, 0.24);
}

.about-hero-image {
	position: relative;
	z-index: 1;
	width: min(100%, 520px);
	aspect-ratio: 13 / 10;
	height: auto;
	max-height: 420px;
	object-fit: cover;
	object-position: center top;
	border-radius: 16px;
	box-shadow: 0 28px 70px rgba(16, 47, 79, 0.28);
}

.authorization-hero-image-wrap {
	position: relative;
	margin: 0;
	display: flex;
	justify-content: flex-end;
}

.authorization-hero-image {
	position: relative;
	z-index: 1;
	width: min(100%, 560px);
	aspect-ratio: 3 / 2;
	height: auto;
	object-fit: cover;
	object-position: center;
	border-radius: 16px;
	box-shadow: 0 28px 70px rgba(16, 47, 79, 0.28);
}

.about-section {
	padding: 74px 0;
}

.about-section-soft {
	background: var(--about-light);
}

.about-role-section {
	background: #fff;
	border-bottom: 1px solid rgba(16, 47, 79, 0.08);
}

.about-role-editorial {
	display: grid;
	grid-template-columns: minmax(280px, 0.88fr) minmax(0, 1.12fr);
	gap: clamp(36px, 5vw, 76px);
	align-items: center;
	max-width: 1180px;
	margin: 0;
	text-align: left;
}

.about-role-media {
	position: relative;
	margin: 0;
	min-width: 0;
}

.about-role-media::before {
	content: '';
	position: absolute;
	inset: 12% -8% -9% 14%;
	border: 1px solid rgba(47, 143, 211, 0.16);
	border-radius: 20px;
	background: linear-gradient(135deg, rgba(233, 245, 251, 0.92), rgba(255, 255, 255, 0.28));
}

.about-role-media img {
	position: relative;
	z-index: 1;
	display: block;
	width: 100%;
	aspect-ratio: 5 / 4;
	height: auto;
	object-fit: cover;
	object-position: center;
	border-radius: 16px;
	box-shadow: 0 22px 52px rgba(16, 47, 79, 0.16);
}

.about-role-content {
	min-width: 0;
}

.about-role-heading {
	margin-left: 0;
	margin-right: 0;
	margin-bottom: 24px;
	text-align: left;
}

.about-role-copy {
	max-width: 680px;
	margin: 0;
}

.about-role-copy > p {
	margin-left: 0;
	margin-right: 0;
}

.about-role-copy > p:last-of-type {
	margin-bottom: 0;
}

.about-role-section .about-lead {
	max-width: none;
	margin-bottom: 14px;
}

.about-standards-faq-section {
	border-bottom: 1px solid rgba(16, 47, 79, 0.08);
	border-top: 1px solid rgba(16, 47, 79, 0.08);
}

.about-support-section {
	position: relative;
	overflow: hidden;
	background:
		linear-gradient(180deg, #fbfdff 0%, #f3f9fd 100%);
}

.about-support-section::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(23, 105, 170, 0.08), rgba(255, 255, 255, 0) 34%),
		linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(23, 105, 170, 0.05) 100%);
	pointer-events: none;
}

.about-support-section .container {
	position: relative;
	z-index: 1;
}

.about-support-editorial {
	display: grid;
	grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1.18fr);
	gap: clamp(42px, 6vw, 92px);
	align-items: start;
}

.about-support-intro {
	position: relative;
	padding-top: 18px;
}

.about-support-intro::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 86px;
	height: 2px;
	background: linear-gradient(90deg, var(--about-blue-2), rgba(47, 143, 211, 0.18));
}

.about-support-intro .about-section-heading {
	margin-bottom: 20px;
}

.about-support-intro p {
	max-width: 520px;
	margin: 0;
	color: var(--about-muted);
	font-size: 1.06rem;
	line-height: 1.7;
}

.about-support-list {
	display: grid;
	border-top: 1px solid rgba(16, 47, 79, 0.12);
}

.about-support-row {
	display: grid;
	grid-template-columns: 44px minmax(0, 1fr);
	gap: 20px;
	align-items: start;
	padding: 24px 0;
	border-bottom: 1px solid rgba(16, 47, 79, 0.1);
}

.about-support-row__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border: 1px solid rgba(23, 105, 170, 0.18);
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.72);
	color: var(--about-blue-2);
}

.about-support-row__icon svg {
	width: 19px;
	height: 19px;
}

.about-support-row__body {
	min-width: 0;
}

.about-support-row h3 {
	margin: 0 0 6px;
	color: var(--about-navy);
	font-size: 1.08rem;
	font-weight: var(--weight-heading);
	line-height: 1.32;
}

.about-support-row p {
	max-width: 680px;
	margin: 0;
	color: var(--about-muted);
	font-size: 0.96rem;
	line-height: 1.62;
}

.about-section-heading {
	max-width: 760px;
	margin-bottom: 34px;
}

.about-section-heading span {
	display: block;
	color: var(--about-blue-2);
	font-size: 0.78rem;
	font-weight: var(--weight-heading);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: 8px;
}

.about-section-heading h2,
.about-final-cta h2 {
	color: var(--about-navy);
	font-size: 2rem;
	line-height: 1.2;
	font-weight: var(--weight-heading);
	margin: 0;
}

.about-section p {
	color: var(--about-muted);
	font-size: 1rem;
	line-height: 1.74;
}

.about-lead {
	color: var(--about-text) !important;
	font-size: 1.08rem !important;
}

.about-narrow {
	max-width: 780px;
}

.about-note {
	border-left: 4px solid var(--about-blue-2);
	border-radius: 8px;
	background: var(--about-soft);
	padding: 24px;
}

.about-note h3,
.about-treatment-band h3,
.about-card h3,
.about-step h3 {
	color: var(--about-navy);
	font-weight: var(--weight-heading);
}

.about-note h3 {
	font-size: 1.2rem;
	margin: 0 0 10px;
}

.about-note p {
	margin-bottom: 0;
}

.about-card {
	height: 100%;
	min-height: 150px;
	border: 1px solid var(--about-line);
	border-radius: 8px;
	background: #fff;
	padding: 24px;
	box-shadow: 0 10px 28px rgba(16, 47, 79, 0.06);
}

.about-card svg {
	width: 26px;
	height: 26px;
	color: var(--about-blue-2);
	margin-bottom: 16px;
}

.about-card h3 {
	font-size: 1rem;
	line-height: 1.45;
	margin: 0;
}

.about-treatment-band {
	border: 1px solid var(--about-line);
	border-radius: 8px;
	background: #fff;
	padding: 28px;
}

.about-treatment-band h3 {
	font-size: 1.18rem;
	margin: 0 0 18px;
}

.about-treatment-band ul {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	padding: 0;
	margin: 0 0 18px;
	list-style: none;
}

.about-treatment-band li {
	border-radius: 999px;
	background: var(--about-soft);
	color: var(--about-blue);
	padding: 7px 12px;
	font-weight: var(--weight-semibold);
	line-height: 1.3;
}

.about-treatment-band p {
	margin-bottom: 0;
}

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

.about-step {
	position: relative;
	min-height: 220px;
	border: 1px solid var(--about-line);
	border-radius: 8px;
	background: #fff;
	padding: 24px;
}

.about-step-number {
	width: 42px;
	height: 42px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: var(--about-blue-2);
	color: #fff;
	font-weight: var(--weight-heading);
	margin-bottom: 18px;
}

.about-step h3 {
	font-size: 1.06rem;
	line-height: 1.35;
	margin: 0 0 10px;
}

.about-step p {
	margin-bottom: 0;
}

.about-assurance-section {
	background: #fff;
}

.about-assurance-heading {
	max-width: 720px;
	margin: 0 0 40px;
	text-align: left;
}

.about-assurance-lead {
	margin: 14px 0 0;
	max-width: 640px;
	color: var(--about-muted);
	font-size: 1.06rem;
	line-height: 1.7;
}

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

.about-assurance-card {
	height: 100%;
	border: 1px solid var(--about-line);
	border-radius: 16px;
	background: #fff;
	padding: 28px;
	box-shadow: 0 10px 28px rgba(16, 47, 79, 0.06);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.about-assurance-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 18px 42px rgba(16, 47, 79, 0.1);
	border-color: rgba(23, 105, 170, 0.28);
}

.about-assurance-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	margin-bottom: 18px;
	border: 1px solid rgba(23, 105, 170, 0.18);
	border-radius: 14px;
	background: var(--about-soft);
	color: var(--about-blue-2);
}

.about-assurance-card__icon svg {
	width: 22px;
	height: 22px;
}

.about-assurance-card h3 {
	margin: 0 0 10px;
	color: var(--about-navy);
	font-size: 1.1rem;
	font-weight: var(--weight-heading);
	line-height: 1.32;
}

.about-assurance-card p {
	margin: 0;
	color: var(--about-muted);
	font-size: 0.96rem;
	line-height: 1.62;
}

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

.about-criterion {
	display: flex;
	align-items: center;
	gap: 10px;
	min-height: 64px;
	border: 1px solid var(--about-line);
	border-radius: 8px;
	background: #fff;
	padding: 14px;
	color: var(--about-text);
	font-weight: var(--weight-semibold);
}

.about-criterion svg {
	width: 18px;
	height: 18px;
	flex: 0 0 18px;
	color: var(--about-blue-2);
}

.about-question-list {
	display: grid;
	gap: 12px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.about-question-list li {
	position: relative;
	border: 1px solid var(--about-line);
	border-radius: 8px;
	background: #fff;
	color: var(--about-text);
	font-weight: var(--weight-semibold);
	line-height: 1.45;
	padding: 16px 18px 16px 44px;
}

.about-question-list li::before {
	content: '?';
	position: absolute;
	left: 16px;
	top: 16px;
	width: 20px;
	height: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--about-soft);
	color: var(--about-blue);
	font-size: 0.85rem;
	font-weight: var(--weight-heading);
}

.about-standards-faq,
.about-standards-faq__list,
.about-standards-faq .sh-faq__item {
	min-width: 0;
}

.about-standards-faq__list {
	display: grid;
	gap: 14px;
}

.about-standards-faq__accordion {
	gap: 14px;
}

.about-standards-faq .sh-faq__item {
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.09);
	border-radius: 8px;
	box-shadow: 0 16px 38px rgba(16, 47, 79, 0.06);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.about-standards-faq .sh-faq__item[open] {
	border-color: rgba(47, 143, 211, 0.26);
	box-shadow: 0 20px 44px rgba(16, 47, 79, 0.08);
}

.about-standards-faq .sh-faq__q {
	align-items: center;
	background: transparent;
	border: 0;
	color: #102f4f;
	display: flex;
	font-size: 1.05rem;
	font-weight: var(--weight-bold);
	gap: 18px;
	justify-content: space-between;
	letter-spacing: 0;
	line-height: 1.28;
	min-height: 72px;
	padding: 20px 24px;
}

.about-standards-faq .sh-faq__q > span {
	overflow-wrap: anywhere;
}

.about-standards-faq .sh-faq__q i,
.about-standards-faq .sh-faq__q svg {
	align-items: center;
	background: #e9f5fb;
	border: 1px solid rgba(47, 143, 211, 0.22);
	border-radius: 50%;
	color: var(--color-primary);
	display: inline-flex;
	flex: 0 0 34px;
	height: 34px;
	justify-content: center;
	padding: 8px;
	transition: transform 0.2s ease;
	width: 34px;
}

.about-standards-faq .sh-faq__item[open] .sh-faq__q i,
.about-standards-faq .sh-faq__item[open] .sh-faq__q svg {
	transform: rotate(180deg);
}

.about-standards-faq .sh-faq__q:focus-visible {
	border-radius: 8px;
	outline-offset: -4px;
}

.about-standards-faq .sh-faq__a {
	border-top: 1px solid rgba(16, 47, 79, 0.08);
	color: #5d7080;
	line-height: 1.62;
	margin: 0 24px;
	overflow-wrap: anywhere;
	padding: 18px 0 22px;
}

.about-policy-links {
	display: grid;
	gap: 12px;
}

.about-policy-links a {
	display: flex;
	align-items: center;
	min-height: 52px;
	border: 1px solid var(--about-line);
	border-radius: 8px;
	background: #fff;
	color: var(--about-blue);
	font-weight: var(--weight-heading);
	padding: 14px 16px;
	text-decoration: none;
	transition:
		background-color 0.2s ease,
		color 0.2s ease,
		border-color 0.2s ease;
}

.about-policy-links a:hover {
	background: var(--about-light);
	border-color: #9cc9eb;
	color: var(--about-navy);
	text-decoration: none;
}

.about-final-cta {
	background: linear-gradient(135deg, #102f4f 0%, #1769aa 100%);
	color: #fff;
	padding: 70px 0;
}

.about-final-cta-inner {
	max-width: 760px;
	margin: 0 auto;
	text-align: center;
}

.about-final-cta h2 {
	color: #fff;
}

.about-final-cta p {
	max-width: 660px;
	margin: 18px auto 0;
	color: rgba(255, 255, 255, 0.86);
	font-size: 1.08rem;
	line-height: 1.7;
}

@media (prefers-reduced-motion: reduce) {
	.about-btn-primary,
	.about-btn-secondary,
	.about-policy-links a {
		transition: none;
	}

	.about-assurance-card {
		transition: none;
	}

	.about-assurance-card:hover {
		transform: none;
	}
}

@media screen and (max-width: 991px) {
	.about-hero {
		padding-bottom: 58px;
	}

	.about-hero h1 {
		font-size: 2.35rem;
	}

	.about-role-editorial {
		grid-template-columns: 1fr;
		gap: 32px;
		max-width: 720px;
	}

	.about-role-media {
		max-width: 560px;
	}

	.about-role-copy {
		max-width: none;
	}

	.about-support-editorial {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	.about-step-grid,
	.about-criteria-grid,
	.about-assurance-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 767px) {
	.about-hero {
		padding: 12px 0 48px;
	}

	.about-breadcrumb {
		margin-bottom: 28px;
	}

	.about-hero h1 {
		font-size: 2rem;
	}

	.about-hero-copy,
	.about-lead,
	.about-final-cta p {
		font-size: 1rem !important;
	}

	.about-role-heading {
		margin-bottom: 24px;
	}

	.about-actions {
		align-items: stretch;
		flex-direction: column;
	}

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

	.about-trust-list,
	.about-step-grid,
	.about-criteria-grid,
	.about-assurance-grid {
		grid-template-columns: 1fr;
	}

	.about-support-intro {
		padding-top: 16px;
	}

	.about-support-row {
		grid-template-columns: 38px minmax(0, 1fr);
		gap: 14px;
		padding: 20px 0;
	}

	.about-support-row__icon {
		width: 38px;
		height: 38px;
	}

	.about-support-row__icon svg {
		width: 17px;
		height: 17px;
	}

	.about-standards-faq .sh-faq__q {
		gap: 12px;
		min-height: 64px;
		padding: 18px;
	}

	.about-standards-faq .sh-faq__q i,
	.about-standards-faq .sh-faq__q svg {
		flex-basis: 32px;
		height: 32px;
		padding: 7px;
		width: 32px;
	}

	.about-standards-faq .sh-faq__a {
		margin: 0 18px;
		padding: 16px 0 18px;
	}

	.about-section,
	.about-final-cta {
		padding: 52px 0;
	}

	.about-section-heading h2,
	.about-final-cta h2 {
		font-size: 1.58rem;
	}

	.about-treatment-band ul {
		display: grid;
		grid-template-columns: 1fr;
	}
}

@media (prefers-reduced-motion: reduce) {
	.about-standards-faq .sh-faq__item,
	.about-standards-faq .sh-faq__q i,
	.about-standards-faq .sh-faq__q svg {
		transition: none;
	}
}

/* ================================================
   Medical Tourism Safety Guide
   ================================================ */
.safety-guide-page {
	--safety-navy: #102f4f;
	--safety-blue: #1769aa;
	--safety-blue-2: #1769aa;
	--safety-blue-accent: #1769aa;
	--safety-light: #f6fbff;
	--safety-soft: #eaf5ff;
	--safety-warn-soft: #fff7ed;
	--safety-line: #d8e8f5;
	--safety-text: #24384f;
	--safety-muted: #5f7184;
	color: var(--safety-text);
	background: #fff;
}

.safety-guide-page .container {
	max-width: var(--site-container-max);
}

.safety-hero {
	background: linear-gradient(135deg, #0d477f 0%, #1769aa 58%, #7fc0ec 100%);
	color: #fff;
	padding: 42px 0 72px;
	overflow: hidden;
}

.safety-breadcrumb {
	background: transparent;
	padding-left: 0;
	margin-bottom: 42px;
}

.safety-breadcrumb a,
.safety-breadcrumb .breadcrumb-item,
.safety-breadcrumb .breadcrumb-item.active {
	color: rgba(255, 255, 255, 0.88);
}

.safety-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
	color: rgba(255, 255, 255, 0.64);
}

.safety-label {
	display: inline-flex;
	align-items: center;
	min-height: 32px;
	padding: 5px 14px;
	border: 1px solid rgba(255, 255, 255, 0.32);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.14);
	color: #fff;
	font-size: 0.75rem;
	font-weight: var(--weight-semibold);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.safety-hero h1 {
	margin: 20px 0 18px;
	color: #fff;
	font-size: 3rem;
	line-height: 1.12;
	font-weight: var(--weight-heading);
}

.safety-hero-copy {
	max-width: 760px;
	color: rgba(255, 255, 255, 0.9);
	font-size: 1.16rem;
	line-height: 1.72;
	margin-bottom: 0;
}

.safety-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-top: 28px;
}

.safety-btn-primary,
.safety-btn-secondary {
	min-height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	padding: 12px 22px;
	font-weight: var(--weight-semibold);
	text-decoration: none !important;
	transition:
		background-color 0.2s ease,
		color 0.2s ease,
		border-color 0.2s ease,
		box-shadow 0.2s ease;
}

.safety-btn-primary {
	background: var(--safety-blue-2);
	border: 1px solid var(--safety-blue-2);
	color: #fff !important;
	box-shadow: 0 12px 30px rgba(23, 105, 170, 0.28);
}

.safety-btn-primary:hover {
	background: var(--safety-navy);
	border-color: var(--safety-navy);
	color: #fff !important;
}

.safety-btn-secondary {
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.44);
	color: #fff !important;
}

.safety-btn-secondary:hover {
	background: rgba(255, 255, 255, 0.22);
	color: #fff !important;
}

.safety-btn-primary-light {
	background: #fff;
	border-color: #fff;
	color: var(--safety-blue) !important;
	box-shadow: none;
}

.safety-btn-primary-light:hover {
	background: var(--safety-light);
	border-color: var(--safety-light);
	color: var(--safety-navy) !important;
}

.safety-btn-secondary-light {
	background: transparent;
	border-color: rgba(255, 255, 255, 0.5);
	color: #fff !important;
}

.safety-btn-primary:focus-visible,
.safety-btn-secondary:focus-visible {
	outline: 3px solid #22d3ee;
	outline-offset: 3px;
}

.safety-trust-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	max-width: 760px;
	margin: 30px 0 0;
	padding: 0;
	list-style: none;
}

.safety-trust-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	color: rgba(255, 255, 255, 0.9);
	line-height: 1.4;
}

.safety-trust-list svg {
	width: 18px;
	height: 18px;
	flex: 0 0 18px;
	color: #d8ecff;
}

.safety-hero-image-wrap {
	position: relative;
	margin: 0;
	display: flex;
	justify-content: flex-end;
}

.safety-hero-image-wrap::before {
	content: '';
	position: absolute;
	inset: 10% -8% -10% 12%;
	border-radius: 24px;
	background: rgba(255, 255, 255, 0.14);
	border: 1px solid rgba(255, 255, 255, 0.24);
}

.safety-hero-image {
	position: relative;
	z-index: 1;
	width: min(100%, 520px);
	aspect-ratio: 13 / 10;
	height: auto;
	max-height: 420px;
	object-fit: cover;
	object-position: center top;
	border-radius: 16px;
	box-shadow: 0 28px 70px rgba(16, 47, 79, 0.28);
}

.safety-section {
	padding: 74px 0;
}

.safety-section-soft {
	background: var(--safety-light);
}

.safety-section-heading {
	max-width: 780px;
	margin-bottom: 34px;
}

.safety-section-heading span {
	display: block;
	color: var(--safety-blue-2);
	font-size: 0.78rem;
	font-weight: var(--weight-heading);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: 8px;
}

.safety-section-heading h2,
.safety-final-cta h2 {
	color: var(--safety-navy);
	font-size: 2rem;
	line-height: 1.2;
	font-weight: var(--weight-heading);
	margin: 0;
}

.safety-section p {
	color: var(--safety-muted);
	font-size: 1rem;
	line-height: 1.74;
}

.safety-lead {
	color: var(--safety-text) !important;
	font-size: 1.08rem !important;
}

.safety-narrow {
	max-width: 780px;
}

.safety-check-grid,
.safety-red-flag-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}

.safety-card,
.safety-red-flag {
	height: 100%;
	min-height: 230px;
	border: 1px solid var(--safety-line);
	border-radius: 8px;
	background: #fff;
	padding: 24px;
	box-shadow: 0 10px 28px rgba(16, 47, 79, 0.06);
}

.safety-card svg,
.safety-red-flag svg {
	width: 26px;
	height: 26px;
	color: var(--safety-blue-2);
	margin-bottom: 16px;
}

.safety-red-flag {
	background: #fff;
	border-color: #f2d7bd;
}

.safety-red-flag svg {
	color: #c2410c;
}

.safety-card h3,
.safety-red-flag h3,
.safety-step h3,
.safety-note h3 {
	color: var(--safety-navy);
	font-weight: var(--weight-heading);
}

.safety-card h3,
.safety-red-flag h3 {
	font-size: 1.05rem;
	line-height: 1.38;
	margin: 0 0 10px;
}

.safety-card p,
.safety-red-flag p {
	margin-bottom: 0;
}

.safety-note {
	border-left: 4px solid var(--safety-blue-accent);
	border-radius: 8px;
	background: var(--safety-soft);
	padding: 24px;
}

.safety-note h3 {
	font-size: 1.2rem;
	margin: 0 0 10px;
}

.safety-note p {
	margin-bottom: 0;
}

.safety-question-list {
	display: grid;
	gap: 12px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.safety-question-list li {
	position: relative;
	border: 1px solid var(--safety-line);
	border-radius: 8px;
	background: #fff;
	color: var(--safety-text);
	font-weight: var(--weight-semibold);
	line-height: 1.45;
	padding: 16px 18px 16px 44px;
}

.safety-question-list li::before {
	content: '?';
	position: absolute;
	left: 16px;
	top: 16px;
	width: 20px;
	height: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--safety-soft);
	color: var(--safety-blue);
	font-size: 0.85rem;
	font-weight: var(--weight-heading);
}

.safety-quote-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.safety-quote-item {
	display: flex;
	align-items: center;
	gap: 12px;
	min-height: 86px;
	border: 1px solid var(--safety-line);
	border-radius: 8px;
	background: #fff;
	padding: 18px;
	color: var(--safety-text);
	font-weight: var(--weight-semibold);
	line-height: 1.45;
}

.safety-quote-item svg {
	width: 19px;
	height: 19px;
	flex: 0 0 19px;
	color: var(--safety-blue-accent);
	margin-top: 0;
}

.safety-quote-item span {
	display: block;
	flex: 1 1 auto;
}

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

.safety-step {
	min-height: 230px;
	border: 1px solid var(--safety-line);
	border-radius: 8px;
	background: #fff;
	padding: 24px;
}

.safety-step-number {
	width: 42px;
	height: 42px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: var(--safety-blue-2);
	color: #fff;
	font-weight: var(--weight-heading);
	margin-bottom: 18px;
}

.safety-step h3 {
	font-size: 1.06rem;
	line-height: 1.35;
	margin: 0 0 10px;
}

.safety-step p {
	margin-bottom: 0;
}

.safety-section-image-wrap {
	margin: 0;
	border-radius: 12px;
	overflow: hidden;
	background: var(--safety-soft);
	box-shadow: 0 18px 42px rgba(16, 47, 79, 0.1);
}

.safety-section-image {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	height: auto;
	object-fit: cover;
	object-position: center;
}

.safety-image-note {
	display: grid;
	gap: 6px;
	border: 1px solid var(--safety-line);
	border-radius: 8px;
	background: #fff;
	padding: 18px;
	margin-top: 16px;
}

.safety-image-note strong {
	color: var(--safety-navy);
}

.safety-image-note span {
	color: var(--safety-muted);
	line-height: 1.6;
}

.safety-support-band {
	border: 1px solid var(--safety-line);
	border-radius: 8px;
	background: #fff;
	margin-top: 22px;
	max-width: 780px;
	padding: 22px;
}

.safety-support-band ul {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.safety-support-band li {
	align-items: center;
	border-radius: 8px;
	background: var(--safety-soft);
	color: var(--safety-blue);
	display: flex;
	font-weight: var(--weight-semibold);
	line-height: 1.35;
	min-height: 48px;
	padding: 10px 14px;
}

.safety-support-band p {
	margin-bottom: 0;
}

.safety-support-section {
	background:
		linear-gradient(180deg, rgba(246, 251, 255, 0) 0%, rgba(246, 251, 255, 0.72) 100%);
}

.safety-support-panel {
	align-items: stretch;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(246, 251, 255, 0.94) 100%);
	border: 1px solid rgba(188, 214, 234, 0.78);
	border-radius: 8px;
	display: grid;
	gap: clamp(26px, 4vw, 58px);
	grid-template-columns: minmax(0, 0.92fr) minmax(320px, 1fr);
	overflow: hidden;
	padding: clamp(28px, 4vw, 52px);
	position: relative;
}

.safety-support-panel::before {
	background: linear-gradient(90deg, var(--safety-blue) 0%, rgba(23, 105, 170, 0.08) 100%);
	content: '';
	height: 4px;
	inset-inline: 0;
	pointer-events: none;
	position: absolute;
	top: 0;
}

.safety-support-panel::after {
	background: radial-gradient(circle at 50% 50%, rgba(47, 143, 211, 0.16), rgba(47, 143, 211, 0) 68%);
	content: '';
	height: 240px;
	pointer-events: none;
	position: absolute;
	right: -90px;
	top: -100px;
	width: 240px;
}

[dir='rtl'] .safety-support-panel::after {
	left: -90px;
	right: auto;
}

.safety-support-panel__copy {
	align-self: center;
	min-width: 0;
	position: relative;
	z-index: 1;
}

.safety-support-section .safety-section-heading {
	margin-bottom: 18px;
	max-width: 680px;
}

.safety-support-section .safety-section-heading h2 {
	font-size: clamp(1.72rem, 1.35rem + 1.1vw, 2.34rem);
	letter-spacing: 0;
	max-width: 640px;
	text-wrap: balance;
}

.safety-support-section .safety-lead {
	margin: 0;
	max-width: 62ch;
}

.safety-support-section .safety-support-band {
	background: transparent;
	border: 0;
	box-shadow: none;
	margin: 0;
	max-width: none;
	min-width: 0;
	padding: 0;
	position: relative;
	z-index: 1;
}

.safety-support-section .safety-support-band ul {
	counter-reset: safety-support;
	display: grid;
	gap: 12px;
	grid-template-columns: 1fr;
}

.safety-support-section .safety-support-band li {
	align-items: center;
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid rgba(188, 214, 234, 0.74);
	border-radius: 8px;
	color: var(--safety-text);
	counter-increment: safety-support;
	display: grid;
	font-weight: var(--weight-semibold);
	gap: 14px;
	grid-template-columns: 42px minmax(0, 1fr);
	line-height: 1.36;
	min-height: 72px;
	padding: 14px 16px;
}

.safety-support-section .safety-support-band li::before {
	align-items: center;
	background: var(--safety-soft);
	border: 1px solid rgba(23, 105, 170, 0.18);
	border-radius: 999px;
	color: var(--safety-blue);
	content: counter(safety-support, decimal-leading-zero);
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: var(--weight-heading);
	height: 42px;
	justify-content: center;
	letter-spacing: 0.03em;
	width: 42px;
}

.safety-final-cta {
	background: linear-gradient(135deg, #102f4f 0%, #1769aa 100%);
	color: #fff;
	padding: 70px 0;
}

.safety-final-cta-inner {
	max-width: 780px;
	margin: 0 auto;
	text-align: center;
}

.safety-final-cta h2 {
	color: #fff;
}

.safety-final-cta p {
	max-width: 680px;
	margin: 18px auto 0;
	color: rgba(255, 255, 255, 0.86);
	font-size: 1.08rem;
	line-height: 1.7;
}

@media (prefers-reduced-motion: reduce) {
	.safety-btn-primary,
	.safety-btn-secondary {
		transition: none;
	}
}

@media screen and (max-width: 991px) {
	.safety-hero {
		padding-bottom: 58px;
	}

	.safety-hero h1 {
		font-size: 2.35rem;
	}

	.safety-support-panel {
		grid-template-columns: 1fr;
	}

	.safety-check-grid,
	.safety-red-flag-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 767px) {
	.safety-hero {
		padding: 12px 0 48px;
	}

	.safety-breadcrumb {
		margin-bottom: 28px;
	}

	.safety-hero h1 {
		font-size: 2rem;
	}

	.safety-hero-copy,
	.safety-lead,
	.safety-final-cta p {
		font-size: 1rem !important;
	}

	.safety-actions {
		align-items: stretch;
		flex-direction: column;
	}

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

	.safety-trust-list,
	.safety-check-grid,
	.safety-red-flag-grid,
	.safety-quote-grid,
	.safety-step-grid {
		grid-template-columns: 1fr;
	}

	.safety-section,
	.safety-final-cta {
		padding: 52px 0;
	}

	.safety-section-heading h2,
	.safety-final-cta h2 {
		font-size: 1.58rem;
	}

	.safety-card,
	.safety-red-flag,
	.safety-step {
		min-height: auto;
	}

	.safety-support-panel {
		gap: 24px;
		padding: 24px;
	}

	.safety-support-section .safety-section-heading h2 {
		font-size: 1.58rem;
	}

	.safety-support-panel::after {
		height: 180px;
		right: -110px;
		top: -90px;
		width: 180px;
	}

	[dir='rtl'] .safety-support-panel::after {
		left: -110px;
		right: auto;
	}

	.safety-support-band ul {
		display: grid;
		grid-template-columns: 1fr;
	}

	.safety-support-section .safety-support-band li {
		grid-template-columns: 36px minmax(0, 1fr);
		min-height: 64px;
		padding: 12px;
	}

	.safety-support-section .safety-support-band li::before {
		height: 36px;
		width: 36px;
	}
}

/* ─── Enhanced content: inline CTA blocks ──────────────────────────────────── */

.blog-cta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	margin: 36px 0;
	padding: 24px 28px;
	background: #fff;
	border-radius: 10px;
	border: 1px solid #eaeaea;
	border-left-width: 4px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.05);
}

.blog-cta__content {
	flex: 1;
}

.blog-cta__eyebrow {
	font-size: 0.72rem;
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 6px;
	opacity: 0.85;
}

.blog-cta h3 {
	font-size: 1.1rem;
	font-weight: var(--weight-semibold);
	margin-bottom: 8px;
	color: #1a2340;
	line-height: 1.35;
}

.blog-cta p {
	font-size: 0.875rem;
	color: #6c757d;
	margin-bottom: 0;
	line-height: 1.55;
}

.blog-cta__button {
	display: inline-block;
	white-space: nowrap;
	padding: 11px 22px;
	border-radius: 999px;
	font-size: 0.875rem;
	font-weight: var(--weight-semibold);
	text-decoration: none;
	color: #fff;
	transition:
		opacity 0.15s ease,
		transform 0.15s ease;
	flex-shrink: 0;
}

.blog-cta__button:hover {
	opacity: 0.88;
	transform: translateY(-1px);
	color: #fff;
	text-decoration: none;
}

/* Type: consultation (default — primary blue) */
.blog-cta--consultation {
	border-left-color: var(--color-trust-blue);
}
.blog-cta--consultation .blog-cta__eyebrow {
	color: var(--color-trust-blue);
}
.blog-cta--consultation .blog-cta__button {
	background: var(--color-trust-blue);
}

/* Type: cost (amber — financial) */
.blog-cta--cost {
	border-left-color: #e67e22;
}
.blog-cta--cost .blog-cta__eyebrow {
	color: #e67e22;
}
.blog-cta--cost .blog-cta__button {
	background: #e67e22;
}

/* Type: safety (blue — trust) */
.blog-cta--safety {
	border-left-color: #27ae60;
}
.blog-cta--safety .blog-cta__eyebrow {
	color: #27ae60;
}
.blog-cta--safety .blog-cta__button {
	background: #27ae60;
}

/* Type: turkey (navy — destination) */
.blog-cta--turkey {
	border-left-color: #102f4f;
}
.blog-cta--turkey .blog-cta__eyebrow {
	color: #102f4f;
}
.blog-cta--turkey .blog-cta__button {
	background: #102f4f;
}

@media (max-width: 640px) {
	.blog-cta {
		flex-direction: column;
		align-items: flex-start;
		gap: 16px;
		padding: 20px;
	}
	.blog-cta__button {
		width: 100%;
		text-align: center;
	}
}

/* ═══════════════════════════════════════════════════════════════════════════
   ARTICLE LANDING PAGE
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Hero ──────────────────────────────────────────────────────────────── */
.article-hero {
	background: linear-gradient(135deg, #102f4f 0%, #1769aa 100%);
	color: #fff;
	padding: 28px 0 36px;
}

.article-breadcrumb ol {
	display: flex;
	flex-wrap: wrap;
	gap: 4px 6px;
	list-style: none;
	padding: 0;
	margin: 0 0 18px;
	font-size: 13px;
}
.article-breadcrumb li {
	display: flex;
	align-items: center;
	color: rgba(255, 255, 255, 0.65);
}
.article-breadcrumb li + li::before {
	content: '/';
	margin-right: 6px;
	opacity: 0.5;
}
.article-breadcrumb a {
	color: rgba(255, 255, 255, 0.8);
	text-decoration: none;
}
.article-breadcrumb a:hover {
	color: #fff;
}
.article-breadcrumb [aria-current] {
	color: #fff;
}

.article-hero-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
	align-items: center;
}

.article-hero .article-category-badge {
	display: inline-block;
	font-size: 11px;
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.07em;
	background: rgba(255, 255, 255, 0.15);
	color: #fff;
	padding: 3px 10px;
	border-radius: 99px;
	margin-bottom: 10px;
	text-decoration: none;
	transition: background 0.15s;
}
.article-hero .article-category-badge:hover {
	background: rgba(255, 255, 255, 0.25);
}

.article-hero h1 {
	font-size: clamp(22px, 2.8vw, 36px);
	line-height: 1.25;
	font-weight: var(--weight-semibold);
	color: #fff;
	margin-bottom: 12px;
}

.article-hero-summary {
	font-size: 16px;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: 14px;
}

.article-trust-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 16px;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.65);
	margin-bottom: 20px;
}
.article-trust-meta a {
	color: rgba(255, 255, 255, 0.85);
	text-decoration: underline;
}

.article-hero-actions {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px 20px;
}

.article-hero-btn {
	background: #fff;
	color: var(--color-primary);
	border: 1px solid #fff;
	font-weight: var(--weight-semibold);
	border-radius: 99px;
	padding: 10px 24px;
	font-size: 15px;
}
.article-hero-btn:hover {
	background: #eaf5ff;
	color: #102f4f;
	border-color: #eaf5ff;
}
.article-hero-btn:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

.article-hero-actions .social-share {
	margin: 0;
}
.article-hero-actions .social-share li a svg {
	stroke: rgba(255, 255, 255, 0.7);
}
.article-hero-actions .social-share li a:hover svg {
	stroke: #fff;
}

.article-hero-image img {
	width: 100%;
	height: auto;
	max-height: 260px;
	object-fit: cover;
	border-radius: 10px;
	display: block;
}

@media (min-width: 992px) {
	.article-hero-grid:not(.article-hero-grid--no-image) {
		grid-template-columns: 1fr 320px;
	}
}

/* ─── Desktop TOC (position:fixed, JS moves it left of container) ────── */
.article-toc {
	position: fixed;
	top: 80px;
	width: 220px;
	max-height: calc(100vh - 100px);
	overflow-y: auto;
	z-index: 90;
	scrollbar-width: thin;
	/* Hidden until JS confirms space is available; !important beats Bootstrap d-xl-block */
	display: none !important;
}
.article-toc.is-visible {
	display: block !important;
}

.article-toc__inner {
	background: #fff;
	border: 1px solid #eaeaea;
	border-radius: 8px;
	padding: 14px 16px;
}

.article-toc__title {
	font-size: 10px;
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.09em;
	color: #aaa;
	margin: 0 0 10px;
}

.article-toc__list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.article-toc__item--h3 > .article-toc__link {
	padding-left: 20px;
	font-size: 12px;
}

.article-toc__link {
	display: block;
	font-size: 13px;
	color: #555;
	line-height: 1.45;
	padding: 4px 0 4px 8px;
	text-decoration: none;
	border-left: 2px solid transparent;
	transition:
		color 0.15s,
		border-color 0.15s;
}
.article-toc__link:hover {
	color: var(--color-primary);
	border-left-color: #9cc9eb;
}
.article-toc__link:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}
.article-toc__link.is-active {
	color: var(--color-primary);
	font-weight: var(--weight-semibold);
	border-left-color: var(--color-primary);
}

/* ─── Mobile TOC ────────────────────────────────────────────────────────── */
.article-toc-mobile {
	background: #f8f9fa;
	border-bottom: 1px solid #eaeaea;
}

.article-toc-mobile__toggle {
	display: flex;
	align-items: center;
	gap: 8px;
	width: 100%;
	background: none;
	border: none;
	padding: 11px 0;
	font-size: 14px;
	font-weight: var(--weight-semibold);
	color: #333;
	cursor: pointer;
}
.article-toc-mobile__toggle:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}
.article-toc-mobile__toggle svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

.article-toc-mobile__toggle .toc-chevron {
	transition: transform 0.2s ease;
	margin-left: auto;
}
.article-toc-mobile__toggle[aria-expanded='true'] .toc-chevron {
	transform: rotate(180deg);
}

.article-toc-mobile__list {
	display: none;
	padding: 0 0 12px 4px;
}
.article-toc-mobile__list.is-open {
	display: block;
}
.article-toc-mobile__list .article-toc__link {
	padding-left: 0;
	border-left: none;
	color: var(--color-primary);
	font-size: 14px;
}
.article-toc-mobile__list .article-toc__item--h3 > .article-toc__link {
	padding-left: 14px;
	font-size: 13px;
}

/* ─── Article body wrapper ──────────────────────────────────────────────── */
.article-body-wrapper {
	position: relative;
}

/* ─── Right sidebar widgets ─────────────────────────────────────────────── */
.article-sidebar-widget {
	margin-top: 18px;
	background: #fff;
	border: 1px solid #eaeaea;
	border-radius: 8px;
	padding: 16px;
}

.article-sidebar-widget__title {
	font-size: 13px;
	font-weight: var(--weight-semibold);
	color: #333;
	margin: 0 0 12px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.article-sidebar-guides {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.article-sidebar-guide-link {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-size: 13px;
	color: var(--color-primary);
	text-decoration: none;
	line-height: 1.4;
}
.article-sidebar-guide-link svg {
	width: 15px;
	height: 15px;
	flex-shrink: 0;
	margin-top: 2px;
}
.article-sidebar-guide-link:hover {
	color: #102f4f;
}

.article-safety-link {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	font-weight: var(--weight-semibold);
	color: #27ae60;
	text-decoration: none;
}
.article-safety-link svg {
	width: 16px;
	height: 16px;
}
.article-safety-link:hover {
	color: #1a7a44;
}

/* ─── Author trust box ──────────────────────────────────────────────────── */
.article-author-box {
	margin: 32px 0 0;
	padding: 18px 20px;
	background: #f6fbff;
	border: 1px solid #d8e8f5;
	border-radius: 8px;
}
.article-author-box__inner {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
	gap: 12px;
}
.article-author-box__label {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #999;
	margin: 0 0 2px;
}
.article-author-box__name {
	display: block;
	font-size: 14px;
	font-weight: var(--weight-semibold);
	color: var(--color-primary);
	text-decoration: none;
}
.article-author-box__name:hover {
	text-decoration: underline;
}
.article-author-box__date {
	font-size: 12px;
	color: #999;
	margin: 8px 0 0;
}
.article-author-box__links {
	display: flex;
	flex-direction: column;
	gap: 6px;
	align-items: flex-end;
}
.article-author-box__links a {
	font-size: 12px;
	color: #666;
	text-decoration: underline;
}

/* ─── Medical disclaimer ─────────────────────────────────────────────────── */
.article-disclaimer {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	margin: 20px 0 0;
	padding: 13px 16px;
	background: #fffbf2;
	border-left: 3px solid #f0ad4e;
	border-radius: 0 6px 6px 0;
}
.article-disclaimer svg {
	width: 17px;
	height: 17px;
	flex-shrink: 0;
	color: #e5960a;
	margin-top: 2px;
}
.article-disclaimer p {
	font-size: 13px;
	color: #666;
	margin: 0;
	line-height: 1.55;
}

/* ─── Treatment guide cards ──────────────────────────────────────────────── */
.treatment-guide-card {
	background: #fff;
	border: 1px solid #eaeaea;
	border-radius: 8px;
	padding: 20px;
	height: 100%;
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.15s;
}
.treatment-guide-card:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.treatment-guide-card h3 {
	font-size: 15px;
	font-weight: var(--weight-semibold);
	color: #1a1a1a;
	margin-bottom: 8px;
	line-height: 1.35;
}
.treatment-guide-card p {
	font-size: 13px;
	color: #666;
	line-height: 1.5;
	flex: 1;
	margin-bottom: 14px;
}
.treatment-guide-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 13px;
	font-weight: var(--weight-semibold);
	color: var(--color-primary);
	text-decoration: none;
}
.treatment-guide-card__cta svg {
	width: 14px;
	height: 14px;
}
.treatment-guide-card__cta:hover {
	color: #102f4f;
}

/* ─── Final CTA section ──────────────────────────────────────────────────── */
.article-final-cta {
	background: linear-gradient(135deg, #102f4f 0%, var(--color-primary) 100%);
	color: #fff;
	text-align: center;
}
.article-final-cta__inner {
	max-width: 620px;
	margin: 0 auto;
}

.article-final-cta h2 {
	font-size: clamp(20px, 2.5vw, 30px);
	font-weight: var(--weight-semibold);
	color: #fff;
	margin-bottom: 14px;
}
.article-final-cta p {
	font-size: 16px;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: 26px;
	line-height: 1.65;
}
.article-final-cta__actions {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	gap: 14px;
}
.article-final-cta__btn {
	background: #fff;
	color: var(--color-primary);
	border: 1px solid #fff;
	font-weight: var(--weight-semibold);
	border-radius: 99px;
	padding: 12px 28px;
	font-size: 16px;
}
.article-final-cta__btn:hover {
	background: #eaf5ff;
	color: #102f4f;
	border-color: #eaf5ff;
}
.article-final-cta__btn:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.6);
	outline-offset: 2px;
}

.article-final-cta__secondary {
	color: rgba(255, 255, 255, 0.8);
	font-size: 14px;
	text-decoration: underline;
}
.article-final-cta__secondary:hover {
	color: #fff;
}

/* ─── Mobile sticky CTA ──────────────────────────────────────────────────── */
.article-mobile-cta {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 1050;
	transform: translateY(100%);
	transition: transform 0.3s ease;
}
.article-mobile-cta.is-visible {
	transform: translateY(0);
}
.article-mobile-cta.is-dismissed {
	transform: translateY(100%);
}

.article-mobile-cta__inner {
	display: flex;
	align-items: center;
	gap: 10px;
	background: #102f4f;
	color: #fff;
	padding: 13px 16px;
	padding-bottom: calc(13px + env(safe-area-inset-bottom, 0px));
}
.article-mobile-cta__label {
	flex: 1;
	font-size: 14px;
	font-weight: var(--weight-medium);
}
.article-mobile-cta__btn {
	background: #fff !important;
	color: #102f4f !important;
	border: 1px solid #fff !important;
	font-weight: var(--weight-semibold);
	border-radius: 99px;
	padding: 7px 20px;
	font-size: 14px;
	white-space: nowrap;
}
.article-mobile-cta__close {
	background: none;
	border: none;
	padding: 4px;
	cursor: pointer;
	color: rgba(255, 255, 255, 0.7);
	display: flex;
	align-items: center;
}
.article-mobile-cta__close:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.8);
	outline-offset: 2px;
}
.article-mobile-cta__close svg {
	width: 18px;
	height: 18px;
}

/* ─── Responsive adjustments ─────────────────────────────────────────────── */
@media (max-width: 991.98px) {
	.article-hero-image {
		display: none;
	}
}

@media (max-width: 767.98px) {
	.section-with-bg {
		aspect-ratio: auto;
		background:
			linear-gradient(
				145deg,
				rgba(255, 255, 255, 0.98) 0%,
				rgba(245, 251, 255, 0.96) 54%,
				rgba(231, 243, 252, 0.9) 100%
			),
			repeating-linear-gradient(90deg, rgba(23, 105, 170, 0.045) 0 1px, transparent 1px 54px),
			repeating-linear-gradient(0deg, rgba(23, 105, 170, 0.035) 0 1px, transparent 1px 54px) !important;
		color: #1f2937;
		max-height: none;
		min-height: unset;
		overflow: visible;
		padding: 28px 0 22px !important;
	}

	.section-with-bg::before {
		bottom: -30%;
		opacity: 0.52;
		right: -34%;
		top: auto;
		width: 82vw;
		height: 80%;
	}

	.section-with-bg .container {
		bottom: auto;
		left: auto;
		position: relative;
		right: auto;
		top: auto;
	}

	.section-with-bg .row {
		gap: 16px;
	}

	.section-with-bg .container h1 {
		color: var(--color-ink-strong);
		font-size: clamp(2rem, 12vw, 3rem);
		line-height: 1.05;
		margin-bottom: 10px;
		margin-top: 0 !important;
		max-width: 100%;
		overflow-wrap: anywhere;
	}

	.section-with-bg .container p {
		color: #42526a;
		font-size: 1rem;
		line-height: 1.55;
		margin-bottom: 0;
	}

	.section-with-bg .breadcrumb {
		display: flex;
		flex-wrap: nowrap;
		font-size: 0.875rem;
		margin-bottom: 22px;
		max-width: 100%;
		overflow: hidden;
		white-space: nowrap;
	}

	.section-with-bg .breadcrumb-item {
		display: inline-flex;
		flex: 0 0 auto;
		min-width: 0;
	}

	.section-with-bg .breadcrumb-item.active {
		flex: 1 1 auto;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}

	.section-with-bg .tag-list {
		flex-wrap: nowrap;
		gap: 8px;
		margin-top: 2px !important;
		max-width: calc(100vw - 30px);
		overflow-x: auto;
		padding-bottom: 2px;
		scrollbar-width: none;
		-webkit-overflow-scrolling: touch;
	}

	.section-with-bg .tag-list::-webkit-scrollbar {
		display: none;
	}

	.section-with-bg .tag-list li {
		background: #fff;
		border-color: #d4e4fa;
		box-shadow: 0 1px 2px rgba(16, 47, 79, 0.05);
		flex: 0 0 auto;
		font-weight: var(--weight-heading);
		height: 34px;
		padding: 0.25rem 0.875rem;
	}

	.sticky-navbar {
		background: rgba(255, 255, 255, 0.85);
		border-bottom: 1px solid rgba(0, 0, 0, 0.05);
		box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
		display: block;
		overflow: visible;
		backdrop-filter: blur(16px);
		-webkit-backdrop-filter: blur(16px);
	}

	.sticky-navbar .container {
		max-width: 100%;
		padding-left: 0;
		padding-right: 0;
	}

	.sticky-navbar .stick-navbar-items {
		display: block !important;
		width: 100%;
	}

	.sticky-navbar .nav {
		display: flex;
		flex-wrap: nowrap;
		gap: 6px;
		margin: 0;
		overflow-x: auto;
		overflow-y: visible;
		padding: 10px 16px 10px 16px;
		scrollbar-width: none;
		scroll-snap-type: x proximity;
		-webkit-overflow-scrolling: touch;
	}

	.sticky-navbar .nav::-webkit-scrollbar {
		display: none;
	}

	.sticky-navbar .nav .nav-item {
		flex: 0 0 auto;
		padding: 0;
		scroll-snap-align: start;
	}

	.sticky-navbar .nav .nav-item .nav-link {
		align-items: center;
		background: rgba(255, 255, 255, 0.9);
		border: 1px solid rgba(0, 0, 0, 0.06);
		border-radius: 999px;
		box-shadow: 0 2px 6px rgba(0, 0, 0, 0.03);
		color: #4a5568;
		display: inline-flex;
		font-size: 0.925rem;
		font-weight: 500;
		gap: 6px;
		min-height: 40px;
		padding: 0.5rem 1rem;
		transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
	}

	.sticky-navbar .nav .nav-item .nav-link:hover,
	.sticky-navbar .nav .nav-item .nav-link.active,
	.sticky-navbar .nav .nav-item .nav-link[aria-expanded='true'] {
		background: var(--color-primary);
		border-color: var(--color-primary);
		color: #fff !important;
		text-decoration: none;
		box-shadow: 0 4px 12px rgba(23, 105, 170, 0.25);
	}

	.sticky-navbar .dropdown-toggle svg {
		height: 16px;
		width: 16px;
	}

	.sticky-navbar .nav .nav-item .dropdown-menu.show {
		border: 1px solid rgba(0, 0, 0, 0.06);
		border-radius: 12px;
		box-shadow: 0 14px 40px rgba(0, 0, 0, 0.12);
		left: 16px !important;
		margin-top: 8px;
		max-height: 55vh;
		overflow-y: auto;
		position: absolute;
		right: 16px !important;
		top: calc(100% - 2px) !important;
		transform: none !important;
		width: auto;
		background: rgba(255, 255, 255, 0.95);
		backdrop-filter: blur(16px);
		-webkit-backdrop-filter: blur(16px);
	}

	.sticky-navbar .nav .nav-item .dropdown-menu .dropdown-item {
		font-size: 0.925rem;
		line-height: 1.35;
		padding: 0.8rem 1rem;
		white-space: normal;
		color: #4a5568 !important;
		transition: all 0.2s ease;
	}

	.sticky-navbar .nav .nav-item .dropdown-menu .dropdown-item:hover {
		color: var(--color-primary) !important;
		background: rgba(23, 105, 170, 0.06) !important;
		text-decoration: none;
	}

	.article-breadcrumb {
		max-width: 100%;
		overflow: hidden;
	}

	.article-breadcrumb ol {
		flex-wrap: nowrap;
		max-width: 100%;
		overflow: hidden;
	}

	.article-breadcrumb li {
		flex: 0 0 auto;
		max-width: 100%;
		min-width: 0;
	}

	.article-breadcrumb a,
	.article-breadcrumb li span {
		white-space: nowrap;
	}

	.article-breadcrumb [aria-current] {
		flex: 1 1 auto;
		min-width: 0;
	}

	.article-breadcrumb [aria-current] span {
		display: block;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}

	.article-author-box__inner {
		flex-direction: column;
	}
	.article-author-box__links {
		align-items: flex-start;
	}
}

/* Hide mobile CTA on xl+ where sidebar is always visible */
@media (min-width: 1200px) {
	.article-mobile-cta {
		display: none !important;
	}
}

/* ─── Sidebar CTA card ───────────────────────────────────────────────────── */
.sidebar-cta-card {
	background: rgba(255, 255, 255, 0.72);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid rgba(148, 163, 184, 0.22);
	border-radius: 24px;
	box-shadow:
		0 6px 22px rgba(15, 23, 42, 0.045),
		inset 0 0 0 1px rgba(255, 255, 255, 0.45);
	color: var(--color-body);
	margin-bottom: 16px;
	overflow: hidden;
	padding: 24px 22px 20px;
	position: relative;
	transition:
		transform 0.35s cubic-bezier(0.16, 1, 0.3, 1),
		box-shadow 0.35s cubic-bezier(0.16, 1, 0.3, 1),
		border-color 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

.sidebar-cta-card::before {
	background: linear-gradient(135deg, rgba(239, 246, 255, 0.64) 0%, rgba(255, 255, 255, 0.08) 100%);
	content: '';
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 0;
}

.sidebar-cta-card:hover {
	border-color: rgba(59, 130, 246, 0.2);
	box-shadow:
		0 12px 28px rgba(15, 23, 42, 0.07),
		inset 0 0 0 1px rgba(255, 255, 255, 0.55);
	transform: translateY(-4px);
}

.sidebar-cta-card > * {
	position: relative;
	z-index: 1;
}

.sidebar-cta-card > img {
	aspect-ratio: 1.28;
	border: 1px solid rgba(148, 163, 184, 0.14);
	border-radius: 18px;
	box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
	display: block;
	margin-bottom: 18px !important;
	object-fit: cover;
	width: 100%;
}

.sidebar-cta-card__label {
	display: inline-block;
	font-size: 10px;
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	background: rgba(255, 255, 255, 0.15);
	color: rgba(255, 255, 255, 0.9);
	padding: 3px 9px;
	border-radius: 99px;
	margin-bottom: 12px;
}

.sidebar-cta-card__title {
	color: var(--color-ink-strong) !important;
	font-size: 1.32rem !important;
	font-weight: var(--weight-heading) !important;
	letter-spacing: -0.02em;
	line-height: 1.16 !important;
	margin: 0 0 16px !important;
}

.sidebar-cta-card__bullets {
	background: rgba(255, 255, 255, 0.54);
	border: 1px solid rgba(148, 163, 184, 0.16);
	border-radius: 18px;
	list-style: none;
	margin: 0 0 18px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 16px;
}

.sidebar-cta-card__bullets li {
	display: flex;
	align-items: flex-start;
	color: var(--color-body);
	font-size: 0.95rem;
	gap: 10px;
	line-height: 1.45;
}

.sidebar-cta-card__bullets svg {
	background: rgba(37, 99, 235, 0.1);
	border-radius: 999px;
	flex-shrink: 0;
	height: 18px;
	margin-top: 1px;
	padding: 2px;
	stroke: var(--color-primary);
	width: 18px;
}

.sidebar-cta-card__btn {
	display: block;
	width: 100%;
	text-align: center;
	background: var(--color-primary);
	border: 1px solid var(--color-primary);
	border-radius: 12px;
	box-shadow: 0 4px 12px rgba(23, 105, 170, 0.18);
	color: #fff;
	font-size: 1rem;
	font-weight: 600;
	padding: 14px 18px;
	text-decoration: none;
	transition:
		transform 0.3s ease,
		box-shadow 0.3s ease,
		background 0.3s ease;
	margin-bottom: 14px;
}
.sidebar-cta-card__btn:hover {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	box-shadow: 0 8px 20px rgba(16, 47, 79, 0.22);
	color: #fff;
	text-decoration: none;
	transform: translateY(-2px);
}
.sidebar-cta-card__btn:focus-visible {
	outline: none;
	box-shadow:
		0 0 0 4px rgba(37, 99, 235, 0.1),
		0 8px 20px rgba(37, 99, 235, 0.24);
}

.sidebar-cta-card__footer {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	font-size: 0.8rem;
	color: var(--color-muted);
	margin: 0;
	opacity: 0.8;
	padding-top: 2px;
}
.sidebar-cta-card__footer svg {
	height: 12px;
	stroke: var(--color-primary);
	width: 12px;
}

/* Public cleanup utilities: replaces one-off inline styles in templates. */
.footer-primary-list {
	gap: 10px;
}

.image-404 {
	width: 200px;
}

.icon-sm-primary {
	width: 16px;
	height: 16px;
	color: #102f4f;
	flex-shrink: 0;
}

.icon-md-primary {
	width: 24px;
	height: 24px;
	color: #102f4f;
	flex-shrink: 0;
}

.icon-xs-primary {
	width: 14px;
	height: 14px;
	color: #102f4f;
	flex-shrink: 0;
}

.icon-inline-xs {
	width: 14px;
	height: 14px;
	color: #102f4f;
	margin-right: 4px;
	vertical-align: middle;
}

.hero-primary-button {
	background: linear-gradient(135deg, var(--color-primary) 0%, #102f4f 100%);
	color: #fff;
	border: 1px solid var(--color-primary);
	transition:
		background 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease,
		color 0.18s ease,
		transform 0.18s ease;
}

.hero-primary-button:hover,
.hero-primary-button:focus {
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary) 100%);
	border-color: var(--color-primary);
	color: #fff;
	text-decoration: none;
	transform: translateY(-1px);
	box-shadow: 0 14px 28px rgba(23, 105, 170, 0.2) !important;
}

.hero-primary-button:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.28);
	outline-offset: 3px;
}

.cta-light-button {
	background: #fff;
	color: #102f4f;
	border: none;
}

/* --- Hero content column (aligned against media panel) --- */
.hero__content {
	--hero-cta-row-width: 690px;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	height: 100%;
	min-height: 100%;
	padding: 28px 0 28px;
}

/* --- Hero eyebrow / authorization chip --- */
.hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	align-self: flex-start;
	min-height: 40px;
	margin-bottom: 16px;
	padding: 7px 14px;
	border: 1px solid rgba(23, 105, 170, 0.22);
	border-radius: 999px;
	background: var(--color-primary-soft);
	font-size: 0.78rem;
	font-weight: var(--weight-semibold);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--color-primary);
	text-decoration: none;
	transition:
		background 0.18s ease,
		border-color 0.18s ease,
		color 0.18s ease;
}

.hero__eyebrow svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

.hero__eyebrow:hover,
.hero__eyebrow:focus {
	background: #dff6f0;
	border-color: var(--color-primary);
	color: var(--color-primary-dark);
	text-decoration: none;
}

.hero__eyebrow:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.28);
	outline-offset: 3px;
}

/* --- Hero lead paragraph --- */
.hero__lead {
	max-width: 56ch;
	margin: 16px 0 28px;
	font-size: 1.05rem;
	line-height: 1.65;
	color: #5f7184;
}

/* --- Hero CTA group --- */
.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	align-items: center;
	width: min(100%, var(--hero-cta-row-width));
	margin-top: auto;
}

.hero__actions .hero-primary-button,
.hero__actions .hero-secondary-button {
	font-weight: var(--weight-medium);
}

/* --- Secondary CTA (mirrors .hero-primary-button pattern) --- */
.hero-secondary-button {
	min-height: 48px;
	background: #fff;
	color: var(--color-primary);
	border: 1px solid var(--color-primary);
	transition:
		background 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease,
		color 0.18s ease,
		transform 0.18s ease;
}

.hero-secondary-button:hover,
.hero-secondary-button:focus {
	background: var(--color-primary-soft);
	border-color: var(--color-primary-dark);
	color: var(--color-primary-dark);
	text-decoration: none;
	transform: translateY(-1px);
}

.hero-secondary-button:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.28);
	outline-offset: 3px;
}

/* --- CTA microcopy --- */
.hero__microcopy {
	margin: 18px 0 0;
	padding-left: 0;
	font-size: 0.85rem;
	line-height: 1.55;
	color: rgba(16, 47, 79, 0.7);
}

/* --- Assurance zone (trust bullets + role disclosure) --- */
.hero__assurance {
	margin-top: 26px;
	padding-top: 22px;
	position: relative;
	width: min(100%, var(--hero-cta-row-width));
}

.hero__assurance::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background: rgba(16, 47, 79, 0.1);
}

/* --- Intermediary role disclosure (quiet compliance note) --- */
.hero__role-disclosure {
	max-width: 62ch;
	margin: 14px 0 0;
	padding-left: 14px;
	border-left: 3px solid var(--color-primary);
	font-size: 0.82rem;
	line-height: 1.6;
	color: rgba(16, 47, 79, 0.66);
}

.main-homepage .main-slider-content .hero__lead {
	color: var(--color-muted);
	font-size: 1.05rem;
	line-height: 1.65;
}

.main-homepage .main-slider-content .hero__microcopy {
	color: var(--color-muted);
	font-size: 0.85rem;
	line-height: 1.55;
}

.main-homepage .main-slider-content .hero__role-disclosure {
	color: var(--color-muted);
	font-size: 0.82rem;
	line-height: 1.6;
}

/* --- Hero media panel --- */
.hero__media {
	position: relative;
	display: flex;
	align-items: stretch;
	height: 100%;
	min-height: 460px;
	margin: 0;
}

.hero__review-panel {
	position: relative;
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 460px;
	padding: 26px;
	overflow: hidden;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 251, 255, 0.98) 100%),
		repeating-linear-gradient(135deg, rgba(23, 105, 170, 0.08) 0 1px, transparent 1px 14px);
	border: 1px solid var(--color-line-soft);
	border-radius: 8px;
	box-shadow: 0 14px 32px rgba(16, 47, 79, 0.09);
	color: var(--color-body);
}

.hero__review-panel::before {
	content: '';
	position: absolute;
	inset: 0 0 auto;
	height: 5px;
	background: linear-gradient(
		90deg,
		var(--color-primary) 0%,
		var(--color-primary) 44%,
		#1f9d72 44%,
		#1f9d72 72%,
		#d7a928 72%,
		#d7a928 100%
	);
}

.hero__review-panel::after {
	content: '';
	position: absolute;
	inset: 5px 0 0;
	pointer-events: none;
	background-image:
		linear-gradient(rgba(23, 105, 170, 0.06) 1px, transparent 1px),
		linear-gradient(90deg, rgba(23, 105, 170, 0.06) 1px, transparent 1px);
	background-size: 36px 36px;
	-webkit-mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.24), transparent 46%);
	mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.24), transparent 46%);
}

.hero__review-header,
.hero__review-title,
.hero__review-copy,
.hero__review-list,
.hero__review-summary,
.hero__review-meta,
.hero__review-form,
.hero__cred-card {
	position: relative;
	z-index: 1;
}

.hero__review-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 22px;
}

.hero__review-kicker {
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	border-radius: 999px;
	font-size: 0.76rem;
	font-weight: var(--weight-semibold);
	line-height: 1;
	white-space: nowrap;
}

.hero__review-kicker {
	padding: 8px 12px;
	background: var(--color-primary-soft);
	border: 1px solid #cfe5f8;
	color: var(--color-primary-dark);
}

.hero__review-title {
	max-width: 12ch;
	margin: 0;
	font-size: 1.65rem;
	font-weight: var(--weight-semibold);
	line-height: 1.12;
	color: var(--color-ink-strong);
}

.main-homepage .main-slider-content .hero__review-copy {
	max-width: 34ch;
	margin: 12px 0 22px;
	font-size: 0.94rem;
	line-height: 1.5;
	color: var(--color-muted);
}

.hero__review-panel--form {
	min-height: 0;
	padding: 36px 32px;
	background: rgba(255, 255, 255, 0.88);
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
	border: 1px solid rgba(255, 255, 255, 0.6);
	border-radius: 20px;
	box-shadow:
		0 4px 6px -1px rgba(0, 0, 0, 0.05),
		0 20px 40px -4px rgba(16, 47, 79, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.hero__review-panel--form::before {
	content: none;
}

.hero__review-panel--form::after {
	content: none;
}

.hero__review-panel--form .hero__review-header {
	margin-bottom: 18px;
}

.hero__review-panel--form .hero__review-kicker {
	padding: 6px 12px;
	background: rgba(23, 105, 170, 0.06);
	border: 1px solid rgba(23, 105, 170, 0.12);
	border-radius: 30px;
	color: var(--color-primary);
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.hero__review-panel--form .hero__review-title {
	max-width: none;
	font-size: 1.6rem;
	font-weight: 700;
	color: #0c2340;
	letter-spacing: -0.02em;
	line-height: 1.25;
}

.hero__review-panel--form .hero__review-copy {
	max-width: none;
	margin-bottom: 20px;
	font-size: 0.92rem;
	line-height: 1.5;
	color: #64748b;
}

.main-homepage .main-slider-content .hero__review-panel--form .hero__review-copy {
	max-width: none;
	margin-bottom: 20px;
	font-size: 0.92rem;
	line-height: 1.5;
	color: #64748b;
}

.hero__review-form {
	display: grid;
	gap: 16px;
}

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

.hero__form-field {
	display: grid;
	gap: 6px;
	min-width: 0;
}

.hero__form-field label {
	margin: 0 0 2px 2px;
	color: #475569;
	font-size: 0.8rem;
	font-weight: 600;
	line-height: 1.2;
	text-transform: none;
	letter-spacing: -0.01em;
}

.hero__review-form .form-control {
	width: 100%;
	min-height: 52px;
	padding: 12px 16px;
	background: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 12px;
	box-shadow: none;
	color: var(--color-ink-strong);
	font-size: 0.95rem;
	font-weight: 500;
	line-height: 1.4;
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.hero__review-form textarea.form-control {
	height: 100px !important;
	min-height: 100px;
	max-height: 100px;
	overflow-x: hidden;
	overflow-y: auto;
	padding-right: 18px;
	resize: none;
	scrollbar-color: rgba(23, 105, 170, 0.42) transparent;
	scrollbar-gutter: stable;
	scrollbar-width: thin;
}

.hero__review-form textarea.form-control::-webkit-scrollbar {
	width: 8px;
}

.hero__review-form textarea.form-control::-webkit-scrollbar-track {
	background: transparent;
	border-radius: 999px;
	margin: 11px 0;
}

.hero__review-form textarea.form-control::-webkit-scrollbar-thumb {
	background: rgba(23, 105, 170, 0.34);
	border: 2px solid #ffffff;
	border-radius: 999px;
	min-height: 28px;
}

.hero__review-form textarea.form-control::-webkit-scrollbar-thumb:hover {
	background: rgba(23, 105, 170, 0.52);
}

.hero__review-form .form-control::placeholder {
	color: #94a3b8;
}

.hero__review-form .form-control:hover {
	border-color: #cbd5e1;
}

.hero__review-form .form-control:focus {
	background: #ffffff;
	border-color: var(--color-primary);
	box-shadow:
		0 0 0 4px rgba(23, 105, 170, 0.08),
		0 4px 12px rgba(23, 105, 170, 0.04);
	outline: none;
}

.hero__review-form .iti {
	width: 100%;
}

.hero__review-form .iti__selected-flag {
	border-radius: 8px 0 0 8px;
}

.hero__review-form .iti__selected-country,
.hero__review-form .iti__selected-country-primary {
	border-radius: 8px 0 0 8px;
	transition:
		background-color 0.16s ease,
		box-shadow 0.16s ease;
}

.hero__review-form .iti__selected-country {
	padding-right: 8px;
}

.hero__review-form .iti__selected-country-primary {
	padding-right: 12px;
}

.hero__review-form .iti__country-container:hover .iti__selected-country,
.hero__review-form .iti__selected-country:hover,
.hero__review-form .iti__selected-country:focus-visible {
	background: rgba(23, 105, 170, 0.035) !important;
	box-shadow: inset 0 0 0 1px rgba(23, 105, 170, 0.16) !important;
}

.hero__review-form .iti--allow-dropdown .iti__country-container:not(:has(+ input[disabled])):not(:has(+ input[readonly])):hover .iti__selected-country-primary,
.hero__review-form .iti--allow-dropdown .iti__country-container:not(:has(+ input[disabled])):not(:has(+ input[readonly])) .iti__selected-country-primary:hover,
.hero__review-form .iti__selected-country:hover .iti__selected-country-primary,
.hero__review-form .iti__selected-country:focus-visible .iti__selected-country-primary {
	background: transparent !important;
	box-shadow: none !important;
}

.hero__form-status {
	min-height: 0;
	margin: 0;
	font-size: 0.84rem;
}

.hero__form-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	min-height: 52px;
	padding: 14px 20px;
	background: linear-gradient(135deg, var(--color-primary) 0%, #0c2340 100%);
	border: none;
	border-radius: 12px;
	box-shadow: 0 4px 12px rgba(23, 105, 170, 0.2);
	color: #fff;
	font-size: 1rem;
	font-weight: var(--weight-bold);
	line-height: 1;
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.hero__form-submit:hover,
.hero__form-submit:focus {
	background: linear-gradient(135deg, var(--color-primary) 20%, #0c2340 100%);
	box-shadow: 0 8px 20px rgba(23, 105, 170, 0.3);
	color: #fff;
	transform: translateY(-2px);
	text-decoration: none;
}

.hero__form-submit:active {
	transform: translateY(0);
}

.hero__form-submit:disabled {
	cursor: wait;
	opacity: 0.78;
	transform: none;
	box-shadow: none;
}

.hero__form-submit svg {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.hero__form-submit:hover svg,
.hero__form-submit:focus svg {
	transform: translateX(4px);
}

.hero__review-list {
	display: grid;
	gap: 10px;
	margin-bottom: 16px;
}

.hero__review-item {
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr);
	align-items: center;
	gap: 12px;
	width: 100%;
	min-height: 66px;
	padding: 11px 12px;
	background: rgba(255, 255, 255, 0.86);
	border: 1px solid rgba(216, 232, 245, 0.9);
	border-radius: 8px;
	box-shadow: 0 12px 24px rgba(16, 47, 79, 0.06);
}

.hero__review-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	background: var(--color-primary-soft);
	border: 1px solid #cfe5f8;
	border-radius: 8px;
	color: var(--color-primary);
}

.hero__review-icon svg {
	width: 20px;
	height: 20px;
}

.hero__review-item-text {
	display: flex;
	flex-direction: column;
	min-width: 0;
	line-height: 1.25;
}

.hero__review-item-text strong {
	font-size: 0.92rem;
	font-weight: var(--weight-semibold);
	color: var(--color-ink-strong);
}

.hero__review-item-text span {
	margin-top: 3px;
	font-size: 0.8rem;
	color: var(--color-muted);
}

.hero__review-summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin-top: 2px;
	padding: 14px;
	background: #102f4f;
	border-radius: 8px;
	color: #fff;
}

.hero__review-summary div {
	min-width: 0;
}

.hero__review-summary-label {
	display: block;
	margin-bottom: 3px;
	font-size: 0.76rem;
	line-height: 1.2;
	color: rgba(255, 255, 255, 0.72);
}

.hero__review-summary strong {
	display: block;
	font-size: 0.98rem;
	line-height: 1.25;
}

.hero__review-summary-step {
	flex-shrink: 0;
	padding: 6px 10px;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	font-size: 0.78rem;
	font-weight: var(--weight-semibold);
	line-height: 1;
}

.hero__review-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin: 20px 0;
	padding-left: 2px;
	padding-right: 2px;
}

.hero__review-meta span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: auto;
	padding: 0;
	background: transparent;
	border: none;
	border-radius: 0;
	color: #475569;
	font-size: 0.78rem;
	font-weight: 500;
	line-height: 1.2;
}

.hero__review-meta svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

.hero__review-meta span:nth-child(1) svg {
	color: #10b981;
}

.hero__review-meta span:nth-child(2) svg {
	color: #3b82f6;
}

.hero__review-meta span:nth-child(3) svg {
	color: #ef4444;
}

.hero__review-meta--form {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 20px;
	padding: 0 1px;
}

.hero__review-meta--form span {
	justify-content: center;
	padding-inline: 1px;
	text-align: center;
}

/* --- Hero signature: credential card --- */
.hero__cred-card {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	width: 100%;
	margin-top: auto;
	padding: 12px 16px;
	background: rgba(255, 255, 255, 0.7);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(226, 232, 240, 0.8);
	border-radius: 12px;
	box-shadow: 0 10px 20px rgba(16, 47, 79, 0.04);
	text-decoration: none;
	color: var(--color-primary-dark);
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.hero__cred-card svg {
	width: 24px;
	height: 24px;
	color: var(--color-primary);
	flex-shrink: 0;
}

.hero__cred-card-text {
	display: flex;
	flex-direction: column;
	line-height: 1.3;
}

.hero__cred-card-text strong {
	font-size: 0.88rem;
	font-weight: 600;
	color: #0f172a;
}

.hero__cred-card-text span {
	font-size: 0.76rem;
	color: #64748b;
}

.hero__cred-card:hover,
.hero__cred-card:focus {
	transform: translateY(-2px);
	box-shadow: 0 12px 24px rgba(16, 47, 79, 0.08);
	border-color: rgba(203, 213, 225, 0.9);
	color: var(--color-primary-dark);
	text-decoration: none;
}

.hero__cred-card:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.4);
	outline-offset: 3px;
}

@media (max-width: 767px) {
	.hero__content {
		height: auto;
	}

	.hero__media {
		min-height: 0;
		margin-top: 28px;
	}

	.hero__review-panel {
		min-height: 0;
		padding: 20px;
	}

	.hero__review-header {
		align-items: flex-start;
		flex-direction: column;
		gap: 10px;
		margin-bottom: 16px;
	}

	.hero__review-title,
	.hero__review-panel--form .hero__review-title {
		max-width: none;
		font-size: 1.38rem;
	}

	.main-homepage .main-slider-content .hero__review-copy {
		max-width: none;
	}

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

	.hero__review-meta {
		grid-template-columns: 1fr;
	}

	.hero__actions {
		flex-direction: column;
		align-items: stretch;
	}

	.hero__microcopy {
		padding-left: 0;
	}

	.hero__actions .hero-primary-button,
	.hero__actions .hero-secondary-button {
		width: 100%;
		text-align: center;
	}
}

@media (min-width: 768px) and (max-width: 991px) {
	.hero__form-grid {
		grid-template-columns: 1fr;
	}

	.hero__review-meta {
		grid-template-columns: 1fr;
	}
}

.homepage-about-snapshot {
	background: #fff;
	border-bottom: 1px solid rgba(16, 47, 79, 0.08);
	padding: clamp(64px, 7vw, 108px) 0 clamp(58px, 6vw, 94px);
}

.homepage-about-snapshot__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(520px, 0.92fr);
	gap: clamp(40px, 7vw, 104px);
	align-items: center;
}

.homepage-about-snapshot__content {
	max-width: 720px;
}

.homepage-about-snapshot__label {
	display: inline-flex;
	margin-bottom: 18px;
	color: var(--color-primary);
	font-size: 0.9rem;
	font-weight: var(--weight-heading);
	line-height: 1.2;
	letter-spacing: 0;
	text-transform: uppercase;
}

.homepage-about-snapshot h2 {
	max-width: 620px;
	margin: 0 0 24px;
	color: var(--color-ink-strong);
	font-size: var(--text-section-title);
	font-weight: var(--weight-display);
	line-height: 1.08;
	letter-spacing: 0;
}

.homepage-about-snapshot p {
	max-width: 66ch;
	margin: 0 0 20px;
	color: #162536;
	font-size: 1.12rem;
	line-height: 1.42;
}

.homepage-about-snapshot__stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0;
	margin-top: clamp(42px, 5vw, 72px);
	overflow: hidden;
	background: linear-gradient(
		135deg,
		rgba(234, 245, 255, 0.82) 0%,
		rgba(255, 255, 255, 0.98) 46%,
		rgba(246, 251, 255, 0.96) 100%
	);
	border: 1px solid rgba(216, 232, 245, 0.95);
	border-radius: 8px;
	box-shadow: 0 18px 42px rgba(16, 47, 79, 0.07);
	color: #07192c;
}

.homepage-about-snapshot__stat {
	position: relative;
	display: flex;
	min-height: 112px;
	min-width: 0;
	flex-direction: column;
	justify-content: center;
	padding: 24px clamp(20px, 2.2vw, 30px);
	background: transparent;
}

.homepage-about-snapshot__stat + .homepage-about-snapshot__stat::before {
	content: '';
	position: absolute;
	top: 24px;
	bottom: 24px;
	left: 0;
	width: 1px;
	background: linear-gradient(
		180deg,
		rgba(216, 232, 245, 0),
		rgba(23, 105, 170, 0.24),
		rgba(216, 232, 245, 0)
	);
}

.homepage-about-snapshot__stat strong {
	display: block;
	color: var(--color-ink-strong);
	font-size: clamp(1.2rem, 0.98rem + 0.45vw, 1.42rem);
	font-weight: var(--weight-semibold);
	line-height: 1.08;
	white-space: nowrap;
}

.homepage-about-snapshot__stat span {
	display: block;
	margin-top: 7px;
	color: var(--color-muted);
	font-size: 0.99rem;
	font-weight: var(--weight-medium);
	line-height: 1.2;
}

.homepage-about-snapshot__media {
	position: relative;
	min-height: 420px;
	max-width: 720px;
	margin-left: auto;
}

.homepage-about-snapshot__image {
	margin: 0;
	overflow: hidden;
	background: var(--color-surface-soft);
	border: 1px solid rgba(216, 232, 245, 0.9);
	border-radius: 8px;
	box-shadow: 0 18px 44px rgba(16, 47, 79, 0.12);
}

.homepage-about-snapshot__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.homepage-about-snapshot__image--main {
	width: calc(100% - 88px);
	height: 368px;
	margin-left: 88px;
}

.homepage-about-snapshot__image--main img {
	object-position: center;
}

.homepage-about-snapshot__image--accent {
	position: absolute;
	top: 52px;
	left: -28px;
	width: 256px;
	height: 306px;
	box-shadow: 0 20px 46px rgba(16, 47, 79, 0.18);
}

.homepage-about-snapshot__image--accent img {
	object-position: center;
}

.homepage-about-snapshot__credential {
	position: absolute;
	right: 24px;
	bottom: 22px;
	display: inline-flex;
	align-items: center;
	gap: 9px;
	max-width: 270px;
	min-height: 48px;
	padding: 10px 14px;
	background: rgba(255, 255, 255, 0.94);
	border: 1px solid var(--color-line-soft);
	border-radius: 8px;
	box-shadow: 0 14px 32px rgba(16, 47, 79, 0.13);
	color: var(--color-primary-dark);
	font-size: 0.86rem;
	font-weight: var(--weight-semibold);
	line-height: 1.15;
	text-decoration: none;
}

.homepage-about-snapshot__credential:hover,
.homepage-about-snapshot__credential:focus {
	color: var(--color-primary-dark);
	text-decoration: none;
	transform: translateY(-1px);
}

.homepage-about-snapshot__credential:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.28);
	outline-offset: 3px;
}

.homepage-about-snapshot__credential svg {
	width: 18px;
	height: 18px;
	flex: 0 0 auto;
	color: var(--color-primary);
}

@media screen and (max-width: 1199px) {
	.homepage-about-snapshot__grid {
		grid-template-columns: minmax(0, 1fr) minmax(360px, 0.88fr);
	}

	.homepage-about-snapshot__stats {
		grid-template-columns: 1fr;
		margin-top: 36px;
	}

	.homepage-about-snapshot__stat {
		min-height: 88px;
	}

	.homepage-about-snapshot__stat + .homepage-about-snapshot__stat::before {
		top: 0;
		right: 24px;
		bottom: auto;
		left: 24px;
		width: auto;
		height: 1px;
		background: linear-gradient(
			90deg,
			rgba(216, 232, 245, 0),
			rgba(23, 105, 170, 0.2),
			rgba(216, 232, 245, 0)
		);
	}
}

@media screen and (max-width: 991px) {
	.homepage-about-snapshot {
		padding: 56px 0 62px;
	}

	.homepage-about-snapshot__grid {
		grid-template-columns: 1fr;
		gap: 38px;
	}

	.homepage-about-snapshot__content {
		max-width: none;
	}

	.homepage-about-snapshot h2 {
		max-width: 15ch;
	}

	.homepage-about-snapshot p {
		font-size: 1.04rem;
	}

	.homepage-about-snapshot__media {
		max-width: 620px;
		margin: 0;
	}
}

@media screen and (max-width: 575px) {
	.homepage-about-snapshot {
		padding: 44px 0 48px;
	}

	.homepage-about-snapshot h2 {
		max-width: none;
		line-height: 1.12;
	}

	.homepage-about-snapshot__stats {
		margin-top: 30px;
	}

	.homepage-about-snapshot__stat strong {
		font-size: 1.18rem;
	}

	.homepage-about-snapshot__stat span {
		font-size: 0.96rem;
	}

	.homepage-about-snapshot__media {
		min-height: 0;
	}

	.homepage-about-snapshot__image--main {
		width: 100%;
		height: auto;
		aspect-ratio: 4 / 3;
		margin-left: 0;
	}

	.homepage-about-snapshot__image--accent {
		position: relative;
		top: auto;
		left: auto;
		width: 72%;
		height: auto;
		aspect-ratio: 4 / 3;
		margin: -64px 0 0 0;
	}

	.homepage-about-snapshot__credential {
		position: relative;
		right: auto;
		bottom: auto;
		width: 100%;
		max-width: none;
		margin-top: 14px;
	}
}

/* --- Authorization page: TURSAB verification --- */
.credential-verify {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 24px;
	padding: 24px;
	margin-bottom: 40px;
	background: var(--color-primary-soft);
	border-radius: 16px;
}

.credential-verify__badge {
	height: auto;
	flex-shrink: 0;
}

.credential-verify__badge-link {
	display: inline-flex;
	border-radius: 10px;
	flex-shrink: 0;
}

.credential-verify__badge-link:focus-visible {
	outline: 3px solid rgba(9, 131, 122, 0.35);
	outline-offset: 4px;
}

.credential-verify__body {
	flex: 1 1 320px;
}

.credential-verify__title {
	font-size: 1.25rem;
	font-weight: var(--weight-semibold);
	color: var(--color-primary-dark);
	margin-bottom: 8px;
}

.credential-verify__text {
	color: #5f7184;
	margin-bottom: 16px;
}

/* --- Authorization page: certificate grid --- */
.credential-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 28px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.credential-card {
	display: flex;
	flex-direction: column;
}

.credential-card__media {
	align-items: center;
	display: flex;
	border: 1px solid rgba(16, 47, 79, 0.12);
	border-radius: 12px;
	aspect-ratio: 16 / 11;
	justify-content: center;
	overflow: hidden;
	background: #fff;
	padding: 6px;
}

.credential-card__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.credential-card__media:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.28);
	outline-offset: 3px;
}

.credential-card__title {
	font-size: 1.05rem;
	font-weight: var(--weight-semibold);
	color: var(--color-primary-dark);
	margin: 14px 0 6px;
}

.credential-card__desc {
	font-size: 0.9rem;
	color: #5f7184;
	margin-bottom: 0;
}

.homepage-social-proof {
	background: var(--color-surface-warm);
	border-bottom-color: rgba(16, 47, 79, 0.08) !important;
	overflow: hidden;
}

.main-homepage .main-slider .homepage-social-proof {
	position: relative;
	z-index: 3;
	background: transparent;
	border-bottom: 0 !important;
}

.main-homepage .main-slider .homepage-social-proof__logo-link:hover,
.main-homepage .main-slider .homepage-social-proof__logo-link:focus {
	background: transparent;
}

.homepage-social-proof__partners {
	margin-top: 0;
}

.homepage-social-proof__marquee {
	--partner-logo-gap: 28px;
	display: flex;
	gap: var(--partner-logo-gap);
	margin-inline: auto;
	max-width: 100%;
	overflow: hidden;
	-webkit-mask-image: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
	mask-image: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
}

.homepage-social-proof__marquee:hover .homepage-social-proof__track,
.homepage-social-proof__marquee:focus-within .homepage-social-proof__track {
	animation-play-state: paused;
}

.homepage-social-proof__track {
	display: flex;
	flex: 0 0 auto;
	gap: var(--partner-logo-gap);
	min-width: max-content;
	animation: homepagePartnerMarquee 42s linear infinite;
}

.homepage-social-proof__logo-link {
	width: 220px;
	height: 82px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 8px 18px;
	background: transparent;
	border: 0;
	border-radius: 6px;
	text-decoration: none;
	transition:
		background-color 0.16s ease,
		opacity 0.16s ease,
		transform 0.16s ease;
}

.homepage-social-proof__logo-link:hover,
.homepage-social-proof__logo-link:focus {
	background: transparent;
	text-decoration: none;
	transform: translateY(-2px);
	opacity: 0.96;
}

.homepage-social-proof__logo-link:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 3px;
}

.homepage-social-proof__logo {
	width: 174px;
	height: 58px;
	display: block;
	object-fit: contain;
	filter: saturate(0.98) contrast(1.03);
	transition:
		filter 0.16s ease,
		transform 0.16s ease;
}

.homepage-social-proof__logo--wide {
	width: 184px;
	height: 52px;
}

.homepage-social-proof__logo--lokman {
	width: 184px;
	height: 62px;
}

.homepage-social-proof__logo--standard {
	width: 150px;
	height: 62px;
}

.homepage-social-proof__logo--compact {
	width: 98px;
	height: 68px;
}

.homepage-social-proof__logo-link:hover .homepage-social-proof__logo,
.homepage-social-proof__logo-link:focus .homepage-social-proof__logo {
	filter: saturate(1.08) contrast(1.04);
	transform: scale(1.02);
}

@keyframes homepagePartnerMarquee {
	from {
		transform: translate3d(0, 0, 0);
	}

	to {
		transform: translate3d(calc(-100% - var(--partner-logo-gap)), 0, 0);
	}
}

@media screen and (max-width: 767px) {
	.homepage-social-proof__partners {
		margin-top: 0;
		padding-top: 0;
	}

	.homepage-social-proof__marquee {
		--partner-logo-gap: 14px;
		margin-inline: -15px;
	}

	.homepage-social-proof__logo-link {
		width: 166px;
		height: 70px;
		padding: 6px 12px;
	}

	.homepage-social-proof__logo {
		width: 132px;
		height: 46px;
	}

	.homepage-social-proof__logo--wide {
		width: 138px;
		height: 40px;
	}

	.homepage-social-proof__logo--lokman {
		width: 142px;
		height: 48px;
	}

	.homepage-social-proof__logo--standard {
		width: 112px;
		height: 50px;
	}

	.homepage-social-proof__logo--compact {
		width: 78px;
		height: 54px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.homepage-social-proof__marquee {
		-webkit-mask-image: none;
		mask-image: none;
		overflow: visible;
	}

	.homepage-social-proof__track {
		flex-wrap: wrap;
		justify-content: center;
		min-width: 0;
		width: 100%;
		animation: none;
	}

	.homepage-social-proof__track[aria-hidden='true'] {
		display: none;
	}

	.homepage-social-proof__logo-link {
		transform: none !important;
	}
}

.homepage-step-media {
	position: relative;
	margin-bottom: 16px;
}

.homepage-step-media img {
	width: 100%;
	height: 200px;
	object-fit: cover;
	border-radius: 8px;
	display: block;
}

.homepage-step-badge,
.appointment-step-badge,
.thankyou-step-badge {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: #102f4f;
	color: #fff;
	font-weight: var(--weight-semibold);
	font-size: 0.8rem;
	display: flex;
	align-items: center;
	justify-content: center;
}

.homepage-step-badge {
	position: absolute;
	top: 10px;
	left: 10px;
}

.homepage-process {
	background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
	border-bottom: 1px solid rgba(216, 232, 245, 0.82);
	overflow: hidden;
	position: relative;
}

.homepage-process::before {
	background: linear-gradient(
		115deg,
		rgba(234, 245, 255, 0) 0%,
		rgba(234, 245, 255, 0.82) 42%,
		rgba(234, 245, 255, 0) 72%
	);
	content: '';
	height: 100%;
	pointer-events: none;
	position: absolute;
	right: -18%;
	top: 0;
	transform: skewX(-14deg);
	width: min(54vw, 720px);
}

.homepage-process > .container {
	position: relative;
	z-index: 1;
}

.homepage-process__header {
	align-items: end;
	display: grid;
	gap: clamp(22px, 4vw, 64px);
	grid-template-columns: minmax(0, 0.9fr) minmax(300px, 0.56fr);
	margin-bottom: clamp(30px, 4.5vw, 58px);
}

.homepage-process__kicker {
	color: var(--color-primary);
	display: inline-flex;
	font-size: 0.82rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.05em;
	line-height: 1.2;
	margin-bottom: 14px;
	text-transform: uppercase;
}

.homepage-process h2 {
	color: var(--color-ink-strong);
	font-size: var(--text-section-title);
	font-weight: var(--weight-display);
	line-height: 1.06;
	margin: 0;
	max-width: 740px;
}

.homepage-process__intro {
	color: var(--color-muted);
	font-size: clamp(1.02rem, 0.98rem + 0.22vw, 1.14rem);
	line-height: 1.5;
	margin: 0;
	max-width: 42rem;
}

.homepage-process__grid {
	--process-gap: clamp(16px, 1.7vw, 24px);
	display: grid;
	gap: var(--process-gap);
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.homepage-process-card {
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.99) 0%,
		rgba(246, 251, 255, 0.97) 100%
	);
	border: 1px solid rgba(192, 219, 239, 0.88);
	border-radius: 22px;
	box-shadow:
		0 22px 54px rgba(16, 47, 79, 0.1),
		0 1px 0 rgba(255, 255, 255, 0.92) inset;
	isolation: isolate;
	min-width: 0;
	padding: 18px;
	position: relative;
	transition:
		background-color 0.22s ease,
		border-color 0.22s ease,
		box-shadow 0.22s ease,
		transform 0.22s ease;
}

.homepage-process-card::before {
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.86) 0%, rgba(255, 255, 255, 0) 46%),
		linear-gradient(180deg, rgba(47, 143, 211, 0.08) 0%, rgba(47, 143, 211, 0) 42%);
	border-radius: 20px;
	content: '';
	inset: 1px;
	pointer-events: none;
	position: absolute;
	z-index: 0;
}

.homepage-process-card__top {
	align-items: center;
	display: flex;
	gap: 10px;
	justify-content: space-between;
	margin-bottom: 16px;
	min-height: 42px;
	position: relative;
	z-index: 2;
}

.homepage-process-card__number {
	align-items: center;
	background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);
	border: 1px solid rgba(255, 255, 255, 0.36);
	border-radius: 14px;
	box-shadow: 0 12px 24px rgba(23, 105, 170, 0.22);
	color: #fff;
	display: inline-flex;
	flex: 0 0 46px;
	font-size: 0.84rem;
	font-weight: var(--weight-emphasis);
	height: 42px;
	justify-content: center;
	line-height: 1;
	width: 46px;
}

.homepage-process-card__step {
	background: rgba(234, 245, 255, 0.86);
	border: 1px solid rgba(189, 219, 242, 0.8);
	border-radius: 999px;
	color: var(--color-primary-dark);
	font-size: 0.8rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.04em;
	line-height: 1.2;
	padding: 7px 10px;
	text-transform: uppercase;
}

.homepage-process-card__media {
	aspect-ratio: 1.35;
	background: var(--color-surface-soft);
	border: 1px solid rgba(216, 232, 245, 0.82);
	border-radius: 18px;
	box-shadow: 0 14px 30px rgba(16, 47, 79, 0.08);
	overflow: hidden;
	position: relative;
	z-index: 1;
}

.homepage-process-card__media::before {
	background: linear-gradient(
		115deg,
		rgba(255, 255, 255, 0) 8%,
		rgba(255, 255, 255, 0.36) 46%,
		rgba(255, 255, 255, 0) 72%
	);
	bottom: 0;
	content: '';
	left: 0;
	pointer-events: none;
	position: absolute;
	top: 0;
	transform: translateX(-125%);
	transition: transform 0.7s ease;
	width: 62%;
	z-index: 2;
}

.homepage-process-card__media::after {
	background: linear-gradient(180deg, rgba(7, 18, 37, 0) 50%, rgba(7, 18, 37, 0.3) 100%);
	bottom: 0;
	content: '';
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	transition: opacity 0.22s ease;
	z-index: 1;
}

.homepage-process-card__media img {
	display: block;
	height: 100%;
	object-fit: cover;
	transform: scale(1.01);
	transition:
		filter 0.35s ease,
		transform 0.35s ease;
	width: 100%;
}

.homepage-process-card__body {
	padding: 20px 4px 5px;
	position: relative;
	z-index: 1;
}

.homepage-process-card h3 {
	color: var(--color-ink-strong);
	font-size: clamp(1.08rem, 1.02rem + 0.22vw, 1.22rem);
	font-weight: var(--weight-display);
	line-height: 1.16;
	margin: 0 0 10px;
}

.homepage-process-card p {
	color: var(--color-muted);
	font-size: 0.98rem;
	line-height: 1.48;
	margin: 0;
}

@media screen and (min-width: 1200px) {
	.homepage-process-card:not(:last-child)::after {
		background: linear-gradient(90deg, rgba(47, 143, 211, 0.42), rgba(47, 143, 211, 0.06));
		content: '';
		height: 1px;
		left: 100%;
		position: absolute;
		top: 40px;
		width: var(--process-gap);
		z-index: 1;
	}
}

@media (hover: hover) and (pointer: fine) {
	.homepage-process-card:hover {
		border-color: rgba(141, 190, 226, 0.95);
		box-shadow:
			0 30px 70px rgba(16, 47, 79, 0.15),
			0 1px 0 rgba(255, 255, 255, 0.94) inset;
		transform: translateY(-6px);
	}

	.homepage-process-card:hover .homepage-process-card__media::before {
		transform: translateX(190%);
	}

	.homepage-process-card:hover .homepage-process-card__media::after {
		opacity: 0.78;
	}

	.homepage-process-card:hover .homepage-process-card__media img {
		filter: saturate(1.06) contrast(1.03);
		transform: scale(1.075);
	}
}

@media screen and (max-width: 1199px) {
	.homepage-process__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 767px) {
	.homepage-process {
		padding-top: 48px !important;
		padding-bottom: 52px !important;
	}

	.homepage-process::before {
		right: -58%;
		width: 92vw;
	}

	.homepage-process__header {
		align-items: start;
		grid-template-columns: 1fr;
		margin-bottom: 28px;
	}

	.homepage-process__grid {
		grid-template-columns: 1fr;
	}

	.homepage-process-card {
		padding: 14px;
		border-radius: 18px;
	}

	.homepage-process-card__media {
		aspect-ratio: 1.65;
		border-radius: 15px;
	}

	.homepage-process-card__body {
		padding-top: 16px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.homepage-process-card,
	.homepage-process-card__media::before,
	.homepage-process-card__media img {
		transition: none;
	}

	.homepage-process-card:hover,
	.homepage-process-card:hover .homepage-process-card__media img {
		transform: none;
	}
}

.homepage-hospitals__grid {
	display: grid;
	gap: clamp(16px, 1.8vw, 24px);
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.homepage-hospitals__summary {
	align-items: flex-start;
	display: grid;
	gap: 18px;
	justify-self: end;
	justify-items: start;
}

.homepage-hospitals__header {
	align-items: center;
	grid-template-columns: minmax(0, 1fr) auto;
}

.homepage-hospital-card {
	min-width: 0;
}

.homepage-hospital-card__link {
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.99) 0%,
		rgba(247, 251, 255, 0.98) 100%
	);
	border: 1px solid rgba(192, 219, 239, 0.88);
	border-radius: 18px;
	box-shadow:
		0 22px 54px rgba(16, 47, 79, 0.1),
		0 1px 0 rgba(255, 255, 255, 0.92) inset;
	color: inherit;
	display: flex;
	flex-direction: column;
	height: 100%;
	min-width: 0;
	overflow: hidden;
	position: relative;
	text-decoration: none;
	transition:
		border-color 0.22s ease,
		box-shadow 0.22s ease,
		transform 0.22s ease;
}

.homepage-hospital-card__link:hover,
.homepage-hospital-card__link:focus {
	color: inherit;
	text-decoration: none;
}

.homepage-hospital-card__link:focus-visible {
	outline: 3px solid rgba(47, 143, 211, 0.38);
	outline-offset: 4px;
}

.homepage-hospital-card__media {
	aspect-ratio: 1.45;
	background: var(--color-surface-soft);
	display: block;
	overflow: hidden;
	position: relative;
}

.homepage-hospital-card__media::after {
	background: linear-gradient(180deg, rgba(7, 18, 37, 0) 42%, rgba(7, 18, 37, 0.46) 100%);
	bottom: 0;
	content: '';
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 1;
}

.homepage-hospital-card__media img {
	display: block;
	height: 100%;
	object-fit: cover;
	transform: scale(1.01);
	transition:
		filter 0.35s ease,
		transform 0.35s ease;
	width: 100%;
}

.homepage-hospital-card__badge {
	align-items: center;
	background: rgba(255, 255, 255, 0.94);
	border: 1px solid rgba(255, 255, 255, 0.8);
	border-radius: 999px;
	bottom: 14px;
	box-shadow: 0 12px 28px rgba(7, 18, 37, 0.18);
	color: var(--color-primary-dark);
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: var(--weight-semibold);
	gap: 7px;
	left: 14px;
	line-height: 1.1;
	max-width: calc(100% - 28px);
	padding: 8px 11px;
	position: absolute;
	z-index: 2;
}

.homepage-hospital-card__badge svg {
	flex: 0 0 14px;
	height: 14px;
	stroke-width: 2.4;
	width: 14px;
}

.homepage-hospital-card__body {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	min-width: 0;
	padding: 20px 18px 18px;
}

.homepage-hospital-card__title {
	color: var(--color-ink-strong);
	display: block;
	font-size: clamp(1.12rem, 1.06rem + 0.24vw, 1.28rem);
	font-weight: var(--weight-semibold);
	line-height: 1.14;
	margin-bottom: 10px;
}

.homepage-hospital-card__description {
	color: var(--color-muted);
	display: block;
	font-size: 0.96rem;
	line-height: 1.48;
	margin-bottom: 16px;
}

.homepage-hospital-card__meta {
	color: #596272;
	display: flex;
	flex-direction: column;
	font-size: 0.92rem;
	gap: 8px;
	line-height: 1.35;
	margin-top: auto;
}

.homepage-hospital-card__meta span {
	align-items: flex-start;
	display: flex;
	gap: 8px;
	min-width: 0;
}

.homepage-hospital-card__meta svg {
	color: var(--color-primary);
	flex: 0 0 16px;
	height: 16px;
	margin-top: 1px;
	stroke-width: 2.3;
	width: 16px;
}

.homepage-hospital-card__cta {
	align-items: center;
	border-top: 1px solid rgba(216, 232, 245, 0.82);
	color: var(--color-primary-dark);
	display: flex;
	font-size: 0.94rem;
	font-weight: var(--weight-semibold);
	gap: 8px;
	justify-content: space-between;
	line-height: 1.2;
	margin-top: 18px;
	padding-top: 15px;
}

.homepage-hospital-card__cta svg {
	flex: 0 0 17px;
	height: 17px;
	stroke-width: 2.5;
	width: 17px;
}

.homepage-hospitals__actions {
	display: flex;
	justify-content: flex-end;
	margin-top: 0;
}

@media (hover: hover) and (pointer: fine) {
	.homepage-hospital-card__link:hover {
		border-color: rgba(141, 190, 226, 0.95);
		box-shadow:
			0 30px 70px rgba(16, 47, 79, 0.15),
			0 1px 0 rgba(255, 255, 255, 0.94) inset;
		transform: translateY(-6px);
	}

	.homepage-hospital-card__link:hover .homepage-hospital-card__media img {
		filter: saturate(1.06) contrast(1.03);
		transform: scale(1.075);
	}
}

@media screen and (max-width: 1199px) {
	.homepage-hospitals__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 767px) {
	.homepage-hospitals__grid {
		grid-template-columns: 1fr;
	}

	.homepage-hospital-card__media {
		aspect-ratio: 1.65;
	}

	.homepage-hospital-card__body {
		padding: 18px 16px 16px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.homepage-hospital-card__link,
	.homepage-hospital-card__media img {
		transition: none;
	}

	.homepage-hospital-card__link:hover,
	.homepage-hospital-card__link:hover .homepage-hospital-card__media img {
		transform: none;
	}
}

.homepage-inline-cta {
	background:
		linear-gradient(90deg, rgba(16, 47, 79, 0.7), rgba(47, 143, 211, 0.7)), rgb(18, 61, 56);
	color: #fff;
	border-radius: 0.25rem !important;
}

.homepage-inline-cta__content {
	z-index: 2;
}

.homepage-inline-cta__badge {
	background-color: rgba(255, 255, 255, 0.2);
	color: #fff;
	font-weight: var(--weight-medium);
}

.homepage-inline-cta__title {
	line-height: 1.2;
}

.homepage-inline-cta__title-accent {
	color: #93c5fd;
}

.homepage-inline-cta__lead {
	font-size: 1.15rem;
	opacity: 0.9;
}

.homepage-inline-cta__button {
	background-color: #fff;
	color: rgb(18, 61, 56);
	font-weight: var(--weight-semibold);
	transition: transform 0.2s;
}

.homepage-inline-cta__button:hover {
	transform: translateY(-2px);
}

.homepage-inline-cta__glow {
	position: absolute;
	top: -50px;
	left: -50px;
	width: 300px;
	height: 300px;
	background: rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	filter: blur(50px);
	z-index: 1;
}

.homepage-inline-cta__image {
	object-fit: cover;
	object-position: center top;
	min-height: 400px;
	z-index: 2;
	position: relative;
}

.homepage-final-cta__copy {
	max-width: 580px;
	font-size: 1.05rem;
	line-height: 1.6;
}

.appointment-plan-section {
	background:
		radial-gradient(circle at 10% 8%, rgba(47, 143, 211, 0.11) 0, rgba(47, 143, 211, 0) 34%),
		linear-gradient(180deg, #f8fcff 0%, #eef7ff 100%);
	overflow: hidden;
	position: relative;
}

.appointment-plan-section::before {
	background: rgba(255, 255, 255, 0.58);
	border: 1px solid rgba(189, 219, 242, 0.7);
	border-radius: 120px 22px 120px 22px;
	content: '';
	height: 380px;
	pointer-events: none;
	position: absolute;
	right: max(-160px, -8vw);
	top: 64px;
	transform: rotate(-18deg);
	width: 380px;
}

.appointment-plan-section__grid {
	align-items: stretch;
	position: relative;
	z-index: 1;
}

.appointment-form-card {
	background: rgba(255, 255, 255, 0.94);
	border: 1px solid rgba(216, 226, 241, 0.9) !important;
	border-radius: 22px !important;
	box-shadow: 0 26px 58px rgba(16, 47, 79, 0.13) !important;
	overflow: hidden;
}

.appointment-form-card__body {
	padding: clamp(28px, 3.2vw, 46px) !important;
}

.appointment-form-card__eyebrow,
.appointment-next-card__eyebrow {
	color: var(--color-primary);
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: var(--weight-emphasis);
	letter-spacing: 0.08em;
	line-height: 1.2;
	margin-bottom: 14px;
	text-transform: uppercase;
}

.appointment-form-title {
	color: #030b1a;
	font-size: clamp(1.85rem, 1.42rem + 1.08vw, 2.55rem);
	font-weight: var(--weight-emphasis);
	line-height: 1.03;
	margin-bottom: 1rem !important;
	max-width: 11em;
}

.appointment-form-card__lead {
	color: #4f6074 !important;
	font-size: 1.06rem;
	line-height: 1.58;
	max-width: 45rem;
}

.appointment-phone-input {
	padding-left: 90px !important;
}

.appointment-submit-button {
	background-color: var(--color-primary);
	border: none;
	transition: transform 0.2s;
}

.appointment-submit-button:hover {
	transform: translateY(-2px);
}

.appointment-secure-icon {
	width: 14px;
}

.appointment-next-card {
	background:
		linear-gradient(180deg, rgba(7, 18, 37, 0.18) 0%, rgba(7, 18, 37, 0.9) 100%),
		linear-gradient(135deg, #123d38 0%, #1769aa 100%);
	border: 1px solid rgba(216, 226, 241, 0.7) !important;
	border-radius: 22px !important;
	box-shadow: 0 26px 58px rgba(16, 47, 79, 0.16) !important;
	isolation: isolate;
	min-height: 100%;
	position: relative;
}

.appointment-next-card__glow {
	position: absolute;
	top: -110px;
	right: -90px;
	width: 260px;
	height: 260px;
	background: rgba(255, 255, 255, 0.16);
	border-radius: 50%;
	filter: blur(22px);
	pointer-events: none;
	z-index: -1;
}

.appointment-next-card__eyebrow {
	color: rgba(255, 255, 255, 0.72);
}

.appointment-next-card h4 {
	font-size: clamp(1.65rem, 1.28rem + 0.75vw, 2.1rem);
	font-weight: var(--weight-emphasis);
	line-height: 1.06;
	max-width: 9em;
}

.appointment-next-card__item {
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.17);
	border-radius: 18px;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
	padding: 18px;
}

.appointment-next-card__item h5 {
	font-weight: var(--weight-display);
	line-height: 1.18;
}

.appointment-step-badge,
.thankyou-step-badge {
	width: 36px;
	height: 36px;
	background-color: rgba(255, 255, 255, 0.2);
	font-size: 0.85rem;
	flex-shrink: 0;
	line-height: 1;
	padding-top: 2px;
}

.appointment-next-card__copy {
	color: rgba(255, 255, 255, 0.78);
	font-size: 0.96rem;
	line-height: 1.45;
}

.thankyou-flow > .container {
	max-width: var(--site-container-max);
}

.thankyou-flow__panel {
	background: #f9fcff;
	border: 1px solid rgba(206, 223, 237, 0.9);
	border-radius: 24px;
	box-shadow: 0 18px 44px rgba(16, 47, 79, 0.06);
	padding: clamp(24px, 3.4vw, 40px);
}

.thankyou-confirmation {
	margin-bottom: clamp(24px, 3vw, 34px);
}

.thankyou-confirmation__panel {
	align-items: center;
	border-bottom: 1px solid rgba(206, 223, 237, 0.82);
	column-gap: clamp(16px, 2.4vw, 22px);
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	padding: 0 0 clamp(24px, 3vw, 32px);
}

.thankyou-confirmation__icon-wrap {
	align-items: center;
	background: #fff;
	border: 1px solid rgba(206, 223, 237, 0.92);
	border-radius: 18px;
	display: flex;
	height: 68px;
	justify-content: center;
	width: 68px;
}

.thankyou-confirmation__icon {
	color: var(--color-primary-dark);
	height: 30px;
	width: 30px;
}

.thankyou-confirmation__body {
	max-width: 720px;
}

.thankyou-kicker {
	color: var(--color-primary);
	font-size: 0.74rem;
	font-weight: var(--weight-semibold);
	letter-spacing: 0.06em;
	line-height: 1.2;
	margin-bottom: 8px;
	text-transform: uppercase;
}

.thankyou-confirmation__copy {
	color: #44576a;
	font-size: clamp(1rem, 0.98rem + 0.18vw, 1.1rem);
	line-height: 1.55;
	margin: 0;
	max-width: 40rem;
}

.thankyou-next {
	display: grid;
	row-gap: clamp(20px, 2.4vw, 28px);
	margin-bottom: clamp(24px, 3vw, 32px);
}

.thankyou-next__header {
	margin: 0;
	max-width: 640px;
}

.thankyou-next__header h2 {
	color: var(--color-ink-strong);
	font-size: clamp(1.55rem, 1.42rem + 0.6vw, 2.05rem);
	font-weight: var(--weight-semibold);
	line-height: 1.12;
	margin: 0;
}

.thankyou-next__grid {
	display: grid;
	gap: clamp(14px, 1.7vw, 18px);
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.thankyou-step-card {
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid rgba(210, 224, 236, 0.92);
	border-radius: 18px;
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 20px 18px 18px;
}

.thankyou-step-heading {
	align-items: center;
	display: flex;
	gap: 12px;
	justify-content: flex-start;
	margin-bottom: 16px;
}

.thankyou-step-badge {
	background: var(--color-primary);
	border-radius: 999px;
	box-shadow: none;
	font-size: 0.85rem;
	height: 32px;
	width: 32px;
}

.thankyou-step-card__icon {
	align-items: center;
	background: rgba(23, 105, 170, 0.06);
	border-radius: 999px;
	display: inline-flex;
	flex: 0 0 36px;
	height: 36px;
	justify-content: center;
	width: 36px;
}

.thankyou-step-card__icon .icon-md-primary {
	color: var(--color-primary-dark);
	height: 18px;
	width: 18px;
}

.thankyou-step-card__title {
	color: var(--color-ink-strong);
	font-size: 1.02rem;
	font-weight: var(--weight-semibold);
	line-height: 1.3;
	margin: 0 0 8px;
}

.thankyou-step-card__copy {
	color: var(--color-muted);
	font-size: 0.93rem;
	line-height: 1.55;
	margin: 0;
	max-width: none;
}

.thankyou-trust-strip {
	border-top: 1px solid rgba(206, 223, 237, 0.82);
	display: grid;
	gap: 14px;
	padding-top: clamp(20px, 2.4vw, 26px);
	text-align: center;
}

.thankyou-trust-list {
	align-items: center;
	color: #5d6a78;
	display: flex;
	flex-wrap: wrap;
	font-size: 0.875rem;
	gap: 14px 22px;
	justify-content: center;
	margin: 0;
}

.thankyou-trust-list span {
	align-items: center;
	display: inline-flex;
	gap: 6px;
}

.thankyou-trust-strip__questions {
	color: var(--color-muted);
	font-size: 0.88rem;
	line-height: 1.5;
	margin: 0;
}

.thankyou-trust-strip__questions a {
	color: var(--color-primary-dark);
	text-decoration: none;
}

.thankyou-trust-strip__questions a:hover,
.thankyou-trust-strip__questions a:focus {
	text-decoration: underline;
}

.listing-thumb {
	width: 200px;
	height: auto;
}

.hospital-detail-icon {
	width: 16px;
	height: 16px;
}

.hospital-detail-actions {
	gap: 12px;
}

.hospital-detail-actions .btn {
	margin-bottom: 10px;
}

.hospital-tabs-shell {
	background: #fff;
	border-bottom: 1px solid #dfdfdf;
}

.hospital-tabs {
	padding-bottom: 1px !important;
}

.hospital-map {
	border: 0;
}

@media screen and (max-width: 767px) {
	.thankyou-flow__panel {
		border-radius: 20px;
		padding: 22px 18px;
	}

	.thankyou-confirmation__panel {
		grid-template-columns: 1fr;
		row-gap: 14px;
		padding-bottom: 22px;
	}

	.thankyou-next__grid {
		grid-template-columns: 1fr;
	}

	.thankyou-trust-list {
		gap: 10px 16px;
	}

	.hospital-detail-actions {
		align-items: stretch !important;
		flex-direction: column;
	}

	.hospital-detail-actions .btn {
		width: 100%;
	}
}

@media screen and (min-width: 768px) and (max-width: 1199px) {
	.thankyou-next__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.thankyou-step-card:last-child {
		grid-column: 1 / -1;
	}
}

.homepage-hospitals__grid {
	gap: clamp(14px, 1.6vw, 22px);
	grid-template-columns: repeat(4, minmax(250px, 1fr));
}

.homepage-hospital-card__link {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(245, 250, 255, 0.96) 100%);
	border: 1px solid rgba(192, 219, 239, 0.84);
	border-radius: 20px;
	box-shadow:
		0 18px 44px rgba(16, 47, 79, 0.11),
		0 1px 0 rgba(255, 255, 255, 0.86) inset;
	display: flex;
	flex-direction: column;
	isolation: isolate;
	justify-content: flex-end;
	min-height: clamp(270px, 16vw, 310px);
	position: relative;
}

.homepage-hospital-card__link::before {
	background: linear-gradient(180deg, rgba(4, 13, 27, 0.02) 0%, rgba(4, 13, 27, 0.03) 38%, rgba(9, 31, 53, 0.56) 100%);
	border-radius: inherit;
	content: '';
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 2;
}

.homepage-hospital-card__media {
	aspect-ratio: auto;
	border-bottom: 0;
	inset: 0;
	position: absolute;
}

.homepage-hospital-card__media::before {
	display: none;
}

.homepage-hospital-card__media::after {
	background: linear-gradient(180deg, rgba(8, 24, 43, 0.04) 0%, rgba(8, 24, 43, 0.01) 42%, rgba(8, 31, 54, 0.28) 100%);
}

.homepage-hospital-card__media img {
	min-height: 100%;
}

.homepage-hospital-card__badge {
	display: none;
}

.homepage-hospital-card__body {
	align-items: end;
	color: #fff;
	display: grid;
	flex: 0 0 auto;
	grid-template-areas:
		'title cta'
		'meta cta';
	grid-template-columns: minmax(0, 1fr) 42px;
	column-gap: 14px;
	row-gap: 6px;
	min-width: 0;
	padding: clamp(18px, 2vw, 24px);
	position: static;
	width: 100%;
	z-index: 3;
}

.homepage-hospital-card__title {
	color: #fff;
	font-size: clamp(1.35rem, 1.06rem + 0.72vw, 1.86rem);
	font-weight: var(--weight-display);
	grid-area: title;
	letter-spacing: 0;
	line-height: 1.04;
	margin: 0;
	min-width: 0;
	text-shadow: 0 12px 28px rgba(4, 13, 27, 0.22);
}

.homepage-hospital-card__description {
	display: none;
}

.homepage-hospital-card__meta {
	align-self: start;
	color: rgba(255, 255, 255, 0.84);
	font-size: 0.88rem;
	grid-area: meta;
	line-height: 1.32;
	margin-top: 0;
	max-width: 100%;
	min-width: 0;
}

.homepage-hospital-card__meta span {
	align-items: center;
	background: transparent;
	border: 0;
	border-radius: 0;
	display: flex;
	gap: 7px;
	max-height: none;
	min-width: 0;
	overflow: hidden;
	padding: 0;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.homepage-hospital-card__meta svg {
	color: rgba(255, 255, 255, 0.82);
	flex: 0 0 15px;
	height: 15px;
	width: 15px;
}

.homepage-hospital-card__cta {
	align-self: end;
	align-items: center;
	background: rgba(255, 255, 255, 0.92);
	border: 1px solid rgba(216, 232, 245, 0.92);
	border-radius: 999px;
	box-shadow: 0 10px 20px rgba(7, 18, 37, 0.12);
	color: var(--color-primary-dark);
	display: inline-flex;
	font-size: 0;
	gap: 0;
	grid-area: cta;
	height: 40px;
	justify-content: center;
	justify-self: end;
	line-height: 1;
	margin: 0;
	overflow: hidden;
	padding: 0;
	position: static;
	transition:
		background-color 0.2s ease,
		transform 0.2s ease;
	width: 40px;
}

.homepage-hospital-card__cta svg {
	flex: 0 0 17px;
	height: 17px;
	stroke-width: 2.35;
	width: 17px;
}

.hospital-detail-hero {
	background: #f5f7fb;
	border-bottom: 1px solid rgba(216, 232, 245, 0.82);
	overflow: hidden;
	padding: clamp(26px, 4vw, 46px) 0 clamp(26px, 4vw, 44px);
	position: relative;
}

.hospital-detail-hero::before {
	display: none;
}

.hospital-detail-hero > .container {
	max-width: var(--site-container-max);
	position: relative;
	z-index: 1;
}

.hospital-detail-breadcrumb .breadcrumb {
	background: transparent;
	margin-bottom: clamp(14px, 2vw, 22px);
	padding: 0;
}

.hospital-detail-breadcrumb .breadcrumb a {
	color: var(--color-primary-dark);
	font-weight: var(--weight-semibold);
}

.hospital-detail-breadcrumb .breadcrumb-item.active {
	color: var(--color-muted);
}

.hospital-detail-hero__grid {
	display: grid;
	gap: clamp(22px, 3vw, 32px);
	grid-template-columns: minmax(0, 1fr);
}

.hospital-detail-hero__grid--single {
	max-width: 920px;
}

.hospital-detail-hero__content {
	max-width: 960px;
}

.hospital-detail-hero__kicker,
.hospital-detail-section__kicker {
	color: var(--color-primary);
	display: inline-flex;
	font-size: 0.82rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.05em;
	line-height: 1.2;
	margin-bottom: 14px;
	text-transform: uppercase;
}

.hospital-detail-hero h1 {
	color: var(--color-ink-strong);
	font-size: clamp(2.15rem, 1.78rem + 1.45vw, 3.15rem);
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.06;
	margin: 0;
}

.hospital-detail-hero__meta {
	display: flex;
	flex-direction: column;
	gap: 7px;
	margin-top: 9px;
	max-width: 920px;
}

.hospital-detail-hero__meta span {
	align-items: center;
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	color: #202938;
	display: inline-flex;
	font-size: 0.96rem;
	font-weight: var(--weight-regular);
	gap: 8px;
	line-height: 1.32;
	max-width: 100%;
	padding: 0;
}

.hospital-detail-icon {
	color: #5d6675;
	flex: 0 0 16px;
	stroke-width: 2.3;
}

.hospital-detail-actions {
	gap: 12px;
	margin-top: 18px;
}

.hospital-detail-actions .btn {
	border-radius: 999px;
	font-weight: var(--weight-semibold);
	margin-bottom: 0;
	padding: 0.68rem 1.05rem;
}

.hospital-detail-action--primary {
	box-shadow: 0 16px 34px rgba(23, 105, 170, 0.24);
}

.hospital-detail-hero__gallery.hospital-photos {
	background: transparent;
	border: 0;
	border-radius: 8px;
	box-shadow: none;
	display: grid;
	gap: 8px;
	grid-template-columns: minmax(0, 1.98fr) minmax(260px, 1fr);
	grid-template-rows: repeat(2, minmax(0, 1fr));
	height: clamp(360px, 31vw, 500px);
	margin: 0;
	min-height: 0;
	overflow: hidden;
	padding: 0;
}

.hospital-detail-hero__gallery .gallery-item:first-child {
	grid-row: span 2;
}

.hospital-detail-hero__gallery--count-1.hospital-photos {
	grid-template-columns: minmax(0, 1fr);
}

.hospital-detail-hero__gallery--count-1 .gallery-item:first-child {
	grid-row: auto;
}

.hospital-detail-hero__gallery--count-2 .gallery-item:not(:first-child) {
	grid-row: span 2;
}

.hospital-detail-hero__gallery .gallery-item,
.hospital-detail-hero__gallery .gallery-item-more {
	border-radius: 8px;
	min-height: 0;
	overflow: hidden;
}

.hospital-detail-hero__gallery .gallery-item a,
.hospital-detail-hero__gallery .gallery-item-more a {
	border-radius: inherit;
	display: block;
	height: 100%;
	padding-bottom: 0;
}

.hospital-detail-hero__gallery .gallery-item a img,
.hospital-detail-hero__gallery .gallery-item-more a img {
	aspect-ratio: auto;
	display: block;
	height: 100%;
	object-fit: cover;
	position: static;
	transition:
		filter 0.35s ease,
		transform 0.35s ease;
	width: 100%;
}

.hospital-detail-hero__gallery .gallery-item-more a .overlay {
	background: rgba(18, 23, 31, 0.56);
}

.hospital-detail-hero__gallery .gallery-item-more a .text {
	font-size: 1.5rem;
	font-weight: var(--weight-display);
}

.hospital-detail-hero__gallery-hidden-link {
	display: none !important;
}

.hospital-tabs-shell {
	background: rgba(255, 255, 255, 0.94);
	border-bottom: 1px solid rgba(216, 232, 245, 0.88);
	box-shadow: 0 14px 32px rgba(16, 47, 79, 0.06);
	position: sticky;
	top: 0;
	z-index: 20;
}

.hospital-tabs {
	border-bottom: 0;
	display: flex;
	gap: 10px;
	overflow-x: auto;
	padding: 14px 0 !important;
}

.hospital-tabs .nav-link {
	border: 1px solid transparent !important;
	border-radius: 999px;
	color: #596272;
	font-weight: var(--weight-semibold);
	line-height: 1.2;
	padding: 10px 16px;
	white-space: nowrap;
}

.hospital-tabs .nav-link.active {
	background: rgba(234, 245, 255, 0.92);
	border-color: rgba(189, 219, 242, 0.86) !important;
	color: var(--color-primary-dark);
}

.hospital-detail-section {
	background: #f7fbff;
}

.hospital-detail-section--overview {
	background: linear-gradient(180deg, #f7fbff 0%, #ffffff 100%);
}

.hospital-detail-overview-grid {
	align-items: start;
	display: grid;
	gap: clamp(20px, 3vw, 34px);
	grid-template-columns: minmax(0, 1fr) minmax(320px, 0.44fr);
}

.hospital-detail-profile-card {
	background: rgba(255, 255, 255, 0.98);
	border: 1px solid rgba(216, 232, 245, 0.86);
	border-radius: 24px;
	box-shadow:
		0 22px 54px rgba(16, 47, 79, 0.09),
		0 1px 0 rgba(255, 255, 255, 0.92) inset;
	margin-top: clamp(22px, 3vw, 34px);
	padding: clamp(24px, 3.6vw, 42px);
}

.hospital-detail-profile-card h2,
.hospital-detail-profile-card h3 {
	color: var(--color-ink-strong);
	font-weight: var(--weight-display);
	letter-spacing: 0;
}

.hospital-detail-profile-card h2 {
	font-size: clamp(1.55rem, 1.25rem + 1vw, 2.15rem);
	line-height: 1.08;
	margin: 0 0 clamp(18px, 2.6vw, 28px);
}

.hospital-detail-profile-card h3 {
	font-size: clamp(1.18rem, 1.05rem + 0.45vw, 1.5rem);
	line-height: 1.16;
	margin: 0 0 16px;
}

.hospital-detail-profile-card__facts {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.hospital-detail-profile-fact span {
	color: var(--color-ink-strong);
	display: block;
	font-size: 0.82rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 6px;
	text-transform: uppercase;
}

.hospital-detail-profile-fact strong {
	color: #596272;
	display: block;
	font-size: 1.02rem;
	font-weight: var(--weight-medium);
	line-height: 1.35;
}

.hospital-detail-known {
	margin-top: clamp(26px, 3vw, 38px);
}

.hospital-detail-known__grid {
	display: grid;
	gap: clamp(12px, 2vw, 18px);
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.hospital-detail-known-card {
	aspect-ratio: 1.18;
	border-radius: 18px;
	isolation: isolate;
	margin: 0;
	overflow: hidden;
	position: relative;
}

.hospital-detail-known-card::after {
	background: linear-gradient(180deg, rgba(7, 18, 37, 0.02) 0%, rgba(7, 18, 37, 0.68) 100%);
	content: '';
	inset: 0;
	position: absolute;
	z-index: 1;
}

.hospital-detail-known-card img {
	display: block;
	height: 100%;
	object-fit: cover;
	transition: transform 0.36s ease;
	width: 100%;
}

.hospital-detail-known-card span {
	bottom: 16px;
	color: #fff;
	font-size: clamp(1rem, 0.94rem + 0.25vw, 1.2rem);
	font-weight: var(--weight-display);
	left: 16px;
	line-height: 1.18;
	position: absolute;
	right: 16px;
	z-index: 2;
}

.hospital-detail-profile-card__sections {
	display: grid;
	gap: clamp(24px, 4vw, 54px);
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	margin-top: clamp(28px, 4vw, 46px);
}

.hospital-detail-profile-list__items {
	display: grid;
	gap: 16px 24px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hospital-detail-profile-list__item {
	align-items: center;
	color: #222c3b;
	display: flex;
	font-size: 0.98rem;
	font-weight: var(--weight-medium);
	gap: 12px;
	line-height: 1.35;
	min-width: 0;
}

.hospital-detail-profile-list__item svg {
	color: var(--color-primary);
	flex: 0 0 22px;
	height: 22px;
	stroke-width: 1.9;
	width: 22px;
}

.hospital-detail-summary,
.hospital-detail-info-panel,
.hospital-detail-map-panel {
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.99) 0%,
		rgba(247, 251, 255, 0.98) 100%
	);
	border: 1px solid rgba(192, 219, 239, 0.88);
	border-radius: 24px;
	box-shadow:
		0 22px 54px rgba(16, 47, 79, 0.1),
		0 1px 0 rgba(255, 255, 255, 0.92) inset;
}

.hospital-detail-summary {
	padding: clamp(24px, 3vw, 38px);
}

.hospital-detail-summary h2,
.hospital-detail-section__header h2,
.hospital-detail-map-panel h2 {
	color: var(--color-ink-strong);
	font-size: clamp(1.6rem, 1.35rem + 1vw, 2.35rem);
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.08;
	margin: 0;
}

.hospital-detail-summary__copy {
	color: var(--color-muted);
	font-size: 1.04rem;
	line-height: 1.62;
	margin-top: 16px;
}

.hospital-detail-info-panel {
	padding: clamp(20px, 2.4vw, 28px);
}

.hospital-detail-info-panel__group + .hospital-detail-info-panel__group {
	border-top: 1px solid rgba(216, 232, 245, 0.82);
	margin-top: 18px;
	padding-top: 18px;
}

.hospital-detail-info-panel h3 {
	color: var(--color-ink-strong);
	font-size: 0.92rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin: 0 0 10px;
	text-transform: uppercase;
}

.hospital-detail-info-panel p {
	color: #596272;
	font-size: 0.98rem;
	line-height: 1.5;
	margin: 0;
}

.hospital-detail-department-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.hospital-detail-department-list span {
	background: rgba(234, 245, 255, 0.82);
	border: 1px solid rgba(189, 219, 242, 0.78);
	border-radius: 999px;
	color: var(--color-primary-dark);
	font-size: 0.88rem;
	font-weight: var(--weight-semibold);
	line-height: 1.2;
	padding: 8px 10px;
}

.hospital-detail-map-panel {
	align-items: stretch;
	display: grid;
	gap: 18px;
	grid-template-columns: minmax(0, 0.72fr) minmax(360px, 1fr);
	margin-top: clamp(22px, 3vw, 34px);
	overflow: hidden;
	padding: 14px;
}

.hospital-detail-map-panel__copy {
	padding: clamp(18px, 2vw, 26px);
}

.hospital-detail-map-panel p {
	color: var(--color-muted);
	font-size: 1rem;
	line-height: 1.5;
	margin: 14px 0 18px;
}

.hospital-detail-map-panel a {
	align-items: center;
	color: var(--color-primary-dark);
	display: inline-flex;
	font-weight: var(--weight-semibold);
	gap: 8px;
	text-decoration: none;
}

.hospital-detail-map-panel a svg {
	flex: 0 0 17px;
	height: 17px;
	width: 17px;
}

.hospital-map {
	border: 0;
	border-radius: 18px;
	height: 100%;
	min-height: 280px;
	width: 100%;
}

.hospital-detail-section__header {
	margin-bottom: clamp(20px, 3vw, 34px);
}

.hospital-detail-photo-grid.hospital-photos-list {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.hospital-detail-photo-grid .hospital-photo {
	max-width: none;
	padding: 0;
	width: auto;
}

.hospital-detail-photo-grid .hospital-photo .img-container {
	aspect-ratio: 1.22;
	border: 1px solid rgba(192, 219, 239, 0.78);
	border-radius: 18px;
	box-shadow: 0 18px 42px rgba(16, 47, 79, 0.1);
	height: auto;
}

@media (hover: hover) and (pointer: fine) {
	.homepage-hospital-card__link:hover .homepage-hospital-card__cta {
		background: rgba(255, 255, 255, 0.98);
		box-shadow: 0 12px 22px rgba(7, 18, 37, 0.14);
		transform: translateX(2px);
	}

	.hospital-detail-hero__gallery .gallery-item a:hover img,
	.hospital-detail-hero__gallery .gallery-item-more a:hover img,
	.hospital-detail-known-card:hover img {
		filter: saturate(1.06) contrast(1.03);
		transform: scale(1.06);
	}
}

@media screen and (max-width: 1199px) {
	.homepage-hospitals__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.homepage-hospital-card__link {
		min-height: clamp(300px, 38vw, 340px);
	}

	.hospital-detail-hero__grid,
	.hospital-detail-overview-grid,
	.hospital-detail-map-panel {
		grid-template-columns: 1fr;
	}

	.hospital-detail-hero__gallery.hospital-photos {
		height: clamp(330px, 45vw, 440px);
	}

	.hospital-detail-profile-card__facts,
	.hospital-detail-known__grid,
	.hospital-detail-profile-card__sections {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hospital-detail-photo-grid.hospital-photos-list {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media screen and (max-width: 767px) {
	.homepage-hospitals__grid {
		grid-template-columns: 1fr;
	}

	.homepage-hospitals__summary {
		gap: 16px;
		justify-self: stretch;
	}

	.homepage-hospitals__actions {
		justify-content: flex-start;
		width: 100%;
	}

	.homepage-hospital-card__link {
		border-radius: 18px;
		min-height: clamp(290px, 68vw, 330px);
	}

	.homepage-hospital-card__body {
		grid-template-columns: minmax(0, 1fr) 40px;
		padding: 20px 14px 18px 18px;
	}

	.homepage-hospital-card__cta {
		height: 38px;
		width: 38px;
	}

	.hospital-detail-hero {
		padding: 24px 0 30px;
	}

	.hospital-detail-hero h1 {
		font-size: clamp(2rem, 1.55rem + 6vw, 2.85rem);
	}

	.hospital-detail-hero__meta span {
		align-items: flex-start;
		min-width: 0;
		overflow-wrap: anywhere;
		width: 100%;
	}

	.hospital-detail-hero__meta span .hospital-detail-icon,
	.hospital-detail-hero__meta span svg {
		margin-top: 2px;
	}

	.hospital-detail-actions {
		align-items: stretch !important;
		flex-direction: column;
	}

	.hospital-detail-actions .btn {
		justify-content: center;
		width: 100%;
	}

	.hospital-detail-hero__gallery.hospital-photos {
		gap: 7px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		grid-template-rows: none;
		height: auto;
		min-height: 0;
		padding: 0;
	}

	.hospital-detail-hero__gallery .gallery-item:first-child {
		grid-column: span 2;
		grid-row: auto;
	}

	.hospital-detail-hero__gallery--count-2 .gallery-item:not(:first-child) {
		grid-column: span 2;
		grid-row: auto;
	}

	.hospital-detail-hero__gallery .gallery-item a,
	.hospital-detail-hero__gallery .gallery-item-more a {
		aspect-ratio: 1.55;
		height: auto;
	}

	.hospital-detail-hero__gallery .gallery-item:first-child a {
		aspect-ratio: 1.92;
		max-height: clamp(170px, 49vw, 220px);
	}

	.hospital-detail-hero__gallery--count-1 .gallery-item:first-child a {
		aspect-ratio: 1.78;
		max-height: clamp(190px, 56vw, 250px);
	}

	.hospital-detail-hero__gallery--count-2 .gallery-item:not(:first-child) a {
		aspect-ratio: 2.45;
		max-height: clamp(112px, 31vw, 150px);
	}

	.hospital-detail-summary,
	.hospital-detail-info-panel {
		border-radius: 20px;
	}

	.hospital-detail-profile-card {
		border-radius: 20px;
	}

	.hospital-detail-profile-card__facts,
	.hospital-detail-known__grid,
	.hospital-detail-profile-card__sections,
	.hospital-detail-profile-list__items {
		grid-template-columns: 1fr;
	}

	.hospital-detail-known-card {
		aspect-ratio: 1.55;
	}

	.hospital-detail-map-panel {
		border-radius: 20px;
		padding: 10px;
	}

	.hospital-tabs {
		padding: 10px 0 !important;
	}

	.hospital-detail-photo-grid.hospital-photos-list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 479px) {
	.homepage-hospital-card__link {
		min-height: 300px;
	}

	.hospital-detail-photo-grid.hospital-photos-list {
		grid-template-columns: 1fr;
	}
}

@media (prefers-reduced-motion: reduce) {
	.homepage-hospital-card__cta,
	.hospital-detail-hero__gallery .gallery-item a img,
	.hospital-detail-hero__gallery .gallery-item-more a img,
	.hospital-detail-known-card img {
		transition: none;
	}

	.homepage-hospital-card__link:hover .homepage-hospital-card__cta,
	.hospital-detail-hero__gallery .gallery-item a:hover img,
	.hospital-detail-hero__gallery .gallery-item-more a:hover img,
	.hospital-detail-known-card:hover img {
		transform: none;
	}
}

.visitor-success-icon {
	font-size: 60px;
	margin-bottom: 15px;
}

/* Public typography guide alignment */
h1,
h2,
h3,
h4,
h5,
h6,
.heading-font {
	font-family: var(--font-primary);
	text-wrap: balance;
}

.content-box,
.article-content,
.article-body-container {
	font-size: var(--text-body-lg);
	line-height: 1.65;
}

.content-box,
.article-content {
	max-width: var(--measure-reading);
}

.content-box p,
.content-box li,
.article-content p,
.article-content li {
	font-size: var(--text-body-lg);
	font-weight: var(--weight-regular);
	line-height: 1.65;
}

.article-content p + p,
.content-box p + p {
	margin-top: 1.25em;
}

.article-hero h1,
.section-with-bg .container h1,
.main-homepage .main-slider-content h1 {
	font-size: var(--text-h1);
	font-weight: var(--weight-semibold);
	line-height: 1.1;
	letter-spacing: 0;
}

.article-hero-summary,
.section-with-bg .container p,
.main-homepage .main-slider-content p.f1 {
	font-size: var(--text-lead);
	font-weight: var(--weight-regular);
	line-height: 1.55;
}

.navbar-expand-lg .navbar-nav .nav-link,
.navbar-call-action {
	font-size: 0.9375rem;
	font-weight: var(--weight-semibold);
	line-height: 1.25;
}

.topstrip__trust,
.topstrip__link {
	font-size: 0.875rem;
	font-weight: var(--weight-regular);
	letter-spacing: 0;
	line-height: 1.25;
}

.topstrip__trust-main,
.topstrip__trust-short,
.topstrip__link--primary {
	font-weight: var(--weight-medium);
}

.btn,
button,
input[type='submit'],
.article-hero-btn,
.article-final-cta__btn,
.sidebar-cta-card__btn,
.appointment-submit-button {
	font-family: var(--font-primary);
	font-size: 1rem;
	font-weight: var(--weight-heading);
	line-height: 1.2;
	letter-spacing: 0;
	text-transform: none;
}

.btn,
button,
input[type='submit'] {
	min-height: 2.75rem;
}

label,
.form-label {
	font-size: 1rem;
	font-weight: var(--weight-semibold);
	line-height: 1.35;
}

input,
select,
textarea,
.form-control {
	font-size: 1rem;
	font-weight: var(--weight-regular);
	line-height: 1.4;
}

.appointment-form-status,
.form-hint,
.form-error,
.appointment-secure-note,
.newsletter-card .input-agreement-text,
.blog-lead-cta__meta,
.cta-info p,
.homepage-trust-bullets,
.homepage-treatment-card h3,
.homepage-treatment-card p,
.homepage-treatment-cta,
.about-section-heading span,
.article-breadcrumb ol,
.article-hero .article-category-badge,
.article-toc__title,
.article-toc__link,
.article-toc__item--h3 > .article-toc__link,
.article-sidebar-widget__title,
.article-sidebar-guide-link,
.article-safety-link,
.article-author-box__label,
.article-author-box__date,
.article-author-box__links a,
.article-disclaimer p,
.treatment-guide-card p,
.treatment-guide-card__cta,
.sidebar-cta-card__label,
.sidebar-cta-card__bullets li,
.sidebar-cta-card__footer,
.article-mobile-cta__label,
.article-trust-meta,
.post-list li .post-content .post-meta,
.caption,
.meta,
.legal,
small {
	font-size: var(--text-small);
	line-height: 1.55;
}

.form-error {
	font-weight: var(--weight-semibold);
}

.metric,
.price,
.date,
.phone-number,
.table-numeric,
.article-trust-meta,
.topstrip__link[href^='tel:'],
.navbar-call-action[href^='tel:'] {
	font-variant-numeric: tabular-nums lining-nums;
}

.thankyou-kicker,
.article-category-badge,
.medical-tourism-safety-kicker,
.section-title-bordered {
	letter-spacing: 0.04em;
}

:lang(ar) .article-hero h1,
:lang(ar) .section-with-bg .container h1,
:lang(ar) .main-homepage .main-slider-content h1,
[dir='rtl'] .article-hero h1,
[dir='rtl'] .section-with-bg .container h1,
[dir='rtl'] .main-homepage .main-slider-content h1 {
	letter-spacing: normal;
	line-height: 1.3;
}

@media screen and (max-width: 767px) {
	.topstrip__trust,
	.topstrip__link {
		font-size: 0.8125rem;
	}
}

/* Blue clinical visual refresh
   Keeps the existing component structure while replacing heavy dark blocks with
   clinical white surfaces, subtle blue panels, and controlled hospital-blue accents. */
body {
	background: #fff;
}

a {
	color: var(--color-primary);
}

.topstrip {
	background: linear-gradient(90deg, #061f38 0%, #0a355e 46%, #0d477f 100%);
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow: inset 0 -1px 0 rgba(2, 14, 28, 0.34);
	color: #fff;
}

.topstrip__trust,
.topstrip__link,
.topstrip__certificate,
.topstrip__language {
	color: rgba(255, 255, 255, 0.9);
}

.topstrip__language {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.2);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.16),
		0 1px 10px rgba(2, 14, 28, 0.18);
}

.topstrip__link:hover,
.topstrip__link:focus,
.topstrip__certificate:hover,
.topstrip__certificate:focus,
.topstrip__link--primary {
	background: rgba(255, 255, 255, 0.13);
	color: #fff;
}

.topstrip__dot {
	background: rgba(255, 255, 255, 0.5);
}

.topstrip__language a:hover,
.topstrip__language a:focus {
	background: rgba(255, 255, 255, 0.13);
	border-color: rgba(255, 255, 255, 0.24);
	color: #fff;
}

.topstrip__language a:focus-visible {
	outline-color: rgba(255, 255, 255, 0.72);
}

.topstrip__language a[aria-current='true'] {
	background: #fff;
	border-color: rgba(255, 255, 255, 0.78);
	box-shadow: 0 1px 8px rgba(2, 14, 28, 0.24);
	color: #0a355e;
}

nav.navbar {
	background: rgba(255, 255, 255, 0.96);
	border-bottom: 1px solid var(--color-line-soft);
	box-shadow: 0 4px 14px rgba(16, 47, 79, 0.045);
	-webkit-backdrop-filter: blur(22px);
	backdrop-filter: blur(22px);
}

.navbar-expand-lg .navbar-nav .nav-link,
.navbar-expand-lg .navbar-nav .nav-link[aria-expanded='true'] {
	color: var(--color-body);
}

.navbar-expand-lg .navbar-nav .nav-link:hover,
.navbar-expand-lg .navbar-nav .nav-link:focus,
.navbar-expand-lg .nav-item.show > .nav-link {
	color: var(--color-primary-dark);
}

.navbar-expand-lg .navbar-nav .nav-link[aria-current='page'],
.navbar-expand-lg .navbar-nav .nav-link.active {
	color: var(--color-primary-dark);
}

.navbar-expand-lg a.navbar-call-action {
	align-items: center;
	background: var(--color-primary);
	border: 1px solid var(--color-primary);
	border-radius: 999px;
	color: #fff;
	justify-content: center;
	margin-left: 24px;
	min-height: 42px;
	padding: 0 18px;
	position: relative;
	text-align: center;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease,
		transform 0.18s ease;
}

.navbar-expand-lg a.navbar-call-action::before {
	background: rgba(16, 47, 79, 0.16);
	border-radius: 999px;
	content: '';
	height: 28px;
	left: -13px;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
}

@media screen and (min-width: 768px) {
	.navbar-expand-lg a.navbar-call-action.d-md-block {
		display: inline-flex !important;
	}
}

@media screen and (min-width: 992px) and (max-width: 1100px) {
	.navbar-expand-lg a.navbar-call-action.d-md-block {
		display: none !important;
	}
}

.navbar-expand-lg a.navbar-call-action:hover,
.navbar-expand-lg a.navbar-call-action:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff;
	transform: translateY(-1px);
}

.navbar-toggler {
	color: var(--color-primary-dark);
}

.navbar-expand-lg .navbar-nav .menu-item {
	border-bottom-color: var(--color-line-soft) !important;
}

.bg-dark,
.bg-light-2,
.safety-section-soft,
.about-section-soft,
.thankyou-confirmation {
	background: var(--color-surface-soft) !important;
}

.bg-dark {
	color: var(--color-body) !important;
}

.main-homepage .main-slider-content h1,
.section-with-bg .container h1,
.article-hero h1,
.about-hero h1,
.safety-hero h1,
.homepage-final-cta h2,
.article-final-cta h2,
.about-final-cta h2,
.safety-final-cta h2 {
	color: var(--color-ink-strong);
}

.hero-primary-button,
.hero__form-submit,
.btn.btn-primary,
.appointment-submit-button,
.about-btn-primary,
.safety-btn-primary,
.article-final-cta__btn,
.homepage-inline-cta__button,
.cta-light-button {
	background: var(--color-primary);
	border-color: var(--color-primary);
	box-shadow: 0 12px 24px rgba(23, 105, 170, 0.16);
	color: #fff !important;
}

.hero-primary-button:hover,
.hero-primary-button:focus,
.hero__form-submit:hover,
.hero__form-submit:focus,
.btn.btn-primary:hover,
.btn.btn-primary:focus,
.appointment-submit-button:hover,
.about-btn-primary:hover,
.safety-btn-primary:hover,
.article-final-cta__btn:hover,
.homepage-inline-cta__button:hover,
.cta-light-button:hover,
.cta-light-button:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff !important;
}

.hero-secondary-button,
.btn.btn-ghost,
.about-btn-secondary,
.safety-btn-secondary,
.about-btn-secondary-dark,
.safety-btn-secondary-light,
.about-btn-secondary-light {
	background: #fff;
	border: 1px solid var(--color-line-soft);
	color: var(--color-primary-dark) !important;
}

.hero-secondary-button:hover,
.hero-secondary-button:focus,
.btn.btn-ghost:hover,
.btn.btn-ghost:focus,
.about-btn-secondary:hover,
.safety-btn-secondary:hover,
.about-btn-secondary-dark:hover,
.safety-btn-secondary-light:hover,
.about-btn-secondary-light:hover {
	background: var(--color-primary-soft);
	border-color: #bddbf2;
	color: var(--color-primary-dark) !important;
}

.navbar-expand-lg .navbar-collapse .navbar-mobile-cta .btn.btn-ghost {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff !important;
}

.navbar-expand-lg .navbar-collapse .navbar-mobile-cta .btn.btn-ghost:hover,
.navbar-expand-lg .navbar-collapse .navbar-mobile-cta .btn.btn-ghost:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff !important;
}

.hero__eyebrow,
.about-label,
.safety-label,
.article-hero .article-category-badge,
.homepage-inline-cta__badge,
.safety-support-band li {
	background: var(--color-primary-soft);
	border: 1px solid #cfe5f8;
	color: var(--color-primary-dark);
}

.hero__cred-card,
.card-featured,
.homepage-treatment-card,
.safety-card,
.safety-red-flag,
.safety-step,
.safety-support-band,
.about-step,
.about-criterion,
.about-question-list li,
.about-policy-links a,
.article-sidebar-widget,
.treatment-guide-card,
.article-author-box,
.blog-cta,
.credential-verify,
.credential-card__media {
	border-color: var(--color-line-soft);
	box-shadow: 0 16px 38px var(--color-shadow-soft);
}

.homepage-step-badge,
.appointment-step-badge,
.thankyou-step-badge,
.safety-step-number,
.about-step-number {
	background: var(--color-primary);
	color: #fff;
}

.section-title-bordered {
	border-bottom-color: var(--color-line-soft);
	color: var(--color-primary-dark);
}

.homepage-featured-articles .section-title-bordered {
	color: var(--color-primary-dark);
}

.homepage-featured-articles__grid {
	align-items: stretch;
	display: grid;
	gap: clamp(26px, 4vw, 60px);
	grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.72fr);
	margin-top: clamp(22px, 3vw, 36px);
}

.homepage-featured-articles__grid--single {
	grid-template-columns: minmax(0, 1fr);
}

.homepage-featured-articles__primary,
.homepage-featured-articles__item,
.homepage-article-index__item {
	min-width: 0;
}

.homepage-featured-articles__link,
.homepage-article-index__link {
	color: var(--color-body);
	display: grid;
	min-width: 0;
	text-decoration: none;
}

.homepage-featured-articles__primary .homepage-featured-articles__link {
	grid-template-rows: minmax(0, 1fr) auto;
	height: 100%;
}

.homepage-featured-articles__link:hover,
.homepage-featured-articles__link:focus,
.homepage-article-index__link:hover,
.homepage-article-index__link:focus {
	color: var(--color-primary-dark);
	text-decoration: none;
}

.homepage-featured-articles__link:focus-visible,
.homepage-article-index__link:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.22);
	outline-offset: 5px;
}

.homepage-featured-articles__media {
	background: var(--color-surface-soft);
	display: block;
	min-width: 0;
	overflow: hidden;
}

.homepage-featured-articles__media--primary {
	aspect-ratio: 1.62;
	border-radius: 20px 20px 6px 6px;
}

.homepage-featured-articles__media img,
.homepage-article-index__media img {
	display: block;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition:
		filter 0.28s ease,
		transform 0.28s ease;
	width: 100%;
}

.homepage-featured-articles__link:hover .homepage-featured-articles__media img,
.homepage-featured-articles__link:focus .homepage-featured-articles__media img,
.homepage-article-index__link:hover .homepage-article-index__media img,
.homepage-article-index__link:focus .homepage-article-index__media img {
	filter: saturate(1.04) contrast(1.02);
	transform: scale(1.025);
}

.homepage-featured-articles__body {
	display: grid;
	gap: 0.5rem;
	min-width: 0;
	position: relative;
}

.homepage-featured-articles__body--primary {
	background: transparent;
	gap: 0.72rem;
	padding: clamp(18px, 2vw, 26px) 0 0;
}

.homepage-featured-articles__eyebrow,
.homepage-article-index__eyebrow {
	color: var(--color-primary);
	display: inline-flex;
	font-size: 0.73rem;
	font-weight: var(--weight-display);
	justify-self: start;
	letter-spacing: 0.08em;
	line-height: 1.2;
	overflow: hidden;
	text-overflow: ellipsis;
	text-transform: uppercase;
	white-space: nowrap;
}

.homepage-featured-articles__body h3 {
	color: var(--color-ink-strong);
	font-size: clamp(1.04rem, 0.98rem + 0.22vw, 1.18rem);
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.22;
	margin: 0;
}

.homepage-featured-articles__body--primary h3 {
	font-size: clamp(1.72rem, 1.22rem + 1.25vw, 2.52rem);
	line-height: 1.02;
	max-width: none;
}

.homepage-featured-articles__body p {
	color: var(--color-muted);
	display: -webkit-box;
	font-size: 0.95rem;
	line-height: 1.48;
	margin: 0;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

.homepage-featured-articles__body--primary p {
	font-size: clamp(1rem, 0.96rem + 0.16vw, 1.08rem);
	line-height: 1.56;
	max-width: 50rem;
	-webkit-line-clamp: 3;
}

.homepage-featured-articles__cta {
	align-items: center;
	color: var(--color-primary-dark);
	display: inline-flex;
	height: 24px;
	justify-content: center;
	transition:
		color 0.18s ease,
		transform 0.18s ease;
	width: 24px;
}

.homepage-featured-articles__cta svg {
	height: 17px;
	stroke-width: 2.5;
	width: 17px;
}

.homepage-featured-articles__link:hover .homepage-featured-articles__cta,
.homepage-featured-articles__link:focus .homepage-featured-articles__cta {
	color: var(--color-primary);
	transform: translateX(4px);
}

.homepage-featured-articles__list {
	display: grid;
	grid-auto-rows: minmax(0, 1fr);
	height: 100%;
	min-height: 0;
}

.homepage-featured-articles__item {
	display: grid;
	min-height: 0;
}

.homepage-featured-articles__link--compact {
	align-items: center;
	gap: clamp(14px, 1.6vw, 20px);
	grid-template-columns: minmax(124px, 174px) minmax(0, 1fr);
	height: 100%;
	padding: clamp(16px, 1.45vw, 22px) 0;
}

@media screen and (min-width: 992px) {
	.homepage-featured-articles__item:first-child .homepage-featured-articles__link--compact {
		align-items: start;
		padding-top: 0;
	}
}

.homepage-featured-articles__media--compact {
	aspect-ratio: 1.26;
	border-radius: 12px 3px 12px 3px;
}

.homepage-featured-articles__link--compact .homepage-featured-articles__body {
	grid-template-columns: minmax(0, 1fr) 24px;
}

.homepage-featured-articles__link--compact .homepage-featured-articles__eyebrow,
.homepage-featured-articles__link--compact h3,
.homepage-featured-articles__link--compact p {
	grid-column: 1;
}

.homepage-featured-articles__link--compact .homepage-featured-articles__cta {
	grid-column: 2;
	grid-row: 1 / span 3;
	justify-self: end;
	margin-top: 2px;
}

.homepage-article-index {
	display: grid;
	margin-top: clamp(22px, 3vw, 34px);
}

.homepage-article-index__link {
	align-items: center;
	gap: clamp(18px, 2.4vw, 34px);
	grid-template-columns: minmax(180px, 0.34fr) minmax(0, 1fr);
	padding: clamp(18px, 2.2vw, 26px) 0;
}

.homepage-article-index__media {
	aspect-ratio: 1.7;
	background: var(--color-surface-soft);
	border-radius: 16px 4px 16px 4px;
	display: block;
	overflow: hidden;
}

.homepage-article-index__body {
	align-items: start;
	display: grid;
	gap: 0.5rem;
	grid-template-columns: minmax(0, 1fr) 30px;
	min-width: 0;
}

.homepage-article-index__eyebrow,
.homepage-article-index__title,
.homepage-article-index__description {
	grid-column: 1;
}

.homepage-article-index__title {
	color: var(--color-ink-strong);
	display: -webkit-box;
	font-size: clamp(1.16rem, 1.03rem + 0.34vw, 1.42rem);
	font-weight: var(--weight-display);
	line-height: 1.12;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

.homepage-article-index__description {
	color: var(--color-muted);
	display: -webkit-box;
	font-size: 0.96rem;
	line-height: 1.5;
	max-width: 56rem;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

@media screen and (max-width: 991px) {
	.homepage-featured-articles__grid {
		align-items: start;
		grid-template-columns: 1fr;
	}

	.homepage-featured-articles__primary .homepage-featured-articles__link,
	.homepage-featured-articles__link--compact {
		height: auto;
	}

	.homepage-featured-articles__list {
		grid-auto-rows: auto;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		height: auto;
	}

	.homepage-featured-articles__item {
		border-bottom: 0;
		border-right: 1px solid rgba(188, 214, 234, 0.78);
	}

	.homepage-featured-articles__item:last-child {
		border-right: 0;
	}

	.homepage-featured-articles__link--compact {
		align-items: start;
		grid-template-columns: 1fr;
		padding: 16px;
	}

	.homepage-featured-articles__link--compact .homepage-featured-articles__body {
		grid-template-columns: minmax(0, 1fr) 24px;
	}

	.homepage-featured-articles__media--compact {
		aspect-ratio: 1.55;
		width: 100%;
	}
}

@media screen and (max-width: 767px) {
	.homepage-featured-articles__grid {
		gap: 24px;
	}

	.homepage-featured-articles__media--primary {
		aspect-ratio: 1.42;
		border-radius: 16px 16px 4px 4px;
	}

	.homepage-featured-articles__body--primary h3 {
		font-size: clamp(1.44rem, 1.16rem + 0.82vw, 1.82rem);
	}

	.homepage-featured-articles__list {
		grid-template-columns: 1fr;
	}

	.homepage-featured-articles__item {
		border-right: 0;
	}

	.homepage-featured-articles__link--compact {
		gap: 12px;
		grid-template-columns: minmax(92px, 116px) minmax(0, 1fr);
		padding: 12px 0;
	}

	.homepage-article-index__link {
		grid-template-columns: minmax(92px, 116px) minmax(0, 1fr);
	}

	.homepage-featured-articles__media--compact,
	.homepage-article-index__media {
		aspect-ratio: 1.08;
		border-radius: 12px 3px 12px 3px;
	}

	.homepage-article-index__link {
		gap: 14px;
		padding: 18px 0;
	}

	.homepage-article-index__body {
		grid-template-columns: minmax(0, 1fr) 22px;
	}

	.homepage-article-index__title {
		font-size: clamp(1.02rem, 0.96rem + 0.22vw, 1.14rem);
	}

	.homepage-article-index__description,
	.homepage-featured-articles__link--compact p {
		display: none;
	}
}

@media screen and (max-width: 479px) {
	.homepage-featured-articles__link--compact {
		gap: 10px;
		grid-template-columns: minmax(86px, 108px) minmax(0, 1fr);
		padding: 10px 0;
	}

	.homepage-article-index__link {
		grid-template-columns: 1fr;
	}

	.homepage-featured-articles__media--compact,
	.homepage-article-index__media {
		aspect-ratio: 1.62;
	}
}

@media (prefers-reduced-motion: reduce) {
	.homepage-featured-articles__media img,
	.homepage-featured-articles__cta,
	.homepage-article-index__media img {
		transition: none;
	}

	.homepage-featured-articles__link:hover .homepage-featured-articles__media img,
	.homepage-featured-articles__link:focus .homepage-featured-articles__media img,
	.homepage-featured-articles__link:hover .homepage-featured-articles__cta,
	.homepage-featured-articles__link:focus .homepage-featured-articles__cta,
	.homepage-article-index__link:hover .homepage-article-index__media img,
	.homepage-article-index__link:focus .homepage-article-index__media img {
		transform: none;
	}
}

.article-similar-topics {
	background: linear-gradient(180deg, #ffffff 0%, #f6fbff 100%);
	border-bottom: 1px solid var(--color-line-soft);
	border-top: 1px solid var(--color-line-soft);
	color: var(--color-body);
	padding-bottom: var(--public-section-y) !important;
	padding-top: var(--public-section-y) !important;
}

.article-similar-topics .container {
	max-width: var(--public-page-max);
}

.article-similar-topics__header {
	align-items: end;
	border-bottom: 1px solid rgba(188, 214, 234, 0.78);
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 1.5rem;
	justify-content: space-between;
	padding-bottom: clamp(18px, 2.5vw, 30px);
}

.article-similar-topics__eyebrow,
.article-similar-topic__kicker {
	color: var(--color-primary);
	display: inline-flex;
	font-size: 0.73rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.08em;
	line-height: 1.2;
	text-transform: uppercase;
}

.article-similar-topics__header h2 {
	color: var(--color-ink-strong);
	font-size: clamp(1.72rem, 1.22rem + 1.25vw, 2.52rem);
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.02;
	margin: 0;
}

.article-similar-topics__grid {
	display: grid;
	gap: 0 clamp(30px, 4vw, 58px);
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.article-similar-topic {
	border-bottom: 1px solid rgba(188, 214, 234, 0.78);
	min-width: 0;
}

.article-similar-topic__link {
	align-items: center;
	color: var(--color-body);
	display: grid;
	gap: clamp(16px, 2vw, 24px);
	grid-template-columns: minmax(128px, 172px) minmax(0, 1fr);
	min-width: 0;
	padding: clamp(18px, 2.1vw, 26px) 0;
	text-decoration: none;
}

.article-similar-topic__link:hover,
.article-similar-topic__link:focus {
	color: var(--color-primary-dark);
	text-decoration: none;
}

.article-similar-topic__link:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.22);
	outline-offset: 5px;
}

.article-similar-topic__media {
	aspect-ratio: 1.34;
	background: var(--color-surface-soft);
	border-radius: 14px 4px 14px 4px;
	display: block;
	overflow: hidden;
}

.article-similar-topic__media img {
	display: block;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition:
		filter 0.28s ease,
		transform 0.28s ease;
	width: 100%;
}

.article-similar-topic__body {
	align-items: start;
	display: grid;
	gap: 0.48rem;
	grid-template-columns: minmax(0, 1fr) 28px;
	min-width: 0;
}

.article-similar-topic__kicker,
.article-similar-topic__body h3,
.article-similar-topic__body p {
	grid-column: 1;
}

.article-similar-topic__body h3 {
	color: var(--color-ink-strong);
	display: -webkit-box;
	font-size: clamp(1.06rem, 1rem + 0.26vw, 1.26rem);
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.16;
	margin: 0;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

.article-similar-topic__body p {
	color: var(--color-muted);
	display: -webkit-box;
	font-size: 0.94rem;
	line-height: 1.48;
	margin: 0;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

.article-similar-topic__cta {
	align-items: center;
	color: var(--color-primary-dark);
	display: inline-flex;
	grid-column: 2;
	grid-row: 1 / span 3;
	height: 28px;
	justify-content: center;
	justify-self: end;
	margin-top: 2px;
	transition:
		color 0.18s ease,
		transform 0.18s ease;
	width: 28px;
}

.article-similar-topic__cta svg {
	height: 17px;
	stroke-width: 2.5;
	width: 17px;
}

.article-similar-topic__link:hover .article-similar-topic__media img,
.article-similar-topic__link:focus .article-similar-topic__media img {
	filter: saturate(1.04) contrast(1.02);
	transform: scale(1.025);
}

.article-similar-topic__link:hover .article-similar-topic__cta,
.article-similar-topic__link:focus .article-similar-topic__cta {
	color: var(--color-primary);
	transform: translateX(4px);
}

@media screen and (max-width: 991px) {
	.article-similar-topics__grid {
		grid-template-columns: 1fr;
	}
}

@media screen and (max-width: 767px) {
	.article-similar-topics__header {
		align-items: start;
		flex-direction: column;
	}

	.article-similar-topic__link {
		grid-template-columns: minmax(96px, 118px) minmax(0, 1fr);
	}

	.article-similar-topic__media {
		aspect-ratio: 1.08;
	}

	.article-similar-topic__body {
		grid-template-columns: minmax(0, 1fr) 22px;
	}

	.article-similar-topic__body h3 {
		font-size: clamp(1.02rem, 0.96rem + 0.22vw, 1.14rem);
	}

	.article-similar-topic__body p {
		display: none;
	}

	.article-similar-topic__cta {
		width: 22px;
	}
}

@media screen and (max-width: 479px) {
	.article-similar-topic__link {
		align-items: start;
		grid-template-columns: 1fr;
	}

	.article-similar-topic__media {
		aspect-ratio: 1.62;
	}
}

@media (prefers-reduced-motion: reduce) {
	.article-similar-topic__media img,
	.article-similar-topic__cta {
		transition: none;
	}

	.article-similar-topic__link:hover .article-similar-topic__media img,
	.article-similar-topic__link:focus .article-similar-topic__media img,
	.article-similar-topic__link:hover .article-similar-topic__cta,
	.article-similar-topic__link:focus .article-similar-topic__cta {
		transform: none;
	}
}

.homepage-inline-cta,
.homepage-final-cta,
.article-hero,
.article-final-cta,
.about-hero,
.about-final-cta,
.safety-hero,
.safety-final-cta,
.newsletter-card {
	background: linear-gradient(180deg, #ffffff 0%, #f6fbff 100%);
	border: 1px solid var(--color-line-soft);
	color: var(--color-body);
}

.about-hero {
	border: 0;
}

.homepage-inline-cta {
	border-radius: 10px !important;
	box-shadow: 0 4px 12px rgba(17, 24, 39, 0.04);
}

.homepage-inline-cta__title,
.homepage-inline-cta__lead,
.homepage-final-cta__copy,
.homepage-final-cta__meta,
.article-hero-summary,
.article-trust-meta,
.article-breadcrumb li,
.article-breadcrumb a,
.article-breadcrumb [aria-current],
.article-final-cta p,
.article-final-cta__secondary,
.about-hero-copy,
.about-trust-list li,
.about-final-cta p,
.safety-hero-copy,
.safety-trust-list li,
.safety-final-cta p,
.newsletter-card p,
.newsletter-card .input-agreement-text,
.newsletter-card .input-agreement-text a {
	color: var(--color-muted);
}

.homepage-final-cta {
	background: linear-gradient(180deg, #f8fcff 0%, #eef6fb 100%);
	border: 0;
	box-shadow: none;
	color: var(--color-body);
	overflow: hidden;
	padding: clamp(52px, 6.5vw, 88px) 0;
}

.homepage-final-cta__inner {
	margin: 0 auto;
	max-width: var(--site-container-max);
	padding: 0 var(--site-container-gutter);
	width: 100%;
}

.homepage-final-cta__panel {
	align-items: center;
	background:
		radial-gradient(
			ellipse at 82% 48%,
			rgba(255, 255, 255, 0.62) 0%,
			rgba(255, 255, 255, 0.24) 34%,
			rgba(255, 255, 255, 0) 62%
		),
		linear-gradient(135deg, #edf8ff 0%, #dceffc 52%, #cfe7f8 100%);
	border: 1px solid rgba(189, 219, 242, 0.74);
	border-radius: clamp(18px, 1.6vw, 26px);
	box-shadow: none;
	column-gap: clamp(26px, 4.5vw, 68px);
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 0.82fr);
	margin-inline: auto;
	min-height: clamp(390px, 31vw, 500px);
	overflow: hidden;
	padding: clamp(36px, 4.5vw, 62px) clamp(28px, 4.5vw, 62px);
	position: relative;
	row-gap: 28px;
	width: 100%;
}

.homepage-final-cta__panel::before,
.homepage-final-cta__panel::after {
	content: '';
	pointer-events: none;
	position: absolute;
}

.homepage-final-cta__panel::before {
	border: 28px solid rgba(255, 255, 255, 0.48);
	border-radius: 50%;
	height: min(44vw, 560px);
	right: clamp(-150px, -9vw, -74px);
	top: 50%;
	transform: translateY(-50%) rotate(-9deg);
	width: min(44vw, 560px);
}

.homepage-final-cta__panel::after {
	background:
		linear-gradient(90deg, rgba(23, 105, 170, 0.18), rgba(23, 105, 170, 0)),
		rgba(255, 255, 255, 0.36);
	border-radius: 999px;
	height: 12px;
	right: clamp(116px, 12vw, 220px);
	top: clamp(54px, 7vw, 88px);
	transform: rotate(-4deg);
	width: clamp(150px, 18vw, 270px);
}

.homepage-final-cta__content,
.homepage-final-cta__visual {
	min-width: 0;
	position: relative;
	z-index: 1;
}

.homepage-final-cta__content {
	max-width: 620px;
}

.homepage-final-cta h2 {
	color: var(--color-ink-strong);
	font-size: var(--text-section-title);
	font-weight: var(--weight-display);
	line-height: 1.04;
	margin-bottom: 18px;
	max-width: 10.5em;
}

.homepage-final-cta__copy {
	color: #415468;
	font-size: clamp(1.04rem, 0.98rem + 0.24vw, 1.18rem);
	line-height: 1.5;
	margin-bottom: clamp(24px, 2.6vw, 34px);
	max-width: 520px;
}

.homepage-final-cta__button {
	align-items: center;
	background: var(--color-primary);
	border: 1px solid var(--color-primary);
	border-radius: 999px;
	box-shadow: none;
	color: #fff !important;
	display: inline-flex;
	font-size: 1.02rem;
	justify-content: center;
	line-height: 1.2;
	min-height: 58px;
	text-decoration: none !important;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease,
		color 0.18s ease,
		transform 0.18s ease;
}

.homepage-final-cta__button:hover,
.homepage-final-cta__button:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	box-shadow: none;
	color: #fff !important;
	text-decoration: none;
	transform: translateY(-1px);
}

.homepage-final-cta__button:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.26);
	outline-offset: 4px;
}

.homepage-final-cta__visual {
	align-self: stretch;
	display: flex;
	justify-content: center;
	min-height: 340px;
}

.homepage-final-cta__visual img {
	bottom: clamp(-92px, -6vw, -54px);
	filter: none;
	height: clamp(390px, 36vw, 540px);
	max-width: none;
	object-fit: contain;
	position: absolute;
	right: clamp(-42px, -2.5vw, -10px);
	width: auto;
}

@media screen and (max-width: 991px) {
	.homepage-final-cta__panel {
		grid-template-columns: 1fr;
		min-height: auto;
		padding-bottom: 0;
	}

	.homepage-final-cta__content {
		max-width: 680px;
	}

	.homepage-final-cta__visual {
		min-height: 390px;
	}

	.homepage-final-cta__visual img {
		bottom: -78px;
		height: 470px;
		left: 50%;
		right: auto;
		transform: translateX(-50%);
	}
}

@media screen and (max-width: 575px) {
	.homepage-final-cta {
		padding: 44px 0;
	}

	.homepage-final-cta__panel {
		border-radius: 22px;
		padding: 30px 22px 0;
	}

	.homepage-final-cta__copy {
		font-size: 1.04rem;
	}

	.homepage-final-cta__panel::before {
		border-width: 18px;
		height: 360px;
		right: -150px;
		top: auto;
		bottom: -110px;
		width: 360px;
	}

	.homepage-final-cta__panel::after {
		right: -30px;
		top: 26px;
		width: 180px;
	}

	.homepage-final-cta__button {
		max-width: 100%;
		white-space: normal;
	}

	.homepage-final-cta__visual {
		min-height: 286px;
	}

	.homepage-final-cta__visual img {
		bottom: -66px;
		height: 330px;
	}
}

.homepage-free-consult {
	background: #ffffff;
	color: #050d1e;
	overflow: hidden;
	padding: clamp(48px, 6vw, 80px) 0;
}

.main-homepage > .homepage-free-consult {
	isolation: isolate;
	position: relative;
	background:
		linear-gradient(
			180deg,
			rgba(248, 252, 255, 0.96) 0%,
			rgba(255, 255, 255, 0.98) 46%,
			#ffffff 100%
		),
		linear-gradient(115deg, rgba(234, 245, 255, 0.72) 0%, rgba(255, 255, 255, 0) 52%), #ffffff;
}

.main-homepage > .homepage-free-consult::before {
	content: '';
	position: absolute;
	inset: 0 0 auto;
	height: clamp(86px, 12vw, 168px);
	pointer-events: none;
	background:
		linear-gradient(180deg, rgba(248, 252, 255, 0.9) 0%, rgba(255, 255, 255, 0) 100%),
		radial-gradient(ellipse at 72% 0%, rgba(234, 245, 255, 0.86) 0%, rgba(234, 245, 255, 0) 64%);
	z-index: 0;
}

.main-homepage > .homepage-free-consult > .container {
	position: relative;
	z-index: 1;
}

.homepage-free-consult > .container {
	max-width: min(100% - 56px, var(--site-container-max, 1540px));
}

.homepage-free-consult__panel {
	background: transparent;
	border-radius: 0;
	box-shadow: none;
	min-height: 0;
	padding: 0;
	position: relative;
}

.homepage-free-consult__grid {
	align-items: center;
	display: grid;
	gap: clamp(24px, 4vw, 56px);
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
	position: relative;
}

.homepage-free-consult__content {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-width: 0;
	padding: clamp(8px, 1.5vw, 20px) 0;
}

.homepage-free-consult__content h2 {
	color: #050d1e;
	font-size: var(--text-section-title);
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.12;
	margin: 0;
	max-width: 12em;
}

.homepage-free-consult__lead {
	color: #41506a;
	font-size: clamp(1rem, 0.96rem + 0.18vw, 1.12rem);
	font-weight: var(--weight-medium);
	line-height: 1.55;
	margin: clamp(14px, 2vw, 22px) 0 0;
	max-width: 34em;
}

.homepage-free-consult__button {
	align-self: flex-start;
	margin-top: clamp(22px, 3vw, 34px);
}

.homepage-free-consult__media {
	align-self: center;
	position: relative;
}

.homepage-free-consult__media > img {
	display: block;
	height: auto;
	margin: 0 auto;
	max-width: min(100%, 520px);
	width: 100%;
}

@media screen and (max-width: 991px) {
	.homepage-free-consult__grid {
		gap: clamp(20px, 4vw, 32px);
		grid-template-columns: 1fr;
	}

	.homepage-free-consult__content h2,
	.homepage-free-consult__lead {
		max-width: 100%;
	}

	.homepage-free-consult__media > img {
		max-width: min(100%, 440px);
	}
}

@media screen and (max-width: 575px) {
	.homepage-free-consult {
		padding: 40px 0;
	}

	.homepage-free-consult__content h2 {
		overflow-wrap: break-word;
	}

	.homepage-free-consult__lead {
		font-size: 1rem;
	}

	.homepage-free-consult__media > img {
		max-width: min(100%, 340px);
	}
}

.homepage-cost-comparison {
	--cost-accent: #9b82e9;
	--cost-accent-strong: #8659ee;
	--cost-country-col: 120px;
	--cost-label-bar-min: 118px;
	--cost-track: #e6f1ff;
	--cost-grid: rgba(134, 89, 238, 0.16);
	--cost-muted: #727b88;
	--cost-row-gap: 22px;
	--cost-value-space: clamp(76px, 5vw, 96px);
	background: #f7f9fc;
	color: #071225;
	overflow: hidden;
	padding: clamp(46px, 5.4vw, 78px) 0 clamp(58px, 7vw, 104px);
}

.homepage-cost-comparison > .container {
	max-width: min(100% - 56px, var(--site-container-max, 1540px));
}

.homepage-cost-comparison__header {
	margin-bottom: clamp(38px, 4.8vw, 72px);
}

.homepage-cost-comparison__header h2 {
	color: #071225;
	font-size: clamp(2rem, 1.45rem + 2.15vw, 3.35rem);
	font-weight: var(--weight-emphasis);
	letter-spacing: 0;
	line-height: 1.08;
	margin: 0;
}

.homepage-cost-comparison__header p {
	color: #6f7784;
	font-size: clamp(1rem, 0.95rem + 0.2vw, 1.18rem);
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	margin: 8px 0 0;
}

.homepage-cost-comparison__layout {
	align-items: start;
	display: grid;
	gap: clamp(30px, 4vw, 64px);
	grid-template-columns: minmax(280px, 380px) minmax(0, 1fr);
}

.homepage-cost-comparison__filters {
	align-items: start;
	display: grid;
	gap: 14px 16px;
	grid-template-columns: minmax(0, 1fr);
	min-width: 0;
}

.homepage-cost-comparison__field,
.homepage-cost-comparison__country-picker {
	display: grid;
	gap: 10px;
	min-width: 0;
}

.homepage-cost-comparison__filters > .homepage-cost-comparison__field:first-child,
.homepage-cost-comparison__filters
	> .homepage-cost-comparison__field:first-child
	.homepage-cost-comparison__select-wrap {
	max-width: 360px;
}

.homepage-cost-comparison__country-picker {
	grid-column: 1 / -1;
}

.homepage-cost-comparison__field-label {
	border: 0;
	clip: rect(0, 0, 0, 0);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	white-space: nowrap;
	width: 1px;
}

.homepage-cost-comparison__field > .homepage-cost-comparison__field-label {
	border: 0;
	clip: auto;
	color: #566274;
	display: block;
	font-size: 0.82rem;
	font-weight: var(--weight-heading);
	height: auto;
	letter-spacing: 0;
	line-height: 1.2;
	margin: 0;
	overflow: visible;
	padding: 0 2px;
	position: static;
	white-space: normal;
	width: auto;
}

.homepage-cost-comparison__select-wrap {
	display: block;
	min-width: 0;
	overflow: visible;
	position: relative;
	width: 100%;
}

.homepage-cost-comparison__field--currency .homepage-cost-comparison__select-wrap {
	max-width: 168px;
}

.homepage-cost-comparison__select,
.homepage-cost-comparison__select-button {
	appearance: none;
	background: linear-gradient(180deg, #fff 0%, #fbfdff 100%);
	border: 1px solid rgba(203, 216, 233, 0.96);
	border-radius: 18px;
	box-shadow: 0 10px 24px rgba(16, 47, 79, 0.08);
	color: #172033;
	display: block;
	font-size: 1rem;
	font-weight: var(--weight-heading);
	line-height: 1.15;
	min-height: 58px;
	min-width: 0;
	padding: 0 64px 0 18px;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease;
	width: 100%;
}

.homepage-cost-comparison__select-button {
	align-items: center;
	cursor: pointer;
	text-align: left;
}

.homepage-cost-comparison__select-button-text {
	display: block;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.homepage-cost-comparison__select-wrap--enhanced .homepage-cost-comparison__select {
	display: none;
}

.homepage-cost-comparison__select--currency {
	max-width: 168px;
	min-width: 0;
}

.homepage-cost-comparison__select-wrap:hover .homepage-cost-comparison__select,
.homepage-cost-comparison__select-wrap:hover .homepage-cost-comparison__select-button,
.homepage-cost-comparison__select-wrap--open .homepage-cost-comparison__select-button {
	border-color: rgba(134, 89, 238, 0.34);
	box-shadow: 0 12px 26px rgba(16, 47, 79, 0.1);
}

.homepage-cost-comparison__select-icon {
	align-items: center;
	background: #eef4fb;
	border-radius: 999px;
	box-shadow: inset 0 0 0 1px rgba(134, 89, 238, 0.12);
	color: var(--cost-accent-strong);
	display: inline-flex;
	height: 42px;
	justify-content: center;
	pointer-events: none;
	position: absolute;
	right: 8px;
	top: 50%;
	transform: translateY(-50%);
	width: 42px;
	z-index: 2;
}

.homepage-cost-comparison__select-icon svg {
	height: 18px;
	stroke-width: 3;
	transition: transform 0.16s ease;
	width: 18px;
}

.homepage-cost-comparison__select-wrap--open .homepage-cost-comparison__select-icon svg {
	transform: rotate(180deg);
}

.homepage-cost-comparison__select-menu {
	background: #fff;
	border: 1px solid rgba(203, 216, 233, 0.96);
	border-radius: 16px;
	box-shadow: 0 18px 38px rgba(16, 47, 79, 0.16);
	box-sizing: border-box;
	display: none;
	left: 0;
	max-height: 260px;
	overflow-x: hidden;
	overflow-y: auto;
	padding: 6px 8px 6px 6px;
	position: absolute;
	right: 0;
	scrollbar-color: rgba(134, 89, 238, 0.52) transparent;
	scrollbar-width: thin;
	top: calc(100% + 8px);
	width: 100%;
	z-index: 40;
}

.homepage-cost-comparison__select-menu::-webkit-scrollbar {
	width: 7px;
}

.homepage-cost-comparison__select-menu::-webkit-scrollbar-track {
	background: transparent;
	margin: 8px 0;
}

.homepage-cost-comparison__select-menu::-webkit-scrollbar-thumb {
	background: rgba(134, 89, 238, 0.58);
	border-radius: 999px;
	min-height: 34px;
}

.homepage-cost-comparison__select-menu::-webkit-scrollbar-thumb:hover {
	background: rgba(134, 89, 238, 0.76);
}

.homepage-cost-comparison__select-wrap--open .homepage-cost-comparison__select-menu {
	display: grid;
	gap: 2px;
}

.homepage-cost-comparison__select-option {
	appearance: none;
	background: transparent;
	border: 0;
	border-radius: 12px;
	color: #263248;
	cursor: pointer;
	display: block;
	font-size: 0.95rem;
	font-weight: var(--weight-semibold);
	line-height: 1.2;
	min-height: 40px;
	padding: 10px 12px;
	text-align: left;
	width: 100%;
}

.homepage-cost-comparison__select-option:hover,
.homepage-cost-comparison__select-option:focus {
	background: #f4f7fb;
	color: var(--cost-accent-strong);
	outline: none;
}

.homepage-cost-comparison__select-option[aria-selected='true'] {
	background: #f0edff;
	color: var(--cost-accent-strong);
}

.homepage-cost-comparison__chips {
	display: grid;
	gap: 12px 10px;
	grid-template-columns: repeat(3, max-content);
	max-width: 560px;
	padding-top: 0;
}

.homepage-cost-comparison__chip {
	align-items: center;
	background: #f7fbff;
	border: 1px solid #d7e4f1;
	border-radius: 999px;
	color: #26435f;
	cursor: pointer;
	display: inline-flex;
	font-size: 0.92rem;
	font-weight: var(--weight-semibold);
	justify-content: center;
	line-height: 1.1;
	min-height: 36px;
	padding: 0 18px;
	transition: box-shadow 0.18s ease;
	white-space: nowrap;
}

.homepage-cost-comparison__country-label {
	font-weight: var(--weight-regular);
}

.homepage-cost-comparison__chip:not(.homepage-cost-comparison__chip--active):not(
		[aria-pressed='true']
	):hover,
.homepage-cost-comparison__chip:not(.homepage-cost-comparison__chip--active):not(
		[aria-pressed='true']
	):focus {
	background: #f7fbff;
	border-color: #d7e4f1;
	color: #26435f;
	outline: none;
}

.homepage-cost-comparison__chip:focus-visible,
.homepage-cost-comparison__select:focus-visible,
.homepage-cost-comparison__select-button:focus-visible,
.homepage-cost-comparison__select-option:focus-visible {
	box-shadow:
		0 0 0 3px rgba(134, 89, 238, 0.2),
		0 10px 22px rgba(16, 47, 79, 0.07);
	outline: none;
}

.homepage-cost-comparison__chip--active,
.homepage-cost-comparison__chip[aria-pressed='true'] {
	background: var(--color-primary);
	border-color: var(--color-primary);
	box-shadow: 0 10px 22px rgba(23, 105, 170, 0.18);
	color: #fff;
	font-weight: var(--weight-semibold);
}

.homepage-cost-comparison__chip--active:hover,
.homepage-cost-comparison__chip--active:focus,
.homepage-cost-comparison__chip[aria-pressed='true']:hover,
.homepage-cost-comparison__chip[aria-pressed='true']:focus {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
	outline: none;
}

.homepage-cost-comparison__chart {
	min-width: 0;
}

.homepage-cost-comparison__chart-head {
	align-items: center;
	display: flex;
	gap: 24px;
	justify-content: space-between;
	margin-bottom: clamp(30px, 3vw, 46px);
	padding-left: calc(var(--cost-country-col) + var(--cost-row-gap));
	padding-right: var(--cost-value-space);
}

.homepage-cost-comparison__chart-head h3 {
	color: #1b2638;
	font-size: clamp(1.24rem, 1.08rem + 0.52vw, 1.58rem);
	font-weight: var(--weight-semibold);
	letter-spacing: 0;
	line-height: 1.18;
	margin: 0;
}

.homepage-cost-comparison__legend,
.homepage-cost-comparison__mobile-legend {
	align-items: center;
	color: #596272;
	display: flex;
	flex-wrap: wrap;
	font-size: 0.88rem;
	font-weight: var(--weight-regular);
	gap: 18px 26px;
	line-height: 1.2;
}

.homepage-cost-comparison__legend {
	justify-content: flex-end;
	margin-left: auto;
	text-align: right;
}

.homepage-cost-comparison__legend span,
.homepage-cost-comparison__mobile-legend span {
	align-items: center;
	display: inline-flex;
	gap: 9px;
	white-space: nowrap;
}

.homepage-cost-comparison__legend-dot {
	border-radius: 999px;
	display: inline-block;
	flex: 0 0 20px;
	height: 20px;
	width: 20px;
}

.homepage-cost-comparison__legend-dot--best {
	background: var(--cost-accent);
}

.homepage-cost-comparison__legend-dot--average {
	background: var(--cost-track);
}

.homepage-cost-comparison__bars {
	display: grid;
	gap: 18px;
}

.homepage-cost-comparison__row {
	align-items: center;
	display: grid;
	gap: var(--cost-row-gap);
	grid-template-columns: var(--cost-country-col) minmax(0, 1fr);
	min-width: 0;
}

.homepage-cost-comparison__country {
	align-items: center;
	color: #1b2638;
	display: flex;
	font-size: 1rem;
	font-weight: var(--weight-semibold);
	gap: 12px;
	min-width: 0;
}

.homepage-cost-comparison__country-label {
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.homepage-cost-comparison__flag {
	align-items: center;
	background: transparent;
	border-radius: 0;
	box-shadow: none;
	display: inline-flex;
	flex: 0 0 34px;
	height: 34px;
	justify-content: center;
	overflow: visible;
	width: 34px;
}

.homepage-cost-comparison__flag .iti__flag {
	border-radius: 1px;
	box-shadow: none;
	transform: scale(1.45);
	transform-origin: center;
}

.homepage-cost-comparison__bar-track {
	box-sizing: border-box;
	height: 28px;
	min-width: 0;
	position: relative;
	width: calc(100% - var(--cost-value-space));
}

.homepage-cost-comparison__gridline {
	background-image: linear-gradient(to right, var(--cost-grid) 1px, transparent 1px);
	background-size: calc(100% / 3) 100%;
	border-right: 1px solid var(--cost-grid);
	inset: -12px 0;
	pointer-events: none;
	position: absolute;
}

.homepage-cost-comparison__bar {
	border-radius: 999px;
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
}

.homepage-cost-comparison__bar--average {
	background: var(--cost-track);
	width: var(--average-width);
	z-index: 1;
}

.homepage-cost-comparison__bar--best {
	align-items: center;
	background: var(--cost-accent);
	display: flex;
	justify-content: flex-end;
	min-width: min(var(--cost-label-bar-min), 100%);
	width: var(--best-width);
	z-index: 2;
}

.homepage-cost-comparison__value {
	color: #fff;
	display: block;
	font-size: 0.84rem;
	font-weight: var(--weight-regular);
	line-height: 1;
	padding-right: 14px;
	position: relative;
	text-align: right;
	white-space: nowrap;
}

.homepage-cost-comparison__quote-value {
	align-items: center;
	color: var(--cost-accent-strong);
	display: inline-flex;
	font-size: 0.96rem;
	font-weight: var(--weight-heading);
	min-height: 100%;
}

.homepage-cost-comparison__axis {
	color: #7a8494;
	display: grid;
	font-size: 0.96rem;
	font-weight: var(--weight-semibold);
	grid-template-columns: repeat(4, minmax(0, 1fr));
	line-height: 1.2;
	margin: 32px 0 0;
	padding-left: calc(var(--cost-country-col) + var(--cost-row-gap));
	padding-right: var(--cost-value-space);
}

.homepage-cost-comparison__axis span:nth-child(1) {
	text-align: left;
}

.homepage-cost-comparison__axis span:nth-child(2),
.homepage-cost-comparison__axis span:nth-child(3) {
	text-align: center;
}

.homepage-cost-comparison__axis span:nth-child(4) {
	text-align: right;
}

.homepage-cost-comparison__mobile-legend {
	display: none;
	margin-top: 22px;
}

.homepage-cost-comparison__note {
	color: #6f7b8d;
	font-size: 0.84rem;
	line-height: 1.45;
	margin: 28px 0 0;
	padding-left: calc(var(--cost-country-col) + var(--cost-row-gap));
	padding-right: var(--cost-value-space);
}

.homepage-cost-comparison__empty {
	background: #fff;
	border: 1px dashed #c9dcea;
	border-radius: 8px;
	color: var(--cost-muted);
	font-weight: var(--weight-semibold);
	line-height: 1.4;
	margin: 0;
	padding: 22px;
	text-align: center;
}

@media screen and (max-width: 1199px) {
	.homepage-cost-comparison {
		--cost-country-col: 116px;
		--cost-row-gap: 18px;
		--cost-value-space: 78px;
	}

	.homepage-cost-comparison__layout {
		gap: 46px;
		grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
	}

	.homepage-cost-comparison__chart-head {
		align-items: flex-start;
		flex-direction: column;
		gap: 14px;
	}
}

@media screen and (max-width: 991px) {
	.homepage-cost-comparison {
		--cost-country-col: 114px;
		--cost-row-gap: 18px;
		--cost-value-space: 84px;
	}

	.homepage-cost-comparison > .container {
		max-width: min(100% - 36px, 860px);
	}

	.homepage-cost-comparison__layout {
		gap: 38px;
		grid-template-columns: 1fr;
	}

	.homepage-cost-comparison__filters {
		gap: 14px;
		grid-template-columns: minmax(0, 1fr);
	}

	.homepage-cost-comparison__select--currency {
		max-width: none;
	}

	.homepage-cost-comparison__field--currency .homepage-cost-comparison__select-wrap {
		max-width: none;
	}

	.homepage-cost-comparison__chips {
		max-width: 100%;
	}

	.homepage-cost-comparison__filters > .homepage-cost-comparison__field:first-child,
	.homepage-cost-comparison__filters
		> .homepage-cost-comparison__field:first-child
		.homepage-cost-comparison__select-wrap {
		max-width: 100%;
	}

	.homepage-cost-comparison__chart-head {
		align-items: center;
		flex-direction: row;
	}
}

@media screen and (max-width: 767px) {
	.homepage-cost-comparison {
		--cost-country-col: 98px;
		--cost-label-bar-min: 96px;
		--cost-row-gap: 12px;
		--cost-value-space: 58px;
		padding: 44px 0 54px;
	}

	.homepage-cost-comparison__header {
		margin-bottom: 24px;
	}

	.homepage-cost-comparison__select,
	.homepage-cost-comparison__select-button {
		font-size: 0.95rem;
		min-height: 52px;
		padding-left: 16px;
		padding-right: 60px;
	}

	.homepage-cost-comparison__select-icon {
		height: 38px;
		width: 38px;
	}

	.homepage-cost-comparison__chip {
		font-size: 0.86rem;
		min-height: 31px;
		padding: 0 14px;
	}

	.homepage-cost-comparison__chart-head {
		display: block;
		padding-left: 0;
	}

	.homepage-cost-comparison__chart-head h3 {
		font-size: 1.12rem;
	}

	.homepage-cost-comparison__legend {
		display: none;
	}

	.homepage-cost-comparison__bars {
		gap: 14px;
		margin-top: 18px;
	}

	.homepage-cost-comparison__row {
		grid-template-columns: var(--cost-country-col) minmax(0, 1fr);
	}

	.homepage-cost-comparison__country {
		font-size: 0.88rem;
		gap: 7px;
	}

	.homepage-cost-comparison__flag {
		flex-basis: 26px;
		height: 26px;
		width: 26px;
	}

	.homepage-cost-comparison__flag .iti__flag {
		transform: scale(1.25);
	}

	.homepage-cost-comparison__bar-track {
		height: 24px;
	}

	.homepage-cost-comparison__gridline {
		inset: -10px 0;
	}

	.homepage-cost-comparison__value {
		font-size: 0.76rem;
		padding-right: 9px;
	}

	.homepage-cost-comparison__axis {
		font-size: 0.78rem;
		margin-top: 18px;
	}

	.homepage-cost-comparison__note {
		margin-left: 0;
		padding-left: 0;
	}

	.homepage-cost-comparison__mobile-legend {
		display: flex;
		font-size: 0.82rem;
	}
}

@media screen and (max-width: 575px) {
	.homepage-cost-comparison__filters {
		grid-template-columns: 1fr;
	}

	.homepage-cost-comparison__chips {
		grid-template-columns: repeat(2, max-content);
	}

	.homepage-cost-comparison__field--currency {
		max-width: 150px;
	}

	.homepage-cost-comparison__select--currency {
		justify-self: start;
		max-width: 150px;
		min-width: 132px;
	}

	.homepage-cost-comparison__field--currency .homepage-cost-comparison__select-wrap {
		max-width: 150px;
		min-width: 132px;
	}

	.homepage-cost-comparison__axis {
		font-size: 0.72rem;
	}

	.homepage-cost-comparison__mobile-legend {
		align-items: flex-start;
		flex-direction: column;
		gap: 10px;
	}
}

@media screen and (max-width: 420px) {
	.homepage-cost-comparison {
		--cost-country-col: 82px;
		--cost-label-bar-min: 88px;
		--cost-value-space: 42px;
	}

	.homepage-cost-comparison > .container {
		max-width: min(100% - 28px, 420px);
	}

	.homepage-cost-comparison__country {
		font-size: 0.8rem;
	}

	.homepage-cost-comparison__axis {
		gap: 4px;
	}
}

.homepage-treatment-showcase {
	background: linear-gradient(180deg, #f7fbff 0%, #ffffff 42%, #f9fcff 100%);
	color: #071225;
	overflow: hidden;
	padding: clamp(56px, 7vw, 104px) 0;
	position: relative;
}

.homepage-treatment-showcase::before {
	background: linear-gradient(
		90deg,
		rgba(23, 105, 170, 0.1),
		rgba(242, 139, 46, 0.18),
		rgba(23, 105, 170, 0.04)
	);
	content: '';
	height: 1px;
	left: max(
		var(--site-container-gutter, 28px),
		calc((100vw - var(--site-container-max, 1540px)) / 2)
	);
	pointer-events: none;
	position: absolute;
	right: max(
		var(--site-container-gutter, 28px),
		calc((100vw - var(--site-container-max, 1540px)) / 2)
	);
	top: clamp(28px, 4vw, 48px);
}

.homepage-treatment-showcase__header {
	align-items: end;
	display: flex;
	gap: clamp(18px, 3vw, 42px);
	justify-content: space-between;
	margin-bottom: clamp(26px, 3.5vw, 46px);
}

.homepage-treatment-showcase__kicker {
	align-items: center;
	color: #8b4b14;
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: var(--weight-display);
	gap: 10px;
	letter-spacing: 0.16em;
	margin-bottom: 12px;
	text-transform: uppercase;
}

.homepage-treatment-showcase__kicker::before {
	background: #f28b2e;
	border-radius: 999px;
	content: '';
	display: inline-block;
	height: 7px;
	width: 7px;
}

.homepage-treatment-showcase h2 {
	color: #081b31;
	font-size: clamp(2rem, 1.42rem + 1.75vw, 3.45rem);
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.04;
	margin: 0;
	max-width: 11.2em;
}

.homepage-treatment-showcase__view-all {
	align-items: center;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(47, 128, 196, 0.28);
	border-radius: 999px;
	box-shadow:
		0 10px 24px rgba(16, 47, 79, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.78);
	color: var(--color-primary-dark) !important;
	display: inline-flex;
	flex: 0 0 auto;
	font-weight: var(--weight-display);
	gap: 12px;
	min-height: 50px;
	padding: 0 8px 0 22px;
	text-decoration: none !important;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease,
		color 0.18s ease,
		transform 0.18s ease;
}

.homepage-treatment-showcase__view-all:hover,
.homepage-treatment-showcase__view-all:focus {
	background: #fafdff;
	border-color: rgba(23, 105, 170, 0.48);
	box-shadow:
		0 14px 30px rgba(16, 47, 79, 0.12),
		inset 0 1px 0 rgba(255, 255, 255, 0.9);
	color: #0b345d !important;
	transform: translateY(-1px);
}

.homepage-treatment-showcase__view-all span {
	white-space: nowrap;
}

.homepage-treatment-showcase__view-all i,
.homepage-treatment-showcase__view-all svg {
	align-items: center;
	background: linear-gradient(135deg, #1769aa 0%, #0f8a91 100%);
	border-radius: 999px;
	box-shadow: 0 8px 16px rgba(23, 105, 170, 0.2);
	color: #fff;
	display: inline-flex;
	height: 36px;
	justify-content: center;
	padding: 9px;
	stroke-width: 2.6;
	transition:
		box-shadow 0.18s ease,
		transform 0.18s ease;
	width: 36px;
}

.homepage-treatment-showcase__view-all svg {
	height: 36px;
	stroke-width: 2.6;
	width: 36px;
}

.homepage-treatment-showcase__view-all:hover i,
.homepage-treatment-showcase__view-all:focus i,
.homepage-treatment-showcase__view-all:hover svg,
.homepage-treatment-showcase__view-all:focus svg {
	box-shadow: 0 10px 18px rgba(23, 105, 170, 0.26);
	transform: translateX(2px);
}

.homepage-treatment-showcase__grid {
	display: grid;
	gap: clamp(14px, 1.5vw, 22px);
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.homepage-treatment-showcase-card {
	aspect-ratio: 1.32;
	background: #071225;
	border-radius: 16px;
	box-shadow: 0 20px 42px rgba(16, 47, 79, 0.16);
	color: #fff !important;
	display: block;
	isolation: isolate;
	min-height: 248px;
	overflow: hidden;
	position: relative;
	text-decoration: none !important;
	transition:
		box-shadow 0.22s ease,
		transform 0.22s ease;
}

.homepage-treatment-showcase-card:hover,
.homepage-treatment-showcase-card:focus {
	box-shadow: 0 28px 54px rgba(16, 47, 79, 0.2);
	color: #fff !important;
	transform: translateY(-2px);
}

.homepage-treatment-showcase-card:focus-visible,
.homepage-treatment-showcase__view-all:focus-visible {
	outline: 3px solid rgba(47, 143, 211, 0.36);
	outline-offset: 5px;
}

.homepage-treatment-showcase-card::before {
	background: linear-gradient(
		180deg,
		rgba(7, 18, 37, 0.14) 0%,
		rgba(7, 18, 37, 0.12) 42%,
		rgba(7, 18, 37, 0.82) 100%
	);
	content: '';
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 1;
}

.homepage-treatment-showcase-card img {
	display: block;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform 0.3s ease;
	width: 100%;
	z-index: 0;
}

.homepage-treatment-showcase-card:hover img,
.homepage-treatment-showcase-card:focus img {
	transform: scale(1.035);
}

.homepage-treatment-showcase-card--women img {
	object-position: center 32%;
}

.homepage-treatment-showcase-card--ent img {
	object-position: 58% center;
}

.homepage-treatment-showcase-card--urology img {
	object-position: center 34%;
}

.homepage-treatment-showcase-card--gastro img {
	object-position: 48% center;
}

.homepage-treatment-showcase-card--oncology img {
	object-position: 54% center;
}

.homepage-treatment-showcase-card--orthopedics img {
	object-position: 62% center;
}

.homepage-treatment-showcase-card__content {
	align-items: end;
	display: grid;
	gap: 14px;
	grid-template-columns: minmax(0, 1fr) auto;
	inset: auto 0 0 0;
	padding: clamp(14px, 1.2vw, 20px);
	position: absolute;
	z-index: 2;
}

.homepage-treatment-showcase-card__title {
	color: #fff;
	display: block;
	font-size: clamp(1.06rem, 0.96rem + 0.38vw, 1.34rem);
	font-weight: var(--weight-emphasis);
	letter-spacing: 0;
	line-height: 1.1;
	max-width: 15em;
	text-shadow: 0 2px 8px rgba(7, 18, 37, 0.55);
}

.homepage-treatment-showcase-card__arrow {
	align-items: center;
	background: rgba(255, 255, 255, 0.16);
	border: 1px solid rgba(255, 255, 255, 0.32);
	border-radius: 999px;
	color: #fff;
	display: inline-flex;
	flex: 0 0 44px;
	height: 44px;
	justify-content: center;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		color 0.18s ease,
		transform 0.18s ease;
	width: 44px;
}

.homepage-treatment-showcase-card:hover .homepage-treatment-showcase-card__arrow,
.homepage-treatment-showcase-card:focus .homepage-treatment-showcase-card__arrow {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
	transform: translateX(3px);
}

.homepage-treatment-showcase-card__arrow svg {
	height: 20px;
	stroke-width: 3;
	width: 20px;
}

@media screen and (max-width: 1199px) {
	.homepage-treatment-showcase__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 767px) {
	.homepage-treatment-showcase {
		padding: 48px 0 58px;
	}

	.homepage-treatment-showcase__header {
		align-items: flex-start;
		flex-direction: column;
		gap: 18px;
	}

	.homepage-treatment-showcase__view-all {
		min-height: 46px;
	}

	.homepage-treatment-showcase__grid {
		grid-template-columns: 1fr;
	}

	.homepage-treatment-showcase-card {
		aspect-ratio: 1.22;
		min-height: 250px;
	}

	.homepage-treatment-showcase-card__content {
		padding: 15px;
	}
}

@media screen and (max-width: 420px) {
	.homepage-treatment-showcase-card {
		aspect-ratio: auto;
		min-height: 232px;
	}

	.homepage-treatment-showcase-card__arrow {
		height: 40px;
		width: 40px;
	}

	.homepage-treatment-showcase-card__content {
		gap: 10px;
	}

	.homepage-treatment-showcase-card__title {
		font-size: 1.06rem;
	}
}

.homepage-ivf-showcase {
	background: #fff;
	color: #071225;
	overflow: hidden;
	padding: clamp(54px, 7vw, 96px) 0 clamp(62px, 8vw, 112px);
}

.homepage-ivf-feature-grid {
	display: grid;
	gap: clamp(18px, 1.6vw, 26px);
	grid-template-columns: minmax(280px, 1fr) minmax(300px, 1fr) minmax(280px, 1fr);
}

.homepage-ivf-feature-card {
	background: #fff;
	border: 1px solid rgba(216, 232, 245, 0.72);
	border-radius: 16px;
	box-shadow: 0 22px 48px rgba(16, 47, 79, 0.09);
	color: #071225;
	display: block;
	min-width: 0;
	overflow: hidden;
	position: relative;
	text-decoration: none !important;
	transition:
		box-shadow 0.2s ease,
		transform 0.2s ease;
}

.homepage-ivf-feature-card:hover,
.homepage-ivf-feature-card:focus {
	color: #071225;
	box-shadow: 0 26px 58px rgba(16, 47, 79, 0.14);
	transform: translateY(-2px);
}

.homepage-ivf-feature-card:focus-visible,
.homepage-ivf-destination-card:focus-visible,
.homepage-ivf-view-more:focus-visible {
	outline: 3px solid rgba(47, 143, 211, 0.36);
	outline-offset: 5px;
}

.homepage-ivf-feature-card img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.homepage-ivf-feature-card__content {
	position: relative;
	z-index: 2;
}

.homepage-ivf-feature-card h2,
.homepage-ivf-feature-card h3 {
	color: #071225;
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	margin: 0;
}

.homepage-ivf-feature-card h2 {
	font-size: clamp(1.45rem, 1.15rem + 0.9vw, 2rem);
	line-height: 1.08;
	max-width: 13.5em;
}

.homepage-ivf-feature-card h3 {
	font-size: clamp(1.18rem, 1rem + 0.58vw, 1.62rem);
	line-height: 1.08;
	max-width: 13em;
}

.homepage-ivf-link {
	align-items: center;
	color: #071225;
	display: inline-flex;
	font-size: 0.9rem;
	font-weight: var(--weight-heading);
	gap: 5px;
	line-height: 1.2;
	margin-top: 10px;
}

.homepage-ivf-link svg {
	height: 17px;
	stroke-width: 3;
	width: 17px;
}

.homepage-ivf-feature-card--destinations {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	min-height: clamp(315px, 23vw, 385px);
	padding: clamp(18px, 1.75vw, 28px);
	background: #eaf5ff;
}

.homepage-ivf-feature-card--destinations::after {
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.9) 0%,
		rgba(255, 255, 255, 0.46) 26%,
		rgba(255, 255, 255, 0.16) 52%,
		rgba(255, 255, 255, 0.5) 78%,
		rgba(255, 255, 255, 0.92) 100%
	);
	content: '';
	inset: 0;
	position: absolute;
	z-index: 1;
}

.homepage-ivf-polaroids {
	align-items: center;
	display: flex;
	flex: 1 1 auto;
	justify-content: center;
	min-height: 148px;
	padding: clamp(14px, 1.7vw, 26px) 0;
	position: relative;
}

.homepage-ivf-polaroid {
	background: #fff;
	border: 6px solid #fff;
	border-radius: 16px;
	box-shadow: 0 14px 26px rgba(16, 47, 79, 0.14);
	display: block;
	height: clamp(82px, 5.4vw, 104px);
	overflow: hidden;
	position: relative;
	width: clamp(82px, 5.4vw, 104px);
}

.homepage-ivf-polaroid img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.homepage-ivf-polaroid--one {
	transform: rotate(-1deg) translateX(12px);
	z-index: 1;
}

.homepage-ivf-polaroid--two {
	transform: rotate(-12deg) translateY(-2px);
	z-index: 2;
}

.homepage-ivf-polaroid--three {
	transform: rotate(15deg) translateX(-12px);
	z-index: 3;
}

.homepage-ivf-feature-card--destinations .homepage-ivf-feature-card__media {
	position: absolute;
	inset: 0;
	margin: 0;
	z-index: 0;
}

.homepage-ivf-feature-card--destinations .homepage-ivf-feature-card__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.homepage-ivf-feature-card--destinations p {
	color: #18253a;
	font-size: clamp(0.84rem, 0.8rem + 0.16vw, 0.96rem);
	font-weight: var(--weight-semibold);
	line-height: 1.32;
	margin: 0;
	max-width: 39ch;
	position: relative;
	z-index: 2;
}

.homepage-ivf-feature-stack {
	display: grid;
	gap: clamp(12px, 1.2vw, 18px);
	grid-template-rows: minmax(145px, 1fr) minmax(145px, 1fr);
	min-width: 0;
}

.homepage-ivf-feature-card--hospital,
.homepage-ivf-feature-card--coordination,
.homepage-ivf-feature-card--treatments {
	min-height: 0;
}

.homepage-ivf-feature-card--hospital,
.homepage-ivf-feature-card--treatments {
	background: #eaf5ff;
}

.homepage-ivf-feature-card--hospital img,
.homepage-ivf-feature-card--treatments img {
	inset: 0;
	object-position: center;
	position: absolute;
}

.homepage-ivf-feature-card--hospital .homepage-ivf-feature-card__content,
.homepage-ivf-feature-card--treatments .homepage-ivf-feature-card__content {
	padding: clamp(17px, 1.55vw, 24px);
	position: relative;
	z-index: 2;
}

.homepage-ivf-feature-card--coordination {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(130px, 0.9fr);
	min-height: 160px;
}

.homepage-ivf-feature-card--coordination img {
	align-self: end;
	grid-column: 2;
	grid-row: 1;
	height: 100%;
	object-position: center bottom;
}

.homepage-ivf-feature-card--coordination .homepage-ivf-feature-card__content {
	align-self: start;
	grid-column: 1 / -1;
	grid-row: 1;
	padding: clamp(17px, 1.55vw, 24px);
	width: min(68%, 420px);
}

.homepage-ivf-feature-card--treatments {
	min-height: clamp(315px, 23vw, 385px);
}

.homepage-ivf-destination-row {
	align-items: stretch;
	display: grid;
	gap: clamp(28px, 4vw, 58px);
	grid-template-columns: minmax(250px, 0.72fr) minmax(0, 1.8fr);
	margin-top: clamp(32px, 4vw, 56px);
}

.homepage-ivf-destination-intro {
	align-content: space-between;
	display: grid;
	grid-template-rows: auto auto 1fr auto;
	justify-items: start;
	min-height: 100%;
}

.homepage-ivf-destination-kicker {
	color: #2d7f64;
	display: block;
	font-size: 0.78rem;
	font-weight: var(--weight-semibold);
	letter-spacing: 0.12em;
	margin-bottom: 13px;
	text-transform: uppercase;
}

.homepage-ivf-destination-intro h2 {
	color: #071225;
	font-size: clamp(1.42rem, 1.14rem + 0.9vw, 2rem);
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	line-height: 1.14;
	margin: 0;
	max-width: 11.5em;
}

.homepage-ivf-destination-intro p {
	color: #425066;
	font-size: clamp(1rem, 0.94rem + 0.22vw, 1.1rem);
	font-weight: var(--weight-regular);
	line-height: 1.52;
	margin: clamp(16px, 1.6vw, 22px) 0 clamp(24px, 2.4vw, 34px);
	max-width: 34ch;
}

.homepage-ivf-view-more {
	align-items: center;
	background: #1769aa;
	border: 1px solid #1769aa;
	border-radius: 999px;
	box-shadow: 0 14px 30px rgba(23, 105, 170, 0.2);
	color: #fff !important;
	display: inline-flex;
	font-weight: var(--weight-semibold);
	justify-content: center;
	min-height: 48px;
	min-width: min(190px, 100%);
	padding: 0 28px;
	text-decoration: none !important;
	transition:
		background-color 0.18s ease,
		box-shadow 0.18s ease,
		transform 0.18s ease;
}

.homepage-ivf-view-more:hover,
.homepage-ivf-view-more:focus {
	background: #10578e;
	border-color: #10578e;
	box-shadow: 0 16px 34px rgba(23, 105, 170, 0.26);
	transform: translateY(-1px);
}

.homepage-ivf-destination-carousel {
	min-width: 0;
	position: relative;
}

.homepage-ivf-destination-track {
	display: grid;
	gap: clamp(9px, 0.85vw, 14px);
	grid-template-columns: repeat(4, minmax(0, 1fr));
	height: 100%;
}

.homepage-ivf-destination-card {
	aspect-ratio: 0.82;
	background: #071225;
	border-radius: 16px;
	box-shadow: 0 20px 42px rgba(16, 47, 79, 0.16);
	color: #fff !important;
	display: block;
	min-height: clamp(205px, 18vw, 275px);
	overflow: hidden;
	position: relative;
	text-decoration: none !important;
	transition:
		box-shadow 0.18s ease,
		transform 0.18s ease;
}

.homepage-ivf-destination-card:hover,
.homepage-ivf-destination-card:focus {
	box-shadow: 0 28px 54px rgba(16, 47, 79, 0.2);
	color: #fff !important;
	transform: translateY(-2px);
}

.homepage-ivf-destination-card::after {
	background: linear-gradient(
		180deg,
		rgba(7, 18, 37, 0.14) 0%,
		rgba(7, 18, 37, 0.12) 42%,
		rgba(7, 18, 37, 0.82) 100%
	);
	content: '';
	inset: 0;
	position: absolute;
	z-index: 1;
}

.homepage-ivf-destination-card img {
	display: block;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform 0.3s ease;
	width: 100%;
}

.homepage-ivf-destination-card:hover img,
.homepage-ivf-destination-card:focus img {
	transform: scale(1.035);
}

.homepage-ivf-destination-card:first-child img {
	object-position: 70% center;
}

.homepage-ivf-destination-card__rank {
	color: #fff;
	display: block;
	font-size: clamp(1.28rem, 1.02rem + 0.64vw, 1.68rem);
	font-weight: var(--weight-regular);
	left: clamp(14px, 1.3vw, 20px);
	line-height: 1;
	position: absolute;
	text-shadow: 0 3px 10px rgba(7, 18, 37, 0.5);
	top: clamp(14px, 1.3vw, 20px);
	z-index: 2;
}

.homepage-ivf-destination-card__content {
	bottom: 0;
	display: grid;
	gap: 5px;
	left: 0;
	padding: clamp(12px, 1vw, 16px);
	position: absolute;
	right: 0;
	z-index: 2;
}

.homepage-ivf-destination-card__name {
	color: #fff;
	display: block;
	font-size: clamp(0.88rem, 0.82rem + 0.22vw, 1rem);
	font-weight: var(--weight-heading);
	line-height: 1.12;
	margin: 0;
	text-shadow: 0 2px 8px rgba(7, 18, 37, 0.55);
}

.homepage-ivf-destination-card__copy {
	color: rgba(255, 255, 255, 0.84);
	display: block;
	display: -webkit-box;
	font-size: clamp(0.66rem, 0.63rem + 0.1vw, 0.74rem);
	font-weight: var(--weight-regular);
	line-height: 1.28;
	margin: 0;
	overflow: hidden;
	text-shadow: 0 2px 8px rgba(7, 18, 37, 0.55);
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

@media screen and (max-width: 1199px) {
	.homepage-ivf-feature-grid {
		grid-template-columns: 1fr 1fr;
	}

	.homepage-ivf-feature-card--destinations,
	.homepage-ivf-feature-card--treatments {
		min-height: 340px;
	}

	.homepage-ivf-feature-card--treatments {
		grid-column: 1 / -1;
		min-height: 260px;
	}

	.homepage-ivf-destination-row {
		align-items: start;
		grid-template-columns: 1fr;
	}

	.homepage-ivf-destination-intro {
		align-content: start;
		align-items: end;
		display: grid;
		gap: 24px;
		grid-template-columns: minmax(0, 1fr) auto;
		grid-template-rows: auto auto auto;
		justify-content: stretch;
		min-height: 0;
	}

	.homepage-ivf-destination-kicker,
	.homepage-ivf-destination-intro h2 {
		grid-column: 1;
		margin-bottom: 0;
		max-width: 16em;
	}

	.homepage-ivf-destination-intro p {
		grid-column: 1;
		margin-bottom: 0;
		max-width: 52ch;
	}

	.homepage-ivf-view-more {
		grid-column: 2;
		grid-row: 2 / span 2;
	}

	.homepage-ivf-destination-track {
		grid-template-columns: repeat(4, minmax(145px, 1fr));
	}
}

@media screen and (max-width: 767px) {
	.homepage-ivf-showcase {
		padding: 42px 0 58px;
	}

	.homepage-ivf-feature-grid,
	.homepage-ivf-feature-stack {
		grid-template-columns: 1fr;
	}

	.homepage-ivf-feature-card--destinations,
	.homepage-ivf-feature-card--treatments {
		min-height: 0;
	}

	.homepage-ivf-polaroids {
		justify-content: flex-start;
		min-height: 132px;
		padding: 16px 0 18px;
	}

	.homepage-ivf-feature-card--destinations,
	.homepage-ivf-feature-card--hospital,
	.homepage-ivf-feature-card--coordination,
	.homepage-ivf-feature-card--treatments {
		min-height: 220px;
	}

	.homepage-ivf-feature-card--coordination {
		grid-template-columns: 1fr;
	}

	.homepage-ivf-feature-card--coordination img {
		grid-column: 1;
		opacity: 0.45;
		position: absolute;
	}

	.homepage-ivf-feature-card--coordination .homepage-ivf-feature-card__content {
		width: 100%;
	}

	.homepage-ivf-destination-row {
		margin-top: 30px;
	}

	.homepage-ivf-destination-intro {
		align-items: flex-start;
		flex-direction: column;
		gap: 0;
		grid-template-columns: 1fr;
		grid-template-rows: auto;
	}

	.homepage-ivf-destination-kicker,
	.homepage-ivf-destination-intro h2,
	.homepage-ivf-destination-intro p,
	.homepage-ivf-view-more {
		grid-column: auto;
		grid-row: auto;
	}

	.homepage-ivf-destination-intro p {
		margin-bottom: 24px;
	}

	.homepage-ivf-view-more {
		min-height: 46px;
		min-width: 180px;
	}

	.homepage-ivf-destination-track {
		display: flex;
		gap: 14px;
		margin: 0 -20px;
		overflow-x: auto;
		padding: 2px 20px 12px;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
	}

	.homepage-ivf-destination-card {
		flex: 0 0 min(62vw, 215px);
		min-height: 255px;
		scroll-snap-align: start;
	}
}

@media screen and (max-width: 420px) {
	.homepage-ivf-feature-card--destinations {
		padding: 24px;
	}

	.homepage-ivf-polaroid {
		height: 104px;
		width: 104px;
	}

	.homepage-ivf-feature-card--hospital .homepage-ivf-feature-card__content,
	.homepage-ivf-feature-card--coordination .homepage-ivf-feature-card__content,
	.homepage-ivf-feature-card--treatments .homepage-ivf-feature-card__content {
		padding: 24px;
	}
}

/* Public subpage width system
   Keeps homepage/nav containers wide while giving inner pages a controlled
   editorial measure on large desktop screens. */
.about-page .container,
.authorization-page .container,
.article-hero .container,
.article-body-wrapper .container,
.faq-page > .container,
.thankyou-confirmation .container,
.bg-primary-gradient > .container,
.bg-primary-gradient + .section-padding > .container {
	max-width: var(--public-page-max);
}

.appointment-hero .container {
	max-width: var(--site-container-max);
}

.thankyou-hero .container {
	max-width: var(--site-container-max);
}

.faq-hero .container {
	max-width: var(--site-container-max);
}

.condition-page-shell > .container {
	max-width: var(--site-container-max);
}

.listing-section.condition-page-shell > .container {
	max-width: var(--site-container-max);
}

.how-it-works-shell > .container {
	max-width: var(--site-container-max);
}

.about-hero .row,
.safety-hero .row,
.authorization-page .bg-primary-gradient .row,
.article-hero-grid,
.article-body-container {
	max-width: var(--public-page-max);
}

.about-page .container,
.about-hero .row {
	max-width: var(--site-container-max);
}

.article-hero-copy,
.article-hero-grid--no-image .article-hero-copy,
.about-section-heading,
.safety-section-heading,
.credential-verify__body,
.faq-page__content {
	max-width: var(--public-content-max);
}

.article-hero-summary,
.about-hero-copy,
.safety-hero-copy,
.about-lead,
.safety-lead,
.content-box,
.article-content,
.article-body-container {
	max-width: var(--public-reading-max);
}

.article-body-wrapper .article-body-container {
	max-width: var(--site-container-max);
}

.article-body-wrapper .content-box {
	max-width: none;
}

.article-body-wrapper .article-content {
	max-width: min(100%, 960px);
}

.about-section,
.safety-section,
.authorization-page .section-padding,
.faq-page.section-padding,
.article-body-wrapper.section-padding,
.article-final-cta.section-padding {
	padding-top: var(--public-section-y) !important;
	padding-bottom: var(--public-section-y) !important;
}

.article-hero {
	border-width: 0 0 1px;
	padding: clamp(34px, 5vw, 66px) 0 clamp(42px, 5.5vw, 78px);
}

.article-hero-grid {
	margin: 0;
}

.article-hero-grid--no-image {
	max-width: var(--public-content-max);
}

.how-it-works-shell .article-hero-grid,
.how-it-works-shell .article-hero-grid--no-image {
	max-width: var(--site-container-max);
}

.faq-hero .article-hero-grid,
.faq-hero .article-hero-grid--no-image {
	max-width: var(--site-container-max);
}

.faq-hero .article-hero-grid {
	align-items: center;
	gap: clamp(28px, 4vw, 56px);
	width: 100%;
}

.faq-hero .article-hero-copy {
	max-width: min(100%, var(--public-content-max));
}

.faq-hero-image {
	justify-self: stretch;
	position: relative;
}

.faq-hero-image::before {
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.18), rgba(143, 192, 238, 0.1));
	border-radius: 22px;
	content: '';
	inset: 0;
	position: absolute;
	transform: translate(12px, 12px);
	z-index: 0;
}

.faq-hero-image img {
	aspect-ratio: 16 / 9;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 22px;
	box-shadow: 0 24px 56px rgba(4, 18, 36, 0.22);
	display: block;
	height: 100%;
	max-height: none;
	object-fit: cover;
	position: relative;
	width: 100%;
	z-index: 1;
}

@media (min-width: 992px) {
	.faq-hero .article-hero-grid:not(.article-hero-grid--no-image) {
		grid-template-columns: minmax(0, 1fr) minmax(360px, 560px);
	}
}

@media screen and (max-width: 991px) {
	.faq-hero .article-hero-copy,
	.faq-hero h1,
	.faq-hero .article-hero-summary {
		max-width: none;
	}

	.faq-hero-image {
		max-width: 680px;
	}
}

@media screen and (max-width: 575px) {
	.faq-hero-image::before {
		transform: translate(8px, 8px);
	}

	.faq-hero-image img {
		border-radius: 18px;
	}
}

.article-hero h1 {
	max-width: var(--public-content-max);
}

.article-hero-summary {
	margin-bottom: 0;
}

.article-trust-meta,
.article-hero-actions {
	max-width: var(--public-content-max);
}

.blog-post-hero.article-hero .container,
.blog-post-hero .article-hero-grid {
	max-width: var(--site-container-max);
}

.blog-post-hero.article-hero {
	background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
	border-bottom: 1px solid rgba(188, 214, 234, 0.58);
	overflow: hidden;
	position: relative;
}

.blog-post-hero.article-hero::before {
	background: linear-gradient(90deg, rgba(23, 105, 170, 0.28), rgba(15, 138, 145, 0.18), rgba(23, 105, 170, 0.08));
	content: '';
	height: 1px;
	left: max(var(--site-container-gutter, 28px), calc((100vw - var(--site-container-max, 1540px)) / 2));
	pointer-events: none;
	position: absolute;
	right: max(var(--site-container-gutter, 28px), calc((100vw - var(--site-container-max, 1540px)) / 2));
	top: 0;
}

.blog-post-hero .article-breadcrumb {
	position: relative;
	z-index: 1;
}

.blog-post-hero .article-breadcrumb li {
	color: #6a7f91;
}

.blog-post-hero .article-breadcrumb li + li::before {
	color: rgba(95, 113, 132, 0.62);
}

.blog-post-hero .article-breadcrumb a {
	color: var(--color-primary);
}

.blog-post-hero .article-breadcrumb a:hover,
.blog-post-hero .article-breadcrumb a:focus {
	color: var(--color-primary-dark);
}

.blog-post-hero .article-breadcrumb [aria-current] {
	color: #344d66;
}

.blog-post-hero .article-hero-grid {
	align-items: center;
	gap: clamp(28px, 4vw, 52px);
	width: 100%;
}

.blog-post-hero .article-hero-copy {
	max-width: none;
}

.blog-post-hero .article-category-badge {
	background: var(--color-primary-soft);
	border: 1px solid rgba(23, 105, 170, 0.16);
	color: var(--color-primary-dark);
	letter-spacing: 0;
	margin-bottom: 14px;
}

.blog-post-hero .article-category-badge:hover,
.blog-post-hero .article-category-badge:focus {
	background: #dff0ff;
	color: var(--color-primary-dark);
}

.blog-post-hero h1 {
	color: #081b31;
	font-weight: var(--weight-display);
	max-width: 1080px;
	text-wrap: balance;
}

.blog-post-hero .article-hero-summary {
	color: #44596a;
	font-size: clamp(1.05rem, 1rem + 0.18vw, 1.2rem);
	line-height: 1.58;
	max-width: 840px;
	padding-bottom: 4px;
}

.blog-post-hero .article-trust-meta,
.blog-post-hero .article-hero-actions {
	max-width: 940px;
}

.blog-post-hero .article-trust-meta {
	color: #5f7184;
	gap: 8px 18px;
	margin-bottom: 22px;
}

.blog-post-hero .article-trust-meta a {
	color: var(--color-primary-dark);
}

.blog-post-hero .article-hero-actions {
	gap: 12px 18px;
}

.blog-post-hero .article-hero-btn {
	align-items: center;
	background: var(--color-primary);
	border: 1px solid var(--color-primary);
	border-radius: 999px;
	color: #fff !important;
	display: inline-flex;
	justify-content: center;
	min-height: 48px;
	padding: 13px 26px;
	text-decoration: none;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		color 0.18s ease,
		transform 0.18s ease;
	white-space: nowrap;
}

.blog-post-hero .article-hero-btn:hover,
.blog-post-hero .article-hero-btn:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff !important;
	transform: translateY(-1px);
}

.blog-post-hero .article-hero-btn:focus-visible {
	outline: 3px solid rgba(47, 143, 211, 0.24);
	outline-offset: 3px;
}

.blog-post-hero .article-hero-actions .social-share li a {
	background: transparent;
	border: 0;
	box-shadow: none;
}

.blog-post-hero .article-hero-actions .social-share li a svg {
	stroke: var(--color-primary);
}

.blog-post-hero .article-hero-actions .social-share li a:hover,
.blog-post-hero .article-hero-actions .social-share li a:focus {
	background: transparent;
	border-color: transparent;
	box-shadow: none;
}

.blog-post-hero .article-hero-actions .social-share li a:hover svg,
.blog-post-hero .article-hero-actions .social-share li a:focus svg {
	stroke: var(--color-primary-dark);
}

.blog-post-hero .article-hero-image {
	position: relative;
}

.blog-post-hero .article-hero-image::before {
	background: linear-gradient(135deg, rgba(23, 105, 170, 0.18), rgba(15, 138, 145, 0.12));
	border-radius: 18px;
	content: '';
	inset: 0;
	position: absolute;
	transform: translate(12px, 12px);
	z-index: 0;
}

.blog-post-hero .article-hero-image img {
	aspect-ratio: 4 / 3;
	border: 1px solid rgba(47, 128, 196, 0.18);
	border-radius: 18px;
	box-shadow: 0 20px 48px rgba(16, 47, 79, 0.13);
	display: block;
	height: 100%;
	max-height: none;
	object-fit: cover;
	position: relative;
	width: 100%;
	z-index: 1;
}

@media (min-width: 992px) {
	.blog-post-hero .article-hero-grid:not(.article-hero-grid--no-image) {
		grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
	}
}

@media screen and (max-width: 991px) {
	.blog-post-hero .article-hero-copy,
	.blog-post-hero h1,
	.blog-post-hero .article-hero-summary,
	.blog-post-hero .article-trust-meta,
	.blog-post-hero .article-hero-actions {
		max-width: none;
	}

	.blog-post-hero .article-hero-image {
		max-width: 560px;
	}

	.blog-post-hero .article-hero-image img {
		aspect-ratio: 16 / 9;
	}
}

@media screen and (max-width: 575px) {
	.blog-post-hero.article-hero {
		padding-top: 24px;
	}

	.blog-post-hero .article-hero-actions {
		align-items: stretch;
		gap: 14px;
	}

	.blog-post-hero .article-hero-btn {
		width: 100%;
	}

	.blog-post-hero .article-hero-actions .social-share {
		justify-content: flex-start;
	}
}

.authorization-page .bg-primary-gradient,
.bg-primary-gradient {
	background: linear-gradient(180deg, #ffffff 0%, #f6fbff 100%) !important;
	border-bottom: 1px solid var(--color-line-soft);
	color: var(--color-body);
}

.authorization-page .bg-primary-gradient h1,
.bg-primary-gradient h1 {
	color: var(--color-ink-strong);
}

.authorization-page .bg-primary-gradient .f1,
.bg-primary-gradient .f1 {
	color: var(--color-muted);
	max-width: var(--public-reading-max);
}

.bg-primary-gradient .breadcrumb,
.bg-primary-gradient .breadcrumb a,
.bg-primary-gradient .breadcrumb .active {
	color: var(--color-primary-dark);
}

.bg-primary-gradient .breadcrumb .breadcrumb-item:not(:first-child):before {
	color: var(--color-muted);
}

.bg-primary-gradient .row > [class*='col-'] {
	min-width: 0;
}

.bg-primary-gradient .row > .col-md-6:first-child,
.bg-primary-gradient .row > .col-md-8:first-child {
	max-width: min(100%, var(--public-content-max));
}

.bg-primary-gradient .row > .col-md-6 + .col-md-6 {
	max-width: min(100%, 520px);
}

.bg-primary-gradient .search-form {
	border-color: var(--color-line-soft);
	box-shadow: 0 12px 28px rgba(16, 47, 79, 0.06);
}

.bg-primary-gradient .btn-ghost-white {
	background: var(--color-primary);
	border-color: var(--color-primary);
	box-shadow: 0 12px 24px rgba(23, 105, 170, 0.16);
	color: #fff !important;
}

.bg-primary-gradient .btn-ghost-white:hover,
.bg-primary-gradient .btn-ghost-white:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff !important;
}

.bg-primary-gradient .letter-box {
	grid-template-columns: repeat(auto-fill, minmax(42px, 1fr));
	max-width: 520px;
}

.bg-primary-gradient .letter-box li a,
.bg-primary .letter-box li a {
	width: 42px;
	height: 42px;
	background: #fff;
	border-color: var(--color-line-soft);
	color: var(--color-primary-dark);
	font-weight: var(--weight-semibold);
}

.bg-primary-gradient .letter-box li a.active,
.bg-primary .letter-box li a.active {
	background: var(--color-primary);
	color: #fff;
}

.bg-primary-gradient + .section-padding > .container > .row > .col-md-8,
.bg-primary-gradient + .section-padding > .container > .row > .col-lg-7 {
	max-width: min(100%, var(--public-content-max));
}

.bg-primary-gradient + .section-padding > .container > .row > .col-md-8 + [class*='col-'],
.bg-primary-gradient + .section-padding > .container > .row > .col-lg-7 + [class*='col-'] {
	min-width: 0;
}

.sitemap-list,
.post-list,
.section-padding .list-unstyled.d-flex.flex-column {
	max-width: var(--public-content-max);
}

.section-padding .list-unstyled.d-flex.flex-column > li > a.text-body.d-flex {
	align-items: flex-start;
	gap: 18px;
	min-width: 0;
}

.section-padding .list-unstyled.d-flex.flex-column > li > a.text-body.d-flex .ml-3 {
	margin-left: 0 !important;
	min-width: 0;
}

.listing-thumb {
	flex: 0 0 clamp(116px, 13vw, 180px);
	width: clamp(116px, 13vw, 180px);
	max-width: clamp(116px, 13vw, 180px);
}

.credential-verify,
.credential-grid {
	max-width: var(--public-page-max);
}

.authorization-page .container,
.authorization-page .bg-primary-gradient > .container,
.authorization-page .bg-primary-gradient + .section-padding > .container,
.authorization-page .bg-primary-gradient .row,
.authorization-page .credential-verify,
.authorization-page .credential-grid {
	max-width: var(--site-container-max);
}

@media screen and (max-width: 991px) {
	.about-hero .row,
	.safety-hero .row,
	.authorization-page .bg-primary-gradient .row,
	.article-hero-grid {
		max-width: none;
	}

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

	.bg-primary-gradient .row > .col-md-6:first-child,
	.bg-primary-gradient .row > .col-md-8:first-child,
	.bg-primary-gradient .row > .col-md-6 + .col-md-6 {
		max-width: none;
	}
}

@media screen and (max-width: 575px) {
	.article-hero,
	.authorization-page .bg-primary-gradient {
		padding-top: 28px !important;
		padding-bottom: 42px !important;
	}

	.bg-primary-gradient .letter-box {
		grid-template-columns: repeat(auto-fill, minmax(38px, 1fr));
	}

	.bg-primary-gradient .letter-box li a,
	.bg-primary .letter-box li a {
		width: 38px;
		height: 38px;
	}

	.section-padding .list-unstyled.d-flex.flex-column > li > a.text-body.d-flex {
		flex-direction: column;
	}

	.listing-thumb {
		flex-basis: auto;
		max-width: 100%;
		width: 100%;
	}
}

.homepage-inline-cta__title-accent,
.article-trust-meta a,
.article-breadcrumb a:hover,
.article-final-cta__secondary:hover,
.about-breadcrumb a,
.about-breadcrumb .breadcrumb-item,
.about-breadcrumb .breadcrumb-item.active,
.safety-breadcrumb a,
.safety-breadcrumb .breadcrumb-item,
.safety-breadcrumb .breadcrumb-item.active,
.sidebar-cta-card__label,
.site-footer__eyebrow {
	color: var(--color-primary);
}

.homepage-inline-cta__glow {
	display: none;
}

.how-it-works-page {
	background: #fff;
	color: #071225;
	overflow: hidden;
}

.how-it-works-page .container {
	max-width: var(--site-container-max);
}

.how-it-works-hero {
	background: linear-gradient(180deg, #f8fcff 0%, #edf7f4 100%);
	border-bottom: 1px solid rgba(188, 214, 234, 0.72);
	padding: 46px 0 74px;
	position: relative;
}

.how-it-works-breadcrumb {
	margin-bottom: 30px;
}

.how-it-works-hero__grid {
	align-items: center;
	display: grid;
	gap: clamp(32px, 5vw, 74px);
	grid-template-columns: minmax(0, 1fr) minmax(300px, 460px);
}

.how-it-works-hero__copy {
	max-width: 720px;
	min-width: 0;
}

.how-it-works-eyebrow {
	color: var(--color-primary);
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: var(--weight-semibold);
	letter-spacing: 0.12em;
	line-height: 1.2;
	margin-bottom: 14px;
	text-transform: uppercase;
}

.how-it-works-hero h1 {
	color: var(--color-ink-strong);
	font-size: 3.35rem;
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.02;
	margin: 0;
	max-width: 10.6em;
}

.how-it-works-hero__copy > p {
	color: #425066;
	font-size: 1.14rem;
	line-height: 1.56;
	margin: 22px 0 0;
	max-width: 58ch;
}

.how-it-works-hero__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 26px;
}

.how-it-works-hero__trust span {
	align-items: center;
	background: rgba(255, 255, 255, 0.86);
	border: 1px solid rgba(188, 214, 234, 0.78);
	border-radius: 999px;
	color: #243b3a;
	display: inline-flex;
	font-size: 0.92rem;
	font-weight: var(--weight-semibold);
	gap: 8px;
	line-height: 1.2;
	min-height: 38px;
	padding: 8px 13px;
}

.how-it-works-hero__trust svg,
.how-it-works-button svg,
.how-it-works-step__timing svg,
.how-it-works-final__list svg {
	flex: 0 0 auto;
	height: 17px;
	stroke-width: 2.45;
	width: 17px;
}

.how-it-works-hero__trust svg {
	color: var(--color-primary);
}

.how-it-works-button {
	align-items: center;
	background: var(--color-primary);
	border: 1px solid var(--color-primary);
	border-radius: 999px;
	box-shadow: 0 14px 30px rgba(23, 105, 170, 0.18);
	color: #fff !important;
	display: inline-flex;
	font-size: 1rem;
	font-weight: var(--weight-semibold);
	gap: 9px;
	justify-content: center;
	line-height: 1.2;
	margin-top: 30px;
	min-height: 54px;
	padding: 0 24px;
	text-decoration: none !important;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease,
		transform 0.18s ease;
}

.how-it-works-button:hover,
.how-it-works-button:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	box-shadow: 0 16px 34px rgba(23, 105, 170, 0.24);
	color: #fff !important;
	text-decoration: none;
	transform: translateY(-1px);
}

.how-it-works-button:focus-visible,
.how-it-works-document-card:focus-within {
	outline: 3px solid rgba(47, 143, 211, 0.35);
	outline-offset: 4px;
}

.how-it-works-hero__visual {
	align-items: flex-start;
	display: flex;
	justify-content: flex-end;
	justify-self: end;
	margin: 0;
	max-width: 540px;
	min-height: 0;
	min-width: 0;
	overflow: visible;
	position: relative;
	width: 100%;
}

.how-it-works-hero__visual::before {
	background: var(--color-primary-soft);
	border: 1px solid var(--color-line-soft);
	border-radius: 24px;
	content: '';
	inset: 10% -8% -10% 12%;
	pointer-events: none;
	position: absolute;
}

.how-it-works-hero__visual::after {
	content: none;
}

.how-it-works-hero__visual img {
	display: block;
	height: auto;
	object-fit: cover;
	object-position: center top;
	position: relative;
	width: min(100%, 520px);
	max-height: 420px;
	aspect-ratio: 13 / 10;
	border-radius: 16px;
	box-shadow: 0 18px 42px var(--color-shadow-soft);
	z-index: 1;
}

.how-it-works-journey,
.how-it-works-documents,
.how-it-works-final {
	padding: 78px 0;
}

.how-it-works-journey {
	background: #fff;
}

.how-it-works-documents {
	background: #f7f9fc;
}

.how-it-works-section-heading {
	margin-bottom: 36px;
	max-width: 760px;
}

.how-it-works-section-heading--split {
	align-items: end;
	display: grid;
	gap: 0 48px;
	grid-template-columns: minmax(0, 0.8fr) minmax(320px, 0.62fr);
	max-width: none;
}

.how-it-works-section-heading--split .how-it-works-eyebrow,
.how-it-works-section-heading--split h2 {
	grid-column: 1;
}

.how-it-works-section-heading h2 {
	color: var(--color-ink-strong);
	font-size: 2.35rem;
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.08;
	margin: 0;
}

.how-it-works-section-heading p {
	color: #596272;
	font-size: 1.08rem;
	line-height: 1.55;
	margin: 14px 0 0;
	max-width: 62ch;
}

.how-it-works-section-heading--split p {
	grid-column: 2;
	grid-row: 1 / span 2;
	margin: 0;
}

.how-it-works-journey__grid {
	align-items: stretch;
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.how-it-works-step {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(247, 251, 255, 0.98) 100%);
	border: 1px solid rgba(188, 214, 234, 0.78);
	border-radius: 16px;
	box-shadow: 0 20px 46px rgba(16, 47, 79, 0.08);
	display: flex;
	flex-direction: column;
	height: 100%;
	min-width: 0;
	padding: 22px;
	place-self: stretch;
}

.how-it-works-step:first-child {
	background: linear-gradient(135deg, #edf8ff 0%, #e6f5ec 100%);
	grid-column: span 2;
}

.how-it-works-step__top {
	align-items: flex-start;
	display: flex;
	gap: 14px;
	justify-content: space-between;
	margin-bottom: 18px;
}

.how-it-works-step__number {
	align-items: center;
	background: #071225;
	border-radius: 999px;
	color: #fff;
	display: inline-flex;
	font-size: 0.95rem;
	font-weight: var(--weight-semibold);
	height: 42px;
	justify-content: center;
	line-height: 1;
	width: 42px;
}

.how-it-works-step__timing {
	align-items: center;
	background: rgba(234, 245, 255, 0.92);
	border: 1px solid rgba(188, 214, 234, 0.72);
	border-radius: 999px;
	color: var(--color-primary-dark);
	display: inline-flex;
	font-size: 0.82rem;
	font-weight: var(--weight-semibold);
	gap: 7px;
	line-height: 1.25;
	max-width: 64%;
	padding: 8px 11px;
}

.how-it-works-step h3 {
	color: var(--color-ink-strong);
	font-size: 1.32rem;
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	line-height: 1.14;
	margin: 0;
}

.how-it-works-step > p {
	color: #596272;
	font-size: 0.98rem;
	line-height: 1.5;
	margin: 12px 0 0;
}

.how-it-works-step__details {
	border-top: 1px solid rgba(188, 214, 234, 0.74);
	margin-top: 18px;
	padding-top: 18px;
}

.how-it-works-step__details summary {
	align-items: center;
	color: var(--color-primary-dark);
	cursor: pointer;
	display: flex;
	font-size: 0.9rem;
	font-weight: var(--weight-semibold);
	gap: 8px;
	justify-content: space-between;
	list-style: none;
}

.how-it-works-step__details summary::-webkit-details-marker {
	display: none;
}

.how-it-works-step__details summary::after {
	content: '+';
	font-size: 1.2rem;
	font-weight: var(--weight-regular);
	line-height: 1;
}

.how-it-works-step__details[open] summary::after {
	content: '-';
}

.how-it-works-step__details dl {
	display: grid;
	gap: 7px;
	margin: 15px 0 0;
}

.how-it-works-step__details dt {
	color: var(--color-primary);
	font-size: 0.8rem;
	font-weight: var(--weight-semibold);
	line-height: 1.25;
}

.how-it-works-step__details dd {
	color: #425066;
	font-size: 0.9rem;
	line-height: 1.45;
	margin: 0 0 6px;
}

.how-it-works-documents__grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.how-it-works-document-card {
	background: #fff;
	border: 1px solid rgba(188, 214, 234, 0.82);
	border-radius: 16px;
	box-shadow: 0 18px 42px rgba(16, 47, 79, 0.08);
	min-width: 0;
	padding: 22px;
}

.how-it-works-document-card__icon {
	align-items: center;
	background: #eaf5ff;
	border: 1px solid rgba(188, 214, 234, 0.72);
	border-radius: 14px;
	color: var(--color-primary);
	display: inline-flex;
	height: 44px;
	justify-content: center;
	margin-bottom: 18px;
	width: 44px;
}

.how-it-works-document-card__icon svg {
	height: 21px;
	stroke-width: 2.25;
	width: 21px;
}

.how-it-works-document-card h3 {
	color: var(--color-ink-strong);
	font-size: 1.1rem;
	font-weight: var(--weight-heading);
	line-height: 1.16;
	margin: 0;
}

.how-it-works-document-card p {
	color: #596272;
	font-size: 0.96rem;
	line-height: 1.48;
	margin: 10px 0 0;
}

.how-it-works-final {
	background: #fff;
	padding-bottom: 90px;
}

.how-it-works-final__panel {
	background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);
	border-radius: 24px;
	box-shadow: 0 28px 60px rgba(16, 47, 79, 0.18);
	color: #fff;
	display: block;
	overflow: hidden;
	padding: 42px;
	position: relative;
}

.how-it-works-final__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	margin: 0 auto;
	max-width: 760px;
	min-width: 0;
	position: relative;
	text-align: center;
	z-index: 1;
}

.how-it-works-final .how-it-works-eyebrow {
	color: rgba(255, 255, 255, 0.78);
}

.how-it-works-final h2 {
	color: #fff;
	font-size: 2.35rem;
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.08;
	margin: 0;
	max-width: 12em;
}

.how-it-works-final__content > p {
	color: rgba(255, 255, 255, 0.82);
	font-size: 1.08rem;
	line-height: 1.55;
	margin: 14px 0 0;
	max-width: 60ch;
}

.how-it-works-final__list {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	list-style: none;
	margin: 26px auto 0;
	max-width: 720px;
	padding: 0;
	text-align: left;
	width: 100%;
}

.how-it-works-final__list li {
	align-items: flex-start;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 14px;
	color: rgba(255, 255, 255, 0.9);
	display: flex;
	font-size: 0.98rem;
	gap: 10px;
	line-height: 1.45;
	padding: 13px 14px;
}

.how-it-works-final__list svg {
	color: rgba(255, 255, 255, 0.92);
	margin-top: 2px;
}

.how-it-works-button--light {
	background: #fff;
	border-color: #fff;
	box-shadow: 0 16px 34px rgba(7, 18, 37, 0.18);
	color: var(--color-primary-dark) !important;
}

.how-it-works-button--light:hover,
.how-it-works-button--light:focus {
	background: #f4fbff;
	border-color: #f4fbff;
	color: var(--color-primary-dark) !important;
}

.how-it-works-final__disclaimer {
	margin: 18px auto 0;
	max-width: 760px;
}

[dir='rtl'] .how-it-works-button svg {
	transform: rotate(180deg);
}

@media screen and (max-width: 1199px) {
	.how-it-works-hero h1 {
		font-size: 2.9rem;
	}

	.how-it-works-hero__grid {
		grid-template-columns: minmax(0, 1fr) minmax(320px, 500px);
	}

	.how-it-works-hero__visual {
		max-width: 500px;
	}

	.how-it-works-documents__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 991px) {
	.how-it-works-hero {
		padding: 34px 0 58px;
	}

	.how-it-works-hero__grid,
	.how-it-works-section-heading--split {
		grid-template-columns: 1fr;
	}

	.how-it-works-section-heading--split p {
		grid-column: auto;
		grid-row: auto;
		margin-top: 14px;
	}

	.how-it-works-hero__copy {
		max-width: 780px;
	}

	.how-it-works-hero__visual {
		justify-self: start;
		max-width: 560px;
	}

	.how-it-works-journey__grid {
		grid-template-columns: 1fr;
	}

	.how-it-works-step:first-child {
		grid-column: auto;
	}
}

@media screen and (max-width: 575px) {
	.how-it-works-hero {
		padding: 28px 0 48px;
	}

	.how-it-works-breadcrumb {
		margin-bottom: 22px;
	}

	.how-it-works-hero h1,
	.how-it-works-section-heading h2,
	.how-it-works-final h2 {
		font-size: 2rem;
		line-height: 1.1;
	}

	.how-it-works-hero__copy > p,
	.how-it-works-section-heading p,
	.how-it-works-final__content > p {
		font-size: 1rem;
	}

	.how-it-works-hero__visual {
		max-width: none;
	}

	.how-it-works-hero__visual::before {
		inset: 8% -4% -8% 8%;
		border-radius: 20px;
	}

	.how-it-works-hero__visual img {
		max-height: none;
		width: 100%;
	}

	.how-it-works-journey,
	.how-it-works-documents,
	.how-it-works-final {
		padding: 52px 0;
	}

	.how-it-works-section-heading {
		margin-bottom: 28px;
	}

	.how-it-works-documents__grid {
		grid-template-columns: 1fr;
	}

	.how-it-works-step,
	.how-it-works-document-card {
		border-radius: 14px;
		padding: 18px;
	}

	.how-it-works-step__top {
		flex-direction: column;
	}

	.how-it-works-step__timing {
		max-width: none;
	}

	.how-it-works-button {
		min-height: 50px;
		width: 100%;
	}

	.how-it-works-final__panel {
		border-radius: 18px;
		padding: 26px 20px;
	}

	.how-it-works-final__list li {
		border-radius: 12px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.how-it-works-button {
		transition: none;
	}

	.how-it-works-button:hover,
	.how-it-works-button:focus {
		transform: none;
	}
}

.about-hero-image-wrap::before,
.safety-hero-image-wrap::before {
	background: var(--color-primary-soft);
	border-color: var(--color-line-soft);
}

.about-hero-image,
.safety-hero-image,
.safety-section-image-wrap {
	box-shadow: 0 18px 42px var(--color-shadow-soft);
}

.article-hero-actions .social-share li,
.social-share li {
	border-color: #bddbf2;
}

.article-hero-actions .social-share li a,
.article-hero-actions .social-share li a svg,
.social-share li a,
.social-share li a svg {
	color: var(--color-primary);
	stroke: var(--color-primary);
}

.sidebar-cta-card__btn,
.sidebar-cta-card__btn:visited {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff !important;
}

.sidebar-cta-card__btn:hover,
.sidebar-cta-card__btn:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff !important;
}

.site-footer {
	background: #fff;
	border-top: 1px solid var(--color-line-soft);
	color: var(--color-body);
}

.site-footer__description,
.site-footer__health-mark,
.site-footer__link-group a,
.site-footer__trust-list li,
.site-footer__contact a,
.site-footer__office-address,
.site-footer__newsletter-copy,
.site-footer__bottom {
	color: var(--color-muted);
}

.site-footer__link-group h3,
.site-footer__trust-panel h3 {
	color: var(--color-ink-strong);
}

.site-footer__link-group h3::after {
	background: linear-gradient(90deg, var(--color-primary), rgba(23, 105, 170, 0));
}

.site-footer__link-group a:hover,
.site-footer__link-group a:focus,
.site-footer__contact a:hover,
.site-footer__contact a:focus {
	color: var(--color-primary-dark);
}

.site-footer__proof {
	background: linear-gradient(135deg, #ffffff 0%, #f7fbff 58%, #eef8ff 100%);
	border-color: #d8eaf8;
	box-shadow: 0 18px 42px var(--color-shadow-soft);
}

.site-footer__proof-heading a {
	background: #eef8ff;
	border-color: #cfe5f8;
	color: var(--color-primary-dark);
}

.site-footer__proof-heading a:hover,
.site-footer__proof-heading a:focus {
	background: #fff;
	border-color: #bddbf2;
	color: var(--color-primary-dark);
}

.site-footer__partner-card {
	background: transparent;
	border-color: transparent;
	box-shadow: none;
}

.site-footer__partner-card:hover,
.site-footer__partner-card:focus {
	background: transparent;
	border-color: transparent;
	box-shadow: none;
}

.site-footer__credential-card {
	background: rgba(255, 255, 255, 0.9);
	border-color: #d8eaf8;
	box-shadow: 0 1px 0 rgba(16, 47, 79, 0.04);
}

.site-footer__trust-panel {
	background: #fbfdff;
	border-color: var(--color-line-soft);
	box-shadow: none;
}

.site-footer__trust-heading,
.site-footer__contact {
	border-color: var(--color-line-soft);
}

.site-footer__credential-card {
	color: var(--color-body);
}

.site-footer__credential-card:hover,
.site-footer__credential-card:focus {
	background: #fff;
	border-color: #bddbf2;
	box-shadow: 0 14px 30px rgba(16, 47, 79, 0.1);
	color: var(--color-primary-dark);
}

.site-footer__credential-title {
	color: var(--color-ink-strong);
}

.site-footer__credential-meta {
	color: var(--color-muted);
}

.site-footer__trust-icon {
	background: var(--color-primary-soft);
	border-color: #cfe5f8;
	color: var(--color-primary);
}

.site-footer__contact a {
	background: #fff;
	border-color: var(--color-line-soft);
}

.site-footer__contact a:hover,
.site-footer__contact a:focus {
	background: var(--color-primary-soft);
	border-color: #cfe5f8;
}

.site-footer__newsletter-row input {
	background: #fff;
	border-color: var(--color-line-soft);
	color: var(--color-ink-strong);
}

.site-footer__newsletter-row input::placeholder {
	color: #7f8f9f;
}

.site-footer__newsletter-row input:focus {
	border-color: #bddbf2;
}

.site-footer__newsletter-row button {
	background: var(--color-primary);
	border-color: var(--color-primary);
}

.site-footer__newsletter-row button:hover,
.site-footer__newsletter-row button:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
}

.site-footer__trust-list svg,
.site-footer__contact svg {
	color: var(--color-primary);
}

.site-footer__proof,
.site-footer__contact,
.site-footer__bottom {
	border-color: var(--color-line-soft);
}

.site-footer__cta {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
}

.site-footer__cta:hover,
.site-footer__cta:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff;
}

.site-footer__social a {
	border-color: var(--color-line-soft);
	color: var(--color-primary);
}

.site-footer__social a:hover,
.site-footer__social a:focus {
	background: var(--color-primary-soft);
	border-color: #cfe5f8;
	color: var(--color-primary-dark);
}

.blog-cta--consultation,
.blog-cta--cost,
.blog-cta--safety,
.blog-cta--turkey {
	border-left-color: var(--color-primary);
}

.blog-cta--consultation .blog-cta__eyebrow,
.blog-cta--cost .blog-cta__eyebrow,
.blog-cta--safety .blog-cta__eyebrow,
.blog-cta--turkey .blog-cta__eyebrow {
	color: var(--color-primary);
}

.blog-cta--consultation .blog-cta__button,
.blog-cta--cost .blog-cta__button,
.blog-cta--safety .blog-cta__button,
.blog-cta--turkey .blog-cta__button {
	background: var(--color-primary);
}

@media screen and (max-width: 991px) {
	.navbar-expand-lg .navbar-collapse {
		background: #fff;
	}

	.navbar-expand-lg .navbar-collapse .dropdown.show > .nav-link {
		background: var(--color-primary-soft);
		border-color: #cfe5f8;
		color: var(--color-primary-dark);
	}
}

/* =======================================================================
   SpesHealth shared UI components (Phase 0)
   Reusable building blocks rendered by inc/partials/*. Token-driven only.
   ======================================================================= */

.sr-only {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ---- Shared button: WhatsApp ----------------------------------------- */
.sh-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: var(--weight-semibold);
	border-radius: 0.65rem;
	padding: 0.7rem 1.15rem;
	text-decoration: none;
	line-height: 1.2;
	transition:
		background-color 0.15s ease,
		transform 0.15s ease;
}

.sh-btn--whatsapp {
	background: var(--color-whatsapp);
	color: #fff;
}

.sh-btn--whatsapp:hover,
.sh-btn--whatsapp:focus {
	background: var(--color-whatsapp-dark);
	color: #fff;
}

.sh-btn--whatsapp i,
.sh-btn--whatsapp svg {
	width: 18px;
	height: 18px;
}

.topstrip__link--whatsapp {
	color: rgba(255, 255, 255, 0.94);
	font-weight: var(--weight-semibold);
}

/* ---- Homepage cookie banner ------------------------------------------ */
.sh-cookie-banner {
	bottom: 1rem;
	left: 1rem;
	position: fixed;
	right: 1rem;
	z-index: 1046;
}

.sh-cookie-banner__shell {
	align-items: center;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(246, 251, 255, 0.98)),
		var(--color-surface-warm);
	border: 1px solid rgba(23, 105, 170, 0.14);
	border-radius: 26px;
	box-shadow:
		0 22px 58px rgba(16, 47, 79, 0.16),
		0 10px 24px rgba(16, 47, 79, 0.08);
	display: grid;
	gap: 1rem;
	grid-template-columns: auto minmax(0, 1fr) auto;
	margin: 0 auto;
	max-width: 960px;
	padding: 1rem 1.1rem 1rem 1rem;
	transition:
		opacity 0.22s ease,
		transform 0.22s ease,
		visibility 0.22s ease;
}

.sh-cookie-banner.is-dismissing .sh-cookie-banner__shell {
	opacity: 0;
	transform: translateY(18px);
	visibility: hidden;
}

.sh-cookie-banner__signal {
	align-items: center;
	background: linear-gradient(135deg, rgba(23, 105, 170, 0.14), rgba(47, 143, 211, 0.08));
	border-radius: 18px;
	color: var(--color-primary-dark);
	display: inline-flex;
	flex: 0 0 auto;
	height: 52px;
	justify-content: center;
	width: 52px;
}

.sh-cookie-banner__signal i {
	height: 22px;
	width: 22px;
}

.sh-cookie-banner__content {
	min-width: 0;
}

.sh-cookie-banner__message {
	color: var(--color-ink-strong);
	font-size: 1rem;
	font-weight: var(--weight-medium);
	line-height: 1.5;
	margin: 0;
	max-width: 58ch;
}

.sh-cookie-banner__learn {
	align-items: center;
	color: var(--color-primary-dark);
	column-gap: 0.45rem;
	display: inline-flex;
	font-size: 0.92rem;
	font-weight: var(--weight-semibold);
	margin-top: 0.45rem;
	text-decoration: none;
}

.sh-cookie-banner__learn i {
	height: 16px;
	transition: transform 0.18s ease;
	width: 16px;
}

.sh-cookie-banner__learn:hover,
.sh-cookie-banner__learn:focus {
	color: var(--color-primary);
	text-decoration: none;
}

.sh-cookie-banner__learn:hover i,
.sh-cookie-banner__learn:focus i {
	transform: translate(2px, -2px);
}

.sh-cookie-banner__learn:focus-visible,
.sh-cookie-banner__accept:focus-visible {
	outline: 3px solid rgba(47, 143, 211, 0.25);
	outline-offset: 3px;
}

.sh-cookie-banner__actions {
	display: flex;
	justify-content: flex-end;
}

.sh-cookie-banner__accept {
	align-items: center;
	background: linear-gradient(135deg, var(--color-primary), var(--color-primary-bright));
	border: 0;
	border-radius: 999px;
	box-shadow: 0 14px 30px rgba(23, 105, 170, 0.24);
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-size: 0.95rem;
	font-weight: var(--weight-semibold);
	justify-content: center;
	min-height: 48px;
	padding: 0.8rem 1.35rem;
	text-align: center;
	transition:
		box-shadow 0.2s ease,
		transform 0.2s ease;
	white-space: nowrap;
}

.sh-cookie-banner__accept:hover,
.sh-cookie-banner__accept:focus {
	box-shadow: 0 18px 34px rgba(23, 105, 170, 0.3);
	transform: translateY(-1px);
}

.sh-cookie-banner__accept:active {
	transform: translateY(0);
}

/* ---- Floating WhatsApp contact --------------------------------------- */
.sh-whatsapp-popup {
	align-items: center;
	background: var(--color-whatsapp);
	border: 0;
	border-radius: 50%;
	bottom: max(1.25rem, env(safe-area-inset-bottom));
	box-shadow:
		0 18px 44px rgba(16, 47, 79, 0.22),
		0 8px 18px rgba(37, 211, 102, 0.28);
	color: #fff;
	display: inline-flex;
	height: 56px;
	justify-content: center;
	padding: 0;
	position: fixed;
	right: max(1.25rem, env(safe-area-inset-right));
	text-decoration: none;
	transition:
		box-shadow 0.3s ease,
		transform 0.3s ease;
	width: 56px;
	z-index: 1045;
}

.sh-whatsapp-popup:hover,
.sh-whatsapp-popup:focus {
	box-shadow:
		0 22px 52px rgba(16, 47, 79, 0.24),
		0 10px 24px rgba(37, 211, 102, 0.34);
	color: #fff;
	text-decoration: none;
	transform: scale(1.1);
}

.sh-whatsapp-popup:active {
	transform: scale(0.95);
}

.sh-whatsapp-popup:focus-visible {
	outline: 3px solid rgba(37, 211, 102, 0.32);
	outline-offset: 3px;
}

.sh-whatsapp-popup__icon {
	align-items: center;
	color: #fff;
	display: inline-flex;
	flex: 0 0 auto;
	height: 24px;
	justify-content: center;
	width: 24px;
}

.sh-whatsapp-popup__icon svg {
	display: block;
	height: 24px;
	width: 24px;
}

@media (max-width: 767px) {
	.sh-whatsapp-popup {
		display: none;
	}
}

/* ---- Timed consultation prompt --------------------------------------- */
.sh-consultation-prompt[hidden] {
	display: none;
}

.sh-consultation-prompt {
	align-items: center;
	display: grid;
	inset: 0;
	justify-items: center;
	padding: clamp(1rem, 3vw, 2.5rem);
	position: fixed;
	z-index: 1085;
}

.sh-consultation-prompt__backdrop {
	background: rgba(15, 24, 36, 0.64);
	backdrop-filter: blur(8px);
	inset: 0;
	position: absolute;
}

.sh-consultation-prompt__dialog {
	background: #fff;
	border-radius: clamp(1.05rem, 1.6vw, 1.55rem);
	box-shadow: 0 36px 100px rgba(11, 31, 51, 0.34);
	display: grid;
	grid-template-columns: minmax(300px, 0.96fr) minmax(310px, 0.84fr);
  gap: clamp(1.5rem, 3vw, 2.65rem);
  max-height: min(760px, calc(100vh - 2rem));
  max-width: 1024px;
  overflow: visible;
	padding: clamp(1rem, 1.6vw, 1.35rem);
	position: relative;
	transform: translateY(12px) scale(0.985);
	transition:
		opacity 0.24s ease,
		transform 0.24s ease;
	width: min(100%, 1024px);
}

.sh-consultation-prompt.is-open .sh-consultation-prompt__dialog {
	transform: translateY(0) scale(1);
}

.sh-consultation-prompt__close {
	align-items: center;
	background: transparent;
	border: 0;
	border-radius: 50%;
	color: #17243a;
	cursor: pointer;
	display: inline-flex;
	height: 42px;
	justify-content: center;
	padding: 0;
	position: absolute;
	right: 1rem;
	top: 1.45rem;
	transition:
		background-color 0.18s ease,
		color 0.18s ease;
	width: 42px;
	z-index: 2;
}

.sh-consultation-prompt__close:hover,
.sh-consultation-prompt__close:focus {
	background: rgba(16, 47, 79, 0.08);
	color: var(--color-primary-dark);
	cursor: pointer;
	outline: none;
}

.sh-consultation-prompt__close:focus:not(:focus-visible) {
	background: transparent;
}

.sh-consultation-prompt__close:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.24);
	outline-offset: 2px;
}

.sh-consultation-prompt__close i {
	height: 22px;
	width: 22px;
}

.sh-consultation-prompt__media {
	align-items: end;
	display: grid;
	min-height: 460px;
	overflow: hidden;
	position: relative;
}

.sh-consultation-prompt__media::before {
	content: none;
}

.sh-consultation-prompt__media img {
	align-self: end;
	display: block;
	filter: drop-shadow(0 26px 38px rgba(16, 47, 79, 0.16));
	height: 560px;
	justify-self: center;
	object-fit: contain;
	object-position: center bottom;
	position: relative;
	width: min(118%, 620px);
}

.sh-consultation-prompt__content {
	align-content: center;
	display: grid;
	padding: clamp(1.45rem, 3vw, 2.55rem) clamp(0.4rem, 1.2vw, 1rem) clamp(1rem, 2vw, 1.5rem) 0;
}

.sh-consultation-prompt__eyebrow {
	color: var(--color-primary);
	font-size: 0.78rem;
	font-weight: var(--weight-emphasis);
	letter-spacing: 0.08em;
	margin: 0 0 0.42rem;
	text-transform: uppercase;
}

.sh-consultation-prompt__content h2 {
	color: #17243a;
	font-size: clamp(1.62rem, 1.35rem + 1vw, 2.25rem);
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.05;
	margin: 0 2.25rem 0.8rem 0;
}

.sh-consultation-prompt__copy {
	color: #334156;
	font-size: 0.98rem;
	line-height: 1.45;
	margin: 0 0 1.55rem;
	max-width: 34rem;
}

.sh-consultation-prompt__form {
	display: grid;
	gap: 0.78rem;
	position: relative;
}

.sh-consultation-prompt__form .form-control {
	background: #fff;
	border: 1px solid #dfe6ee;
	border-radius: 999px;
	box-shadow: none;
	color: #17243a;
	font-size: 0.94rem;
	font-weight: var(--weight-medium);
	height: 48px;
	padding: 0 1.05rem;
	transition:
		border-color 0.18s ease,
		box-shadow 0.18s ease;
}

.sh-consultation-prompt__form select.form-control {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9L12 15L18 9' stroke='%2317243A' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-position: right 1.15rem center;
	background-repeat: no-repeat;
	background-size: 18px 18px;
	color: #17243a;
	line-height: 1.2;
	padding-left: 1.25rem;
	padding-right: 3rem;
}

[dir='rtl'] .sh-consultation-prompt__form select.form-control {
	background-position: left 1.15rem center;
	padding-left: 3rem;
	padding-right: 1.25rem;
}

.sh-consultation-prompt__native-select {
	block-size: 1px !important;
	inline-size: 1px !important;
	inset-inline-start: 0;
	margin: 0 !important;
	opacity: 0;
	padding: 0 !important;
	pointer-events: none;
	position: absolute;
}

.sh-consultation-select {
	position: relative;
}

.sh-consultation-select__button {
	align-items: center;
	background: #fff;
	border: 1px solid #dfe6ee;
	border-radius: 999px;
	box-shadow: none;
	color: #17243a;
	display: flex;
	font-size: 0.94rem;
	font-weight: var(--weight-medium);
	gap: 0.8rem;
	height: 48px;
	justify-content: space-between;
	line-height: 1.2;
	padding: 0 1.05rem 0 1.25rem;
	text-align: left;
	transition:
		border-color 0.18s ease,
		box-shadow 0.18s ease,
		color 0.18s ease;
	width: 100%;
}

[dir='rtl'] .sh-consultation-select__button {
	padding-left: 1.05rem;
	padding-right: 1.25rem;
	text-align: right;
}

.sh-consultation-select__button span {
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sh-consultation-select__button i,
.sh-consultation-select__button svg {
	flex: 0 0 auto;
	height: 18px;
	transition: transform 0.18s ease;
	width: 18px;
}

.sh-consultation-select.is-open .sh-consultation-select__button i,
.sh-consultation-select.is-open .sh-consultation-select__button svg {
	transform: rotate(180deg);
}

.sh-consultation-select__button:hover,
.sh-consultation-select__button:focus,
.sh-consultation-select.is-open .sh-consultation-select__button {
	border-color: rgba(23, 105, 170, 0.56);
	box-shadow: 0 0 0 4px rgba(23, 105, 170, 0.12);
	outline: none;
}

.sh-consultation-prompt__form.was-validated
	.sh-consultation-prompt__native-select:invalid
	+ .sh-consultation-select
	.sh-consultation-select__button,
.sh-consultation-select.is-invalid .sh-consultation-select__button {
	border-color: #dc3545;
	box-shadow: 0 0 0 4px rgba(220, 53, 69, 0.12);
}

.sh-consultation-select__menu {
	background: #fff;
	border: 1px solid #dfe6ee;
	border-radius: 18px;
	box-shadow: 0 18px 42px rgba(16, 47, 79, 0.18);
	display: none;
	gap: 2px;
	inset-inline: 0;
	max-height: min(270px, calc(100vh - 320px));
	overflow-x: hidden;
	overflow-y: auto;
	padding: 6px;
	position: absolute;
	scrollbar-color: rgba(23, 105, 170, 0.36) transparent;
	scrollbar-gutter: stable;
	scrollbar-width: thin;
	top: calc(100% + 8px);
	z-index: 6;
}

.sh-consultation-select__menu::-webkit-scrollbar {
	width: 7px;
}

.sh-consultation-select__menu::-webkit-scrollbar-track {
	background: transparent;
	margin: 10px 0;
}

.sh-consultation-select__menu::-webkit-scrollbar-thumb {
	background: rgba(23, 105, 170, 0.34);
	border: 2px solid #fff;
	border-radius: 999px;
	min-height: 34px;
}

.sh-consultation-select__menu::-webkit-scrollbar-thumb:hover {
	background: rgba(23, 105, 170, 0.54);
}

.sh-consultation-select.is-open .sh-consultation-select__menu {
	display: grid;
}

.sh-consultation-select__option {
	background: transparent;
	border: 0;
	border-radius: 12px;
	color: #17243a;
	cursor: pointer;
	display: block;
	font-size: 0.92rem;
	font-weight: var(--weight-medium);
	line-height: 1.25;
	padding: 0.72rem 0.85rem;
	text-align: left;
	transition:
		background-color 0.16s ease,
		color 0.16s ease;
	width: 100%;
}

[dir='rtl'] .sh-consultation-select__option {
	text-align: right;
}

.sh-consultation-select__option:hover,
.sh-consultation-select__option:focus,
.sh-consultation-select__option[aria-selected='true'] {
	background: rgba(23, 105, 170, 0.1);
	color: var(--color-primary-dark);
	outline: none;
}

.sh-consultation-prompt__form .form-control::placeholder {
	color: #7b8798;
}

.sh-consultation-prompt__form .form-control:focus {
	border-color: rgba(23, 105, 170, 0.56);
	box-shadow: 0 0 0 4px rgba(23, 105, 170, 0.12);
}

.sh-consultation-prompt__phone-row .iti {
	width: 100%;
}

.sh-consultation-prompt__phone-row .iti__selected-flag {
	border-radius: 999px 0 0 999px;
}

.sh-consultation-prompt__phone-row .iti__selected-country {
	border-radius: 999px 0 0 999px;
	transition:
		background-color 0.16s ease,
		box-shadow 0.16s ease;
}

.sh-consultation-prompt__phone-row .iti__selected-country:hover,
.sh-consultation-prompt__phone-row .iti__country-container:hover .iti__selected-country {
	background: transparent !important;
	box-shadow: inset 0 0 0 1px rgba(23, 105, 170, 0.2) !important;
}

.sh-consultation-prompt__phone-row .iti__selected-country-primary {
	border-radius: 999px 0 0 999px;
	transition:
		background-color 0.16s ease,
		box-shadow 0.16s ease;
}

.sh-consultation-prompt__phone-row .iti__selected-country:hover .iti__selected-country-primary,
.sh-consultation-prompt__phone-row .iti__country-container:hover .iti__selected-country-primary,
.sh-consultation-prompt__phone-row
	.iti--allow-dropdown
	.iti__country-container:not(:has(+ input[disabled])):not(:has(+ input[readonly])):hover
	.iti__selected-country-primary,
.sh-consultation-prompt__phone-row
	.iti--allow-dropdown
	.iti__country-container:not(:has(+ input[disabled])):not(:has(+ input[readonly]))
	.iti__selected-country-primary:hover,
.sh-consultation-prompt__phone-row .iti__selected-country-primary:hover {
	background: transparent !important;
	box-shadow: inset 0 0 0 1px rgba(23, 105, 170, 0.2) !important;
}

.sh-consultation-prompt__status {
	min-height: 1.15rem;
}

.sh-consultation-prompt__submit {
	align-items: center;
	background: linear-gradient(135deg, var(--color-primary) 0%, #102f4f 100%);
	border: 0;
	border-radius: 12px;
	box-shadow: 0 4px 12px rgba(23, 105, 170, 0.2);
	color: #fff;
	display: inline-flex;
	font-size: 1rem;
	font-weight: var(--weight-semibold);
	gap: 10px;
	justify-content: center;
	line-height: 1;
	margin-top: 0.2rem;
	min-height: 52px;
	padding: 14px 20px;
	transition:
		background 0.18s ease,
		box-shadow 0.18s ease,
		color 0.18s ease,
		transform 0.18s ease;
	width: 100%;
}

.sh-consultation-prompt__submit:hover,
.sh-consultation-prompt__submit:focus {
	background: linear-gradient(135deg, var(--color-primary) 20%, #0c2340 100%);
	box-shadow: 0 8px 20px rgba(23, 105, 170, 0.3);
	color: #fff;
	transform: translateY(-2px);
}

.sh-consultation-prompt__submit:disabled {
	cursor: wait;
	opacity: 0.72;
	transform: none;
}

.sh-consultation-prompt__submit:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.28);
	outline-offset: 3px;
}

.sh-consultation-prompt__submit-icon {
	align-items: center;
	color: currentColor;
	display: inline-flex;
	height: 20px;
	justify-content: center;
	width: 20px;
}

.sh-consultation-prompt__submit-icon i {
	height: 18px;
	transition: transform 0.2s ease;
	width: 18px;
}

.sh-consultation-prompt__submit:hover .sh-consultation-prompt__submit-icon i,
.sh-consultation-prompt__submit:focus .sh-consultation-prompt__submit-icon i {
	transform: translateX(4px);
}

body.sh-consultation-prompt-open {
	overflow: hidden;
}

.sh-consultation-prompt .iti--container,
.sh-consultation-prompt .iti--fullscreen-popup.iti--container {
	z-index: 4 !important;
}

body.sh-consultation-prompt-open .iti--container .iti__country-list {
	scrollbar-color: rgba(23, 105, 170, 0.36) transparent;
	scrollbar-gutter: stable;
	scrollbar-width: thin;
}

body.sh-consultation-prompt-open .iti--container .iti__country-list::-webkit-scrollbar {
	width: 7px;
}

body.sh-consultation-prompt-open .iti--container .iti__country-list::-webkit-scrollbar-track {
	background: transparent;
	margin: 8px 0;
}

body.sh-consultation-prompt-open .iti--container .iti__country-list::-webkit-scrollbar-thumb {
	background: rgba(23, 105, 170, 0.34);
	border: 2px solid #fff;
	border-radius: 999px;
	min-height: 34px;
}

body.sh-consultation-prompt-open .iti--container .iti__country-list::-webkit-scrollbar-thumb:hover {
	background: rgba(23, 105, 170, 0.54);
}

body.sh-consultation-prompt-open .iti--container .iti__country {
	border-radius: 10px;
	margin: 1px 6px;
	padding-left: 10px;
	padding-right: 10px;
	transition:
		background-color 0.16s ease,
		box-shadow 0.16s ease,
		color 0.16s ease;
}

body.sh-consultation-prompt-open .iti--container .iti__country:hover,
body.sh-consultation-prompt-open .iti--container .iti__country.iti__highlight {
	background: transparent;
	box-shadow: inset 0 0 0 1px rgba(23, 105, 170, 0.16);
	color: var(--color-primary-dark);
}

body.sh-consultation-prompt-open .iti--container .iti__country:hover .iti__dial-code,
body.sh-consultation-prompt-open .iti--container .iti__country.iti__highlight .iti__dial-code {
	color: var(--color-primary);
}

body.sh-consultation-prompt-open .sh-sticky-cta,
body.sh-consultation-prompt-open .sh-whatsapp-popup,
body.sh-consultation-prompt-open .sh-cookie-banner,
body.sh-consultation-prompt-open .cc_banner-wrapper {
	opacity: 0;
	pointer-events: none;
	visibility: hidden;
}

body.sh-cookie-banner-visible .sh-whatsapp-popup,
body.sh-cookie-banner-visible .sh-sticky-cta {
	opacity: 0;
	pointer-events: none;
	visibility: hidden;
}

body.sh-consultation-prompt-open .cc_banner-wrapper {
	display: none;
}

@media (max-width: 767px) {
	body.sh-cookie-banner-visible {
		padding-bottom: var(--cookie-banner-space-mobile);
	}

	.sh-cookie-banner {
		bottom: 0;
		left: 0;
		right: 0;
	}

	.sh-cookie-banner__shell {
		border-bottom-left-radius: 0;
		border-bottom-right-radius: 0;
		border-left: 0;
		border-right: 0;
		border-top: 1px solid rgba(23, 105, 170, 0.14);
		box-shadow: 0 -14px 32px rgba(16, 47, 79, 0.14);
		gap: 0.85rem;
		grid-template-columns: auto minmax(0, 1fr);
		padding: 0.95rem 0.95rem calc(0.95rem + env(safe-area-inset-bottom, 0px));
	}

	.sh-cookie-banner__signal {
		height: 46px;
		width: 46px;
	}

	.sh-cookie-banner__actions {
		grid-column: 1 / -1;
	}

	.sh-cookie-banner__accept {
		width: 100%;
	}

	.sh-consultation-prompt {
		align-items: end;
		padding: 0;
	}

  .sh-consultation-prompt__dialog {
    border-radius: 1.15rem 1.15rem 0 0;
    grid-template-columns: 1fr;
    gap: 1rem;
    max-height: calc(100vh - 1rem);
    overflow: auto;
    padding: 0.85rem;
    width: 100%;
  }

	.sh-consultation-prompt__media {
		min-height: 240px;
	}

	.sh-consultation-prompt__media img {
		height: 300px;
		width: min(112%, 390px);
	}

	.sh-consultation-prompt__content {
		padding: 0.35rem 0.25rem 0.5rem;
	}

	.sh-consultation-prompt__content h2 {
		font-size: 1.55rem;
		margin-right: 2.4rem;
	}

	.sh-consultation-prompt__copy {
		font-size: 0.94rem;
		margin-bottom: 1rem;
	}

  .sh-consultation-prompt__form .form-control {
    height: 46px;
  }

  .sh-consultation-select__button {
    height: 46px;
  }
}

@media (max-width: 380px), (max-height: 680px) {
  .sh-consultation-prompt__dialog {
    overflow: auto;
  }

  .sh-consultation-prompt__media {
    display: none;
  }
}

/* ---- Trust bar -------------------------------------------------------- */
.sh-trust-bar {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem 1.25rem;
	align-items: center;
	justify-content: center;
	padding: 1rem 1.25rem;
	background: var(--color-surface-soft);
	border: 1px solid var(--color-line-soft);
	border-radius: 1rem;
}

.sh-trust-bar__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: var(--text-small);
	font-weight: var(--weight-semibold);
	color: var(--color-ink-strong);
	text-decoration: none;
}

a.sh-trust-bar__badge:hover,
a.sh-trust-bar__badge:focus {
	color: var(--color-primary);
}

.sh-trust-bar__badge i {
	width: 18px;
	height: 18px;
	color: var(--color-primary);
	flex: none;
}

/* ---- Journey timeline ------------------------------------------------- */
.sh-journey {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 1.25rem;
	counter-reset: sh-journey;
}

.sh-journey__step {
	position: relative;
	display: flex;
	gap: 1rem;
	padding: 1.25rem 1.25rem 1.25rem 1rem;
	background: var(--color-surface-warm);
	border: 1px solid var(--color-line-soft);
	border-radius: 1rem;
	box-shadow: 0 12px 30px -24px var(--color-shadow-soft);
}

.sh-journey__num {
	flex: none;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	display: grid;
	place-items: center;
	font-weight: var(--weight-semibold);
	color: #fff;
	background: var(--color-primary);
}

.sh-journey__title {
	font-size: var(--text-h4);
	margin: 0 0 0.35rem;
	color: var(--color-ink-strong);
}

.sh-journey__desc {
	margin: 0;
	color: var(--color-muted);
}

.sh-journey__meta {
	margin: 0.85rem 0 0;
	display: grid;
	gap: 0.4rem;
}

.sh-journey__meta dt {
	font-size: var(--text-small);
	font-weight: var(--weight-semibold);
	color: var(--color-primary-dark);
}

.sh-journey__meta dd {
	margin: 0 0 0.35rem;
	color: var(--color-body);
}

@media (min-width: 768px) {
	.sh-journey--horizontal {
		grid-auto-flow: column;
		grid-auto-columns: 1fr;
		align-items: stretch;
	}
}

/* ---- FAQ accordion ---------------------------------------------------- */
.faq-page__content {
	margin: 0 auto;
	max-width: 980px;
	width: 100%;
}

.sh-faq {
	display: grid;
	gap: 0.75rem;
}

.sh-faq--page {
	gap: clamp(1.25rem, 2vw, 1.75rem);
}

.sh-faq--page .sh-faq__group {
	display: grid;
	gap: 0.75rem;
}

.sh-faq__group-title {
	font-size: var(--text-h4);
	color: var(--color-ink-strong);
	margin: 1.5rem 0 0.75rem;
}

.sh-faq--page .sh-faq__group-title {
	line-height: 1.2;
	margin: 0;
}

.sh-faq__item {
	border: 1px solid var(--color-line-soft);
	border-radius: 0.85rem;
	background: var(--color-surface-warm);
	overflow: hidden;
}

.sh-faq__q {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	cursor: pointer;
	list-style: none;
	padding: 1rem 1.25rem;
	font-weight: var(--weight-semibold);
	color: var(--color-ink-strong);
}

.sh-faq__q > span {
	flex: 1 1 auto;
	min-width: 0;
}

.sh-faq__q::-webkit-details-marker {
	display: none;
}

.sh-faq__q:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: -2px;
}

.sh-faq__q i {
	flex: none;
	transition: transform 0.2s ease;
}

.sh-faq__item[open] .sh-faq__q i {
	transform: rotate(180deg);
}

.sh-faq__a {
	padding: 0 1.25rem 1.15rem;
	color: var(--color-body);
}

@media (max-width: 575.98px) {
	.sh-faq--page {
		gap: 1.5rem;
	}

	.sh-faq--page .sh-faq__group {
		gap: 0.6rem;
	}

	.sh-faq--page .sh-faq__q {
		align-items: center;
		gap: 0.85rem;
		padding: 0.85rem 1rem;
	}

	.sh-faq--page .sh-faq__a {
		padding: 0 1rem 1rem;
	}
}

/* ---- Package inclusion table ----------------------------------------- */
.sh-pkg {
	overflow-x: auto;
}

.sh-pkg__table {
	width: 100%;
	border-collapse: collapse;
	background: var(--color-surface-warm);
	border: 1px solid var(--color-line-soft);
	border-radius: 1rem;
	overflow: hidden;
}

.sh-pkg__table th,
.sh-pkg__table td {
	padding: 0.85rem 1rem;
	text-align: left;
	border-bottom: 1px solid var(--color-line-soft);
	vertical-align: top;
}

.sh-pkg__table thead th {
	background: var(--color-primary-soft);
	color: var(--color-primary-dark);
	font-size: var(--text-small);
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.sh-pkg__table tbody th {
	font-weight: var(--weight-semibold);
	color: var(--color-ink-strong);
}

.sh-pkg__mark--yes {
	color: var(--color-success);
}

.sh-pkg__mark--depends {
	color: var(--color-primary);
	font-weight: var(--weight-semibold);
	font-size: var(--text-small);
}

.sh-pkg__mark--no {
	color: var(--color-muted);
}

@media (max-width: 640px) {
	.sh-pkg__table,
	.sh-pkg__table thead,
	.sh-pkg__table tbody,
	.sh-pkg__table th,
	.sh-pkg__table td,
	.sh-pkg__table tr {
		display: block;
	}

	.sh-pkg__table thead {
		display: none;
	}

	.sh-pkg__table tr {
		border-bottom: 2px solid var(--color-line-soft);
		padding: 0.5rem 0;
	}

	.sh-pkg__table td {
		border: 0;
		display: flex;
		justify-content: space-between;
		gap: 1rem;
	}

	.sh-pkg__table td::before {
		content: attr(data-label);
		font-weight: var(--weight-semibold);
		color: var(--color-muted);
	}
}

/* ---- Coordinator card ------------------------------------------------- */
.sh-coordinator {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
	padding: 1.5rem;
	background: var(--color-surface-warm);
	border: 1px solid var(--color-line-soft);
	border-radius: 1rem;
}

.sh-coordinator__media img,
.sh-coordinator__avatar {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	object-fit: cover;
	display: grid;
	place-items: center;
	background: var(--color-primary-soft);
	color: var(--color-primary);
}

.sh-coordinator__name {
	font-size: var(--text-h4);
	margin: 0;
	color: var(--color-ink-strong);
}

.sh-coordinator__role {
	margin: 0.1rem 0 0.5rem;
	color: var(--color-muted);
}

.sh-coordinator__languages {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	color: var(--color-body);
	margin: 0 0 0.85rem;
}

.sh-coordinator__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	align-items: center;
}

.sh-coordinator__email {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	color: var(--color-primary);
	text-decoration: none;
}

/* ---- Review / patient story card ------------------------------------- */
.sh-review {
	margin: 0;
	padding: 1.5rem;
	background: var(--color-surface-warm);
	border: 1px solid var(--color-line-soft);
	border-radius: 1rem;
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	height: 100%;
}

.sh-review__quote {
	margin: 0;
	font-size: var(--text-body-lg);
	color: var(--color-ink-strong);
}

.sh-review__quote::before {
	content: '\201C';
	color: var(--color-primary);
	font-weight: var(--weight-semibold);
}

.sh-review__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem 0.85rem;
	align-items: center;
	font-size: var(--text-small);
}

.sh-review__country,
.sh-review__date {
	color: var(--color-muted);
}

.sh-review__treatment {
	color: var(--color-primary-dark);
	font-weight: var(--weight-semibold);
}

.sh-review__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	color: var(--color-muted);
}

.sh-review__badge--verified {
	color: var(--color-success);
	font-weight: var(--weight-semibold);
}

.sh-review__disclaimer {
	margin: 0;
	font-size: var(--text-small);
	color: var(--color-muted);
	font-style: italic;
}

/* ---- Treatment card --------------------------------------------------- */
.sh-treatment-card {
	height: 100%;
}

.sh-treatment-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	background: var(--color-surface-warm);
	border: 1px solid var(--color-line-soft);
	border-radius: 1rem;
	overflow: hidden;
	transition:
		transform 0.15s ease,
		box-shadow 0.15s ease;
}

.sh-treatment-card__link:hover,
.sh-treatment-card__link:focus {
	transform: translateY(-3px);
	box-shadow: 0 20px 40px -28px var(--color-shadow-soft);
}

.sh-treatment-card__media img {
	width: 100%;
	height: 160px;
	object-fit: cover;
	display: block;
}

.sh-treatment-card__icon {
	display: grid;
	place-items: center;
	width: 3.25rem;
	height: 3.25rem;
	margin: 1.25rem 1.25rem 0;
	border-radius: 0.85rem;
	background: var(--color-primary-soft);
	color: var(--color-primary);
}

.sh-treatment-card__body {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	padding: 1rem 1.25rem 1.25rem;
}

.sh-treatment-card__title {
	font-size: var(--text-h4);
	font-weight: var(--weight-semibold);
	color: var(--color-ink-strong);
}

.sh-treatment-card__desc {
	color: var(--color-muted);
}

.sh-treatment-card__stay {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: var(--text-small);
	color: var(--color-primary-dark);
}

.sh-treatment-card__cta {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: var(--weight-semibold);
	color: var(--color-primary);
}

/* ---- Medical disclaimer ---------------------------------------------- */
.sh-disclaimer {
	--disclaimer-icon-size: 1.05rem;
	--disclaimer-line-height: 1.55;

	display: grid;
	grid-template-columns: auto 1fr;
	align-items: start;
	gap: 0.75rem;
	padding: 0.95rem 1.1rem;
	border-radius: 0.9rem;
	background: var(--color-surface-soft);
	border: 1px solid var(--color-line-soft);
	border-left: 4px solid var(--color-danger);
	box-shadow: 0 12px 24px -22px rgba(16, 47, 79, 0.2);
}

.sh-disclaimer i,
.sh-disclaimer svg {
	flex: none;
	width: var(--disclaimer-icon-size);
	height: var(--disclaimer-icon-size);
	color: var(--color-danger);
}

.sh-disclaimer svg {
	margin-top: 0.1rem;
	overflow: visible;
}

.sh-disclaimer i {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--color-danger);
	background: rgba(180, 35, 24, 0.08);
	border-radius: 0.45rem;
	padding: 0.22rem;
}

.sh-disclaimer__text p {
	margin: 0;
	font-size: var(--text-small);
	line-height: var(--disclaimer-line-height);
	color: var(--color-body);
}

.sh-disclaimer__text p + p {
	margin-top: 0.42rem;
}

.sh-disclaimer--compact {
	border-left-width: 3px;
	padding: 0.76rem 0.95rem;
	gap: 0.65rem;
}

.sh-disclaimer--compact i,
.sh-disclaimer--compact svg {
	width: 0.98rem;
	height: 0.98rem;
}

.sh-disclaimer--compact .sh-disclaimer__text p {
	line-height: 1.45;
}

@media (max-width: 767px) {
	.sh-disclaimer {
		padding: 0.88rem 0.95rem;
	}

	.sh-disclaimer--compact {
		padding: 0.7rem 0.85rem;
		gap: 0.55rem;
	}

	.sh-disclaimer i,
	.sh-disclaimer svg {
		margin-top: 0.05rem;
	}
}

/* ---- Sticky mobile CTA ------------------------------------------------ */
.sh-sticky-cta {
	display: none;
}

@media (max-width: 767px) {
	.sh-sticky-cta {
		position: fixed;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 1040;
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		background: var(--color-surface-warm);
		border-top: 1px solid var(--color-line-soft);
		box-shadow: 0 -8px 24px -18px var(--color-shadow-soft);
		padding-bottom: env(safe-area-inset-bottom, 0);
	}

	.sh-hide-sticky .sh-sticky-cta {
		display: none;
	}

	.sh-sticky-cta__item {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 0.2rem;
		padding: 0.6rem 0.4rem;
		font-size: 0.72rem;
		font-weight: var(--weight-semibold);
		text-decoration: none;
		color: var(--color-ink-strong);
	}

	.sh-sticky-cta__item i {
		width: 20px;
		height: 20px;
	}

	.sh-sticky-cta__item--whatsapp {
		color: var(--color-whatsapp-dark);
	}

	.sh-sticky-cta__item--primary {
		color: var(--color-primary);
	}

	body.sh-has-sticky-cta {
		/* keep content clear of the fixed bar */
		padding-bottom: 4rem;
	}

	body.sh-cookie-banner-visible {
		padding-bottom: var(--cookie-banner-space-mobile);
	}
}

/* =======================================================================
   Get-Quote multi-step wizard + secure upload (Phase 1b)
   ======================================================================= */
.appointment-wizard__progress {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	list-style: none;
	margin: 0 0 clamp(1.7rem, 2.6vw, 2.35rem);
	padding: 0;
}

.appointment-wizard__progress-item {
	display: inline-flex;
	align-items: center;
	background: #f5f9fd;
	border: 1px solid rgba(216, 226, 241, 0.9);
	border-radius: 999px;
	color: #6a788b;
	gap: 0.45rem;
	font-size: 0.84rem;
	font-weight: var(--weight-semibold);
	padding: 0.36rem 0.72rem 0.36rem 0.4rem;
}

.appointment-wizard__progress-num {
	display: grid;
	place-items: center;
	width: 1.72rem;
	height: 1.72rem;
	border-radius: 50%;
	background: #fff;
	box-shadow: inset 0 0 0 1px rgba(216, 226, 241, 0.9);
	color: #6a788b;
	font-size: 0.8rem;
	font-weight: var(--weight-emphasis);
}

.appointment-wizard__progress-item.is-active .appointment-wizard__progress-num,
.appointment-wizard__progress-item.is-done .appointment-wizard__progress-num {
	background: var(--color-primary-dark);
	box-shadow: none;
	color: #fff;
}

.appointment-wizard__progress-item.is-active {
	background: #eef7ff;
	border-color: #bddbf2;
	color: var(--color-primary-dark);
}

.appointment-wizard__step {
	border: 0;
	padding: 0;
	margin: 0;
}

.appointment-wizard__step[hidden] {
	display: none;
}

.appointment-wizard__step legend {
	color: #071225;
	font-size: clamp(1.24rem, 1.05rem + 0.42vw, 1.48rem);
	font-weight: var(--weight-emphasis);
	line-height: 1.16;
	margin-bottom: 1.15rem;
}

.appointment-wizard .form-label {
	color: #172235 !important;
	font-size: 0.92rem;
	font-weight: var(--weight-heading) !important;
}

.appointment-wizard .form-control {
	background: #f7fbff !important;
	border: 1px solid rgba(216, 226, 241, 0.88) !important;
	border-radius: 14px;
	color: #071225;
	min-height: 48px;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease;
}

.appointment-wizard textarea.form-control {
	min-height: 132px;
	resize: none;
}

.appointment-wizard .form-control:focus {
	background: #fff !important;
	border-color: rgba(47, 143, 211, 0.42) !important;
	box-shadow: 0 0 0 3px rgba(47, 143, 211, 0.08);
}

.appointment-wizard .custom-control-label {
	color: #26364a;
	line-height: 1.4;
}

.appointment-wizard__nav {
	border-top: 1px solid rgba(216, 226, 241, 0.8);
	gap: 12px;
	padding-top: 22px;
}

.appointment-wizard__nav .btn-primary {
	box-shadow: 0 14px 28px rgba(23, 105, 170, 0.16);
}

.appointment-wizard__nav .btn-light {
	background: #f5f9fd;
	border: 1px solid rgba(216, 226, 241, 0.9);
	color: #172235;
}

.appointment-upload__input {
	position: absolute;
	width: 1px;
	height: 1px;
	opacity: 0;
}

.appointment-upload__drop {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	padding: 1.75rem;
	border: 2px dashed var(--color-line-soft);
	border-radius: 1rem;
	background: var(--color-surface-soft);
	color: var(--color-primary-dark);
	cursor: pointer;
	text-align: center;
	font-weight: var(--weight-semibold);
}

.appointment-upload__drop:hover {
	border-color: var(--color-primary);
}

.appointment-upload__list {
	list-style: none;
	margin: 1rem 0 0;
	padding: 0;
	display: grid;
	gap: 0.5rem;
}

.appointment-upload__file {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.6rem 0.9rem;
	background: var(--color-surface-warm);
	border: 1px solid var(--color-line-soft);
	border-radius: 0.6rem;
}

.appointment-upload__file-remove {
	border: 0;
	background: transparent;
	font-size: 1.4rem;
	line-height: 1;
	color: var(--color-danger);
	cursor: pointer;
}

/* Public listing cards */
.listing-hero {
	background: linear-gradient(135deg, #f2f9fd 0%, #e9f6fb 56%, #f8fcf8 100%);
}

.listing-hero__grid {
	align-items: start;
	display: grid;
	gap: 48px;
	grid-template-columns: minmax(0, 1fr) minmax(300px, 520px);
	margin-top: 40px;
}

.listing-hero__grid--single {
	grid-template-columns: minmax(0, 820px);
}

.listing-hero__intro h1 {
	color: var(--color-primary-dark);
	font-size: 3rem;
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	line-height: 1.05;
	margin: 0;
	max-width: 780px;
}

.listing-hero__lead {
	color: var(--color-muted);
	font-size: 1.08rem;
	line-height: 1.7;
	margin: 22px 0 0;
	max-width: 720px;
}

.listing-hero__search {
	margin-top: 34px;
	max-width: 520px;
}

.listing-hero__search-surface {
	background: rgba(255, 255, 255, 0.78);
	border: 1px solid rgba(23, 105, 170, 0.14);
	border-radius: 24px;
	box-shadow: 0 20px 48px rgba(16, 47, 79, 0.08);
	padding: 22px;
}

.listing-hero__search h6,
.listing-hero__filters h6 {
	color: var(--color-primary-dark);
	font-size: 0.82rem;
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	margin: 0;
	text-transform: uppercase;
}

.listing-hero__search-helper {
	color: #4d6375;
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 12px 0 0;
	max-width: 54ch;
}

.listing-hero__search .search-form--listing {
	align-items: center;
	border: 1px solid rgba(47, 128, 196, 0.18);
	border-radius: 18px;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.86);
	display: grid;
	gap: 10px;
	grid-template-columns: minmax(0, 1fr) auto;
	height: auto;
	min-height: 62px;
	padding: 8px;
}

.listing-hero__search .search-form--listing svg {
	color: #5c7285;
	left: 20px;
}

.listing-hero__search .search-form--listing input {
	color: var(--color-primary-dark);
	padding-left: 54px;
}

.listing-hero__search .search-form--listing input:-webkit-autofill,
.listing-hero__search .search-form--listing input:-webkit-autofill:hover,
.listing-hero__search .search-form--listing input:-webkit-autofill:focus {
	-webkit-box-shadow: 0 0 0 1000px #fff inset;
	-webkit-text-fill-color: var(--color-primary-dark);
	caret-color: var(--color-primary-dark);
	box-shadow: 0 0 0 1000px #fff inset;
	transition: background-color 9999s ease-out;
}

.listing-hero__search .search-submit {
	align-items: center;
	background: linear-gradient(135deg, #1769aa 0%, #0f8a91 100%);
	border: 0;
	border-radius: 999px;
	box-shadow: 0 12px 24px rgba(23, 105, 170, 0.22);
	color: #fff;
	display: inline-flex;
	font-size: 0.94rem;
	font-weight: var(--weight-heading);
	justify-content: center;
	line-height: 1;
	min-height: 46px;
	padding: 0 18px;
	transition:
		box-shadow 0.2s ease,
		transform 0.2s ease;
}

.listing-hero__search .search-submit:hover,
.listing-hero__search .search-submit:focus {
	box-shadow: 0 16px 28px rgba(23, 105, 170, 0.28);
	color: #fff;
	text-decoration: none;
	transform: translateY(-1px);
}

[dir='rtl'] .listing-hero__search .search-form--listing svg {
	left: auto;
	right: 20px;
}

[dir='rtl'] .listing-hero__search .search-form--listing input {
	padding-left: 16px;
	padding-right: 54px;
}

.listing-hero__filters {
	background: rgba(255, 255, 255, 0.56);
	border: 1px solid rgba(23, 105, 170, 0.12);
	border-radius: 8px;
	padding: 24px;
}

.listing-hero__filters--links {
	background: rgba(255, 255, 255, 0.68);
}

.listing-hero__quick-links {
	display: grid;
	gap: 10px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.listing-hero__filters h6 + .listing-hero__quick-links {
	margin-top: 18px;
}

.listing-hero__quick-links a {
	align-items: center;
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.1);
	border-radius: 8px;
	color: var(--color-primary-dark);
	display: flex;
	font-weight: var(--weight-heading);
	gap: 12px;
	justify-content: space-between;
	line-height: 1.35;
	padding: 14px 16px;
	text-decoration: none !important;
	transition:
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		transform 0.2s ease;
}

.listing-hero__quick-links a:hover,
.listing-hero__quick-links a:focus {
	border-color: rgba(23, 105, 170, 0.3);
	box-shadow: 0 14px 28px rgba(16, 47, 79, 0.1);
	transform: translateY(-1px);
}

.listing-hero__quick-links i,
.listing-hero__quick-links svg {
	color: var(--color-primary);
	flex: 0 0 16px;
	height: 16px;
	width: 16px;
}

.listing-section {
	background: #f8fafc;
}

.listing-shell {
	align-items: start;
	display: grid;
	gap: 32px;
	grid-template-columns: minmax(0, 1fr) 360px;
}

.listing-main {
	min-width: 0;
}

.listing-card-list {
	display: flex;
	flex-direction: column;
	gap: 18px;
	list-style: none;
	margin: 0;
	max-width: 980px;
	padding: 0;
}

.condition-page-shell .listing-card-list {
	max-width: none;
}

.listing-card-list--articles {
	display: grid;
	gap: 24px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	max-width: none;
}

.listing-card-list--articles .listing-card-list__item {
	display: flex;
	min-width: 0;
}

.listing-card {
	align-items: stretch;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, #fdfefe 100%);
	border: 1px solid rgba(16, 47, 79, 0.09);
	border-radius: 20px;
	box-shadow:
		0 14px 34px rgba(16, 47, 79, 0.06),
		0 1px 0 rgba(255, 255, 255, 0.84) inset;
	color: var(--color-body) !important;
	display: grid;
	gap: 26px;
	grid-template-columns: minmax(168px, 228px) minmax(0, 1fr);
	min-height: 196px;
	overflow: hidden;
	padding: 22px;
	position: relative;
	text-decoration: none !important;
	transition:
		border-color 0.22s ease,
		box-shadow 0.22s ease,
		transform 0.22s ease;
}

.listing-card:hover,
.listing-card:focus {
	border-color: rgba(23, 105, 170, 0.18);
	box-shadow:
		0 22px 48px rgba(16, 47, 79, 0.1),
		0 1px 0 rgba(255, 255, 255, 0.92) inset;
	transform: translateY(-3px);
}

.listing-card--category {
	grid-template-columns: 1fr;
	min-height: 0;
	padding: 28px;
}

.listing-card__media {
	align-self: stretch;
	background: linear-gradient(180deg, #edf6fb 0%, #f7fbfd 100%);
	border: 1px solid rgba(16, 47, 79, 0.05);
	border-radius: 16px;
	display: block;
	min-height: 150px;
	overflow: hidden;
	position: relative;
}

.listing-card__media img {
	display: block;
	height: 100%;
	object-fit: cover;
	transition:
		filter 0.28s ease,
		transform 0.28s ease;
	width: 100%;
}

.listing-card:hover .listing-card__media img,
.listing-card:focus .listing-card__media img {
	filter: saturate(1.03) contrast(1.02);
	transform: scale(1.035);
}

.listing-card__body {
	display: flex;
	flex-direction: column;
	gap: 0;
	min-width: 0;
	padding: 4px 0;
}

.listing-card__eyebrow {
	color: #567287;
	font-size: 0.72rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.08em;
	margin-bottom: 10px;
	text-transform: uppercase;
}

.listing-card__title {
	color: var(--color-primary-dark);
	font-size: clamp(1.28rem, 1.2rem + 0.22vw, 1.46rem);
	font-weight: var(--weight-display);
	letter-spacing: 0;
	line-height: 1.16;
	text-wrap: balance;
}

.listing-card__description {
	color: #5f7281;
	display: -webkit-box;
	font-size: 0.96rem;
	line-height: 1.62;
	margin-top: 12px;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
}

.listing-card__meta {
	color: #597184;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 12px;
	margin-top: 16px;
}

.listing-card__meta span {
	align-items: center;
	background: rgba(237, 246, 251, 0.92);
	border: 1px solid rgba(95, 137, 168, 0.16);
	border-radius: 999px;
	display: inline-flex;
	font-size: 0.79rem;
	font-weight: var(--weight-medium);
	gap: 7px;
	line-height: 1.3;
	min-width: 0;
	padding: 7px 11px;
}

.listing-card__meta i,
.listing-feature-card__list i {
	flex: 0 0 auto;
	height: 16px;
	width: 16px;
}

.listing-card__meta svg,
.listing-feature-card__list svg {
	flex: 0 0 auto;
	height: 16px;
	width: 16px;
}

.listing-card__cta {
	align-items: center;
	color: var(--color-primary-dark);
	display: inline-flex;
	font-size: 0.82rem;
	font-weight: var(--weight-display);
	gap: 10px;
	letter-spacing: 0.08em;
	line-height: 1;
	margin-top: auto;
	padding-top: 22px;
	text-transform: uppercase;
}

.listing-card__cta i,
.listing-card__cta svg {
	align-items: center;
	background: rgba(23, 105, 170, 0.08);
	border: 1px solid rgba(23, 105, 170, 0.16);
	border-radius: 999px;
	color: var(--color-primary);
	display: inline-flex;
	flex: 0 0 auto;
	height: 30px;
	justify-content: center;
	padding: 7px;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		color 0.18s ease,
		transform 0.18s ease;
	width: 30px;
}

.listing-card:hover .listing-card__cta i,
.listing-card:hover .listing-card__cta svg,
.listing-card:focus .listing-card__cta i,
.listing-card:focus .listing-card__cta svg {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
	transform: translateX(2px);
}

.listing-card--article {
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	color: var(--color-body) !important;
	display: flex;
	flex-direction: column;
	min-height: 100%;
	overflow: hidden;
	padding: 0;
	position: relative;
	transition:
		border-color 0.2s ease,
		box-shadow 0.22s ease,
		transform 0.22s ease;
	width: 100%;
}

.listing-card--article:hover,
.listing-card--article:focus {
	border-color: transparent;
	box-shadow: none;
	color: var(--color-body) !important;
	transform: none;
}

.listing-card--article::before {
	content: none;
}

.listing-card--article .listing-card__media {
	aspect-ratio: 1.26;
	background: var(--color-surface-soft);
	border: 0;
	border-radius: 20px 20px 6px 6px;
	display: block;
	flex: 0 0 auto;
	height: auto;
	min-height: 0;
	position: relative;
	width: 100%;
}

.listing-card--article .listing-card__media img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.listing-card--article:hover .listing-card__media img,
.listing-card--article:focus .listing-card__media img {
	filter: saturate(1.04) contrast(1.02);
	transform: scale(1.035);
}

.listing-card--article .listing-card__body {
	box-sizing: border-box;
	display: grid;
	flex: 1 1 auto;
	gap: 0.28rem;
	grid-template-columns: minmax(0, 1fr);
	min-height: 0;
	padding: clamp(4px, 0.55vw, 8px) 0 0;
	position: relative;
	width: 100%;
}

.listing-card--article .listing-card__title {
	color: var(--color-primary-dark);
	display: -webkit-box;
	font-size: clamp(1.08rem, 1rem + 0.2vw, 1.2rem);
	font-weight: var(--weight-display);
	line-height: 1.22;
	max-width: none;
	overflow: hidden;
	text-shadow: none;
	text-wrap: balance;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

.listing-card--article .listing-card__description {
	color: var(--color-muted);
	display: -webkit-box;
	font-size: 0.95rem;
	line-height: 1.48;
	margin: 0;
	max-width: none;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

.listing-card--article .listing-card__meta {
	display: none;
}

.listing-card--article .listing-card__meta span {
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	color: var(--color-primary);
	display: inline-flex;
	font-size: 0.73rem;
	font-weight: var(--weight-display);
	gap: 8px;
	letter-spacing: 0.08em;
	line-height: 1.2;
	padding: 0;
	text-transform: uppercase;
}

.listing-card--article .listing-card__cta {
	display: none;
}

.listing-card--article:hover .listing-card__description,
.listing-card--article:focus .listing-card__description {
	color: var(--color-muted);
}

.listing-card--article:hover .listing-card__meta span,
.listing-card--article:focus .listing-card__meta span {
	background: transparent;
	border: 0;
	color: var(--color-primary);
}

.listing-feature-card {
	background: #102f4f;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	box-shadow: none;
	color: #fff;
	padding: 28px;
}

.listing-feature-card__icon {
	align-items: center;
	background: rgba(255, 255, 255, 0.12);
	border-radius: 8px;
	color: #8fd3c7;
	display: flex;
	height: 42px;
	justify-content: center;
	margin-bottom: 20px;
	width: 42px;
}

.listing-feature-card__icon i {
	height: 20px;
	width: 20px;
}

.listing-feature-card__eyebrow {
	color: #8fd3c7;
	display: block;
	font-size: 0.78rem;
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	margin-bottom: 10px;
	text-transform: uppercase;
}

.listing-feature-card h2 {
	color: #fff;
	font-size: 1.35rem;
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	line-height: 1.25;
	margin: 0;
}

.listing-feature-card p {
	color: rgba(255, 255, 255, 0.78);
	line-height: 1.62;
	margin: 14px 0 0;
}

.listing-feature-card__list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	list-style: none;
	margin: 22px 0 0;
	padding: 0;
}

.listing-feature-card__list li {
	align-items: center;
	color: rgba(255, 255, 255, 0.9);
	display: flex;
	font-size: 0.94rem;
	gap: 10px;
}

.listing-feature-card__list i {
	color: #8fd3c7;
}

.listing-feature-card__cta {
	margin-top: 24px;
	width: 100%;
}

.listing-hero--care {
	background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
	overflow: hidden;
	position: relative;
}

.listing-hero--care.section-padding {
	padding: clamp(30px, 4.8vw, 64px) 0 clamp(20px, 3vw, 34px);
}

.listing-hero--care::before {
	background: linear-gradient(90deg, rgba(23, 105, 170, 0.28), rgba(15, 138, 145, 0.18), rgba(23, 105, 170, 0.08));
	content: '';
	height: 1px;
	left: max(var(--site-container-gutter, 28px), calc((100vw - var(--site-container-max, 1540px)) / 2));
	pointer-events: none;
	position: absolute;
	right: max(var(--site-container-gutter, 28px), calc((100vw - var(--site-container-max, 1540px)) / 2));
	top: 0;
}

.listing-hero--care .listing-hero__grid {
	display: block;
	margin-top: clamp(20px, 2.8vw, 32px);
}

.listing-hero--care .listing-hero__grid--media {
	align-items: center;
	display: grid;
	gap: clamp(28px, 4vw, 52px);
	grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
}

.listing-hero--care .listing-hero__intro {
	max-width: 1040px;
}

.listing-hero--care .listing-hero__grid--media .listing-hero__intro {
	max-width: none;
}

.listing-hero__media {
	border-radius: 18px;
	position: relative;
}

.listing-hero__media::before {
	background: linear-gradient(135deg, rgba(23, 105, 170, 0.18), rgba(15, 138, 145, 0.12));
	border-radius: 18px;
	content: '';
	inset: 0;
	position: absolute;
	transform: translate(12px, 12px);
	z-index: 0;
}

.listing-hero__media img {
	aspect-ratio: 4 / 3;
	border: 1px solid rgba(47, 128, 196, 0.18);
	border-radius: 18px;
	box-shadow: 0 20px 48px rgba(16, 47, 79, 0.13);
	display: block;
	height: 100%;
	object-fit: cover;
	position: relative;
	width: 100%;
	z-index: 1;
}

.listing-hero__eyebrow {
	align-items: center;
	color: var(--color-primary-dark);
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: var(--weight-display);
	gap: 10px;
	letter-spacing: 0;
	margin-bottom: 14px;
	text-transform: uppercase;
}

.listing-hero__eyebrow::before {
	background: var(--color-primary);
	border-radius: 999px;
	content: '';
	display: inline-block;
	height: 7px;
	width: 7px;
}

.listing-hero--care .listing-hero__intro h1 {
	color: #081b31;
	font-size: clamp(3rem, 2.35rem + 2.35vw, 4.7rem);
	font-weight: var(--weight-display);
	line-height: 1;
	max-width: 1220px;
	text-wrap: balance;
}

.listing-hero--care .listing-hero__lead {
	color: #44596a;
	font-size: clamp(1.05rem, 1rem + 0.18vw, 1.2rem);
	line-height: 1.58;
	max-width: 840px;
}

.listing-hero__support {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	list-style: none;
	margin: 22px 0 0;
	padding: 0;
}

.listing-hero__support li {
	align-items: center;
	background: rgba(255, 255, 255, 0.74);
	border: 1px solid rgba(47, 128, 196, 0.18);
	border-radius: 999px;
	color: #23445f;
	display: inline-flex;
	font-size: 0.9rem;
	font-weight: var(--weight-semibold);
	gap: 8px;
	min-height: 38px;
	padding: 0 14px;
}

.listing-hero__support i,
.listing-hero__support svg {
	color: var(--color-primary);
	height: 16px;
	width: 16px;
}

.listing-hero__tools {
	align-items: end;
	background: transparent;
	border: 1px solid rgba(188, 214, 234, 0.76);
	border-left: 0;
	border-right: 0;
	border-radius: 0;
	box-shadow: none;
	display: grid;
	gap: clamp(20px, 3vw, 44px);
	grid-template-columns: minmax(280px, 460px) minmax(0, 1fr);
	margin-top: clamp(24px, 3.2vw, 38px);
	padding: 20px 0;
}

.listing-hero__tools--single {
	align-items: center;
	border: 0;
	grid-template-columns: minmax(0, 1fr);
	padding: 0;
}

.listing-hero--care .listing-hero__search {
	margin-top: clamp(20px, 2.4vw, 28px);
	max-width: 590px;
	width: 100%;
}

.listing-search-band .listing-hero__search {
	margin-top: 0;
	max-width: none;
}

.listing-hero--care .listing-hero__search-surface {
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	padding: 0;
}

.listing-search-band .listing-hero__search-surface {
	background: rgba(255, 255, 255, 0.84);
	border-color: rgba(188, 214, 234, 0.94);
	box-shadow:
		0 18px 38px rgba(16, 47, 79, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.listing-hero--care .listing-hero__search .search-form,
.listing-search-band .listing-hero__search .search-form {
	border-color: rgba(47, 128, 196, 0.24);
	box-shadow:
		0 14px 30px rgba(16, 47, 79, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.listing-hero--care .listing-hero__search .search-form--listing {
	border-radius: 999px;
	min-height: 56px;
	padding: 6px;
}

.listing-hero--care .listing-hero__search .search-submit {
	box-shadow: 0 6px 14px rgba(23, 105, 170, 0.14);
	min-height: 40px;
	padding: 0 16px;
}

.listing-hero--care .listing-hero__search .search-submit:hover,
.listing-hero--care .listing-hero__search .search-submit:focus {
	box-shadow: 0 8px 16px rgba(23, 105, 170, 0.18);
}

.listing-hero--care .listing-hero__search .search-form.mt-4,
.listing-hero--care .letter-box.mt-4,
.listing-search-band .listing-hero__search .search-form.mt-4 {
	margin-top: 14px !important;
}

.listing-hero--care .listing-hero__search .search-form--listing.mt-4,
.listing-search-band .listing-hero__search .search-form--listing.mt-4 {
	margin-top: 0 !important;
}

.listing-hero--care .listing-hero__filters {
	background: transparent;
	border: 0;
	box-shadow: none;
	padding: 0;
}

.listing-hero--care .listing-hero__filters h6 {
	color: var(--color-primary-dark);
	display: block;
	font-size: 0.78rem;
	font-weight: var(--weight-display);
	line-height: 1.25;
	margin-bottom: 14px;
}

.listing-hero--care .listing-hero__search h6,
.listing-search-band .listing-hero__search h6 {
	color: #004a85;
	display: block;
	font-size: 0.78rem;
	font-weight: var(--weight-display);
	line-height: 1.25;
	margin-bottom: 10px;
}

.listing-hero--care .listing-hero__search-helper,
.listing-search-band .listing-hero__search-helper {
	color: #4b6171;
}

[dir='rtl'] .listing-hero--care .listing-hero__search h6,
[dir='rtl'] .listing-hero--care .listing-hero__filters h6,
[dir='rtl'] .listing-search-band .listing-hero__search h6 {
	text-align: right;
}

.listing-hero--care .letter-box {
	grid-template-columns: repeat(auto-fill, minmax(38px, 1fr));
	max-width: none;
}

.listing-hero--care .letter-box li a {
	background: #fff;
	border-color: rgba(47, 128, 196, 0.2);
	border-radius: 999px;
	color: var(--color-primary-dark);
	font-weight: var(--weight-semibold);
	height: 38px;
	width: 38px;
}

.listing-hero--care .letter-box li a:hover,
.listing-hero--care .letter-box li a:focus {
	border-color: rgba(23, 105, 170, 0.44);
	box-shadow: 0 8px 18px rgba(16, 47, 79, 0.09);
	text-decoration: none;
}

.listing-hero--care .letter-box li a.active {
	background: linear-gradient(135deg, #1769aa 0%, #0f8a91 100%);
	border-color: transparent;
	color: #fff;
}

.listing-search-band {
	background: #f4f8fc;
	border-bottom: 1px solid rgba(188, 214, 234, 0.58);
	padding: clamp(18px, 2.4vw, 28px) 0;
}

.condition-page-shell.listing-section {
	background: linear-gradient(180deg, #ffffff 0%, #f7fbff 48%, #fbfdff 100%);
}

.condition-page-shell .listing-shell {
	gap: 34px;
	grid-template-columns: minmax(0, 1fr) 340px;
}

.condition-page-shell .listing-card-list--care {
	display: grid;
	gap: 24px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	max-width: none;
}

.condition-page-shell .listing-card-list--care .listing-card-list__item {
	display: flex;
	min-width: 0;
}

.condition-page-shell .listing-card--care {
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	color: var(--color-body) !important;
	display: flex;
	flex-direction: column;
	min-height: 100%;
	overflow: hidden;
	padding: 0;
	position: relative;
	transition:
		border-color 0.2s ease,
		box-shadow 0.22s ease,
		transform 0.22s ease;
	width: 100%;
}

.condition-page-shell .listing-card--care:hover,
.condition-page-shell .listing-card--care:focus {
	border-color: transparent;
	box-shadow: none;
	color: var(--color-body) !important;
	transform: none;
}

.condition-page-shell .listing-card--care::before {
	content: none;
}

.condition-page-shell .listing-card--care .listing-card__media {
	aspect-ratio: 1.26;
	background: var(--color-surface-soft);
	border-radius: 20px 20px 6px 6px;
	display: block;
	flex: 0 0 auto;
	height: auto;
	min-height: 0;
	position: relative;
	width: 100%;
}

.condition-page-shell .listing-card--care .listing-card__media img {
	height: 100%;
	object-fit: cover;
	transition:
		filter 0.28s ease,
		transform 0.28s ease;
	width: 100%;
}

.condition-page-shell .listing-card--care:hover .listing-card__media img,
.condition-page-shell .listing-card--care:focus .listing-card__media img {
	filter: saturate(1.04) contrast(1.02);
	transform: scale(1.035);
}

.condition-page-shell .listing-card--care .listing-card__body {
	box-sizing: border-box;
	display: grid;
	flex: 1 1 auto;
	gap: 0.28rem;
	grid-template-columns: minmax(0, 1fr);
	min-height: 0;
	padding: clamp(4px, 0.55vw, 8px) 0 0;
	position: relative;
	width: 100%;
}

.condition-page-shell .listing-card--care .listing-card__title {
	color: var(--color-primary-dark);
	display: -webkit-box;
	font-size: clamp(1.08rem, 1rem + 0.2vw, 1.2rem);
	font-weight: var(--weight-display);
	grid-column: 1;
	line-height: 1.22;
	max-width: none;
	overflow: hidden;
	text-shadow: none;
	text-wrap: balance;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

.condition-page-shell .listing-card--care .listing-card__description {
	color: var(--color-muted);
	display: -webkit-box;
	font-size: 0.95rem;
	line-height: 1.48;
	margin: 0;
	max-width: none;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

.condition-page-shell .listing-card--care .listing-card__cta {
	display: none;
}

.condition-page-shell .listing-card-list--care-articles .listing-card {
	box-shadow: none;
	border-color: rgba(188, 214, 234, 0.72);
}

.condition-page-shell .listing-feature-card {
	background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
	border: 1px solid rgba(188, 214, 234, 0.82);
	border-radius: clamp(18px, 1.8vw, 24px);
	box-shadow: none;
	color: var(--color-body);
	overflow: hidden;
	padding: clamp(24px, 2vw, 30px);
	position: sticky;
	top: 116px;
}

.condition-page-shell .listing-feature-card::before {
	background: radial-gradient(circle at 100% 0%, rgba(47, 143, 211, 0.16), rgba(47, 143, 211, 0) 64%);
	content: '';
	height: 230px;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	width: 230px;
}

.condition-page-shell .listing-feature-card > * {
	position: relative;
	z-index: 1;
}

.condition-page-shell .listing-feature-card__icon {
	background: rgba(23, 105, 170, 0.08);
	border: 1px solid rgba(23, 105, 170, 0.12);
	border-radius: 14px;
	color: var(--color-primary);
	height: 48px;
	width: 48px;
}

.condition-page-shell .listing-feature-card__eyebrow {
	color: var(--color-primary);
	letter-spacing: 0.08em;
}

.condition-page-shell .listing-feature-card h2 {
	color: var(--color-ink-strong);
}

.condition-page-shell .listing-feature-card p {
	color: var(--color-muted);
}

.condition-page-shell .listing-feature-card__list {
	border-top: 1px solid rgba(188, 214, 234, 0.72);
	margin-top: 22px;
	padding-top: 20px;
}

.condition-page-shell .listing-feature-card__list li {
	color: var(--color-body);
}

.condition-page-shell .listing-feature-card__list i {
	color: var(--color-primary);
}

.condition-page-shell .listing-feature-card__cta,
.condition-page-shell .listing-feature-card__cta:visited {
	align-items: center;
	background: var(--color-primary);
	border: 1px solid var(--color-primary);
	border-radius: 999px;
	box-shadow: 0 14px 28px rgba(23, 105, 170, 0.18);
	color: #fff !important;
	display: inline-flex;
	font-weight: var(--weight-heading);
	justify-content: center;
	min-height: 52px;
	transition:
		background-color 0.18s ease,
		box-shadow 0.18s ease,
		transform 0.18s ease;
}

.condition-page-shell .listing-feature-card__cta:hover,
.condition-page-shell .listing-feature-card__cta:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	box-shadow: 0 16px 34px rgba(16, 47, 79, 0.2);
	color: #fff !important;
	transform: translateY(-1px);
}

/* Card sits inside the sticky wrapper on the overview page — let the wrapper pin it. */
.sticky-cta-box .listing-feature-card {
	position: static;
	top: auto;
}

.listing-empty {
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.11);
	border-radius: 8px;
	padding: 28px;
}

.listing-shell:has(.listing-empty) {
	grid-template-columns: 1fr;
}

.listing-section .pagination-wrapper {
	margin-top: 28px !important;
}

.listing-section .pagination-wrapper .pagination {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.listing-section .pagination-wrapper .pagination li a {
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.12);
	border-radius: 8px;
	color: var(--color-primary-dark);
	height: 42px;
	line-height: 40px;
	margin: 0;
	min-width: 42px;
	padding: 0 12px;
}

.listing-section .pagination-wrapper .pagination li a.current {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
	opacity: 1;
}

.treatment-overview-section,
.treatment-overview-content,
.treatment-overview-subbranches {
	background: var(--color-surface-soft);
}

.treatment-overview-subbranches__title {
	color: var(--color-primary-dark);
	font-size: clamp(1.28rem, 1.08rem + 0.5vw, 1.72rem);
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	line-height: 1.18;
	margin: 0 0 22px;
}

.treatment-overview-subbranches__grid {
	display: grid;
	gap: clamp(16px, 1.8vw, 24px);
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 420px));
	justify-content: start;
	list-style: none;
	margin: 0;
	padding: 0;
}

.treatment-overview-subbranches__grid > li {
	display: flex;
	min-width: 0;
}

.subbranch-card {
	background: #fff;
	border: 1px solid rgba(188, 214, 234, 0.82);
	border-radius: 8px;
	box-shadow: 0 18px 42px rgba(16, 47, 79, 0.08);
	color: var(--color-primary-dark);
	display: grid;
	gap: 16px;
	grid-template-columns: minmax(0, 1fr) 42px;
	grid-template-rows: auto minmax(54px, 1fr);
	min-height: 100%;
	overflow: hidden;
	padding: 14px;
	text-decoration: none !important;
	transition:
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		transform 0.2s ease;
	width: 100%;
}

.subbranch-card:hover,
.subbranch-card:focus {
	border-color: rgba(23, 105, 170, 0.35);
	box-shadow: 0 24px 54px rgba(16, 47, 79, 0.14);
	transform: translateY(-2px);
}

.subbranch-card:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.24);
	outline-offset: 3px;
}

.subbranch-card__media {
	aspect-ratio: 16 / 9;
	border-radius: 7px;
	grid-column: 1 / -1;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.subbranch-card__media img {
	display: block;
	height: 100%;
	object-fit: cover;
	transition:
		filter 0.28s ease,
		transform 0.28s ease;
	width: 100%;
}

.subbranch-card:hover .subbranch-card__media img,
.subbranch-card:focus .subbranch-card__media img {
	filter: saturate(1.04) contrast(1.02);
	transform: scale(1.035);
}

.subbranch-card__body {
	align-self: center;
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 0;
}

.subbranch-card__title {
	font-size: clamp(1.05rem, 1rem + 0.22vw, 1.22rem);
	font-weight: var(--weight-heading);
	line-height: 1.22;
	min-width: 0;
	overflow-wrap: anywhere;
	text-wrap: balance;
}

.subbranch-card__description {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	color: var(--color-muted);
	display: -webkit-box;
	font-size: 0.875rem;
	line-height: 1.5;
	overflow: hidden;
}

.subbranch-card .feather {
	align-self: center;
	background: rgba(23, 105, 170, 0.08);
	border: 1px solid rgba(23, 105, 170, 0.18);
	border-radius: 999px;
	box-sizing: border-box;
	color: var(--color-primary);
	height: 42px;
	justify-self: end;
	padding: 11px;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		color 0.18s ease,
		transform 0.18s ease;
	width: 42px;
}

.subbranch-card:hover .feather,
.subbranch-card:focus .feather {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
	transform: translateX(3px);
}

[dir='rtl'] .subbranch-card .feather {
	transform: scaleX(-1);
}

[dir='rtl'] .subbranch-card:hover .feather,
[dir='rtl'] .subbranch-card:focus .feather {
	transform: scaleX(-1) translateX(3px);
}

.treatment-overview-section.condition-page-shell > .container,
.treatment-overview-content.condition-page-shell > .container,
.treatment-overview-subbranches.condition-page-shell > .container {
	max-width: var(--site-container-max);
}

.treatment-overview-section + .treatment-overview-section {
	padding-top: 0 !important;
}

.treatment-overview-section .border-category {
	align-items: center;
	border-bottom: 1px solid rgba(16, 47, 79, 0.12) !important;
	gap: 18px;
	margin-bottom: 22px;
	padding-bottom: 14px;
}

.treatment-overview-section .border-category h2 {
	color: var(--color-primary-dark);
	font-size: clamp(1.25rem, 1.1rem + 0.45vw, 1.65rem);
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	line-height: 1.2;
	margin: 0;
}

.treatment-overview-section .view-all-button {
	align-items: center;
	border: 1px solid rgba(23, 105, 170, 0.24);
	border-radius: 999px;
	color: var(--color-primary);
	display: inline-flex;
	flex: 0 0 auto;
	font-size: 0.9rem;
	font-weight: var(--weight-heading);
	justify-content: center;
	line-height: 1;
	margin-bottom: 0;
	min-height: 2.75rem;
	padding: 0.55rem 1rem;
	text-align: center;
	white-space: nowrap;
}

.treatment-overview-section .view-all-button:focus,
.treatment-overview-section .view-all-button:active {
	background: transparent;
	border-color: rgba(23, 105, 170, 0.24);
	box-shadow: none;
	color: var(--color-primary);
	outline: none;
	text-decoration: none;
}

.treatment-overview-section .view-all-button:focus-visible {
	box-shadow: 0 0 0 3px rgba(47, 143, 211, 0.18);
	outline: 2px solid rgba(23, 105, 170, 0.42);
	outline-offset: 3px;
}

.treatment-overview-section .row {
	align-items: stretch;
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.11);
	border-radius: 8px;
	box-shadow: 0 18px 42px rgba(16, 47, 79, 0.07);
	display: grid;
	gap: 30px;
	grid-template-columns: minmax(0, 1.08fr) minmax(380px, 0.92fr);
	margin-left: 0;
	margin-right: 0;
	padding: 22px;
}

.treatment-overview-section .row > [class*='col-'] {
	flex: none;
	max-width: none;
	min-width: 0;
	padding-left: 0;
	padding-right: 0;
	width: 100%;
}

.treatment-overview-section .row > [class*='col-'] + [class*='col-'] {
	padding-left: 0;
}

.treatment-overview-section .row.flex-row-reverse > [class*='col-']:first-child {
	order: 2;
}

.treatment-overview-section .row.flex-row-reverse > [class*='col-']:last-child {
	order: 1;
}

.treatment-overview-section img.img-fluid.rounded {
	aspect-ratio: 16 / 10;
	border-radius: 8px !important;
	height: 100%;
	min-height: 280px;
	object-fit: contain;
	object-position: center;
	width: 100%;
}

.treatment-overview-section .list-category-posts {
	gap: 0;
	height: 100%;
	justify-content: center;
}

.treatment-overview-section .list-category-posts a {
	display: block;
	margin: 0;
	padding: 16px 0;
}

.treatment-overview-section .list-category-posts a h4 {
	color: var(--color-primary-dark);
	font-size: clamp(1rem, 0.96rem + 0.22vw, 1.16rem);
	font-weight: var(--weight-heading);
	line-height: 1.35;
}

.treatment-overview-section .list-category-posts a p {
	color: var(--color-muted);
	font-size: 0.96rem;
	line-height: 1.55;
	margin-top: 6px;
}

.treatment-overview-section .list-category-posts a:after {
	background: rgba(16, 47, 79, 0.1);
	margin-top: 16px;
}

.treatment-overview-cta {
	background: var(--color-surface-soft);
	padding-bottom: 28px;
}

.treatment-overview-content__row {
	align-items: flex-start;
	margin-left: 0;
	margin-right: 0;
}

.treatment-overview-content__row > [class*='col-']:first-child {
	padding-left: 0;
}

.treatment-overview-content__row > [class*='col-']:last-child {
	padding-right: 0;
}

.treatment-overview-content__body {
	color: var(--color-muted);
	margin: 0;
	max-width: none;
	overflow-wrap: break-word;
}

.treatment-overview-content__body > :first-child {
	margin-top: 0;
}

.treatment-overview-content__body h2,
.treatment-overview-content__body h3 {
	color: var(--color-primary-dark);
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	line-height: 1.25;
	margin: 34px 0 14px;
}

.treatment-overview-content__body h2 {
	font-size: clamp(1.55rem, 1.35rem + 0.58vw, 2rem);
}

.treatment-overview-content__body h3 {
	font-size: clamp(1.25rem, 1.12rem + 0.36vw, 1.55rem);
}

.treatment-overview-content__body p,
.treatment-overview-content__body li {
	color: var(--color-muted);
	font-size: var(--text-body-lg);
	line-height: 1.68;
	hyphens: auto;
}

.treatment-overview-content__body p {
	margin: 0 0 18px;
}

.treatment-overview-content__body p + p {
	margin-top: 0;
}

.treatment-overview-content__body ul,
.treatment-overview-content__body ol {
	margin: 0 0 24px;
	padding-left: 1.35rem;
}

.treatment-overview-content__body li + li {
	margin-top: 8px;
}

.treatment-overview-content__body strong {
	color: var(--color-primary-dark);
	font-weight: var(--weight-semibold);
}

.treatment-overview-content__body a {
	color: var(--color-primary);
	font-weight: var(--weight-semibold);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.18em;
}

.treatment-overview-content__body img {
	border-radius: 8px;
	display: block;
	height: auto;
	margin: 24px 0;
	max-width: 100%;
}

.treatment-overview-content__body hr {
	border: 0;
	border-top: 1px solid rgba(16, 47, 79, 0.14);
	margin: 34px 0;
}

[dir='rtl'] .treatment-overview-content__body ul,
[dir='rtl'] .treatment-overview-content__body ol {
	padding-left: 0;
	padding-right: 1.35rem;
}

@media screen and (max-width: 991px) {
	.listing-hero__grid,
	.listing-shell {
		grid-template-columns: 1fr;
	}

	.listing-hero__intro h1 {
		font-size: 2.35rem;
	}

	.listing-feature-card {
		max-width: 520px;
	}

	.listing-hero--care .listing-hero__intro h1 {
		font-size: 2.58rem;
	}

	.listing-hero--care .listing-hero__grid,
	.listing-hero--care .listing-hero__grid--media,
	.listing-hero__tools {
		grid-template-columns: 1fr;
	}

	.listing-hero__search-surface {
		padding: 20px 18px;
	}

	.listing-hero__search .search-form--listing {
		grid-template-columns: 1fr;
		padding: 10px;
	}

	.listing-hero__search .search-form--listing input {
		min-height: 44px;
	}

	.listing-hero__search .search-submit {
		width: 100%;
	}

	.listing-hero--care .listing-hero__grid--media .listing-hero__media {
		margin-top: clamp(20px, 4vw, 32px);
		max-width: 560px;
	}

	.listing-hero--care .listing-hero__grid--media .listing-hero__media img {
		aspect-ratio: 16 / 9;
	}

	.condition-page-shell .listing-shell {
		grid-template-columns: 1fr;
	}

	.condition-page-shell .listing-card-list--care {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

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

	.condition-page-shell .listing-feature-card {
		max-width: none;
		position: static;
	}

	.listing-card-list--articles .listing-card,
	.listing-card-list--categories .listing-card {
		gap: 20px;
		grid-template-columns: 1fr;
		padding: 20px;
	}

	.listing-card-list--articles .listing-card__media,
	.listing-card-list--categories .listing-card__media {
		aspect-ratio: 16 / 10;
		min-height: 0;
	}

	.listing-card-list--articles .listing-card__body,
	.listing-card-list--categories .listing-card__body {
		padding: 0;
	}

	.listing-card-list--articles .listing-card--article {
		gap: 0;
		min-height: 0;
		padding: 0;
	}

	.listing-card-list--articles .listing-card--article::before {
		content: none;
	}

	.listing-card-list--articles .listing-card--article .listing-card__title {
		max-width: none;
	}

	.listing-card-list--articles .listing-card--article .listing-card__body {
		padding: 4px 0 0;
	}

	.listing-card-list--articles .listing-card--article .listing-card__media {
		aspect-ratio: 1.26;
	}

	.treatment-overview-section .row > [class*='col-'] + [class*='col-'] {
		padding-left: 0;
		padding-top: 22px;
	}

	.treatment-overview-section .row {
		display: block;
	}

	.treatment-overview-section .row.flex-row-reverse > [class*='col-']:first-child,
	.treatment-overview-section .row.flex-row-reverse > [class*='col-']:last-child {
		order: initial;
	}

	.treatment-overview-section img.img-fluid.rounded {
		aspect-ratio: 16 / 9;
		height: auto;
		min-height: 0;
	}
}

@media screen and (max-width: 575px) {
	.listing-hero__grid {
		gap: 28px;
		margin-top: 28px;
	}

	.listing-hero--care.section-padding {
		padding-bottom: 18px;
		padding-top: 24px;
	}

	.listing-hero--care .listing-hero__grid {
		margin-top: 22px;
	}

	.listing-hero--care .listing-hero__grid--media .listing-hero__media {
		display: none;
	}

	.listing-hero--conditions-root .listing-hero__grid--media .listing-hero__media,
	.listing-hero--treatments-root .listing-hero__grid--media .listing-hero__media {
		display: block;
		margin-top: 18px;
		max-width: none;
	}

	.listing-hero__intro h1 {
		font-size: 2rem;
	}

	.listing-hero__lead {
		font-size: 1rem;
	}

	.listing-hero--care .listing-hero__intro h1 {
		font-size: 2.28rem;
		line-height: 1.02;
	}

	.listing-hero--care .listing-hero__lead {
		font-size: 1rem;
	}

	.listing-hero__tools {
		gap: 16px;
		margin-top: 20px;
		padding: 16px 0;
	}

	.listing-hero__tools--single {
		margin-top: 18px;
		padding-top: 16px;
	}

	.listing-hero__support {
		gap: 8px;
	}

	.listing-hero__support li {
		font-size: 0.84rem;
		min-height: 34px;
		padding: 0 11px;
	}

	.listing-hero__filters {
		padding: 18px;
	}

	.listing-hero--care .listing-hero__filters {
		padding: 0;
	}

	.listing-hero--care .letter-box {
		display: flex;
		flex-wrap: nowrap;
		gap: 8px;
		margin-top: 14px;
		overflow-x: auto;
		padding-bottom: 4px;
		-webkit-overflow-scrolling: touch;
	}

	.listing-hero--care .letter-box li {
		flex: 0 0 auto;
	}

	.condition-page-shell .listing-card-list--care {
		grid-template-columns: 1fr;
	}

	.listing-card-list--articles {
		grid-template-columns: 1fr;
	}

	.condition-page-shell .listing-card--care {
		min-height: 0;
	}

	.condition-page-shell .listing-card--care .listing-card__media {
		aspect-ratio: 1.3;
	}

	.condition-page-shell .listing-card--care .listing-card__body {
		min-height: 0;
		padding: 4px 0 0;
	}

	.condition-page-shell .listing-card--care .listing-card__title {
		font-size: 1.02rem;
	}

	.listing-hero__quick-links a {
		padding: 12px 14px;
	}

	.treatment-overview-subbranches__title {
		margin-bottom: 16px;
	}

	.treatment-overview-subbranches__grid {
		gap: 14px;
		grid-template-columns: 1fr;
	}

	.subbranch-card {
		gap: 14px;
		grid-template-columns: minmax(0, 1fr) 38px;
		grid-template-rows: auto minmax(46px, auto);
		padding: 12px;
	}

	.subbranch-card__title {
		font-size: 1.04rem;
	}

	.subbranch-card__description {
		-webkit-line-clamp: 2;
		font-size: 0.84rem;
	}

	.subbranch-card .feather {
		height: 38px;
		padding: 10px;
		width: 38px;
	}

	.listing-card-list--articles .listing-card,
	.listing-card-list--categories .listing-card {
		gap: 16px;
		padding: 16px;
	}

	.listing-card-list--articles .listing-card--article {
		gap: 0;
		min-height: 0;
		padding: 0;
	}

	.listing-card-list--categories .listing-card {
		padding: 20px;
	}

	.listing-card-list--articles .listing-card__media,
	.listing-card-list--categories .listing-card__media {
		aspect-ratio: 16 / 10;
		min-height: 0;
	}

	.listing-card-list--articles .listing-card--article .listing-card__media {
		aspect-ratio: 1.3;
		border-radius: 20px 20px 6px 6px;
		min-height: 0;
	}

	.listing-card-list--articles .listing-card--article::before {
		content: none;
	}

	.listing-card-list--articles .listing-card--article .listing-card__body {
		grid-template-columns: minmax(0, 1fr);
		padding: 4px 0 0;
	}

	.listing-card-list--articles .listing-card--article .listing-card__description {
		display: -webkit-box;
	}

	.listing-card-list--articles .listing-card--article .listing-card__cta {
		display: none;
	}

	.listing-card-list--articles .listing-card--article .listing-card__cta i,
	.listing-card-list--articles .listing-card--article .listing-card__cta svg {
		height: 16px;
		width: 16px;
	}

	.listing-card__title {
		font-size: 1.16rem;
	}

	.listing-card__description {
		font-size: 0.93rem;
		line-height: 1.56;
	}

	.listing-card__meta {
		gap: 8px;
	}

	.listing-card-list--articles .listing-card--article .listing-card__cta {
		padding: 0;
	}

	.listing-feature-card {
		padding: 22px;
	}

	.treatment-overview-section .border-category {
		align-items: flex-start;
		flex-direction: column;
	}

	.treatment-overview-section .row {
		padding: 16px;
	}

}

@media screen and (max-width: 479px) {
	.listing-card-list--articles .listing-card--article .listing-card__media {
		aspect-ratio: 1.3;
	}
}

.listing-hero--hospital-directory > .container,
.listing-hero--hospital-directory + .hospital-directory-page > .container {
	max-width: var(--site-container-max);
}

.listing-hero--hospital-directory .listing-hero__grid--single {
	grid-template-columns: minmax(0, 1fr);
}

.listing-hero--hospital-directory .listing-hero__lead {
	max-width: 820px;
}

.hospital-directory-page {
	background: linear-gradient(180deg, #f8fafc 0%, #eef7fb 100%);
}

.hospital-directory-page .container {
	max-width: var(--site-container-max);
}

.listing-shell--hospital-directory {
	display: block;
}

.hospital-directory-header {
	align-items: end;
	border-bottom: 1px solid rgba(188, 214, 234, 0.85);
	display: flex;
	gap: 18px 36px;
	justify-content: space-between;
	margin-bottom: clamp(22px, 3vw, 34px);
	padding-bottom: clamp(18px, 2.4vw, 28px);
}

.hospital-directory-header__eyebrow,
.hospital-directory-cta__eyebrow {
	color: var(--color-primary);
	display: inline-flex;
	font-size: 0.74rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.08em;
	line-height: 1.2;
	text-transform: uppercase;
}

.hospital-directory-header h2 {
	color: var(--color-ink-strong);
	font-size: clamp(1.72rem, 1.2rem + 1.15vw, 2.42rem);
	font-weight: var(--weight-display);
	line-height: 1.06;
	margin: 0;
}

.hospital-directory-header p {
	color: var(--color-muted);
	font-size: 1rem;
	line-height: 1.62;
	margin: 12px 0 0;
	max-width: 720px;
}

.listing-card-list--hospital-directory {
	display: grid;
	gap: clamp(14px, 1.6vw, 22px);
	grid-template-columns: repeat(4, minmax(250px, 1fr));
	max-width: none;
}

.listing-card-list--hospital-directory .listing-card-list__item {
	min-width: 0;
}

.listing-card-list--hospital-directory .listing-card {
	background: transparent;
	border: 0;
	border-radius: 20px;
	box-shadow: 0 18px 44px rgba(16, 47, 79, 0.12);
	display: flex;
	flex-direction: column;
	gap: 0;
	height: 100%;
	isolation: isolate;
	justify-content: flex-end;
	min-height: clamp(270px, 16vw, 310px);
	overflow: hidden;
	padding: 0;
	position: relative;
}

.listing-card-list--hospital-directory .listing-card:hover,
.listing-card-list--hospital-directory .listing-card:focus {
	box-shadow: 0 24px 56px rgba(16, 47, 79, 0.18);
	transform: translateY(-4px);
}

.listing-card-list--hospital-directory .listing-card::before {
	background: linear-gradient(180deg, rgba(4, 13, 27, 0) 0%, rgba(4, 13, 27, 0) 36%, rgba(4, 13, 27, 0.78) 100%);
	border-radius: inherit;
	content: '';
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 2;
}

.listing-card-list--hospital-directory .listing-card__media {
	aspect-ratio: auto;
	background: #f5f9fc;
	border-radius: inherit;
	inset: 0;
	min-height: 100%;
	position: absolute;
	z-index: 1;
}

.listing-card-list--hospital-directory .listing-card__media::after {
	background: linear-gradient(180deg, rgba(5, 13, 27, 0) 0%, rgba(5, 13, 27, 0) 38%, rgba(5, 13, 27, 0.48) 100%);
	bottom: 0;
	content: '';
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
}

.listing-card-list--hospital-directory .listing-card__media img {
	height: 100%;
	min-height: 100%;
	object-fit: cover;
	transition:
		filter 0.24s ease,
		transform 0.24s ease;
	width: 100%;
}

.listing-card-list--hospital-directory .listing-card__body {
	align-items: end;
	color: #fff;
	display: grid;
	flex: 0 0 auto;
	grid-template-areas:
		'title cta'
		'meta cta';
	grid-template-columns: minmax(0, 1fr) 42px;
	column-gap: 14px;
	row-gap: 6px;
	min-width: 0;
	padding: clamp(18px, 2vw, 24px);
	position: relative;
	width: 100%;
	z-index: 3;
}

.listing-card-list--hospital-directory .listing-card__title {
	color: #fff;
	font-size: clamp(1.35rem, 1.06rem + 0.72vw, 1.86rem);
	font-weight: var(--weight-display);
	grid-area: title;
	letter-spacing: 0;
	line-height: 1.04;
	margin: 0;
	min-width: 0;
	text-shadow: 0 12px 28px rgba(4, 13, 27, 0.28);
}

.listing-card-list--hospital-directory .listing-card__description {
	display: none;
}

.listing-card-list--hospital-directory .listing-card__meta {
	align-self: start;
	color: rgba(255, 255, 255, 0.84);
	font-size: 0.88rem;
	gap: 0;
	grid-area: meta;
	line-height: 1.32;
	margin-top: 0;
	max-width: 100%;
	min-width: 0;
}

.listing-card-list--hospital-directory .listing-card__meta span {
	align-items: center;
	background: transparent;
	border: 0;
	border-radius: 0;
	color: inherit;
	display: flex;
	gap: 7px;
	max-height: none;
	min-width: 0;
	overflow: hidden;
	padding: 0;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.listing-card-list--hospital-directory .listing-card__meta i,
.listing-card-list--hospital-directory .listing-card__meta svg {
	color: rgba(255, 255, 255, 0.82);
	flex: 0 0 15px;
	height: 15px;
	margin-top: 0;
	width: 15px;
}

.listing-card-list--hospital-directory .listing-card__cta {
	align-self: end;
	align-items: center;
	background: rgba(255, 255, 255, 0.92);
	border: 1px solid rgba(255, 255, 255, 0.72);
	border-radius: 999px;
	box-shadow: 0 10px 20px rgba(7, 18, 37, 0.12);
	color: var(--color-primary-dark);
	display: inline-flex;
	font-size: 0;
	gap: 0;
	grid-area: cta;
	height: 40px;
	justify-content: center;
	justify-self: end;
	line-height: 1;
	margin: 0;
	overflow: hidden;
	padding: 0;
	position: relative;
	transition:
		background-color 0.2s ease,
		transform 0.2s ease;
	width: 40px;
}

.listing-card-list--hospital-directory .listing-card__cta i,
.listing-card-list--hospital-directory .listing-card__cta svg {
	background: transparent;
	border: 0;
	border-radius: 0;
	color: currentColor;
	flex: 0 0 17px;
	height: 17px;
	padding: 0;
	stroke-width: 2.35;
	width: 17px;
}

.listing-card-list--hospital-directory .listing-card:hover .listing-card__cta,
.listing-card-list--hospital-directory .listing-card:focus .listing-card__cta {
	background: #fff;
	color: var(--color-primary-dark);
	transform: translateX(2px);
}

.listing-card-list--hospital-directory .listing-card:hover .listing-card__cta i,
.listing-card-list--hospital-directory .listing-card:hover .listing-card__cta svg,
.listing-card-list--hospital-directory .listing-card:focus .listing-card__cta i,
.listing-card-list--hospital-directory .listing-card:focus .listing-card__cta svg {
	background: transparent;
	border: 0;
	color: currentColor;
	transform: none;
}

.listing-card-list--hospital-directory .listing-card:hover .listing-card__media img,
.listing-card-list--hospital-directory .listing-card:focus .listing-card__media img {
	filter: saturate(1.04) contrast(1.02);
	transform: scale(1.025);
}

.listing-card-list--hospital-directory .listing-card--hospital-partner .listing-card__media {
	background: #f5f9fc;
}

.listing-card-list--hospital-directory .listing-card--hospital-partner .listing-card__media img {
	object-fit: cover;
	padding: 0;
}

.hospital-directory-final-cta {
	background: transparent;
	margin-top: clamp(26px, 3vw, 40px);
	padding: 0;
	width: 100%;
}

.hospital-directory-final-cta .homepage-final-cta__inner {
	max-width: none;
	padding-left: 0;
	padding-right: 0;
}

.hospital-directory-cta {
	align-items: center;
	background:
		linear-gradient(135deg, rgba(16, 47, 79, 0.98) 0%, rgba(13, 71, 127, 0.96) 58%, rgba(16, 113, 121, 0.94) 100%);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 14px;
	box-shadow: 0 22px 52px rgba(16, 47, 79, 0.18);
	color: #fff;
	display: grid;
	gap: clamp(18px, 2vw, 28px);
	grid-template-columns: 54px minmax(0, 1fr) auto;
	margin-top: clamp(26px, 3vw, 40px);
	padding: clamp(22px, 2.8vw, 34px);
}

.hospital-directory-cta__icon {
	align-items: center;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 14px;
	color: #8fd3c7;
	display: flex;
	height: 54px;
	justify-content: center;
	width: 54px;
}

.hospital-directory-cta__icon i,
.hospital-directory-cta__icon svg {
	height: 24px;
	width: 24px;
}

.hospital-directory-cta__eyebrow {
	color: #8fd3c7;
	margin-bottom: 10px;
}

.hospital-directory-cta h2 {
	color: #fff;
	font-size: clamp(1.32rem, 1.08rem + 0.55vw, 1.72rem);
	font-weight: var(--weight-display);
	line-height: 1.12;
	margin: 0;
}

.hospital-directory-cta p {
	color: rgba(255, 255, 255, 0.78);
	line-height: 1.58;
	margin: 12px 0 0;
	max-width: 760px;
}

.hospital-directory-cta__list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 16px;
	list-style: none;
	margin: 18px 0 0;
	padding: 0;
}

.hospital-directory-cta__list li {
	align-items: center;
	color: rgba(255, 255, 255, 0.9);
	display: inline-flex;
	font-size: 0.92rem;
	gap: 8px;
}

.hospital-directory-cta__list i,
.hospital-directory-cta__list svg {
	color: #8fd3c7;
	flex: 0 0 16px;
	height: 16px;
	width: 16px;
}

.hospital-directory-cta__button {
	align-items: center;
	border-radius: 999px;
	display: inline-flex;
	gap: 10px;
	justify-content: center;
	min-height: 48px;
	padding: 13px 24px;
	white-space: nowrap;
}

.hospital-directory-cta__button i,
.hospital-directory-cta__button svg {
	height: 17px;
	width: 17px;
}

@media screen and (max-width: 1199px) {
	.listing-card-list--hospital-directory {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 991px) {
	.hospital-directory-header {
		align-items: start;
		flex-direction: column;
	}

	.hospital-directory-cta {
		align-items: start;
		grid-template-columns: 54px minmax(0, 1fr);
	}

	.hospital-directory-cta__button {
		grid-column: 2;
		justify-self: start;
	}
}

@media screen and (max-width: 767px) {
	.listing-card-list--hospital-directory,
	.hospital-directory-cta {
		grid-template-columns: 1fr;
	}

	.hospital-directory-cta__button {
		grid-column: auto;
		width: 100%;
	}
}

@media screen and (max-width: 575px) {
	.hospital-directory-header {
		margin-bottom: 20px;
		padding-bottom: 18px;
	}

	.listing-card-list--hospital-directory .listing-card__body {
		padding: 20px;
	}

	.hospital-directory-cta {
		border-radius: 12px;
		padding: 22px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.listing-card-list--hospital-directory .listing-card,
	.listing-card-list--hospital-directory .listing-card__media img {
		transition: none;
	}

	.listing-card-list--hospital-directory .listing-card:hover,
	.listing-card-list--hospital-directory .listing-card:focus,
	.listing-card-list--hospital-directory .listing-card:hover .listing-card__media img,
	.listing-card-list--hospital-directory .listing-card:focus .listing-card__media img {
		transform: none;
	}
}

.support-topic-page {
	background: #f7fbff;
	color: var(--color-ink-strong);
}

.support-topic-hero {
	background:
		linear-gradient(135deg, rgba(239, 248, 255, 0.96), rgba(255, 255, 255, 0.98) 54%),
		radial-gradient(circle at 88% 18%, rgba(31, 157, 114, 0.12), transparent 26%);
	padding: 64px 0 76px;
}

.support-topic-hero .container,
.support-topic-section .container,
.support-topic-final .container {
	max-width: var(--site-container-max);
	padding-left: var(--site-container-gutter);
	padding-right: var(--site-container-gutter);
}

.support-topic-hero__grid {
	align-items: center;
	display: grid;
	gap: clamp(32px, 4.4vw, 72px);
	grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
	margin-top: 34px;
}

.support-topic-hero__copy {
	max-width: var(--public-content-max);
}

.support-topic-hero__copy h1 {
	color: #102f4f;
	font-size: clamp(2.25rem, 5vw, 4.8rem);
	font-weight: var(--weight-bold);
	letter-spacing: 0;
	line-height: 0.98;
	margin: 18px 0 22px;
	max-width: 880px;
}

.support-topic-hero__copy p {
	color: #4f6478;
	font-size: var(--text-lead);
	line-height: 1.55;
	margin: 0;
	max-width: var(--public-reading-max);
}

.support-topic-hero__trust {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 6px 0;
	margin-top: 18px;
	max-width: var(--public-content-max);
}

.support-topic-hero__trust span {
	align-items: center;
	color: #667d91;
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: var(--weight-bold);
	letter-spacing: 0.08em;
	line-height: 1.35;
	text-transform: uppercase;
	white-space: nowrap;
}

.support-topic-hero__trust span + span {
	margin-left: 12px;
}

.support-topic-hero__trust span + span::before {
	color: rgba(102, 125, 145, 0.58);
	content: '/';
	margin-right: 12px;
}

.support-topic-hero__cta {
	align-items: center;
	display: inline-flex;
	justify-content: center;
	margin-top: 30px;
	text-align: center;
}

.support-topic-hero__media {
	align-items: center;
	border-radius: 8px;
	display: flex;
	justify-content: flex-end;
	margin: 0;
	min-height: auto;
	overflow: hidden;
}

.support-topic-hero__media img {
	aspect-ratio: 4 / 3;
	border-radius: 18px;
	box-shadow: 0 24px 60px rgba(16, 47, 79, 0.1);
	display: block;
	height: auto;
	max-width: 100%;
	object-fit: cover;
	object-position: center;
	width: min(100%, 560px);
}

/* Topical hero photo inside trust hero panels */
.trust-topic-hero__panel-media {
	margin: -30px -30px 24px;
	border-radius: 8px 8px 0 0;
	overflow: hidden;
}

.trust-topic-hero__panel-media img {
	display: block;
	width: 100%;
	height: 220px;
	object-fit: cover;
	object-position: center;
}

.trust-topic-hero__panel--has-image i,
.trust-topic-hero__panel--has-image svg {
	margin-bottom: 18px;
}

.support-topic-section {
	padding: 70px 0;
}

.support-topic-section--soft {
	background: #fff;
	border-bottom: 1px solid rgba(16, 47, 79, 0.08);
	border-top: 1px solid rgba(16, 47, 79, 0.08);
}

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

.support-topic-card {
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.1);
	border-radius: 8px;
	min-height: 248px;
	padding: 28px;
}

.support-topic-card span,
.support-topic-kicker {
	color: var(--color-primary);
	display: inline-block;
	font-size: 0.78rem;
	font-weight: var(--weight-bold);
	letter-spacing: 0.08em;
	margin-bottom: 16px;
	text-transform: uppercase;
}

.support-topic-card h2,
.support-topic-checklist h2,
.support-topic-final h2 {
	color: #102f4f;
	font-weight: var(--weight-bold);
	letter-spacing: 0;
	margin: 0;
}

.support-topic-card h2 {
	font-size: 1.32rem;
	margin-bottom: 14px;
}

.support-topic-card p {
	color: #5d7080;
	line-height: 1.68;
	margin: 0;
}

.support-topic-checklist {
	align-items: start;
	display: grid;
	gap: 42px;
	grid-template-columns: minmax(260px, 0.42fr) minmax(0, 0.58fr);
}

.support-topic-checklist h2 {
	font-size: clamp(1.8rem, 3vw, 3rem);
	line-height: 1.05;
}

.support-topic-checklist ul {
	display: grid;
	gap: 14px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.support-topic-checklist li {
	align-items: flex-start;
	background: #f7fbff;
	border: 1px solid rgba(16, 47, 79, 0.09);
	border-radius: 8px;
	color: #34495c;
	display: flex;
	gap: 12px;
	line-height: 1.55;
	padding: 16px 18px;
}

.support-topic-checklist li i,
.support-topic-checklist li svg {
	color: #1f9d72;
	flex: 0 0 auto;
	height: 20px;
	margin-top: 2px;
	width: 20px;
}

.support-topic-section--details {
	background: #f7fbff;
}

.support-topic-details {
	align-items: start;
	display: grid;
	gap: clamp(28px, 4vw, 54px);
	grid-template-columns: minmax(0, 1fr);
}

.support-topic-include,
.request-prep-after,
.support-topic-faq,
.support-topic-faq .sh-faq__item {
	min-width: 0;
}

.support-topic-include h2,
.request-prep-after h2,
.support-topic-faq h2 {
	color: #102f4f;
	font-weight: var(--weight-bold);
	letter-spacing: 0;
	line-height: 1.08;
	margin: 0;
}

.support-topic-include h2,
.support-topic-faq h2 {
	font-size: 2.65rem;
	max-width: 860px;
}

.request-prep-after h2 {
	font-size: 1.85rem;
}

.support-topic-section-lead {
	color: #5d7080;
	font-size: 1.06rem;
	line-height: 1.68;
	margin: 18px 0 0;
	max-width: 760px;
}

.support-topic-include__grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-top: 28px;
}

.support-topic-include__item {
	align-items: flex-start;
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.09);
	border-radius: 8px;
	box-shadow: 0 16px 38px rgba(16, 47, 79, 0.06);
	display: flex;
	gap: 14px;
	min-width: 0;
	padding: 20px;
}

.support-topic-include__icon {
	align-items: center;
	background: #e9f5fb;
	border: 1px solid rgba(47, 143, 211, 0.2);
	border-radius: 50%;
	color: var(--color-primary);
	display: inline-flex;
	flex: 0 0 42px;
	height: 42px;
	justify-content: center;
	width: 42px;
}

.support-topic-include__icon i,
.support-topic-include__icon svg {
	height: 19px;
	width: 19px;
}

.support-topic-include__item h3,
.request-prep-after h3 {
	color: #102f4f;
	font-size: 1.05rem;
	font-weight: var(--weight-bold);
	letter-spacing: 0;
	line-height: 1.28;
	margin: 0;
	overflow-wrap: anywhere;
}

.support-topic-include__item p,
.request-prep-after p {
	color: #5d7080;
	line-height: 1.62;
	margin: 8px 0 0;
	overflow-wrap: anywhere;
}

.request-prep-after {
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.1);
	border-radius: 8px;
	box-shadow: 0 20px 48px rgba(16, 47, 79, 0.08);
	padding: clamp(24px, 3vw, 34px);
}

.request-prep-after__steps {
	counter-reset: request-prep-after-step;
	display: grid;
	gap: 18px;
	list-style: none;
	margin: 26px 0 0;
	padding: 0;
}

.request-prep-after__steps li {
	align-items: flex-start;
	border-top: 1px solid rgba(16, 47, 79, 0.1);
	counter-increment: request-prep-after-step;
	display: flex;
	gap: 14px;
	min-width: 0;
	padding-top: 18px;
}

.request-prep-after__steps li:first-child {
	border-top: 0;
	padding-top: 0;
}

.request-prep-after__steps li::before {
	align-items: center;
	background: var(--color-primary);
	border-radius: 50%;
	color: #fff;
	content: counter(request-prep-after-step);
	display: inline-flex;
	flex: 0 0 32px;
	font-size: 0.82rem;
	font-weight: var(--weight-bold);
	height: 32px;
	justify-content: center;
	line-height: 1;
	margin-top: 2px;
	width: 32px;
}

.support-topic-faq-section {
	border-bottom: 1px solid rgba(16, 47, 79, 0.08);
	border-top: 1px solid rgba(16, 47, 79, 0.08);
}

.support-topic-faq {
	align-items: start;
	display: grid;
	gap: clamp(26px, 4vw, 52px);
	grid-template-columns: minmax(240px, 0.36fr) minmax(0, 0.64fr);
}

.support-topic-faq__list {
	display: grid;
	gap: 14px;
}

.support-topic-faq__accordion {
	gap: 14px;
}

.support-topic-faq .sh-faq__item {
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.09);
	border-radius: 8px;
	box-shadow: 0 16px 38px rgba(16, 47, 79, 0.06);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.support-topic-faq .sh-faq__item[open] {
	border-color: rgba(47, 143, 211, 0.26);
	box-shadow: 0 20px 44px rgba(16, 47, 79, 0.08);
}

.support-topic-faq .sh-faq__q {
	align-items: center;
	background: transparent;
	border: 0;
	color: #102f4f;
	display: flex;
	font-size: 1.05rem;
	font-weight: var(--weight-bold);
	gap: 18px;
	justify-content: space-between;
	letter-spacing: 0;
	line-height: 1.28;
	min-height: 72px;
	padding: 20px 24px;
}

.support-topic-faq .sh-faq__q > span {
	overflow-wrap: anywhere;
}

.support-topic-faq .sh-faq__q i,
.support-topic-faq .sh-faq__q svg {
	align-items: center;
	background: #e9f5fb;
	border: 1px solid rgba(47, 143, 211, 0.22);
	border-radius: 50%;
	color: var(--color-primary);
	display: inline-flex;
	flex: 0 0 34px;
	height: 34px;
	justify-content: center;
	padding: 8px;
	transition: transform 0.2s ease;
	width: 34px;
}

.support-topic-faq .sh-faq__item[open] .sh-faq__q svg {
	transform: rotate(180deg);
}

.support-topic-faq .sh-faq__q:focus-visible {
	border-radius: 8px;
	outline-offset: -4px;
}

.support-topic-faq .sh-faq__a {
	border-top: 1px solid rgba(16, 47, 79, 0.08);
	color: #5d7080;
	line-height: 1.62;
	margin: 0 24px;
	overflow-wrap: anywhere;
	padding: 18px 0 22px;
}

.support-topic-final {
	padding: 72px 0 86px;
}

.support-topic-final__panel {
	background: linear-gradient(135deg, #102f4f 0%, #1769aa 100%);
	border-radius: 8px;
	color: #fff;
	padding: 46px;
	text-align: center;
}

.support-topic-final h2 {
	color: #fff;
	font-size: clamp(1.8rem, 3vw, 3.2rem);
}

.support-topic-final p {
	color: rgba(255, 255, 255, 0.82);
	font-size: 1.08rem;
	line-height: 1.65;
	margin: 18px auto 28px;
	max-width: 760px;
}

@media screen and (max-width: 991px) {
	.support-topic-hero__grid,
	.support-topic-grid,
	.support-topic-checklist,
	.support-topic-details,
	.support-topic-faq {
		grid-template-columns: 1fr;
	}

	.support-topic-hero__media {
		min-height: auto;
	}

	.support-topic-hero__copy,
	.support-topic-hero__copy h1,
	.support-topic-hero__copy p,
	.support-topic-hero__trust {
		max-width: none;
	}

	.support-topic-include h2,
	.support-topic-faq h2 {
		font-size: 2.25rem;
	}
}

@media screen and (max-width: 575px) {
	.support-topic-hero {
		padding: 42px 0 54px;
	}

	.support-topic-hero__grid {
		gap: 24px;
		margin-top: 24px;
	}

	.support-topic-hero__copy h1 {
		font-size: clamp(2rem, 1.8rem + 1vw, 2.4rem);
	}

	.support-topic-hero__copy p {
		font-size: 1rem;
	}

	.support-topic-card,
	.support-topic-final__panel {
		padding: 22px;
	}

	.support-topic-hero__media {
		min-height: 240px;
	}

	.support-topic-section {
		padding: 48px 0;
	}

	.support-topic-include__grid {
		grid-template-columns: 1fr;
	}

	.support-topic-include__item {
		padding: 18px;
	}

	.support-topic-faq .sh-faq__q {
		gap: 12px;
		min-height: 64px;
		padding: 18px;
	}

	.support-topic-faq .sh-faq__q i,
	.support-topic-faq .sh-faq__q svg {
		flex-basis: 32px;
		height: 32px;
		padding: 7px;
		width: 32px;
	}

	.support-topic-faq .sh-faq__a {
		margin: 0 18px;
		padding: 16px 0 18px;
	}

	.support-topic-include h2,
	.support-topic-faq h2 {
		font-size: 1.85rem;
	}

	.request-prep-after h2 {
		font-size: 1.5rem;
	}

	.support-topic-final {
		padding: 54px 0 66px;
	}

	.support-topic-hero__trust {
		align-items: flex-start;
		flex-direction: column;
		gap: 6px;
	}

	.support-topic-hero__trust span {
		font-size: 0.72rem;
		min-width: 0;
		white-space: normal;
	}

	.support-topic-hero__trust span + span {
		margin-left: 0;
	}

	.support-topic-hero__trust span + span::before {
		content: none;
	}

	.support-topic-hero__media img {
		width: 100%;
	}
}

.trust-topic-page,
.policy-topic-page {
	background: #f7fbff;
	color: var(--color-ink-strong);
}

.trust-topic-hero,
.policy-topic-hero {
	background:
		linear-gradient(135deg, rgba(239, 248, 255, 0.96), rgba(255, 255, 255, 0.98) 54%),
		radial-gradient(circle at 88% 18%, rgba(31, 157, 114, 0.12), transparent 26%);
	padding: 64px 0 76px;
}

.trust-topic-hero .container,
.trust-topic-section .container,
.trust-topic-final .container,
.policy-topic-hero .container,
.policy-topic-section .container,
.policy-topic-final .container {
	max-width: var(--site-container-max);
	padding-left: var(--site-container-gutter);
	padding-right: var(--site-container-gutter);
}

.trust-topic-hero__grid,
.policy-topic-hero__grid {
	align-items: stretch;
	display: grid;
	gap: 34px;
	grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.55fr);
	margin-top: 34px;
}

.trust-topic-hero__copy h1,
.policy-topic-hero__copy h1 {
	color: #102f4f;
	font-size: clamp(2.25rem, 5vw, 4.8rem);
	font-weight: var(--weight-bold);
	line-height: 0.98;
	margin: 18px 0 22px;
	max-width: 880px;
}

.trust-topic-hero__copy p,
.policy-topic-hero__copy p {
	color: #496276;
	font-size: 1.18rem;
	line-height: 1.7;
	margin: 0;
	max-width: 760px;
}

.trust-topic-hero__trust,
.policy-topic-hero__trust,
.trust-topic-hero__cta {
	margin-top: 26px;
}

.trust-topic-hero__panel,
.policy-topic-hero__panel {
	align-self: end;
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.1);
	border-radius: 8px;
	box-shadow: 0 24px 56px rgba(16, 47, 79, 0.11);
	min-height: 280px;
	padding: 30px;
}

.trust-topic-hero__panel i,
.trust-topic-hero__panel svg,
.policy-topic-hero__panel i,
.policy-topic-hero__panel svg {
	background: rgba(23, 105, 170, 0.1);
	border-radius: 50%;
	color: var(--color-primary);
	height: 52px;
	margin-bottom: 26px;
	padding: 14px;
	width: 52px;
}

.trust-topic-hero__panel h2,
.policy-topic-hero__panel h2 {
	color: #102f4f;
	font-size: 1.32rem;
	font-weight: var(--weight-bold);
	margin: 0 0 12px;
}

.trust-topic-hero__panel p,
.policy-topic-hero__panel p {
	color: #5d7080;
	line-height: 1.64;
	margin: 0;
}

.trust-topic-section,
.policy-topic-section {
	padding: 70px 0;
}

.trust-topic-section--soft {
	background: #fff;
	border-bottom: 1px solid rgba(16, 47, 79, 0.08);
	border-top: 1px solid rgba(16, 47, 79, 0.08);
}

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

.trust-topic-card,
.policy-topic-content {
	background: #fff;
	border: 1px solid rgba(16, 47, 79, 0.1);
	border-radius: 8px;
	box-shadow: 0 18px 44px rgba(16, 47, 79, 0.06);
}

.trust-topic-card {
	min-height: 248px;
	padding: 28px;
}

.trust-topic-card span,
.trust-topic-kicker {
	color: var(--color-primary);
	display: inline-block;
	font-size: 0.78rem;
	font-weight: var(--weight-bold);
	letter-spacing: 0.08em;
	margin-bottom: 16px;
	text-transform: uppercase;
}

.trust-topic-card h2,
.trust-topic-checklist h2,
.trust-topic-final h2,
.policy-topic-final h2 {
	color: #102f4f;
	font-weight: var(--weight-bold);
	letter-spacing: 0;
	margin: 0;
}

.trust-topic-card h2 {
	font-size: 1.32rem;
	margin-bottom: 14px;
}

.trust-topic-card p {
	color: #5d7080;
	line-height: 1.68;
	margin: 0;
}

.trust-topic-list {
	display: grid;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.trust-topic-list li {
	align-items: flex-start;
	color: #34495c;
	display: flex;
	gap: 10px;
	line-height: 1.55;
}

.trust-topic-list svg {
	color: var(--color-primary);
	flex: 0 0 auto;
	height: 18px;
	margin-top: 3px;
	width: 18px;
}

.trust-topic-list a,
.trust-topic-card__actions a {
	color: var(--color-primary);
	font-weight: var(--weight-semibold);
}

.trust-topic-card__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 22px;
}

.trust-topic-checklist {
	align-items: start;
	display: grid;
	gap: 42px;
	grid-template-columns: minmax(260px, 0.42fr) minmax(0, 0.58fr);
}

.trust-topic-checklist h2 {
	font-size: clamp(1.8rem, 3vw, 3rem);
	line-height: 1.05;
}

.trust-topic-checklist p {
	color: #5d7080;
	line-height: 1.65;
	margin: 18px 0 0;
}

.trust-topic-checklist ul {
	display: grid;
	gap: 14px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.trust-topic-checklist li {
	align-items: flex-start;
	background: #f7fbff;
	border: 1px solid rgba(16, 47, 79, 0.09);
	border-radius: 8px;
	color: #34495c;
	display: flex;
	gap: 12px;
	line-height: 1.55;
	padding: 16px 18px;
}

.trust-topic-checklist li svg {
	color: #1f9d72;
	flex: 0 0 auto;
	height: 20px;
	margin-top: 2px;
	width: 20px;
}

.policy-topic-content {
	color: #34495c;
	font-size: 1.02rem;
	line-height: 1.75;
	margin: 0 auto;
	max-width: 980px;
	padding: 42px;
}

.policy-topic-content h2,
.policy-topic-content h3 {
	color: #102f4f;
	font-weight: var(--weight-bold);
	letter-spacing: 0;
	margin: 34px 0 14px;
}

.policy-topic-content h2:first-child,
.policy-topic-content h3:first-child,
.policy-topic-content p:first-child {
	margin-top: 0;
}

.policy-topic-content a {
	color: var(--color-primary);
	font-weight: var(--weight-semibold);
}

.trust-topic-final,
.policy-topic-final {
	padding: 72px 0 86px;
}

.trust-topic-final__panel,
.policy-topic-final__panel {
	background: linear-gradient(135deg, #102f4f 0%, #1769aa 100%);
	border-radius: 8px;
	color: #fff;
	padding: 46px;
	text-align: center;
}

.trust-topic-final h2,
.policy-topic-final h2 {
	color: #fff;
	font-size: clamp(1.8rem, 3vw, 3.2rem);
}

.trust-topic-final p,
.policy-topic-final p {
	color: rgba(255, 255, 255, 0.82);
	font-size: 1.08rem;
	line-height: 1.65;
	margin: 18px auto 28px;
	max-width: 760px;
}

@media screen and (max-width: 991px) {
	.trust-topic-hero__grid,
	.policy-topic-hero__grid,
	.trust-topic-grid,
	.trust-topic-checklist {
		grid-template-columns: 1fr;
	}

	.trust-topic-hero__panel,
	.policy-topic-hero__panel {
		align-self: stretch;
		min-height: 0;
	}
}

@media screen and (max-width: 575px) {
	.trust-topic-hero,
	.policy-topic-hero {
		padding: 42px 0 54px;
	}

	.trust-topic-hero__grid,
	.policy-topic-hero__grid {
		gap: 24px;
		margin-top: 24px;
	}

	.trust-topic-hero__copy h1,
	.policy-topic-hero__copy h1 {
		font-size: 2.15rem;
	}

	.trust-topic-hero__copy p,
	.policy-topic-hero__copy p {
		font-size: 1rem;
	}

	.trust-topic-hero__panel,
	.policy-topic-hero__panel,
	.trust-topic-card,
	.policy-topic-content,
	.trust-topic-final__panel,
	.policy-topic-final__panel {
		padding: 22px;
	}

	.trust-topic-section,
	.policy-topic-section {
		padding: 48px 0;
	}

	.trust-topic-final,
	.policy-topic-final {
		padding: 54px 0 66px;
	}
}

/* =======================================================================
   Trust & Compliance premium clinical refresh
   ======================================================================= */
.trust-topic-page {
	background: #ffffff;
	color: var(--color-body);
	overflow: hidden;
}

.trust-topic-hero {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(246, 251, 255, 0.98) 100%),
		repeating-linear-gradient(90deg, rgba(23, 105, 170, 0.045) 0 1px, transparent 1px 80px);
	border-bottom: 1px solid rgba(189, 219, 242, 0.72);
	isolation: isolate;
	overflow: hidden;
	padding: clamp(42px, 5.8vw, 86px) 0 clamp(72px, 7vw, 112px);
	position: relative;
}

.trust-topic-hero::before {
	background:
		linear-gradient(135deg, rgba(23, 105, 170, 0.12), rgba(47, 143, 211, 0.02) 58%, transparent 58%),
		linear-gradient(315deg, rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0) 62%);
	border-left: 1px solid rgba(141, 190, 226, 0.36);
	bottom: -20%;
	content: '';
	pointer-events: none;
	position: absolute;
	right: -8%;
	top: -18%;
	transform: skewX(-13deg);
	width: min(42vw, 620px);
	z-index: -1;
}

.trust-topic-hero__grid {
	align-items: center;
	gap: clamp(30px, 5vw, 78px);
	grid-template-columns: minmax(0, 0.98fr) minmax(360px, 0.68fr);
	margin-top: clamp(28px, 3.6vw, 52px);
}

.trust-topic-hero__copy h1 {
	color: var(--color-ink-strong);
	font-size: clamp(2.5rem, 4.7vw, 5.35rem);
	font-weight: var(--weight-display);
	line-height: 1.02;
	margin: 20px 0 22px;
	max-width: 900px;
}

.trust-topic-hero__copy p {
	color: #415468;
	font-size: clamp(1.06rem, 1rem + 0.3vw, 1.28rem);
	font-weight: var(--weight-medium);
	line-height: 1.55;
	max-width: 780px;
}

.trust-topic-hero__trust {
	gap: 10px;
	margin-top: 28px;
}

.trust-topic-hero__actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 14px 18px;
	margin-top: 30px;
}

.trust-topic-hero__cta {
	background: var(--color-primary);
	border-color: var(--color-primary);
	box-shadow: 0 14px 30px rgba(23, 105, 170, 0.18);
	min-height: 56px;
}

.trust-topic-hero__cta:hover,
.trust-topic-hero__cta:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	box-shadow: 0 16px 34px rgba(16, 47, 79, 0.2);
}

.trust-topic-hero__secondary,
.trust-topic-inline-link,
.trust-topic-authorization-card a {
	align-items: center;
	color: var(--color-primary-dark);
	display: inline-flex;
	font-weight: var(--weight-semibold);
	gap: 8px;
	line-height: 1.2;
	text-decoration: none;
}

.trust-topic-hero__secondary:hover,
.trust-topic-hero__secondary:focus,
.trust-topic-inline-link:hover,
.trust-topic-inline-link:focus,
.trust-topic-authorization-card a:hover,
.trust-topic-authorization-card a:focus {
	color: var(--color-primary);
	text-decoration: none;
}

.trust-topic-hero__secondary svg,
.trust-topic-inline-link svg,
.trust-topic-authorization-card a svg {
	height: 17px;
	width: 17px;
}

.trust-topic-hero__panel {
	align-self: center;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 251, 255, 0.98)),
		#fff;
	border: 1px solid rgba(189, 219, 242, 0.82);
	border-radius: 8px;
	box-shadow: 0 26px 64px rgba(16, 47, 79, 0.14);
	min-height: 0;
	overflow: hidden;
	padding: 0;
}

.trust-topic-hero__panel-media {
	aspect-ratio: 1.42;
	border-radius: 0;
	margin: 0;
	position: relative;
}

.trust-topic-hero__panel-media::after {
	background: linear-gradient(180deg, rgba(7, 18, 37, 0) 45%, rgba(7, 18, 37, 0.22) 100%);
	content: '';
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.trust-topic-hero__panel-media img {
	height: 100%;
	object-position: center;
}

.trust-topic-hero__panel-body {
	padding: clamp(22px, 2.4vw, 34px);
}

.trust-topic-hero__panel-body > i,
.trust-topic-hero__panel-body > svg {
	background: rgba(23, 105, 170, 0.1);
	border-radius: 50%;
	color: var(--color-primary);
	height: 50px;
	margin: 0 0 18px;
	padding: 13px;
	width: 50px;
}

.trust-topic-hero__panel-kicker {
	color: var(--color-primary);
	display: block;
	font-size: 0.78rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.05em;
	margin-bottom: 9px;
	text-transform: uppercase;
}

.trust-topic-hero__panel h2 {
	color: var(--color-ink-strong);
	font-size: clamp(1.25rem, 1.08rem + 0.45vw, 1.54rem);
	font-weight: var(--weight-display);
	line-height: 1.16;
	margin-bottom: 10px;
}

.trust-topic-hero__panel p {
	color: var(--color-muted);
	font-size: 1rem;
	line-height: 1.55;
}

.trust-topic-proof {
	background: #fff;
	margin-top: clamp(-46px, -3vw, -26px);
	position: relative;
	z-index: 3;
}

.trust-topic-proof .container,
.trust-topic-section .container {
	max-width: var(--site-container-max);
	padding-left: var(--site-container-gutter);
	padding-right: var(--site-container-gutter);
}

.trust-topic-proof .container {
	padding-top: clamp(18px, 2.4vw, 34px);
}

.trust-topic-proof__grid {
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(189, 219, 242, 0.84);
	border-radius: 8px;
	box-shadow: 0 22px 52px rgba(16, 47, 79, 0.08);
	display: grid;
	gap: 0;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	overflow: hidden;
}

.trust-topic-proof-card {
	align-items: center;
	display: flex;
	gap: 13px;
	min-height: 108px;
	min-width: 0;
	padding: 20px;
	position: relative;
}

.trust-topic-proof-card + .trust-topic-proof-card {
	border-left: 1px solid rgba(216, 232, 245, 0.92);
}

.trust-topic-proof-card > i,
.trust-topic-proof-card > svg {
	background: rgba(23, 105, 170, 0.09);
	border-radius: 8px;
	color: var(--color-primary);
	flex: 0 0 40px;
	height: 40px;
	padding: 10px;
	width: 40px;
}

.trust-topic-proof-card strong,
.trust-topic-proof-card span {
	display: block;
	min-width: 0;
}

.trust-topic-proof-card strong {
	color: var(--color-ink-strong);
	font-size: 0.98rem;
	font-weight: var(--weight-display);
	line-height: 1.16;
}

.trust-topic-proof-card span {
	color: var(--color-muted);
	font-size: 0.88rem;
	line-height: 1.28;
	margin-top: 5px;
}

.trust-topic-section {
	background: #fff;
	padding: clamp(62px, 7vw, 106px) 0;
}

.trust-topic-section--decision {
	background: linear-gradient(180deg, #ffffff 0%, #f8fcff 100%);
}

.trust-topic-section--soft {
	background: linear-gradient(180deg, #f8fcff 0%, #ffffff 100%);
	border-bottom: 1px solid rgba(216, 232, 245, 0.8);
	border-top: 1px solid rgba(216, 232, 245, 0.8);
}

.trust-topic-section__header {
	align-items: start;
	display: grid;
	gap: clamp(20px, 3vw, 40px);
	grid-template-columns: minmax(0, 0.9fr) minmax(360px, 0.74fr);
	margin-bottom: clamp(28px, 4vw, 52px);
}

.trust-topic-section__header--center {
	display: block;
	margin-inline: auto;
	max-width: 860px;
	text-align: center;
}

.trust-topic-section__header h2,
.trust-topic-verification__copy h2 {
	color: var(--color-ink-strong);
	font-size: clamp(2.2rem, 1.84rem + 1.55vw, 3.25rem);
	font-weight: var(--weight-display);
	line-height: 1.08;
	margin: 0;
	max-width: 720px;
}

.trust-topic-section__header p,
.trust-topic-verification__copy > p {
	color: var(--color-muted);
	font-size: clamp(1.02rem, 0.98rem + 0.22vw, 1.14rem);
	line-height: 1.58;
	margin: 0;
	max-width: 46rem;
}

.trust-topic-section__header--center h2,
.trust-topic-section__header--center p {
	margin-left: auto;
	margin-right: auto;
}

.trust-topic-kicker {
	color: var(--color-primary);
	display: inline-flex;
	font-size: 0.82rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.05em;
	line-height: 1.2;
	margin-bottom: 14px;
	text-transform: uppercase;
}

.trust-topic-section--decision .trust-topic-section__header {
	display: block;
	margin-bottom: clamp(30px, 3.2vw, 46px);
	max-width: 860px;
	text-align: left;
}

.trust-topic-section--decision .trust-topic-section__header h2 {
	max-width: 760px;
}

.trust-topic-section--decision .trust-topic-section__header p {
	margin-top: 18px;
	max-width: 740px;
}

.trust-topic-decision-grid,
.trust-topic-safeguards-grid {
	display: grid;
	gap: clamp(16px, 1.7vw, 24px);
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.trust-topic-card,
.trust-topic-list-card,
.trust-topic-authorization-card,
.trust-topic-company-card {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(247, 251, 255, 0.98)),
		#fff;
	border: 1px solid rgba(192, 219, 239, 0.86);
	border-radius: 8px;
	box-shadow: 0 20px 48px rgba(16, 47, 79, 0.08);
}

.trust-topic-decision-card {
	min-height: 238px;
	padding: clamp(22px, 1.8vw, 28px);
}

.trust-topic-decision-card > i,
.trust-topic-decision-card > svg {
	background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);
	border-radius: 8px;
	box-shadow: 0 12px 24px rgba(23, 105, 170, 0.18);
	color: #fff;
	height: 42px;
	margin-bottom: 20px;
	padding: 10px;
	width: 42px;
}

.trust-topic-decision-card h3,
.trust-topic-authorization-card h3 {
	color: var(--color-ink-strong);
	font-size: clamp(1.08rem, 1.02rem + 0.22vw, 1.22rem);
	font-weight: var(--weight-display);
	line-height: 1.18;
	margin: 0 0 10px;
}

.trust-topic-decision-card p,
.trust-topic-authorization-card p,
.trust-topic-list-card p {
	color: var(--color-muted);
	line-height: 1.5;
	margin: 0;
}

.trust-topic-verification {
	align-items: start;
	display: grid;
	gap: clamp(28px, 4.5vw, 70px);
	grid-template-columns: minmax(0, 0.72fr) minmax(420px, 0.88fr);
}

.trust-topic-company-card {
	display: grid;
	gap: 0;
	margin: clamp(26px, 3vw, 42px) 0 0;
	overflow: hidden;
}

.trust-topic-company-card div {
	display: grid;
	gap: 6px;
	grid-template-columns: minmax(130px, 0.34fr) minmax(0, 1fr);
	padding: 18px 20px;
}

.trust-topic-company-card div + div {
	border-top: 1px solid rgba(216, 232, 245, 0.9);
}

.trust-topic-company-card dt {
	color: var(--color-muted);
	font-size: 0.84rem;
	font-weight: var(--weight-display);
	margin: 0;
	text-transform: uppercase;
}

.trust-topic-company-card dd {
	color: var(--color-ink-strong);
	font-weight: var(--weight-semibold);
	margin: 0;
	min-width: 0;
	word-break: break-word;
}

.trust-topic-company-card a {
	color: var(--color-primary-dark);
	text-decoration: none;
}

.trust-topic-authorization-list {
	display: grid;
	gap: 14px;
}

.trust-topic-authorization-card {
	display: grid;
	gap: 16px;
	grid-template-columns: 48px minmax(0, 1fr);
	padding: 20px;
}

.trust-topic-authorization-card > i,
.trust-topic-authorization-card > svg {
	background: rgba(23, 105, 170, 0.1);
	border-radius: 8px;
	color: var(--color-primary);
	height: 48px;
	padding: 12px;
	width: 48px;
}

.trust-topic-authorization-card a {
	margin-top: 12px;
}

.trust-topic-safeguards-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.trust-topic-list-card {
	display: flex;
	flex-direction: column;
	gap: 18px;
	min-height: 100%;
	padding: clamp(22px, 2vw, 30px);
}

.trust-topic-list-card > span {
	color: var(--color-primary);
	display: inline-flex;
	font-size: 0.8rem;
	font-weight: var(--weight-display);
	letter-spacing: 0.05em;
	line-height: 1.2;
	text-transform: uppercase;
}

.trust-topic-list-card .trust-topic-list {
	gap: 13px;
}

.trust-topic-list-card .trust-topic-list li {
	color: #34495c;
	display: grid;
	gap: 11px;
	grid-template-columns: 20px minmax(0, 1fr);
	line-height: 1.45;
}

.trust-topic-list-card .trust-topic-list svg {
	color: #1f9d72;
	height: 19px;
	margin-top: 1px;
	width: 19px;
}

.trust-topic-inline-link,
.trust-topic-card__actions {
	margin-top: auto;
}

.trust-topic-card__actions {
	gap: 12px 16px;
}

.trust-topic-card__actions a {
	text-decoration: none;
}

.trust-topic-final-cta {
	background: linear-gradient(180deg, #ffffff 0%, #eef6fb 100%);
}

.trust-topic-final-cta .homepage-final-cta__panel {
	background:
		linear-gradient(115deg, rgba(255, 255, 255, 0.64), rgba(255, 255, 255, 0) 48%),
		linear-gradient(135deg, #edf8ff 0%, #dceffc 52%, #cfe7f8 100%);
}

.trust-topic-final-cta .homepage-final-cta__copy {
	max-width: 560px;
}

@media (hover: hover) and (pointer: fine) {
	.trust-topic-decision-card,
	.trust-topic-authorization-card,
	.trust-topic-list-card {
		transition:
			border-color 0.2s ease,
			box-shadow 0.2s ease,
			transform 0.2s ease;
	}

	.trust-topic-decision-card:hover,
	.trust-topic-authorization-card:hover,
	.trust-topic-list-card:hover {
		border-color: rgba(141, 190, 226, 0.95);
		box-shadow: 0 28px 62px rgba(16, 47, 79, 0.12);
		transform: translateY(-4px);
	}
}

@media screen and (max-width: 1199px) {
	.trust-topic-proof__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.trust-topic-proof-card + .trust-topic-proof-card {
		border-left: 0;
	}

	.trust-topic-proof-card {
		border-top: 1px solid rgba(216, 232, 245, 0.92);
	}

	.trust-topic-proof-card:nth-child(-n + 3) {
		border-top: 0;
	}

	.trust-topic-decision-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 991px) {
	.trust-topic-hero__grid,
	.trust-topic-section__header,
	.trust-topic-verification,
	.trust-topic-safeguards-grid {
		grid-template-columns: 1fr;
	}

	.trust-topic-hero__panel {
		max-width: 620px;
	}

	.trust-topic-section__header,
	.trust-topic-section__header--center {
		text-align: left;
	}

	.trust-topic-section__header--center h2,
	.trust-topic-section__header--center p {
		margin-left: 0;
		margin-right: 0;
	}
}

@media screen and (max-width: 767px) {
	.trust-topic-hero {
		padding-bottom: 68px;
	}

	.trust-topic-proof {
		margin-top: -34px;
	}

	.trust-topic-proof__grid,
	.trust-topic-decision-grid {
		grid-template-columns: 1fr;
	}

	.trust-topic-proof-card,
	.trust-topic-proof-card:nth-child(-n + 3) {
		border-top: 1px solid rgba(216, 232, 245, 0.92);
		min-height: 0;
	}

	.trust-topic-proof-card:first-child {
		border-top: 0;
	}
}

@media screen and (max-width: 575px) {
	.trust-topic-hero__copy h1 {
		font-size: clamp(2.18rem, 14vw, 3.2rem);
	}

	.trust-topic-hero__actions,
	.trust-topic-hero__cta,
	.trust-topic-hero__secondary {
		width: 100%;
	}

	.trust-topic-hero__cta,
	.trust-topic-hero__secondary {
		justify-content: center;
	}

	.trust-topic-section {
		padding: 50px 0;
	}

	.trust-topic-company-card div {
		grid-template-columns: 1fr;
		padding: 16px;
	}

	.trust-topic-authorization-card {
		grid-template-columns: 42px minmax(0, 1fr);
		padding: 18px;
	}

	.trust-topic-authorization-card > i,
	.trust-topic-authorization-card > svg {
		height: 42px;
		padding: 10px;
		width: 42px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.trust-topic-decision-card,
	.trust-topic-authorization-card,
	.trust-topic-list-card {
		transition: none;
	}

	.trust-topic-decision-card:hover,
	.trust-topic-authorization-card:hover,
	.trust-topic-list-card:hover {
		transform: none;
	}
}

/* =======================================================================
   Appointment page clinical polish
   ======================================================================= */
.appointment-hero {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(246, 251, 255, 0.98) 100%),
		radial-gradient(circle at 78% 24%, rgba(47, 143, 211, 0.13) 0, rgba(47, 143, 211, 0) 36%);
	border-bottom-color: rgba(216, 232, 245, 0.86);
}

.appointment-hero .article-hero-grid {
	align-items: center;
	display: grid;
	gap: clamp(32px, 4.4vw, 72px);
	grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
	margin: 0;
	max-width: var(--site-container-max);
}

.appointment-hero .article-category-badge {
	background: var(--color-primary-soft);
	border: 1px solid rgba(23, 105, 170, 0.16);
	color: var(--color-primary-dark);
}

.appointment-hero .article-hero-summary {
	color: #4f6478;
	font-size: clamp(1.04rem, 0.98rem + 0.28vw, 1.16rem);
	line-height: 1.68;
}

.appointment-hero-image {
	align-items: center;
	display: flex;
	justify-content: flex-end;
	position: relative;
}

.appointment-hero-image::before {
	background: linear-gradient(135deg, rgba(234, 245, 255, 0.96), rgba(255, 255, 255, 0.88));
	border: 1px solid rgba(216, 232, 245, 0.9);
	border-radius: 22px;
	content: '';
	inset: 22px -12px -14px 42px;
	position: absolute;
}

.appointment-hero-image img {
	aspect-ratio: 4 / 3;
	background: #fff;
	border: 1px solid rgba(216, 232, 245, 0.92);
	border-radius: 18px;
	box-shadow: 0 24px 60px rgba(16, 47, 79, 0.1);
	height: auto;
	max-width: 100%;
	object-fit: cover;
	position: relative;
	width: min(100%, 560px);
	z-index: 1;
}

.appointment-hero-image img:hover {
	transform: none;
}

.appointment-hero .article-trust-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 22px;
	max-width: var(--public-content-max);
}

.appointment-hero .article-trust-meta span {
	align-items: center;
	background: #fff;
	border: 1px solid rgba(192, 219, 239, 0.9);
	border-radius: 999px;
	box-shadow: 0 10px 26px rgba(16, 47, 79, 0.05);
	color: #344d66;
	display: inline-flex;
	font-size: 0.92rem;
	font-weight: var(--weight-semibold);
	gap: 7px;
	line-height: 1.15;
	min-height: 36px;
	padding: 8px 13px 8px 9px;
	white-space: nowrap;
}

.appointment-hero .article-trust-meta i,
.appointment-hero .article-trust-meta svg {
	color: var(--color-primary);
	flex: 0 0 16px;
	height: 16px;
	margin-right: 0 !important;
	stroke-width: 2.35;
	width: 16px;
}

.thankyou-hero {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(246, 251, 255, 0.98) 100%),
		radial-gradient(circle at 78% 24%, rgba(47, 143, 211, 0.12) 0, rgba(47, 143, 211, 0) 36%);
	border-bottom-color: rgba(216, 232, 245, 0.86);
}

.thankyou-hero .article-hero-grid {
	align-items: center;
	display: grid;
	gap: clamp(32px, 4.4vw, 72px);
	grid-template-columns: minmax(0, 1.02fr) minmax(360px, 0.98fr);
	margin: 0;
	max-width: var(--site-container-max);
}

.thankyou-hero .article-category-badge {
	background: var(--color-primary-soft);
	border: 1px solid rgba(23, 105, 170, 0.16);
	color: var(--color-primary-dark);
}

.thankyou-hero .article-hero-summary {
	color: #4f6478;
	font-size: clamp(1.04rem, 0.98rem + 0.28vw, 1.16rem);
	line-height: 1.68;
}

.thankyou-hero-image {
	align-items: center;
	display: flex;
	justify-content: flex-end;
	position: relative;
}

.thankyou-hero-image::before {
	background: linear-gradient(135deg, rgba(234, 245, 255, 0.96), rgba(255, 255, 255, 0.88));
	border: 1px solid rgba(216, 232, 245, 0.9);
	border-radius: 22px;
	content: '';
	inset: 22px -12px -14px 42px;
	position: absolute;
}

.thankyou-hero-image img {
	aspect-ratio: 4 / 3;
	background: #fff;
	border: 1px solid rgba(216, 232, 245, 0.92);
	border-radius: 18px;
	box-shadow: 0 24px 60px rgba(16, 47, 79, 0.1);
	height: auto;
	max-width: 100%;
	object-fit: cover;
	object-position: 78% center;
	position: relative;
	width: min(100%, 560px);
	z-index: 1;
}

.thankyou-hero-image img:hover {
	transform: none;
}

.thankyou-hero .article-trust-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 22px;
	max-width: var(--public-content-max);
}

.thankyou-hero .article-trust-meta span {
	align-items: center;
	background: #fff;
	border: 1px solid rgba(192, 219, 239, 0.9);
	border-radius: 999px;
	box-shadow: 0 10px 26px rgba(16, 47, 79, 0.05);
	color: #344d66;
	display: inline-flex;
	font-size: 0.92rem;
	font-weight: var(--weight-semibold);
	line-height: 1.15;
	min-height: 36px;
	padding: 8px 13px;
	white-space: nowrap;
}

.appointment-plan-section {
	background:
		linear-gradient(180deg, #fbfdff 0%, #f4f9fd 52%, #ffffff 100%) !important;
	padding-top: clamp(46px, 5.4vw, 82px) !important;
	padding-bottom: clamp(54px, 6.4vw, 94px) !important;
}

.appointment-plan-section::before {
	display: none;
}

.appointment-plan-section > .container {
	max-width: var(--site-container-max);
}

.appointment-plan-section__grid {
	align-items: flex-start;
	row-gap: 28px;
}

.appointment-form-card,
.appointment-next-card {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 1) 100%),
		var(--color-surface-warm);
	border: 1px solid rgba(201, 224, 241, 0.92) !important;
	border-radius: 18px !important;
	box-shadow:
		0 22px 54px rgba(16, 47, 79, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.94) !important;
}

.appointment-form-card {
	overflow: hidden;
}

.appointment-form-card__body {
	padding: clamp(24px, 3.2vw, 44px) !important;
}

.appointment-form-card__header {
	border-bottom: 1px solid rgba(216, 232, 245, 0.9);
	margin-bottom: clamp(22px, 3vw, 34px);
	padding-bottom: clamp(20px, 2.6vw, 30px);
}

.appointment-form-card__eyebrow,
.appointment-next-card__eyebrow,
.appointment-form-card__subhead {
	color: var(--color-primary);
	font-size: 0.76rem;
	font-weight: var(--weight-emphasis);
	letter-spacing: 0.08em;
	line-height: 1.2;
	text-transform: uppercase;
}

.appointment-form-card__eyebrow,
.appointment-next-card__eyebrow {
	display: block;
	margin-bottom: 10px;
}

.appointment-form-title {
	color: var(--color-ink-strong);
	font-size: clamp(1.65rem, 1.28rem + 0.9vw, 2.2rem);
	font-weight: var(--weight-heading);
	letter-spacing: 0;
	line-height: 1.08;
	margin-bottom: 12px !important;
	max-width: 14em;
}

.appointment-form-card__lead {
	color: #51687d !important;
	font-size: 1rem;
	line-height: 1.6;
	max-width: 62rem;
}

.appointment-form-card__subhead {
	margin: 0 0 14px;
}

.appointment-form-card__subhead--spaced {
	margin-top: 24px;
}

.appointment-wizard__progress {
	background: #f7fbff;
	border: 1px solid rgba(203, 225, 241, 0.94);
	border-radius: 16px;
	display: grid;
	gap: 6px;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	margin-bottom: clamp(24px, 3.2vw, 36px);
	padding: 6px;
}

.appointment-wizard__progress-item {
	align-items: center;
	background: transparent;
	border: 0;
	border-radius: 11px;
	color: #60768a;
	cursor: default;
	display: inline-flex;
	gap: 0.45rem;
	justify-content: center;
	min-height: 44px;
	min-width: 0;
	overflow: hidden;
	padding: 0.42rem 0.55rem;
	position: relative;
	transform: none !important;
	transition:
		background-color 0.18s ease,
		box-shadow 0.18s ease,
		color 0.18s ease;
}

.appointment-wizard__progress-item.is-active {
	background: #fff;
	box-shadow: 0 10px 22px rgba(16, 47, 79, 0.08) !important;
	color: var(--color-ink-strong);
}

.appointment-wizard__progress-item.is-done {
	background: var(--color-primary-soft) !important;
	border-color: transparent !important;
	color: var(--color-primary-dark) !important;
}

.appointment-wizard__progress-num {
	align-items: center;
	background: #fff;
	border-radius: 50%;
	box-shadow: inset 0 0 0 1px rgba(190, 212, 229, 0.95);
	color: #617487;
	display: inline-flex;
	flex: 0 0 1.62rem;
	font-size: 0.86rem;
	height: 1.62rem;
	justify-content: center;
	line-height: 1;
	width: 1.62rem;
}

.appointment-wizard__progress-item.is-active .appointment-wizard__progress-num,
.appointment-wizard__progress-item.is-done .appointment-wizard__progress-num {
	background: var(--color-primary) !important;
	color: #fff !important;
}

.appointment-wizard__progress-item.is-done .appointment-wizard__progress-num {
	color: transparent !important;
	position: relative;
}

.appointment-wizard__progress-item.is-done .appointment-wizard__progress-num::after {
	color: #fff;
	content: '';
	height: 0.42rem;
	position: absolute;
	top: 46%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
	width: 0.72rem;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
}

.appointment-wizard__progress-label {
	font-size: 0.9rem;
	font-weight: var(--weight-semibold);
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.appointment-wizard__step legend {
	color: var(--color-ink-strong);
	font-size: clamp(1.18rem, 1.02rem + 0.35vw, 1.42rem);
	letter-spacing: 0;
	margin-bottom: 1.05rem;
}

.appointment-wizard .form-label {
	color: #24384f !important;
	font-size: 0.9rem;
	font-weight: var(--weight-semibold) !important;
	margin-bottom: 0.45rem;
}

.appointment-wizard .form-control {
	background: #fbfdff !important;
	border: 1px solid rgba(203, 221, 236, 0.96) !important;
	border-radius: 12px;
	color: var(--color-ink-strong);
	min-height: 52px;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		box-shadow 0.16s ease;
}

.appointment-wizard textarea.form-control {
	min-height: 136px;
}

.appointment-wizard .form-control:hover {
	border-color: rgba(141, 190, 226, 0.95) !important;
}

.appointment-wizard .form-control:focus {
	background: #fff !important;
	border-color: rgba(47, 143, 211, 0.42) !important;
	box-shadow: 0 0 0 3px rgba(47, 143, 211, 0.08) !important;
}

.appointment-select {
	position: relative;
}

.appointment-select__button,
.appointment-select__menu {
	display: none;
}

.appointment-select.is-enhanced .appointment-select__native {
	block-size: 1px !important;
	inline-size: 1px !important;
	inset-inline-start: 0;
	margin: 0 !important;
	opacity: 0;
	padding: 0 !important;
	pointer-events: none;
	position: absolute;
}

.appointment-select.is-enhanced .appointment-select__button {
	align-items: center;
	background: #fbfdff;
	border: 1px solid rgba(203, 221, 236, 0.96);
	border-radius: 12px;
	box-shadow: none;
	color: var(--color-ink-strong);
	cursor: pointer;
	display: flex;
	font-size: 0.96rem;
	font-weight: var(--weight-medium);
	gap: 0.8rem;
	justify-content: space-between;
	line-height: 1.2;
	min-height: 52px;
	padding: 0 0.95rem 0 1rem;
	text-align: left;
	transition:
		background-color 0.16s ease,
		border-color 0.16s ease,
		box-shadow 0.16s ease,
		color 0.16s ease;
	width: 100%;
}

[dir='rtl'] .appointment-select.is-enhanced .appointment-select__button {
	padding-left: 0.95rem;
	padding-right: 1rem;
	text-align: right;
}

.appointment-select__button span {
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.appointment-select__button i,
.appointment-select__button svg {
	flex: 0 0 18px;
	height: 18px;
	stroke-width: 2.35;
	transition: transform 0.18s ease;
	width: 18px;
}

.appointment-select.is-open .appointment-select__button i,
.appointment-select.is-open .appointment-select__button svg {
	transform: rotate(180deg);
}

.appointment-select.is-enhanced .appointment-select__button:hover {
	background: #fff;
	border-color: rgba(47, 143, 211, 0.36);
	box-shadow: 0 0 0 2px rgba(47, 143, 211, 0.04);
	outline: none;
}

.appointment-select.is-open .appointment-select__button {
	background: #fff;
	border-color: rgba(23, 105, 170, 0.46);
	box-shadow: 0 8px 18px rgba(16, 47, 79, 0.06);
	outline: none;
}

.appointment-select.is-enhanced .appointment-select__button:focus {
	outline: none;
}

.appointment-select.is-enhanced .appointment-select__button:focus-visible {
	background: #fff;
	border-color: rgba(47, 143, 211, 0.46);
	box-shadow: 0 0 0 3px rgba(47, 143, 211, 0.1);
	outline: none;
}

.appointment-select.is-invalid .appointment-select__button,
.appointment-select__native.is-invalid + .appointment-select__button,
.appointment-wizard.was-validated .appointment-select__native:invalid + .appointment-select__button {
	border-color: rgba(180, 35, 24, 0.62);
	box-shadow: 0 0 0 4px rgba(180, 35, 24, 0.12);
}

.appointment-select.is-open {
	z-index: 20;
}

.appointment-select.is-enhanced .appointment-select__menu {
	background: #fff;
	border: 1px solid rgba(203, 221, 236, 0.96);
	border-radius: 16px;
	box-shadow: 0 18px 42px rgba(16, 47, 79, 0.18);
	gap: 2px;
	inset-inline: 0;
	max-height: min(270px, calc(100vh - 320px));
	overflow-x: hidden;
	overflow-y: auto;
	padding: 6px;
	position: absolute;
	scrollbar-color: rgba(23, 105, 170, 0.36) transparent;
	scrollbar-gutter: stable;
	scrollbar-width: thin;
	top: calc(100% + 8px);
	z-index: 21;
}

.appointment-select.is-open .appointment-select__menu {
	display: grid;
}

.appointment-select__menu::-webkit-scrollbar {
	width: 7px;
}

.appointment-select__menu::-webkit-scrollbar-track {
	background: transparent;
	margin: 10px 0;
}

.appointment-select__menu::-webkit-scrollbar-thumb {
	background: rgba(23, 105, 170, 0.34);
	border: 2px solid #fff;
	border-radius: 999px;
	min-height: 34px;
}

.appointment-select__menu::-webkit-scrollbar-thumb:hover {
	background: rgba(23, 105, 170, 0.54);
}

.appointment-select__option {
	background: transparent;
	border: 0;
	border-radius: 12px;
	color: #24384f;
	cursor: pointer;
	display: block;
	font-size: 0.93rem;
	font-weight: var(--weight-medium);
	line-height: 1.25;
	min-height: 40px;
	padding: 0.7rem 0.8rem;
	text-align: left;
	transition:
		background-color 0.16s ease,
		box-shadow 0.16s ease,
		color 0.16s ease;
	width: 100%;
}

[dir='rtl'] .appointment-select__option {
	text-align: right;
}

.appointment-select__option:hover,
.appointment-select__option:focus,
.appointment-select__option[aria-selected='true'] {
	background: rgba(23, 105, 170, 0.1);
	color: var(--color-primary-dark);
	outline: none;
}

.appointment-select__option[aria-selected='true'] {
	box-shadow: inset 0 0 0 1px rgba(23, 105, 170, 0.08);
}

.appointment-wizard .iti {
	width: 100%;
}

.appointment-wizard .iti__selected-flag,
.appointment-wizard .iti__selected-country,
.appointment-wizard .iti__selected-country-primary {
	border-radius: 12px 0 0 12px;
}

[dir='rtl'] .appointment-wizard .iti__selected-flag,
[dir='rtl'] .appointment-wizard .iti__selected-country,
[dir='rtl'] .appointment-wizard .iti__selected-country-primary {
	border-radius: 0 12px 12px 0;
}

.appointment-wizard .iti__selected-country,
.appointment-wizard .iti__selected-country-primary {
	transition:
		background-color 0.16s ease,
		box-shadow 0.16s ease;
}

.appointment-wizard .iti__country-container:hover .iti__selected-country,
.appointment-wizard .iti__selected-country:hover,
.appointment-wizard .iti__selected-country:focus-visible {
	background: rgba(23, 105, 170, 0.025) !important;
	box-shadow: inset 0 0 0 1px rgba(23, 105, 170, 0.11) !important;
}

.appointment-wizard .iti--allow-dropdown .iti__country-container:not(:has(+ input[disabled])):not(:has(+ input[readonly])):hover .iti__selected-country-primary,
.appointment-wizard .iti--allow-dropdown .iti__country-container:not(:has(+ input[disabled])):not(:has(+ input[readonly])) .iti__selected-country-primary:hover,
.appointment-wizard .iti__selected-country:hover .iti__selected-country-primary,
.appointment-wizard .iti__selected-country:focus-visible .iti__selected-country-primary {
	background: transparent !important;
	box-shadow: none !important;
}

.appointment-wizard .form-control.is-invalid,
.appointment-wizard .form-control:invalid:focus {
	border-color: rgba(180, 35, 24, 0.62) !important;
}

.appointment-wizard .custom-control-label {
	color: #40566b;
	font-size: 0.96rem;
	line-height: 1.45;
}

.appointment-field-error {
	color: #b42318;
	display: block;
	font-size: 0.84rem;
	font-weight: var(--weight-medium);
	line-height: 1.45;
	margin-top: 0.5rem;
}

.appointment-field-error:empty {
	display: none;
}

.appointment-wizard .custom-control-input:focus-visible ~ .custom-control-label::before,
.appointment-wizard .custom-control-input:focus ~ .custom-control-label::before {
	box-shadow: 0 0 0 3px rgba(47, 143, 211, 0.1);
}

.appointment-short-form .mb-4 {
	margin-bottom: 1rem !important;
}

.appointment-short-form textarea.form-control {
	min-height: 112px;
	resize: none;
}

.appointment-short-form .custom-control-label {
	line-height: 1.45;
	margin-bottom: 0;
}

.appointment-short-form .custom-control-label::before,
.appointment-short-form .custom-control-label::after {
	top: 0.15rem;
	transform: none;
}

.appointment-short-form__consents {
	background: #f7fbff;
	border: 1px solid rgba(203, 221, 236, 0.86);
	border-radius: 14px;
	margin-top: 4px;
	padding: 16px 18px;
}

.appointment-short-form__consents.is-invalid {
	border-color: rgba(180, 35, 24, 0.35);
	box-shadow: 0 0 0 4px rgba(180, 35, 24, 0.08);
}

.appointment-short-form__consents .custom-control {
	margin-bottom: 0.85rem !important;
}

.appointment-short-form__consents .custom-control:last-of-type {
	margin-bottom: 0 !important;
}

.appointment-short-form__consents .custom-control-label {
	font-size: 0.9rem;
}

.appointment-wizard .custom-control-input.is-invalid:not(:checked) ~ .custom-control-label,
.appointment-wizard.was-validated .custom-control-input:invalid:not(:checked) ~ .custom-control-label {
	color: #7a2e25;
}

.appointment-wizard .custom-control-input.is-invalid:not(:checked) ~ .custom-control-label::before,
.appointment-wizard.was-validated .custom-control-input:invalid:not(:checked) ~ .custom-control-label::before {
	border-color: rgba(180, 35, 24, 0.62);
	box-shadow: 0 0 0 3px rgba(180, 35, 24, 0.12);
}

.appointment-short-form__consents .appointment-field-error {
	margin-bottom: 0;
}

.appointment-upload__drop {
	background: #f7fbff;
	border: 1px dashed rgba(23, 105, 170, 0.34);
	border-radius: 16px;
	color: var(--color-primary-dark);
	min-height: 142px;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease;
}

.appointment-upload__drop:hover {
	background: #eef7ff;
	border-color: rgba(23, 105, 170, 0.58);
	box-shadow: inset 0 0 0 1px rgba(23, 105, 170, 0.08);
}

.appointment-upload__file {
	background: #fbfdff;
	border-color: rgba(203, 221, 236, 0.92);
	border-radius: 12px;
}

.appointment-travel-grid {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(152px, 1fr));
	margin-bottom: 24px;
}

.appointment-travel-card {
	position: relative;
}

.appointment-travel-checkbox {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.appointment-travel-label {
	align-items: center;
	background: #fbfdff;
	border: 1px solid rgba(203, 221, 236, 0.96);
	border-radius: 14px;
	box-shadow: none;
	color: #40566b;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	font-size: 0.9rem;
	font-weight: var(--weight-semibold);
	gap: 10px;
	justify-content: center;
	line-height: 1.25;
	min-height: 108px;
	padding: 18px 14px;
	text-align: center;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		color 0.18s ease,
		box-shadow 0.18s ease;
}

.appointment-travel-label i,
.appointment-travel-label svg {
	color: #6a8197;
	height: 24px;
	stroke-width: 2;
	width: 24px;
}

.appointment-travel-label:hover {
	background: #f4f9fd;
	border-color: rgba(141, 190, 226, 0.95);
	box-shadow: none;
	transform: none;
}

.appointment-travel-checkbox:focus-visible + .appointment-travel-label {
	box-shadow: 0 0 0 0.2rem rgba(47, 143, 211, 0.18);
}

.appointment-travel-checkbox:checked + .appointment-travel-label {
	background: var(--color-primary-soft);
	border-color: rgba(23, 105, 170, 0.55) !important;
	box-shadow: inset 0 0 0 1px rgba(23, 105, 170, 0.08) !important;
	color: var(--color-primary-dark) !important;
}

.appointment-travel-checkbox:checked + .appointment-travel-label i,
.appointment-travel-checkbox:checked + .appointment-travel-label svg {
	color: var(--color-primary);
}

.appointment-wizard__nav {
	align-items: center;
	border-top: 1px solid rgba(216, 232, 245, 0.9);
	display: grid !important;
	gap: 12px;
	grid-template-columns: auto minmax(0, 1fr) auto;
	margin-top: clamp(24px, 3.2vw, 36px) !important;
	padding-top: 22px;
}

.appointment-wizard__secure-note {
	align-items: center;
	background: #f7fbff;
	border: 1px solid rgba(192, 219, 239, 0.92);
	border-radius: 999px;
	color: #4d6579;
	display: inline-flex;
	font-size: 0.88rem;
	justify-self: center;
	line-height: 1.2;
	padding: 0.55rem 0.85rem;
}

.appointment-secure-icon {
	color: var(--color-primary);
	flex: 0 0 14px;
	width: 14px;
}

.appointment-wizard__nav .btn {
	align-items: center;
	box-shadow: none !important;
	display: inline-flex;
	justify-content: center;
	min-height: 48px;
}

.appointment-wizard__nav .btn-primary,
.appointment-submit-button {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
}

.appointment-submit-button:hover,
.appointment-wizard__nav .btn-primary:hover,
.appointment-submit-button:focus,
.appointment-wizard__nav .btn-primary:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff;
	transform: none;
}

.appointment-wizard__nav .btn-light {
	background: #fff;
	border: 1px solid rgba(203, 221, 236, 0.96);
	color: var(--color-primary-dark);
}

.appointment-wizard__nav .btn-light:hover,
.appointment-wizard__nav .btn-light:focus {
	background: #f6fbff;
	border-color: rgba(141, 190, 226, 0.95);
	color: var(--color-primary-dark);
}

.appointment-short-form__nav {
	grid-template-columns: minmax(0, 1fr) auto !important;
}

.appointment-short-form__nav .appointment-wizard__secure-note {
	justify-self: start;
}

.appointment-short-form__nav .appointment-submit-button {
	justify-self: end;
}

.sticky-sidebar {
	position: sticky;
	top: calc(var(--navbar-height, 78px) + 28px);
	z-index: 2;
}

.appointment-next-card {
	overflow: hidden !important;
	padding: clamp(22px, 2.6vw, 30px);
}

.appointment-next-card__header {
	border-bottom: 1px solid rgba(216, 232, 245, 0.9);
	margin-bottom: 18px;
	padding-bottom: 18px;
}

.appointment-next-card h4 {
	color: var(--color-ink-strong) !important;
	font-size: clamp(1.28rem, 1.08rem + 0.45vw, 1.62rem);
	font-weight: var(--weight-heading);
	line-height: 1.14;
	max-width: none;
}

.appointment-next-card__timeline {
	display: grid;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
	position: relative;
}

.appointment-next-card__item {
	align-items: flex-start;
	background: #fbfdff !important;
	border: 1px solid rgba(216, 232, 245, 0.86) !important;
	border-radius: 14px;
	box-shadow: none !important;
	display: grid;
	gap: 12px;
	grid-template-columns: auto minmax(0, 1fr);
	margin: 0 !important;
	padding: 14px;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease;
}

.appointment-next-card__item:hover {
	background: #f6fbff !important;
	border-color: rgba(141, 190, 226, 0.95) !important;
	transform: none;
}

.appointment-next-card__item h5 {
	color: var(--color-ink-strong) !important;
	font-size: 1rem;
	font-weight: var(--weight-emphasis);
	line-height: 1.2;
}

.appointment-step-badge,
.thankyou-step-badge {
	align-items: center;
	background: var(--color-primary-soft) !important;
	border: 1px solid rgba(23, 105, 170, 0.18);
	border-radius: 50%;
	box-shadow: none;
	color: var(--color-primary-dark) !important;
	display: inline-flex;
	font-size: 0.86rem;
	font-weight: var(--weight-emphasis) !important;
	height: 34px;
	justify-content: center;
	padding: 0;
	width: 34px;
}

.appointment-next-card__copy {
	color: #52687c;
	font-size: 0.94rem;
	line-height: 1.45;
}

.appointment-sidebar-secure {
	align-items: flex-start;
	background: #f7fbff;
	border: 1px solid rgba(192, 219, 239, 0.92);
	border-radius: 16px;
	box-shadow: none !important;
	color: #40566b;
	display: flex;
	gap: 12px;
	margin-top: 16px;
	padding: 16px;
}

.appointment-sidebar-secure strong {
	color: var(--color-primary-dark);
	display: block;
	font-weight: var(--weight-emphasis);
	line-height: 1.25;
}

.appointment-sidebar-secure p {
	color: #52687c;
	line-height: 1.45;
}

.appointment-sidebar-secure i,
.appointment-sidebar-secure svg {
	color: var(--color-primary);
	flex: 0 0 18px;
	height: 18px;
	margin-top: 2px;
	width: 18px;
}

.appointment-final-cta {
	background: #ffffff;
	padding-top: clamp(44px, 5vw, 72px);
}

.appointment-final-cta .homepage-final-cta__panel {
	background:
		linear-gradient(135deg, rgba(246, 251, 255, 0.98) 0%, rgba(234, 245, 255, 0.96) 100%),
		#f6fbff;
	border-color: rgba(201, 224, 241, 0.92);
	box-shadow:
		0 18px 48px rgba(16, 47, 79, 0.07),
		inset 0 1px 0 rgba(255, 255, 255, 0.94);
	min-height: clamp(320px, 25vw, 420px);
}

.appointment-final-cta .homepage-final-cta__panel::before,
.appointment-final-cta .homepage-final-cta__panel::after {
	display: none;
}

.appointment-final-cta .homepage-final-cta__visual img {
	bottom: clamp(-86px, -6vw, -54px);
	filter: none;
}

@media screen and (max-width: 1199px) {
	.appointment-hero .article-hero-grid {
		grid-template-columns: minmax(0, 1fr) minmax(320px, 0.82fr);
	}

	.thankyou-hero .article-hero-grid {
		grid-template-columns: minmax(0, 1fr) minmax(320px, 0.82fr);
	}

	.appointment-wizard__progress {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media screen and (max-width: 991px) {
	.appointment-hero .article-hero-grid {
		grid-template-columns: 1fr;
	}

	.thankyou-hero .article-hero-grid {
		grid-template-columns: 1fr;
	}

	.appointment-hero-image {
		justify-content: flex-start;
	}

	.thankyou-hero-image {
		justify-content: flex-start;
	}

	.appointment-hero-image::before {
		inset: 20px 28px -12px 28px;
	}

	.thankyou-hero-image::before {
		inset: 20px 28px -12px 28px;
	}

	.sticky-sidebar {
		position: static;
	}

	.appointment-next-card {
		margin-top: 0;
	}
}

@media screen and (max-width: 767px) {
	.appointment-form-card__body {
		padding: 22px !important;
	}

	.appointment-wizard__progress {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		padding: 5px;
	}

	.appointment-wizard__progress-item {
		gap: 0.32rem;
		min-height: 42px;
		padding: 0.28rem;
	}

	.appointment-wizard__progress-label {
		font-size: 0.78rem;
	}

	.appointment-wizard__nav {
		grid-template-columns: 1fr;
	}

	.appointment-short-form__nav {
		grid-template-columns: 1fr !important;
	}

	.appointment-wizard__nav .btn,
	.appointment-submit-button {
		justify-content: center;
		width: 100%;
	}

	.appointment-wizard__secure-note {
		justify-content: center;
		justify-self: stretch;
		order: -1;
	}
}

@media screen and (max-width: 575px) {
	.appointment-plan-section {
		padding-top: 34px !important;
		padding-bottom: 54px !important;
	}

	.appointment-hero .article-trust-meta {
		display: grid;
		gap: 8px;
		margin-top: 16px;
	}

	.thankyou-hero .article-trust-meta {
		display: grid;
		gap: 8px;
		margin-top: 16px;
	}

	.appointment-hero .article-trust-meta span {
		border-radius: 12px;
		font-size: 0.91rem;
		justify-content: flex-start;
		min-height: 38px;
		padding: 9px 10px;
		white-space: normal;
		width: 100%;
	}

	.thankyou-hero .article-trust-meta span {
		border-radius: 12px;
		font-size: 0.91rem;
		justify-content: flex-start;
		min-height: 38px;
		padding: 9px 10px;
		white-space: normal;
		width: 100%;
	}

	.appointment-hero-image::before {
		inset: 16px 12px -10px 18px;
	}

	.thankyou-hero-image::before {
		inset: 16px 12px -10px 18px;
	}

	.appointment-form-title {
		font-size: 1.48rem;
	}

	.appointment-travel-grid {
		grid-template-columns: 1fr;
	}

	.appointment-next-card__item {
		padding: 12px;
	}
}

/* Homepage section titles: align weight and placement with the hero title. */
.main-homepage {
	--homepage-section-title-size: clamp(1.95rem, 1.58rem + 1.2vw, 2.5rem);
	--homepage-section-title-compact-size: clamp(1.42rem, 1.18rem + 0.75vw, 2rem);
	--homepage-section-title-leading: 1.2;
}

.main-homepage
	:is(
		.homepage-free-consult__content h2,
		.homepage-cost-comparison__header h2,
		.homepage-treatment-showcase h2,
		.homepage-about-snapshot h2,
		.homepage-process h2,
		.homepage-final-cta h2,
		.homepage-featured-articles .section-title-bordered,
		.bg-light-2 > .section-padding .section-title-bordered
	) {
	color: var(--color-ink-strong);
	font-size: var(--homepage-section-title-size);
	font-weight: var(--weight-semibold);
	letter-spacing: 0;
	line-height: var(--homepage-section-title-leading);
	margin-top: 0;
	text-align: left;
	text-transform: none;
}

.main-homepage
	:is(.homepage-ivf-feature-card--destinations h2, .homepage-ivf-destination-intro h2) {
	font-size: var(--homepage-section-title-compact-size);
	font-weight: var(--weight-semibold);
	letter-spacing: 0;
	line-height: var(--homepage-section-title-leading);
	text-align: left;
	text-transform: none;
}

.main-homepage .section-title-bordered {
	border-bottom: 0;
	margin-bottom: clamp(22px, 3vw, 36px);
	padding-bottom: 0;
}

.main-homepage
	:is(.homepage-cost-comparison__header, .homepage-treatment-showcase__header, .homepage-process__header) {
	text-align: left;
}

.main-homepage :is(.homepage-treatment-showcase__header, .homepage-process__header) {
	align-items: flex-start;
}

.main-homepage .homepage-hospitals__header {
	align-items: center;
}

@media screen and (max-width: 767px) {
	.main-homepage {
		--homepage-section-title-size: clamp(1.72rem, 1.45rem + 1.35vw, 1.95rem);
		--homepage-section-title-compact-size: clamp(1.32rem, 1.16rem + 0.8vw, 1.62rem);
		--homepage-section-title-leading: 1.24;
	}

	.main-homepage .section-title-bordered {
		margin-bottom: 20px;
	}
}

/* Public breadcrumb system: keep all public page breadcrumbs visually consistent. */
nav[aria-label='breadcrumb'],
nav[aria-label='Breadcrumb'] {
	--public-breadcrumb-link-color: var(--color-primary);
	--public-breadcrumb-current-color: var(--color-muted);
	--public-breadcrumb-separator-color: rgba(95, 113, 132, 0.58);
	display: block;
	margin: 0 0 clamp(18px, 2.2vw, 30px);
	max-width: 100%;
	overflow: hidden;
}

nav[aria-label='breadcrumb'] > ol,
nav[aria-label='Breadcrumb'] > ol {
	align-items: center;
	background: transparent;
	color: var(--public-breadcrumb-current-color);
	display: flex;
	flex-wrap: wrap;
	gap: 4px 0;
	list-style: none;
	margin: 0;
	max-width: 100%;
	min-width: 0;
	padding: 0;
}

nav[aria-label='breadcrumb'] > ol,
nav[aria-label='Breadcrumb'] > ol,
nav[aria-label='breadcrumb'] > ol > li,
nav[aria-label='Breadcrumb'] > ol > li,
nav[aria-label='breadcrumb'] > ol > li > a,
nav[aria-label='Breadcrumb'] > ol > li > a {
	font-size: 0.8125rem;
	letter-spacing: 0;
	line-height: 1.45;
}

nav[aria-label='breadcrumb'] > ol > li,
nav[aria-label='Breadcrumb'] > ol > li {
	align-items: center;
	color: var(--public-breadcrumb-current-color);
	display: inline-flex;
	font-weight: var(--weight-medium);
	min-width: 0;
}

nav[aria-label='breadcrumb'] > ol > li + li::before,
nav[aria-label='Breadcrumb'] > ol > li + li::before,
nav[aria-label='breadcrumb'] > ol.breadcrumb > li.breadcrumb-item:not(:first-child)::before,
nav[aria-label='Breadcrumb'] > ol.breadcrumb > li.breadcrumb-item:not(:first-child)::before {
	color: var(--public-breadcrumb-separator-color);
	content: '/';
	font-weight: var(--weight-medium);
	margin: 0 8px;
	opacity: 1;
	padding: 0;
}

nav[aria-label='breadcrumb'] > ol > li > a,
nav[aria-label='Breadcrumb'] > ol > li > a {
	color: var(--public-breadcrumb-link-color);
	font-weight: var(--weight-semibold);
	text-decoration: none;
	transition: color 160ms ease;
}

nav[aria-label='breadcrumb'] > ol > li > a:hover,
nav[aria-label='Breadcrumb'] > ol > li > a:hover,
nav[aria-label='breadcrumb'] > ol > li > a:focus,
nav[aria-label='Breadcrumb'] > ol > li > a:focus {
	color: var(--color-primary-dark);
	text-decoration: none;
}

nav[aria-label='breadcrumb'] > ol > li > a:focus-visible,
nav[aria-label='Breadcrumb'] > ol > li > a:focus-visible {
	border-radius: 4px;
	box-shadow: 0 0 0 3px rgba(23, 105, 170, 0.16);
	outline: 2px solid var(--color-primary);
	outline-offset: 3px;
}

nav[aria-label='breadcrumb'] > ol > li[aria-current='page'],
nav[aria-label='Breadcrumb'] > ol > li[aria-current='page'],
nav[aria-label='breadcrumb'] > ol > li.active,
nav[aria-label='Breadcrumb'] > ol > li.active {
	color: var(--public-breadcrumb-current-color);
	font-weight: var(--weight-medium);
}

nav[aria-label='breadcrumb'] > ol > li span,
nav[aria-label='Breadcrumb'] > ol > li span {
	min-width: 0;
}

@media screen and (max-width: 575px) {
	nav[aria-label='breadcrumb'],
	nav[aria-label='Breadcrumb'] {
		margin-bottom: 18px;
	}

	nav[aria-label='breadcrumb'] > ol,
	nav[aria-label='Breadcrumb'] > ol {
		flex-wrap: wrap;
		overflow: visible;
	}

	nav[aria-label='breadcrumb'] > ol > li,
	nav[aria-label='Breadcrumb'] > ol > li {
		flex: 0 1 auto;
		max-width: 100%;
		overflow: hidden;
	}

	nav[aria-label='breadcrumb'] > ol > li[aria-current='page'],
	nav[aria-label='Breadcrumb'] > ol > li[aria-current='page'],
	nav[aria-label='breadcrumb'] > ol > li.active,
	nav[aria-label='Breadcrumb'] > ol > li.active {
		flex: 1 1 auto;
		max-width: 100%;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}

	nav[aria-label='breadcrumb'] > ol > li > a,
	nav[aria-label='Breadcrumb'] > ol > li > a,
	nav[aria-label='breadcrumb'] > ol > li[aria-current='page'] > span,
	nav[aria-label='Breadcrumb'] > ol > li[aria-current='page'] > span,
	nav[aria-label='breadcrumb'] > ol > li.active > span,
	nav[aria-label='Breadcrumb'] > ol > li.active > span {
		display: block;
		max-width: 100%;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}
}

/* Public hero title normalization: keep inner-page hero H1s aligned with the homepage hero. */
:is(
	.main-homepage .main-slider-content h1,
	.section-with-bg .container h1,
	.bg-primary-gradient h1,
	.article-hero h1,
	.about-hero h1,
	.safety-hero h1,
	.how-it-works-hero h1,
	.listing-hero__intro h1,
	.support-topic-hero__copy h1,
	.trust-topic-hero__copy h1,
	.policy-topic-hero__copy h1,
	.hospital-detail-hero h1
) {
	font-size: var(--text-h1);
	font-weight: var(--weight-semibold);
	line-height: 1.1;
}

/* Public H2/H3 weight normalization: mirror the current H1 weight without changing heading scale or spacing. */
:is(
	.main-homepage,
	.section-padding,
	.article-hero,
	.article-body-wrapper,
	.content-box,
	.article-content,
	.about-page,
	.authorization-page,
	.safety-guide-page,
	.how-it-works-page,
	.support-topic-page,
	.trust-topic-page,
	.policy-topic-page,
	.listing-hero,
	.listing-section,
	.hospital-detail-hero,
	.hospital-detail-section,
	.homepage-final-cta,
	.homepage-inline-cta,
	.sh-consultation-prompt,
	.site-footer
) :is(h2, h3),
.main-homepage .hero__review-title,
.appointment-form-title {
	font-weight: var(--weight-semibold);
}

.static-page-shell--site-width .bg-primary-gradient > .container,
.static-page-shell--site-width .static-page-content > .container {
	max-width: var(--site-container-max);
	padding-left: var(--site-container-gutter);
	padding-right: var(--site-container-gutter);
}

.static-page-shell--site-width .static-page-content__body {
	max-width: none;
}

/* 404 page: homepage-aligned, shadowless recovery panel. */
.not-found-page:focus {
	outline: none;
}

.not-found-hero {
	background: linear-gradient(180deg, #f8fcff 0%, #eef6fb 100%);
	color: var(--color-body);
	overflow: hidden;
	padding: clamp(54px, 7vw, 96px) 0;
}

.not-found-hero__inner {
	margin: 0 auto;
	max-width: var(--site-container-max);
	padding: 0 var(--site-container-gutter);
	width: 100%;
}

.not-found-hero__panel {
	align-items: center;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.42) 0%, rgba(255, 255, 255, 0) 62%),
		linear-gradient(135deg, #edf8ff 0%, #dceffc 54%, #cfe7f8 100%);
	border: 1px solid rgba(189, 219, 242, 0.74);
	border-radius: clamp(18px, 1.6vw, 26px);
	box-shadow: none;
	column-gap: clamp(28px, 5vw, 72px);
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(300px, 0.72fr);
	min-height: clamp(420px, 35vw, 540px);
	overflow: hidden;
	padding: clamp(34px, 4.6vw, 66px);
	position: relative;
	row-gap: 30px;
	width: 100%;
}

.not-found-hero__panel::before {
	background: linear-gradient(90deg, rgba(23, 105, 170, 0.2), rgba(23, 105, 170, 0));
	content: '';
	height: 12px;
	inset-inline-end: clamp(108px, 13vw, 224px);
	pointer-events: none;
	position: absolute;
	top: clamp(48px, 6vw, 84px);
	transform: rotate(-4deg);
	width: clamp(150px, 18vw, 270px);
}

.not-found-hero__content,
.not-found-hero__visual {
	min-width: 0;
	position: relative;
	z-index: 1;
}

.not-found-hero__content {
	max-width: 650px;
}

.not-found-hero__kicker {
	align-items: center;
	background: rgba(255, 255, 255, 0.58);
	border: 1px solid rgba(23, 105, 170, 0.16);
	border-radius: 999px;
	color: var(--color-primary-dark);
	display: inline-flex;
	font-size: 0.84rem;
	font-weight: var(--weight-semibold);
	justify-content: center;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: 18px;
	min-height: 34px;
	padding: 0 16px;
}

.not-found-hero h1 {
	color: var(--color-ink-strong);
	font-size: var(--text-h1);
	font-weight: var(--weight-semibold);
	line-height: 1.08;
	margin-bottom: 18px;
	max-width: 11em;
}

.not-found-hero__copy {
	color: #415468;
	font-size: clamp(1.06rem, 1rem + 0.24vw, 1.2rem);
	line-height: 1.5;
	margin-bottom: 12px;
	max-width: 540px;
}

.not-found-hero__body {
	color: #5f7184;
	font-size: 1rem;
	line-height: 1.58;
	margin-bottom: clamp(24px, 2.8vw, 36px);
	max-width: 560px;
}

.not-found-hero__actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.not-found-hero__button {
	align-items: center;
	border-radius: 999px;
	box-shadow: none;
	display: inline-flex;
	font-size: 1rem;
	font-weight: var(--weight-semibold);
	justify-content: center;
	line-height: 1.2;
	min-height: 56px;
	padding: 0 28px;
	text-align: center;
	text-decoration: none !important;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		color 0.18s ease,
		transform 0.18s ease;
}

.not-found-hero__button--primary {
	background: var(--color-primary);
	border: 1px solid var(--color-primary);
	color: #fff !important;
}

.not-found-hero__button--secondary {
	background: rgba(255, 255, 255, 0.42);
	border: 1px solid rgba(23, 105, 170, 0.24);
	color: var(--color-primary-dark) !important;
}

.not-found-hero__button:hover,
.not-found-hero__button:focus {
	text-decoration: none;
	transform: translateY(-1px);
}

.not-found-hero__button--primary:hover,
.not-found-hero__button--primary:focus {
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff !important;
}

.not-found-hero__button--secondary:hover,
.not-found-hero__button--secondary:focus {
	background: rgba(255, 255, 255, 0.68);
	border-color: rgba(23, 105, 170, 0.34);
	color: var(--color-primary-dark) !important;
}

.not-found-hero__button:focus-visible {
	outline: 3px solid rgba(23, 105, 170, 0.26);
	outline-offset: 4px;
}

.not-found-hero__visual {
	align-items: center;
	aspect-ratio: 1.12;
	background: rgba(255, 255, 255, 0.36);
	border: 1px solid rgba(255, 255, 255, 0.52);
	border-radius: clamp(18px, 1.5vw, 24px);
	box-shadow: none;
	display: flex;
	justify-content: center;
	padding: clamp(18px, 2.8vw, 38px);
}

.not-found-hero__visual .image-404 {
	height: auto;
	max-width: min(100%, 430px);
	width: 100%;
}

@media screen and (max-width: 991px) {
	.not-found-hero__panel {
		grid-template-columns: 1fr;
		min-height: auto;
	}

	.not-found-hero__content {
		max-width: 720px;
	}

	.not-found-hero__visual {
		max-width: 560px;
	}
}

@media screen and (max-width: 575px) {
	.not-found-hero {
		padding: 44px 0;
	}

	.not-found-hero__panel {
		border-radius: 22px;
		padding: 30px 22px;
	}

	.not-found-hero h1 {
		font-size: clamp(2.1rem, 1.76rem + 1.7vw, 2.7rem);
	}

	.not-found-hero__actions {
		align-items: stretch;
		flex-direction: column;
	}

	.not-found-hero__button {
		min-height: 54px;
		width: 100%;
	}

	.not-found-hero__visual {
		aspect-ratio: 1.2;
	}
}

/* Public responsive hardening: keep all visitor-facing templates usable on narrow screens. */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html,
body {
	max-width: 100%;
	overflow-x: hidden;
	overflow-x: clip;
}

img,
svg,
video,
canvas,
iframe,
table {
	max-width: 100%;
}

img,
video,
canvas {
	height: auto;
}

.article-content,
.content-box,
.static-page-content__body,
.policy-topic-content,
.treatment-overview-content__body,
.hospital-detail-summary__copy,
.listing-card__description,
.listing-card__title,
.site-footer,
.navbar-collapse,
.article-breadcrumb,
.breadcrumb {
	overflow-wrap: anywhere;
	word-break: normal;
}

.article-content table,
.content-box table,
.static-page-content__body table,
.policy-topic-content table,
.treatment-overview-content__body table {
	display: block;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	width: max-content;
}

.article-content iframe,
.content-box iframe,
.static-page-content__body iframe,
.policy-topic-content iframe {
	aspect-ratio: 16 / 9;
	display: block;
	height: auto;
	width: 100%;
}

.btn,
button,
input,
select,
textarea,
.navbar-toggler,
.topstrip__language a,
.listing-hero__quick-links a,
.listing-card,
.subbranch-card {
	min-width: 0;
}

.btn,
button,
[role='button'],
.navbar-toggler,
.listing-hero__quick-links a,
.listing-card,
.subbranch-card,
.site-footer__cta,
.homepage-final-cta__button,
.article-hero-btn,
.appointment-wizard__nav .btn,
.appointment-submit-button {
	touch-action: manipulation;
}

@media screen and (max-width: 991.98px) {
	:root {
		--site-container-gutter: clamp(16px, 4.4vw, 28px);
	}

	body.sh-cookie-banner-visible {
		padding-bottom: var(--cookie-banner-space-mobile);
	}

	.topstrip {
		margin-bottom: var(--navbar-height);
	}

	nav.navbar {
		min-height: var(--navbar-height);
		left: 0;
		position: fixed;
		right: 0;
		width: 100%;
	}

	nav.navbar > .container {
		min-width: 0;
	}

	nav.navbar .logo-wrapper {
		min-width: 0;
		padding-left: 0;
		padding-right: 8px;
	}

	nav.navbar .logo {
		max-width: min(190px, calc(100vw - 118px));
	}

	.navbar-toggler {
		align-items: center;
		background: #fff;
		border: 1px solid rgba(23, 105, 170, 0.28);
		border-radius: 10px;
		color: var(--color-primary-dark);
		display: inline-flex;
		flex: 0 0 auto;
		height: 44px;
		justify-content: center;
		padding: 0;
		width: 44px;
	}

	.navbar-collapse {
		-webkit-overflow-scrolling: touch;
		left: 0;
		max-height: calc(100dvh - var(--navbar-offset-top) - var(--navbar-height) - 10px);
		overscroll-behavior: contain;
		overflow-x: hidden;
		right: 0;
		top: var(--navbar-height);
	}

	.navbar-collapse.show,
	.navbar-collapse.collapsing {
		display: block;
	}

	.navbar-expand-lg .navbar-collapse .navbar-nav .nav-link,
	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-link {
		white-space: normal;
	}

	.navbar-expand-lg .navbar-collapse .nav-mega__link-label,
	.navbar-expand-lg .navbar-collapse .nav-label-full,
	.navbar-expand-lg .navbar-collapse .nav-label-short {
		min-width: 0;
		overflow-wrap: anywhere;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu {
		max-width: 100%;
		overflow-x: hidden;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-mega__list {
		grid-template-columns: minmax(0, 1fr);
		width: 100%;
	}

	.navbar-expand-lg .navbar-collapse > .navbar-nav > .nav-item,
	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-item {
		min-width: 0;
		width: 100%;
	}

	.navbar-expand-lg .navbar-collapse > .navbar-nav {
		gap: 6px;
		padding: 8px 0 2px;
	}

	.navbar-expand-lg .navbar-collapse .sh-btn--whatsapp {
		align-items: center;
		display: flex;
		gap: 0.55rem;
		justify-content: center;
		line-height: 1.2;
		min-height: 48px;
		padding: 0.78rem 1rem;
		text-align: center;
		width: 100%;
	}

	.navbar-expand-lg .navbar-collapse .sh-btn--whatsapp svg {
		flex: 0 0 auto;
	}

	.navbar-expand-lg .navbar-collapse > .navbar-nav > .nav-item > .nav-link {
		border: 1px solid transparent;
		border-radius: 12px;
		padding: 0.78rem 0.8rem;
	}

	.navbar-expand-lg .navbar-collapse > .navbar-nav > .nav-item.nav-item--mobile-split {
		position: relative;
	}

	.navbar-expand-lg .navbar-collapse > .navbar-nav > .nav-item.nav-item--mobile-split > .nav-link {
		padding-right: 3.25rem;
	}

	.navbar-expand-lg .navbar-collapse > .navbar-nav > .nav-item.nav-item--mobile-split > .nav-link svg {
		display: none;
	}

	.navbar-expand-lg .navbar-collapse > .navbar-nav > .nav-item.nav-item--mobile-split > .nav-mobile-disclosure {
		align-items: center;
		background: transparent;
		border: 0;
		border-radius: 10px;
		color: var(--color-primary-dark);
		display: inline-flex;
		height: 42px;
		justify-content: center;
		padding: 0;
		position: absolute;
		right: 0.24rem;
		top: 0.45rem;
		width: 42px;
		z-index: 2;
	}

	.navbar-expand-lg .navbar-collapse > .navbar-nav > .nav-item.nav-item--mobile-split > .nav-mobile-disclosure svg {
		height: 22px;
		transition: transform 0.18s ease;
		width: 18px;
	}

	.navbar-expand-lg .navbar-collapse > .navbar-nav > .nav-item.nav-item--mobile-split > .nav-mobile-disclosure[aria-expanded='true'] svg {
		transform: rotate(180deg);
	}

	.navbar-expand-lg .navbar-collapse .dropdown.show > .nav-link {
		background: #eef7ff;
		border-color: #d6e8f7;
		box-shadow:
			inset 0 1px 0 rgba(255, 255, 255, 0.78),
			0 6px 14px rgba(16, 47, 79, 0.07);
		color: var(--color-primary-dark);
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu {
		background: #f7fbff !important;
		border: 1px solid #dbeaf6;
		border-radius: 14px;
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.74);
		margin: 6px 0 10px;
		padding: 8px;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu.nav-mega {
		padding: 8px;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav,
	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-mega__list {
		gap: 4px;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-link {
		border: 0 !important;
		border-radius: 10px;
		min-height: 42px;
		padding: 0.68rem 0.78rem;
		transition:
			background-color 0.16s ease,
			color 0.16s ease,
			transform 0.16s ease;
	}

	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-link:hover,
	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-link:focus,
	.navbar-expand-lg .navbar-collapse .dropdown-menu .nav-link[aria-current='page'] {
		background: #fff;
		color: var(--color-primary) !important;
		transform: translateX(2px);
	}

	.article-hero-grid,
	.appointment-hero .article-hero-grid,
	.thankyou-hero .article-hero-grid,
	.support-topic-hero__grid,
	.trust-topic-hero__grid,
	.policy-topic-hero__grid,
	.listing-hero__grid,
	.listing-hero--care .listing-hero__grid--media,
	.listing-shell,
	.condition-page-shell .listing-shell,
	.hospital-detail-hero__grid,
	.hospital-detail-overview-grid,
	.hospital-detail-map-panel,
	.homepage-final-cta__panel {
		grid-template-columns: minmax(0, 1fr);
	}

	.listing-feature-card,
	.condition-page-shell .listing-feature-card,
	.sticky-sidebar,
	.sticky-cta-box {
		position: static;
		top: auto;
	}

	.main-homepage .main-slider-content .row,
	.homepage-free-consult__grid,
	.homepage-cost__grid,
	.homepage-final-cta__panel,
	.treatment-overview-section .row,
	.hospital-detail-map-panel {
		min-width: 0;
	}

	.hero__media,
	.hero__review-panel,
	.homepage-free-consult__media,
	.listing-hero__media,
	.article-hero-image,
	.appointment-hero-image,
	.thankyou-hero-image,
	.hospital-detail-hero__gallery,
	.homepage-final-cta__visual {
		max-width: 100%;
	}
}

@media screen and (max-width: 767px) {
	:root {
		--navbar-height: 68px;
	}

	.blog-post-hero.article-hero::before,
	.listing-hero--care::before {
		content: none;
	}

	.container,
	nav.navbar > .container,
	.topstrip__inner,
	.site-footer__inner,
	.homepage-final-cta__inner,
	.not-found-hero__inner,
	.article-hero .container,
	.article-body-wrapper .container,
	.bg-primary-gradient > .container,
	.bg-primary-gradient + .section-padding > .container,
	.static-page-shell--site-width .bg-primary-gradient > .container,
	.static-page-shell--site-width .static-page-content > .container {
		padding-left: var(--site-container-gutter);
		padding-right: var(--site-container-gutter);
	}

	.topstrip__inner {
		min-width: 0;
	}

	.topstrip__trust {
		max-width: none;
	}

	.topstrip__actions {
		min-width: 0;
	}

	.main-homepage .main-slider-content {
		padding: 0;
	}

	.main-homepage .main-slider-content .container {
		padding-bottom: 38px;
		padding-top: 38px;
	}

	.main-homepage .main-slider-content .row {
		margin-left: 0;
		margin-right: 0;
	}

	.main-homepage .main-slider-content .row > [class*='col-'] {
		padding-left: 0;
		padding-right: 0;
	}

	.main-homepage .hero__media,
	.main-homepage .hero__review-panel--form {
		width: 100%;
	}

	.main-homepage .hero__review-panel--form {
		box-sizing: border-box;
		margin-left: 0;
		margin-right: 0;
		max-width: 100%;
		transform: none;
		width: 100%;
	}

	.main-homepage .main-slider-content h1,
	.section-with-bg .container h1,
	.bg-primary-gradient h1,
	.article-hero h1,
	.about-hero h1,
	.safety-hero h1,
	.how-it-works-hero h1,
	.listing-hero__intro h1,
	.support-topic-hero__copy h1,
	.trust-topic-hero__copy h1,
	.policy-topic-hero__copy h1,
	.hospital-detail-hero h1 {
		font-size: clamp(2rem, 1.48rem + 7vw, 2.85rem);
		line-height: 1.08;
		max-width: 100%;
		text-wrap: balance;
	}

	.main-homepage .main-slider-content p,
	.hero__lead,
	.article-hero-summary,
	.listing-hero__lead,
	.support-topic-hero__copy p,
	.trust-topic-hero__copy p,
	.policy-topic-hero__copy p {
		font-size: clamp(1rem, 0.96rem + 0.7vw, 1.12rem);
		line-height: 1.55;
	}

	.hero__actions,
	.article-hero-actions,
	.trust-topic-hero__actions,
	.not-found-hero__actions,
	.homepage-hospitals__actions,
	.hospital-detail-actions {
		align-items: stretch;
		display: flex;
		flex-direction: column;
		width: 100%;
	}

	.hero__actions .btn,
	.article-hero-btn,
	.trust-topic-hero__cta,
	.trust-topic-hero__secondary,
	.homepage-final-cta__button,
	.homepage-free-consult__button,
	.not-found-hero__button,
	.hospital-detail-actions .btn,
	.site-footer__cta {
		justify-content: center;
		margin-left: 0 !important;
		margin-right: 0 !important;
		max-width: 100%;
		min-height: 52px;
		white-space: normal;
		width: 100%;
	}

	.hero__actions .hero-secondary-button {
		align-self: stretch;
		max-width: 100%;
		min-height: 46px;
		padding-left: 1.25rem !important;
		padding-right: 1.25rem !important;
		width: 100%;
	}

	.hero__review-panel,
	.blog-lead-form,
	.appointment-form-card,
	.appointment-next-card,
	.listing-feature-card,
	.condition-page-shell .listing-feature-card,
	.hospital-detail-summary,
	.hospital-detail-info-panel,
	.hospital-detail-profile-card,
	.hospital-detail-map-panel,
	.policy-topic-hero__panel,
	.trust-topic-hero__panel,
	.not-found-hero__panel {
		border-radius: 18px !important;
	}

	.hero__form-grid,
	.appointment-travel-grid,
	.support-topic-include__grid,
	.hospital-detail-profile-card__facts,
	.hospital-detail-profile-card__sections,
	.hospital-detail-profile-list__items,
	.hospital-detail-known__grid,
	.site-footer__link-group ul {
		grid-template-columns: minmax(0, 1fr);
	}

	.hero__review-meta,
	.article-trust-meta,
	.appointment-hero .article-trust-meta,
	.thankyou-hero .article-trust-meta,
	.listing-hero__support,
	.site-footer__bottom {
		align-items: stretch;
		display: grid;
		grid-template-columns: minmax(0, 1fr);
	}

	.hero__review-meta--form {
		display: none;
	}

	.article-trust-meta span,
	.appointment-hero .article-trust-meta span,
	.thankyou-hero .article-trust-meta span,
	.listing-hero__support li {
		border-radius: 12px;
		justify-content: flex-start;
		white-space: normal;
		width: 100%;
	}

	.listing-hero__search,
	.listing-hero--care .listing-hero__search {
		max-width: none;
		width: 100%;
	}

	.listing-hero__search .search-form--listing,
	.listing-hero--care .listing-hero__search .search-form--listing,
	.listing-search-band .listing-hero__search .search-form {
		border-radius: 16px;
		grid-template-columns: minmax(0, 1fr);
		padding: 10px;
	}

	.listing-hero__search .search-form--listing svg {
		top: 20px;
	}

	.listing-hero__search .search-form--listing input {
		min-height: 44px;
		padding-right: 14px;
		width: 100%;
	}

	.listing-hero__search .search-submit,
	.listing-hero--care .listing-hero__search .search-submit {
		min-height: 44px;
		width: 100%;
	}

	.listing-card-list,
	.condition-page-shell .listing-card-list,
	.listing-card-list--articles,
	.listing-card-list--directory,
	.listing-card-list--hospital-directory,
	.condition-page-shell .listing-card-list--care {
		grid-template-columns: minmax(0, 1fr);
		max-width: none;
		width: 100%;
	}

	.listing-card,
	.listing-card-list--hospital-directory .listing-card {
		grid-template-columns: minmax(0, 1fr);
		min-height: 0;
	}

	.listing-card__media,
	.listing-card-list--hospital-directory .listing-card__media {
		aspect-ratio: 16 / 10;
		min-height: 0;
	}

	.listing-card__meta,
	.listing-card-list--hospital-directory .listing-card__meta {
		display: grid;
		grid-template-columns: minmax(0, 1fr);
	}

	.listing-card__meta span,
	.listing-card-list--hospital-directory .listing-card__meta span {
		border-radius: 12px;
		white-space: normal;
		width: 100%;
	}

	.listing-card-list--hospital-directory .listing-card {
		background: #fff;
		border: 1px solid rgba(16, 47, 79, 0.08);
		box-shadow: 0 16px 34px rgba(16, 47, 79, 0.1);
		display: grid;
		grid-template-columns: minmax(0, 1fr);
		justify-content: stretch;
		min-height: 0;
		padding: 0;
	}

	.listing-card-list--hospital-directory .listing-card::before,
	.listing-card-list--hospital-directory .listing-card__media::after {
		content: none;
	}

	.listing-card-list--hospital-directory .listing-card__media {
		aspect-ratio: 16 / 9;
		border: 0;
		border-radius: 18px 18px 0 0;
		inset: auto;
		min-height: 0;
		position: relative;
		z-index: auto;
	}

	.listing-card-list--hospital-directory .listing-card__media img {
		height: 100%;
		min-height: 0;
		object-fit: cover;
		width: 100%;
	}

	.listing-card-list--hospital-directory .listing-card__body {
		align-items: stretch;
		background: #fff;
		color: var(--color-body);
		display: flex;
		flex-direction: column;
		gap: 0;
		padding: 18px;
		position: relative;
		z-index: auto;
	}

	.listing-card-list--hospital-directory .listing-card__title {
		color: var(--color-primary-dark);
		font-size: 1.2rem;
		line-height: 1.18;
		text-shadow: none;
	}

	.listing-card-list--hospital-directory .listing-card__meta {
		color: #597184;
		display: grid;
		gap: 10px;
		grid-template-columns: minmax(0, 1fr);
		margin-top: 14px;
	}

	.listing-card-list--hospital-directory .listing-card__meta span {
		align-items: flex-start;
		background: rgba(237, 246, 251, 0.92);
		border: 1px solid rgba(95, 137, 168, 0.16);
		border-radius: 12px;
		color: inherit;
		display: flex;
		font-size: 0.84rem;
		line-height: 1.42;
		overflow: visible;
		overflow-wrap: anywhere;
		padding: 9px 10px;
		text-overflow: clip;
		white-space: normal;
		width: 100%;
	}

	.listing-card-list--hospital-directory .listing-card__meta i,
	.listing-card-list--hospital-directory .listing-card__meta svg {
		color: var(--color-primary);
		flex: 0 0 16px;
		height: 16px;
		margin-top: 2px;
		width: 16px;
	}

	.listing-card-list--hospital-directory .listing-card__cta {
		align-self: stretch;
		background: var(--color-primary);
		border-color: var(--color-primary);
		border-radius: 12px;
		box-shadow: 0 10px 20px rgba(23, 105, 170, 0.16);
		color: #fff;
		font-size: 0.78rem;
		gap: 8px;
		height: auto;
		justify-self: stretch;
		margin-top: 16px;
		min-height: 44px;
		padding: 12px 14px;
		width: 100%;
	}

	.listing-card-list--hospital-directory .listing-card__cta i,
	.listing-card-list--hospital-directory .listing-card__cta svg {
		color: currentColor;
		flex: 0 0 16px;
		height: 16px;
		width: 16px;
	}

	.pagination-wrapper .pagination {
		justify-content: flex-start;
	}

	.homepage-final-cta__content,
	.not-found-hero__content {
		max-width: 100%;
	}

	.homepage-final-cta__visual {
		min-height: 240px;
		overflow: hidden;
	}

	.homepage-final-cta__visual img {
		height: 295px;
		max-width: min(84vw, 320px);
		object-fit: contain;
	}

	.appointment-wizard__progress {
		gap: 5px;
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.appointment-wizard__progress-label {
		white-space: normal;
	}

	.appointment-select.is-enhanced .appointment-select__menu,
	.iti--container .iti__dropdown-content {
		max-height: min(320px, calc(100dvh - 180px));
		max-width: calc(100vw - 24px);
	}

	.hospital-detail-hero__meta span,
	.hospital-detail-profile-list__item,
	.hospital-detail-department-list span {
		overflow-wrap: anywhere;
	}

	.hospital-map {
		min-height: 220px;
	}
}

@media screen and (max-width: 575px) {
	:root {
		--site-container-gutter: clamp(14px, 4.8vw, 20px);
		--topstrip-height: 38px;
		--cookie-banner-space-mobile: 9.5rem;
	}

	body {
		font-size: 0.98rem;
	}

	.topstrip {
		height: 38px;
	}

	.topstrip__language a {
		min-width: 25px;
		padding-left: 0.24rem;
		padding-right: 0.24rem;
	}

	.navbar-collapse {
		left: 0;
		right: 0;
		border-radius: 0 0 14px 14px;
		padding: 0 12px 12px;
	}

	.main-homepage .main-slider {
		min-height: 0;
	}

	.hero__review-panel,
	.appointment-form-card__body,
	.appointment-next-card,
	.listing-feature-card,
	.condition-page-shell .listing-feature-card,
	.hospital-detail-summary,
	.hospital-detail-info-panel,
	.hospital-detail-profile-card,
	.policy-topic-hero__panel,
	.trust-topic-hero__panel {
		padding: 20px !important;
	}

	.hero__form-field label,
	.appointment-wizard .form-label,
	.appointment-short-form__consents .custom-control-label {
		font-size: 0.88rem;
	}

	.hero__form-submit,
	.appointment-wizard .form-control,
	.appointment-select.is-enhanced .appointment-select__button {
		min-height: 50px;
	}

	.article-breadcrumb ol,
	.breadcrumb {
		display: flex;
		flex-wrap: nowrap;
		gap: 8px;
		overflow-x: auto;
		padding-bottom: 4px;
		-webkit-overflow-scrolling: touch;
	}

	.article-breadcrumb li,
	.breadcrumb-item {
		flex: 0 0 auto;
		max-width: 78vw;
	}

	nav[aria-label='breadcrumb'] > ol.breadcrumb,
	nav[aria-label='Breadcrumb'] > ol.breadcrumb {
		gap: 0;
	}

	nav[aria-label='breadcrumb'] > ol.breadcrumb > li,
	nav[aria-label='Breadcrumb'] > ol.breadcrumb > li,
	nav[aria-label='breadcrumb'] > ol.breadcrumb > li[aria-current='page'],
	nav[aria-label='Breadcrumb'] > ol.breadcrumb > li[aria-current='page'],
	nav[aria-label='breadcrumb'] > ol.breadcrumb > li.active,
	nav[aria-label='Breadcrumb'] > ol.breadcrumb > li.active {
		flex: 0 0 auto;
		max-width: 78vw;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}

	.article-content,
	.content-box,
	.static-page-content__body,
	.policy-topic-content {
		font-size: 1rem;
		line-height: 1.68;
	}

	.article-content h2,
	.content-box h2,
	.static-page-content__body h2,
	.policy-topic-content h2 {
		font-size: clamp(1.42rem, 1.2rem + 4vw, 1.9rem);
		line-height: 1.18;
	}

	.article-content h3,
	.content-box h3,
	.static-page-content__body h3,
	.policy-topic-content h3 {
		font-size: clamp(1.18rem, 1.05rem + 3vw, 1.48rem);
		line-height: 1.22;
	}

	.article-content ul,
	.article-content ol,
	.content-box ul,
	.content-box ol,
	.static-page-content__body ul,
	.static-page-content__body ol,
	.policy-topic-content ul,
	.policy-topic-content ol {
		padding-left: 1.15rem;
	}

	[dir='rtl'] .article-content ul,
	[dir='rtl'] .article-content ol,
	[dir='rtl'] .content-box ul,
	[dir='rtl'] .content-box ol,
	[dir='rtl'] .static-page-content__body ul,
	[dir='rtl'] .static-page-content__body ol,
	[dir='rtl'] .policy-topic-content ul,
	[dir='rtl'] .policy-topic-content ol {
		padding-left: 0;
		padding-right: 1.15rem;
	}

	.listing-hero--care .listing-hero__intro h1 {
		font-size: clamp(2.05rem, 1.55rem + 8vw, 2.75rem);
	}

	.listing-card,
	.listing-card-list--hospital-directory .listing-card {
		border-radius: 18px;
		padding: 16px;
	}

	.listing-card-list--hospital-directory .listing-card {
		padding: 0;
	}

	.listing-card-list--hospital-directory .listing-card__body {
		padding: 16px;
	}

	.listing-card--article,
	.listing-card-list--articles .listing-card--article {
		padding: 0;
	}

	.listing-card__title,
	.listing-card-list--hospital-directory .listing-card__title {
		font-size: 1.08rem;
		line-height: 1.22;
	}

	.condition-page-shell .listing-card--care .listing-card__description,
	.listing-card-list--articles .listing-card--article .listing-card__description {
		-webkit-line-clamp: 3;
		line-height: 1.52;
		padding-bottom: 2px;
	}

	.treatment-overview-section .view-all-button {
		width: 100%;
	}

	.subbranch-card {
		border-radius: 12px;
	}

	.appointment-wizard__progress {
		grid-template-columns: minmax(0, 1fr);
	}

	.appointment-wizard__progress-item {
		justify-content: flex-start;
		min-height: 40px;
		padding-left: 10px;
		padding-right: 10px;
	}

	.appointment-wizard__nav {
		gap: 10px;
	}

	.appointment-wizard__secure-note {
		border-radius: 14px;
		white-space: normal;
	}

	.hospital-detail-hero__gallery.hospital-photos {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hospital-detail-hero__gallery .gallery-item:first-child {
		grid-column: span 2;
	}

	.hospital-detail-hero__gallery--count-2 .gallery-item:not(:first-child) {
		grid-column: span 2;
	}

	.hospital-detail-hero__gallery .gallery-item a,
	.hospital-detail-hero__gallery .gallery-item-more a {
		aspect-ratio: 1.55;
		max-height: none;
	}

	.hospital-detail-hero__gallery .gallery-item:first-child a {
		aspect-ratio: 1.92;
		max-height: clamp(170px, 49vw, 220px);
	}

	.hospital-detail-hero__gallery--count-1.hospital-photos {
		grid-template-columns: minmax(0, 1fr);
	}

	.hospital-detail-hero__gallery--count-1 .gallery-item:first-child {
		grid-column: auto;
	}

	.hospital-detail-hero__gallery--count-1 .gallery-item:first-child a {
		aspect-ratio: 1.78;
		max-height: clamp(190px, 56vw, 250px);
	}

	.hospital-detail-hero__gallery--count-2 .gallery-item:not(:first-child) a {
		aspect-ratio: 2.45;
		max-height: clamp(112px, 31vw, 150px);
	}

	.hospital-detail-photo-grid.hospital-photos-list,
	.site-footer__credentials {
		grid-template-columns: minmax(0, 1fr);
	}

	.site-footer__partner-strip {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.site-footer__credential-card {
		grid-template-columns: 68px minmax(0, 1fr);
	}

	.not-found-hero__panel {
		padding: 26px 18px;
	}
}

@media screen and (max-width: 360px) {
	:root {
		--site-container-gutter: 14px;
	}

	nav.navbar .logo {
		max-width: 168px;
	}

	.topstrip__language a {
		font-size: 0.66rem;
		min-width: 23px;
	}

	.main-homepage .main-slider-content h1,
	.section-with-bg .container h1,
	.bg-primary-gradient h1,
	.article-hero h1,
	.listing-hero__intro h1,
	.hospital-detail-hero h1 {
		font-size: 1.95rem;
	}

	.hero__review-panel,
	.appointment-form-card__body,
	.appointment-next-card,
	.listing-feature-card,
	.condition-page-shell .listing-feature-card,
	.hospital-detail-summary,
	.hospital-detail-info-panel,
	.hospital-detail-profile-card {
		padding: 18px !important;
	}

	.homepage-final-cta__panel,
	.not-found-hero__panel {
		padding-left: 18px;
		padding-right: 18px;
	}
}

@media screen and (max-width: 991.98px) {
	.authorization-page .bg-primary-gradient .row,
	.safety-check-grid,
	.safety-red-flag-grid,
	.safety-quote-grid,
	.safety-step-grid,
	.safety-support-panel,
	.how-it-works-hero__grid,
	.how-it-works-section-heading--split,
	.how-it-works-journey__grid,
	.how-it-works-documents__grid,
	.support-topic-hero__grid,
	.support-topic-grid,
	.support-topic-checklist,
	.support-topic-details,
	.support-topic-faq,
	.trust-topic-hero__grid,
	.trust-topic-proof__grid,
	.trust-topic-decision-grid,
	.trust-topic-verification,
	.trust-topic-safeguards-grid,
	.policy-topic-hero__grid,
	.article-similar-topics__grid,
	.homepage-cost-comparison__layout,
	.homepage-about-snapshot__grid,
	.credential-grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.authorization-page .bg-primary-gradient .row,
	.safety-support-panel,
	.how-it-works-hero__grid,
	.how-it-works-section-heading--split,
	.support-topic-hero__grid,
	.trust-topic-hero__grid,
	.trust-topic-verification,
	.policy-topic-hero__grid,
	.homepage-cost-comparison__layout,
	.homepage-about-snapshot__grid {
		min-width: 0;
	}

	.sidebar-cta-card,
	.article-similar-topic,
	.credential-card,
	.support-topic-card,
	.support-topic-include,
	.support-topic-faq,
	.trust-topic-card,
	.trust-topic-proof-card,
	.trust-topic-decision-card,
	.trust-topic-list-card,
	.trust-topic-authorization-card,
	.trust-topic-company-card,
	.policy-topic-content,
	.how-it-works-step,
	.how-it-works-document-card,
	.safety-card,
	.safety-red-flag,
	.safety-step,
	.safety-support-band {
		min-width: 0;
	}

	.safety-hero-image-wrap,
	.safety-section-image-wrap,
	.how-it-works-hero__visual,
	.support-topic-hero__media,
	.trust-topic-hero__panel-media,
	.homepage-about-snapshot__media,
	.authorization-hero-image-wrap {
		max-width: 100%;
	}
}

@media screen and (max-width: 767px) {
	.authorization-page .btn,
	.safety-actions,
	.how-it-works-button,
	.support-topic-hero__cta,
	.trust-topic-hero__actions,
	.trust-topic-card__actions,
	.trust-topic-authorization-card a,
	.article-final-cta__actions,
	.homepage-cost-comparison__filters,
	.homepage-cost-comparison__chips {
		width: 100%;
	}

	.safety-actions,
	.trust-topic-card__actions,
	.article-final-cta__actions,
	.homepage-cost-comparison__filters {
		align-items: stretch;
		display: flex;
		flex-direction: column;
	}

	.authorization-page .btn,
	.safety-actions .btn,
	.how-it-works-button,
	.support-topic-hero__cta,
	.trust-topic-hero__cta,
	.trust-topic-hero__secondary,
	.trust-topic-card__actions a,
	.trust-topic-authorization-card a,
	.article-final-cta__btn,
	.article-final-cta__secondary {
		justify-content: center;
		max-width: 100%;
		min-height: 48px;
		white-space: normal;
	}

	.safety-trust-list,
	.safety-support-band ul,
	.how-it-works-hero__trust,
	.how-it-works-final__list,
	.support-topic-hero__trust,
	.support-topic-checklist ul,
	.trust-topic-hero__trust,
	.trust-topic-list,
	.trust-topic-checklist ul,
	.homepage-social-proof__partners,
	.homepage-cost-comparison__chips {
		min-width: 0;
	}

	.safety-trust-list,
	.how-it-works-hero__trust,
	.support-topic-hero__trust,
	.trust-topic-hero__trust {
		align-items: stretch;
		display: grid;
		grid-template-columns: minmax(0, 1fr);
	}

	.safety-trust-list li,
	.how-it-works-hero__trust span,
	.support-topic-hero__trust span,
	.trust-topic-hero__trust span,
	.trust-topic-company-card div {
		overflow-wrap: anywhere;
		white-space: normal;
		width: 100%;
	}

	.homepage-cost-comparison__chips {
		align-items: center;
		display: grid;
		gap: 10px;
		grid-template-columns: repeat(2, minmax(0, max-content));
		justify-content: start;
	}

	.homepage-cost-comparison__chip {
		max-width: 100%;
		white-space: nowrap;
		width: auto;
	}

	.homepage-cost-comparison__select-menu {
		max-height: min(320px, calc(100dvh - 190px));
		max-width: calc(100vw - 24px);
	}

	.homepage-social-proof__marquee {
		overflow: hidden;
		width: 100%;
	}

	.homepage-social-proof__track {
		min-width: max-content;
	}

	.homepage-ivf-destination-track {
		gap: 14px;
		margin-left: 0;
		margin-right: 0;
		padding-left: 4px;
		padding-right: 4px;
	}

	.homepage-ivf-destination-card {
		aspect-ratio: auto;
		background: transparent;
		box-shadow: none;
		flex: 0 0 min(62vw, 205px);
		min-height: 245px;
	}

	.homepage-ivf-destination-card:hover,
	.homepage-ivf-destination-card:focus {
		box-shadow: none;
	}

	.homepage-ivf-destination-card__content {
		gap: 6px;
		padding: 14px;
	}

	.homepage-ivf-destination-card__name {
		display: -webkit-box;
		font-size: 0.96rem;
		line-height: 1.16;
		overflow: hidden;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 3;
	}

	.homepage-ivf-destination-card__copy {
		font-size: 0.72rem;
		line-height: 1.35;
	}

	.sidebar-cta-card__title,
	.article-similar-topic__body h3,
	.support-topic-card h2,
	.support-topic-include h2,
	.support-topic-faq h2,
	.trust-topic-card h2,
	.policy-topic-content h2,
	.policy-topic-content h3,
	.how-it-works-step h3,
	.how-it-works-document-card h3,
	.safety-card h3,
	.safety-red-flag h3,
	.safety-step h3,
	.credential-card__title {
		overflow-wrap: anywhere;
	}
}

@media screen and (max-width: 575px) {
	.listing-hero__search .search-form--listing,
	.listing-hero--care .listing-hero__search .search-form--listing,
	.listing-search-band .listing-hero__search .search-form {
		align-items: stretch;
		display: grid;
		grid-template-columns: minmax(0, 1fr);
		min-height: 0;
		row-gap: 8px;
	}

	.listing-hero__search .search-form--listing svg,
	.listing-search-band .listing-hero__search .search-form svg {
		left: 18px;
		top: 32px;
		transform: translateY(-50%);
	}

	[dir='rtl'] .listing-hero__search .search-form--listing svg,
	[dir='rtl'] .listing-search-band .listing-hero__search .search-form svg {
		left: auto;
		right: 18px;
	}

	.listing-hero__search .search-form--listing input,
	.listing-search-band .listing-hero__search .search-form input {
		background: #fff;
		border-radius: 12px;
		box-sizing: border-box;
		min-height: 44px;
		padding-left: 48px;
		padding-right: 14px;
		width: 100%;
	}

	[dir='rtl'] .listing-hero__search .search-form--listing input,
	[dir='rtl'] .listing-search-band .listing-hero__search .search-form input {
		padding-left: 14px;
		padding-right: 48px;
	}

	.listing-hero__search .search-submit,
	.listing-hero--care .listing-hero__search .search-submit,
	.listing-search-band .listing-hero__search .search-submit {
		border-radius: 12px;
		min-height: 44px;
		padding-left: 16px;
		padding-right: 16px;
		white-space: normal;
		width: 100%;
	}

	.authorization-page .bg-primary-gradient,
	.safety-hero,
	.safety-section,
	.safety-final-cta,
	.how-it-works-hero,
	.how-it-works-journey,
	.how-it-works-documents,
	.how-it-works-final,
	.support-topic-hero,
	.support-topic-section,
	.support-topic-final,
	.trust-topic-hero,
	.trust-topic-proof,
	.trust-topic-section,
	.trust-topic-final,
	.policy-topic-hero,
	.policy-topic-section,
	.policy-topic-final,
	.article-similar-topics {
		padding-left: 0;
		padding-right: 0;
	}

	.authorization-page .credential-verify,
	.credential-card,
	.safety-card,
	.safety-red-flag,
	.safety-step,
	.safety-support-panel,
	.safety-support-band,
	.how-it-works-step,
	.how-it-works-document-card,
	.how-it-works-final__panel,
	.support-topic-card,
	.support-topic-include,
	.support-topic-faq,
	.support-topic-final__panel,
	.trust-topic-card,
	.trust-topic-proof-card,
	.trust-topic-decision-card,
	.trust-topic-list-card,
	.trust-topic-authorization-card,
	.trust-topic-company-card,
	.trust-topic-hero__panel,
	.policy-topic-hero__panel,
	.policy-topic-content,
	.policy-topic-final__panel,
	.sidebar-cta-card,
	.article-similar-topic__link {
		border-radius: 16px;
		padding: 20px;
	}

	.how-it-works-step__top,
	.homepage-cost-comparison__chart-head {
		align-items: stretch;
		flex-direction: column;
	}

	.how-it-works-step__top {
		gap: 12px;
		margin-bottom: 16px;
	}

	.how-it-works-step__number {
		height: 40px;
		width: 40px;
	}

	.how-it-works-step__timing {
		align-items: flex-start;
		border-radius: 14px;
		box-sizing: border-box;
		max-width: 100%;
		overflow-wrap: anywhere;
		padding: 10px 12px;
		white-space: normal;
		width: 100%;
	}

	.how-it-works-step__timing svg {
		margin-top: 1px;
	}

	.how-it-works-step__details summary {
		align-items: flex-start;
		line-height: 1.35;
		overflow-wrap: anywhere;
	}

	.how-it-works-step__details summary::after {
		flex: 0 0 auto;
	}

	.homepage-cost-comparison__row {
		grid-template-columns: minmax(0, 1fr);
		row-gap: 8px;
	}

	.homepage-cost-comparison__country,
	.homepage-cost-comparison__value {
		max-width: 100%;
		min-width: 0;
	}

}

@media screen and (max-width: 360px) {
	.homepage-ivf-destination-card {
		flex-basis: min(64vw, 196px);
		min-height: 235px;
	}

	.homepage-ivf-destination-card__content {
		padding: 12px;
	}

	.homepage-ivf-destination-card__name {
		font-size: 0.92rem;
	}

	.homepage-ivf-destination-card__copy {
		font-size: 0.68rem;
		-webkit-line-clamp: 2;
	}
}

/* Mobile typography and spacing normalization: compact public-site rhythm. */
@media screen and (max-width: 767px) {
	:root {
		--mobile-section-y: 42px;
		--mobile-section-y-tight: 34px;
		--mobile-panel-padding: 18px;
		--mobile-card-padding: 16px;
		--mobile-card-padding-tight: 14px;
		--mobile-h1: 2.12rem;
		--mobile-h2: 1.55rem;
		--mobile-h3: 1.24rem;
		--mobile-h4: 1.08rem;
		--mobile-lead: 1.03rem;
		--mobile-body: 0.98rem;
		--mobile-small: 0.84rem;
	}

	body {
		font-size: var(--mobile-body);
		line-height: 1.58;
	}

	.section-padding,
	.article-body-wrapper.section-padding,
	.article-similar-topics.section-padding,
	.container-fluid.section-padding,
	.listing-section.section-padding,
	.treatment-overview-section.section-padding,
	.hospital-detail-section.section-padding {
		padding-bottom: var(--mobile-section-y) !important;
		padding-top: var(--mobile-section-y) !important;
	}

	.main-homepage .main-slider-content .container,
	.bg-primary-gradient,
	.article-hero,
	.appointment-hero,
	.thankyou-hero,
	.listing-hero,
	.hospital-detail-hero,
	.authorization-page .bg-primary-gradient,
	.safety-hero,
	.how-it-works-hero,
	.support-topic-hero,
	.trust-topic-hero,
	.policy-topic-hero,
	.not-found-hero {
		padding-bottom: var(--mobile-section-y) !important;
		padding-top: var(--mobile-section-y) !important;
	}

	.homepage-free-consult,
	.homepage-cost-comparison,
	.homepage-treatment-showcase,
	.homepage-ivf-showcase,
	.homepage-about-snapshot,
	.homepage-final-cta,
	.safety-section,
	.safety-final-cta,
	.how-it-works-journey,
	.how-it-works-documents,
	.how-it-works-final,
	.support-topic-section,
	.support-topic-final,
	.trust-topic-proof,
	.trust-topic-section,
	.trust-topic-final,
	.policy-topic-section,
	.policy-topic-final {
		padding-bottom: var(--mobile-section-y) !important;
		padding-top: var(--mobile-section-y) !important;
	}

	.main-homepage .main-slider-content h1,
	.section-with-bg .container h1,
	.bg-primary-gradient h1,
	.article-hero h1,
	.about-hero h1,
	.safety-hero h1,
	.how-it-works-hero h1,
	.listing-hero__intro h1,
	.support-topic-hero__copy h1,
	.trust-topic-hero__copy h1,
	.policy-topic-hero__copy h1,
	.hospital-detail-hero h1,
	.not-found-hero h1 {
		font-size: var(--mobile-h1);
		font-weight: var(--weight-semibold);
		letter-spacing: 0;
		line-height: 1.1;
		margin-bottom: 14px;
		text-wrap: balance;
	}

	.main-homepage h2,
	.section-title-bordered,
	.homepage-free-consult h2,
	.homepage-cost-comparison__header h2,
	.homepage-treatment-showcase__header h2,
	.homepage-ivf-feature-card h2,
	.homepage-ivf-destination-intro h2,
	.homepage-about-snapshot h2,
	.homepage-process__header h2,
	.homepage-final-cta h2,
	.article-content h2,
	.content-box h2,
	.static-page-content__body h2,
	.policy-topic-content h2,
	.treatment-overview-content__body h2,
	.hospital-detail-section h2,
	.appointment-form-title,
	.support-topic-card h2,
	.support-topic-include h2,
	.support-topic-faq h2,
	.trust-topic-card h2,
	.how-it-works-section-heading h2,
	.how-it-works-step h3,
	.safety-card h3,
	.safety-step h3,
	.safety-red-flag h3 {
		font-size: var(--mobile-h2);
		font-weight: var(--weight-semibold);
		letter-spacing: 0;
		line-height: 1.18;
		margin-bottom: 14px;
		text-wrap: balance;
	}

	.main-homepage h3,
	.article-content h3,
	.content-box h3,
	.static-page-content__body h3,
	.policy-topic-content h3,
	.treatment-overview-content__body h3,
	.listing-card__title,
	.homepage-hospital-card__title,
	.homepage-featured-articles__title,
	.homepage-article-index__title,
	.appointment-next-card h4,
	.hospital-detail-profile-list h3,
	.site-footer__link-group h3,
	.site-footer__trust-panel h3,
	.site-footer__credential-title {
		font-size: var(--mobile-h3);
		font-weight: var(--weight-semibold);
		letter-spacing: 0;
		line-height: 1.22;
	}

	.hospital-detail-profile-card h2 {
		font-size: var(--mobile-h2);
		font-weight: var(--weight-semibold);
		letter-spacing: 0;
		line-height: 1.18;
		margin-bottom: 14px;
		text-wrap: balance;
	}

	.hospital-detail-profile-card h3,
	.hospital-detail-known h3,
	.hospital-detail-profile-list h3 {
		font-size: var(--mobile-h3);
		font-weight: var(--weight-semibold);
		letter-spacing: 0;
		line-height: 1.22;
	}

	.hospital-detail-profile-fact span {
		font-size: var(--mobile-small);
		font-weight: var(--weight-semibold);
		letter-spacing: 0;
		line-height: 1.25;
	}

	.hospital-detail-profile-fact strong {
		font-size: var(--mobile-body);
		font-weight: var(--weight-medium);
		line-height: 1.4;
	}

	.hospital-detail-known-card span {
		font-size: 1rem;
		font-weight: var(--weight-semibold);
		line-height: 1.2;
	}

	.hospital-detail-profile-list__item {
		font-size: var(--mobile-body);
		font-weight: var(--weight-medium);
		line-height: 1.42;
	}

	.hero__lead,
	.main-homepage .main-slider-content p,
	.article-hero-summary,
	.listing-hero__lead,
	.support-topic-hero__copy p,
	.trust-topic-hero__copy p,
	.policy-topic-hero__copy p,
	.not-found-hero__copy,
	.homepage-free-consult__lead,
	.homepage-final-cta__copy {
		font-size: var(--mobile-lead);
		line-height: 1.52;
	}

	.article-content,
	.content-box,
	.static-page-content__body,
	.policy-topic-content,
	.treatment-overview-content__body,
	.hospital-detail-summary__copy,
	.listing-card__description,
	.homepage-hospital-card__description,
	.homepage-featured-articles__description,
	.homepage-article-index__description,
	.appointment-form-card__lead,
	.appointment-next-card__copy,
	.site-footer__description,
	.site-footer__office-address,
	.site-footer__newsletter-copy {
		font-size: var(--mobile-body);
		line-height: 1.58;
	}

	.hero__review-kicker,
	.article-category-badge,
	.listing-hero__eyebrow,
	.hospital-detail-hero__kicker,
	.hospital-detail-section__kicker,
	.homepage-process__kicker,
	.homepage-hospitals__kicker,
	.homepage-about-snapshot__label,
	.appointment-form-card__eyebrow,
	.appointment-next-card__eyebrow,
	.how-it-works-eyebrow,
	.not-found-hero__kicker,
	.site-footer__eyebrow,
	.homepage-featured-articles__eyebrow,
	.homepage-article-index__eyebrow {
		font-size: var(--mobile-small);
		font-weight: var(--weight-heading);
		letter-spacing: 0;
		line-height: 1.2;
	}

	.hero__review-panel,
	.blog-lead-form,
	.homepage-free-consult__panel,
	.homepage-cost-comparison__chart,
	.homepage-cost-comparison__filters,
	.homepage-about-snapshot__content,
	.homepage-final-cta__panel,
	.appointment-form-card__body,
	.appointment-next-card,
	.listing-feature-card,
	.condition-page-shell .listing-feature-card,
	.hospital-detail-summary,
	.hospital-detail-info-panel,
	.hospital-detail-profile-card,
	.hospital-detail-map-panel,
	.authorization-page .credential-verify,
	.credential-card,
	.safety-card,
	.safety-red-flag,
	.safety-step,
	.safety-support-panel,
	.safety-support-band,
	.how-it-works-step,
	.how-it-works-document-card,
	.how-it-works-final__panel,
	.support-topic-card,
	.support-topic-include,
	.support-topic-faq,
	.support-topic-final__panel,
	.trust-topic-card,
	.trust-topic-proof-card,
	.trust-topic-decision-card,
	.trust-topic-list-card,
	.trust-topic-authorization-card,
	.trust-topic-company-card,
	.trust-topic-hero__panel,
	.policy-topic-hero__panel,
	.policy-topic-content,
	.policy-topic-final__panel,
	.sidebar-cta-card,
	.article-similar-topic__link,
	.not-found-hero__panel {
		padding: var(--mobile-panel-padding) !important;
	}

	.listing-card,
	.listing-card-list--hospital-directory .listing-card__body,
	.homepage-hospital-card__body,
	.homepage-featured-articles__body,
	.homepage-article-index__body,
	.site-footer__trust-panel,
	.site-footer__newsletter-panel,
	.site-footer__proof,
	.site-footer__credential-card {
		padding: var(--mobile-card-padding) !important;
	}

	.listing-card--article,
	.listing-card-list--articles .listing-card--article,
	.listing-card-list--hospital-directory .listing-card {
		padding: 0 !important;
	}

	.hero__actions .btn,
	.article-hero-btn,
	.homepage-free-consult__button,
	.homepage-final-cta__button,
	.appointment-submit-button,
	.appointment-wizard__nav .btn,
	.hospital-detail-actions .btn,
	.site-footer__cta,
	.not-found-hero__button {
		font-size: 0.96rem;
		font-weight: var(--weight-semibold);
		line-height: 1.2;
		min-height: 48px;
		padding-bottom: 0.78rem !important;
		padding-top: 0.78rem !important;
	}

	.hero__review-form .form-control,
	.blog-lead-form .form-control,
	.appointment-wizard .form-control,
	.appointment-select.is-enhanced .appointment-select__button,
	.homepage-cost-comparison__select {
		font-size: 0.96rem;
		min-height: 48px;
		padding-bottom: 0.72rem;
		padding-top: 0.72rem;
	}

	.homepage-cost-comparison__field-label,
	.hero__form-field label,
	.appointment-wizard .form-label,
	.appointment-short-form__consents .custom-control-label,
	.listing-card__meta span,
	.homepage-cost-comparison__legend,
	.homepage-cost-comparison__note,
	.hospital-detail-hero__meta span,
	.hospital-detail-department-list span,
	.site-footer__credential-meta {
		font-size: var(--mobile-small);
		font-weight: var(--weight-medium);
		line-height: 1.35;
	}
}

@media screen and (max-width: 575px) {
	:root {
		--mobile-section-y: 34px;
		--mobile-section-y-tight: 28px;
		--mobile-panel-padding: 16px;
		--mobile-card-padding: 14px;
		--mobile-card-padding-tight: 12px;
		--mobile-h1: 1.92rem;
		--mobile-h2: 1.38rem;
		--mobile-h3: 1.12rem;
		--mobile-h4: 1.02rem;
		--mobile-lead: 1rem;
		--mobile-body: 0.96rem;
		--mobile-small: 0.82rem;
	}

	.main-homepage .main-slider-content .container,
	.bg-primary-gradient,
	.article-hero,
	.appointment-hero,
	.thankyou-hero,
	.listing-hero,
	.hospital-detail-hero,
	.authorization-page .bg-primary-gradient,
	.safety-hero,
	.how-it-works-hero,
	.support-topic-hero,
	.trust-topic-hero,
	.policy-topic-hero,
	.not-found-hero {
		padding-bottom: var(--mobile-section-y) !important;
		padding-top: var(--mobile-section-y) !important;
	}

	.section-padding,
	.article-body-wrapper.section-padding,
	.article-similar-topics.section-padding,
	.container-fluid.section-padding,
	.listing-section.section-padding,
	.treatment-overview-section.section-padding,
	.hospital-detail-section.section-padding,
	.homepage-free-consult,
	.homepage-cost-comparison,
	.homepage-treatment-showcase,
	.homepage-ivf-showcase,
	.homepage-about-snapshot,
	.homepage-final-cta,
	.safety-section,
	.safety-final-cta,
	.how-it-works-journey,
	.how-it-works-documents,
	.how-it-works-final,
	.support-topic-section,
	.support-topic-final,
	.trust-topic-proof,
	.trust-topic-section,
	.trust-topic-final,
	.policy-topic-section,
	.policy-topic-final {
		padding-bottom: var(--mobile-section-y) !important;
		padding-top: var(--mobile-section-y) !important;
	}

	.article-content,
	.content-box,
	.static-page-content__body,
	.policy-topic-content,
	.treatment-overview-content__body {
		line-height: 1.62;
	}

	.article-content p,
	.content-box p,
	.static-page-content__body p,
	.policy-topic-content p,
	.treatment-overview-content__body p {
		margin-bottom: 0.95rem;
	}

	.article-content ul,
	.article-content ol,
	.content-box ul,
	.content-box ol,
	.static-page-content__body ul,
	.static-page-content__body ol,
	.policy-topic-content ul,
	.policy-topic-content ol {
		margin-bottom: 1rem;
		padding-inline-start: 1.1rem;
	}

	[dir='rtl'] .article-content ul,
	[dir='rtl'] .article-content ol,
	[dir='rtl'] .content-box ul,
	[dir='rtl'] .content-box ol,
	[dir='rtl'] .static-page-content__body ul,
	[dir='rtl'] .static-page-content__body ol,
	[dir='rtl'] .policy-topic-content ul,
	[dir='rtl'] .policy-topic-content ol {
		padding-inline-end: 1.1rem;
		padding-inline-start: 0;
	}

	.homepage-cost-comparison__chips {
		grid-template-columns: minmax(0, 1fr);
	}

	.homepage-cost-comparison__chip,
	.homepage-cost-comparison__field,
	.homepage-cost-comparison__select,
	.listing-hero__quick-links a,
	.article-trust-meta span,
	.listing-hero__support li,
	.hospital-detail-hero__meta span {
		width: 100%;
	}

	.homepage-ivf-destination-card {
		flex-basis: min(60vw, 190px);
		min-height: 224px;
	}

	.homepage-ivf-destination-card__content {
		padding: var(--mobile-card-padding-tight);
	}

	.hospital-detail-known-card span {
		font-size: 0.96rem;
	}

	.hospital-detail-profile-list__item {
		font-size: 0.94rem;
	}

	.site-footer__inner {
		padding-bottom: 22px;
		padding-top: 34px;
	}
}

@media screen and (max-width: 360px) {
	:root {
		--mobile-h1: 1.82rem;
		--mobile-h2: 1.28rem;
		--mobile-h3: 1.06rem;
		--mobile-panel-padding: 14px;
		--mobile-card-padding: 12px;
	}

	.main-homepage .main-slider-content h1,
	.section-with-bg .container h1,
	.bg-primary-gradient h1,
	.article-hero h1,
	.about-hero h1,
	.safety-hero h1,
	.how-it-works-hero h1,
	.listing-hero__intro h1,
	.support-topic-hero__copy h1,
	.trust-topic-hero__copy h1,
	.policy-topic-hero__copy h1,
	.hospital-detail-hero h1,
	.not-found-hero h1 {
		font-size: var(--mobile-h1);
	}
}
