﻿:root {
	--primary: #0ea5a4;
	--primary-dark: #0d9488;
	--primary2: #0284c7;
	--danger: #ef4444;
	--danger-bg: #fee2e2;
	--danger-border: #fecaca;
	--bg-body: #f6f7fb;
	--text: #0f172a;
	--muted: #64748b;
	--border: rgba(15,23,42,.10);
	--shadow: 0 14px 35px rgba(2,6,23,.10);
	--glass: rgba(255,255,255,.72);
	--glass2: rgba(255,255,255,.58);
	--glass-blur: blur(14px);
	--radius: 20px;
	--tap: 44px;
}

* {
	box-sizing: border-box
}

html {
	-webkit-text-size-adjust: 100%
}

body {
	margin: 0;
	font-family: 'Inter',system-ui,-apple-system,sans-serif;
	color: var(--text);
	background: radial-gradient(1000px 600px at 12% 10%, rgba(14,165,164,.14), transparent 60%), radial-gradient(900px 520px at 88% 18%, rgba(2,132,199,.10), transparent 55%), var(--bg-body);
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	overflow-x: hidden;
}

a {
	color: inherit;
	text-decoration: none
}

	a:focus-visible, button:focus-visible, input:focus-visible {
		outline: 3px solid rgba(14,165,164,.35);
		outline-offset: 2px;
		border-radius: 12px;
	}

.container {
	max-width: 1200px;
	margin: 0 auto;
	width: 100%;
	padding-left: max(1rem, env(safe-area-inset-left));
	padding-right: max(1rem, env(safe-area-inset-right));
}

/* ✅ Header rộng hơn main */
.header-container {
	max-width: 1440px
}

/* ================= BACK TO TOP ================= */
#backToTop {
	position: fixed;
	right: 18px;
	bottom: calc(18px + env(safe-area-inset-bottom));
	z-index: 2000;
	width: 46px;
	height: 46px;
	border-radius: 16px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.70);
	backdrop-filter: var(--glass-blur);
	-webkit-backdrop-filter: var(--glass-blur);
	box-shadow: var(--shadow);
	cursor: pointer;
	user-select: none;
	opacity: 0;
	transform: translateY(10px);
	pointer-events: none;
	transition: opacity .2s ease, transform .2s ease, background .2s ease;
}

	#backToTop:hover {
		background: rgba(255,255,255,.90);
		transform: translateY(6px)
	}

	#backToTop.show {
		opacity: 1;
		transform: translateY(0);
		pointer-events: auto
	}

	#backToTop svg {
		width: 20px;
		height: 20px;
		color: var(--primary-dark)
	}

/* ================= HEADER ================= */
header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: rgba(255,255,255,.72);
	backdrop-filter: var(--glass-blur);
	-webkit-backdrop-filter: var(--glass-blur);
	border-bottom: 1px solid var(--border);
}

.topbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	padding: .85rem 0;
	flex-wrap: nowrap;
}

.brand-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 6px 10px;
	border-radius: 14px;
	transition: .2s;
	flex: 1;
	min-width: 0;
}

	.brand-link:hover {
		background: rgba(14,165,164,.08)
	}

.brand-badge {
	width: 50px;
	height: 50px;
	border-radius: 14px;
	background: linear-gradient(135deg, rgba(14,165,164,.18), rgba(2,132,199,.12));
	border: 1px solid rgba(14,165,164,.18);
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	overflow: hidden;
}

	.brand-badge img {
		width: 100%;
		height: 100%;
		display: block;
		object-fit: contain;
		object-position: center;
		background: rgba(255,255,255,.75);
	}

