/* WM Landing — luxury wood interior (public) */

:root {
	--wm-wood: #5c4033;
	--wm-wood-dark: #3d2a22;
	--wm-wood-light: #8b6914;
	--wm-cream: #f7f3ed;
	--wm-cream-dark: #ebe4d8;
	--wm-charcoal: #1c1917;
	--wm-charcoal-soft: #292524;
	--wm-text: #44403c;
	--wm-text-muted: #78716c;
	--wm-white: #fafaf9;
	--wm-gold: #b8860b;
	--wm-header-h: 72px;
	--wm-radius: 12px;
	--wm-radius-lg: 16px;
	--wm-shadow: 0 8px 32px rgba(28, 25, 23, 0.08);
	--wm-shadow-hover: 0 16px 48px rgba(28, 25, 23, 0.12);
	--wm-transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

html {
	scroll-behavior: smooth;
}

body.wm-landing-public {
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	color: var(--wm-text);
	background: var(--wm-white);
	line-height: 1.6;
	overflow-x: hidden;
}

/* Header */
.wm-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1030;
	transition: background var(--wm-transition), box-shadow var(--wm-transition), padding var(--wm-transition);
}

.wm-header .navbar {
	padding: 1rem 0;
	transition: padding var(--wm-transition);
}

.wm-header--scrolled {
	background: rgba(255, 255, 255, 0.97);
	box-shadow: 0 1px 0 rgba(28, 25, 23, 0.06), 0 4px 24px rgba(28, 25, 23, 0.06);
	backdrop-filter: blur(12px);
}

.wm-header--scrolled .navbar {
	padding: 0.6rem 0;
}

.wm-header:not(.wm-header--scrolled) .navbar-brand,
.wm-header:not(.wm-header--scrolled) .wm-nav-links .nav-link,
.wm-header:not(.wm-header--scrolled) .wm-hotline {
	color: var(--wm-white);
}

.wm-header:not(.wm-header--scrolled) .wm-nav-toggler {
	border-color: rgba(255, 255, 255, 0.4);
}

.wm-header:not(.wm-header--scrolled) .navbar-toggler-icon {
	filter: invert(1);
}

.wm-header--scrolled .navbar-brand,
.wm-header--scrolled .wm-nav-links .nav-link,
.wm-header--scrolled .wm-hotline {
	color: var(--wm-charcoal);
}

.wm-brand-text {
	font-weight: 600;
	letter-spacing: 0.02em;
	font-size: 1.1rem;
}

.wm-brand-logo {
	max-height: 48px;
	height: 48px;
	width: auto;
	max-width: 160px;
	object-fit: contain;
}

.wm-nav-links .nav-link {
	font-size: 0.9rem;
	font-weight: 500;
	padding: 0.5rem 1rem !important;
	transition: color 0.2s ease, opacity 0.2s ease;
}

.wm-nav-links .nav-link:hover {
	opacity: 0.75;
}

.wm-hotline {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: 600;
	font-size: 0.9rem;
	text-decoration: none;
	white-space: nowrap;
}

.wm-hotline:hover {
	opacity: 0.85;
}

/* Buttons */
.btn-wm-login {
	border: 1.5px solid rgba(255, 255, 255, 0.9);
	color: var(--wm-wood-dark);
	background: rgba(255, 255, 255, 0.96);
	font-weight: 600;
	font-size: 0.875rem;
	padding: 0.45rem 1.1rem;
	border-radius: 999px;
	text-decoration: none;
	white-space: nowrap;
	box-shadow: 0 2px 12px rgba(28, 25, 23, 0.12);
	transition: background var(--wm-transition), color var(--wm-transition), border-color var(--wm-transition), box-shadow var(--wm-transition);
}

.btn-wm-login:hover,
.btn-wm-login:focus {
	background: #fff;
	color: var(--wm-wood);
	border-color: #fff;
	box-shadow: 0 4px 16px rgba(28, 25, 23, 0.16);
}

