@font-face {
	font-family: 'Material Icons';
	font-style: normal;
	font-weight: 400;
	src: url(https://fonts.gstatic.com/s/materialicons/v145/flUhRq6tzZclQEJ-Vdg-IuiaDsNc.woff2) format('woff2');
}
:root {
	--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
	--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
	--fs-color-main: #e31e24;
	--tw-ring-offset-shadow: 0 0 #0000;
	--tw-ring-shadow: 0 0 #0000;
}
.material-icons {
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	font-size: 24px;
	line-height: 1;
	letter-spacing: normal;
	text-transform: none;
	display: inline-block;
	white-space: nowrap;
	word-wrap: normal;
	direction: ltr;
	-webkit-font-feature-settings: 'liga';
	-webkit-font-smoothing: antialiased;
}
#masthead > div > div:nth-child(3) > ul {
	justify-content: center !important;
	gap: 25px;
}
#masthead > div > div:nth-child(3) > ul > li > a {
	font-size: 16px;
	color: rgb(17 17 17 / 85%);
	position: relative;
	transition: all 0.3s ease;
}
#masthead > div > div:nth-child(3) > ul > li > a:after {
	content: '';
	background-color: var(--fs-color-main);
	height: 2px;
	width: 0;
	position: absolute;
	bottom: 2px;
	left: 0;
	transition: all 0.3s ease;
}
#masthead > div > div:nth-child(3) > ul > li.current-menu-item > a,
#masthead > div > div:nth-child(3) > ul > li > a:hover{
	color: var(--fs-color-main);
	transition: all 0.3s ease;
}
#masthead > div > div:nth-child(3) > ul > li.current-menu-item > a:after,
#masthead > div > div:nth-child(3) > ul > li > a:hover:after{
	width: 100%;
	transition: all 0.3s ease;
}
.tel-hotline {
	color: rgb(255 255 255) !important;
	background-color: rgb(227 30 36);
	border-radius: 9999px;
	font-size: 16px !important;
	line-height: 1.5 !important;
	display: flex !important;
	gap: 10px;
	text-transform: capitalize !important;
	align-items: center !important;
	padding: 8px 24px !important;
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
	transition: all 0.3s ease;
}
.tel-hotline:hover {
	background-color: rgb(194 22 27);
	transform: translatey(-2.5px);
	transition: all 0.3s ease;
}
.tel-hotline span {
	font-size: 14px;
}
.logogan-bottom {
	margin: 0;
	width: 100%;
	display: flex;
	align-items: center;
	gap: 15px;
	text-align: center;
	padding: 12px 0;
	background-color: rgb(250 204 21);
	justify-content: center;
}
.logogan-bottom div {
	display: flex;
	align-items: center;
	gap: 10px;
}
.logogan-bottom span {
	color: #000;
}
.logogan-bottom div span {
	font-size: 16px;
	line-height: 24px;
	color: #000;
	text-transform: uppercase;
	font-weight: 700;
}
.about-banner,
.about-banner img,
.about-banner .img-inner {
	border-radius: 10px;
}
.content-about > p:nth-child(1) {
	margin-bottom: 8px;
	line-height: 1;
}
.content-about > h1 {
	line-height: 1;
	margin-bottom: 24px;
}
.content-about > p:nth-child(1) span{
	color: rgb(227 30 36) !important;
	font-size: 14px;
	line-height: 20px;
	text-transform: uppercase;
	font-weight: 700;
}
.content-about > h1 span {
	color: rgb(17 24 39) !important;
	font-size: 30px;
	line-height: 36px;
	text-transform: uppercase;
	font-weight: 700;
}
.content-about > p:nth-child(3) {
	margin-bottom: 0;
}
.content-about > p:nth-child(3) span{
	color: rgb(75 85 99) !important;
	text-align: justify;
	margin-bottom: 20px;
	font-size: 18px;
	display: block;
}
.content-about > p:nth-child(4) {
	margin-bottom: 24px;
}
.content-about > p:nth-child(4) span:nth-child(1){
	font-weight: 700;
	margin-bottom: 4px;
	color: rgb(31 41 55);
	font-size: 14px;
}
.content-about > p:nth-child(4) span:nth-child(3) {
	font-weight: 700;
	margin-bottom: 0;
	color: var(--fs-color-main);
	font-size: 26px;
}
.btn-custom {
	background-color: var(--fs-color-main);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
	color: #FFF;
	padding: 12px 32px;
	margin: 0;
	line-height: 1;
	border-radius: 6px;
}
.about-banner .img-inner {
	position: relative;
}
.about-banner .img-inner:before {
	content: '';
	position: absolute;
	background-color: rgb(227 30 36 / 20%);
	border-top-left-radius: 1.5rem;
	width: 96px;
	height: 96px;
	top: -16px;
	left: -16px;
	z-index: -1;
}
.about-banner .img-inner:after {
	content: '';
	position: absolute;
	background-color: rgb(250 204 21 / 20%);
	border-bottom-right-radius: 1.5rem;
	width: 96px;
	height: 96px;
	bottom: -16px;
	right: -16px;
	z-index: -1;
}
.about-banner .img-inner {
	overflow: unset;
}
.title-all h2 {
	position: relative;
	color: rgb(17 24 39);
	text-transform: uppercase;
	font-weight: 900;
	font-size: 30px;
	line-height: 36px;
	margin-bottom: 48px;
	margin-top: 0;
}
.title-all h2:before {
	content: '';
	position: absolute;
	top: -25px;
	left: 50%;
	transform: translatex(-50%);
	background-color: rgb(227 30 36);
	width: 96px;
	height: 4px;
}
.box-custom-image .col-inner  {
	background-color: rgb(255 255 255);
	border-radius: 12px;
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
	transition: all 0.3s ease;
}
.box-custom-image .col-inner .img,
.box-custom-image .col-inner .img .img-inner,
.box-custom-image .col-inner .img .img-inner img {
	border-radius: 12px 12px 0 0;
	margin-bottom: 0;
	transition: all 0.3s ease;
}
.box-custom-image .col-inner a.button {
	background-color: var(--fs-color-main);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
	color: #FFF;
	padding: 12px 32px;
	margin: 20px auto;
	line-height: 1;
	font-size: 12px;
	line-height: 16px;
	border-radius: 6px !important; 
	transition: all 0.3s ease-in;
}
.box-custom-image .col-inner:hover {
	--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
	--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
	transition: all 0.3s ease;
}
.box-custom-image .col-inner:hover .img .img-inner img {
	transform: scale(1.1);
	transition: all 0.3s ease;
}
.box-custom-image .col-inner a.button:hover {
	transform: translatey(-5px);
	background-color: rgb(194 22 27);
	transition: all 0.3s ease-in;
}
.title-why {
	text-align: center;
}
.title-why h2 {
	color: rgb(220 38 38);
	text-transform: uppercase;
	font-size: 24px;
	width: max-content;
	margin: 0 auto 48px;
	line-height: 32px;
	padding: 12px 32px;
	background-color: rgb(254 242 242);
	border: 2px solid rgb(254 226 226);
	border-radius: 9999px;
}
.bds-features{
	display:grid;
	grid-template-columns:repeat(4,1fr);
	gap:28px;
}
.bds-feature{
	background:#fff;
	border-radius:16px;
	padding:26px 20px;
	text-align:center;
	box-shadow:0 10px 28px rgba(0,0,0,.06);
	transition:.35s ease;
	position:relative;
}
.bds-feature:hover{
	transform:translateY(-10px);
	box-shadow:0 22px 48px rgba(0,0,0,.15);
}

