/* =========================================================
   Thủy Tiên Việt Nam — Custom Theme CSS
   ========================================================= */

/* ---------------------------------------------------------
   RESET / BASE
   --------------------------------------------------------- */
*,
*::before,
*::after {
	box-sizing: border-box;
}

body {
	font-family: 'Inter', sans-serif;
	margin: 0;
	padding: 0;
	color: #1e293b;
	background-color: #ffffff;
}

/* ---------------------------------------------------------
   HEADER (OVERLAY & TRANSPARENT BY DEFAULT)
   --------------------------------------------------------- */
.wp-site-blocks > header {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 10050;
	background: transparent;
	transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
	padding: 15px 0;
}

/* Sticky Header on scroll */
.wp-site-blocks > header.is-scrolled {
	position: fixed;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	box-shadow: 0 4px 30px rgba(15, 23, 42, 0.06);
	padding: 10px 0;
	border-bottom: 1px solid rgba(226, 232, 240, 0.8);
}

/* Trang kết quả tìm kiếm (?s=…): chừa đệm dưới header absolute (template index.html) */
body.search .wp-site-blocks > main,
body.search-results .wp-site-blocks > main {
	padding-top: clamp(4.25rem, 3rem + 3vw, 5.75rem) !important;
}

.ttvn-header-container {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 24px;
}

.ttvn-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

@media (min-width: 1025px) {
	.ttvn-header__inner {
		display: grid;
		grid-template-columns: auto 1fr auto;
		align-items: center;
		justify-content: initial;
		column-gap: clamp(0.75rem, 1.5vw, 1.25rem);
	}
	.ttvn-header__brand {
		justify-self: start;
	}
	.ttvn-header__nav {
		justify-self: center;
	}
	.ttvn-header__cta {
		justify-self: end;
	}
}

/* Brand area */
.ttvn-header__brand {
	display: flex;
	align-items: center;
	gap: 12px;
	text-decoration: none;
	color: #ffffff;
	transition: color 0.3s ease;
}

.wp-site-blocks > header.is-scrolled .ttvn-header__brand {
	color: #0369a1; /* Primary Blue */
}

.ttvn-header__logo-img {
	display: block;
	height: 56px;
	width: auto;
	max-width: 200px;
	object-fit: contain;
	object-position: left center;
}

@media (max-width: 768px) {
	.ttvn-header__logo-img {
		height: 44px;
		max-width: 160px;
	}
}

.ttvn-footer__logo-img {
	display: block;
	height: 72px;
	width: auto;
	max-width: 240px;
	object-fit: contain;
	margin-bottom: 1rem;
}

.wp-site-blocks > header.is-scrolled .ttvn-header__tagline {
	color: #64748b; /* Muted Slate */
	opacity: 1;
}

/* Navigation Links */
.ttvn-header__nav {
	display: flex;
	align-items: center;
}

.ttvn-header__nav-list {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: clamp(1.75rem, 3.5vw, 3.25rem);
}

.ttvn-header__nav-link {
	text-decoration: none;
	color: rgba(255, 255, 255, 0.95);
	font-size: 0.9375rem;
	font-weight: 500;
	padding: 6px 0;
	position: relative;
	transition: color 0.25s ease;
}

.ttvn-header__nav-link:hover,
.ttvn-header__nav-link.active {
	color: #ffffff;
}

.wp-site-blocks > header.is-scrolled .ttvn-header__nav-link {
	color: #334155; /* Slate-700 */
}

.wp-site-blocks > header.is-scrolled .ttvn-header__nav-link:hover,
.wp-site-blocks > header.is-scrolled .ttvn-header__nav-link.active {
	color: #0284c7; /* Primary Blue */
}

/* Nav Link Underline effect */
.ttvn-header__nav-link::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 2px;
	background-color: #ffffff;
	transform: scaleX(0);
	transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
	transform-origin: right;
}

.ttvn-header__nav-link:hover::after,
.ttvn-header__nav-link.active::after {
	transform: scaleX(1);
	transform-origin: left;
}

.wp-site-blocks > header.is-scrolled .ttvn-header__nav-link::after {
	background-color: #0284c7;
}

/* Dropdown Submenu */
.ttvn-header__nav-item {
	position: relative;
}

.ttvn-header__nav-item.has-dropdown .dropdown-arrow {
	font-size: 0.65rem;
	margin-left: 4px;
	display: inline-block;
	transition: transform 0.25s ease;
}

.ttvn-header__nav-item.has-dropdown:hover .dropdown-arrow {
	transform: rotate(180deg);
}

.ttvn-header__submenu {
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%) translateY(15px);
	background: #ffffff;
	border-radius: 8px;
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);
	padding: 10px 0;
	min-width: 200px;
	list-style: none;
	margin: 0;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	border: 1px solid rgba(226, 232, 240, 0.8);
}

.ttvn-header__nav-item.has-dropdown:hover .ttvn-header__submenu {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(4px);
}

.ttvn-header__submenu a {
	display: block;
	padding: 10px 20px;
	color: #334155;
	text-decoration: none;
	font-size: 0.875rem;
	font-weight: 500;
	transition: all 0.2s ease;
}

.ttvn-header__submenu a:hover {
	background-color: #f1f5f9;
	color: #0284c7;
}

/* Header: Zalo + hotline (khối CTA) */
.ttvn-header__cta {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: flex-end;
	flex-wrap: wrap;
	gap: 10px;
	flex-shrink: 0;
}

.ttvn-header__zalo-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 16px;
	background-color: #ffffff;
	border: 2px solid #0180c7;
	border-radius: 8px;
	color: #0180c7;
	text-decoration: none;
	font-size: 0.875rem;
	font-weight: 600;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
	white-space: nowrap;
}

.ttvn-header__zalo-btn:hover {
	background-color: #e8f6fc;
	border-color: #016a9e;
	color: #016a9e;
}

.ttvn-header__zalo-btn svg {
	flex-shrink: 0;
}

/* Phone CTA Button in header */
.ttvn-header__phone-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 20px;
	border: 1px solid rgba(255, 255, 255, 0.4);
	border-radius: 99px;
	color: #ffffff;
	text-decoration: none;
	font-size: 0.875rem;
	font-weight: 600;
	transition: all 0.25s ease;
}

.ttvn-header__phone-btn:hover {
	background: #ffffff;
	color: #0369a1;
	border-color: #ffffff;
	box-shadow: 0 4px 12px rgba(255, 255, 255, 0.2);
}

.wp-site-blocks > header.is-scrolled .ttvn-header__phone-btn {
	border-color: rgba(3, 105, 161, 0.4);
	color: #0369a1;
}

.wp-site-blocks > header.is-scrolled .ttvn-header__phone-btn:hover {
	background: #0369a1;
	color: #ffffff;
	border-color: #0369a1;
	box-shadow: 0 4px 12px rgba(3, 105, 161, 0.15);
}

/* Mobile Toggle Hamburger */
.ttvn-header__toggle {
	display: none;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 5px;
	width: 44px;
	height: 44px;
	background: transparent;
	border: none;
	border-radius: 10px;
	cursor: pointer;
	padding: 0;
	z-index: 10060;
	-webkit-tap-highlight-color: transparent;
}

.ttvn-header__toggle:focus-visible {
	outline: 2px solid #0068ff;
	outline-offset: 2px;
}

.ttvn-header__toggle .toggle-line {
	width: 22px;
	height: 2px;
	border-radius: 2px;
	background-color: #1e293b;
	transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.25s ease;
	transform-origin: center;
}

.ttvn-header__toggle.is-open .toggle-line:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.ttvn-header__toggle.is-open .toggle-line:nth-child(2) {
	opacity: 0;
	transform: scaleX(0);
}

.ttvn-header__toggle.is-open .toggle-line:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

.ttvn-header__nav-backdrop {
	position: fixed;
	inset: 0;
	z-index: 10040;
	background: rgba(15, 23, 42, 0.48);
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.28s ease, visibility 0.28s ease;
}

.ttvn-header__nav-backdrop.is-visible {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

html.ttvn-nav-open {
	overflow: hidden;
	touch-action: none;
}

/* ---------------------------------------------------------
   HERO BANNER
   --------------------------------------------------------- */
.ttvn-hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	overflow: hidden;
	padding-top: 140px;
	padding-bottom: 120px;
	background-color: #0c4a6e;
}

.ttvn-hero__bg-wrap {
	position: absolute;
	inset: 0;
	z-index: 1;
}

.ttvn-hero__bg-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}

.ttvn-hero__bg-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		105deg,
		rgba(12, 74, 110, 0.6) 0%,
		rgba(12, 74, 110, 0.45) 40%,
		rgba(3, 105, 161, 0.15) 100%
	);
}

.ttvn-hero__container {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 24px;
}

.ttvn-hero__content-box {
	max-width: 680px;
	color: #ffffff;
	animation: heroContentFadeIn 0.8s cubic-bezier(0.4, 0, 0.2, 1) both;
}

/* Badge in Hero */
.ttvn-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: 99px;
	padding: 6px 16px;
	font-size: 0.8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #ffffff;
	margin-bottom: 24px;
}

/* H1 Title */
.ttvn-hero__title {
	font-family: 'Montserrat', sans-serif;
	font-size: clamp(2.5rem, 5vw, 4.25rem);
	font-weight: 800;
	line-height: 1.15;
	margin: 0 0 16px 0;
	text-shadow: 0 4px 20px rgba(12, 74, 110, 0.3);
}

.ttvn-hero__title .ttvn-hero__title-line {
	display: block;
}

.ttvn-hero__title .ttvn-hero__title-line--sub {
	font-size: clamp(1.35rem, 3.4vw, 2.35rem);
	font-weight: 600;
	margin-top: 0.35em;
	line-height: 1.25;
	letter-spacing: 0.02em;
	color: rgba(255, 255, 255, 0.96);
	text-shadow: 0 2px 14px rgba(12, 74, 110, 0.35);
}

/* Desktop: một dòng — Thủy Tiên Việt Nam — Đồng hành mọi hành trình */
@media (min-width: 1024px) {
	.ttvn-hero__title {
		white-space: nowrap;
		font-size: clamp(2rem, 3.5vw, 3.35rem);
	}
	.ttvn-hero__title .ttvn-hero__title-line {
		display: inline;
	}
	.ttvn-hero__title .ttvn-hero__title-line--sub::before {
		content: ' — ';
		white-space: normal;
	}
	.ttvn-hero__title .ttvn-hero__title-line--sub {
		display: inline;
		font-size: inherit;
		font-weight: 800;
		margin-top: 0;
		line-height: inherit;
		letter-spacing: inherit;
		color: #ffffff;
		text-shadow: 0 4px 20px rgba(12, 74, 110, 0.3);
	}
}

