:root {
	--color-primary: #DDA678;
	--color-primary-dark: #C4915F;
	--color-primary-light: #E8C4A8;
	--color-primary-subtle: rgba(221, 166, 120, 0.08);
	--color-black: #1A1A1A;
	--color-text: #2D2D2D;
	--color-text-secondary: #6B6B6B;
	--color-text-tertiary: #999999;
	--color-border: #E5E5E5;
	--color-border-light: #F0F0F0;
	--color-surface: #FAFAFA;
	--color-white: #FFFFFF;
	--font-serif: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
	--font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--font-theme: 'Marcellus', serif;
	--space-xs: 0.5rem;
	--space-sm: 0.75rem;
	--space-md: 1rem;
	--space-lg: 1.5rem;
	--space-xl: 2rem;
	--space-2xl: 3rem;
	--space-3xl: 4rem;
	--space-4xl: 6rem;
	--content-width: 720px;
	--content-width-wide: 960px;
	--content-width-full: 1120px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
	font-size: 16px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	scroll-behavior: smooth;
}

header,
footer {
  font-family: var(--font-theme);
}

.banobagi-eye,
.banobagi-eye * {
    letter-spacing: 0 !important;
}

body {
	font-family: var(--font-sans);
	color: var(--color-text);
	line-height: 1.7;
	background-color: var(--color-white);
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }

/* ===== Breadcrumb ===== */
.breadcrumb {
	max-width: var(--content-width-full);
	margin: 0 auto;
	padding: var(--space-lg) var(--space-lg) 0;
	font-size: 0.8125rem;
	color: var(--color-text-tertiary);
}

.breadcrumb a {
	color: var(--color-text-tertiary);
	transition: color 0.2s ease;
}

.breadcrumb a:hover { color: var(--color-primary-dark); }

.breadcrumb-separator {
	margin: 0 var(--space-xs);
	opacity: 0.5;
}

.breadcrumb-current {
	color: var(--color-text);
	font-weight: 500;
}


/* ===== HERO ===== */
.hero {
	position: relative;
	min-height: 640px;
	display: flex;
	align-items: center;
	overflow: hidden;
	margin-bottom: 0;
}

.hero-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	background-color: #E5C7AF;
	background-image:
		linear-gradient(
			90deg,
			rgba(229,199,175,0.94) 0%,
			rgba(229,199,175,0.88) 42%,
			rgba(229,199,175,0.68) 100%
		),
		url('https://www.banobagi.com/img_up/shop_pds/banobagi/design/images/promotion/eye/sec_main_bg.jpg');
	background-position: center bottom;
	background-size: cover;
	background-repeat: no-repeat;
}

.hero-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: none;
}

.hero-inner {
	position: relative;
	z-index: 1;
	max-width: var(--content-width-full);
	margin: 0 auto;
	padding: clamp(5rem, 10vw, 7rem) var(--space-lg) clamp(4rem, 8vw, 5.5rem);
	width: 100%;
}

.hero-visual {
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 0;
	width: min(52vw, 820px);
	pointer-events: none;
	display: none;
}

.hero-visual img {
	width: 100%;
	height: auto;
	display: block;
}

.hero-category {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: #8C6247;
	margin-bottom: var(--space-lg);
}

.hero-category::before {
	content: '';
	width: 24px;
	height: 1px;
	background-color: #8C6247;
}

.hero-title {
	font-family: var(--font-serif);
	font-size: clamp(2.25rem, 5vw, 3.25rem);
	font-weight: 600;
	color: #2F2118;
	line-height: 1.15;
	margin-bottom: var(--space-lg);
	letter-spacing: -0.02em;
	max-width: 580px;
	text-shadow: none;
}

.hero-desc {
	font-size: 1.0625rem;
	color: #5C4A3D;
	text-shadow: none;
	max-width: 480px;
	line-height: 1.7;
	margin-bottom: var(--space-xl);
}

.hero-actions {
	display: flex;
	gap: var(--space-md);
	flex-wrap: wrap;
	margin-bottom: var(--space-xl);
}

.btn-primary {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	padding: 14px var(--space-xl);
	background: linear-gradient(135deg, #4B3428 0%, #2F2118 100%);
	color: var(--color-white);
	font-family: var(--font-sans);
	font-size: 0.8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	transition: all 0.3s ease;
	position: relative;
	overflow: hidden;
}

.btn-primary::before {
	content: '';
	position: absolute;
	top: 0; left: -100%;
	width: 100%; height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
	transition: left 0.5s ease;
}

.btn-primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 24px rgba(47,33,24,0.22);
}

.btn-primary:hover::before { left: 100%; }

.btn-primary svg { width: 16px; height: 16px; transition: transform 0.3s ease; }
.btn-primary:hover svg { transform: translateX(4px); }

.btn-secondary {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	padding: 14px var(--space-xl);
	background: rgba(255,255,255,0.22);
	color: #3A2A20;
	font-family: var(--font-sans);
	font-size: 0.8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	border: 1px solid rgba(58,42,32,0.24);
	border-radius: 4px;
	cursor: pointer;
	transition: all 0.3s ease;
}

.btn-secondary:hover {
	background: rgba(255,255,255,0.35);
	border-color: #8C6247;
	color: #2F2118;
	transform: translateY(-2px);
}

.btn-secondary svg { width: 16px; height: 16px; }

.hero-trust {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
	font-size: 0.8125rem;
	color: #6B5546;
}

.hero-trust-item {
	display: flex;
	align-items: center;
	gap: 6px;
	line-height: 1.6;
}

.hero-trust-item svg {
	width: 16px;
	height: 16px;
	color: #3B9B6D;
	flex-shrink: 0;
}

.hero-trust-item strong {
	font-weight: 600;
	color: #3A2A20;
}


/* ===== Section Utilities ===== */
.section {
	max-width: var(--content-width-full);
	margin: 0 auto;
	padding: var(--space-3xl) var(--space-lg);
}

.section-full {
	padding: var(--space-3xl) var(--space-lg);
}