.wm-header--scrolled .btn-wm-login {
	border-color: var(--wm-wood);
	color: var(--wm-wood);
	background: var(--wm-cream);
	box-shadow: 0 1px 8px rgba(28, 25, 23, 0.08);
}

.wm-header--scrolled .btn-wm-login:hover,
.wm-header--scrolled .btn-wm-login:focus {
	background: var(--wm-wood);
	color: var(--wm-white);
	border-color: var(--wm-wood);
	box-shadow: 0 4px 16px rgba(61, 42, 34, 0.2);
}

.btn-wm-primary {
	background: var(--wm-wood);
	border-color: var(--wm-wood);
	color: var(--wm-white);
	font-weight: 600;
	padding: 0.6rem 1.5rem;
	border-radius: 999px;
	transition: background var(--wm-transition), transform 0.2s ease, box-shadow 0.2s ease;
}

.btn-wm-primary:hover,
.btn-wm-primary:focus {
	background: var(--wm-wood-dark);
	border-color: var(--wm-wood-dark);
	color: var(--wm-white);
	transform: translateY(-1px);
	box-shadow: 0 6px 20px rgba(92, 64, 51, 0.35);
}

.btn-wm-outline {
	border: 2px solid rgba(255, 255, 255, 0.85);
	color: var(--wm-white);
	background: transparent;
	font-weight: 600;
	padding: 0.6rem 1.5rem;
	border-radius: 999px;
	transition: background var(--wm-transition), color var(--wm-transition);
}

.btn-wm-outline:hover {
	background: var(--wm-white);
	color: var(--wm-charcoal);
	border-color: var(--wm-white);
}

.wm-header--scrolled .btn-wm-outline {
	border-color: var(--wm-wood);
	color: var(--wm-wood);
}

.wm-header--scrolled .btn-wm-outline:hover {
	background: var(--wm-wood);
	color: var(--wm-white);
}

/* Hero */
.wm-hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	padding: calc(var(--wm-header-h) + 3rem) 0 4rem;
	background: var(--wm-charcoal) center / cover no-repeat;
	background-image: var(--wm-hero-bg, none);
}

.wm-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		135deg,
		rgba(28, 25, 23, 0.75) 0%,
		rgba(61, 42, 34, 0.55) 50%,
		rgba(28, 25, 23, 0.65) 100%
	);
}

.wm-hero-overlay {
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse at 30% 50%, rgba(184, 134, 11, 0.08) 0%, transparent 60%);
	pointer-events: none;
}

.wm-hero-inner {
	position: relative;
	z-index: 1;
	max-width: 720px;
}

.wm-hero-kicker {
	text-transform: uppercase;
	letter-spacing: 0.2em;
	font-size: 0.75rem;
	color: var(--wm-gold);
	margin-bottom: 1rem;
	font-weight: 600;
}

.wm-hero-title {
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 700;
	color: var(--wm-white);
	line-height: 1.15;
	margin-bottom: 1.25rem;
	letter-spacing: -0.02em;
}

.wm-hero-lead {
	font-size: 1.125rem;
	color: rgba(250, 250, 249, 0.88);
	margin-bottom: 2rem;
	max-width: 540px;
}

/* Sections */
.wm-section {
	padding: 5rem 0;
}

.bg-wm-cream {
	background: var(--wm-cream);
}

.wm-section-label {
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-size: 0.7rem;
	font-weight: 700;
	color: var(--wm-gold);
	margin-bottom: 0.75rem;
}

.wm-section-title {
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--wm-charcoal);
	letter-spacing: -0.02em;
	margin-bottom: 1rem;
}

.wm-about-text {
	font-size: 1.05rem;
	line-height: 1.75;
}

.wm-about-slider-wrap {
	border-radius: var(--wm-radius-lg);
	overflow: hidden;
	box-shadow: var(--wm-shadow);
	background: var(--wm-charcoal);
}

.wm-about-swiper {
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 3;
}

.wm-about-swiper-pagination {
	position: absolute;
	bottom: 0.75rem;
	left: 0;
	right: 0;
	z-index: 2;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.35rem;
	padding: 0;
	margin: 0;
	pointer-events: none;
}