.brand {
	min-width: 0
}

	.brand strong {
		font-size: clamp(1.1rem, 2.1vw, 1.55rem);
		color: var(--primary-dark);
		letter-spacing: -.2px;
		display: block;
		line-height: 1.2;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.brand span {
		font-size: clamp(.72rem, 1.2vw, .78rem);
		color: var(--muted);
		display: block;
		line-height: 1.2;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

/* nút menu: desktop ẩn */
.nav-toggle {
	display: none;
	width: var(--tap);
	height: var(--tap);
	border: 1px solid var(--border);
	background: rgba(255,255,255,.60);
	border-radius: 14px;
	cursor: pointer;
	font-weight: 900;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	touch-action: manipulation;
}

/* nav desktop */
nav.nav {
	display: flex;
	gap: .35rem;
	align-items: center;
	flex-wrap: wrap;
	justify-content: flex-end;
	margin-left: auto;
}

.nav-link {
	padding: .55rem .85rem;
	border-radius: 12px;
	font-weight: 850;
	transition: .2s;
}

	.nav-link:hover {
		background: rgba(14,165,164,.10);
		color: var(--primary-dark)
	}

	.nav-link.active {
		background: rgba(14,165,164,.14);
		color: var(--primary-dark);
		border: 1px solid rgba(14,165,164,.18);
	}

/* search */
.search {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 6px 8px;
	border-radius: 14px;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.55);
}

	.search input {
		border: 0;
		outline: none;
		background: transparent;
		width: 190px;
		max-width: 42vw;
		font-size: 14px;
		min-width: 0;
		flex: 1;
	}

.btn {
	padding: .58rem 1.05rem;
	border-radius: 12px;
	border: 1px solid var(--border);
	cursor: pointer;
	font-weight: 900;
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	transition: .18s ease;
	background: rgba(255,255,255,.55);
	touch-action: manipulation;
	min-height: 40px;
}

	.btn:hover {
		transform: translateY(-1px)
	}

	.btn.primary {
		background: var(--primary);
		color: #fff;
		border: none;
		box-shadow: 0 10px 18px rgba(14,165,164,.20);
	}

		.btn.primary:hover {
			background: var(--primary-dark)
		}

	.btn.danger {
		background: var(--danger-bg);
		color: var(--danger);
		border: 1px solid var(--danger-border);
	}

	.btn.sm {
		padding: .48rem .85rem;
		min-height: 36px
	}

	.btn.lg {
		padding: .85rem 1.4rem;
		min-height: 44px;
		border-radius: 14px
	}

.chip {
	padding: 8px 10px;
	border-radius: 999px;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.55);
	font-size: 13px;
	font-weight: 900;
	color: var(--primary-dark);
	max-width: 240px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* nav panel header inside mobile */
.nav-panel-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}

.nav-panel-title {
	font-weight: 1000;
	color: var(--primary-dark);
	letter-spacing: -.2px;
}

/* ================= MOBILE NAV PANEL + OVERLAY ================= */
.nav-overlay {
	position: fixed;
	inset: 0;
	background: rgba(2,6,23,.35);
	backdrop-filter: blur(2px);
	opacity: 0;
	pointer-events: none;
	transition: opacity .18s ease;
	z-index: 999;
}

	.nav-overlay.show {
		opacity: 1;
		pointer-events: auto
	}

/* ================= HERO ================= */
.slider {
	border-radius: 26px;
	overflow: hidden;
	box-shadow: var(--shadow);
	height: 460px;
	position: relative;
	background: #0b1220;
}

.slides {
	display: flex;
	height: 100%;
	animation: heroSlide 18s infinite ease-in-out;
	will-change: transform;
}

.slider:hover .slides,
.slider:focus-within .slides {
	animation-play-state: paused
}

.slide {
	flex: 0 0 100%;
	width: 100%;
	height: 100%;
	position: relative;
	display: flex;
	align-items: center;
	padding: 0 5%;
	overflow: hidden;
	background: #0b1220;
}

.slide-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: center;
	z-index: 1;
	transform: translateZ(0);
}

.slide::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(0,0,0,.76) 0%, rgba(0,0,0,.32) 58%, rgba(0,0,0,.08) 100%);
	z-index: 2;
}

.slide-content {
	position: relative;
	z-index: 3;
	color: #fff;
	max-width: 680px;
}

	.slide-content h2 {
		margin: 0 0 10px 0;
		font-size: clamp(1.6rem, 3.2vw, 2.5rem);
		line-height: 1.15;
		letter-spacing: -.5px;
	}

	.slide-content p {
		margin: 0 0 16px 0;
		opacity: .9;
		line-height: 1.7;
		font-size: clamp(.95rem, 1.4vw, 1.05rem);
	}