.section-header {
	text-align: center;
	margin-bottom: var(--space-2xl);
}

.section-label {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--color-primary-dark);
	margin-bottom: var(--space-md);
}

.section-label::before,
.section-label::after {
	content: '';
	width: 24px;
	height: 1px;
	background-color: var(--color-primary);
}

.section-title {
	font-family: var(--font-serif);
	font-size: clamp(1.75rem, 4vw, 2.25rem);
	font-weight: 600;
	color: var(--color-black);
	line-height: 1.2;
	margin-bottom: var(--space-md);
	letter-spacing: -0.02em;
}

.section-subtitle {
	font-size: 1rem;
	color: var(--color-text-secondary);
	max-width: 560px;
	margin: 0 auto;
	line-height: 1.6;
}


/* ===== Procedure Cards ===== */
.procedures-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-lg);
}

.procedure-card {
	display: flex;
	flex-direction: column;
	padding: var(--space-xl);
	background: var(--color-white);
	border: 1px solid var(--color-border);
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	position: relative;
	overflow: hidden;
}

.procedure-card:hover {
	border-color: var(--color-primary-light);
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(0,0,0,0.08);
}

.procedure-card-icon {
	width: 48px;
	height: 48px;
	margin-bottom: var(--space-md);
	color: var(--color-primary-dark);
}

.procedure-card-title {
	font-family: var(--font-serif);
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: var(--space-sm);
	line-height: 1.3;
}

.procedure-card-desc {
	font-size: 0.9375rem;
	color: var(--color-text-secondary);
	line-height: 1.6;
	margin-bottom: var(--space-lg);
	flex: 1;
}

.procedure-card-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--color-primary-dark);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	transition: gap 0.3s ease;
	text-decoration: none !important;
}

.procedure-card-link:hover { gap: 12px; }
.procedure-card-link svg { width: 14px; height: 14px; }

.procedure-card-sublinks {
	display: flex;
	flex-direction: column;
	margin-top: auto;
}

.procedure-card-sublinks .procedure-card-link {
	padding: 7px 0;
	border-top: 1px solid var(--color-border-light);
}

.procedure-card-sublinks .procedure-card-link:first-child {
	border-top: none;
	padding-top: 0;
}


/* ===== Quick Facts Bar ===== */
.facts-bar {
	background: var(--color-surface);
	border-top: 1px solid var(--color-border-light);
	border-bottom: 1px solid var(--color-border-light);
}

.facts-bar-inner {
	max-width: var(--content-width-full);
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	padding: 0 var(--space-lg);
}

.facts-bar-item {
	padding: var(--space-xl) var(--space-lg);
	text-align: center;
	border-right: 1px solid var(--color-border-light);
}

.facts-bar-item:last-child { border-right: none; }

.facts-bar-value {
	font-family: var(--font-serif);
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--color-primary-dark);
	line-height: 1;
	margin-bottom: 4px;
}

.facts-bar-label {
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--color-text-secondary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}


/* ===== Featured / Balance of Beauty ===== */
.featured {
	position: relative;
	overflow: hidden;
}

.featured-inner {
	max-width: var(--content-width-full);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	gap: var(--space-3xl);
}

.featured-image {
	position: relative;
}

.featured-image img {
	width: 100%;
	height: auto;
	display: block;
}

.featured-content {
	padding: var(--space-2xl) 0;
}

.featured-label {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--color-primary-dark);
	margin-bottom: var(--space-md);
	display: flex;
	align-items: center;
	gap: var(--space-xs);
}

.featured-label::before {
	content: '';
	width: 24px;
	height: 1px;
	background-color: var(--color-primary);
}

.featured-title {
	font-family: var(--font-serif);
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 600;
	color: var(--color-black);
	line-height: 1.2;
	margin-bottom: var(--space-xl);
	letter-spacing: -0.02em;
}

.featured-pillars {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	margin-bottom: var(--space-xl);
}

.featured-pillar {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	padding: var(--space-md) var(--space-lg);
	background: var(--color-surface);
	border-left: none;
	border-radius: 0 6px 6px 0;
}

.featured-pillar-icon {
	width: 40px;
	height: 40px;
	flex-shrink: 0;
	color: var(--color-primary-dark);
}

.featured-pillar h3 {
	font-family: var(--font-serif);
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: 2px;
}

.featured-pillar p {
	font-size: 0.8125rem;
	color: var(--color-text-secondary);
	line-height: 1.5;
}

.featured-desc {
	font-size: 1rem;
	color: var(--color-text-secondary);
	line-height: 1.8;
}

@media (max-width: 768px) {
	.featured-inner {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}
	.featured-content {
		padding: 0 var(--space-md) var(--space-xl);
	}
	.featured-image {
		order: -1;
	}
}

/* ===== What's the Difference ===== */
.difference {
	background: var(--color-surface);
	color: var(--color-black);
}

.difference-inner {
	max-width: var(--content-width-full);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	gap: var(--space-3xl);
}

.difference-content {
	padding: var(--space-4xl) 0 var(--space-4xl) var(--space-lg);
}

.difference-label {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--color-primary-dark);
	margin-bottom: var(--space-md);
}

.difference-label::before {
	content: '';
	width: 24px;
	height: 1px;
	background-color: var(--color-primary);
}

.difference-title {
	font-family: var(--font-serif);
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 600;
	color: var(--color-black);
	line-height: 1.2;
	margin-bottom: var(--space-md);
	letter-spacing: -0.02em;
}

.difference-tagline {
	font-family: var(--font-serif);
	font-size: 1.125rem;
	font-style: italic;
	color: var(--color-primary-dark);
	margin-bottom: var(--space-xl);
}

.difference-desc {
	font-size: 1rem;
	color: var(--color-text-secondary);
	line-height: 1.8;
}

.difference-image {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-xl);
}

.difference-image img {
	max-width: 360px;
	width: 100%;
	height: auto;
	display: block;
}

