/* =====================================================================
 * Celléva – Page "Dịch vụ" (page 131).
 * ===================================================================== */

/* Cho phép shortcode full-bleed thoát khỏi container của theme/Elementor. */
body.celleva-sv .elementor-widget-shortcode .elementor-widget-container,
body.celleva-sv .elementor-shortcode { max-width: none; }
body.celleva-sv .elementor-section.elementor-section-boxed > .elementor-container { max-width: 100% !important; }
body.celleva-sv .site-main,
body.celleva-sv main.site-main,
body.celleva-sv .page-content { max-width: none; padding: 0; }

/* =========================================================
 * SECTOR 1 – HERO TITLE
 * ========================================================= */
.celleva-sv-hero {
	background: var(--cl-bg);
	padding-block: 0;
	text-align: center;
}
.celleva-sv-hero > .celleva-container {
	min-height: 555px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-block: clamp(32px, 3vw, 64px);
	box-sizing: border-box;
}
.celleva-sv-hero__title {
	font-family: 'TUV Domaine Display', 'Cormorant Garamond', Georgia, serif;
	font-weight: 400;
	font-size: clamp(40px, 4.5vw, 86px);
	line-height: 1.2;
	letter-spacing: 0.025em;
	color: var(--cl-text);
	margin: 0;
	text-transform: uppercase;
}
@media (max-width: 782px) {
	.celleva-sv-hero > .celleva-container { min-height: 380px; }
}

/* =========================================================
 * SECTOR 2 – BANNER (full-width)
 * ========================================================= */
.celleva-sv-banner {
	background: var(--cl-bg);
	padding-block: 0;
}
.celleva-sv-banner > .celleva-container { padding-inline: 0; width: 100%; max-width: 100%; }
.celleva-sv-banner__wrap {
	width: 100%;
	height: 660px;
}
.celleva-sv-banner__wrap img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}
@media (max-width: 782px) {
	.celleva-sv-banner__wrap { height: clamp(220px, 45vw, 380px); }
}

/* =========================================================
 * SECTOR 3 – TẠI CELLÉVA (intro 2 cột)
 * ========================================================= */
.celleva-sv-intro {
	background: var(--cl-bg);
	padding-block: 28px;
}
.celleva-sv-intro__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
	gap: clamp(36px, 4vw, 100px);
	align-items: start;
}
.celleva-sv-intro__eyebrow {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: clamp(20px, 1.6vw, 30px);
	letter-spacing: 0.14em;
	color: var(--cl-text);
	margin: 0 0 24px;
	text-transform: uppercase;
	line-height: 1.35;
}
.celleva-sv-intro__desc p,
.celleva-sv-intro__outro p {
	font-size: clamp(14px, 0.95vw, 17px);
	line-height: 1.75;
	color: var(--cl-text-soft);
	margin: 0 0 16px;
}
.celleva-sv-intro__rtitle {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: clamp(15px, 1.1vw, 20px);
	letter-spacing: 0.08em;
	color: var(--cl-text);
	margin: 0 0 18px;
	text-transform: uppercase;
}
.celleva-sv-intro__list {
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
}
.celleva-sv-intro__list li {
	position: relative;
	padding-left: 22px;
	font-size: clamp(14px, 0.95vw, 17px);
	line-height: 1.75;
	color: var(--cl-text-soft);
	margin-bottom: 8px;
}
.celleva-sv-intro__list li::before {
	content: "";
	position: absolute;
	left: 6px;
	top: 0.7em;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--cl-pink);
}
@media (max-width: 900px) {
	.celleva-sv-intro__grid { grid-template-columns: 1fr; }
}

/* =========================================================
 * SECTOR 4 – CHƯƠNG TRÌNH (alternating rows)
 * ========================================================= */