/* ICON IMAGE */
.bds-feature__icon{
	width:70px;
	height:70px;
	margin:0 auto 14px;
	border-radius:50%;
	border:2px solid #e51b1b;
	display:flex;
	align-items:center;
	justify-content:center;
	background:#fff;
	transition:.35s ease;
}
.bds-feature__icon img{
	width: 45px;
	height: 45px;
	object-fit:contain;
	transition:.35s ease;
}

.bds-feature:hover .bds-feature__icon{
	background:#e51b1b;
	box-shadow:0 10px 22px rgba(229,27,27,.35);
}
.bds-feature:hover .bds-feature__icon img{
	filter:brightness(0) invert(1);
	transform:scale(1.1);
}

/* TEXT */
.bds-feature__title{
	color:#16a000;
	font-weight:800;
	font-size:16px;
	margin:6px 0 10px;
	text-transform:uppercase;
}
.bds-feature__desc{
	font-size:14px;
	line-height:1.6;
	color:#333;
}

/* Box nổi bật (như box cuối hình bạn) */
.bds-feature.highlight{
	box-shadow:0 25px 60px rgba(0,0,0,.18);
}
.section-title-normal span {
	border-bottom-color: var(--fs-color-main);
}
.blog-post-custom .col-inner,
.blog-post-custom .col-inner .box {
	border-radius: 10px;
}
.blog-post-custom .col-inner .box .box-image,
.blog-post-custom .col-inner .box .box-image img {
	border-radius: 10px 0 0 10px;
}
.blog-post-custom .col-inner .box .post-title {
	font-weight: 700;
	font-size: 16px;
	line-height: 22px;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	color: rgb(17 24 39);
	margin-bottom: 15px;
	transition: all 0.3s ease;
}
.blog-post-custom .col-inner:hover .box .post-title {
	color: var(--fs-color-main);
	transition: all 0.3s ease;
}
.blog-post-custom .col-inner .box .is-divider {
	display: none;
}
.from_the_blog_excerpt {
	font-size: 14px;
}
.btn-custom-2 {
	color: rgb(227 30 36) !important;
	font-weight: 700;
	font-size: 14px;
	line-height: 20px !important;
	padding: 8px 24px !important;
	border: 1px solid rgb(227 30 36) !important;
	border-color: rgb(227 30 36) !important;
	border-radius: 6px;
	margin: 0;
	transition: all 0.3s ease;
}
.btn-custom-2:hover {
	background-color: rgb(227 30 36) !important;
	color: #FFF !important;
	transition: all 0.3s ease;
}
.box-left-content,
.about-content .col-inner{
	--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
	--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
	padding: 24px;
	background-color: #FFF;
	border-radius: 8px;
}
.btn-custom-left {
	color: rgb(255 255 255);
	font-weight: 700;
	font-size: 14px;
	border: 1px solid rgb(227 30 36);
	line-height: 20px;
	padding: 8px 24px;
	background-color: rgb(227 30 36);
	border-radius: 6px;
	transition: all 0.3s ease;
}
.btn-custom-left:hover {
	background-color: #FFF;
	color: rgb(227 30 36);
	transition: all 0.3s ease;
}
.section-row-0 .row .col {
	padding-bottom: 0 !important;
}
.row-soluong .col-inner {
	--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
	--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
	padding: 24px;
	background-color: #FFF;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	text-align: center;
	border: 2px solid #FFF;
	transition: all 0.3s ease;
}
.row-soluong .col-inner:hover {
	transform: translatey(-5px);
	border: 2px solid var(--fs-color-main);
	transition: all 0.3s ease;
}
.row-soluong .col-inner h2 span {
	color: var(--fs-color-main) !important;
}
.row-soluong .col-inner p{
	color: #000 !important;
	margin: 0;
}
#footer .infor-ft h3 {
	text-align: left;
}
#footer .infor-ft p span{
	font-size: 16px;
	display: block;
	margin-bottom: 15px;
}
#footer .infor-ft p br {
	display: none;
}
#footer .ux-menu .menu-item a span {
	font-weight: 700;
}
#footer .ux-menu .menu-item a:hover {
	transform: translatex(5px);
	transition: all 0.3s ease;
}