@media (max-width: 768px) {
	.difference-inner {
		grid-template-columns: 1fr;
		gap: 0;
	}
	.difference-content {
		padding: var(--space-2xl) var(--space-md);
		order: 2;
	}
	.difference-image {
		min-height: 320px;
		order: 1;
	}
}

/* ===== Comparison Table ===== */
.comparison-table-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.comparison-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9375rem;
	min-width: 600px;
}

.comparison-table thead th {
	font-family: var(--font-sans);
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--color-black);
	text-align: left;
	padding: var(--space-md) var(--space-lg);
	border-bottom: 2px solid var(--color-primary);
	background: var(--color-surface);
}

.comparison-table tbody td {
	padding: var(--space-md) var(--space-lg);
	border-bottom: 1px solid var(--color-border-light);
	vertical-align: top;
	color: var(--color-text);
}

.comparison-table tbody tr:hover { background: var(--color-primary-subtle); }

.comparison-table .procedure-name {
	font-weight: 600;
	color: var(--color-black);
	white-space: nowrap;
}

.comparison-table .best-for {
	color: var(--color-text-secondary);
}


/* ===== Key Point ===== */
.key-point {
	padding: var(--space-xl);
	background-color: var(--color-primary-subtle);
	margin-top: var(--space-2xl);
}

.key-point-label {
	display: block;
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-primary-dark);
	margin-bottom: var(--space-sm);
}

.key-point p {
	margin: 0;
	font-size: 1rem;
	line-height: 1.7;
}

.key-point strong {
	font-weight: 600;
	color: var(--color-black);
}


/* ===== Stats Grid ===== */
.stats-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-lg);
	margin-bottom: var(--space-2xl);
}

.stat-card {
	text-align: center;
	padding: var(--space-xl) var(--space-md);
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
}

.stat-number {
	font-family: var(--font-serif);
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--color-primary-dark);
	line-height: 1;
	margin-bottom: var(--space-xs);
}

.stat-label {
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--color-text-secondary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}


/* ===== Why Banobagi Section ===== */
.why-section {
	background: var(--color-surface);
	border-top: 1px solid var(--color-border-light);
	border-bottom: 1px solid var(--color-border-light);
}

.why-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl) var(--space-3xl);
}

.why-item {
	display: flex;
	gap: var(--space-lg);
}

.why-item-icon {
	width: 40px;
	height: 40px;
	flex-shrink: 0;
	color: var(--color-primary-dark);
}

.why-item-content h3 {
	font-family: var(--font-serif);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: 4px;
	line-height: 1.3;
}

.why-item-content p {
	font-size: 0.9375rem;
	color: var(--color-text-secondary);
	line-height: 1.6;
}


/* ===== Why Specialties (featured rows) ===== */
.why-specialties {
	margin-top: var(--space-3xl);
	display: flex;
	flex-direction: column;
	gap: var(--space-3xl);
}

.why-specialty-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	gap: var(--space-3xl);
	max-width: var(--content-width-full);
	margin: 0 auto;
}

.why-specialty-row:nth-child(even) .why-specialty-image {
	order: 2;
}

.why-specialty-row:nth-child(even) .why-specialty-content {
	order: 1;
}

.why-specialty-image img {
	width: 100%;
	max-width: 380px;
	height: auto;
	display: block;
	margin: 0 auto;
}

.why-specialty-content h3 {
	font-family: var(--font-serif);
	font-size: clamp(1.25rem, 2.5vw, 1.5rem);
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: var(--space-sm);
	line-height: 1.3;
}

.why-specialty-content p {
	font-size: 0.9375rem;
	color: var(--color-text-secondary);
	line-height: 1.7;
}

@media (max-width: 768px) {
	.why-specialty-row { grid-template-columns: 1fr; gap: var(--space-xl); }
	.why-specialty-row:nth-child(even) .why-specialty-image { order: -1; }
	.why-specialty-row:nth-child(even) .why-specialty-content { order: 2; }
	.why-specialty-image img { max-width: 280px; }
}

/* ===== Before & After ===== */
.ba-tabs {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-xs);
	margin-bottom: var(--space-2xl);
}

.ba-tab {
	padding: 8px 18px;
	font-family: var(--font-sans);
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--color-text-secondary);
	background: none;
	border: 1px solid var(--color-border);
	border-radius: 100px;
	cursor: pointer;
	transition: all 0.25s ease;
	white-space: nowrap;
}

.ba-tab:hover {
	color: var(--color-primary-dark);
	border-color: var(--color-primary-light);
}

.ba-tab.active {
	color: var(--color-white);
	background: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	font-weight: 600;
}

.ba-panels { position: relative; }

.ba-panel {
	display: none;
}

.ba-panel.active {
	display: block;
}

.ba-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
}

.ba-card {
	border: 1px solid var(--color-border-light);
	overflow: hidden;
}

.ba-card-label {
	display: flex;
	justify-content: space-between;
	padding: var(--space-sm) var(--space-md);
	background: var(--color-surface);
	border-top: 1px solid var(--color-border-light);
}

.ba-card-label span {
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.ba-card-label .ba-label-before { color: var(--color-text-tertiary); }
.ba-card-label .ba-label-after { color: var(--color-primary-dark); }

/* --- Slider (desktop) --- */
.ba-slider {
	position: relative;
	overflow: hidden;
	cursor: ew-resize;
	aspect-ratio: 4 / 3;
	user-select: none;
	-webkit-user-select: none;
}

.ba-slider img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	pointer-events: none;
}

.ba-slider .ba-img-before {
	z-index: 1;
	clip-path: inset(0 50% 0 0);
}

.ba-slider .ba-img-after {
	z-index: 0;
}

.ba-slider-handle {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 50%;
	z-index: 2;
	width: 3px;
	background: var(--color-white);
	box-shadow: 0 0 6px rgba(0,0,0,0.3);
	transform: translateX(-50%);
	pointer-events: none;
}

.ba-slider-handle::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--color-white);
	box-shadow: 0 2px 8px rgba(0,0,0,0.2);
	pointer-events: none;
}