.celleva-sv-prog {
	background: var(--cl-bg);
	padding-block: 28px;
}
.celleva-sv-prog__row {
	display: grid;
	/* Canvas 1920px: text 700 + ảnh 1220, giữ tỉ lệ khi thu nhỏ.
	 * minmax(0, …) ép min-width=0 để ảnh không "bung" cột do natural size. */
	grid-template-columns: minmax(0, 700fr) minmax(0, 1220fr);
	gap: clamp(40px, 4vw, 80px);
	align-items: start;
	margin-bottom: clamp(60px, 6vw, 140px);
}
.celleva-sv-prog__content,
.celleva-sv-prog__media { min-width: 0; }
.celleva-sv-prog__row.is-flip .celleva-sv-prog__media { order: 1; }
.celleva-sv-prog__row.is-flip .celleva-sv-prog__content { order: 2; }
.celleva-sv-prog__row:not(.is-flip) .celleva-sv-prog__media { order: 2; }
.celleva-sv-prog__row:not(.is-flip) .celleva-sv-prog__content { order: 1; }

.celleva-sv-prog__media {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: clamp(20px, 2vw, 40px);
	position: sticky;
	top: calc(var(--menu-height, 125px) + 24px);
	align-self: start;
}
.celleva-sv-prog__pic {
	margin: 0;
	width: 100%;
}
.celleva-sv-prog__pic img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 4px;
	object-fit: cover;
}
/* Khi có nhiều ảnh: lồng so le (zigzag) */
/* 2 ảnh lồng — pic--1 lớn (top-right), pic--2 nhỏ (bottom-left, viền trắng) */
.celleva-sv-prog__media[data-count="2"] {
	gap: 0;
	position: sticky; /* sticky vừa pin ảnh, vừa là containing block cho pic--2 absolute */
}
.celleva-sv-prog__media[data-count="2"] .celleva-sv-prog__pic { width: auto; }
.celleva-sv-prog__media[data-count="2"] .celleva-sv-prog__pic img { aspect-ratio: auto; }
.celleva-sv-prog__media[data-count="2"] .celleva-sv-prog__pic--1 {
	align-self: flex-start;
	width: 88%;
	aspect-ratio: 523 / 655;
	margin-top: 0;
	position: sticky;
	top: calc(var(--menu-height, 125px) + 24px);
}
.celleva-sv-prog__media[data-count="2"] .celleva-sv-prog__pic--2 {
	position: absolute;
	left: 0;
	top: 78%;            /* lùi xuống dưới */
	width: 45%;
	z-index: 2;
	border: 12px solid #fff;
	box-sizing: border-box;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}
.celleva-sv-prog__media[data-count="2"] .celleva-sv-prog__pic--2 img {
	height: auto;
	aspect-ratio: auto;
}
.celleva-sv-prog__media[data-count="2"] .celleva-sv-prog__pic img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* 3 ảnh lồng nhau — canvas thiết kế 1920px, cột ảnh = 1220px:
 *   Ảnh 1 (phải, lớn)   650 × 810   → 650/1220 ≈ 53.28%
 *   Ảnh 2 (trái, nổi)   523 × 655   → 523/1220 ≈ 42.87%
 *   Ảnh 3 (phải, nhỏ)   655 × 385   → 655/1220 ≈ 53.69%
 */
.celleva-sv-prog__media[data-count="3"] {
	gap: 0;
	position: sticky; /* sticky vừa pin ảnh, vừa là containing block cho pic--2 absolute */
}
.celleva-sv-prog__media[data-count="3"] .celleva-sv-prog__pic { width: auto; }
.celleva-sv-prog__media[data-count="3"] .celleva-sv-prog__pic img { aspect-ratio: auto; }

.celleva-sv-prog__media[data-count="3"] .celleva-sv-prog__pic--1 {
	align-self: flex-start;     /* căn phải cột ảnh */
	width: 53.28%;            /* 650 / 1220 */
	aspect-ratio: 650 / 810;
}
/* pic--2 absolute — không chiếm flow để pic--3 stack sát pic--1 */
.celleva-sv-prog__media[data-count="3"] .celleva-sv-prog__pic--2 {
	position: absolute;
	left: 17%;                /* lấn sâu vào pic--1 (~12-15% overlap) */
	top: 35%;                 /* nổi đè giữa pic--1 */
	width: 42.87%;            /* 523 / 1220 */
	aspect-ratio: 523 / 655;
	z-index: 2;
	border: 12px solid #fff;
	box-sizing: border-box;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}
