.elysian-announcement-bar-slider {
	background: var(--text-primary);
	color: var(--bg-primary);
	height: 40px;
	overflow: hidden;
	position: relative;
	display: flex;
	align-items: center;
	z-index: 101;
}
.announcement-track {
	display: flex;
	white-space: nowrap;
	animation: slideAnnouncements 20s linear infinite;
}
.announcement-msg {
	padding: 0 4rem;
	font-family: var(--font-sans);
	font-size: 0.8rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 500;
}
@keyframes slideAnnouncements {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-50%);
	}
}
.elysian-circular-categories-row {
	display: flex;
	gap: 2rem;
	overflow-x: auto;
	padding: 2.5rem 0;
	scrollbar-width: none;
	-ms-overflow-style: none;
	justify-content: center;
}
@media (max-width: 992px) {
	.elysian-circular-categories-row {
		justify-content: flex-start;
	}
}
.elysian-circular-categories-row::-webkit-scrollbar {
	display: none;
}
.circular-category-item {
	min-width: 100px;
}
.circular-category-item a {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.75rem;
	width: 100%;
}
.circular-img-wrap {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	overflow: hidden;
	border: 1px solid var(--border);
	background: var(--bg-secondary);
	transition: var(--transition-quick);
}
.circular-category-item:hover .circular-img-wrap {
	transform: scale(1.08);
	border-color: var(--accent);
	box-shadow: 0 4px 15px rgba(0,0,0,0.05);
}
.circular-img-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.circular-label {
	font-family: var(--font-sans);
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--text-primary);
	white-space: nowrap;
	letter-spacing: 0.02em;
}
.elysian-mega-hero-banner {
	display: grid;
	grid-template-columns: minmax(0, 1.02fr) minmax(420px, 0.98fr);
	background: linear-gradient(135deg, #20261f 0%, #313225 48%, #8c7865 100%);
	color: var(--bg-primary);
	border: 1px solid rgba(255,255,255,0.16);
	overflow: hidden;
	margin-bottom: 3.5rem;
	min-height: 560px;
	position: relative;
}
.hero-banner-content {
	padding: 4.75rem 5rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	gap: 1.35rem;
	position: relative;
	z-index: 2;
	max-width: 720px;
}
.promo-tag {
	font-family: var(--font-sans);
	font-size: 0.85rem;
	letter-spacing: 0;
	text-transform: uppercase;
	color: #efe2cf;
	font-weight: 600;
	border: 1px solid rgba(252,251,250,0.26);
	padding: 0.55rem 0.9rem;
	background: rgba(252,251,250,0.08);
}
.hero-banner-content h1 {
	font-family: var(--font-serif);
	font-size: 4.8rem;
	line-height: 0.96;
	font-weight: 300;
	color: var(--bg-primary);
	max-width: 620px;
}
.hero-banner-content p {
	font-family: var(--font-sans);
	font-size: 1rem;
	color: rgba(252,251,250,0.78);
	line-height: 1.8;
	max-width: 560px;
}
.hero-voucher-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.85rem;
	background: rgba(252,251,250,0.12);
	border: 1px dashed rgba(252,251,250,0.42);
	padding: 0.75rem 1rem;
	font-family: var(--font-sans);
	font-size: 0.85rem;
	color: rgba(252,251,250,0.86);
}
.hero-voucher-badge strong {
	background: var(--bg-primary);
	color: var(--text-primary);
	font-size: 0.8rem;
	font-weight: 700;
	padding: 0.4rem 0.65rem;
}
.hero-actions-row {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
	margin-top: 1rem;
}
.hero-actions-row .elysian-btn {
	min-width: 190px;
	letter-spacing: 0;
}
.hero-actions-row .elysian-btn.primary {
	background: var(--bg-primary);
	border-color: var(--bg-primary);
	color: var(--text-primary);
}
.hero-actions-row .elysian-btn.primary:hover {
	background: #efe2cf;
	border-color: #efe2cf;
	color: var(--text-primary);
}
.hero-actions-row .elysian-btn.secondary {
	border-color: rgba(252,251,250,0.64);
	color: var(--bg-primary);
}
.hero-actions-row .elysian-btn.secondary:hover {
	background: rgba(252,251,250,0.16);
	color: var(--bg-primary);
}
.hero-proof-row {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.75rem;
	width: 100%;
	max-width: 560px;
	margin-top: 1.25rem;
	border-top: 1px solid rgba(252,251,250,0.18);
	padding-top: 1.25rem;
}
.hero-proof-row span {
	font-family: var(--font-sans);
	font-size: 0.78rem;
	font-weight: 600;
	color: rgba(252,251,250,0.82);
	text-transform: uppercase;
	letter-spacing: 0;
}
.hero-banner-visual {
	height: 100%;
	min-height: 560px;
	position: relative;
	isolation: isolate;
}
.hero-banner-visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	filter: saturate(0.92) contrast(1.02);
}
.hero-banner-visual::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(90deg, rgba(32,38,31,0.78) 0%, rgba(32,38,31,0.18) 38%, rgba(32,38,31,0) 74%);
	pointer-events: none;
}
.hero-visual-offer {
	position: absolute;
	right: 2rem;
	bottom: 2rem;
	z-index: 2;
	width: min(280px, calc(100% - 4rem));
	background: rgba(252,251,250,0.94);
	color: var(--text-primary);
	border: 1px solid rgba(28,27,26,0.08);
	padding: 1rem 1.15rem;
	box-shadow: 0 18px 44px rgba(0,0,0,0.18);
}
.hero-visual-offer span {
	display: block;
	font-family: var(--font-sans);
	font-size: 0.74rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0;
	color: var(--accent-hover);
	margin-bottom: 0.35rem;
}
.hero-visual-offer strong {
	display: block;
	font-family: var(--font-serif);
	font-size: 1.5rem;
	line-height: 1.12;
	font-weight: 500;
}
.elysian-promo-coupons-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	margin-bottom: 4rem;
}
.promo-coupon-card {
	border: 1px solid var(--border);
	overflow: hidden;
	display: flex;
	justify-content: space-between;
	height: 200px;
	transition: var(--transition-smooth);
}
.promo-coupon-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 10px 25px rgba(0,0,0,0.03);
}
.coupon-text {
	padding: 2rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	gap: 0.5rem;
	flex: 1;
}
.coupon-text h3 {
	font-family: var(--font-serif);
	font-size: 1.5rem;
}
.discount-val {
	font-family: var(--font-sans);
	font-size: 0.85rem;
	font-weight: 700;
	color: #D9381E;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.coupon-text p {
	font-family: var(--font-sans);
	font-size: 0.8rem;
	color: var(--text-secondary);
}
.coupon-link {
	font-family: var(--font-sans);
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--text-primary);
	margin-top: 0.5rem;
}
.coupon-image {
	width: 140px;
	object-fit: cover;
}
.elysian-flash-deal-day {
	border: 2px solid var(--accent);
	background: var(--bg-primary);
	margin-bottom: 5rem;
}
.flash-deal-header {
	background: var(--bg-secondary);
	border-bottom: 1px solid var(--border);
	padding: 1.5rem 3rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 1.5rem;
}
.header-left {
	display: flex;
	align-items: center;
	gap: 1.5rem;
}
.live-indicator {
	font-family: var(--font-sans);
	font-size: 0.75rem;
	font-weight: 700;
	color: #D9381E;
	background: rgba(217, 56, 30, 0.08);
	padding: 0.3rem 0.8rem;
	border-radius: 20px;
	display: flex;
	align-items: center;
	gap: 0.4rem;
}
.live-dot {
	width: 6px;
	height: 6px;
	background: #D9381E;
	border-radius: 50%;
	animation: flashDot 1s infinite alternate;
}
@keyframes flashDot {
	from { opacity: 0.2; }
	to { opacity: 1; }
}
.flash-deal-title {
	font-family: var(--font-serif);
	font-size: 1.8rem;
	margin: 0;
}
.flash-countdown-wrap {
	display: flex;
	align-items: center;
	gap: 1rem;
}
.timer-label {
	font-family: var(--font-sans);
	font-size: 0.95rem;
	color: var(--text-secondary);
}
.timer-digits {
	display: flex;
	align-items: center;
	gap: 0.4rem;
}
.digit-box {
	background: var(--text-primary);
	color: var(--bg-primary);
	font-family: var(--font-sans);
	font-size: 1.1rem;
	font-weight: 700;
	padding: 0.4rem 0.8rem;
	border-radius: 3px;
}
.timer-digits .sep {
	font-weight: 700;
	color: var(--text-primary);
}
.flash-deal-body {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	align-items: center;
}
.flash-product-image {
	position: relative;
	aspect-ratio: 16 / 10;
	background: var(--bg-secondary);
	overflow: hidden;
}
.flash-product-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.save-tag {
	position: absolute;
	top: 1.5rem;
	left: 1.5rem;
	background: #D9381E;
	color: var(--white);
	font-family: var(--font-sans);
	font-size: 0.85rem;
	font-weight: 700;
	padding: 0.5rem 1rem;
}
.flash-product-info {
	padding: 4rem;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}