#footer .ux-menu .menu-item a:hover span{
	color: var(--fs-color-main);
	transition: all 0.3s ease;
}
.btn-pulse {
	position: relative;
}
.btn-pulse::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 100%;
	height: 100%;
	background: rgba(255, 0, 0, 0.5);
	border-radius: 10px;
	transform: translate(-50%, -50%);
	animation: pulse 0.8s infinite;
	z-index: 1;
}
@keyframes pulse {
	0% {
		transform: translate(-50%, -50%) scale(1);
		opacity: 0.7;
	}
	100% {
		transform: translate(-50%, -50%) scale(1.8);
		opacity: 0;
	}
}
.about-content a.button {
	width: max-content !important;
	margin: 0 auto;
	display: block;
	padding: 0 30px !important;
	border-radius: 10px !important;
}
.img-about,
.img-about .img-inner,
.img-about .img-inner img {
	border-radius: 12px;
}
/* ===== Feature Cards ===== */
.oai-feature-wrap {
	--card-radius: 14px;
	--shadow: 0 10px 24px rgba(15, 23, 42, .08);
	--shadow-hover: 0 18px 40px rgba(15, 23, 42, .14);
	--border: rgba(2, 6, 23, .06);
	--muted: rgba(2, 6, 23, .62);
	--title: rgba(2, 6, 23, .86);
	--pink: #ff3b5c;
	--pink-soft: rgba(255, 59, 92, .10);
	--bg: #ffffff;
}

.oai-feature-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 28px;
}

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

.oai-feature-card {
	position: relative;
	background: var(--bg);
	border-radius: var(--card-radius);
	border: 1px solid var(--border);
	box-shadow: var(--shadow);
	padding: 28px 26px 24px;
	text-align: center;
	transition: all .35s cubic-bezier(.2,.8,.2,1);
	overflow: hidden;
}

.oai-feature-card::before {
	content: "";
	position: absolute;
	inset: -2px;
	background: radial-gradient(
		600px 140px at 50% -40px,
		rgba(255, 59, 92, .18),
		transparent 65%
	);
	opacity: 0;
	transition: opacity .35s ease;
}