.wm-about-swiper-pagination .swiper-pagination-bullet {
	pointer-events: auto;
	width: 8px;
	height: 8px;
	margin: 0 !important;
	background: rgba(255, 255, 255, 0.55);
	opacity: 1;
	transition: transform 0.2s ease, background 0.2s ease;
}

.wm-about-swiper-pagination .swiper-pagination-bullet-active {
	background: #fff;
	transform: scale(1.15);
}

.wm-about-swiper .swiper-slide {
	height: auto;
}

.wm-about-slide {
	display: block;
	width: 100%;
	height: 100%;
}

.wm-about-slide img {
	display: block;
	width: 100%;
	height: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	transition: transform 0.6s ease;
}

.wm-about-slide:hover img {
	transform: scale(1.04);
}

/* Service cards */
.wm-service-card,
.wm-project-card {
	background: var(--wm-white);
	border-radius: var(--wm-radius-lg);
	overflow: hidden;
	box-shadow: var(--wm-shadow);
	cursor: pointer;
	transition: transform var(--wm-transition), box-shadow var(--wm-transition);
	border: none;
}

.wm-service-card:hover,
.wm-project-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--wm-shadow-hover);
}

.wm-service-card-img,
.wm-project-card-img {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--wm-cream-dark);
}

.wm-service-card-img img,
.wm-project-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
}

.wm-service-card:hover .wm-service-card-img img,
.wm-project-card:hover .wm-project-card-img img {
	transform: scale(1.06);
}

.wm-service-card-body,
.wm-project-card-body {
	padding: 1.5rem;
}

.wm-service-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 10px;
	background: var(--wm-cream);
	color: var(--wm-wood);
	font-size: 1.1rem;
	margin-bottom: 0.75rem;
}

.wm-project-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
}

/* Projects, services & videos sliders — mobile full width; desktop trong container */
.wm-projects-slider-outer,
.wm-services-slider-outer,
.wm-videos-slider-outer {
	display: flex;
	align-items: center;
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0;
	gap: 0.5rem;
}

.wm-projects-slider-wrap,
.wm-services-slider-wrap,
.wm-videos-slider-wrap {
	position: relative;
	flex: 1;
	min-width: 0;
	padding: 0;
	margin: 0;
}

.wm-projects-swiper,
.wm-services-swiper,
.wm-videos-swiper {
	overflow: hidden;
	width: 100%;
	padding: 0;
	margin: 0;
}

.wm-projects-swiper .swiper-wrapper,
.wm-services-swiper .swiper-wrapper,
.wm-videos-swiper .swiper-wrapper {
	align-items: stretch;
}

.wm-projects-swiper .swiper-slide,
.wm-services-swiper .swiper-slide,
.wm-videos-swiper .swiper-slide {
	display: flex;
	height: auto;
	box-sizing: border-box;
}

.wm-projects-swiper .swiper-slide .wm-project-card,
.wm-services-swiper .swiper-slide .wm-service-card,
.wm-videos-swiper .swiper-slide .wm-video-card {
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 100%;
	height: 100%;
}

.wm-projects-swiper .wm-project-card-img,
.wm-services-swiper .wm-service-card-img,
.wm-videos-swiper .wm-video-card__thumb {
	flex-shrink: 0;
}

.wm-projects-swiper .wm-project-card-body,
.wm-services-swiper .wm-service-card-body,
.wm-videos-swiper .wm-video-card__body {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	min-height: 0;
}

.wm-projects-swiper .wm-project-card-title,
.wm-services-swiper .wm-service-card-title,
.wm-videos-swiper .wm-video-card__title {
	flex-shrink: 0;
}

.wm-projects-swiper .wm-project-card-desc,
.wm-services-swiper .wm-service-card-desc,
.wm-videos-swiper .wm-video-card__desc {
	flex-shrink: 0;
}

.wm-projects-swiper .wm-project-meta,
.wm-services-swiper .wm-service-icon {
	flex-shrink: 0;
}