.flash-rating-row {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}
.flash-ratings-count {
	font-family: var(--font-sans);
	font-size: 0.8rem;
	color: var(--text-secondary);
}
.flash-product-info h3 {
	font-family: var(--font-serif);
	font-size: 2.2rem;
	margin: 0;
}
.flash-desc {
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--text-secondary);
}
.flash-price-block {
	display: flex;
	align-items: baseline;
	gap: 1rem;
}
.flash-price-new {
	font-family: var(--font-serif);
	font-size: 2.4rem;
	color: var(--text-primary);
	font-weight: 400;
}
.flash-price-old {
	font-family: var(--font-sans);
	font-size: 1.35rem;
	color: var(--text-secondary);
	text-decoration: line-through;
}
.flash-discount-percentage {
	font-family: var(--font-sans);
	font-size: 0.85rem;
	font-weight: 700;
	color: #D9381E;
	background: rgba(217, 56, 30, 0.08);
	padding: 0.25rem 0.6rem;
}
.flash-emi-tag {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--font-sans);
	font-size: 0.85rem;
	color: var(--text-primary);
}
.flash-emi-tag svg {
	color: var(--accent);
}
.flash-stock-meter-wrap {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.flash-meter-labels {
	display: flex;
	justify-content: space-between;
	font-family: var(--font-sans);
	font-size: 0.8rem;
	font-weight: 600;
}
.stock-left-lbl {
	color: #D9381E;
}
.percentage-claimed-lbl {
	color: var(--text-secondary);
}
.flash-progress-bar {
	width: 100%;
	height: 6px;
	background: var(--border);
	border-radius: 3px;
	overflow: hidden;
}
.flash-progress-fill {
	height: 100%;
	background: #D9381E;
	border-radius: 3px;
}
.elysian-shop-by-room-section {
	padding: 5rem 0;
	border-top: 1px solid var(--border);
}
.home-section-title {
	font-family: var(--font-serif);
	font-size: 2.5rem;
	text-align: center;
	margin-bottom: 0.5rem;
	font-weight: 300;
}
.home-section-subtitle {
	font-family: var(--font-sans);
	font-size: 0.95rem;
	color: var(--text-secondary);
	text-align: center;
	display: block;
	margin-bottom: 3.5rem;
}
.room-tabs-nav {
	display: flex;
	justify-content: center;
	gap: 2.5rem;
	border-bottom: 1px solid var(--border);
	margin-bottom: 3rem;
}
.room-tab-btn {
	background: transparent;
	border: none;
	font-family: var(--font-sans);
	font-size: 0.95rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 1rem 0;
	cursor: pointer;
	color: var(--text-secondary);
	position: relative;
	transition: var(--transition-quick);
}
.room-tab-btn.active, .room-tab-btn:hover {
	color: var(--text-primary);
}
.room-tab-btn.active::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 100%;
	height: 2px;
	background: var(--text-primary);
}
.room-tab-panel {
	display: none;
}
.room-tab-panel.active {
	display: block;
	animation: tabFadeIn 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}