@keyframes heroSlide {
	0%,25% {
		transform: translateX(0%)
	}

	33%,58% {
		transform: translateX(-100%)
	}

	66%,91% {
		transform: translateX(-200%)
	}

	100% {
		transform: translateX(0%)
	}
}

/* prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
	.slides {
		animation: none !important
	}

	.btn:hover {
		transform: none
	}
}

@media (max-width:950px) {
	.slider {
		height: 340px;
		border-radius: 22px
	}

	.slide {
		padding: 0 18px
	}

		.slide::before {
			background: linear-gradient(180deg, rgba(0,0,0,.70) 0%, rgba(0,0,0,.40) 55%, rgba(0,0,0,.16) 100%);
		}

	.slide-content {
		max-width: 100%
	}

		.slide-content .btn {
			width: fit-content
		}
}

/* ================= MAIN ================= */
main {
	flex: 1;
	padding-bottom: 2.2rem
}

.surface {
	border-radius: 24px;
	padding: 1.4rem;
	background: rgba(255,255,255,.70);
	border: 1px solid var(--border);
	box-shadow: var(--shadow);
	backdrop-filter: var(--glass-blur);
	-webkit-backdrop-filter: var(--glass-blur);
}

/* ================= POSTS ================= */
.post-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0,1fr));
	gap: 16px;
}

.post-card {
	border-radius: 18px;
	overflow: hidden;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.62);
	box-shadow: 0 10px 22px rgba(2,6,23,.08);
	transition: .25s;
	display: flex;
	flex-direction: column;
}

	.post-card:hover {
		transform: translateY(-2px)
	}

.post-thumb {
	width: 100%;
	height: 170px;
	background: #e2e8f0;
	overflow: hidden
}

	.post-thumb img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		display: block;
		transform: scale(1.02)
	}

.post-body {
	padding: 14px 14px 16px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1;
}

.post-title {
	font-size: 1.02rem;
	font-weight: 900;
	letter-spacing: -.2px;
	margin: 0;
	line-height: 1.35;
}

.post-meta {
	font-size: 12px;
	color: var(--muted);
	font-weight: 800;
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.post-desc {
	color: #334155;
	line-height: 1.6;
	margin: 0;
	flex: 1
}

.post-actions {
	display: flex;
	gap: 10px;
	align-items: center;
	justify-content: space-between;
	margin-top: 6px;
}

/* badge dùng chung */
.badge {
	font-size: 12px;
	font-weight: 900;
	padding: 6px 10px;
	border-radius: 999px;
	background: rgba(14,165,164,.10);
	border: 1px solid rgba(14,165,164,.18);
	color: var(--primary-dark);
}

/* ================= LANDING ================= */
.section {
	margin-top: 14px
}

.features {
	display: grid;
	grid-template-columns: repeat(3, minmax(0,1fr));
	gap: 14px;
	margin-top: 14px;
}

.feature-card {
	border-radius: 18px;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.62);
	box-shadow: 0 10px 22px rgba(2,6,23,.08);
	padding: 14px 14px;
	display: flex;
	gap: 12px;
	align-items: flex-start;
}

.feature-ico {
	width: 44px;
	height: 44px;
	border-radius: 16px;
	background: linear-gradient(135deg, rgba(14,165,164,.18), rgba(2,132,199,.12));
	border: 1px solid rgba(14,165,164,.18);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	color: var(--primary-dark);
	flex: 0 0 auto;
}

.feature-title {
	font-weight: 900;
	margin: 0;
	letter-spacing: -.2px
}

.feature-desc {
	margin: 6px 0 0 0;
	color: #475569;
	line-height: 1.6
}

.doctors-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}

	.doctors-head h3 {
		margin: 0;
		letter-spacing: -.2px
	}

	.doctors-head p {
		margin: 6px 0 0 0;
		opacity: .75
	}

.doctor-controls {
	display: flex;
	gap: 10px;
	align-items: center
}