.oai-feature-card::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: calc(var(--card-radius) + 2px);
	padding: 1px;
	background: linear-gradient(
		120deg,
		rgba(255, 59, 92, 0),
		rgba(255, 59, 92, .55),
		rgba(59, 130, 246, .35),
		rgba(255, 59, 92, 0)
	);
	-webkit-mask:
		linear-gradient(#000 0 0) content-box,
		linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	opacity: 0;
	transition: opacity .35s ease;
}

.oai-feature-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-hover);
	border-color: rgba(255, 59, 92, .18);
}

.oai-feature-card:hover::before,
.oai-feature-card:hover::after {
	opacity: 1;
}

/* Icon */
.oai-feature-icon {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: var(--pink-soft);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 14px;
	transition: transform .35s ease, background .35s ease;
}

.oai-feature-icon svg {
	width: 24px;
	height: 24px;
	fill: var(--pink);
	transition: transform .35s ease;
}

.oai-feature-card:hover .oai-feature-icon {
	transform: translateY(-2px) scale(1.05);
	background: rgba(255, 59, 92, .15);
}

.oai-feature-card:hover .oai-feature-icon svg {
	transform: rotate(-6deg) scale(1.06);
}

/* Text */
.oai-feature-title {
	font-size: 20px;
	line-height: 28px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .6px;
	margin-bottom: 10px;
	color: var(--title);
}

.oai-feature-desc {
	font-size: 14px;
	line-height: 1.6;
	color: var(--muted);
	margin: 0;
}

/* Glow spark */
.oai-feature-spark {
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0;
	transition: opacity .35s ease;
}

.oai-feature-card:hover .oai-feature-spark {
	opacity: 1;
}

.oai-feature-spark::before,
.oai-feature-spark::after {
	content: "";
	position: absolute;
	width: 140px;
	height: 140px;
	border-radius: 50%;
	filter: blur(18px);
	opacity: .45;
}

.oai-feature-spark::before {
	background: rgba(255, 59, 92, .35);
	top: -70px;
	left: -60px;
}

.oai-feature-spark::after {
	background: rgba(59, 130, 246, .28);
	bottom: -80px;
	right: -70px;
}

.oai-feature-icon span {
	color: var(--fs-color-main);
}
/* ===== CTA Hotline (namespace: oai-cta) ===== */
.oai-cta {
	--red: #e31b23;
	--red-dark: #c51218;
	--white: #fff;

	position: relative;
	padding: 70px 18px;
	background: var(--red);
	overflow: hidden;
}

.oai-cta::before{
	content:"";
	position:absolute;
	inset:0;
	/* pattern chấm như ảnh */
	background-image:
		radial-gradient(rgba(255,255,255,.18) 1px, rgba(255,255,255,0) 1px);
	background-size: 10px 10px;
	opacity: .35;
	pointer-events:none;
}

.oai-cta__inner{
	position:relative;
	max-width: 1100px;
	margin: 0 auto;
	text-align: center;
}

.oai-cta__title{
	margin: 0 0 12px;
	color: #fff;
	font-weight: 900;
	letter-spacing: 1px;
	text-transform: uppercase;
	line-height: 1.1;
	font-size: clamp(28px, 3.2vw, 44px);
	text-shadow: 0 2px 0 rgba(0,0,0,.06);
}

.oai-cta__desc{
	margin: 0 auto 26px;
	color: rgba(255,255,255,.9);
	max-width: 780px;
	font-size: 15px;
	line-height: 1.8;
}

/* ===== Button ===== */
.oai-cta__btn{
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 10px;

	padding: 14px 28px;
	border-radius: 999px;
	background: #fff;
	color: var(--red);
	text-decoration: none;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .6px;

	box-shadow: 0 14px 30px rgba(0,0,0,.18);
	transform: translateY(0);
	transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
	overflow: hidden;
}

.oai-cta__btn .material-icons{
	font-size: 20px;
	line-height: 1;
	transition: transform .25s ease;
}

.oai-cta__btn:hover{
	background: var(--red-dark);
	color: #fff;
	transform: translateY(-3px);
	box-shadow: 0 18px 44px rgba(0,0,0,.26);
}
.oai-cta__btn:hover .material-icons{
	transform: rotate(-10deg) scale(1.05);
}

/* ripple */
.oai-cta__btn::after{
	content:"";
	position:absolute;
	inset:auto;
	width: 12px;
	height: 12px;
	border-radius: 999px;
	background: rgba(255,255,255,.55);
	transform: scale(0);
	opacity: 0;
	pointer-events:none;
}
.oai-cta__btn:active::after{
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%) scale(24);
	opacity: 1;
	transition: transform .55s ease, opacity .7s ease;
}

