/* =====================================================================
 * Celléva – Trang "Triết lý" (page 218)
 * Dùng chung tokens & .celleva-container / .celleva-section từ global.css
 * ===================================================================== */

/* ---------- Typography dùng chung trong trang ---------- */
.celleva-tl-eyebrow {
	display: inline-block;
	font-family: var(--font-head);
	font-weight: 600;             /* SemiBold */
	font-size: 24px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--cl-pink);
	margin: 0 0 14px;
}
/* Hero eyebrow "OUR PHILOSOPHY" lớn hơn (32px). */
.celleva-tl-hero .celleva-tl-eyebrow { font-size: 32px; }
.celleva-tl-heading {
	font-family: var(--font-display);
	font-weight: 400;             /* Regular */
	font-size: 40px;
	line-height: 1.18;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--cl-text);
	margin: 0;
}
.celleva-tl-head { margin-bottom: 40px; }
.celleva-tl-head--center { text-align: center; }
.celleva-tl-diamond {
	display: block;
	color: var(--cl-pink);
	font-size: 12px;
	margin-top: 14px;
}

/* =========================================================
 * SECTION 1 – HERO
 * ========================================================= */
.celleva-tl-hero {
	background-size: cover;
	background-position: center right;
	background-repeat: no-repeat;
	padding-block: clamp(90px, 11vw, 200px);
}
.celleva-tl-hero::before {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(90deg, rgba(248,241,234,.95) 0%, rgba(248,241,234,.8) 40%, rgba(248,241,234,.25) 100%);
}
.celleva-tl-hero__inner { position: relative; max-width: 600px; }
.celleva-tl-hero__title {
	font-family: var(--font-display);
	font-weight: 400;             /* Regular */
	font-size: clamp(30px, 8.5vw, 70px);
	overflow-wrap: break-word;
	line-height: 1.08;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--cl-text);
	margin: 0 0 22px;
}
.celleva-tl-hero__title span { display: block; }
.celleva-tl-hero__desc {
	color: var(--cl-text);
	font-weight: 600;             /* SemiBold */
	font-size: 20px;
	line-height: 1.8;
	max-width: 520px;
}
.celleva-tl-hero__desc p { margin: 0 0 12px; }

.celleva-tl-hero__actions {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	gap: 28px;
	margin-top: clamp(48px, 8vw, 100px);
}
.celleva-tl-hero__actions .celleva-btn { flex: 0 0 auto; white-space: nowrap; font-size: 15px; }
.celleva-tl-hero__actions .celleva-btn svg { width: 18px; height: 18px; display: block; }

.celleva-tl-hero__play {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--cl-text);
	font-family: var(--font-head);
	font-weight: 600;             /* SemiBold */
	font-size: 15px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	white-space: nowrap;
	transition: color .25s ease;
}
.celleva-tl-hero__play-icon {
	display: inline-grid;
	place-items: center;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: var(--cl-pink);
	color: #fff;
	flex: 0 0 30px;
	transition: transform .25s ease;
}
.celleva-tl-hero__play-icon svg { width: 12px; height: 12px; display: block; margin-left: 1px; }
.celleva-tl-hero__play:hover { color: var(--cl-pink); }
.celleva-tl-hero__play:hover .celleva-tl-hero__play-icon { transform: scale(1.08); }

@media (max-width: 600px) {
	.celleva-tl-hero__actions { flex-wrap: wrap; gap: 20px; }
}

/* =========================================================
 * SECTION 2 – OUR BELIEF (5 niềm tin)
 * ========================================================= */
.celleva-tl-belief { background: var(--cl-bg); padding-block: 28px; }
.celleva-tl-belief .celleva-tl-head { text-align: center; }
.celleva-tl-belief__grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 50px;
}
.celleva-tl-belief__item { text-align: center; }
.celleva-tl-belief__icon {
	width: 100px; height: 100px;
	margin: 0 auto 20px;
	border-radius: 50%;
	border: 1px solid var(--cl-pink-soft, #DCB1A8);
	display: grid; place-items: center;
	color: var(--cl-pink);
}
.celleva-tl-belief__icon svg { width: 46px; height: 46px; }
.celleva-tl-belief__icon img { width: 46px; height: 46px; object-fit: contain; }
.celleva-tl-belief__title {
	font-family: var(--font-head);
	font-weight: 700;
	font-size: 14px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cl-text);
	margin: 0 0 12px;
}
.celleva-tl-belief__desc {
	font-size: 18px;
	font-weight: 600;             /* SemiBold */
	line-height: 1.65;
	color: var(--cl-text-soft);
	margin: 0;
}