.celleva-sv-prog__media[data-count="3"] .celleva-sv-prog__pic--3 {
	align-self: flex-start;     /* căn phải, thẳng hàng pic 1 */
	width: 53.69%;            /* 655 / 1220 */
	aspect-ratio: 655 / 385;
	margin-top: 40px;
}
.celleva-sv-prog__media[data-count="3"] .celleva-sv-prog__pic img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.celleva-sv-prog__item + .celleva-sv-prog__item { margin-top: clamp(36px, 4vw, 72px); }
.celleva-sv-prog__title {
	font-family: var(--font-head);
	font-weight: 600;
	font-size: 21px;
	letter-spacing: 0.06em;
	color: var(--cl-text);
	margin: 0 0 20px;
	text-transform: uppercase;
	line-height: 1.35;
}
.celleva-sv-prog__desc p {
	font-size: 20px;
	line-height: 1.6;
	color: var(--cl-text-soft);
	margin: 0 0 16px;
}
.celleva-sv-prog__block {
	margin-top: clamp(20px, 2vw, 32px);
}
.celleva-sv-prog__btitle {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: 21px;
	letter-spacing: 0.06em;
	color: var(--cl-text);
	margin: 0 0 12px;
	text-transform: uppercase;
}
.celleva-sv-prog__list {
	list-style: none;
	padding: 0;
	margin: 0 0 12px;
}
.celleva-sv-prog__list li {
	position: relative;
	padding-left: 22px;
	font-size: 20px;
	line-height: 1.6;
	color: var(--cl-text-soft);
	margin-bottom: 6px;
}
.celleva-sv-prog__list li::before {
	content: "";
	position: absolute;
	left: 6px;
	top: 0.7em;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--cl-pink);
}
@media (max-width: 900px) {
	.celleva-sv-prog__row,
	.celleva-sv-prog__row.is-flip { grid-template-columns: 1fr; }
	.celleva-sv-prog__row .celleva-sv-prog__media,
	.celleva-sv-prog__row .celleva-sv-prog__content { order: initial; }
	/* Reset sticky khi 1 cột — sticky không có tác dụng và gây layout lỗi */
	.celleva-sv-prog__media,
	.celleva-sv-prog__media[data-count="2"],
	.celleva-sv-prog__media[data-count="3"] { position: relative; top: auto; }
}

/* =========================================================
 * SECTOR 5 – ẢNH NGANG (1560x477)
 * ========================================================= */
.celleva-sv-wide {
	background: var(--cl-bg);
	padding-block: 28px;
}
.celleva-sv-wide__wrap {
	width: 100%;
	max-width: 1560px;
	margin: 0 auto;
	aspect-ratio: 1560 / 477;
	overflow: hidden;
	border-radius: 4px;
}
.celleva-sv-wide__wrap img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}

/* =========================================================
 * SECTOR 6 – INNER RECOVERY & WELLNESS SUPPORT
 * ========================================================= */