.ba-slider-handle::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 1;
	width: 18px;
	height: 18px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpath d='M15 18l-6-6 6-6'/%3E%3C/svg%3E"), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpath d='M9 18l6-6-6-6'/%3E%3C/svg%3E");
	background-size: 10px 10px, 10px 10px;
	background-position: 1px center, 7px center;
	background-repeat: no-repeat, no-repeat;
	pointer-events: none;
}

/* --- Side-by-side (mobile) --- */
.ba-sidebyside {
	display: none;
	aspect-ratio: auto;
}

.ba-sidebyside .ba-sbs-pair {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ba-sidebyside .ba-sbs-pair > div {
	position: relative;
}

.ba-sidebyside .ba-sbs-pair > div::after {
	position: absolute;
	top: 8px;
	left: 8px;
	font-size: 0.625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 3px 8px;
	background: rgba(0,0,0,0.5);
	color: var(--color-white);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}

.ba-sidebyside .ba-sbs-pair > div:first-child::after { content: 'Before'; }
.ba-sidebyside .ba-sbs-pair > div:last-child::after { content: 'After'; }

.ba-sidebyside img {
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	object-position: center;
	display: block;
}

.ba-more-link {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-xs);
	margin-top: var(--space-xl);
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--color-primary-dark);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	transition: gap 0.3s ease;
}

.ba-more-link:hover { gap: var(--space-md); }
.ba-more-link svg { width: 16px; height: 16px; }

@media (max-width: 768px) {
	.ba-slider { display: none; }
	.ba-sidebyside { display: block; }
	.ba-grid { grid-template-columns: 1fr; }
	.ba-card-label { display: none; }
}

@media (max-width: 480px) {
	.ba-tabs { gap: 6px; }
	.ba-tab { padding: 6px 14px; font-size: 0.75rem; }
}


/* ===== Inline CTA Strip ===== */
.cta-strip {
	max-width: var(--content-width-full);
	margin: 0 auto;
	padding: var(--space-2xl) var(--space-lg);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-xl);
	border-top: 1px solid var(--color-border-light);
	border-bottom: 1px solid var(--color-border-light);
}

.cta-strip-text h3 {
	font-family: var(--font-serif);
	font-size: 1.375rem;
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: 4px;
}

.cta-strip-text p {
	font-size: 0.9375rem;
	color: var(--color-text-secondary);
}

.cta-strip-actions {
	display: flex;
	gap: var(--space-md);
	flex-shrink: 0;
}


/* ===== FAQ ===== */
.faq-item {
	border-bottom: 1px solid var(--color-border-light);
}

.faq-question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--space-lg) 0;
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	font-family: var(--font-sans);
	font-size: 1rem;
	font-weight: 600;
	color: var(--color-black);
	line-height: 1.4;
	gap: var(--space-md);
	transition: color 0.2s ease;
}

.faq-question:hover { color: var(--color-primary-dark); }

.faq-question svg {
	width: 20px; height: 20px;
	flex-shrink: 0;
	color: var(--color-text-tertiary);
	transition: transform 0.3s ease;
}

.faq-item.active .faq-question svg { transform: rotate(180deg); }

.faq-answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease;
}

.faq-answer-inner {
	padding-bottom: var(--space-xl);
	font-size: 0.9375rem;
	line-height: 1.75;
	color: var(--color-text-secondary);
}