.icon-btn {
	width: var(--tap);
	height: var(--tap);
	border-radius: 14px;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.62);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	transition: .2s;
	touch-action: manipulation;
}

	.icon-btn:hover {
		transform: translateY(-1px)
	}

.doctor-track {
	display: flex;
	gap: 12px;
	overflow: auto;
	padding-bottom: 8px;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
}

	.doctor-track::-webkit-scrollbar {
		height: 8px
	}

	.doctor-track::-webkit-scrollbar-thumb {
		background: rgba(15,23,42,.12);
		border-radius: 999px
	}

.doctor-card {
	scroll-snap-align: start;
	min-width: 270px;
	border-radius: 18px;
	overflow: hidden;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.62);
	box-shadow: 0 10px 22px rgba(2,6,23,.08);
	display: flex;
	flex-direction: column;
}

.doctor-img {
	height: 160px;
	background: #e2e8f0
}

	.doctor-img img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		display: block
	}

.doctor-body {
	padding: 12px 12px 14px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.doctor-name {
	font-weight: 900;
	letter-spacing: -.2px
}

.doctor-meta {
	font-size: 12px;
	color: var(--muted);
	font-weight: 800;
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.doctor-cta {
	margin-top: 8px;
	display: flex;
	gap: 10px;
	flex-wrap: wrap
}

.cta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
}

	.cta h3 {
		margin: 0;
		letter-spacing: -.2px
	}

	.cta p {
		margin: 6px 0 0 0;
		opacity: .78;
		line-height: 1.6
	}

/* ================= FOOTER ================= */
footer {
	background: #0b1220;
	color: #e2e8f0;
	padding: 3rem 0 2.4rem;
	border-radius: 40px 40px 0 0;
	margin-top: 30px;
}

.footer-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	gap: 2.2rem;
}

.footer-title {
	color: #5eead4;
	font-size: 1.05rem;
	font-weight: 900;
	margin-bottom: 1rem;
}

.footer-item {
	line-height: 1.85;
	opacity: .85;
	font-size: .95rem;
}

	.footer-item a {
		color: #38bdf8
	}

		.footer-item a:hover {
			text-decoration: underline
		}

/* ================= RESPONSIVE ================= */
@media (max-width:950px) {
	.topbar {
		flex-wrap: wrap;
		gap: 10px;
		padding: .75rem 0;
	}

	.nav-toggle {
		display: inline-flex
	}

	nav.nav {
		position: fixed;
		top: 0;
		right: 0;
		height: 100vh;
		width: min(92vw, 420px);
		padding: 14px 14px calc(16px + env(safe-area-inset-bottom));
		background: rgba(255,255,255,.86);
		backdrop-filter: var(--glass-blur);
		-webkit-backdrop-filter: var(--glass-blur);
		border-left: 1px solid rgba(15,23,42,.10);
		box-shadow: -18px 0 40px rgba(2,6,23,.12);
		display: flex;
		flex-direction: column;
		align-items: stretch;
		justify-content: flex-start;
		gap: 10px;
		transform: translateX(105%);
		transition: transform .18s ease;
		z-index: 1001;
		overflow: auto;
		-webkit-overflow-scrolling: touch;
		margin-left: 0;
	}

		nav.nav.open {
			transform: translateX(0)
		}

	.nav-link {
		padding: 12px 12px;
		border-radius: 14px;
		font-size: 15px
	}

	.chip {
		max-width: 100%
	}

	.search {
		width: 100%
	}

		.search input {
			width: 100%;
			max-width: none
		}

	.post-grid {
		grid-template-columns: 1fr
	}

	.features {
		grid-template-columns: 1fr
	}

	.doctor-card {
		min-width: 78vw
	}

	.footer-grid {
		grid-template-columns: 1fr;
		text-align: center;
		gap: 1.6rem
	}
}

@media (max-width:1200px) and (min-width:951px) {
	.post-grid {
		grid-template-columns: repeat(2, minmax(0,1fr))
	}
}