.celleva-sv-inner {
	background: var(--cl-bg);
	padding-block: 28px;
}
.celleva-sv-inner__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
	gap: clamp(36px, 4vw, 100px);
	align-items: start;
}
.celleva-sv-inner__left {
	position: sticky;
	top: calc(var(--menu-height, 125px) + 24px);
	align-self: start;
}
.celleva-sv-inner__eyebrow {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: clamp(20px, 1.6vw, 30px);
	letter-spacing: 0.14em;
	color: var(--cl-text);
	margin: 0;
	text-transform: uppercase;
	line-height: 1.35;
}
.celleva-sv-inner__rtitle {
	font-family: var(--font-head);
	font-weight: 600;
	font-size: clamp(16px, 1.2vw, 22px);
	letter-spacing: 0.06em;
	color: var(--cl-text);
	margin: 0 0 18px;
	text-transform: uppercase;
}
.celleva-sv-inner__intro p,
.celleva-sv-inner__mid p,
.celleva-sv-inner__outro p {
	font-size: clamp(14px, 0.95vw, 17px);
	line-height: 1.75;
	color: var(--cl-text-soft);
	margin: 0 0 16px;
}
.celleva-sv-inner__list {
	list-style: none;
	padding: 0;
	margin: 0 0 20px;
}
.celleva-sv-inner__list li {
	position: relative;
	padding-left: 22px;
	font-size: clamp(14px, 0.95vw, 17px);
	line-height: 1.75;
	color: var(--cl-text-soft);
	margin-bottom: 6px;
}
.celleva-sv-inner__list li::before {
	content: "";
	position: absolute;
	left: 6px;
	top: 0.7em;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--cl-pink);
}
.celleva-sv-inner__block { margin-top: clamp(18px, 2vw, 28px); }
.celleva-sv-inner__btitle {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: clamp(14px, 1vw, 18px);
	letter-spacing: 0.06em;
	color: var(--cl-text);
	margin: 0 0 10px;
	text-transform: uppercase;
}
@media (max-width: 900px) {
	.celleva-sv-inner__grid { grid-template-columns: 1fr; }
}

/* =========================================================
 * SECTOR 7 – HÀNH TRÌNH TẠI CELLÉVA
 * ========================================================= */
.celleva-sv-journey {
	background: var(--cl-bg);
	padding-block: 28px;
}
.celleva-sv-journey__grid {
	display: grid;
	/* Canvas design: ảnh 410 + text 945; tỉ lệ giữ khi thu nhỏ */
	grid-template-columns: minmax(0, 410fr) minmax(0, 945fr);
	gap: clamp(40px, 4vw, 80px);
	align-items: stretch;
}
.celleva-sv-journey__left {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
}
.celleva-sv-journey__eyebrow {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: clamp(20px, 1.6vw, 30px);
	letter-spacing: 0.14em;
	color: var(--cl-text);
	margin: 0 0 28px;
	text-transform: uppercase;
	line-height: 1.35;
}
.celleva-sv-journey__img {
	width: 100%;
	max-width: 410px;
	margin: auto;            /* cân bằng giữa theo chiều dọc cột trái */
	aspect-ratio: 410 / 720;
}
.celleva-sv-journey__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.celleva-sv-journey__steps {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.celleva-sv-journey__step {
	background: #F7F2ED;
	max-width: 945px;
	min-height: 150px;
	padding: clamp(20px, 1.6vw, 30px) clamp(24px, 2vw, 38px);
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 8px;
}
.celleva-sv-journey__head {
	display: flex;
	align-items: baseline;
	gap: 12px;
}
.celleva-sv-journey__num {
	font-family: var(--font-head);
	font-weight: 600;
	font-size: clamp(14px, 1vw, 18px);
	color: var(--cl-text);
	letter-spacing: 0.04em;
	line-height: 1.2;
}
.celleva-sv-journey__num::after {
	content: " — ";
	color: var(--cl-text);
	margin: 0 4px;
}
.celleva-sv-journey__stitle {
	font-family: var(--font-head);
	font-weight: 600;
	font-size: clamp(14px, 1vw, 18px);
	letter-spacing: 0.04em;
	color: var(--cl-text);
	margin: 0;
	text-transform: none;
}
.celleva-sv-journey__sdesc {
	font-size: clamp(13px, 0.9vw, 15px);
	line-height: 1.6;
	color: var(--cl-text-soft);
	margin: 0;
}
@media (max-width: 900px) {
	.celleva-sv-journey__grid { grid-template-columns: 1fr; }
}