/* ===== Final CTA Section ===== */
.cta-final {
	position: relative;
	overflow: hidden;
	background: linear-gradient(135deg, #FCF8F4 0%, #F5EDE5 50%, #FFFFFF 100%);
	background-size: 200% 200%;
	animation: gradientShift 8s ease infinite;
}

@keyframes gradientShift {
	0%, 100% { background-position: 0% 50%; }
	50% { background-position: 100% 50%; }
}

.cta-final-bg {
	position: absolute; inset: 0;
	pointer-events: none; overflow: hidden;
}

.cta-bg-shape {
	position: absolute;
	border-radius: 50%;
	background: linear-gradient(135deg, rgba(221,166,120,0.15) 0%, rgba(221,166,120,0.05) 100%);
	filter: blur(2px);
}

.cta-bg-shape:nth-child(1) { width: 300px; height: 300px; top: -100px; right: -50px; animation: float1 12s ease-in-out infinite; }
.cta-bg-shape:nth-child(2) { width: 200px; height: 200px; bottom: -60px; left: -40px; animation: float2 10s ease-in-out infinite; }
.cta-bg-shape:nth-child(3) { width: 150px; height: 150px; top: 50%; left: 15%; transform: translateY(-50%); animation: float3 14s ease-in-out infinite; }
.cta-bg-shape:nth-child(4) { width: 100px; height: 100px; top: 20%; right: 20%; animation: float4 9s ease-in-out infinite; }
.cta-bg-shape:nth-child(5) { width: 80px; height: 80px; bottom: 20%; right: 10%; animation: float5 11s ease-in-out infinite; }

@keyframes float1 { 0%, 100% { transform: translate(0,0) scale(1); opacity: 0.6; } 50% { transform: translate(-30px,40px) scale(1.1); opacity: 0.8; } }
@keyframes float2 { 0%, 100% { transform: translate(0,0) scale(1); opacity: 0.5; } 50% { transform: translate(40px,-30px) scale(1.15); opacity: 0.7; } }
@keyframes float3 { 0%, 100% { transform: translateY(-50%) translate(0,0) scale(1); opacity: 0.4; } 50% { transform: translateY(-50%) translate(20px,20px) scale(1.2); opacity: 0.6; } }
@keyframes float4 { 0%, 100% { transform: translate(0,0) scale(1); opacity: 0.5; } 33% { transform: translate(-15px,25px) scale(1.1); opacity: 0.7; } 66% { transform: translate(15px,-10px) scale(0.95); opacity: 0.5; } }
@keyframes float5 { 0%, 100% { transform: translate(0,0) scale(1); opacity: 0.4; } 50% { transform: translate(-25px,-20px) scale(1.15); opacity: 0.6; } }

.cta-final::before {
	content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
	background: linear-gradient(90deg, transparent, var(--color-primary-dark), transparent);
}

.cta-final::after {
	content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
	background: linear-gradient(90deg, transparent, var(--color-primary-dark), transparent);
}

.cta-shimmer {
	position: absolute; top: 0; left: -100%; width: 50%; height: 100%;
	background: linear-gradient(90deg, transparent, rgba(221,166,120,0.08), transparent);
	animation: shimmer 6s ease-in-out infinite;
	pointer-events: none;
}

@keyframes shimmer { 0% { left: -100%; } 50%, 100% { left: 150%; } }

.cta-final-inner {
	position: relative;
	z-index: 1;
	max-width: var(--content-width-full);
	margin: 0 auto;
	padding: var(--space-3xl) var(--space-lg);
	display: grid;
	grid-template-columns: 1fr 380px;
	gap: var(--space-3xl);
	align-items: center;
}

/* Left column */
.cta-final-title {
	font-family: var(--font-serif);
	font-size: clamp(1.75rem, 4vw, 2.25rem);
	font-weight: 600;
	color: var(--color-black);
	line-height: 1.2;
	margin-bottom: var(--space-md);
	letter-spacing: -0.02em;
}

.cta-final-desc {
	font-size: 1rem;
	color: var(--color-text-secondary);
	line-height: 1.7;
	margin-bottom: var(--space-2xl);
	max-width: 480px;
}

.cta-steps {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
}

.cta-step {
	display: flex;
	gap: var(--space-lg);
	align-items: flex-start;
}

.cta-step-num {
	font-family: var(--font-serif);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1;
	flex-shrink: 0;
	width: 32px;
	padding-top: 2px;
}

.cta-step strong {
	display: block;
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: 2px;
}

.cta-step p {
	font-size: 0.875rem;
	color: var(--color-text-secondary);
	line-height: 1.5;
	margin: 0;
}

/* Right column card */
.cta-final-card {
	background: rgba(255,255,255,0.85);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid rgba(221,166,120,0.2);
	border-radius: 4px;
	padding: var(--space-2xl) var(--space-xl);
}

.cta-final-card-title {
	font-family: var(--font-serif);
	font-size: 1.375rem;
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: var(--space-xs);
}

.cta-final-card-desc {
	font-size: 0.875rem;
	color: var(--color-text-secondary);
	line-height: 1.6;
	margin-bottom: var(--space-xl);
}

.cta-contact-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	width: 100%;
	padding: 14px var(--space-lg);
	border-radius: 4px;
	font-family: var(--font-sans);
	font-size: 0.875rem;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.3s ease;
	border: none;
}

.cta-contact-btn svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
}

.cta-contact-whatsapp {
	background: var(--color-white);
	color: var(--color-black);
	border: 1px solid var(--color-border);
	margin-bottom: var(--space-sm);
}

.cta-contact-whatsapp svg {
	color: #25D366;
}

.cta-contact-whatsapp:hover {
	border-color: var(--color-primary);
	color: var(--color-primary-dark);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

.cta-contact-instagram {
	background: var(--color-white);
	color: var(--color-black);
	border: 1px solid var(--color-border);
}

.cta-contact-instagram svg {
	color: #E1306C;
}

.cta-contact-instagram:hover {
	border-color: var(--color-primary);
	color: var(--color-primary-dark);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

.cta-final-divider {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	margin: var(--space-xl) 0;
}

.cta-final-divider::before,
.cta-final-divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background-color: rgba(92,74,61,0.15);
}

.cta-final-divider span {
	font-size: 0.6875rem;
	color: var(--color-text-tertiary);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

.cta-final-social {
	display: flex;
	justify-content: center;
	gap: var(--space-lg);
}

.cta-final-social a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--color-surface);
	border: 1px solid var(--color-border-light);
	color: var(--color-text-secondary);
	transition: all 0.3s ease;
}

.cta-final-social a svg {
	width: 18px;
	height: 18px;
}

.cta-final-social a:hover {
	color: var(--color-primary-dark);
	border-color: var(--color-primary);
	transform: translateY(-2px);
}


/* ===== Related Posts ===== */
.related-posts-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-xl);
}

.related-post-card {
	display: block;
	transition: transform 0.3s ease;
}

.related-post-card:hover { transform: translateY(-4px); }
.related-post-card:hover .related-post-title { color: var(--color-primary-dark); }

.related-post-image {
	width: 100%; aspect-ratio: 16 / 10; object-fit: cover;
	margin-bottom: var(--space-md);
}

.related-post-category {
	font-size: 0.6875rem; font-weight: 600; text-transform: uppercase;
	letter-spacing: 0.1em; color: var(--color-primary-dark);
	margin-bottom: var(--space-xs);
}

.related-post-title {
	font-family: var(--font-serif); font-size: 1.125rem; font-weight: 600;
	color: var(--color-black); line-height: 1.4; transition: color 0.2s ease;
}

.related-post-date {
	font-size: 0.8125rem; color: var(--color-text-tertiary);
	margin-top: var(--space-sm);
}

.related-header {
	display: flex; align-items: center; gap: var(--space-md);
	margin-bottom: var(--space-xl);
}

.related-header h3 {
	font-family: var(--font-serif); font-size: 1.25rem; font-weight: 600;
	color: var(--color-black); white-space: nowrap;
}

.related-header::after {
	content: ''; flex: 1; height: 1px; background-color: var(--color-border-light);
}


/* ===== Doctors Section ===== */
.doctor-showcase {
	position: relative;
}

.doctors-grid {
	display: flex;
	gap: var(--space-lg);
}