/* pulse vòng lan tỏa nhẹ (tự chạy) */
.oai-cta__btn-pulse{
	position:absolute;
	inset:-10px;
	border-radius: 999px;
	border: 2px solid rgba(255,255,255,.45);
	opacity: 0;
	animation: oaiPulse 1.8s infinite;
	pointer-events:none;
}
@keyframes oaiPulse{
	0% { transform: scale(.92); opacity: .0; }
	30%{ opacity: .55; }
	100%{ transform: scale(1.10); opacity: 0; }
}

/* ===== Phones ===== */
.oai-cta__phones{
	margin-top: 18px;
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
}

.oai-cta__phone{
	display:inline-flex;
	align-items:center;
	gap:8px;

	padding: 10px 16px;
	border-radius: 999px;
	text-decoration:none;

	background: rgba(255,255,255,.14);
	border: 1px solid rgba(255,255,255,.18);
	color:#fff;
	font-weight: 800;

	backdrop-filter: blur(6px);
	transition: transform .25s ease, background .25s ease, border-color .25s ease;
}
.oai-cta__phone .material-icons{ font-size: 18px; }

.oai-cta__phone:hover{
	transform: translateY(-2px);
	background: rgba(255,255,255,.22);
	border-color: rgba(255,255,255,.32);
}
.oai-cta__phones {
	margin-top: 28px;
	display: flex;
	gap: 18px;
	justify-content: center;
	flex-wrap: wrap;
}

.oai-cta__phone {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 10px;

	padding: 14px 28px;
	border-radius: 999px;

	background: #ffffff;
	color: #e31b23;
	font-weight: 900;
	font-size: 16px;
	letter-spacing: .4px;
	text-decoration: none;

	box-shadow: 0 14px 32px rgba(0,0,0,.18);
	overflow: hidden;

	transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
}

.oai-cta__phone .material-icons {
	font-size: 22px;
	transition: transform .25s ease;
}

/* hover */
.oai-cta__phone:hover {
	background: #c51218;
	color: #ffffff;
	transform: translateY(-3px);
	box-shadow: 0 18px 44px rgba(0,0,0,.28);
}

.oai-cta__phone:hover .material-icons {
	transform: rotate(-10deg) scale(1.1);
}

/* pulse lan tỏa */
.oai-cta__phone::after {
	content: "";
	position: absolute;
	inset: -8px;
	border-radius: 999px;
	border: 2px solid rgba(255,255,255,.6);
	opacity: 0;
	animation: phonePulse 2s infinite;
	pointer-events: none;
}

@keyframes phonePulse {
	0% {
		transform: scale(.92);
		opacity: 0;
	}
	30% {
		opacity: .55;
	}
	100% {
		transform: scale(1.15);
		opacity: 0;
	}
}
/* ===== Page Banner (namespace: oai-banner) ===== */
.oai-banner {
	position: relative;
	width: 100%;
	min-height: 260px;              /* giống chiều cao ảnh */
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background: #0b1220;
}

/* nền ảnh */
.oai-banner__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	transform: scale(1.02);
}

/* overlay tối + gradient nhẹ */
.oai-banner__overlay {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(900px 420px at 50% 30%, rgba(255,255,255,.06), rgba(255,255,255,0) 60%),
		linear-gradient(90deg, rgba(3,8,18,.78), rgba(3,8,18,.55), rgba(3,8,18,.78));
}

/* nội dung */
.oai-banner__inner {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: 22px 16px;
	max-width: 1200px;
}

/* title */
.oai-banner__title {
	margin: 0 0 14px;
	color: #fff;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: 2px;
	font-size: clamp(34px, 4vw, 56px);
	line-height: 1.05;
	text-shadow: 0 10px 30px rgba(0,0,0,.35);
}

/* breadcrumb pill */
.oai-banner__crumb {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 10px 18px;
	border-radius: 999px;
	background: rgba(255,255,255,.10);
	border: 1px solid rgba(255,255,255,.12);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	box-shadow: 0 10px 30px rgba(0,0,0,.22);
}

.oai-banner__crumb a,
.oai-banner__crumb span {
	font-size: 14px;
	font-weight: 700;
	color: rgba(255,255,255,.85);
	text-decoration: none;
}

.oai-banner__crumb a:hover {
	color: #fff;
}

.oai-banner__sep {
	opacity: .65;
}

/* current page đỏ */
.oai-banner__current {
	color: #ff2d2d !important;
}
/* ===== News Archive Full Width (namespace: oai-news) ===== */
.oai-news {
	width: 100%;
}