.wm-projects-swiper .wm-card-link,
.wm-services-swiper .wm-card-link {
	margin-top: auto;
	flex-shrink: 0;
}

.wm-projects-swiper-prev,
.wm-projects-swiper-next,
.wm-services-swiper-prev,
.wm-services-swiper-next,
.wm-videos-swiper-prev,
.wm-videos-swiper-next {
	position: relative;
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	left: auto;
	right: auto;
	top: auto;
	margin: 0;
	transform: none;
	color: var(--wm-wood);
	width: 40px;
	height: 40px;
	background: var(--wm-white);
	border-radius: 50%;
	box-shadow: var(--wm-shadow);
}

.wm-projects-swiper-prev::after,
.wm-projects-swiper-next::after,
.wm-services-swiper-prev::after,
.wm-services-swiper-next::after,
.wm-videos-swiper-prev::after,
.wm-videos-swiper-next::after {
	font-size: 1rem;
	font-weight: 700;
}

.wm-projects-swiper-prev.swiper-button-disabled,
.wm-projects-swiper-next.swiper-button-disabled,
.wm-services-swiper-prev.swiper-button-disabled,
.wm-services-swiper-next.swiper-button-disabled,
.wm-videos-swiper-prev.swiper-button-disabled,
.wm-videos-swiper-next.swiper-button-disabled {
	opacity: 0.35;
}

/* Mobile: lưới 2×2 (chỉ trong slider mobile) */
.wm-projects-slider-outer--mobile .wm-projects-grid-mobile,
.wm-services-slider-outer--mobile .wm-services-grid-mobile,
.wm-videos-slider-outer--mobile .wm-videos-grid-mobile {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	grid-template-rows: repeat(2, auto);
	gap: 10px;
	width: 100%;
	justify-content: start;
	align-content: start;
}

.wm-projects-slider-outer--mobile .wm-projects-grid-mobile[data-count="4"],
.wm-services-slider-outer--mobile .wm-services-grid-mobile[data-count="4"],
.wm-videos-slider-outer--mobile .wm-videos-grid-mobile[data-count="4"] {
	grid-auto-flow: row;
}

.wm-projects-slider-outer--mobile .wm-projects-grid-mobile[data-count="1"],
.wm-projects-slider-outer--mobile .wm-projects-grid-mobile[data-count="2"],
.wm-projects-slider-outer--mobile .wm-projects-grid-mobile[data-count="3"],
.wm-services-slider-outer--mobile .wm-services-grid-mobile[data-count="1"],
.wm-services-slider-outer--mobile .wm-services-grid-mobile[data-count="2"],
.wm-services-slider-outer--mobile .wm-services-grid-mobile[data-count="3"],
.wm-videos-slider-outer--mobile .wm-videos-grid-mobile[data-count="1"],
.wm-videos-slider-outer--mobile .wm-videos-grid-mobile[data-count="2"],
.wm-videos-slider-outer--mobile .wm-videos-grid-mobile[data-count="3"] {
	grid-auto-flow: column;
}

.wm-projects-slider-outer--mobile .wm-projects-grid-mobile .wm-project-card,
.wm-services-slider-outer--mobile .wm-services-grid-mobile .wm-service-card,
.wm-videos-slider-outer--mobile .wm-videos-grid-mobile .wm-video-card {
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 100%;
	height: 100%;
}

/* Desktop video: lưới 3×2 (tối đa 6 video / slide) */
.wm-videos-slider-outer--desktop .wm-videos-grid-desktop {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	grid-template-rows: repeat(2, auto);
	gap: 20px;
	width: 100%;
	justify-content: start;
	align-content: start;
}

.wm-videos-slider-outer--desktop .wm-videos-grid-desktop[data-count="6"],
.wm-videos-slider-outer--desktop .wm-videos-grid-desktop[data-count="4"],
.wm-videos-slider-outer--desktop .wm-videos-grid-desktop[data-count="5"] {
	grid-auto-flow: row;
}