.room-panel-grid {
	display: grid;
	grid-template-columns: 1.15fr 0.85fr;
	gap: 4.5rem;
	align-items: center;
}
.room-panel-visual {
	aspect-ratio: 16 / 10;
	background: var(--bg-secondary);
	overflow: hidden;
	border: 1px solid var(--border);
}
.room-panel-visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.room-panel-details {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.room-panel-details h3 {
	font-family: var(--font-serif);
	font-size: 2.2rem;
	font-weight: 300;
}
.room-panel-details p {
	font-family: var(--font-sans);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--text-secondary);
}
.room-product-checklist {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	border-top: 1px solid var(--border);
	border-bottom: 1px solid var(--border);
	padding: 1.5rem 0;
}
.room-check-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-family: var(--font-sans);
	font-size: 0.9rem;
}
.room-check-item span {
	color: var(--text-primary);
	font-weight: 500;
}
.room-check-item strong {
	color: var(--accent);
}
.elysian-catalog-best-sellers {
	padding: 5rem 0;
	border-top: 1px solid var(--border);
}
.badge-tag-selling {
	position: absolute;
	top: 1rem;
	left: 1rem;
	background: var(--accent);
	color: var(--white);
	font-family: var(--font-sans);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	padding: 0.3rem 0.8rem;
	border-radius: 2px;
	z-index: 5;
}
.product-star-rating-catalog {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	margin: 0.25rem 0;
}
.stars-gold {
	color: #D4AF37;
	font-size: 0.85rem;
	letter-spacing: 1px;
}
.product-star-rating-catalog .rating-val {
	font-family: var(--font-sans);
	font-size: 0.75rem;
	color: var(--text-secondary);
}
.product-emi-note-catalog {
	font-family: var(--font-sans);
	font-size: 0.8rem;
	color: var(--text-primary);
	font-weight: 500;
	margin-top: 0.25rem;
}
.product-assembly-free-badge {
	font-family: var(--font-sans);
	font-size: 0.75rem;
	color: #2E7D32;
	font-weight: 600;
	display: block;
	margin-top: 0.2rem;
}
.elysian-curated-looks-hotspots {
	padding: 5rem 0;
	border-top: 1px solid var(--border);
}
.hotspots-image-container {
	position: relative;
	width: 100%;
	aspect-ratio: 21 / 9;
	overflow: hidden;
	border: 1px solid var(--border);
}
.hotspots-image-container > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.hotspot-pin {
	position: absolute;
	width: 24px;
	height: 24px;
	z-index: 10;
}
.hotspot-trigger {
	width: 100%;
	height: 100%;
	background: var(--white);
	border: 2px solid var(--text-primary);
	border-radius: 50%;
	cursor: pointer;
	box-shadow: 0 2px 10px rgba(0,0,0,0.25);
	position: relative;
}
.hotspot-trigger::after {
	content: '';
	position: absolute;
	top: -6px;
	left: -6px;
	right: -6px;
	bottom: -6px;
	border: 1px solid var(--white);
	border-radius: 50%;
	animation: pulsePin 1.5s infinite;
}
@keyframes pulsePin {
	0% { transform: scale(1); opacity: 0.8; }
	100% { transform: scale(1.6); opacity: 0; }
}
.hotspot-popup {
	position: absolute;
	bottom: 34px;
	left: 50%;
	transform: translateX(-50%) translateY(10px);
	background: var(--bg-primary);
	border: 1px solid var(--border);
	width: 220px;
	padding: 1rem;
	display: flex;
	gap: 1rem;
	box-shadow: 0 10px 30px rgba(0,0,0,0.15);
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
	z-index: 15;
}
.hotspot-pin:hover .hotspot-popup {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0);
}
.hotspot-popup img {
	width: 60px;
	height: 60px;
	object-fit: cover;
	border: 1px solid var(--border);
	background: var(--bg-secondary);
}
.popup-meta {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	flex: 1;
}
.popup-meta h4 {
	font-family: var(--font-serif);
	font-size: 0.95rem;
	margin: 0;
}
.popup-meta span {
	font-family: var(--font-sans);
	font-size: 0.85rem;
	color: var(--text-secondary);
	font-weight: 500;
}
.popup-add-to-cart {
	font-family: var(--font-sans);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	color: var(--accent);
	margin-top: 0.25rem;
	display: inline-block;
}
.elysian-assured-quality-matrix {
	padding: 5rem 0;
	border-top: 1px solid var(--border);
}
.assured-matrix-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2.5rem;
}
.assured-card {
	background: var(--bg-secondary);
	border: 1px solid var(--border);
	padding: 3rem 2.5rem;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
}
.assured-icon {
	color: var(--accent);
}
.assured-card h3 {
	font-family: var(--font-serif);
	font-size: 1.5rem;
	margin: 0;
}
.assured-card p {
	font-family: var(--font-sans);
	font-size: 0.9rem;
	color: var(--text-secondary);
	line-height: 1.6;
}
.elysian-home-testimonials {
	padding: 5rem 0;
	border-top: 1px solid var(--border);
}
.testimonials-masonry-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2.5rem;
}
.testimonial-mason-card {
	background: var(--bg-secondary);
	border: 1px solid var(--border);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}