/* Slogan */
.ttvn-hero__slogan {
	font-size: clamp(1.1rem, 2.2vw, 1.45rem);
	font-weight: 400;
	color: rgba(255, 255, 255, 0.95);
	margin: 0 0 32px 0;
	line-height: 1.5;
}

/* Checklist services */
.ttvn-hero__checklist {
	list-style: none;
	padding: 0;
	margin: 0 0 40px 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.ttvn-hero__checklist li {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 1.05rem;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.9);
}

.ttvn-hero__checklist .check-icon {
	color: #38bdf8; /* Sky blue tick */
	font-weight: bold;
	font-size: 1.2rem;
}

/* CTA buttons inside Hero */
.ttvn-hero__ctas {
	display: flex;
	align-items: center;
	gap: 16px;
}

.ttvn-hero__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 14px 28px;
	border-radius: 99px;
	font-size: 0.9375rem;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Zalo button - Navy Blue */
.ttvn-hero__btn--zalo {
	background: #0d2a4a;
	color: #ffffff;
	box-shadow: 0 8px 24px rgba(13, 42, 74, 0.35);
}

.ttvn-hero__btn--zalo:hover {
	background: #163f6a;
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(13, 42, 74, 0.45);
}

/* Phone button - White */
.ttvn-hero__btn--phone {
	background: #ffffff;
	color: #1e293b;
	box-shadow: 0 8px 24px rgba(255, 255, 255, 0.15);
}

.ttvn-hero__btn--phone:hover {
	background: #f8fafc;
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(255, 255, 255, 0.2);
}

/* Wave Curve Transition */
.ttvn-hero__curve {
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 100%;
	line-height: 0;
	z-index: 3;
}

.ttvn-hero__curve svg {
	display: block;
	width: 100%;
	height: 120px;
}

/* Animations */
@keyframes heroContentFadeIn {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ---------------------------------------------------------
   SERVICE CARDS
   --------------------------------------------------------- */
.ttvn-service-card {
	border-left: 4px solid var(--wp--preset--color--accent) !important;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06), 0 2px 8px rgba(15, 23, 42, 0.04);
}

.ttvn-service-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 28px rgba(3, 105, 161, 0.14);
}

.ttvn-service-card__icon {
	font-size: 2rem;
	line-height: 1;
	margin-bottom: 0.75rem;
	display: block;
}

/* ---------------------------------------------------------
   WHY US CARDS
   --------------------------------------------------------- */
.ttvn-value-card {
	background: #fff;
	border-top: 3px solid var(--wp--preset--color--accent);
	border-radius: 8px;
	padding: 1.5rem !important;
	box-shadow: 0 1px 4px rgba(15, 23, 42, 0.07);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.ttvn-value-card:hover {
	box-shadow: 0 6px 20px rgba(3, 105, 161, 0.12);
	transform: translateY(-3px);
}

/* ---------------------------------------------------------
   NEWS / POSTS SECTION
   --------------------------------------------------------- */
.ttvn-news-section .wp-block-latest-posts li {
	background: #fff;
	border-radius: 8px;
	padding: 1.25rem;
	box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
	transition: box-shadow 0.2s ease;
}

.ttvn-news-section .wp-block-latest-posts li:hover {
	box-shadow: 0 4px 16px rgba(3, 105, 161, 0.1);
}

/* ---------------------------------------------------------
   FOOTER LINKS
   --------------------------------------------------------- */
footer .wp-block-group a {
	color: #bae6fd;
	text-decoration: none;
	transition: color 0.15s ease;
}

footer .wp-block-group a:hover {
	color: #ffffff;
	text-decoration: underline;
}

/* =========================================================
   WHY CHOOSE US — Premium Cards
   ========================================================= */
.ttvn-why-section {
	background: #f0f9ff;
	padding: 80px 30px;
}

.ttvn-why-container {
	max-width: 1320px;
	margin: 0 auto;
}

.ttvn-why__header {
	text-align: center;
	max-width: 640px;
	margin: 0 auto 56px;
}

.ttvn-why__badge {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	color: #0068ff;
	background-color: #e0eeff;
	padding: 6px 14px;
	border-radius: 99px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 14px;
	font-family: 'Inter', sans-serif;
}

.ttvn-why__title {
	font-family: 'Montserrat', sans-serif;
	font-size: clamp(1.75rem, 2.5vw, 2.25rem);
	font-weight: 800;
	color: #072448;
	margin: 0 0 14px;
	line-height: 1.25;
}

.ttvn-why__desc {
	font-size: 1rem;
	color: #64748b;
	margin: 0;
	line-height: 1.65;
}

.ttvn-why__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 28px;
	width: 100%;
}

@media (max-width: 1024px) {
	.ttvn-why__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 22px;
	}
}

@media (max-width: 768px) {
	.ttvn-why-section {
		box-sizing: border-box;
		width: 100%;
		overflow-x: clip;
		padding: 36px 18px max(72px, calc(env(safe-area-inset-bottom, 0px) + 56px));
	}

	.ttvn-why-container {
		width: 100%;
		max-width: 100%;
		margin-inline: auto;
		box-sizing: border-box;
	}

	.ttvn-why__header {
		margin-bottom: 24px;
		margin-inline: auto;
	}

	.ttvn-why__title {
		font-size: clamp(1.35rem, 5vw, 1.85rem);
	}

	.ttvn-why__grid {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) !important;
		gap: 16px;
		margin-inline: auto;
		max-width: 100%;
		justify-items: stretch;
	}

	.ttvn-why-card {
		padding: 24px 20px;
		min-width: 0;
		width: 100%;
		max-width: 100%;
		margin-inline: auto;
		box-sizing: border-box;
	}

	.ttvn-why-card__desc {
		max-width: 100%;
		text-align: center;
	}
}

.ttvn-why__grid > br,
.ttvn-why__grid > p,
.ttvn-products-grid > :not(.ttvn-product-card),
.ttvn-flights-list > :not(.ttvn-product-card),
.ttvn-products-grid > br,
.ttvn-products-grid > p,
.ttvn-flights-list > br,
.ttvn-flights-list > p,
.ttvn-news-split-container > br,
.ttvn-news-split-container > p,
.wp-block-latest-posts > br,
.wp-block-latest-posts > p {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
	height: 0 !important;
	overflow: hidden !important;
}

/* ========== Đơn giản: 4 card cao bằng nhau ========== */
.ttvn-products-grid {
	align-items: stretch !important;
}

/* wpautop hay chèn <p></p> trước card đầu — ẩn hẳn */
.ttvn-products-grid > p,
.ttvn-product-card > p {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
	height: 0 !important;
	line-height: 0 !important;
	overflow: hidden !important;
}

.ttvn-product-card {
	display: flex !important;
	flex-direction: column !important;
	height: 100% !important;
	overflow: hidden !important;
	position: relative !important;
}

.ttvn-product-card__media {
	position: relative !important;
	width: 100% !important;
	height: 200px !important;
	min-height: 200px !important;
	max-height: 200px !important;
	overflow: hidden !important;
	background: #e8f4fd !important;
	flex-shrink: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
}

.ttvn-product-card__media img,
.ttvn-product-card__media .ttvn-product-card__img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	object-position: center !important;
	display: block !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	max-width: none !important;
	max-height: none !important;
	position: static !important;
}

.ttvn-product-card__content {
	flex: 1 1 auto !important;
	display: flex !important;
	flex-direction: column !important;
}

.ttvn-product-card__title {
	display: -webkit-box !important;
	-webkit-line-clamp: 2 !important;
	-webkit-box-orient: vertical !important;
	overflow: hidden !important;
	min-height: 2.9em !important;
}

.ttvn-product-card__footer {
	margin-top: auto !important;
}

.ttvn-why-card {
	background: #ffffff;
	border-radius: 18px;
	padding: 36px 28px;
	text-align: center;
	box-shadow: 0 2px 12px rgba(15, 23, 42, 0.06);
	border: 1px solid rgba(226, 232, 240, 0.7);
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.ttvn-why-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 16px 40px rgba(0, 104, 255, 0.1);
	border-color: rgba(0, 104, 255, 0.2);
}