.wm-videos-slider-outer--desktop .wm-videos-grid-desktop[data-count="1"],
.wm-videos-slider-outer--desktop .wm-videos-grid-desktop[data-count="2"],
.wm-videos-slider-outer--desktop .wm-videos-grid-desktop[data-count="3"] {
	grid-auto-flow: column;
}

.wm-videos-slider-outer--desktop .wm-videos-grid-desktop .wm-video-card {
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 100%;
	height: 100%;
}

/* < 6 video: lưới tĩnh (mobile 2 cột, desktop 3 cột), không slider */
.wm-videos-grid-static {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	width: 100%;
	justify-content: start;
	align-content: start;
}

.wm-videos-grid-static[data-count="4"],
.wm-videos-grid-static[data-count="5"],
.wm-videos-grid-static[data-count="6"],
.wm-videos-grid-static[data-count="7"] {
	grid-auto-flow: row;
}

.wm-videos-grid-static[data-count="1"],
.wm-videos-grid-static[data-count="2"],
.wm-videos-grid-static[data-count="3"] {
	grid-auto-flow: column;
}

.wm-videos-grid-static .wm-video-card {
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 100%;
	height: 100%;
}

@media (min-width: 992px) {
	.wm-videos-grid-static {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 20px;
		max-width: 960px;
		margin-left: auto;
		margin-right: auto;
	}
}

@media (min-width: 1200px) {
	.wm-videos-grid-static {
		max-width: 1140px;
	}
}

@media (min-width: 1400px) {
	.wm-videos-grid-static {
		max-width: 1320px;
	}
}

/* Đảm bảo đúng slider theo breakpoint (Bootstrap d-lg-* dự phòng) */
@media (min-width: 992px) {
	.wm-projects-slider-outer--mobile,
	.wm-services-slider-outer--mobile,
	.wm-videos-slider-outer--mobile {
		display: none !important;
	}

	.wm-projects-slider-outer--desktop,
	.wm-services-slider-outer--desktop,
	.wm-videos-slider-outer--desktop {
		display: flex !important;
	}
}

@media (max-width: 991.98px) {
	.wm-projects-slider-outer--desktop,
	.wm-services-slider-outer--desktop,
	.wm-videos-slider-outer--desktop {
		display: none !important;
	}
}

@media (min-width: 992px) {
	.wm-projects-slider-outer--desktop,
	.wm-services-slider-outer--desktop,
	.wm-videos-slider-outer--desktop {
		gap: 0.75rem;
		width: 100%;
		max-width: 960px;
		margin-left: auto;
		margin-right: auto;
		padding-left: calc(var(--bs-gutter-x, 1.5rem) * 0.5);
		padding-right: calc(var(--bs-gutter-x, 1.5rem) * 0.5);
		box-sizing: border-box;
	}

	.wm-projects-swiper-prev,
	.wm-projects-swiper-next,
	.wm-services-swiper-prev,
	.wm-services-swiper-next,
	.wm-videos-swiper-prev,
	.wm-videos-swiper-next {
		width: 44px;
		height: 44px;
	}

	.wm-projects-swiper-prev::after,
	.wm-projects-swiper-next::after,
	.wm-services-swiper-prev::after,
	.wm-services-swiper-next::after,
	.wm-videos-swiper-prev::after,
	.wm-videos-swiper-next::after {
		font-size: 1.125rem;
	}
}

@media (min-width: 1200px) {
	.wm-projects-slider-outer--desktop,
	.wm-services-slider-outer--desktop,
	.wm-videos-slider-outer--desktop {
		max-width: 1140px;
	}
}

@media (min-width: 1400px) {
	.wm-projects-slider-outer--desktop,
	.wm-services-slider-outer--desktop,
	.wm-videos-slider-outer--desktop {
		max-width: 1320px;
	}
}