.mason-visual {
	aspect-ratio: 4 / 3;
	overflow: hidden;
}
.mason-visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.mason-meta {
	padding: 2rem;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.mason-stars {
	color: #D4AF37;
	font-size: 0.95rem;
}
.mason-meta p {
	font-family: var(--font-sans);
	font-size: 0.95rem;
	color: var(--text-secondary);
	line-height: 1.6;
	font-style: italic;
}
.mason-meta h4 {
	font-family: var(--font-sans);
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--text-primary);
}
.elysian-homepage-faqs {
	padding: 5rem 0;
	border-top: 1px solid var(--border);
}
.homepage-faqs-accordion-list {
	max-width: 800px;
	margin: 0 auto;
	border-top: 1px solid var(--border);
}
.faq-accordion-item {
	border-bottom: 1px solid var(--border);
}
.faq-accordion-header {
	padding: 1.5rem 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	cursor: pointer;
	font-family: var(--font-sans);
	font-size: 1rem;
	font-weight: 600;
	color: var(--text-primary);
}
.faq-accordion-header::after {
	content: '+';
	font-size: 1.4rem;
	font-weight: 300;
	color: var(--text-secondary);
	transition: var(--transition-quick);
}
.faq-accordion-item.active .faq-accordion-header::after {
	transform: rotate(45deg);
}
.faq-accordion-content {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.4s cubic-bezier(0.25, 1, 0.5, 1);
	color: var(--text-secondary);
	font-size: 0.95rem;
	line-height: 1.65;
}
.faq-accordion-item.active .faq-accordion-content {
	max-height: 250px;
	padding-bottom: 1.5rem;
}
.elysian-club-signup-banner {
	background: var(--bg-secondary);
	border: 1px solid var(--border);
	padding: 4rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 2rem;
	margin-bottom: 5rem;
	flex-wrap: wrap;
	gap: 3rem;
}
.club-banner-text {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	flex: 1;
	min-width: 300px;
}
.club-subtitle {
	font-family: var(--font-sans);
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--accent);
	font-weight: 600;
}
.club-banner-text h2 {
	font-family: var(--font-serif);
	font-size: 2.4rem;
	font-weight: 300;
}
.club-banner-text p {
	font-family: var(--font-sans);
	font-size: 0.95rem;
	color: var(--text-secondary);
	line-height: 1.6;
	max-width: 500px;
}
.club-email-form {
	display: flex;
	gap: 1rem;
	align-items: center;
	min-width: 400px;
}
.club-email-input {
	flex: 1;
	border: 1px solid var(--border);
	background: var(--bg-primary);
	padding: 1rem 1.5rem;
	font-family: var(--font-sans);
	font-size: 0.95rem;
	outline: none;
}
.club-email-form button {
	height: 54px;
}
@media (max-width: 1200px) {
	.elysian-mega-hero-banner {
		grid-template-columns: minmax(0, 1fr) minmax(360px, 0.9fr);
		min-height: 500px;
	}
	.hero-banner-content {
		padding: 3.5rem;
	}
	.hero-banner-content h1 {
		font-size: 4rem;
	}
	.hero-banner-visual {
		min-height: 500px;
	}
	.assured-matrix-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.testimonials-masonry-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 992px) {
	.elysian-mega-hero-banner {
		grid-template-columns: 1fr;
		min-height: unset;
	}
	.hero-banner-content {
		padding: 3.25rem;
	}
	.hero-banner-content h1 {
		font-size: 4rem;
	}
	.hero-banner-visual {
		min-height: 360px;
	}
	.hero-banner-visual::before {
		background: linear-gradient(180deg, rgba(32,38,31,0) 38%, rgba(32,38,31,0.48) 100%);
	}
	.elysian-promo-coupons-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}
	.promo-coupon-card {
		height: 180px;
	}
	.elysian-flash-deal-day {
		margin-bottom: 4rem;
	}
	.flash-deal-body {
		grid-template-columns: 1fr;
	}
	.flash-product-info {
		padding: 2.5rem;
	}
	.room-panel-grid {
		grid-template-columns: 1fr;
		gap: 2.5rem;
	}
	.hotspots-image-container {
		aspect-ratio: 16 / 10;
	}
	.elysian-club-signup-banner {
		padding: 2.5rem;
	}
	.club-email-form {
		width: 100%;
		min-width: unset;
	}
}
@media (max-width: 768px) {
	.elysian-mega-hero-banner {
		margin-left: -0.5rem;
		margin-right: -0.5rem;
		margin-bottom: 2.5rem;
	}
	.hero-banner-content {
		padding: 2rem 1.5rem 2.25rem;
		gap: 1rem;
	}
	.hero-banner-content h1 {
		font-size: 3rem;
		line-height: 1;
	}
	.hero-banner-content p {
		font-size: 0.95rem;
		line-height: 1.7;
	}
	.hero-voucher-badge {
		width: 100%;
		justify-content: space-between;
		gap: 0.65rem;
	}
	.hero-actions-row {
		width: 100%;
		gap: 0.75rem;
	}
	.hero-actions-row .elysian-btn {
		width: 100%;
		min-width: 0;
		padding-left: 1rem;
		padding-right: 1rem;
	}
	.hero-proof-row {
		grid-template-columns: 1fr;
		gap: 0.55rem;
		margin-top: 0.75rem;
		padding-top: 1rem;
	}
	.hero-banner-visual {
		min-height: 280px;
	}
	.hero-visual-offer {
		left: 1rem;
		right: 1rem;
		bottom: 1rem;
		width: auto;
		padding: 0.85rem 1rem;
	}
	.hero-visual-offer strong {
		font-size: 1.25rem;
	}
	.assured-matrix-grid {
		grid-template-columns: 1fr;
	}
	.testimonials-masonry-grid {
		grid-template-columns: 1fr;
	}
	.room-tabs-nav {
		gap: 1rem;
		flex-wrap: wrap;
	}
	.room-tab-btn {
		font-size: 0.85rem;
	}
	.hotspots-image-container {
		aspect-ratio: 4 / 3;
	}
	.hotspot-popup {
		width: 180px;
		padding: 0.75rem;
	}
	.hotspot-popup img {
		width: 44px;
		height: 44px;
	}
	.popup-meta h4 {
		font-size: 0.85rem;
	}
	.popup-meta span {
		font-size: 0.8rem;
	}
}

body.home {
	padding-top: 120px;
}