/* =========================================================
 * SECTION 3 – BEYOND TREATMENT (dải ảnh)
 * ========================================================= */
.celleva-tl-beyond {
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 575px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-block: 40px;
}
.celleva-tl-beyond::before {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(90deg, rgba(255,255,255,.85) 0%, rgba(255,255,255,.55) 55%, rgba(255,255,255,.2) 100%);
}
.celleva-tl-beyond__inner { position: relative; max-width: 620px; }
.celleva-tl-beyond__heading {
	font-family: var(--font-display);
	font-weight: 400;             /* Regular */
	font-size: 40px;
	line-height: 1.2;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--cl-text);
	margin: 0 0 18px;
}
.celleva-tl-beyond__heading span { display: block; }
.celleva-tl-beyond__desc {
	color: var(--cl-text-soft);
	font-size: 20px;
	font-weight: 600;             /* SemiBold */
	line-height: 1.8;
	margin: 0;
	max-width: 540px;
}

/* =========================================================
 * SECTION 4 – 5 TRỤ CỘT
 * ========================================================= */
.celleva-tl-pillars { background: var(--cl-bg); padding-block: 28px; }
.celleva-tl-pillars__grid {
	display: grid;
	grid-template-columns: repeat(5, 330px);
	gap: 10px;
	justify-content: center;
}
.celleva-tl-pillar {
	text-align: left;
	width: 330px;
	min-height: 480px;
	background: var(--cl-bg-soft);      /* nền card beige theo thiết kế */
	border-radius: 16px;
	overflow: hidden;
	padding-bottom: 28px;
}
.celleva-tl-pillar__img {
	width: 100%;
	height: 280px;
	background: #ECE0D6 center/cover no-repeat;   /* placeholder khi chưa có ảnh */
	margin-bottom: 18px;
}
.celleva-tl-pillar__title {
	font-family: var(--font-head);
	font-weight: 600;             /* SemiBold */
	font-size: 20px;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--cl-text);
	margin: 0 0 10px;
	padding-inline: 22px;
}
.celleva-tl-pillar__desc {
	font-size: 18px;
	font-weight: 600;             /* SemiBold */
	line-height: 1.6;
	color: var(--cl-text-soft);
	margin: 0;
	padding-inline: 22px;
}

/* =========================================================
 * SECTION 5 – OUR MANIFESTO
 * ========================================================= */
.celleva-tl-manifesto {
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 550px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-block: 40px;
}
.celleva-tl-manifesto__inner {
	position: relative;
	max-width: 600px;
	margin-left: auto;       /* cả khối nằm bên phải */
	margin-right: 0;
	text-align: center;      /* nhưng chữ canh giữa trong khối */
}
.celleva-tl-manifesto .celleva-tl-heading { margin-bottom: 24px; }
.celleva-tl-manifesto__desc {
	color: var(--cl-text);
	font-size: 20px;
	font-weight: 600;             /* SemiBold */
	line-height: 1.9;
}
.celleva-tl-manifesto__desc p { margin: 0 0 14px; }
.celleva-tl-manifesto__sign {
	font-family: var(--font-head);   /* Montserrat */
	font-weight: 700;                /* Bold */
	font-size: 20px;
	color: var(--cl-text);           /* màu đen */
	margin: 18px 0 0;
}

/* =====================================================================
 *  RESPONSIVE
 * ===================================================================== */
/* Dưới 1740px (5×330 + gap không còn vừa) → cho ảnh/card co theo cột. */
@media (max-width: 1740px) {
	.celleva-tl-pillars__grid { grid-template-columns: repeat(5, minmax(0, 330px)); }
	.celleva-tl-pillar { width: 100%; }
	.celleva-tl-pillar__img { width: 100%; }
}
@media (max-width: 1024px) {
	.celleva-tl-belief__grid { grid-template-columns: repeat(3, 1fr); row-gap: 36px; }
	.celleva-tl-pillars__grid { grid-template-columns: repeat(3, minmax(0, 330px)); row-gap: 32px; }
}
@media (max-width: 680px) {
	.celleva-tl-belief__grid { grid-template-columns: repeat(2, 1fr); }
	.celleva-tl-pillars__grid { grid-template-columns: repeat(2, minmax(0, 330px)); }
	.celleva-tl-hero { padding-block: 90px; }
	.celleva-tl-hero::before { background: linear-gradient(180deg, rgba(248,241,234,.55) 0%, rgba(248,241,234,.95) 70%); }
}
@media (max-width: 420px) {
	.celleva-tl-belief__grid { grid-template-columns: 1fr; }
	.celleva-tl-pillars__grid { grid-template-columns: minmax(0, 330px); }
	.celleva-tl-pillar { min-height: 0; }
}