@media (max-width: 991.98px) {
	.wm-projects-swiper-prev,
	.wm-projects-swiper-next,
	.wm-services-swiper-prev,
	.wm-services-swiper-next,
	.wm-videos-swiper-prev,
	.wm-videos-swiper-next {
		width: 32px;
		height: 32px;
	}

	.wm-projects-swiper-prev::after,
	.wm-projects-swiper-next::after,
	.wm-services-swiper-prev::after,
	.wm-services-swiper-next::after,
	.wm-videos-swiper-prev::after,
	.wm-videos-swiper-next::after {
		font-size: 0.8125rem;
	}

	.wm-projects-swiper .wm-project-card-img,
	.wm-services-swiper .wm-service-card-img,
	.wm-videos-swiper .wm-video-card__thumb,
	.wm-videos-grid-static .wm-video-card__thumb {
		aspect-ratio: 1 / 1;
		min-height: 0;
	}

	@supports not (aspect-ratio: 1 / 1) {
		.wm-videos-swiper .wm-video-card__thumb::before,
		.wm-videos-grid-static .wm-video-card__thumb::before {
			padding-top: 100%;
		}
	}
}

@media (max-width: 767.98px) {
	.wm-project-card-desc,
	.wm-service-card-desc,
	.wm-video-card__desc {
		display: none !important;
	}

	.wm-projects-swiper .wm-project-card-body,
	.wm-services-swiper .wm-service-card-body,
	.wm-videos-swiper .wm-video-card__body,
	.wm-videos-grid-static .wm-video-card__body {
		padding: 0.75rem 0.65rem;
	}

	.wm-projects-swiper .wm-project-card-title,
	.wm-services-swiper .wm-service-card-title,
	.wm-videos-swiper .wm-video-card__title,
	.wm-videos-grid-static .wm-video-card__title {
		font-size: 0.8125rem;
		margin-bottom: 0.25rem;
		line-height: 1.35;
	}

	.wm-projects-swiper .wm-project-meta {
		gap: 0.35rem;
		font-size: 0.7rem;
	}

	.wm-projects-swiper .wm-project-meta span {
		display: block;
	}

	.wm-services-swiper .wm-service-icon {
		width: 32px;
		height: 32px;
		font-size: 0.95rem;
		margin-bottom: 0.35rem;
	}

	.wm-projects-swiper .wm-card-link,
	.wm-services-swiper .wm-card-link {
		display: none;
	}

	.wm-videos-swiper .wm-video-card__title {
		font-size: 0.8125rem;
		line-height: 1.35;
	}

	.wm-videos-swiper .wm-video-card__play {
		font-size: 2.25rem;
	}
}

.wm-card-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	margin-top: 0.75rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--wm-wood);
}

/* Gallery — tối đa 8 hình: mobile 2 cột, tablet+ 4 cột × 2 hàng */
.wm-gallery-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	grid-auto-rows: auto;
	gap: 0.5rem;
}

@media (min-width: 576px) {
	.wm-gallery-grid {
		gap: 0.75rem;
	}
}

@media (min-width: 768px) {
	.wm-gallery-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		grid-template-rows: repeat(2, auto);
		gap: 1rem;
	}
}

.wm-gallery-item {
	position: relative;
	display: block;
	border-radius: var(--wm-radius);
	overflow: hidden;
	aspect-ratio: 1;
	box-shadow: var(--wm-shadow);
}

.wm-gallery-item--hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.wm-gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
}

.wm-gallery-item:hover img {
	transform: scale(1.08);
}

.wm-gallery-item--more::after {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(28, 25, 23, 0.45);
	pointer-events: none;
	transition: background 0.3s ease;
}

.wm-gallery-item--more:hover::after {
	background: rgba(28, 25, 23, 0.55);
}

.wm-gallery-more {
	position: absolute;
	inset: 0;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: clamp(1.5rem, 4vw, 2rem);
	font-weight: 700;
	color: var(--wm-white);
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
	pointer-events: none;
}

/* Videos */
.wm-video-card {
	background: #fff;
	border-radius: var(--wm-radius);
	overflow: hidden;
	box-shadow: var(--wm-shadow);
	cursor: pointer;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.wm-video-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(44, 36, 28, 0.12);
}

.wm-video-card__thumb {
	display: block;
	position: relative;
	width: 100%;
	flex: 0 0 auto;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #1a1a1a;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
}