/* Banner top */
.oai-news__banner {
	background: linear-gradient(90deg, #1f4f9a, #1b458a);
	padding: 52px 16px 44px;
	text-align: center;
	color: #fff;
}

.oai-news__banner h1 {
	margin: 0 0 8px;
	font-weight: 900;
	letter-spacing: 1px;
	text-transform: uppercase;
	font-size: clamp(22px, 2.6vw, 34px);
	line-height: 1.1;
	color: var(--fs-color-main);
}

.oai-news__crumb {
	font-size: 12px;
	opacity: .9;
}
.oai-news__crumb a {
	color: rgba(255,255,255,.9);
	text-decoration: none;
}
.oai-news__crumb a:hover { color: #fff; }
.oai-news__crumb .sep { margin: 0 8px; opacity: .8; }

/* Container */
.oai-news__wrap {
	max-width: 1200px;
	margin: 0 auto;
	padding: 26px 16px 44px;
}

/* List */
.oai-news__list {
	display: grid;
	gap: 18px;
}

/* Card */
.oai-news__card {
	display: grid;
	grid-template-columns: 360px 1fr;
	background: #fff;
	border: 1px solid rgba(2,6,23,.06);
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0 10px 24px rgba(15,23,42,.06);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.oai-news__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 18px 40px rgba(15,23,42,.12);
	border-color: rgba(239, 68, 68, .22);
}

@media (max-width: 900px){
	.oai-news__card { grid-template-columns: 1fr; }
}

/* Thumb */
.oai-news__thumb {
	position: relative;
	min-height: 210px;
	background: #eef2ff;
}

.oai-news__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Date badge */
.oai-news__badge {
	position: absolute;
	top: 12px;
	left: 12px;
	background: #e11d2e;
	color: #fff;
	font-weight: 800;
	font-size: 11px;
	padding: 6px 10px;
	border-radius: 6px;
	line-height: 1;
	box-shadow: 0 10px 22px rgba(0,0,0,.18);
}

/* Content */
.oai-news__content {
	padding: 18px 20px 16px;
}

.oai-news__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
	font-size: 12px;
	color: rgba(2,6,23,.55);
	margin-bottom: 8px;
}

.oai-news__title {
	margin: 0 0 10px;
	font-size: 18px;
	font-weight: 900;
	line-height: 1.25;
	color: rgba(2,6,23,.88);
}

.oai-news__title a {
	text-decoration: none;
	color: inherit;
}
.oai-news__title a:hover { color: #e11d2e; }

.oai-news__excerpt {
	margin: 0 0 14px;
	color: rgba(2,6,23,.65);
	font-size: 13px;
	line-height: 1.7;
}

/* Read more */
.oai-news__more {
	display: inline-flex;
	gap: 8px;
	align-items: center;
	color: #e11d2e;
	font-weight: 800;
	text-decoration: none;
	font-size: 13px;
}
.oai-news__more:hover { text-decoration: underline; }

/* Pagination */
.oai-news__pagination {
	margin-top: 26px;
	display: flex;
	justify-content: center;
}

.oai-news__pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 12px;
	margin: 0 4px;
	border-radius: 6px;
	border: 1px solid rgba(2,6,23,.08);
	background: #fff;
	color: rgba(2,6,23,.75);
	text-decoration: none;
	font-weight: 800;
	font-size: 13px;
	transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
}

.oai-news__pagination .page-numbers:hover {
	transform: translateY(-1px);
	border-color: rgba(225,29,46,.28);
	color: #e11d2e;
}

.oai-news__pagination .page-numbers.current {
	background: #e11d2e;
	border-color: #e11d2e;
	color: #fff;
}
.entry-category {
	display: none;
}
/* ===== Contact Section (namespace: oai-contact) ===== */
.oai-contact {
	--red: #e11d2e;
	--blue: #1f4f9a;
	--text: rgba(2,6,23,.86);
	--muted: rgba(2,6,23,.62);
	--border: rgba(2,6,23,.08);
	--shadow: 0 12px 28px rgba(15,23,42,.08);
	--shadow2: 0 18px 44px rgba(15,23,42,.14);
	--radius: 12px;
}

.oai-contact__head{
	text-align: center;
	margin-bottom: 26px;
}

.oai-contact__kicker{
	width: 72px;
	height: 3px;
	background: var(--red);
	border-radius: 999px;
	margin: 0 auto 12px;
}

.oai-contact__title{
	margin: 0 0 8px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .6px;
	font-size: clamp(20px, 2.3vw, 28px);
	color: var(--blue);
}

.oai-contact__desc{
	margin: 0 auto;
	max-width: 720px;
	font-size: 13px;
	line-height: 1.8;
	color: var(--muted);
}

/* Grid */
.oai-contact__grid{
	margin-top: 26px;
	display: grid;
	grid-template-columns: 1fr;
	gap: 28px;
}

@media (max-width: 980px){
	.oai-contact__grid{ grid-template-columns: 1fr; }
}

/* Card */
.oai-contact__card,
.div-text{
	position: relative;
	border-radius: var(--radius);
	background: #fff;
	border: 1px solid var(--border);
	box-shadow: var(--shadow);
	overflow: hidden;
	transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.div-text {
	border-radius: 20px;
	padding: 20px;
	margin-top: 30px;
}
.oai-contact__card:hover{
	transform: translateY(-6px);
	box-shadow: var(--shadow2);
	border-color: rgba(225,29,46,.18);
}

/* Gradient rim on hover */
.oai-contact__card::after{
	content:"";
	position:absolute;
	inset:0;
	border-radius: calc(var(--radius) + 2px);
	padding: 1px;
	background: linear-gradient(120deg,
		rgba(225,29,46,0),
		rgba(225,29,46,.55),
		rgba(31,79,154,.30),
		rgba(225,29,46,0));
	-webkit-mask:
		linear-gradient(#000 0 0) content-box,
		linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	opacity: 0;
	transition: opacity .3s ease;
	pointer-events: none;
}
.oai-contact__card:hover::after{ opacity: 1; }

.oai-contact__inner{
	padding: 22px 22px 18px;
}

.oai-contact__card-title{
	margin: 0 0 14px;
	font-weight: 900;
	font-size: 20px;
	color: var(--text);
}

.oai-contact__divider{
	height: 1px;
	background: rgba(2,6,23,.06);
	margin: 0 0 18px;
}

/* Left info rows */
.oai-contact__row{
	display:flex;
	gap: 14px;
	align-items:flex-start;
	padding: 10px 0;
}

.oai-contact__icon{
	width: 42px;
	height: 42px;
	border-radius: 999px;
	background: rgba(225,29,46,.10);
	display:flex;
	align-items:center;
	justify-content:center;
	flex: 0 0 42px;
	transition: transform .25s ease, background .25s ease;
	position: relative;
}

.oai-contact__card:hover .oai-contact__icon{
	transform: translateY(-1px) scale(1.03);
	background: rgba(225,29,46,.14);
}

.oai-contact__icon .material-icons{
	font-size: 20px;
	color: var(--red);
}

.oai-contact__label{
	font-weight: 800;
	font-size: 16px;
	color: var(--text);
	margin: 0 0 3px;
}

.oai-contact__value{
	margin: 0;
	font-size: 18px;
	color: var(--muted);
	line-height: 1.6;
}

.oai-contact__value a{
	color: var(--muted);
	text-decoration: none;
}
.oai-contact__value a:hover{ color: var(--red); }

.oai-contact__hotline a{
	color: var(--red);
	font-weight: 900;
}

/* Social */
.oai-contact__social-title{
	margin: 18px 0 10px;
	font-weight: 900;
	color: var(--text);
	font-size: 13px;
}

.oai-contact__social{
	display:flex;
	gap: 10px;
}

.oai-contact__social a{
	width: 36px;
	height: 36px;
	border-radius: 999px;
	display:flex;
	align-items:center;
	justify-content:center;
	border: 1px solid rgba(2,6,23,.08);
	background: #fff;
	box-shadow: 0 10px 22px rgba(15,23,42,.08);
	text-decoration:none;
	transition: transform .25s ease, background .25s ease, border-color .25s ease;
}

.oai-contact__social a:hover{
	transform: translateY(-2px);
	border-color: rgba(225,29,46,.22);
	background: rgba(225,29,46,.06);
}

.oai-contact__social .material-icons{
	font-size: 18px;
	color: var(--blue);
}

/* ===== CF7 style ===== */
.oai-contact .wpcf7{
	margin: 0;
}
.oai-contact .wpcf7 form{
	margin: 0;
}

.oai-contact .wpcf7 .wpcf7-form-control-wrap{
	display:block;
}

.oai-contact .wpcf7 label{
	display:block;
	font-size: 12px;
	font-weight: 800;
	color: var(--text);
	margin-bottom: 6px;
}

/* 2 cols on first row like screenshot */
.oai-contact__two{
	display:grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}
@media (max-width: 600px){
	.oai-contact__two{ grid-template-columns: 1fr; }
}

.oai-contact input[type="text"],
.oai-contact input[type="tel"],
.oai-contact input[type="email"],
.oai-contact select,
.oai-contact textarea{
	width: 100%;
	border-radius: 8px;
	border: 1px solid rgba(2,6,23,.14);
	padding: 11px 12px;
	height: unset;
	font-size: 13px;
	outline: none;
	transition: box-shadow .2s ease, border-color .2s ease, transform .2s ease;
	background: #fff;
}

.oai-contact textarea{ min-height: 110px; resize: vertical; }

.oai-contact input:focus,
.oai-contact select:focus,
.oai-contact textarea:focus{
	border-color: rgba(225,29,46,.45);
	box-shadow: 0 0 0 4px rgba(225,29,46,.14);
	transform: translateY(-1px);
}

/* Submit button full width */
.oai-contact .wpcf7-submit{
	width: 100%;
	margin-top: 10px;
	border: none;
	border-radius: 8px;
	padding: 12px 14px;
	background: var(--red);
	color: #fff;
	font-weight: 900;
	letter-spacing: .6px;
	text-transform: uppercase;
	cursor: pointer;
	box-shadow: 0 14px 30px rgba(225,29,46,.22);
	transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
}

.oai-contact .wpcf7-submit:hover{
	transform: translateY(-2px);
	box-shadow: 0 18px 44px rgba(225,29,46,.28);
	filter: brightness(.98);
}

/* CF7 messages */
.oai-contact .wpcf7-response-output{
	border-radius: 10px;
	border: 1px solid rgba(2,6,23,.10);
	padding: 12px 14px;
	margin: 14px 0 0;
}
.nav-dropdown-has-arrow li.current-dropdown.has-dropdown:after, .nav-dropdown-has-arrow li.current-dropdown.has-dropdown:before {
	opacity: 0 !important;
}
.sub-menu.nav-dropdown {
	--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
	--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
	background-color: rgb(255 255 255);
	border: 1px solid rgb(243 244 246);
	border-radius: 8px;
	padding: 0;
	overflow: hidden;
}
.sub-menu.nav-dropdown li {
	padding: 0;
	margin: 0;
}
.sub-menu.nav-dropdown li a {
    margin: 0;
    border-bottom: unset;
    padding: 8px 16px;
    font-size: 16px;
    line-height: 1.5;
    font-weight: 600;
    color: rgb(55 65 81);
    text-transform: uppercase;
    transition: all 0.3s ease;
}
.sub-menu.nav-dropdown li a:hover {
	color: var(--fs-color-main);
	background-color: rgb(249 250 251);
	transition: all 0.3s ease;
}
/* Responsive */
@media(max-width:1024px){
	.bds-features{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:849px) {
	.section {
		padding-top: 30px !important;
		padding-bottom: 30px !important;
	}
	.logogan-bottom div {
		flex-wrap: wrap;
		justify-content: center;
	}
	.logogan-bottom div span {
		width: 100%;
		display: block;
	}
	.logogan-bottom span {
		display: none;
	}
	.box-custom-image .col,
	.row-soluong .col{
		flex-basis: 50%;
		max-width: 50%;
		width: 50%;
	}
	.row-soluong .col:nth-child(1),
	.row-soluong .col:nth-child(2) {
		padding-bottom: 15px !important;
	}
	.title-why h2 {
		font-size: 16px;
		width: 90%;
		padding: 6px 11px;
		margin: 0 auto 24px;
	}
	.box-custom-image .col-inner a.button {
		padding: 6px 20px;
	}
	.title-all h2 {
		font-size: 20px;
		line-height: 30px;
		margin-bottom: 20px;
	}
	.title-all h2:before {
		top: -5px;
	}
	.header-button a{
		background-color: #e31e24;
	}
	.off-canvas-right .mfp-content, .off-canvas-left .mfp-content {
		background-color: #FFF;
	}
	.off-canvas .nav-vertical>li>a,
	.off-canvas .nav-vertical li li>a,
	.toggle i{
		color: #000;
	}
	.nav:not(.nav-slide) .active>.children {
		padding-bottom: 20px;
	}
	.nav:not(.nav-slide) .active>.children li a {
		font-size: 15px;
	}
	.logo-custom {
		padding: 0 !important;
		width: 100% !important;
	}
	.logo-custom img {
		width: 65%;
		margin: 0 auto;
	}
	.nav-sidebar.nav-vertical>li+li {
		border-top: unset;
	}
	.off-canvas .nav-vertical>li>a {
		padding-top: 10px;
		padding-bottom: 10px;
		font-size: 15px;
	}
	.html_nav_position_text {
		padding: 0 !important;
	}
	.btn-custom {
		padding: 8px 24px;
	}
}
@media(max-width:600px){
	.bds-features{grid-template-columns:1fr;}
}