body.home-page {
	background:
		radial-gradient(circle at top, rgba(255, 255, 255, 0.58), transparent 28%),
		linear-gradient(180deg, #f7f7f9 0%, #f1f2f5 38%, #eceef2 100%);
	color: #1d1d1f !important;
}

.home-page a {
	text-decoration: none;
}

.home-page .section-spacing {
	padding-block: clamp(4rem, 8vw, 6.5rem);
}

.home-page .hero-shell {
	position: relative;
	overflow: hidden;
	padding: clamp(4rem, 9vw, 7rem) 0 clamp(5rem, 10vw, 7.5rem);
}

.home-page .hero-shell::before,
.home-page .hero-shell::after {
	content: "";
	position: absolute;
	border-radius: 999px;
	filter: blur(10px);
	opacity: 0.6;
	pointer-events: none;
}

.home-page .hero-shell::before {
	width: 18rem;
	height: 18rem;
	top: 2rem;
	left: -4rem;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.95), transparent 70%);
}

.home-page .hero-shell::after {
	width: 22rem;
	height: 22rem;
	right: -6rem;
	bottom: 2rem;
	background: radial-gradient(circle, rgba(215, 225, 245, 0.75), transparent 70%);
}

.home-page .hero-card {
	position: relative;
	background:
		linear-gradient(135deg, rgba(9, 10, 14, 0.9), rgba(17, 20, 28, 0.82)),
		url('/img/eq-bg2.webp') center/cover;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 2.25rem;
	box-shadow: 0 30px 80px rgba(15, 23, 42, 0.28);
	overflow: hidden;
}

.home-page .hero-card::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(120deg, rgba(255, 255, 255, 0.06), transparent 45%, rgba(103, 114, 140, 0.14));
	pointer-events: none;
}

.home-page .hero-content,
.home-page .hero-side {
	position: relative;
	z-index: 1;
}

.home-page .hero-title {
	font-size: clamp(2.6rem, 7vw, 5.6rem);
	line-height: 0.96;
	letter-spacing: -0.05em;
	margin: 1.4rem 0 1.1rem;
	color: #f5f5f7 !important;
	max-width: 10ch;
	font-weight: 700;
	text-shadow: 0 10px 30px rgba(0, 0, 0, 0.32);
}

.home-page .hero-title span {
	color: #d5d9e3;
}

.home-page .hero-copy {
	max-width: 38rem;
	font-size: clamp(1rem, 2vw, 1.15rem);
	line-height: 1.75;
	color: rgba(255, 255, 255, 0.86);
	text-shadow: 0 8px 24px rgba(0, 0, 0, 0.28);
}

.home-page .hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 2rem;
}

.home-page .btn-ghost-light {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.65rem 1.4rem;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.16);
	color: #f5f5f7 !important;
	background: rgba(255, 255, 255, 0.06);
	transition: transform 150ms ease, background-color 150ms ease, border-color 150ms ease, box-shadow 150ms ease;
}

.home-page .btn-ghost-light:hover,
.home-page .btn-ghost-light:focus {
	transform: translateY(-1px);
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.24);
	box-shadow: 0 14px 28px rgba(0, 0, 0, 0.18);
}

.home-page .hero-stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
	margin-top: 2.5rem;
}

.home-page .stat-chip,
.home-page .info-panel,
.home-page .room-card,
.home-page .location-card,
.home-page .contact-card {
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 1.5rem;
	backdrop-filter: blur(18px);
}

.home-page .stat-chip {
	padding: 1.1rem 1rem;
}

.home-page .stat-chip strong {
	display: block;
	font-size: 1.5rem;
	color: #ffffff;
}

.home-page .stat-chip span {
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.95rem;
}

.home-page .hero-side {
	padding: clamp(1.25rem, 2vw, 1.6rem);
}

.home-page .info-panel {
	padding: 1.5rem;
	height: 100%;
}

.home-page .info-panel + .info-panel {
	margin-top: 1rem;
}