/* Safari iOS cũ: aspect-ratio chưa hỗ trợ → chiều cao thumb = 0, chỉ thấy chữ */
@supports not (aspect-ratio: 16 / 9) {
	.wm-video-card__thumb::before {
		content: '';
		display: block;
		padding-top: 56.25%;
	}
}

.wm-video-card__thumb img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.45s ease;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
}

.wm-video-card:hover .wm-video-card__thumb img {
	transform: scale(1.05);
}

.wm-video-card__play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.28);
	color: #fff;
	font-size: 3rem;
	line-height: 1;
	transition: background 0.25s ease;
}

.wm-video-card:hover .wm-video-card__play {
	background: rgba(0, 0, 0, 0.4);
}

.wm-video-card__badge {
	position: absolute;
	top: 0.65rem;
	right: 0.65rem;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	background: none;
	border: 0;
	line-height: 0;
}

.wm-video-card__badge .wm-video-card__platform-icon {
	display: block;
	width: 26px;
	height: 26px;
	object-fit: contain;
	filter: drop-shadow(0 1px 4px rgba(0, 0, 0, 0.35));
}

.wm-video-card__body {
	display: block;
	padding: 1rem 1.1rem 1.15rem;
}

.wm-video-card__title {
	display: block;
	font-weight: 600;
	color: var(--wm-charcoal);
	line-height: 1.35;
}

.wm-video-card__desc {
	display: block;
	margin-top: 0.35rem;
}

.wm-video-modal .modal-content {
	border: none;
	border-radius: var(--wm-radius);
	overflow: hidden;
}

.wm-video-modal-embed {
	min-height: 200px;
}

.wm-video-modal-embed .ratio iframe {
	width: 100%;
	height: 100%;
	border: 0;
}

.wm-video-modal-embed--tiktok {
	display: flex;
	justify-content: center;
	padding: 0.5rem 0;
}

/* Contact */
.wm-contact-list li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 1rem;
	font-size: 1rem;
}

.wm-contact-list i {
	color: var(--wm-wood);
	font-size: 1.1rem;
	margin-top: 0.15rem;
}

.wm-contact-list a {
	color: var(--wm-text);
	text-decoration: none;
}

.wm-contact-list a:hover {
	color: var(--wm-wood);
}

.wm-social {
	display: flex;
	gap: 0.75rem;
	margin-top: 1.5rem;
}

.wm-social a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--wm-cream);
	color: var(--wm-wood);
	font-size: 1.15rem;
	transition: background var(--wm-transition), color var(--wm-transition);
}

.wm-social a:hover {
	background: var(--wm-wood);
	color: var(--wm-white);
}

.wm-social a.wm-social-zalo,
.wm-social a.wm-social-brand {
	background: transparent;
	padding: 0;
}

.wm-social a.wm-social-zalo:hover,
.wm-social a.wm-social-brand:hover {
	background: transparent;
	color: inherit;
	transform: scale(1.06);
}

.wm-social a.wm-social-zalo .wm-icon-brand,
.wm-social a.wm-social-brand .wm-icon-brand {
	display: block;
	width: 30px;
	height: 30px;
	object-fit: contain;
}

.wm-map {
	border-radius: var(--wm-radius-lg);
	overflow: hidden;
	box-shadow: var(--wm-shadow);
}

.wm-map iframe {
	border: 0;
}

/* Footer */
.wm-footer {
	background: var(--wm-charcoal);
	color: var(--wm-white);
}

.wm-footer a {
	color: rgba(250, 250, 249, 0.7);
	text-decoration: none;
	transition: color 0.2s ease;
}

.wm-footer a:hover {
	color: var(--wm-white);
}

.wm-footer-aside-inner {
	display: flex;
	gap: 1.5rem;
	align-items: flex-start;
}

.wm-footer-contact-col,
.wm-footer-links-col {
	min-width: 0;
}

@media (min-width: 992px) {
	.wm-footer-contact-col {
		flex: 4 1 0;
	}

	.wm-footer-links-col {
		flex: 3 1 0;
	}
}