/* ================= ZALO CHAT BUBBLE (LEFT) ================= */
.zalo-fab {
	position: fixed;
	left: 18px;
	bottom: calc(18px + env(safe-area-inset-bottom));
	z-index: 2500;
	display: flex;
	align-items: flex-end;
	gap: 10px;
}

	.zalo-fab .zalo-btn {
		width: 56px;
		height: 56px;
		border-radius: 18px;
		border: 1px solid var(--border);
		background: rgba(255,255,255,.78);
		backdrop-filter: var(--glass-blur);
		-webkit-backdrop-filter: var(--glass-blur);
		box-shadow: var(--shadow);
		display: inline-flex;
		align-items: center;
		justify-content: center;
		cursor: pointer;
		user-select: none;
		transition: transform .2s ease, background .2s ease;
		position: relative;
		overflow: hidden;
		touch-action: manipulation;
	}

		.zalo-fab .zalo-btn:hover {
			transform: translateY(-2px);
			background: rgba(255,255,255,.92);
		}

		.zalo-fab .zalo-btn img {
			width: 30px;
			height: 30px;
			display: block
		}

	.zalo-fab .zalo-ping::before {
		content: "";
		position: absolute;
		inset: 0;
		border-radius: 18px;
		box-shadow: 0 0 0 0 rgba(0,136,255,.25);
		animation: zaloPing 1.6s infinite;
	}
/* ✅ Desktop: ẩn header của mobile panel (Menu + nút ✕) */
.nav-panel-head {
	display: none !important;
}

/* ✅ Mobile: hiện header trong panel */
@media (max-width: 950px) {
	.nav-panel-head {
		display: flex !important;
	}
}

@keyframes zaloPing {
	0% {
		box-shadow: 0 0 0 0 rgba(0,136,255,.28)
	}

	70% {
		box-shadow: 0 0 0 18px rgba(0,136,255,0)
	}

	100% {
		box-shadow: 0 0 0 0 rgba(0,136,255,0)
	}
}

.zalo-fab .zalo-card {
	max-width: 300px;
	width: min(300px, calc(100vw - 120px));
	border-radius: 18px;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.82);
	backdrop-filter: var(--glass-blur);
	-webkit-backdrop-filter: var(--glass-blur);
	box-shadow: var(--shadow);
	padding: 12px 12px;
	transform-origin: left bottom;
	transform: scale(.96);
	opacity: 0;
	pointer-events: none;
	transition: opacity .18s ease, transform .18s ease;
}

	.zalo-fab .zalo-card.open {
		opacity: 1;
		transform: scale(1);
		pointer-events: auto;
	}

.zalo-card .t {
	font-weight: 1000;
	letter-spacing: -.2px;
	margin: 0
}

.zalo-card .d {
	margin: 6px 0 10px 0;
	color: var(--muted);
	font-weight: 700;
	line-height: 1.45;
	font-size: 13px;
}

.zalo-card .row {
	display: flex;
	gap: 10px;
	flex-wrap: wrap
}

.zalo-card .mini {
	padding: 9px 10px;
	border-radius: 12px;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.55);
	font-weight: 900;
	cursor: pointer;
	touch-action: manipulation;
}

	.zalo-card .mini.primary {
		background: var(--primary);
		color: #fff;
		border: none
	}

@media (max-width:950px) {
	.zalo-fab {
		left: 14px;
		bottom: calc(12px + env(safe-area-inset-bottom))
	}

		.zalo-fab .zalo-btn {
			width: 54px;
			height: 54px
		}
}
/* ===== Sponsors slider ===== */
.sponsors-section {
	margin: 14px auto 0;
}

.sponsors-surface {
	border-radius: 24px;
	padding: 16px 16px;
	background: rgba(255,255,255,0.70);
	border: 1px solid var(--border);
	box-shadow: var(--shadow);
	backdrop-filter: var(--glass-blur);
	-webkit-backdrop-filter: var(--glass-blur);
}

.sponsors-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}

	.sponsors-head h3 {
		margin: 0;
		letter-spacing: -.2px;
	}

	.sponsors-head p {
		margin: 6px 0 0 0;
		opacity: .75;
	}

.sponsors-strip {
	overflow: hidden;
	border-radius: 18px;
}