.doctor-card {
	flex: 1 1 0;
	min-width: 0;
	height: 640px;
	min-height: 640px;
	display: grid;
	grid-template-columns: 1fr 0fr;
	align-items: stretch;
	background: linear-gradient(180deg, #36373C 0%, #2E2F34 100%);
	border: 1px solid rgba(221, 166, 120, 0.2);
	overflow: hidden;
	transition: flex 0.52s cubic-bezier(0.22, 1, 0.36, 1), grid-template-columns 0.52s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.28s ease, box-shadow 0.28s ease, transform 0.28s ease;
}

.doctor-card:focus-visible {
	outline: 2px solid rgba(221, 166, 120, 0.45);
	outline-offset: 2px;
}

.doctors-grid:hover .doctor-card,
.doctors-grid:not(:hover):focus-within .doctor-card {
	flex: 0.86 1 0;
}

.doctors-grid:hover .doctor-card:hover,
.doctors-grid:not(:hover):focus-within .doctor-card:focus-within {
	flex: 1.72 1 0;
	grid-template-columns: minmax(250px, 41%) 1fr;
	border-color: rgba(221, 166, 120, 0.45);
	box-shadow: 0 18px 38px rgba(0,0,0,0.1);
	transform: translateY(-2px);
}

.doctor-card-image {
	position: relative;
	height: 100%;
	min-height: 0;
	overflow: hidden;
}

.doctor-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
	display: block;
	transition: transform 0.52s cubic-bezier(0.22, 1, 0.36, 1);
}

.doctor-card-image::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(19,19,19,0.82), rgba(19,19,19,0.08) 42%, rgba(19,19,19,0) 68%);
	transition: opacity 0.32s ease;
}

.doctor-card-badge {
	position: absolute;
	top: var(--space-md);
	left: var(--space-md);
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 4px 10px;
	background: rgba(255,255,255,0.9);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-primary-dark);
	z-index: 1;
}

.doctor-card-badge svg {
	width: 12px;
	height: 12px;
	color: #3B9B6D;
}

.doctor-card-info {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: var(--space-lg);
	z-index: 1;
	transition: opacity 0.24s ease, transform 0.38s cubic-bezier(0.22, 1, 0.36, 1);
}

.doctor-card-name {
	font-family: var(--font-serif);
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--color-white);
	margin-bottom: 1px;
	line-height: 1.3;
}

.doctor-card-title {
	display: block;
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.82);
	font-weight: 500;
	margin-bottom: 0;
}

.doctor-card-detail {
	min-width: 0;
	height: 100%;
	display: flex;
	align-items: stretch;
	background: linear-gradient(180deg, #36373C 0%, #2E2F34 100%);
	overflow: hidden;
}

.doctor-detail-content {
	height: auto;
	width: min(100%, 400px);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	padding: var(--space-3xl) clamp(1.2rem, 2.3vw, 2rem);
	color: rgba(255,255,255,0.88);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(10px);
	filter: blur(6px);
	transition: opacity 0.18s ease, transform 0.36s cubic-bezier(0.22, 1, 0.36, 1), filter 0.36s ease, visibility 0s linear 0.18s;
}

.doctors-grid:hover .doctor-card:hover .doctor-card-image img,
.doctors-grid:not(:hover):focus-within .doctor-card:focus-within .doctor-card-image img {
	transform: scale(1.02);
}

.doctors-grid:hover .doctor-card:hover .doctor-card-image::after,
.doctors-grid:not(:hover):focus-within .doctor-card:focus-within .doctor-card-image::after {
	opacity: 0.12;
}

.doctors-grid:hover .doctor-card:hover .doctor-card-info,
.doctors-grid:not(:hover):focus-within .doctor-card:focus-within .doctor-card-info {
	opacity: 0;
	transform: translateY(12px);
}

.doctors-grid:hover .doctor-card:hover .doctor-detail-content,
.doctors-grid:not(:hover):focus-within .doctor-card:focus-within .doctor-detail-content {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0);
	filter: blur(0);
	transition-delay: 0.18s, 0.18s, 0.18s, 0s;
}

.doctor-detail-kicker {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: rgba(221, 166, 120, 0.78);
	margin-bottom: var(--space-md);
	line-height: 1.6;
}

.doctor-detail-head {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px 14px;
	margin-bottom: var(--space-lg);
}

.doctor-detail-name {
	font-family: var(--font-serif);
	font-size: clamp(1.8rem, 2.5vw, 2.25rem);
	font-weight: 600;
	color: var(--color-white);
	line-height: 1.08;
	margin: 0;
}

.doctor-detail-title {
	margin: 0;
	padding-left: 14px;
	border-left: 1px solid rgba(255,255,255,0.24);
	font-size: 0.8125rem;
	font-weight: 600;
	color: rgba(255,255,255,0.8);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

.doctor-detail-credentials {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin: 0;
	padding: 0;
	font-size: 0.875rem;
	line-height: 1.5;
}

.doctor-detail-credentials li {
	position: relative;
	padding-left: 18px;
}

.doctor-detail-credentials li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.7em;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--color-primary);
}

.doctor-detail-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: var(--space-lg);
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--color-primary-light);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	transition: gap 0.3s ease;
	align-self: flex-start;
}

.doctor-detail-link:hover { gap: 12px; }
.doctor-detail-link svg { width: 14px; height: 14px; }

.doctors-more {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-xs);
	margin-top: var(--space-xl);
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--color-primary-dark);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	transition: gap 0.3s ease;
}

.doctors-more:hover { gap: var(--space-md); }
.doctors-more svg { width: 16px; height: 16px; }