.ttvn-why-card__icon-wrap {
	width: 64px;
	height: 64px;
	background: linear-gradient(135deg, #e0eeff 0%, #bfdbfe 100%);
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 20px;
	color: #0068ff;
	transition: all 0.3s ease;
}

.ttvn-why-card:hover .ttvn-why-card__icon-wrap {
	background: linear-gradient(135deg, #0068ff 0%, #0050cc 100%);
	color: #ffffff;
}

.ttvn-why-card__title {
	font-family: 'Montserrat', sans-serif;
	font-size: 1.0625rem;
	font-weight: 700;
	color: #072448;
	margin: 0 0 12px;
}

.ttvn-why-card__desc {
	font-size: 0.9rem;
	color: #64748b;
	line-height: 1.65;
	margin: 0;
}

/* =========================================================
   PRODUCT CARDS — View Button + Price Old
   ========================================================= */
.price-old {
	font-size: 0.78rem !important;
	color: #94a3b8 !important;
	text-decoration: line-through !important;
	font-weight: 500 !important;
	display: block !important;
}

.ttvn-product-card__view-btn {
	margin-top: 14px;
	display: block;
	text-align: center;
	padding: 10px 16px;
	background: #f0f7ff;
	color: #0068ff;
	border-radius: 10px;
	font-size: 0.85rem;
	font-weight: 600;
	transition: all 0.25s ease;
	font-family: 'Inter', sans-serif;
}

.ttvn-product-card:hover .ttvn-product-card__view-btn {
	background: #0068ff;
	color: #ffffff;
}

html, body {
	overflow-x: hidden !important;
}

.ttvn-home-products-wrapper {
	width: 100vw !important;
	max-width: 100vw !important;
	position: relative !important;
	left: 50% !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	padding: 80px 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
	font-family: 'Inter', sans-serif !important;
	box-sizing: border-box !important;
	background-image: url('../images/tour-bg-clouds.png') !important;
	background-size: cover !important;
	background-position: center center !important;
	background-repeat: no-repeat !important;
	border-radius: 0 !important;
	border-left: none !important;
	border-right: none !important;
	border-top: 1px solid rgba(226, 232, 240, 0.8) !important;
	border-bottom: 1px solid rgba(226, 232, 240, 0.8) !important;
	box-shadow: none !important;
	overflow: hidden !important;
}

@media (max-width: 768px) {
	/* Mobile / tablet hẹp: gap = 0, padding dọc gọn */
	.ttvn-home-products-wrapper {
		padding: 28px 0 !important;
		gap: 0 !important;
	}

	.ttvn-products-section {
		padding: 22px 18px !important;
	}

	.ttvn-products-section__header {
		flex-direction: column !important;
		align-items: center !important;
		text-align: center !important;
		gap: 12px !important;
		margin-bottom: 14px !important;
	}

	.ttvn-products-section__header-left {
		align-items: center !important;
		width: 100% !important;
	}

	.ttvn-products-section__title {
		text-align: center !important;
	}

	.ttvn-products-section__header-right {
		width: 100% !important;
	}

	.ttvn-products-section__all-link {
		width: 100% !important;
		justify-content: center !important;
	}

	.ttvn-products-grid {
		grid-template-columns: 1fr !important;
		gap: 20px !important;
	}
}

.ttvn-products-section {
	max-width: 1320px !important;
	width: 100% !important;
	padding: 50px 24px !important;
	margin: 0 auto !important;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	box-sizing: border-box !important;
	position: relative !important;
}

.ttvn-products-section--tour {
	padding-top: 0 !important;
}

.ttvn-products-section--combo {
}

.ttvn-products-section--ve-may-bay,
.ttvn-products-section--ticket {
	padding-bottom: 0 !important;
}

.ttvn-products-section__empty {
	grid-column: 1 / -1;
	text-align: center;
	padding: 2rem 1rem;
	color: #64748b;
	font-size: 0.95rem;
}

.ttvn-product-card__meta .meta-icon--svg {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #0369a1;
	flex-shrink: 0;
}

.ttvn-product-card__meta .meta-item {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}

.ttvn-product-card__meta .meta-text {
	line-height: 1.2;
}

.ttvn-product-card__footer .star--svg {
	display: inline-flex;
	vertical-align: middle;
	color: #eab308;
}

/* Alternating section background - kept for compatibility but overridden with cloud bg */
.ttvn-products-section.section-alt-bg {
	background: transparent !important;
}

/* =========================================================
   NEWS SECTION — wp-block-latest-posts Override
   ========================================================= */
.ttvn-news-section {
	background: #f8fafc;
}

.ttvn-news-section .wp-block-latest-posts {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 28px !important;
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

.ttvn-news-section .wp-block-latest-posts li {
	background: #ffffff !important;
	border-radius: 18px !important;
	overflow: hidden !important;
	box-shadow: 0 2px 12px rgba(15, 23, 42, 0.06) !important;
	border: 1px solid rgba(226, 232, 240, 0.7) !important;
	padding: 0 !important;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
	display: flex !important;
	flex-direction: column !important;
	width: 100% !important;
	max-width: 100% !important;
}

.ttvn-news-section .wp-block-latest-posts li:hover {
	transform: translateY(-5px) !important;
	box-shadow: 0 16px 40px rgba(7, 36, 72, 0.09) !important;
	border-color: rgba(0, 104, 255, 0.15) !important;
}

.ttvn-news-section .wp-block-latest-posts__featured-image {
	overflow: hidden !important;
	border-radius: 0 !important;
}

.ttvn-news-section .wp-block-latest-posts__featured-image img {
	width: 100% !important;
	aspect-ratio: 16 / 9 !important;
	object-fit: cover !important;
	transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1) !important;
	display: block !important;
}

.ttvn-news-section .wp-block-latest-posts li:hover .wp-block-latest-posts__featured-image img {
	transform: scale(1.05) !important;
}

.ttvn-news-section .wp-block-latest-posts li > a {
	display: block !important;
	padding: 18px 20px 8px !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	color: #072448 !important;
	text-decoration: none !important;
	line-height: 1.45 !important;
}

.ttvn-news-section .wp-block-latest-posts li > a:hover {
	color: #0068ff !important;
}

.ttvn-news-section .wp-block-latest-posts__post-excerpt {
	padding: 0 20px 8px !important;
	font-size: 0.875rem !important;
	color: #64748b !important;
	line-height: 1.6 !important;
}

.ttvn-news-section .wp-block-latest-posts__post-date {
	padding: 0 20px 20px !important;
	font-size: 0.8rem !important;
	color: #94a3b8 !important;
	margin-top: auto !important;
}

/* ---------------------------------------------------------
   RESPONSIVE DESIGN
   --------------------------------------------------------- */
@media (max-width: 1024px) {
	.ttvn-header__inner {
		position: relative;
	}

	.ttvn-header__nav {
		display: flex;
		flex-direction: column;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		width: 100%;
		transform: translateY(-6px);
		max-height: 0;
		margin: 0;
		padding: 0 20px;
		overflow: hidden;
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		background: #ffffff;
		border-top: 1px solid #e2e8f0;
		border-radius: 0 0 18px 18px;
		box-shadow: 0 24px 48px rgba(15, 23, 42, 0.12);
		z-index: 10055;
		transition: max-height 0.38s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.28s ease,
			visibility 0.28s ease, transform 0.32s cubic-bezier(0.4, 0, 0.2, 1), padding 0.28s ease;
	}

	.ttvn-header__cta {
		display: none; /* Hide header cta */
	}

	.ttvn-header__toggle {
		display: flex; /* Show hamburger toggle */
	}

	.ttvn-header__nav.mobile-active {
		max-height: min(78vh, 560px);
		padding-top: 16px;
		padding-bottom: 20px;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: translateY(0);
	}

	.ttvn-header__nav.mobile-active .ttvn-header__nav-list {
		flex-direction: column;
		width: 100%;
		gap: 4px;
	}

	.ttvn-header__nav.mobile-active .ttvn-header__nav-item {
		border-bottom: 1px solid #f1f5f9;
	}

	.ttvn-header__nav.mobile-active .ttvn-header__nav-item:last-child {
		border-bottom: none;
	}

	.ttvn-header__nav.mobile-active .ttvn-header__nav-link {
		color: #0f172a !important;
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 14px 4px;
		font-size: 1.0625rem;
		font-weight: 600;
	}

	.ttvn-header__nav.mobile-active .ttvn-header__submenu {
		position: static;
		transform: none !important;
		opacity: 1;
		visibility: visible;
		box-shadow: none;
		border: none;
		padding: 6px 0 12px 12px;
		margin: 0 0 8px 0;
		background: #f8fafc;
		border-radius: 10px;
	}

	.ttvn-header__nav.mobile-active .ttvn-header__submenu a {
		padding: 10px 12px;
		font-size: 0.95rem;
		border-radius: 8px;
	}

	.ttvn-header__nav.mobile-active .ttvn-header__nav-link::after {
		display: none;
	}
}

@media (max-width: 768px) {
	.ttvn-hero {
		padding-top: 120px;
		/* Không chừa chỗ strip — đã ẩn strip trên mobile */
		padding-bottom: 80px !important;
	}

	/* Ẩn quick-nav (strip + inner) trên mobile */
	.ttvn-hero__nav-strip {
		display: none !important;
	}

	.ttvn-hero__ctas {
		flex-direction: column;
		width: 100%;
		align-items: stretch;
		gap: 12px;
	}

	.ttvn-hero__btn {
		width: 100%;
	}

	.ttvn-hero__curve svg {
		height: 60px;
	}
}

/* =========================================================
   COMBO & HOTEL SECTIONS — 3 Columns + Checklists
   ========================================================= */
.ttvn-products-grid--3cols {
	grid-template-columns: repeat(3, 1fr) !important;
}

.combo-benefits-list {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 0 20px 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 8px !important;
}

.combo-benefits-list li {
	font-size: 0.85rem !important;
	color: #475569 !important;
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	font-weight: 500 !important;
}

.combo-benefits-list li .benefit-icon {
	color: #10b981 !important; /* Vivid Emerald Green Tick */
	font-weight: 700 !important;
	font-size: 0.9rem !important;
}

@media (max-width: 900px) {
	.ttvn-products-grid--3cols {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

@media (max-width: 600px) {
	.ttvn-products-grid--3cols {
		grid-template-columns: 1fr !important;
	}
}

/* =========================================================
   FLIGHT TICKETS SECTION — Premium Boarding Pass Rows
   ========================================================= */
.ttvn-flights-list {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
	width: 100% !important;
	max-width: 1320px !important;
	margin: 0 auto !important;
}

.ttvn-flight-ticket-row {
	background: #ffffff !important;
	border-radius: 18px !important;
	border: 1px solid rgba(226, 232, 240, 0.8) !important;
	box-shadow: 0 4px 12px rgba(15, 23, 42, 0.03) !important;
	padding: 24px 36px !important;
	display: grid !important;
	grid-template-columns: 1.2fr 2fr 1.2fr !important;
	align-items: center !important;
	gap: 32px !important;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
	position: relative !important;
	text-decoration: none !important;
}

.ttvn-flight-ticket-row:hover {
	transform: translateY(-4px) !important;
	box-shadow: 0 16px 36px rgba(0, 104, 255, 0.08) !important;
	border-color: rgba(0, 104, 255, 0.25) !important;
}

/* Flight Left - Airline brand */
.ttvn-flight__airline {
	display: flex !important;
	align-items: center !important;
	gap: 18px !important;
}

.airline-logo-badge {
	width: 46px !important;
	height: 46px !important;
	border-radius: 12px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-weight: 800 !important;
	font-size: 0.9rem !important;
	color: #ffffff !important;
	letter-spacing: 0.05em !important;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.06) !important;
	flex-shrink: 0 !important;
	font-family: 'Montserrat', sans-serif !important;
}

.airline-logo-badge.vna {
	background: linear-gradient(135deg, #072448 0%, #1e4d75 100%) !important;
	color: #e2b93c !important; /* Gold */
}

.airline-logo-badge.vj {
	background: linear-gradient(135deg, #de1e22 0%, #f74548 100%) !important;
	color: #fff200 !important; /* Yellow */
}

.airline-logo-badge.qh {
	background: linear-gradient(135deg, #005a3c 0%, #008f5d 100%) !important;
	color: #ffffff !important;
}

.airline-logo-badge.bl {
	background: linear-gradient(135deg, #f47321 0%, #ff8c42 100%) !important;
	color: #072448 !important;
}

.airline-meta {
	display: flex !important;
	flex-direction: column !important;
	gap: 3px !important;
}

.airline-name {
	font-size: 1rem !important;
	font-weight: 750 !important;
	color: #072448 !important;
	line-height: 1.2 !important;
}

.flight-type {
	font-size: 0.8rem !important;
	color: #64748b !important;
	font-weight: 600 !important;
}

/* Flight Center - Boarding Pass Route */
.ttvn-flight__route {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 32px !important;
}

.route-airport {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	gap: 3px !important;
	min-width: 80px !important;
}

.airport-code {
	font-size: 1.55rem !important;
	font-weight: 800 !important;
	color: #072448 !important;
	font-family: 'Montserrat', sans-serif !important;
	letter-spacing: -0.02em !important;
	line-height: 1.1 !important;
}

.airport-name {
	font-size: 0.78rem !important;
	color: #64748b !important;
	font-weight: 600 !important;
}

.route-connector {
	position: relative !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	flex-grow: 1 !important;
	max-width: 160px !important;
}

.connector-line {
	width: 100% !important;
	height: 2px !important;
	background: repeating-linear-gradient(90deg, #cbd5e1, #cbd5e1 5px, transparent 5px, transparent 10px) !important;
}

.connector-icon {
	position: absolute !important;
	color: #0068ff !important;
	font-size: 1.15rem !important;
	background: #ffffff !important;
	padding: 0 10px !important;
}

/* Flight Right - Booking and Pricing */
.ttvn-flight__booking {
	display: flex !important;
	align-items: center !important;
	justify-content: flex-end !important;
	gap: 24px !important;
}

.ttvn-flight__booking .price-box {
	align-items: flex-end !important;
}

.btn-book-ticket {
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
	background: #f0f7ff !important;
	color: #0068ff !important;
	padding: 12px 24px !important;
	border-radius: 12px !important;
	font-size: 0.88rem !important;
	font-weight: 700 !important;
	text-decoration: none !important;
	transition: all 0.25s ease !important;
	white-space: nowrap !important;
}

.ttvn-flight-ticket-row:hover .btn-book-ticket {
	background: #0068ff !important;
	color: #ffffff !important;
	box-shadow: 0 6px 20px rgba(0, 104, 255, 0.2) !important;
}

/* Responsive adjustments for tickets */
@media (max-width: 960px) {
	.ttvn-flight-ticket-row {
		grid-template-columns: 1fr 1fr !important;
		gap: 20px !important;
		padding: 24px !important;
	}
	
	.ttvn-flight__booking {
		grid-column: span 2 !important;
		justify-content: space-between !important;
		border-top: 1px dashed #cbd5e1 !important;
		padding-top: 18px !important;
		margin-top: 6px !important;
	}
}

@media (max-width: 600px) {
	.ttvn-flight-ticket-row {
		display: flex !important;
		flex-direction: column !important;
		align-items: stretch !important;
		gap: 20px !important;
		padding: 20px !important;
	}
	
	.ttvn-flight__route {
		justify-content: space-between !important;
		padding: 12px 0 !important;
		gap: 0 !important;
	}
	
	.route-connector {
		max-width: 90px !important;
	}
	
	.ttvn-flight__booking {
		grid-column: auto !important;
	}
}


/* =========================================================
   HERO FLOATING QUICK NAV STRIP
   ========================================================= */
/* Chừa chỗ strip — chỉ màn ≥769px (mobile ẩn strip) */
@media (min-width: 769px) {
	.ttvn-hero {
		padding-bottom: 220px !important;
	}
}

.ttvn-hero__nav-strip {
	position: absolute !important;
	bottom: 30px !important; /* Floats beautifully overlapping hero curve */
	left: 50% !important;
	transform: translateX(-50%) !important;
	width: calc(100% - 48px) !important;
	max-width: 1200px !important;
	background: #ffffff !important;
	border-radius: 18px !important;
	box-shadow: 0 10px 30px rgba(7, 36, 72, 0.12) !important;
	z-index: 40 !important;
	border: 1px solid rgba(226, 232, 240, 0.8) !important;
	overflow: hidden !important;
}

.ttvn-hero__nav-strip-inner {
	display: grid !important;
	grid-template-columns: repeat(5, 1fr) !important;
	align-items: center !important;
}

.ttvn-hero__nav-item {
	display: flex !important;
	align-items: center !important;
	gap: 16px !important;
	padding: 24px 28px !important;
	text-decoration: none !important;
	transition: all 0.25s ease !important;
	position: relative !important;
}

.ttvn-hero__nav-item:not(:last-child)::after {
	content: "" !important;
	position: absolute !important;
	right: 0 !important;
	top: 25% !important;
	height: 50% !important;
	width: 1px !important;
	background-color: #e2e8f0 !important;
}

.ttvn-hero__nav-item:hover {
	background-color: #f0f7ff !important;
}

.ttvn-hero__nav-item:hover .nav-item-title {
	color: #0068ff !important;
}

.nav-item-icon {
	font-size: 1.8rem !important;
	color: #0068ff !important;
	flex-shrink: 0 !important;
}

.nav-item-meta {
	display: flex !important;
	flex-direction: column !important;
	gap: 3px !important;
}

.nav-item-title {
	font-size: 0.95rem !important;
	font-weight: 700 !important;
	color: #072448 !important;
}

.nav-item-desc {
	font-size: 0.78rem !important;
	color: #64748b !important;
	font-weight: 500 !important;
}

/* Tablet nhỏ: strip 3 cột (chỉ ≥769px — mobile ẩn strip ở block 768px phía trên) */
@media (min-width: 769px) and (max-width: 960px) {
	.ttvn-hero {
		padding-bottom: 280px !important;
	}
	.ttvn-hero__nav-strip {
		bottom: 20px !important;
		left: max(16px, env(safe-area-inset-left, 0px)) !important;
		right: max(16px, env(safe-area-inset-right, 0px)) !important;
		width: auto !important;
		max-width: none !important;
		transform: none !important;
		box-sizing: border-box !important;
	}
	.ttvn-hero__nav-strip-inner {
		grid-template-columns: repeat(3, 1fr) !important;
	}
	.ttvn-hero__nav-item:nth-child(3)::after {
		display: none !important;
	}
}

/* =========================================================
   NEWS SECTION — 2-Column Split Layout & Newsletter Box
   ========================================================= */
.ttvn-news-section-split {
	background: #f8fafc !important;
	padding: 80px 24px !important;
}

.ttvn-news-split-container {
	max-width: 1200px !important;
	margin: 0 auto !important;
	display: grid !important;
	grid-template-columns: 1.4fr 1fr !important;
	gap: 48px !important;
	align-items: flex-start !important;
}

.ttvn-news-split-left {
	display: flex !important;
	flex-direction: column !important;
}

.ttvn-news-split__badge {
	font-size: 0.78rem !important;
	font-weight: 700 !important;
	color: #0068ff !important;
	text-transform: uppercase !important;
	letter-spacing: 0.05em !important;
	margin-bottom: 12px !important;
	font-family: 'Inter', sans-serif !important;
}

.ttvn-news-split__title {
	font-family: 'Montserrat', sans-serif !important;
	font-size: clamp(1.75rem, 2.5vw, 2.1rem) !important;
	font-weight: 800 !important;
	color: #072448 !important;
	margin: 0 0 32px 0 !important;
	line-height: 1.25 !important;
}

.ttvn-news-cards-list {
	display: flex !important;
	flex-direction: column !important;
	gap: 20px !important;
}

.ttvn-news-card-wide {
	background: #ffffff !important;
	border-radius: 18px !important;
	padding: 28px !important;
	box-shadow: 0 4px 14px rgba(15, 23, 42, 0.03) !important;
	border: 1px solid rgba(226, 232, 240, 0.7) !important;
	transition: all 0.3s ease !important;
}

.ttvn-news-card-wide:hover {
	transform: translateY(-2px) !important;
	box-shadow: 0 10px 25px rgba(7, 36, 72, 0.06) !important;
	border-color: rgba(0, 104, 255, 0.15) !important;
}

.news-card-meta {
	margin-bottom: 10px !important;
}

.news-date {
	font-size: 0.8rem !important;
	color: #94a3b8 !important;
	font-weight: 600 !important;
}

.news-card-title {
	font-family: 'Montserrat', sans-serif !important;
	font-size: 1.15rem !important;
	font-weight: 750 !important;
	margin: 0 0 10px 0 !important;
	line-height: 1.4 !important;
}

.news-card-title a {
	color: #072448 !important;
	text-decoration: none !important;
	transition: color 0.2s ease !important;
}

.news-card-title a:hover {
	color: #0068ff !important;
}

.news-card-excerpt {
	font-size: 0.9rem !important;
	color: #64748b !important;
	line-height: 1.6 !important;
	margin: 0 0 16px 0 !important;
}

.news-card-more {
	display: inline-flex !important;
	align-items: center !important;
	gap: 6px !important;
	font-size: 0.85rem !important;
	font-weight: 700 !important;
	color: #0068ff !important;
	text-decoration: none !important;
	transition: gap 0.2s ease !important;
}

.news-card-more:hover {
	gap: 10px !important;
}

/* Right - Premium Newsletter Card with Envelope illustration */
.ttvn-news-split-right {
	height: 100% !important;
}

.ttvn-newsletter-card {
	background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%) !important;
	border-radius: 20px !important;
	padding: 40px 36px !important;
	border: 1px solid rgba(191, 219, 254, 0.6) !important;
	box-shadow: 0 10px 30px rgba(0, 104, 255, 0.04) !important;
	position: relative !important;
	overflow: hidden !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: space-between !important;
	min-height: 380px !important;
}

.newsletter-badge {
	display: inline-block !important;
	background: #0068ff !important;
	color: #ffffff !important;
	font-size: 0.72rem !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	padding: 4px 10px !important;
	border-radius: 99px !important;
	margin-bottom: 16px !important;
	letter-spacing: 0.05em !important;
}

.newsletter-title {
	font-family: 'Montserrat', sans-serif !important;
	font-size: 1.35rem !important;
	font-weight: 800 !important;
	color: #072448 !important;
	margin: 0 0 8px 0 !important;
	letter-spacing: -0.01em !important;
}

.newsletter-subtitle {
	font-size: 0.9375rem !important;
	color: #475569 !important;
	margin: 0 0 28px 0 !important;
	line-height: 1.5 !important;
}

.newsletter-form {
	display: flex !important;
	flex-direction: column !important;
	gap: 12px !important;
	position: relative !important;
	z-index: 10 !important;
}

.newsletter-input {
	width: 100% !important;
	padding: 14px 18px !important;
	border: 1px solid #cbd5e1 !important;
	border-radius: 10px !important;
	background: #ffffff !important;
	font-size: 0.9375rem !important;
	color: #0f172a !important;
	outline: none !important;
	transition: all 0.2s ease !important;
}

.newsletter-input:focus {
	border-color: #0068ff !important;
	box-shadow: 0 0 0 3px rgba(0, 104, 255, 0.12) !important;
}

.newsletter-submit {
	width: 100% !important;
	padding: 14px 18px !important;
	border: none !important;
	border-radius: 10px !important;
	background: #0068ff !important;
	color: #ffffff !important;
	font-size: 0.9375rem !important;
	font-weight: 700 !important;
	cursor: pointer !important;
	transition: all 0.25s ease !important;
	text-align: center !important;
}

.newsletter-submit:hover {
	background: #0056d6 !important;
	box-shadow: 0 4px 14px rgba(0, 104, 255, 0.25) !important;
}

/* Flying envelope illustration */
.newsletter-illustration {
	position: absolute !important;
	right: -20px !important;
	bottom: -20px !important;
	opacity: 0.85 !important;
	pointer-events: none !important;
	z-index: 1 !important;
}

.flying-envelope {
	width: 130px !important;
	height: 90px !important;
	background: #ffffff !important;
	border-radius: 12px !important;
	border: 3px solid #3b82f6 !important;
	position: relative !important;
	transform: rotate(-12deg) !important;
	box-shadow: 0 10px 25px rgba(0, 104, 255, 0.1) !important;
}

.envelope-body {
	position: absolute !important;
	inset: 0 !important;
}

.envelope-body::before {
	content: "" !important;
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	width: 0 !important;
	height: 0 !important;
	border-style: solid !important;
	border-width: 45px 62px 0 62px !important;
	border-color: #93c5fd transparent transparent transparent !important;
}

.envelope-percentage {
	position: absolute !important;
	top: -15px !important;
	right: -15px !important;
	background: #ef4444 !important;
	color: #ffffff !important;
	font-weight: 800 !important;
	font-size: 1rem !important;
	width: 40px !important;
	height: 40px !important;
	border-radius: 50% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	border: 3px solid #ffffff !important;
	box-shadow: 0 4px 10px rgba(239, 68, 68, 0.25) !important;
}

/* Responsive news split */
@media (max-width: 960px) {
	.ttvn-news-split-container {
		grid-template-columns: 1fr !important;
		gap: 36px !important;
	}
	.ttvn-newsletter-card {
		min-height: auto !important;
	}
	.newsletter-illustration {
		display: none !important;
	}
}

/* ---------------------------------------------------------
   CẨM NANG (ttvn_blog) — listing + single
   Tokens: primary #0369a1, primary-dark #0c4a6e, Montserrat display
   --------------------------------------------------------- */

/* Đệm trên vừa đủ dưới header absolute (~5rem); tránh khoảng trắng quá cao */
body.single-ttvn_blog main.ttvn-blog-single {
	padding-top: clamp(4.25rem, 3rem + 3vw, 5.75rem) !important;
	max-width: 1240px;
	margin-left: auto;
	margin-right: auto;
	padding-left: clamp(1rem, 4vw, 1.5rem);
	padding-right: clamp(1rem, 4vw, 1.5rem);
	box-sizing: border-box;
}

body.post-type-archive-ttvn_blog .ttvn-blog-hero--listing,
body.tax-ttvn_blog_loai .ttvn-blog-hero--listing {
	padding-top: clamp(5.75rem, 4.5rem + 5vw, 9rem) !important;
}

@media (min-width: 960px) {
	body.single-ttvn_blog .ttvn-blog-single__columns {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) minmax(278px, 336px);
		gap: clamp(1.5rem, 3vw, 2.75rem);
		align-items: start;
	}

	body.single-ttvn_blog .ttvn-blog-single__columns > .wp-block-column {
		flex-basis: auto !important;
		width: auto !important;
		max-width: none !important;
		margin-left: 0 !important;
	}
}

body.single-ttvn_blog .ttvn-blog-single__column-main .ttvn-blog-prose .wp-block-post-content {
	max-width: min(100%, 42rem);
}

.ttvn-blog-sidebar {
	font-family: Inter, system-ui, sans-serif;
}

.ttvn-blog-sidebar__sticky {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

@media (min-width: 960px) {
	.ttvn-blog-sidebar__sticky {
		position: sticky;
		top: clamp(4.5rem, 5vw, 5.75rem);
	}
}

.ttvn-blog-sidebar__card {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	padding: 1.15rem 1.2rem 1.25rem;
}

.ttvn-blog-sidebar__card--trust {
	background: rgba(3, 105, 161, 0.07);
	border-color: rgba(3, 105, 161, 0.2);
}

.ttvn-blog-sidebar__kicker {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #0369a1;
	margin: 0 0 0.5rem;
}

.ttvn-blog-sidebar__slogan {
	font-family: "Montserrat", Inter, sans-serif;
	font-size: 0.95rem;
	font-weight: 600;
	color: #0f172a;
	line-height: 1.45;
	margin: 0;
}

.ttvn-blog-sidebar__h {
	font-family: "Montserrat", Inter, sans-serif;
	font-size: 1rem;
	font-weight: 700;
	color: #0c4a6e;
	margin: 0 0 0.65rem;
	line-height: 1.25;
}

.ttvn-blog-sidebar__muted {
	font-size: 0.875rem;
	color: #64748b;
	margin: 0 0 1rem;
	line-height: 1.5;
}

.ttvn-blog-sidebar__card--cta {
	background: #ffffff;
	border-color: rgba(3, 105, 161, 0.22);
	box-shadow: 0 8px 28px rgba(3, 105, 161, 0.08);
}

.ttvn-blog-sidebar__actions {
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
}

.ttvn-blog-sidebar__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	box-sizing: border-box;
	padding: 0.68rem 1rem;
	border-radius: 10px;
	font-size: 0.92rem;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.18s ease, transform 0.12s ease, box-shadow 0.18s ease;
}

.ttvn-blog-sidebar__btn--zalo {
	background: #0369a1;
	color: #ffffff !important;
	box-shadow: 0 4px 14px rgba(3, 105, 161, 0.28);
}

.ttvn-blog-sidebar__btn--zalo:hover {
	background: #0c4a6e;
	color: #ffffff !important;
}

/* Thu hút mắt: chấm nhấp nháy + hào quang nút Zalo (tắt khi prefers-reduced-motion) */
@keyframes ttvn-attention-dot-blink {
	0%,
	100% {
		opacity: 1;
		transform: scale(1);
		box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.4);
	}
	50% {
		opacity: 0.3;
		transform: scale(0.88);
		box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.15);
	}
}

@keyframes ttvn-attention-glow {
	0%,
	100% {
		box-shadow: 0 4px 14px rgba(3, 105, 161, 0.32);
	}
	50% {
		box-shadow:
			0 6px 26px rgba(3, 105, 161, 0.5),
			0 0 0 3px rgba(14, 165, 233, 0.22);
	}
}

@media (prefers-reduced-motion: no-preference) {
	.ttvn-blog-sidebar__h--pulse {
		display: flex;
		align-items: center;
		gap: 0.5rem;
		flex-wrap: wrap;
	}

	.ttvn-attention-dot {
		flex-shrink: 0;
		width: 10px;
		height: 10px;
		border-radius: 50%;
		background: #0ea5e9;
		animation: ttvn-attention-dot-blink 1.2s ease-in-out infinite;
	}

	.ttvn-blog-sidebar__btn--zalo.ttvn-attention-glow {
		animation: ttvn-attention-glow 2.4s ease-in-out infinite;
	}

	.ttvn-blog-sidebar__btn--zalo.ttvn-attention-glow:hover {
		animation: none;
	}
}

.ttvn-blog-sidebar__btn--phone {
	background: #072448;
	color: #ffffff !important;
}

.ttvn-blog-sidebar__btn--phone:hover {
	filter: brightness(1.08);
	color: #ffffff !important;
}

.ttvn-blog-sidebar__svc,
.ttvn-blog-sidebar__related {
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 0.9rem;
}

.ttvn-blog-sidebar__svc li,
.ttvn-blog-sidebar__related li {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid #e2e8f0;
}

.ttvn-blog-sidebar__svc li:last-child,
.ttvn-blog-sidebar__related li:last-child {
	border-bottom: none;
}

.ttvn-blog-sidebar__svc a,
.ttvn-blog-sidebar__related a {
	display: block;
	padding: 0.55rem 0;
	color: #0f172a;
	text-decoration: none;
	font-weight: 500;
}

.ttvn-blog-sidebar__svc a:hover,
.ttvn-blog-sidebar__related a:hover {
	color: #0369a1;
}

.ttvn-blog-hero--listing {
	border-bottom: 1px solid #e2e8f0;
}

/* Hero Cẩm nang: căn giữa intro + pill — tránh lệch trái / khoảng trống phải */
body.post-type-archive-ttvn_blog .ttvn-blog-hero--archive .ttvn-blog-hero__intro,
body.tax-ttvn_blog_loai .ttvn-blog-hero--taxonomy .ttvn-blog-hero__intro {
	max-width: 38rem;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}

body.post-type-archive-ttvn_blog .ttvn-blog-hero--archive .ttvn-blog-hero__eyebrow,
body.tax-ttvn_blog_loai .ttvn-blog-hero--taxonomy .ttvn-blog-hero__eyebrow {
	margin-left: auto;
	margin-right: auto;
}

body.tax-ttvn_blog_loai .ttvn-blog-hero__head {
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 1rem;
}

body.tax-ttvn_blog_loai .ttvn-blog-hero__all-link,
body.tax-ttvn_blog_loai .ttvn-blog-hero__all-link.has-text-align-right {
	align-self: center;
	text-align: center;
}

/* Tiêu đề taxonomy: 1 dòng desktop, line-height đủ để không đè nếu xuống dòng (màn hẹp) */
body.tax-ttvn_blog_loai .ttvn-blog-hero--taxonomy .ttvn-blog-hero__intro {
	max-width: min(100%, 56rem);
}

body.tax-ttvn_blog_loai .ttvn-blog-hero--taxonomy .ttvn-blog-hero__intro .wp-block-query-title,
body.tax-ttvn_blog_loai .ttvn-blog-hero--taxonomy .ttvn-blog-hero__intro h1.wp-block-query-title {
	line-height: 1.28 !important;
}

@media (min-width: 480px) {
	body.tax-ttvn_blog_loai .ttvn-blog-hero--taxonomy .ttvn-blog-hero__intro .wp-block-query-title,
	body.tax-ttvn_blog_loai .ttvn-blog-hero--taxonomy .ttvn-blog-hero__intro h1.wp-block-query-title {
		white-space: nowrap;
	}
}

body.post-type-archive-ttvn_blog .ttvn-blog-hero--archive .ttvn-blog-filters,
body.tax-ttvn_blog_loai .ttvn-blog-hero--taxonomy .ttvn-blog-filters {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 0.55rem 0.75rem;
	margin-top: 1.75rem;
}

/* Danh sách: thở dọc + lưới rộng gap */
body.post-type-archive-ttvn_blog .ttvn-blog-listing,
body.tax-ttvn_blog_loai .ttvn-blog-listing {
	padding-top: clamp(2.75rem, 5vw, 3.75rem) !important;
	padding-bottom: clamp(3.25rem, 6vw, 4.75rem) !important;
}

.ttvn-blog-listing .wp-block-query.alignwide {
	width: 100%;
	max-width: 1180px;
	margin-left: auto;
	margin-right: auto;
}

.ttvn-blog-listing ul.wp-block-post-template.is-layout-grid,
.ttvn-blog-listing ul.wp-block-post-template.wp-block-post-template-is-layout-grid,
.ttvn-blog-listing ul.wp-block-post-template {
	gap: clamp(1.35rem, 3vw, 2.25rem) !important;
}

@media (min-width: 1200px) {
	.ttvn-blog-listing ul.wp-block-post-template.is-layout-grid,
	.ttvn-blog-listing ul.wp-block-post-template.wp-block-post-template-is-layout-grid,
	.ttvn-blog-listing ul.wp-block-post-template {
		gap: 2rem !important;
	}
}

.ttvn-blog-card .wp-block-post-title {
	line-height: 1.38;
}

.ttvn-blog-card .wp-block-post-title a {
	line-height: inherit;
}

.ttvn-blog-card .wp-block-post-excerpt__excerpt {
	line-height: 1.65;
}

.ttvn-blog-hero__head {
	width: 100%;
}

.ttvn-blog-hero__intro {
	max-width: 52rem;
}

.ttvn-blog-hero__eyebrow {
	display: inline-block;
	margin: 0 0 0.25rem;
	padding: 0.35rem 0.75rem;
	border-radius: 999px;
	background: rgba(3, 105, 161, 0.1);
	color: #0369a1;
	letter-spacing: 0.08em;
}

.ttvn-blog-hero__all-link {
	flex-shrink: 0;
	margin: 0;
	align-self: flex-end;
}

.ttvn-blog-hero__all-link a {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.9375rem;
	font-weight: 600;
	color: #0369a1;
	text-decoration: none;
	border-bottom: 2px solid transparent;
	transition: color 0.2s ease, border-color 0.2s ease;
}

.ttvn-blog-hero__all-link a:hover {
	color: #0c4a6e;
	border-bottom-color: rgba(3, 105, 161, 0.45);
}

.ttvn-blog-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.75rem;
	align-items: center;
}

.ttvn-blog-filters--spaced {
	margin-top: 1.25rem;
}

.ttvn-blog-hero--listing .ttvn-blog-filters__pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.5rem 1rem;
	border-radius: 999px;
	font-size: 0.875rem;
	font-weight: 600;
	text-decoration: none;
	color: #0f172a;
	background: #ffffff;
	border: 1px solid #cbd5e1;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}

.ttvn-blog-hero--listing .ttvn-blog-filters__pill:hover {
	background: #f8fafc;
	border-color: #0369a1;
	color: #0369a1;
	box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
}

.ttvn-blog-hero--listing .ttvn-blog-filters__pill:active {
	transform: scale(0.98);
}

.ttvn-blog-hero--listing .ttvn-blog-filters__pill.is-active {
	background: #0369a1;
	color: #ffffff;
	border-color: #0369a1;
	box-shadow: 0 4px 14px rgba(3, 105, 161, 0.28);
}

.ttvn-blog-listing {
	min-height: 40vh;
}

.ttvn-blog-listing ul.wp-block-post-template > li,
.ttvn-blog-listing .wp-block-post-template.is-layout-grid > .wp-block-post {
	display: flex;
}

.ttvn-blog-listing ul.wp-block-post-template > li > .ttvn-blog-card,
.ttvn-blog-listing .wp-block-post-template.is-layout-grid > .wp-block-post > .ttvn-blog-card {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	width: 100%;
	min-height: 100%;
}

.ttvn-blog-card {
	overflow: hidden;
	border: 1px solid #e2e8f0;
	box-shadow: 0 4px 20px rgba(15, 23, 42, 0.06);
	transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
}

.ttvn-blog-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 44px rgba(12, 74, 110, 0.12);
	border-color: rgba(3, 105, 161, 0.28);
}

.ttvn-blog-card .wp-block-post-featured-image {
	margin: 0;
}

.ttvn-blog-card .wp-block-post-featured-image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ttvn-blog-card .wp-block-post-featured-image a {
	display: block;
	line-height: 0;
}

/* Overlay dim nằm trong <a>: đảm bảo click luôn kích hoạt link (tránh lớp phủ chặn ở một số trình duyệt/layout) */
.ttvn-blog-card .wp-block-post-featured-image__overlay {
	pointer-events: none;
}

.ttvn-blog-card__body {
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	min-height: 0;
}

.ttvn-blog-card .ttvn-blog-card__terms {
	margin: 0;
}

.ttvn-blog-card .ttvn-blog-card__terms .wp-block-post-terms__separator {
	display: none;
}

.ttvn-blog-card .ttvn-blog-card__terms a {
	display: inline-flex;
	align-items: center;
	padding: 0.28rem 0.65rem;
	border-radius: 6px;
	background: rgba(3, 105, 161, 0.09);
	color: #0369a1 !important;
	font-size: 0.75rem;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.2s ease, color 0.2s ease;
}

.ttvn-blog-card .ttvn-blog-card__terms a:hover {
	background: rgba(3, 105, 161, 0.16);
	color: #0c4a6e !important;
}

.ttvn-blog-card .wp-block-post-title {
	margin: 0;
}

.ttvn-blog-card .wp-block-post-title a {
	text-decoration: none;
	color: inherit;
	transition: color 0.2s ease;
}

.ttvn-blog-card .wp-block-post-title a:hover {
	color: #0369a1;
}

.ttvn-blog-card .wp-block-post-excerpt {
	margin: 0;
	flex-grow: 1;
}

.ttvn-blog-card .wp-block-post-excerpt__excerpt {
	margin: 0;
}

.ttvn-blog-card .wp-block-post-excerpt__more-text,
.ttvn-blog-card .wp-block-post-excerpt__more-link {
	display: none;
}

.ttvn-blog-card__meta {
	margin: 0;
}

.ttvn-blog-card__meta time,
.ttvn-blog-card__meta .wp-block-post-date {
	font-size: 0.8125rem;
}

.ttvn-blog-card__cta {
	margin-top: auto;
}

.ttvn-blog-card__cta .wp-block-read-more {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	box-sizing: border-box;
	padding: 0.65rem 1rem;
	border-radius: 10px;
	font-size: 0.9375rem;
	font-weight: 600;
	text-decoration: none;
	text-align: center;
	background: #0369a1;
	color: #ffffff !important;
	border: none;
	box-shadow: 0 4px 14px rgba(3, 105, 161, 0.25);
	transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}

.ttvn-blog-card__cta .wp-block-read-more:hover {
	background: #0c4a6e;
	color: #ffffff !important;
	box-shadow: 0 6px 18px rgba(12, 74, 110, 0.28);
}

.ttvn-blog-card__cta .wp-block-read-more:active {
	transform: translateY(1px);
}

@media (max-width: 600px) {
	.ttvn-blog-hero__head {
		flex-direction: column;
		align-items: flex-start;
	}

	body.tax-ttvn_blog_loai .ttvn-blog-hero__head {
		align-items: center;
	}

	.ttvn-blog-hero__all-link {
		align-self: flex-start;
	}

	body.tax-ttvn_blog_loai .ttvn-blog-hero__all-link {
		align-self: center;
	}

	.ttvn-blog-hero__all-link.has-text-align-right {
		text-align: left;
	}

	body.tax-ttvn_blog_loai .ttvn-blog-hero__all-link.has-text-align-right {
		text-align: center;
	}
}

.ttvn-blog-prose .wp-block-post-content {
	max-width: 65ch;
}

.ttvn-blog-prose .wp-block-post-content p {
	margin-top: 0;
	margin-bottom: 1.15em;
}

.ttvn-blog-prose .wp-block-post-content h2,
.ttvn-blog-prose .wp-block-post-content h3 {
	font-family: "Montserrat", Inter, system-ui, sans-serif;
	color: #0f172a;
	margin-top: 1.75em;
	margin-bottom: 0.65em;
	line-height: 1.25;
}

.ttvn-blog-related {
	margin-top: 2.75rem;
	padding-top: 2rem;
	border-top: 1px solid #e2e8f0;
}

.ttvn-blog-related__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 1.5rem;
	border-radius: 8px;
	font-size: 0.9375rem;
	font-weight: 600;
	text-decoration: none;
	background: #0369a1;
	color: #ffffff;
	box-shadow: 0 4px 14px rgba(3, 105, 161, 0.28);
	transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}

.ttvn-blog-related__btn:hover {
	background: #0c4a6e;
	color: #ffffff;
}

.ttvn-blog-related__btn:active {
	transform: translateY(1px);
}

.ttvn-blog-more {
	margin-top: 2.5rem;
	padding: 1.5rem 1.25rem;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 12px;
}

.ttvn-blog-more__title {
	font-family: "Montserrat", Inter, system-ui, sans-serif;
	font-size: 1.125rem;
	font-weight: 700;
	color: #0c4a6e;
	margin: 0 0 1rem;
}

.ttvn-blog-more__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.ttvn-blog-more__list a {
	color: #0369a1;
	font-weight: 600;
	text-decoration: none;
}

.ttvn-blog-more__list a:hover {
	text-decoration: underline;
}

/* —— Cẩm nang archive: bám mockup (hero xanh #0056b3, strip icon, dock, 3+4, promo, newsletter) —— */
body.post-type-archive-ttvn_blog .ttvn-blog-archive-main,
body.tax-ttvn_blog_loai .ttvn-blog-archive-main {
	overflow-x: clip;
	--ttvn-cn-blue: #0056b3;
	--ttvn-cn-blue-dark: #003d82;
	--ttvn-cn-gold: #f5c518;
	--ttvn-cn-gold-shadow: #d4a012;
}

.ttvn-blog-cover-hero {
	position: relative;
	min-height: clamp(380px, 50vw, 540px);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp(6.75rem, 11vw, 9.5rem) 1.25rem clamp(5.5rem, 11vw, 8rem);
	background:
		linear-gradient(
			180deg,
			rgba(248, 250, 252, 0.92) 0%,
			rgba(248, 250, 252, 0.45) 22%,
			rgba(0, 70, 130, 0.35) 55%,
			rgba(0, 34, 72, 0.78) 100%
		),
		url("https://images.unsplash.com/photo-1436491865332-7a61a109cc05?w=1920&q=82") center 30% / cover no-repeat;
	color: #0f172a;
	text-align: center;
}

.ttvn-blog-cover-hero__inner {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 46rem;
	margin-inline: auto;
	display: grid;
	justify-items: center;
}

.ttvn-blog-cover-hero__badge {
	justify-self: start;
	margin: 0 0 0.75rem !important;
	padding: 0.4rem 1rem;
	border-radius: 999px;
	background: var(--ttvn-cn-blue, #0056b3);
	border: none;
	color: #ffffff !important;
	box-shadow: 0 4px 14px rgba(0, 86, 179, 0.35);
	font-weight: 700 !important;
}

.ttvn-blog-cover-hero__title {
	color: var(--ttvn-cn-blue, #0056b3) !important;
	text-shadow: none;
}

.ttvn-blog-cover-hero__brand {
	color: var(--ttvn-cn-gold, #e6a317) !important;
	font-weight: 800;
}

.ttvn-blog-cover-hero__lead {
	color: #334155 !important;
	max-width: 34rem;
	margin-inline: auto !important;
	font-weight: 500;
}

.ttvn-blog-hero-strip-wrap {
	position: relative;
	z-index: 2;
	margin-top: clamp(1rem, 2.5vw, 1.5rem);
	padding: 0 1rem 0;
	max-width: 1200px;
	margin-inline: auto;
}

.ttvn-blog-hero-strip {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem 1.25rem;
	padding: 1.1rem 1.35rem;
	background: #ffffff;
	border-radius: 20px;
	box-shadow: 0 22px 55px rgba(0, 56, 120, 0.14);
	border: 1px solid #e8eef4;
}

.ttvn-blog-filters--strip {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
}

.ttvn-blog-filters--strip .ttvn-blog-filters__pill {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.55rem 1rem;
	border-radius: 999px;
	font-size: 0.875rem;
	font-weight: 600;
	text-decoration: none;
	color: #334155;
	background: #eef2f7;
	border: 1px solid transparent;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.ttvn-blog-filters--strip .ttvn-blog-filters__pill-ico {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #64748b;
}

.ttvn-blog-filters--strip .ttvn-blog-filters__pill.is-active .ttvn-blog-filters__pill-ico {
	color: #fff;
}

.ttvn-blog-filters--strip .ttvn-blog-filters__pill:hover {
	background: #e2e8f0;
	color: #0f172a;
}

.ttvn-blog-filters--strip .ttvn-blog-filters__pill.is-active {
	background: var(--ttvn-cn-blue, #0056b3);
	color: #fff;
	box-shadow: 0 4px 16px rgba(0, 86, 179, 0.35);
	border-color: transparent;
}

.ttvn-blog-hero-search {
	display: flex;
	flex: 1 1 220px;
	min-width: min(100%, 220px);
	max-width: 380px;
	margin-left: auto;
	border: 1px solid #e2e8f0;
	border-radius: 12px;
	overflow: hidden;
	background: #f8fafc;
}

.ttvn-blog-hero-search input[type="search"] {
	flex: 1;
	border: 0;
	padding: 0.65rem 1rem;
	font-size: 0.9375rem;
	background: transparent;
	outline: none;
}

.ttvn-blog-hero-search__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	border: 0;
	background: var(--ttvn-cn-blue, #0056b3);
	color: #fff;
	cursor: pointer;
	transition: background 0.2s ease;
}

.ttvn-blog-hero-search__btn:hover {
	background: var(--ttvn-cn-blue-dark, #003d82);
}

.ttvn-blog-catdock {
	padding: 1.25rem 1rem 0;
	max-width: 1240px;
	margin-inline: auto;
}

.ttvn-blog-catdock__inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem 0.35rem;
	padding: 0.85rem 1rem;
	background: #ffffff;
	border-radius: 16px;
	box-shadow: 0 8px 28px rgba(15, 23, 42, 0.06);
	border: 1px solid #e2e8f0;
}

.ttvn-blog-catdock__item {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.45rem 0.75rem;
	border-radius: 12px;
	font-size: 0.8125rem;
	font-weight: 600;
	color: #475569;
	text-decoration: none;
	transition: background 0.2s ease, color 0.2s ease;
}

.ttvn-blog-catdock__item:hover {
	background: #f1f5f9;
	color: #0f172a;
}

.ttvn-blog-catdock__item.is-active {
	background: #e8f2fc;
	color: var(--ttvn-cn-blue, #0056b3);
	border: 1px solid rgba(0, 86, 179, 0.25);
}

.ttvn-blog-catdock__ico {
	font-size: 1rem;
	line-height: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: 999px;
	background: #eef5fc;
}

.ttvn-blog-section-head {
	align-items: flex-start !important;
}

.ttvn-blog-section-head__left {
	flex: 1 1 min(100%, 28rem);
	min-width: 0;
}

.ttvn-blog-section-head__sub {
	margin: 0;
	max-width: 36rem;
}

.ttvn-blog-section-head__link {
	margin: 0;
	align-self: flex-start;
	padding-top: 0.2rem;
}

@media (min-width: 640px) {
	.ttvn-blog-section-head__link {
		margin-left: auto;
		align-self: flex-start;
	}
}

.ttvn-blog-section-head__title {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0;
	color: var(--ttvn-cn-blue-dark, #003d82);
	border-bottom: 3px solid var(--ttvn-cn-gold, #f5c518);
	padding-bottom: 0.35rem;
}

.ttvn-blog-section-head__icon {
	font-size: 1.25rem;
	filter: grayscale(0.2);
}

.ttvn-blog-section-head__link a {
	font-weight: 600;
	font-size: 0.9375rem;
	color: var(--ttvn-cn-blue, #0056b3);
	text-decoration: none;
}

.ttvn-blog-section-head__link a:hover {
	text-decoration: underline;
}

/* Lưới 3 + 4: dùng ul (core/post-template luôn render ul>li), không phụ thuộc is-layout-grid / className DB */
.ttvn-blog-listing--magazine .wp-block-query.alignwide {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	width: 100% !important;
	max-width: 1180px;
	min-width: 0;
	box-sizing: border-box;
}

/* Phân trang (số trang) luôn full width, nằm dưới cùng lưới 3+4 */
.ttvn-blog-listing--magazine .wp-block-query-pagination {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	flex-shrink: 0;
}

.ttvn-blog-listing--magazine ul.wp-block-post-template,
.ttvn-blog-listing--magazine .wp-block-post-template.ttvn-blog-mag-grid,
.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid {
	display: grid !important;
	grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
	gap: clamp(1rem, 2vw, 1.35rem) !important;
	width: 100% !important;
	max-width: 100% !important;
	min-width: 0 !important;
	box-sizing: border-box !important;
	list-style: none;
	margin: 0;
	padding: 0;
}

.ttvn-blog-listing--magazine ul.wp-block-post-template > li,
.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > li,
.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > .wp-block-post {
	min-width: 0 !important;
}

/* Chỉ hiển thị tối đa 7 bài (3 + 4); ẩn phần thừa nếu query vẫn trả về >7 */
.ttvn-blog-listing--magazine ul.wp-block-post-template > li:nth-child(n + 8),
.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > li:nth-child(n + 8),
.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > .wp-block-post:nth-child(n + 8) {
	display: none !important;
}

@media (min-width: 900px) {
	.ttvn-blog-listing--magazine ul.wp-block-post-template,
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid {
		row-gap: 1.75rem !important;
		column-gap: clamp(1rem, 2vw, 1.35rem) !important;
	}

	.ttvn-blog-listing--magazine ul.wp-block-post-template > li:nth-child(-n + 3),
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > li:nth-child(-n + 3),
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > .wp-block-post:nth-child(-n + 3) {
		grid-column: span 4 !important;
		grid-row: 1 !important;
	}

	.ttvn-blog-listing--magazine ul.wp-block-post-template > li:nth-child(n + 4):nth-child(-n + 7),
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > li:nth-child(n + 4):nth-child(-n + 7),
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > .wp-block-post:nth-child(n + 4):nth-child(-n + 7) {
		grid-column: span 3 !important;
		grid-row: 2 !important;
	}

	.ttvn-blog-listing--magazine ul.wp-block-post-template > li:nth-child(-n + 3) .ttvn-blog-card--mag .wp-block-post-featured-image,
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > li:nth-child(-n + 3) .ttvn-blog-card--mag .wp-block-post-featured-image,
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > .wp-block-post:nth-child(-n + 3) .ttvn-blog-card--mag .wp-block-post-featured-image {
		aspect-ratio: 4 / 3 !important;
	}

	.ttvn-blog-listing--magazine ul.wp-block-post-template > li:nth-child(n + 4) .ttvn-blog-card--mag .wp-block-post-featured-image,
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > li:nth-child(n + 4) .ttvn-blog-card--mag .wp-block-post-featured-image,
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > .wp-block-post:nth-child(n + 4) .ttvn-blog-card--mag .wp-block-post-featured-image {
		aspect-ratio: 16 / 10 !important;
	}

}

@media (max-width: 899px) {
	.ttvn-blog-listing--magazine ul.wp-block-post-template > li,
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > li,
	.ttvn-blog-listing--magazine .wp-block-post-template.is-layout-grid.ttvn-blog-mag-grid > .wp-block-post {
		grid-column: span 12 !important;
		grid-row: auto !important;
	}
}

.ttvn-blog-card--mag {
	box-shadow: 0 8px 28px rgba(15, 23, 42, 0.07);
	border: 1px solid #e2e8f0;
	border-radius: 20px;
	overflow: hidden;
	height: 100%;
	min-width: 0;
	display: flex;
	flex-direction: column;
}

.ttvn-blog-card--mag .wp-block-post-title {
	min-width: 0;
	font-size: clamp(1.0625rem, 2.15vw, 1.3125rem) !important;
	font-weight: 700 !important;
	line-height: 1.35 !important;
	letter-spacing: -0.02em;
	color: #0f172a !important;
}

.ttvn-blog-card--mag .wp-block-post-title a {
	color: inherit !important;
	word-break: normal;
	overflow-wrap: break-word;
}

.ttvn-blog-card--mag .wp-block-post-featured-image {
	position: relative;
	flex-shrink: 0;
	margin-bottom: 0 !important;
}

.ttvn-blog-card--mag .wp-block-post-featured-image a {
	pointer-events: auto;
}

.ttvn-blog-card--mag .ttvn-blog-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	text-align: left;
	/* Tag + tiêu đề sát mép dưới ảnh; đáy vẫn đủ chỗ cho CTA */
	padding: 0.5rem 1.25rem 1.125rem !important;
	/* Khoảng cột dọc: tách rõ từng dòng (chủ đề / tiêu đề / ngày / mô tả) */
	--wp--style--block-gap: 0.9375rem !important;
	gap: 0.9375rem !important;
}

/* Chỉ dùng gap của flex — tránh margin core WP chồng lên làm lệch “cột” dọc */
.ttvn-blog-card--mag .ttvn-blog-card__body > *:not(a.wp-block-read-more) {
	margin-block-start: 0 !important;
	margin-block-end: 0 !important;
}

.ttvn-blog-card--mag .ttvn-blog-card__meta,
.ttvn-blog-card--mag .ttvn-blog-card__meta .wp-block-post-date,
.ttvn-blog-card--mag .ttvn-blog-card__meta time {
	font-size: 0.8125rem !important;
	color: #94a3b8 !important;
	font-weight: 500 !important;
}

.ttvn-blog-card--mag .ttvn-blog-card__meta .wp-block-post-date {
	margin: 0 !important;
}

.ttvn-blog-card--mag .wp-block-post-terms.ttvn-blog-card__terms,
.ttvn-blog-card--mag .ttvn-blog-card__terms {
	margin: 0 !important;
	padding-top: 0 !important;
}

.ttvn-blog-card--mag .wp-block-post-excerpt {
	color: #64748b !important;
}

.ttvn-blog-card--mag .wp-block-post-excerpt__excerpt {
	margin-top: 0 !important;
	font-size: 0.9375rem !important;
	line-height: 1.55 !important;
	color: #64748b !important;
}

.ttvn-blog-card--mag .wp-block-read-more,
.ttvn-blog-card--mag a.wp-block-read-more {
	display: flex !important;
	align-items: center;
	justify-content: space-between;
	width: 100% !important;
	max-width: 100%;
	box-sizing: border-box;
	margin-top: auto !important;
	margin-bottom: 0;
	padding: 0.875rem 0 0 !important;
	border: none !important;
	border-top: 1px solid #e8edf3 !important;
	border-radius: 0 !important;
	background: none !important;
	box-shadow: none !important;
	font-size: 0.9375rem !important;
	font-weight: 700 !important;
	color: var(--ttvn-cn-blue, #0056b3) !important;
	text-decoration: none !important;
	gap: 0.75rem;
}

.ttvn-blog-card--mag .wp-block-read-more::after,
.ttvn-blog-card--mag a.wp-block-read-more::after {
	content: "→";
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin-left: auto;
	font-size: 1.125rem;
	font-weight: 600;
	line-height: 1;
	color: var(--ttvn-cn-blue, #0056b3);
}

.ttvn-blog-card--mag .wp-block-read-more:hover {
	color: var(--ttvn-cn-blue-dark, #003d82) !important;
	text-decoration: underline !important;
}

.ttvn-blog-card--mag a.wp-block-read-more:hover::after,
.ttvn-blog-card--mag .wp-block-read-more:hover::after {
	color: var(--ttvn-cn-blue-dark, #003d82) !important;
}

body.post-type-archive-ttvn_blog .ttvn-blog-listing--magazine .ttvn-blog-card--mag .ttvn-blog-card__terms a,
body.tax-ttvn_blog_loai .ttvn-blog-listing--magazine .ttvn-blog-card--mag .ttvn-blog-card__terms a {
	color: var(--ttvn-cn-blue, #0056b3) !important;
	background: #e8f4fc !important;
	border-radius: 999px !important;
	padding: 0.3rem 0.7rem !important;
	font-size: 0.75rem !important;
	font-weight: 600 !important;
}

.ttvn-blog-promo {
	background: linear-gradient(180deg, #e8f2fc 0%, #f4f8fc 45%, #f8fafc 100%);
	padding: clamp(2.5rem, 5vw, 4.25rem) 1.25rem;
	border-block: 1px solid #dbeafe;
}

.ttvn-blog-promo__inner {
	max-width: 1180px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr minmax(220px, 340px);
	gap: clamp(1.5rem, 4vw, 2.75rem);
	align-items: center;
}

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

.ttvn-blog-promo__eyebrow {
	margin: 0 0 0.35rem;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--ttvn-cn-blue, #0056b3);
}

.ttvn-blog-promo__title {
	margin: 0 0 0.75rem;
	font-family: "Montserrat", Inter, system-ui, sans-serif;
	font-size: clamp(1.35rem, 3vw, 1.85rem);
	font-weight: 800;
	color: var(--ttvn-cn-blue-dark, #003d82);
	line-height: 1.2;
}

.ttvn-blog-promo__desc {
	margin: 0 0 1.5rem;
	font-size: 1rem;
	line-height: 1.65;
	color: #475569;
	max-width: 36rem;
}

.ttvn-blog-promo__features {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem 1.5rem;
}

@media (max-width: 520px) {
	.ttvn-blog-promo__features {
		grid-template-columns: 1fr;
	}
}

.ttvn-blog-promo__feat {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
}

.ttvn-blog-promo__feat-ico {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	border-radius: 999px;
	background: var(--ttvn-cn-blue, #0056b3);
	color: #fff;
	box-shadow: 0 4px 12px rgba(0, 86, 179, 0.25);
}

.ttvn-blog-promo__feat strong {
	display: block;
	font-size: 0.9375rem;
	font-weight: 700;
	color: #0f172a;
	margin-bottom: 0.15rem;
}

.ttvn-blog-promo__feat span:not(.ttvn-blog-promo__feat-ico) {
	display: block;
	font-size: 0.8125rem;
	font-weight: 500;
	color: #64748b;
	line-height: 1.45;
}

.ttvn-blog-promo__visual {
	min-height: clamp(220px, 32vw, 300px);
	border-radius: 24px;
	background:
		linear-gradient(145deg, rgba(0, 86, 179, 0.08) 0%, rgba(0, 61, 130, 0.2) 100%),
		url("https://images.unsplash.com/photo-1488646953014-85cb44e25828?w=800&h=900&fit=crop&q=82") center 60% / cover no-repeat;
	box-shadow: 0 20px 50px rgba(0, 56, 120, 0.15);
	border: 1px solid rgba(255, 255, 255, 0.65);
}

.ttvn-blog-newsletter {
	background: var(--ttvn-cn-blue-dark, #003d82);
	padding: clamp(1.5rem, 5vw, 3rem) clamp(1rem, 4vw, 1.25rem);
}

.ttvn-blog-newsletter__inner {
	max-width: 1100px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem 1.25rem;
	padding: clamp(1.25rem, 3vw, 1.75rem) clamp(1rem, 3vw, 1.75rem);
	background: linear-gradient(135deg, #004a8f 0%, #003d82 42%, #002a5c 100%);
	border-radius: 20px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow: 0 16px 40px rgba(0, 34, 72, 0.35);
}

.ttvn-blog-newsletter__text {
	flex: 1 1 220px;
	min-width: 0;
	max-width: 36rem;
}

.ttvn-blog-newsletter__title {
	margin: 0 0 0.35rem;
	font-family: "Montserrat", Inter, system-ui, sans-serif;
	font-size: clamp(1.2rem, 2.5vw, 1.5rem);
	font-weight: 700;
	color: #f8fafc;
	line-height: 1.25;
}

.ttvn-blog-newsletter__sub {
	margin: 0;
	font-size: 0.9375rem;
	color: #bae6fd;
	line-height: 1.55;
}

/* Form: desktop hàng ngang; mobile chuyển cột (tránh đè input / nút) */
.ttvn-blog-newsletter__form {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 0.75rem;
	flex: 1 1 min(100%, 340px);
	min-width: 0;
	width: min(100%, 480px);
	justify-content: flex-end;
	margin-left: auto;
}

.ttvn-blog-newsletter__input {
	flex: 1 1 12rem;
	min-width: 0;
	width: auto;
	min-height: 48px;
	padding: 0.85rem 1rem;
	border-radius: 12px;
	border: 0;
	font-size: 1rem;
	box-sizing: border-box;
}

.ttvn-blog-newsletter__btn {
	flex: 0 0 auto;
	align-self: stretch;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0.85rem 1.35rem;
	border-radius: 12px;
	border: 0;
	font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
	font-weight: 700;
	font-size: 0.9375rem;
	letter-spacing: 0.01em;
	cursor: pointer;
	background: #facc15;
	color: #422006;
	box-shadow: 0 4px 0 #ca8a04;
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.ttvn-blog-newsletter__btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 0 #ca8a04;
}

@media (max-width: 900px) {
	.ttvn-blog-newsletter__inner {
		flex-direction: column;
		align-items: stretch;
		text-align: center;
		border-radius: 18px;
		padding: 1.35rem 1.1rem;
		gap: 1.15rem;
	}

	.ttvn-blog-newsletter__text {
		flex: none;
		width: 100%;
		max-width: none;
		text-align: center;
	}

	.ttvn-blog-newsletter__title {
		font-size: clamp(1.1rem, 4.5vw, 1.35rem);
	}

	.ttvn-blog-newsletter__sub {
		font-size: 0.9rem;
		padding: 0 0.25rem;
	}

	.ttvn-blog-newsletter__form {
		flex-direction: column;
		flex-wrap: nowrap;
		width: 100%;
		max-width: none;
		margin-left: 0;
		justify-content: stretch;
		gap: 0.7rem;
	}

	.ttvn-blog-newsletter__input {
		flex: none;
		width: 100%;
		min-width: 0;
		text-align: left;
	}

	.ttvn-blog-newsletter__btn {
		width: 100%;
		flex: none;
		box-shadow: 0 3px 0 #ca8a04;
	}
}

.ttvn-blog-trust {
	background: #f8fafc;
	padding: 1.25rem 1rem 2rem;
	border-top: 1px solid #e2e8f0;
}

.ttvn-blog-trust__inner {
	max-width: 1100px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 1rem;
	text-align: center;
	font-size: 0.8125rem;
	font-weight: 600;
	color: #475569;
}

@media (max-width: 720px) {
	.ttvn-blog-trust__inner {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.ttvn-blog-trust__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.35rem;
}

.ttvn-blog-trust__ico {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 999px;
	line-height: 0;
	background: #e8f2fc;
	color: var(--ttvn-cn-blue, #0056b3);
	margin-bottom: 0.15rem;
}

.ttvn-blog-trust__ico svg {
	display: block;
	width: 1.125rem;
	height: 1.125rem;
	flex-shrink: 0;
}

body.tax-ttvn_blog_loai .ttvn-blog-hero--taxonomy {
	padding-top: clamp(5.5rem, 10vw, 7rem);
}