.sponsors-track {
	display: flex;
	gap: 12px;
	width: max-content;
	animation: sponsorsMarquee 22s linear infinite;
	will-change: transform;
	padding: 6px 2px;
}

.sponsors-strip:hover .sponsors-track {
	animation-play-state: paused;
}

.sponsor-item {
	width: 72px;
	height: 72px;
	border-radius: 18px;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.86);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 10px 20px rgba(2,6,23,.06);
	flex: 0 0 auto;
}

	.sponsor-item img {
		width: 46px;
		height: 46px;
		object-fit: contain;
		display: block;
	}

@keyframes sponsorsMarquee {
	from {
		transform: translateX(0);
	}

	to {
		transform: translateX(-50%);
	}
}

@media (prefers-reduced-motion: reduce) {
	.sponsors-track {
		animation: none;
	}
}
/* ===== Sponsors slider (FIX) ===== */
.sponsors-section {
  margin: 14px auto 0;
}

.sponsors-surface {
  border-radius: 24px;
  padding: 16px;
  background: rgba(255,255,255,.70);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
}

.sponsors-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.sponsors-head h3 { margin: 0; letter-spacing: -.2px; }
.sponsors-head p  { margin: 6px 0 0 0; opacity: .75; }

.sponsors-strip {
  overflow: hidden;
  border-radius: 18px;
}

.sponsors-track {
  display: flex;
  flex-wrap: nowrap;
  gap: 12px;
  width: max-content;
  padding: 8px 2px;
  will-change: transform;

  /* ép chạy animation */
  animation: sponsorsMarquee 20s linear infinite !important;
  transform: translate3d(0,0,0);
}

/* tạm thời bỏ pause để test (sau chạy ok muốn pause thì thêm lại) */
/* .sponsors-strip:hover .sponsors-track { animation-play-state: paused; } */

.sponsor-item {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.86);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 20px rgba(2,6,23,.06);
  flex: 0 0 auto;
}

.sponsor-item img {
  width: 34px !important;
  height: 34px !important;
  max-width: 34px !important;
  max-height: 34px !important;
  object-fit: contain;
  display: block;
}

/* chạy -50% vì bạn đã duplicate set 2 lần */
@keyframes sponsorsMarquee {
  from { transform: translate3d(0,0,0); }
  to   { transform: translate3d(-50%,0,0); }
}

/* ===== SPONSORS OVERRIDE (PASTE LAST) ===== */
.sponsors-section {
	margin: 14px 0 0;
}

.sponsors-surface {
	border-radius: 24px;
	padding: 16px;
	background: rgba(255,255,255,.70);
	border: 1px solid var(--border);
	box-shadow: var(--shadow);
	backdrop-filter: var(--glass-blur);
	-webkit-backdrop-filter: var(--glass-blur);
}

.sponsors-strip {
	overflow: hidden;
	border-radius: 18px;
}

.sponsors-track {
	display: flex !important;
	flex-wrap: nowrap !important;
	gap: 12px;
	width: max-content !important;
	padding: 8px 2px;
	animation: sponsorsMarquee 18s linear infinite !important;
	will-change: transform;
	transform: translate3d(0,0,0);
}

.sponsor-item {
	width: 64px !important;
	height: 64px !important;
	border-radius: 18px;
	border: 1px solid var(--border);
	background: rgba(255,255,255,.86);
	display: flex !important;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto !important;
	overflow: hidden; /* ✅ chặn SVG phình */
}

	.sponsor-item img {
		width: 34px !important;
		height: 34px !important;
		max-width: 34px !important;
		max-height: 34px !important;
		object-fit: contain !important;
		display: block !important;
	}

/* chạy -50% vì bạn đã duplicate 2 lần */
@keyframes sponsorsMarquee {
	from {
		transform: translate3d(0,0,0);
	}

	to {
		transform: translate3d(-50%,0,0);
	}
}

/* ✅ nếu máy bạn đang bật “Reduce motion”, vẫn ép chạy */
@media (prefers-reduced-motion: reduce) {
	.sponsors-track {
		animation: sponsorsMarquee 18s linear infinite !important;
	}
}