/* ===== Responsive ===== */
@media (max-width: 1024px) {
	.procedures-grid { grid-template-columns: repeat(2, 1fr); }
	.stats-grid { grid-template-columns: repeat(2, 1fr); }
	.why-grid { grid-template-columns: 1fr; }
	.related-posts-grid { grid-template-columns: repeat(2, 1fr); }
	.doctors-grid { gap: var(--space-md); }
	.doctor-card { height: 480px; min-height: 480px; }
	.doctors-grid:hover .doctor-card:hover,
	.doctors-grid:not(:hover):focus-within .doctor-card:focus-within {
		grid-template-columns: minmax(200px, 39%) 1fr;
	}
	.facts-bar-inner { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
	.hero { min-height: 460px; }

	.hero-visual {
		width: min(78vw, 420px);
		right: -40px;
		opacity: 0.55;
	}

	.hero-bg::after {
		background: none;
	}

	.hero-inner { padding: var(--space-3xl) var(--space-md) var(--space-2xl); }
	.hero-title { font-size: 1.875rem; max-width: 100%; }
	.hero-desc { max-width: 100%; }
	.hero-actions { flex-direction: column; }
	.hero-trust { flex-direction: column; align-items: flex-start; gap: var(--space-sm); }

	.section { padding: var(--space-2xl) var(--space-md); }
	.section-full { padding: var(--space-2xl) var(--space-md); }

	.procedures-grid { grid-template-columns: 1fr; }
	.stats-grid { grid-template-columns: repeat(2, 1fr); }
	.doctors-grid { flex-direction: column; }

	.doctor-card {
		flex: 0 0 auto;
		height: auto;
		min-height: auto;
		display: grid;
		grid-template-columns: 1fr;
		grid-template-rows: 280px auto;
		transform: none !important;
	}

	.doctors-grid:hover .doctor-card,
	.doctors-grid:not(:hover):focus-within .doctor-card,
	.doctors-grid:hover .doctor-card:hover,
	.doctors-grid:not(:hover):focus-within .doctor-card:focus-within {
		flex: 0 0 auto;
		grid-template-columns: 1fr;
		grid-template-rows: 280px auto;
		transform: none !important;
	}

	.doctor-card-image {
		height: 100%;
		min-height: 0;
	}

	.doctor-card-image::after {
		opacity: 0.18;
	}

	.doctor-card-detail {
		height: auto;
	}

	.doctor-detail-content {
		width: 100%;
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: none;
		filter: none;
		padding: var(--space-lg) var(--space-lg) var(--space-xl);
	}

	.doctor-card-info {
		display: none;
	}

	.doctor-detail-head {
		align-items: flex-start;
		gap: 8px 12px;
	}

	.doctor-detail-title {
		padding-left: 12px;
	}

	.doctor-detail-credentials {
		font-size: 0.875rem;
	}

	.facts-bar-inner { grid-template-columns: 1fr; }
	.facts-bar-item { border-right: none; border-bottom: 1px solid var(--color-border-light); }
	.facts-bar-item:last-child { border-bottom: none; }

	.cta-strip { flex-direction: column; text-align: center; }
	.cta-strip-actions { justify-content: center; }

	.comparison-table-wrap {
		overflow-x: visible;
		margin: 0;
		padding: 0;
	}

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

	.comparison-table {
		min-width: 0;
		border: none;
	}

	.comparison-table thead {
		display: none;
	}

	.comparison-table tbody tr {
		border: 1px solid var(--color-border-light);
		margin-bottom: var(--space-md);
	}

	.comparison-table tbody tr:hover {
		background: none;
	}

	.comparison-table tbody td {
		padding: var(--space-sm) var(--space-md);
		border-bottom: 1px solid var(--color-border-light);
		white-space: normal;
	}

	.comparison-table tbody td:last-child {
		border-bottom: none;
	}

	.comparison-table .procedure-name {
		white-space: normal;
		background: var(--color-surface);
		padding: var(--space-md);
		font-size: 1rem;
	}

	.comparison-table td:not(.procedure-name)::before {
		content: attr(data-label);
		display: block;
		font-size: 0.6875rem;
		font-weight: 600;
		text-transform: uppercase;
		letter-spacing: 0.08em;
		color: var(--color-text-secondary);
		margin-bottom: 3px;
	}

	.related-posts-grid { grid-template-columns: 1fr; gap: var(--space-2xl); }

	.cta-final-inner { grid-template-columns: 1fr; gap: var(--space-2xl); }

	.breadcrumb { padding: var(--space-md) var(--space-md) 0; }
}

@media (max-width: 480px) {
	.hero-title { font-size: 1.625rem; }
	.stats-grid { gap: var(--space-sm); }
	.stat-number { font-size: 2rem; }
	.cta-final-inner { padding: var(--space-xl) var(--space-md); }
	.key-point { padding: var(--space-lg); }
	.doctor-card { grid-template-rows: 240px auto; }
	.facts-bar-inner { grid-template-columns: 1fr; }
	.facts-bar-item { border-right: none; border-bottom: 1px solid var(--color-border-light); }
	.facts-bar-item:last-child { border-bottom: none; }
}

/* ===== Table of Contents ===== */
.toc {
	max-width: var(--content-width-full);
	margin: 0 auto;
	padding: var(--space-md) var(--space-lg);
	border-bottom: 1px solid var(--color-border-light);
}

.toc-inner {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
	flex-wrap: wrap;
}

.toc-label {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-tertiary);
	white-space: nowrap;
}

.toc-links {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs) var(--space-md);
}

.toc-links a {
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--color-text-secondary);
	transition: color 0.2s ease;
	white-space: nowrap;
}

.toc-links a:hover {
	color: var(--color-primary-dark);
}

@media (max-width: 768px) {
	.toc-inner { flex-direction: column; align-items: flex-start; gap: var(--space-sm); }
	.toc-links { gap: var(--space-xs) var(--space-sm); }
}

/* ===== Why Korea Grid ===== */
.why-korea-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
}

.why-korea-item {
	padding: var(--space-xl);
	background: var(--color-surface);
	border: 1px solid var(--color-border-light);
}

.why-korea-icon {
	width: 36px;
	height: 36px;
	color: var(--color-primary-dark);
	margin-bottom: var(--space-md);
	display: block;
}

.why-korea-stat {
	font-family: var(--font-serif);
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-primary-dark);
	line-height: 1;
	margin-bottom: var(--space-sm);
}

.why-korea-item h3 {
	font-family: var(--font-serif);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: var(--space-xs);
}

.why-korea-item p {
	font-size: 0.9375rem;
	color: var(--color-text-secondary);
	line-height: 1.7;
}