.home-page .info-panel h2,
.home-page .info-panel h3 {
	color: #f5f5f7 !important;
	margin-bottom: 0.6rem;
}

.home-page .info-panel p,
.home-page .info-panel li {
	color: rgba(255, 255, 255, 0.84);
}

.home-page .rooms-grid {
	display: grid;
	gap: 1.5rem;
}

.home-page .room-card {
	padding: 1rem;
	background: rgba(255, 255, 255, 0.72);
	border-color: rgba(255, 255, 255, 0.92);
	box-shadow: 0 24px 60px rgba(15, 23, 42, 0.08);
}

.home-page .room-card img {
	width: 100%;
	height: 100%;
	min-height: 18rem;
	object-fit: cover;
	box-shadow: 0 16px 35px rgba(15, 23, 42, 0.1);
}

.home-page .room-card h3,
.home-page .room-card p,
.home-page .room-card li {
	color: #231c15 !important;
}

.home-page .room-card h3 {
	font-size: clamp(1.8rem, 3vw, 2.6rem);
	margin-bottom: 1rem;
}

.home-page .room-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin: 1.5rem 0 2rem;
	padding: 0;
	list-style: none;
}

.home-page .room-meta li {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.7rem 0.9rem;
	background: rgba(245, 247, 250, 0.95);
	border-radius: 999px;
	font-weight: 500;
}

.home-page .room-meta i {
	color: #6f7681;
}

.home-page .location-band {
	background: linear-gradient(180deg, #f4f5f8 0%, #edf0f4 100%);
	color: #1d1d1f;
}

.home-page .location-card,
.home-page .contact-card {
	padding: 1.5rem;
	height: 100%;
}

.home-page .location-card h2,
.home-page .location-card h3,
.home-page .location-card p,
.home-page .location-card li,
.home-page .contact-card h3,
.home-page .contact-card p,
.home-page .contact-card a {
	color: #1d1d1f !important;
}

.home-page .location-list,
.home-page .contact-list {
	list-style: none;
	padding: 0;
	margin: 1.5rem 0 0;
}

.home-page .location-list li,
.home-page .contact-list li {
	display: flex;
	gap: 0.9rem;
	align-items: flex-start;
	padding: 0.9rem 0;
	border-top: 1px solid rgba(29, 29, 31, 0.08);
}

.home-page .location-list li:first-child,
.home-page .contact-list li:first-child {
	border-top: none;
	padding-top: 0;
}

.home-page .location-map {
	min-height: 100%;
	overflow: hidden;
	border-radius: 1.5rem;
	box-shadow: 0 22px 50px rgba(15, 23, 42, 0.1);
}

.home-page .location-map iframe {
	width: 100%;
	height: 100%;
	min-height: 30rem;
	border: 0;
	filter: saturate(0.9) contrast(1.05);
}

.home-page .contact-row {
	margin-top: 2rem;
}

.home-page .contact-card {
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(244, 247, 252, 0.72));
}

.home-page .contact-card i {
	font-size: 1.2rem;
	color: #6f7681;
}

.home-page .contact-card a:hover,
.home-page .contact-card a:focus {
	color: #4f5661 !important;
}

@media (max-width: 991.98px) {
	.home-page .hero-shell {
		padding: 2.5rem 0 4rem;
	}

	.home-page .hero-card,
	.home-page .hero-content,
	.home-page .hero-side,
	.home-page .room-card,
	.home-page .location-card,
	.home-page .contact-card {
		text-align: center;
	}

	.home-page .hero-actions {
		justify-content: center;
	}

	.home-page .hero-stats {
		grid-template-columns: 1fr;
	}

	.home-page .hero-title {
		max-width: none;
		font-size: clamp(3.2rem, 11vw, 4.5rem);
	}

	.home-page .room-meta {
		justify-content: center;
	}

	.home-page .location-list li,
	.home-page .contact-list li {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.home-page .location-map iframe {
		min-height: 24rem;
	}
}