@media (max-width: 991.98px) {
	.wm-footer-aside-inner {
		display: grid;
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		gap: 0.75rem;
	}

	.wm-footer-contact-col .wm-footer-contact li {
		overflow-wrap: anywhere;
		word-break: break-word;
	}

	.wm-footer-links-col ul li + li {
		margin-top: 0.35rem;
	}
}

/* Modals & Swiper */
.wm-detail-modal .modal-content {
	border: none;
	border-radius: var(--wm-radius-lg);
	overflow: hidden;
}

.wm-detail-swiper {
	border-radius: var(--wm-radius);
	overflow: hidden;
	margin-top: 1rem;
}

.wm-detail-swiper .swiper-slide img {
	width: 100%;
	max-height: 420px;
	object-fit: cover;
	display: block;
}

.wm-detail-swiper .swiper-button-prev,
.wm-detail-swiper .swiper-button-next {
	color: var(--wm-wood);
}

.wm-detail-swiper .swiper-pagination-bullet-active {
	background: var(--wm-wood);
}

/* Scroll reveal */
.wm-reveal {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

.wm-reveal.wm-reveal--visible {
	opacity: 1;
	transform: translateY(0);
}

.wm-reveal-delay {
	transition-delay: 0.15s;
}

/* Mobile */
@media (max-width: 991.98px) {
	.wm-header {
		background: rgba(255, 255, 255, 0.98);
		box-shadow: 0 1px 0 rgba(28, 25, 23, 0.06), 0 4px 20px rgba(28, 25, 23, 0.08);
		backdrop-filter: blur(12px);
		-webkit-backdrop-filter: blur(12px);
	}

	.wm-header:not(.wm-header--scrolled) .navbar-brand,
	.wm-header:not(.wm-header--scrolled) .wm-nav-links .nav-link,
	.wm-header:not(.wm-header--scrolled) .wm-hotline,
	.wm-header--scrolled .navbar-brand,
	.wm-header--scrolled .wm-nav-links .nav-link,
	.wm-header--scrolled .wm-hotline {
		color: var(--wm-charcoal);
	}

	.wm-header:not(.wm-header--scrolled) .wm-nav-toggler,
	.wm-header--scrolled .wm-nav-toggler {
		border-color: rgba(28, 25, 23, 0.2);
	}

	.wm-header:not(.wm-header--scrolled) .navbar-toggler-icon,
	.wm-header--scrolled .navbar-toggler-icon {
		filter: none;
	}

	.wm-header .navbar-collapse {
		margin-top: 0.5rem;
		padding: 0.75rem 0 0.25rem;
		border-top: 1px solid rgba(28, 25, 23, 0.06);
	}

	.wm-header .navbar-collapse.show,
	.wm-header .navbar-collapse.collapsing {
		background: var(--wm-cream);
		margin-left: -0.75rem;
		margin-right: -0.75rem;
		padding: 1rem 0.75rem 1.25rem;
		border-radius: 0 0 var(--wm-radius) var(--wm-radius);
	}

	.wm-header-actions {
		padding: 1rem 0 0.5rem;
	}

	.btn-wm-login,
	.wm-header--scrolled .btn-wm-login {
		background: #fff;
		color: var(--wm-wood-dark);
		border-color: rgba(255, 255, 255, 0.95);
		box-shadow: 0 2px 14px rgba(28, 25, 23, 0.14);
	}

	.btn-wm-login:hover,
	.btn-wm-login:focus,
	.wm-header--scrolled .btn-wm-login:hover,
	.wm-header--scrolled .btn-wm-login:focus {
		background: var(--wm-wood);
		color: var(--wm-white);
		border-color: var(--wm-wood);
	}

	.wm-hero {
		min-height: 90vh;
	}

	.wm-section {
		padding: 3.5rem 0;
	}
}

@media (max-width: 575.98px) {
	.wm-hero-title {
		font-size: 1.85rem;
	}

	.wm-hero-lead {
		font-size: 1rem;
	}
}