@media (max-width: 768px) {
	.why-korea-grid { grid-template-columns: 1fr; }
}

/* ===== Candidate Grid ===== */
.candidate-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-lg);
}

.candidate-item {
	padding: var(--space-xl);
	background: var(--color-surface);
	border: 1px solid var(--color-border-light);
}

.candidate-item h3 {
	font-family: var(--font-serif);
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: var(--space-md);
}

.candidate-item ul {
	list-style: none;
	padding: 0;
}

.candidate-item li {
	position: relative;
	padding-left: 18px;
	font-size: 0.9375rem;
	color: var(--color-text-secondary);
	line-height: 1.6;
	margin-bottom: var(--space-xs);
}

.candidate-item li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.65em;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--color-primary);
}

@media (max-width: 1024px) {
	.candidate-grid { grid-template-columns: repeat(2, 1fr); }
}

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

/* ===== Recovery Timeline ===== */
.recovery-section {
	background: var(--color-surface);
	border-top: 1px solid var(--color-border-light);
	border-bottom: 1px solid var(--color-border-light);
}

.recovery-timeline {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	position: relative;
	margin-top: var(--space-xl);
}

.recovery-timeline::before {
	content: '';
	position: absolute;
	top: 39px;
	left: calc(12.5% + 8px);
	right: calc(12.5% + 8px);
	height: 2px;
	background: var(--color-border);
}

.recovery-phase {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	position: relative;
	padding: 0 var(--space-md);
}

.recovery-phase-icon {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-white);
	border: 2px solid var(--color-border);
	position: relative;
	z-index: 1;
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	flex-shrink: 0;
}

.recovery-phase-icon svg {
	width: 32px;
	height: 32px;
	color: var(--color-primary-dark);
	transition: transform 0.3s ease;
}

.recovery-phase:hover .recovery-phase-icon {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 6px var(--color-primary-subtle), 0 8px 24px rgba(196, 145, 95, 0.15);
	transform: translateY(-4px);
}

.recovery-phase:hover .recovery-phase-icon svg {
	transform: scale(1.1);
}

.recovery-phase-marker {
	margin-top: var(--space-lg);
	margin-bottom: var(--space-xs);
}

.recovery-phase-day {
	font-family: var(--font-serif);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--color-primary-dark);
	white-space: nowrap;
	line-height: 1.2;
}

.recovery-phase-content h3 {
	font-family: var(--font-serif);
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: var(--space-xs);
	line-height: 1.3;
}

.recovery-phase-content p {
	font-size: 0.875rem;
	color: var(--color-text-secondary);
	line-height: 1.65;
	max-width: 260px;
	margin: 0 auto;
}

.recovery-phase-tags {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 4px;
	margin-top: var(--space-sm);
}

.recovery-tag {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	padding: 3px 10px;
	font-size: 0.6875rem;
	font-weight: 500;
	color: var(--color-text-secondary);
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: 100px;
	white-space: nowrap;
}

.recovery-tag svg {
	width: 10px;
	height: 10px;
	color: var(--color-primary-dark);
}

@media (max-width: 1024px) {
	.recovery-timeline {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-2xl) 0;
	}
	.recovery-timeline::before { display: none; }
	.recovery-phase-content p { max-width: 300px; }
}

@media (max-width: 768px) {
	.recovery-timeline {
		grid-template-columns: 1fr;
		gap: 0;
	}
	.recovery-phase {
		flex-direction: row;
		text-align: left;
		align-items: flex-start;
		padding: var(--space-lg) 0;
		gap: var(--space-lg);
		border-bottom: 1px solid var(--color-border-light);
	}
	.recovery-phase:last-child { border-bottom: none; }
	.recovery-phase-icon { width: 56px; height: 56px; flex-shrink: 0; }
	.recovery-phase-icon svg { width: 24px; height: 24px; }
	.recovery-phase-marker { margin-top: 0; margin-bottom: 2px; }
	.recovery-phase-day { font-size: 1.0625rem; }
	.recovery-phase-content p { max-width: none; }
	.recovery-phase-tags { justify-content: flex-start; }
}

/* ===== Risks & Complications ===== */
.risks-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
	margin-bottom: var(--space-2xl);
}

.risks-group {
	padding: var(--space-xl);
	background: var(--color-surface);
	border: 1px solid var(--color-border-light);
}

.risks-group h3 {
	font-family: var(--font-serif);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-black);
	margin-bottom: var(--space-md);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border);
}

.risks-group ul {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.risks-group ul li {
	font-size: 0.9375rem;
	color: var(--color-text-secondary);
	line-height: 1.6;
	padding-left: 1.25rem;
	position: relative;
}

.risks-group ul li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--color-primary);
}

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

/* ===== How to Prepare ===== */
.prepare-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
	margin-bottom: var(--space-2xl);
}

.prepare-card {
	padding: var(--space-xl);
	background: var(--color-white);
	border: 1px solid var(--color-border);
}

.prepare-card-header {
	display: flex;
	align-items: flex-start;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
}

.prepare-card-number {
	font-family: var(--font-serif);
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1;
	flex-shrink: 0;
}

.prepare-card h3 {
	font-family: var(--font-serif);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-black);
	line-height: 1.3;
	padding-top: 0.35rem;
}

.prepare-card ul {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.prepare-card ul li {
	font-size: 0.9375rem;
	color: var(--color-text-secondary);
	line-height: 1.6;
	padding-left: 1.25rem;
	position: relative;
}

.prepare-card ul li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--color-primary);
}

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

/* ===== Medical Disclaimer ===== */
.medical-disclaimer {
	width: 100%;
	border-top: 1px solid var(--color-border-light);
	background: var(--color-surface);
	padding: var(--space-xl) var(--space-lg);
}

.medical-disclaimer p {
	font-size: 0.8125rem;
	color: var(--color-text-tertiary);
	line-height: 1.7;
	text-align: center;
	max-width: var(--content-width-full);
	margin: 0 auto;
}

.medical-disclaimer strong {
	color: var(--color-text-secondary);
}