/**
 * Component Styles
 *
 * @package FolèResidence
 */

/* Site Branding */
.site-branding {
	display: flex;
	align-items: center;
}

.site-logo {
	display: block;
	text-decoration: none;
}

.logo-image {
	max-height: 60px;
	width: auto;
	height: auto;
	display: block;
	filter: brightness(0) invert(1); /* White logo for overlay */
	transition: filter var(--transition-base);
}

/* Desktop: Dark logo only after 200px scroll */
@media (min-width: 769px) {
	.site-header.scrolled-dark .logo-image {
		filter: brightness(0) invert(0); /* Dark logo when scrolled 200px+ */
	}
}

.site-title {
	font-family: var(--font-serif);
	font-size: var(--font-size-logo);
	font-weight: 400;
	letter-spacing: 0.02em;
}

.site-title a {
	text-decoration: none;
	color: var(--color-white);
	transition: color var(--transition-base);
}

/* Desktop: Dark site title only after 200px scroll */
@media (min-width: 769px) {
	.site-header.scrolled-dark .site-title a {
		color: var(--color-primary);
	}
}

.site-title a:hover {
	color: var(--color-white);
	opacity: 0.8;
}

/* Navigation */
.main-navigation {
	display: flex;
	align-items: flex-start;
}

.nav-container {
	display: flex;
	gap: var(--spacing-sm);
	align-items: flex-start;
}

.nav-column {
	display: flex;
	flex-direction: column;
	min-width: 170px;
	border-top: 1px solid var(--color-white);
	padding-top: 5px;
}

.nav-menu {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 0;
	margin: 0;
	padding: 0;
}

.nav-menu li {
	margin: 0;
	padding: 0;
	position: relative;
}


.nav-menu li:last-child::after {
	display: none;
}


.nav-menu a {
	display: block;
	color: var(--color-white);
	text-decoration: none;
	transition: transform var(--transition-base), color var(--transition-base), opacity var(--transition-base);
	position: relative;
	font-size: 24px;
	font-weight: 500;
	letter-spacing: 0.01em;
	line-height: 1.1;
}

/* Desktop: Dark navigation items only after 200px scroll */
@media (min-width: 769px) {
	.site-header.scrolled-dark .nav-menu a {
		color: var(--color-text);
	}
	
	.site-header.scrolled-dark .nav-menu a:hover {
		color: var(--color-text);
		opacity: 0.7;
	}
	
	.site-header.scrolled-dark .nav-column {
		border-top-color: var(--color-text);
	}
}


/* Desktop: Dark nav menu li::after only after 200px scroll */
@media (min-width: 769px) {
	.site-header.scrolled-dark .nav-menu li::after {
		background-color: rgba(0, 0, 0, 0.15);
	}
}

.nav-menu a:hover {
	transform: translateX(4px);
	color: var(--color-white);
	opacity: 0.9;
}

/* Responsive Navigation */
@media (max-width: 768px) {
	.nav-container {
		flex-direction: row;
		justify-content: space-between;
		width: 100%;
		gap: 0;
	}

	.nav-column {
		width: auto;
		min-width: auto;
	}

	.nav-column.nav-tertiary {
		border-top: none;
		padding-top: 5px;
		position: relative;
	}

	.nav-column.nav-tertiary::after {
		content: "";
		position: absolute;
		top: 0;
		right: 0;
		width: 220%;
		height: 1px;
		background-color: var(--color-white);
		display: block;
	}

	.nav-column.nav-primary,
	.nav-column.nav-secondary {
		display: none;
	}

	.nav-menu {
		flex-direction: column;
		gap: 0;
	}

	.nav-menu a {
		padding: 0;
		font-size: 22px;
	}

	.nav-menu a:hover {
		transform: translateX(4px);
	}
}

/* Mobile Menu Toggle Button */
.mobile-menu-toggle {
	display: none;
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
}

@media (max-width: 768px) {
	.mobile-menu-toggle {
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: 1;
	}

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

/* Mobile Menu Overlay */
.mobile-menu-overlay {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100vw;
	height: 100vh;
	background-color: transparent;
	z-index: 9999;
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--transition-base), visibility var(--transition-base);
}

.mobile-menu-overlay.active {
	opacity: 1;
	visibility: visible;
}

.mobile-menu-container {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100vw;
	height: 100vh;
	padding: var(--spacing-sm);
	background-color: var(--color-background); /* Medium-dark taupe/brownish-grey */
	border-left: 2px solid var(--color-divider); /* Dark blue-grey border */
	border-top: 2px solid var(--color-divider);
	border-bottom: 2px solid var(--color-divider);
	transform: translateX(-100%);
	transition: transform var(--transition-base);
	overflow-y: auto;
	z-index: 10000;
	display: flex;
	flex-direction: column;
	box-sizing: border-box;
}

.mobile-menu-overlay.active .mobile-menu-container {
	transform: translateX(0);
}

/* Mobile Menu Navigation */
.mobile-menu {
	padding: 0;
	margin: 0;
	flex: 1;
	display: flex;
	flex-direction: column;
	position: relative;
}

/* Mobile Menu Close Button */
.mobile-menu-close {
	position: absolute;
	top: 0;
	right: 0;
	padding: 0;
	background: none;
	border: none;
	color: #e0ddc9;
	font-family: var(--font-primary);
	font-size: 22px;
	font-weight: 500;
	cursor: pointer;
	transition: opacity var(--transition-base);
	z-index: 10;
	height: 1.5em;
	display: flex;
	align-items: center;
	margin-top: 5px;
	letter-spacing: 0.01em;
}

.mobile-menu-close::after {
	content: "";
	position: absolute;
	top: 0;
	left: -125px;
	width: 320%;
	height: 1px;
	background-color: #e0ddc9;
	display: block;
	z-index: 1;
	pointer-events: none;
	margin-top: -5px;
}

.mobile-menu-close:hover {
	opacity: 0.8;
}

.mobile-menu-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	width: 100%;
	gap: 4px;
}

.mobile-menu-list li {
	margin: 0;
	padding: 0;
	position: relative;
	max-width: fit-content;
}

.mobile-menu-list li:first-child {
	position: relative;
	padding-right: 60px; /* Space for close button */
	margin-top: 5px;
}

.mobile-menu-list li:first-child a {
	position: relative;
}

.mobile-menu-list li:first-child::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 150%;
	height: 1px;
	background-color: #e0ddc9;
	display: block;
	z-index: 1;
	pointer-events: none;
	margin-top: -5px;
}

.mobile-menu-list li:last-child::after {
	display: none;
}

.mobile-menu-list a {
	display: block;
	color: #e0ddc9;
	font-family: var(--font-primary);
	font-size: 22px;
	font-weight: 400;
	text-decoration: none;
	transition: background-color var(--transition-base), color var(--transition-base);
	width: fit-content;
	line-height: 1.1;
}

.mobile-menu-list a:hover,
.mobile-menu-list a:focus {
	background-color: rgba(255, 255, 255, 0.1);
	color: rgba(255, 255, 255, 1);
}

/* Mobile: Dark menu items after scroll (same threshold as desktop) */
@media (max-width: 768px) {
	/* Mobile menu toggle (Menu text) */
	.site-header.scrolled-dark .site-branding::before {
		color: var(--color-text);
	}
	
	.site-header.scrolled-dark .site-branding::after {
		background-color: var(--color-text);
	}
	
	/* Tertiary menu items (visible on mobile) */
	.site-header.scrolled-dark .nav-column.nav-tertiary .nav-menu a {
		color: var(--color-text);
	}
	
	.site-header.scrolled-dark .nav-column.nav-tertiary .nav-menu a:hover {
		color: var(--color-text);
		opacity: 0.7;
	}
	
	.site-header.scrolled-dark .nav-column.nav-tertiary::after {
		background-color: var(--color-text);
	}
	
	/* Mobile menu overlay items */
	.site-header.scrolled-dark .mobile-menu-list a,
	.mobile-menu-overlay.scrolled-dark .mobile-menu-list a {
		color: var(--color-text);
	}
	
	.site-header.scrolled-dark .mobile-menu-list a:hover,
	.site-header.scrolled-dark .mobile-menu-list a:focus,
	.mobile-menu-overlay.scrolled-dark .mobile-menu-list a:hover,
	.mobile-menu-overlay.scrolled-dark .mobile-menu-list a:focus {
		color: var(--color-text);
		opacity: 0.7;
	}
	
	.site-header.scrolled-dark .mobile-menu-close,
	.mobile-menu-overlay.scrolled-dark .mobile-menu-close {
		color: var(--color-text);
	}
	
	.site-header.scrolled-dark .mobile-menu-close::after,
	.mobile-menu-overlay.scrolled-dark .mobile-menu-close::after {
		background-color: var(--color-text);
	}
	
	.site-header.scrolled-dark .mobile-menu-list li:first-child::before,
	.mobile-menu-overlay.scrolled-dark .mobile-menu-list li:first-child::before {
		background-color: var(--color-text);
	}
}

/* Why Fole Section */
.why-fole-section {
	width: 100%;
	background-color: var(--color-background);
	padding: 0;
}

.why-fole-container {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	width: 100%;
	padding: var(--spacing-lg) var(--spacing-md) var(--spacing-sm);
}

.why-fole-content {
	display: flex;
	flex-direction: column;
	width: 50%;
	max-width: 600px;
}

.why-fole-title {
	font-family: 'Instrument Serif', serif;
	font-style: italic;
	font-size: 3rem;
	font-weight: 400;
	color: var(--color-beige);
	margin: 0 0 var(--spacing-sm) 0;
	letter-spacing: 0.02em;
}

.why-fole-description {
	font-family: var(--font-primary);
	font-size: 1.2rem;
	font-weight: 400;
	color: var(--color-beige);
	line-height: var(--line-height-base);
	margin: 0 0 var(--spacing-md) 0;
}

.why-fole-separator {
	width: 100%;
	height: 1px;
	background-color: var(--color-beige);
	margin: 0 0 var(--spacing-sm) 0;
	opacity: 0.8;
}

.why-fole-actions {
	display: flex;
	gap: var(--spacing-2xl);
	align-items: center;
}

.why-fole-link {
	display: flex;
	align-items: center;
	gap: 0;
	font-family: var(--font-primary);
	font-size: 1.1rem;
	font-weight: 400;
	color: var(--color-beige);
	text-decoration: none;
	transition: opacity var(--transition-base);
}

.why-fole-link:hover {
	opacity: 0.8;
}

.why-fole-link:hover .hero-button-arrow {
	opacity: 1;
	transform: translateX(0);
	margin-right: 10px;
}

.why-fole-link:hover .hero-button-text {
	transform: translateX(28px);
}

/* Responsive */
@media (max-width: 768px) {
	.why-fole-container {
		min-height: auto;
		justify-content: flex-start;
		padding: var(--spacing-md) var(--spacing-sm);
	}

	.why-fole-content {
		width: 100%;
		max-width: 100%;
	}

	.why-fole-title {
		font-size: 2rem;
	}

	.why-fole-description {
		font-size: var(--font-size-base);
	}

	.why-fole-actions {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-sm);
	}

	.why-fole-link {
		font-size: var(--font-size-base);
	}
}

/* Why Fole Features Section */
.why-fole-features {
	width: 100%;
	background-color: var(--color-white);
	padding: var(--spacing-2xl) var(--spacing-md);
}

.why-fole-features-container {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	gap: var(--spacing-md);
}

.why-fole-features-title {
	font-family: 'Instrument Serif', serif;
	font-style: italic;
	font-size: 3rem;
	font-weight: 400;
	line-height: var(--line-height-tight);
}

.why-fole-features-title-dark {
	color: var(--color-text);
	font-family: var(--font-heading);
}

.why-fole-features-title-light {
	color: #8b7355;
	font-family: 'Instrument Serif', serif;
}

.why-fole-features-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--spacing-lg);
	align-items: flex-start;
}

.why-fole-feature {
	display: flex;
	flex-direction: column;
}

.why-fole-feature-content {
	display: flex;
	gap: var(--spacing-sm);
	align-items: flex-start;
}

.why-fole-feature-icon {
	width: 50px;
	height: 50px;
	object-fit: contain;
	flex-shrink: 0;
	margin-top: 2px;
}

.why-fole-feature-icon-lottie {
	display: flex;
	align-items: center;
	justify-content: center;
}

.why-fole-feature-icon-lottie svg {
	width: 100%;
	height: 100%;
}

.why-fole-feature-text {
	flex: 1;
}

.why-fole-feature-heading {
	font-family: var(--font-primary);
	font-size: var(--font-size-h3);
	font-weight: 400;
	color: var(--color-text);
	margin: 0 0 var(--spacing-xs) 0;
	line-height: var(--line-height-tight);
}

.why-fole-feature-description {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text);
	line-height: var(--line-height-base);
	margin: 0;
}

/* Responsive for Why Fole Features */
@media (max-width: 768px) {
	.why-fole-features-title {
		font-size: 2rem;
	}

	.why-fole-features {
		padding: var(--spacing-lg) var(--spacing-sm);
	}

	.why-fole-feature-heading {
		font-size: var(--font-size-large);
	}

	.why-fole-features-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}

}

/* The Building Section */
.the-building-section {
	width: 100%;
	background-color: #f5f1e8;
	padding: var(--spacing-xl) var(--spacing-md);
}

.the-building-container {
	width: 100%;
	max-width: 1400px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xl);
}

/* The Building Gallery - Scattered Layout */
.the-building-gallery {
	position: relative;
	width: 100%;
	min-height: 600px;
	margin-bottom: var(--spacing-xl);
	padding: var(--spacing-lg) 0;
}

.the-building-gallery-item {
	position: absolute;
	will-change: transform;
	transition: transform 0.1s ease-out;
}

.the-building-gallery-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 4px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

/* Scattered positioning for gallery items */
.the-building-gallery-item[data-index="0"] {
	width: 280px;
	height: 200px;
	top: 5%;
	right: 10%;
	z-index: 1;
}

.the-building-gallery-item[data-index="1"] {
	width: 240px;
	height: 320px;
	top: 8%;
	left: 8%;
	z-index: 2;
}

.the-building-gallery-item[data-index="2"] {
	width: 320px;
	height: 420px;
	top: 25%;
	left: 50%;
	transform: translateX(-50%);
	z-index: 3;
}

.the-building-gallery-item[data-index="3"] {
	width: 200px;
	height: 200px;
	top: 35%;
	left: 12%;
	z-index: 1;
}

.the-building-gallery-item[data-index="4"] {
	width: 260px;
	height: 180px;
	top: 40%;
	right: 15%;
	z-index: 2;
}

.the-building-gallery-item[data-index="5"] {
	width: 220px;
	height: 300px;
	top: 55%;
	left: 10%;
	z-index: 1;
}

.the-building-gallery-item[data-index="6"] {
	width: 200px;
	height: 200px;
	top: 60%;
	right: 12%;
	z-index: 2;
}

/* Additional items if more than 7 images */
.the-building-gallery-item[data-index="7"] {
	width: 240px;
	height: 280px;
	top: 15%;
	right: 25%;
	z-index: 1;
}

.the-building-gallery-item[data-index="8"] {
	width: 180px;
	height: 240px;
	top: 45%;
	left: 35%;
	z-index: 1;
}

.the-building-gallery-item[data-index="9"] {
	width: 250px;
	height: 200px;
	top: 70%;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
}

.the-building-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--spacing-md);
	padding: 0 var(--spacing-md);
	max-width: 800px;
	margin: 0 auto;
}

.the-building-title {
	font-family: var(--font-serif);
	font-size: 4.5rem;
	font-weight: 400;
	color: var(--color-text);
	margin: 0;
	letter-spacing: 0.02em;
	line-height: var(--line-height-tight);
}

.the-building-description {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text);
	line-height: var(--line-height-base);
	margin: 0;
	max-width: 900px;
}

.the-building-image-wrapper {
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: var(--spacing-md);
	perspective: 1200px;
}

.the-building-image {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
	object-fit: contain;
	will-change: transform;
	opacity: 1;
	transform: perspective(1200px) scale(0.8) rotateX(25deg);
	transition: transform 0.3s ease-out;
}

/* Responsive for The Building Section */
@media (max-width: 768px) {
	.the-building-section {
		padding: var(--spacing-lg) var(--spacing-sm);
	}

	.the-building-container {
		gap: var(--spacing-lg);
	}

	.the-building-title {
		font-size: 2.5rem;
	}

	.the-building-description {
		font-size: var(--font-size-small);
	}

	/* Gallery responsive adjustments */
	.the-building-gallery {
		min-height: 400px;
		padding: var(--spacing-md) 0;
	}

	/* Scale down gallery items on mobile */
	.the-building-gallery-item {
		width: 180px !important;
		height: 140px !important;
	}

	.the-building-gallery-item[data-index="1"] {
		width: 160px !important;
		height: 220px !important;
	}

	.the-building-gallery-item[data-index="2"] {
		width: 200px !important;
		height: 280px !important;
	}

	.the-building-gallery-item[data-index="3"] {
		width: 140px !important;
		height: 140px !important;
	}

	.the-building-gallery-item[data-index="4"] {
		width: 170px !important;
		height: 120px !important;
	}

	.the-building-gallery-item[data-index="5"] {
		width: 150px !important;
		height: 200px !important;
	}

	.the-building-gallery-item[data-index="6"] {
		width: 140px !important;
		height: 140px !important;
	}
}

/* Facilities Section */
.facilities-section {
	width: 100%;
	background-color: var(--color-white);
}

/* Facilities Header Container */
.facilities-header-container {
	width: 100%;
	background-color: var(--color-white);
	padding: var(--spacing-2xl) var(--spacing-md);
}

.facilities-header-content {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	gap: var(--spacing-md);
}

@media (min-width: 769px) {
	.facilities-header-content {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: var(--spacing-xl);
		align-items: flex-start;
	}
}

.facilities-header-left {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
}

.facilities-separator {
	width: 100%;
	height: 1px;
	background-color: #d0d0d0;
}

.facilities-subtitle {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: #999999;
	margin: 0;
	line-height: var(--line-height-base);
}

.facilities-title {
	font-family: var(--font-primary);
	font-size: var(--font-size-h1);
	font-weight: 400;
	color: var(--color-text);
	margin: 0;
	line-height: var(--line-height-tight);
}

.facilities-header-right {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
}

.facilities-description {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text);
	line-height: var(--line-height-base);
	margin: 0;
}

.facilities-brochure-link {
	display: flex;
	align-items: center;
	gap: 0;
	font-family: var(--font-primary);
	font-size: var(--font-size-h3);
	font-weight: 400;
	color: var(--color-text);
	text-decoration: none;
	transition: opacity var(--transition-base);
	cursor: pointer;
	padding: 0.25rem 0 0 0;
	border-top: 2px solid rgba(0, 0, 0, 0.75);
	width: 200px;
}

.facilities-brochure-link .hero-button-arrow {
	/* `arrow-right.svg` is white; invert for dark-on-light sections */
	filter: invert(1);
}

.facilities-brochure-link:hover {
	opacity: 0.8;
}

.facilities-brochure-link:hover .hero-button-arrow {
	opacity: 1;
	transform: translateX(0);
	margin-right: 10px;
}

.facilities-brochure-link:hover .hero-button-text {
	transform: translateX(28px);
}

/* Facilities Gallery Container */
.facilities-gallery-container {
	width: 100%;
	position: relative;
	overflow: hidden;
	padding: var(--spacing-sm) 0 var(--spacing-lg);
}

.facilities-gallery-wrapper {
	width: 100%;
	position: relative;
	overflow: visible;
}

.facilities-gallery-track {
	display: flex;
	gap: var(--spacing-sm);
	will-change: transform;
	transition: transform 0.3s ease-out;
	padding-left: var(--spacing-sm);
	padding-right: var(--spacing-sm);
}

.facilities-nav-button {
	position: absolute;
	top: var(--spacing-md);
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color-white);
	border: none;
	cursor: pointer;
	z-index: 10;
	border-radius: 50%;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
	transition: transform var(--transition-base), opacity var(--transition-base), box-shadow var(--transition-base);
	padding: 0;
}

.facilities-nav-button:hover:not(:disabled) {
	transform: scale(1.03);
}

.facilities-nav-button:disabled {
	cursor: not-allowed;
	opacity: 0.3;
}

.facilities-nav-button-prev {
	right: calc(var(--spacing-xl) + 55px);
}

.facilities-nav-button-next {
	right: var(--spacing-xl);
}

.facilities-nav-button svg {
	width: 24px;
	height: 24px;
	display: block;
	flex-shrink: 0;
}

.facilities-card {
	flex: 0 0 auto;
	width: 600px;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
	background-color: var(--color-white);
}

.facilities-card-image-wrapper {
	width: 100%;
	height: 600px;
	overflow: hidden;
	position: relative;
}

.facilities-card-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}


.facilities-card-title {
	font-family: var(--font-primary);
	font-size: var(--font-size-large);
	font-weight: 400;
	color: var(--color-text);
	margin: 0;
	line-height: var(--line-height-tight);
}

.facilities-card-text {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text);
	line-height: var(--line-height-base);
	margin: 0;
}

/* Responsive for Facilities Section */
@media (max-width: 768px) {
	.facilities-header-container {
		padding: var(--spacing-lg) var(--spacing-sm);
	}

	.facilities-header-content {
		display: flex;
		flex-direction: column;
		gap: var(--spacing-md);
	}

	.facilities-card {
		width: 300px;
	}

	.facilities-card-image-wrapper {
		height: 350px;
	}

	.facilities-nav-button {
		width: 40px;
		height: 40px;
		top: var(--spacing-sm);
	}

	.facilities-nav-button-prev {
		right: calc(var(--spacing-sm) + 48px);
	}

	.facilities-nav-button-next {
		right: var(--spacing-sm);
	}

	.facilities-nav-button svg {
		width: 20px;
		height: 20px;
	}
}

/* AI Scrolljack Section (Front Page) */
.ai-scrolljack-section {
	width: 100%;
	background-color: var(--color-background);
	color: var(--color-beige);
	padding: var(--spacing-xs) var(--spacing-md);
	margin: var(--spacing-2xl) 0;
}

.ai-scrolljack-stage {
	box-sizing: border-box;
	display: flex;
	align-items: center;
}

.ai-scrolljack-grid {
	width: 100%;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-xl);
	align-items: center;
}

.ai-scrolljack-left-inner {
	position: relative;
	height: 65vh;
}

.ai-scrolljack-heading {
	position: absolute;
	left: 0;
	top: 0;
	margin: 0;
	font-family: var(--font-primary);
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: 0.01em;
	/* clamp(min, preferred, max) — keep min < max for responsive sizing */
	font-size: clamp(9rem, 10vw, 5.5rem);
	color: var(--color-beige);
	will-change: transform;
	transform: translateY(0);
	transition: transform 650ms cubic-bezier(0.2, 0.7, 0.2, 1);
}

.ai-scrolljack-prefix {
	color: var(--color-beige);
	opacity: 1;
	margin-right: 0.25ch;
}

/* (left column now shows only the prefix) */

.ai-scrolljack-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
}

.ai-scrolljack-item {
	flex: 1;
	display: flex;
	align-items: center;
	font-family: var(--font-primary);
	font-weight: 400;
	letter-spacing: 0.01em;
	/* clamp(min, preferred, max) — keep min < max for responsive sizing */
	font-size: clamp(9rem, 10vw, 5.5rem);
	color: var(--color-text-secondary);
	transition: color var(--transition-base);
}

.ai-scrolljack-item:first-child {
	border-top: none;
}

.ai-scrolljack-item.is-active {
	color: var(--color-amber);
}

@media (min-width: 769px) {
	.ai-scrolljack-grid {
		grid-template-columns: 1.8fr 1.4fr;
		gap: 0;
	}
}

@media (max-width: 768px) {
	.ai-scrolljack-section {
		padding: var(--spacing-md) var(--spacing-sm);
	}

	.ai-scrolljack-stage {
		min-height: auto;
		align-items: flex-start;
	}

	.ai-scrolljack-left-inner {
		height: auto;
	}

	.ai-scrolljack-heading {
		position: static;
		transform: none !important;
		transition: none;
		font-size: clamp(3.5rem, 9vw, 3.25rem);
		margin-bottom: var(--spacing-sm);
	}

	.ai-scrolljack-list {
		height: auto;
	}

	.ai-scrolljack-item {
		flex: 0 0 auto; /* don't stretch each row on mobile */
		font-size: clamp(3.5rem, 9vw, 3.25rem);
	}

	.ai-scrolljack-grid {
		gap: 0;
	}
}

/* Accessibility Section */
.accessibility-section {
	width: 100%;
	background-color: var(--color-white);
}

.accessibility-graph-container {
	width: 100%;
	padding: 0 var(--spacing-md) var(--spacing-2xl);
}

.accessibility-graph {
	position: relative;
	width: 100%;
	max-width: 1500px;
}

.accessibility-lines {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	overflow: visible;
	pointer-events: auto; /* only hit-paths accept pointer events */
	z-index: 1;
}

.accessibility-items {
	list-style: none;
	margin: 0;
	padding: var(--spacing-md) 0;
	width: 45%;
	max-width: 520px;
	display: flex;
	flex-direction: column;
	gap: 28px;
	position: relative;
	z-index: 2;
}

.accessibility-item {
	position: relative;
}

.accessibility-item-button {
	appearance: none;
	border: 0;
	background: transparent;
	padding: 0;
	margin: 0;
	text-align: left;
	cursor: pointer;
	font-family: var(--font-heading);
	font-size: 1.6rem;
	font-weight: 400;
	color: #6f6f6f;
	line-height: 1.2;
	transition: color var(--transition-base);
}

.accessibility-item-label--no-desktop-br {
	display: none;
}

@media (min-width: 769px) {
	.accessibility-section[data-desktop-label-br="0"] .accessibility-item-label--with-br {
		display: none;
	}

	.accessibility-section[data-desktop-label-br="0"] .accessibility-item-label--no-desktop-br {
		display: inline;
	}
}

.accessibility-item:first-child .accessibility-item-button {
	color: var(--color-text);
}

.accessibility-item-button:hover,
.accessibility-item-button:focus-visible {
	color: var(--color-text);
	outline: none;
}

.accessibility-symbol {
	position: absolute;
	right: 140px;
	top: 50%;
	transform: translateY(-50%);
	width: 80px;
	height: 80px;
	display: grid;
	place-items: center;
	z-index: 2;
}

.accessibility-symbol-image {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}

.accessibility-symbol-fallback {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	border: 5px dashed #1f1f1f;
	opacity: 0.9;
}

.accessibility-tooltip {
	position: absolute;
	z-index: 5;
	background-color: var(--color-background);
	color: var(--color-white);
	border-radius: var(--spacing-xs);
	padding: 10px 12px;
	min-width: 118px;
	pointer-events: none;
	opacity: 0;
	transform: translateY(2px);
	transition: opacity 120ms ease, transform 120ms ease;
}

.accessibility-tooltip.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.accessibility-tooltip-inner {
	display: grid;
	gap: 6px;
}

.accessibility-tooltip-row {
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-primary);
	font-size: 16px;
	font-weight: 400;
}

.accessibility-tooltip-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--color-white);
}

.accessibility-tooltip-icon svg {
	width: 24px;
	height: 24px;
}

.accessibility-footer {
	padding: var(--spacing-lg) 0 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
	align-items: flex-start;
}

.accessibility-footer-separator {
	width: 200px;
	height: 1px;
	background-color: #d0d0d0;
}

@media (max-width: 768px) {
	.accessibility-graph-container {
		padding: 0 var(--spacing-sm) var(--spacing-xl);
	}

	.accessibility-graph {
		min-height: fit-content;
	}

	.accessibility-items {
		width: 60%;
		max-width: 280px;
		padding: var(--spacing-md) 0;
		gap: 60px;
	}

	.accessibility-item-button {
		font-size: 1.25rem;
	}

	.accessibility-lines {
		display: block;
	}

	.accessibility-symbol {
		position: absolute;
		right: 20px;
		top: 50%;
		transform: translateY(-50%);
		width: 48px;
		height: 48px;
		margin: 0;
	}
}

/**
 * Layout Styles
 *
 * @package FolèResidence
 */

 * {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}

body {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	line-height: var(--line-height-base);
	color: var(--color-text);
	background-color: var(--color-white);
}

/* Headings - Use Self Modern font */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
}

.site-header {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	transition: transform 0.3s ease-in-out;
}

.site-header.scrolled {
	position: fixed;
}

/* Desktop: Sticky when scrolled */
@media (min-width: 769px) {
	.site-header.scrolled {
		position: fixed;
		top: 0;
	}
}

/* Mobile: Smooth show/hide animation */
@media (max-width: 768px) {
	.site-header {
		transform: translateY(0);
	}
	
	.site-header.hidden {
		transform: translateY(-100%);
	}
	
	.site-header.scrolled {
		transform: translateY(0);
	}
}

.header-container {
	width: 100%;
	margin: 0;
	padding: 1rem var(--spacing-sm) 1rem var(--spacing-md);
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 0;
}


.site-main {
	margin-top: 0;
}

/* Hero Section */
.hero-section {
	position: relative;
	width: 100%;
	height: 100vh;
	min-height: 600px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background-color: var(--color-background);
}

/* Hero section for about page */
.page-template-page-about-php .hero-section,
body.page-template-about .hero-section {
	background-color: var(--color-dark);
}

.hero-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	transform-origin: center center;
	transition: transform 0.1s ease-out;
}

.hero-video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero-image {
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.hero-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.2);
	z-index: 2;
}

.hero-content {
	position: relative;
	z-index: 3;
	width: 100%;
	padding: 0 var(--spacing-md) var(--spacing-2xl);
	text-align: left;
	color: var(--color-white);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: flex-end;
	height: 100%;
    gap: var(--spacing-sm);
	animation: slideInFromLeft 0.6s ease-out;
}

/* Hotel Amenities Inside Hero */
.hero-hotel-amenities {
	width: 100%;
	margin-top: var(--spacing-lg);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
}

.hero-hotel-amenities-description {
	width: 100%;
	max-width: 600px;
}

.hero-hotel-amenities-description p {
	font-family: var(--font-primary);
	font-size: var(--font-size-large);
	font-weight: 400;
	color: var(--color-white);
	line-height: var(--line-height-base);
	margin: 0;
	opacity: 0.9;
}

.hero-hotel-amenities-list {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-xs);
	max-width: 800px;
}

.hero-hotel-amenity {
	display: flex;
	align-items: center;
	gap: var(--spacing-xs);
	padding: var(--spacing-xs) var(--spacing-sm);
	background-color: rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 24px;
	transition: background-color var(--transition-base), border-color var(--transition-base);
}

.hero-hotel-amenity:hover {
	background-color: rgba(255, 255, 255, 0.25);
	border-color: rgba(255, 255, 255, 0.3);
}

.hero-hotel-amenity-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	color: var(--color-white);
}

.hero-hotel-amenity-icon svg {
	width: 100%;
	height: 100%;
	display: block;
}

.hero-hotel-amenity-text {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-white);
	white-space: nowrap;
}

/* Responsive */
@media (max-width: 768px) {
	.hero-hotel-amenities {
		margin-top: var(--spacing-md);
		gap: var(--spacing-sm);
	}
	
	.hero-hotel-amenities-description p {
		font-size: var(--font-size-base);
	}
	
	.hero-hotel-amenities-list {
		gap: calc(var(--spacing-xs) * 0.75);
	}
	
	.hero-hotel-amenity {
		padding: calc(var(--spacing-xs) * 0.75) var(--spacing-sm);
	}
	
	.hero-hotel-amenity-text {
		font-size: var(--font-size-small);
	}
}

@keyframes slideInFromLeft {
	from {
		transform: translateX(-80px);
		opacity: 0;
	}
	to {
		transform: translateX(0);
		opacity: 1;
	}
}

.hero-title {
	font-family: 'Instrument Serif', serif;
	font-style: italic;
	font-size: var(--font-size-h2);
	font-weight: 400;
	letter-spacing: -0.02em;
	color: var(--color-white);
	text-transform: none;
	max-width: 600px;
}

.hero-subtext {
	font-family: var(--font-serif);
	font-size: var(--font-size-h1);
	font-weight: 400;
	color: var(--color-white);
	opacity: 0.9;
	max-width: 600px;
    line-height: 1;
}

.hero-cta {
	margin-top: 0;
}

.hero-button {
	display: flex;
	align-items: center;
	text-decoration: none;
	color: var(--color-white);
	background-color: transparent;
	transition: all var(--transition-base);
	cursor: pointer;
	font-family: var(--font-primary);
	font-size: var(--font-size-h3);
	font-weight: 400;
	padding: 0.25rem 0 0 0;
	border-top: 2px solid rgba(255, 255, 255, 0.75);
	width: 200px;
	gap: 0;
}

.hero-button-arrow {
	flex: 0 0 25px;
	width: 25px;
	height: auto;
	display: block;
	opacity: 0;
	transform: translateX(-50px);
	transition: opacity var(--transition-base), transform var(--transition-base);
}

.hero-button-text {
	flex: 1;
	text-align: left;
	display: inline-block;
	margin-left: -26px;
	transform: translateX(0);
	transition: transform var(--transition-base);
}

.hero-button:hover .hero-button-arrow {
	opacity: 1;
	transform: translateX(0);
	margin-right: 10px;
}

.hero-button:hover .hero-button-text {
	transform: translateX(28px);
}

/* Responsive */
@media (max-width: 768px) {
	:root {
		--font-size-h1: 2.5rem;
		--header-height: 70px;
		--hero-padding-left: 1.5rem;
		--hero-padding-right: 1.5rem;
	}

	.header-container {
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-start;
		gap: 0;
		padding: 1rem var(--spacing-sm) 1rem var(--spacing-sm);
	}

	/* Show Menu button instead of logo on mobile */
	.site-branding {
		position: relative;
		display: flex;
		align-items: flex-start;
		cursor: pointer;
	}

	.site-branding .site-logo,
	.site-branding .site-title {
		display: none;
	}

	.site-branding::before {
		content: "Menu";
		color: var(--color-white);
		font-family: var(--font-primary);
		font-size: 22px;
		font-weight: 500;
		letter-spacing: 0.01em;
		padding-top: 5px;
		display: block;
		position: relative;
		z-index: 2;
		pointer-events: none;
	}

	.site-branding::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 300%;
		height: 1px;
		background-color: var(--color-white);
		display: block;
		z-index: 1;
		pointer-events: none;
	}

	.hero-section {
		min-height: 500px;
	}

	.hero-title {
		font-size: 2rem;
	}

    .hero-content {
        gap: var(--spacing-xs);
        padding: 0 var(--spacing-sm) 6rem;
		justify-content: flex-end;
    }

    .hero-subtext {
        font-size: 3rem;
    }

	/* Hide hero button on mobile */
	.hero-button,
	.hero-cta {
		display: none;
	}

	.nav-container {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
		width: 100%;
		gap: 0;
	}

	/* Hide primary and secondary nav on mobile */
	.nav-column.nav-primary,
	.nav-column.nav-secondary {
		display: none;
	}
}

/**
 * Footer
 */
.site-footer {
	background-color: var(--color-background);
	color: rgba(255, 255, 255, 0.9);
	padding: var(--spacing-sm) 0 var(--spacing-lg);
}

.footer-inner {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--spacing-xl);
	padding: var(--spacing-xl) var(--spacing-md);
}

.footer-brand {
	flex: 1 1 40%;
	min-width: 240px;
}

.footer-logo {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	color: rgba(255, 255, 255, 0.95);
}

.footer-logo-image {
	display: block;
	width: auto;
	max-width: 260px;
	max-height: 64px;
	height: auto;
}

.footer-logo-text {
	font-family: var(--font-heading);
	font-size: 2.25rem;
	font-weight: 400;
	letter-spacing: 0.01em;
}

.footer-social {
	margin-top: var(--spacing-lg);
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.footer-social-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
	font-family: var(--font-primary);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	transition: color var(--transition-base), opacity var(--transition-base);
}

.footer-social-link:hover {
	color: rgba(255, 255, 255, 0.95);
}

.footer-social-icon {
	display: inline-flex;
	width: 20px;
	height: 20px;
	color: rgba(255, 255, 255, 0.85);
}

.footer-socials {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
}

.footer-socials-item {
	display: inline-flex;
	flex-direction: row;
	align-items: flex-start;
	gap: 8px;
	width: fit-content;
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
	font-family: var(--font-primary);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	transition: color var(--transition-base), opacity var(--transition-base);
}

.footer-socials-item:hover {
	color: rgba(255, 255, 255, 0.95);
}

.footer-socials-icon {
	display: inline-flex;
	width: 20px;
	height: 20px;
	color: rgba(255, 255, 255, 0.85);
}

.footer-socials-text {
	font-family: var(--font-primary);
	font-size: 14px;
	font-weight: 600;
	text-transform: capitalize;
	color: var(--color-beige);
	text-decoration: none;
	transition: color var(--transition-base), opacity var(--transition-base);
	line-height: 1.2;
}

.footer-content {
	flex: 1 1 60%;
	display: flex;
	justify-content: flex-end;
}

.footer-grid {
	width: 100%;
	max-width: 980px;
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: var(--spacing-lg);
	align-items: start;
}

.footer-col--meta {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xl);
}

.footer-title {
	font-family: var(--font-primary);
	font-size: 18px;
	font-weight: 700;
	color: var(--color-beige);
	margin: 0 0 var(--spacing-sm);
}

.footer-text {
	margin: 0;
	font-family: var(--font-primary);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.6;
	color: var(--color-beige);
}

.footer-link {
	font-family: var(--font-primary);
	font-size: 14px;
	font-weight: 600;
	color: var(--color-beige);
	text-decoration: none;
	transition: color var(--transition-base), opacity var(--transition-base);
}

.footer-link:hover {
	color: var(--color-beige);
}

.footer-rental-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-2xl);
}

.footer-rental-grid--with-socials {
	grid-template-columns: 1fr 1fr 200px;
}

.footer-rental-company {
	font-family: var(--font-primary);
	font-size: 18px;
	font-weight: 700;
	color: var(--color-beige);
	margin: 0 0 var(--spacing-sm);
}

.footer-contact-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
}

.footer-contact-item {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.footer-contact-name {
	font-family: var(--font-primary);
	font-size: 14px;
	font-weight: 700;
	color: var(--color-beige);
}

.footer-contact-value {
	font-family: var(--font-primary);
	font-size: 14px;
	font-weight: 500;
	color: var(--color-beige);
	text-decoration: none;
	width: fit-content;
	transition: color var(--transition-base), opacity var(--transition-base);
}

.footer-contact-value:hover {
	color: var(--color-beige);
}

.footer-bottom {
	border-top: 1px solid var(--color-divider);
}

.footer-bottom-inner {
	padding: var(--spacing-md) var(--spacing-md) 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--spacing-md);
}

.footer-copyright {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	letter-spacing: 0.08em;
	color: var(--color-beige);
	text-transform: uppercase;
}

.footer-credit {
	display: flex;
	align-items: center;
	background-color: var(--color-white);
	gap: var(--spacing-xs);
	font-size: var(--font-size-base);
	color: var(--color-black);
	text-transform: uppercase;
	padding: var(--spacing-xs);
	text-decoration: none;
	transition: opacity var(--transition-fast);
}

.footer-credit:hover {
	opacity: 0.8;
}

.footer-credit span {
	line-height: 1;
}

.footer-credit .pulse {
	width: 0.4em;
	height: 0.4em;
	border-radius: 50%;
	background-color: var(--color-black);
	animation: pulse 1.5s ease-in-out infinite;
}

@keyframes pulse {
	0%, 100% {
		opacity: 1;
	}
	50% {
		opacity: 0.4;
	}
}

.footer-credit img {
	height: 1em;
	width: auto;
	display: block;
	filter: brightness(0) invert(0);
}

@media (max-width: 1024px) {
	.footer-grid {
		grid-template-columns: 1fr;
	}

	.footer-content {
		justify-content: flex-start;
	}
}

@media (max-width: 768px) {
	.site-footer {
		padding: var(--spacing-md) 0 var(--spacing-lg);
	}

	.footer-inner {
		flex-direction: column;
		padding: 0 var(--spacing-sm) var(--spacing-lg);
		gap: var(--spacing-lg);
	}

	.footer-social {
		margin-top: var(--spacing-sm);
	}

	.footer-rental-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}

	.footer-bottom-inner {
		padding: var(--spacing-lg) var(--spacing-sm) 0;
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-sm);
	}
}

/* Contact Section */
/**
 * Contact Hero Styles
 *
 * @package FolèResidence
 */

 .contact-hero {
	width: 100%;
	background-color: var(--color-dark-charcoal);
	padding: 0;
}

.contact-hero-container {
	width: 100%;
	display: flex;
	flex-direction: column;
}

/* Contact page: make content fill viewport height (footer hidden) */
.page-template-page-contact-php .contact-hero,
.page-template-page-contact-php .contact-hero-container {
	min-height: 100vh;
	min-height: 100svh;
	/* Prefer dynamic viewport height on modern mobile browsers (fixes bottom toolbar “extra space”). */
	min-height: 100dvh;
}

.page-template-page-contact-php .contact-hero-divider {
	margin-top: auto;
}

.contact-hero-heading {
	width: 100%;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: var(--spacing-2xl) var(--spacing-md) var(--spacing-md);
	min-height: 40vh;
}

.contact-hero-title {
	font-family: var(--font-serif);
	font-size: var(--font-size-h1);
	font-weight: 400;
	color: var(--color-beige);
	text-align: center;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	line-height: var(--line-height-tight);
	margin: 0;
}

.contact-hero-mobile-image {
	display: none; /* mobile-only */
	width: 100%;
	margin-top: var(--spacing-md);
}

.contact-hero-mobile-image img {
	display: block;
	width: 100%;
	height: auto;
}

.contact-hero-divider {
	width: 100%;
	height: 1px;
	background-color: var(--color-divider);
	margin: 0;
}

.contact-hero-info {
	width: 100%;
	display: flex;
	align-items: center;
	padding: 0;
}

.contact-hero-item {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--spacing-lg) var(--spacing-md);
}

.contact-hero-item-content {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
	align-items: center;
	text-align: center;
}

.contact-hero-label {
	font-family: var(--font-primary);
	font-size: var(--font-size-2xl);
	font-weight: 400;
	color: var(--color-text-secondary);
	text-transform: none;
	letter-spacing: 0.01em;
}

.contact-hero-value {
	font-family: var(--font-primary);
	font-size: var(--font-size-h2);
	font-weight: 400;
	color: var(--color-beige);
	text-decoration: none;
	transition: opacity var(--transition-base);
}

.contact-hero-value:hover {
	opacity: 0.8;
}

.contact-hero-divider-vertical {
	width: 1px;
	height: 100%;
	background-color: var(--color-divider);
	flex-shrink: 0;
	min-height: 60px;
}

/* Responsive */
@media (max-width: 768px) {
	.contact-hero-heading {
		flex-direction: column;
		align-items: center;
		min-height: 30vh;
		padding: var(--spacing-2xl) var(--spacing-md) var(--spacing-sm);
	}
	
	.contact-hero-title {
		font-size: 3.5rem;
	}

	.contact-hero-mobile-image {
		display: block;
	}
	
	.contact-hero-info {
		flex-direction: column;
	}
	
	.contact-hero-item {
		width: 100%;
		padding: var(--spacing-md);
	}
	
	.contact-hero-label {
		font-size: var(--font-size-xl);
	}
	
	.contact-hero-value {
		font-size: var(--font-size-2xl);
	}
	
	.contact-hero-divider-vertical {
		width: 100%;
		height: 1px;
		min-height: 1px;
	}
}

/* About Content Section */
.about-content-section {
	width: 100%;
	background-color: var(--color-dark);
	padding: var(--spacing-2xl) var(--spacing-md);
}

.about-content-container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-xl);
}

.about-content-description {
	width: 100%;
	text-align: center;
	max-width: 800px;
}

.about-content-description p {
	font-family: var(--font-primary);
	font-size: var(--font-size-xl);
	font-weight: 400;
	color: var(--color-beige);
	line-height: var(--line-height-base);
	margin: 0;
}

.about-content-amenities {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--spacing-sm);
	max-width: 1000px;
}

.about-content-amenity {
	display: flex;
	align-items: center;
	gap: var(--spacing-xs);
	padding: var(--spacing-xs) var(--spacing-sm);
	background-color: var(--color-white);
	border: 1px solid #e0e0e0;
	border-radius: 24px;
	transition: border-color var(--transition-base), background-color var(--transition-base);
}

.about-content-amenity:hover {
	border-color: var(--color-text-light);
	background-color: #f9f9f9;
}

.about-content-amenity-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	color: var(--color-text);
}

.about-content-amenity-icon svg {
	width: 100%;
	height: 100%;
	display: block;
}

.about-content-amenity-text {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text);
	white-space: nowrap;
}

/* Responsive */
@media (max-width: 768px) {
	.about-content-section {
		padding: var(--spacing-xl) var(--spacing-sm);
	}
	
	.about-content-container {
		gap: var(--spacing-lg);
	}
	
	.about-content-description p {
		font-size: var(--font-size-large);
	}
	
	.about-content-amenities {
		gap: var(--spacing-xs);
	}
	
	.about-content-amenity {
		padding: calc(var(--spacing-xs) * 0.75) var(--spacing-sm);
	}
	
	.about-content-amenity-text {
		font-size: var(--font-size-small);
	}
}

/* About Gallery Section */
.about-gallery-section {
	width: 100%;
	padding: var(--spacing-2xl) var(--spacing-md) var(--spacing-md);
}

.about-gallery-grid {
	width: 100%;
	display: grid;
	grid-template-columns: repeat(var(--gallery-columns, 4), 1fr);
	grid-auto-rows: 1fr;
	gap: var(--spacing-sm);
}

.about-gallery-item {
	width: 100%;
	position: relative;
	overflow: hidden;
	aspect-ratio: 1 / 1;
}

.about-gallery-item .about-gallery-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 0;
}

/* Responsive */
@media (max-width: 1024px) {
	.about-gallery-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 768px) {
	.about-gallery-section {
		padding: var(--spacing-xl) var(--spacing-sm);
	}
	
	.about-gallery-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.about-gallery-grid {
		grid-template-columns: 1fr;
	}
}

/* About Workspace Section */
.about-workspace-section {
	width: 100%;
	background-color: var(--color-white);
	padding: var(--spacing-2xl) var(--spacing-md);
}

.about-workspace-container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-xl);
	align-items: start;
}

.about-workspace-left {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
}

.about-workspace-title {
	font-family: var(--font-primary);
	font-size: var(--font-size-h2);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: var(--line-height-tight);
}

.about-workspace-description {
	font-family: var(--font-primary);
	font-size: var(--font-size-large);
	font-weight: 400;
	color: var(--color-text-light);
	line-height: var(--line-height-base);
	margin: 0;
}

.about-workspace-button {
	display: inline-block;
	padding: 0.75rem 2rem;
	background-color: var(--color-black);
	color: var(--color-white);
	text-decoration: none;
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	border-radius: 50px;
	transition: background-color var(--transition-base), transform var(--transition-base);
	align-self: flex-start;
}

.about-workspace-button:hover {
	background-color: var(--color-text);
	transform: translateY(-2px);
}

.about-workspace-right {
	position: relative;
	min-height: 200px;
}

.about-workspace-card {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	display: flex;
	gap: var(--spacing-md);
	padding: var(--spacing-md);
	background-color: #f5f5f5;
	border: 1px solid #e0e0e0;
	border-radius: 12px;
	transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1), transform 0.6s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.6s ease;
	opacity: 0;
	visibility: hidden;
	transform: translateY(30px);
}

.about-workspace-card.active {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.about-workspace-card.prev {
	opacity: 0;
	visibility: hidden;
	transform: translateY(-30px);
}

.about-workspace-card:hover {
	border-color: #d0d0d0;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.about-workspace-card-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	background-color: #e8e8e8;
	border-radius: 50%;
	color: var(--color-text);
}

.about-workspace-card-icon svg {
	width: 20px;
	height: 20px;
	display: block;
}

.about-workspace-card-content {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	flex: 1;
}

.about-workspace-card-title {
	font-family: var(--font-primary);
	font-size: var(--font-size-large);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: var(--line-height-tight);
}

.about-workspace-card-subtitle {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text-light);
	margin: 0;
	line-height: var(--line-height-base);
}

.about-workspace-card-description {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text-light);
	margin: 0;
	line-height: var(--line-height-base);
}

/* Responsive */
@media (max-width: 1024px) {
	.about-workspace-container {
		gap: var(--spacing-lg);
	}
	
	.about-workspace-title {
		font-size: 2rem;
	}
}

@media (max-width: 768px) {
	.about-workspace-section {
		padding: var(--spacing-xl) var(--spacing-sm);
	}
	
	.about-workspace-container {
		grid-template-columns: 1fr;
		gap: var(--spacing-lg);
	}
	
	.about-workspace-title {
		font-size: 1.75rem;
	}
	
	.about-workspace-description {
		font-size: var(--font-size-base);
	}
	
	.about-workspace-right {
		min-height: auto;
	}
	
	.about-workspace-card {
		position: relative;
		opacity: 1;
		visibility: visible;
		transform: none;
		padding: var(--spacing-sm);
		gap: var(--spacing-sm);
		margin-bottom: var(--spacing-sm);
	}
	
	.about-workspace-card-icon {
		width: 40px;
		height: 40px;
	}
	
	.about-workspace-card-icon svg {
		width: 18px;
		height: 18px;
	}
}

/* About CTA Section */
.about-cta-section {
	width: 100%;
	background-color: var(--color-dark);
	padding: var(--spacing-2xl) var(--spacing-md);
}

.about-cta-container {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	background-color: var(--color-white);
	border-radius: 40px;
	padding: var(--spacing-xl);
	display: grid;
	grid-template-columns: 1.5fr 0.8fr;
	gap: var(--spacing-sm);
	align-items: flex-start;
}

.about-cta-left {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
}

.about-cta-headline {
	font-family: var(--font-primary);
	font-size: var(--font-size-h2);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: var(--line-height-tight);
}

.about-cta-description {
	font-family: var(--font-primary);
	font-size: var(--font-size-large);
	font-weight: 400;
	color: var(--color-text);
	line-height: var(--line-height-base);
	margin: 0;
	opacity: 0.9;
}

.about-cta-button {
	display: inline-flex;
	align-items: center;
	gap: 0;
	background-color: var(--color-dark);
	color: var(--color-white);
	text-decoration: none;
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	border-radius: 50px;
	padding: 0.3rem 1rem;
	transition: transform var(--transition-base), box-shadow var(--transition-base);
	align-self: flex-start;
	position: relative;
}

.about-cta-button:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(255, 255, 255, 0.2);
}

.about-cta-button-text {
	margin-right: 0.5rem;
}


.about-cta-right {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-lg);
}

.about-cta-features {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
}

.about-cta-feature {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
}

.about-cta-feature-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	color: var(--color-dark);
}

.about-cta-feature-icon svg {
	width: 20px;
	height: 20px;
	display: block;
}

.about-cta-feature-text {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text);
	line-height: var(--line-height-base);
}

/* Responsive */
@media (max-width: 1024px) {
	.about-cta-container {
		padding: var(--spacing-md) var(--spacing-sm);
		gap: var(--spacing-sm);
	}
	
	.about-cta-headline {
		font-size: 2rem;
	}
}

@media (max-width: 768px) {
	.about-cta-section {
		padding: var(--spacing-xl) var(--spacing-sm);
	}
	
	.about-cta-container {
		grid-template-columns: 1fr;
		border-radius: 24px;
	}
	
	.about-cta-headline {
		font-size: 1.75rem;
	}
	
	.about-cta-description {
		font-size: var(--font-size-base);
	}
	
	.about-cta-right {
		gap: var(--spacing-md);
	}
}

/**
 * Student Paragraphs Section
 * Text that darkens on scroll (UX-optimized scroll-driven animation)
 */
.student-paragraphs-section {
	position: relative;
	/* Height on desktop is managed by JS for scroll-driven animation */
	min-height: 65vh;
	padding: var(--spacing-sm) var(--spacing-sm);
	background-color: var(--color-white);
	display: flex;
	align-items: flex-start;
	justify-content: center;
}

/* Desktop: Make section tall for scroll-driven animation */
@media (min-width: 769px) {
	.student-paragraphs-section {
		min-height: 200vh; /* 2x viewport height - reduced from 250vh */
		padding-top: var(--spacing-md);
	}
}

.student-paragraphs-container {
	max-width: 1400px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-lg);
	width: 100%;
}

/* Desktop: Sticky positioning for smooth reveal */
@media (min-width: 769px) {
	.student-paragraphs-container {
		position: sticky;
		top: 10vh; /* Reduced from 20vh - less empty space above */
		min-height: 60vh;
		display: flex;
		align-items: center;
		justify-content: center;
	}
}

.student-paragraph {
	font-family: var(--font-primary);
	font-size: var(--font-size-h3);
	line-height: var(--line-height-relaxed);
	color: var(--color-dark);
	margin: 0;
}

.student-word {
	display: inline;
	opacity: 0.3;
	transition: opacity 0.15s ease-out;
	will-change: opacity;
}

.student-word.darkening {
	opacity: 1;
}

/* Responsive */
@media (max-width: 768px) {
	.student-paragraphs-section {
		min-height: auto;
		padding: var(--spacing-xl) var(--spacing-sm);
	}
	
	.student-paragraphs-container {
		gap: var(--spacing-md);
		position: static; /* Remove sticky on mobile */
	}
	
	.student-paragraph {
		font-size: var(--font-size-large);
	}
	
	/* On mobile, show all words fully visible */
	.student-word {
		opacity: 1;
	}
}

/* Student Features Section */
.student-features-section {
	width: 100%;
	background-color: var(--color-white);
	padding: var(--spacing-2xl) var(--spacing-md);
}

.student-features-container {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	gap: var(--spacing-xl);
}

.student-features-heading {
	font-family: var(--font-primary);
	font-size: var(--font-size-h2);
	font-weight: 400;
	color: var(--color-text);
	margin: 0;
	line-height: var(--line-height-tight);
}

.student-features-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--spacing-lg);
	align-items: flex-start;
	width: 100%;
}

.student-features-feature {
	display: flex;
	flex-direction: column;
}

.student-features-feature-content {
	display: flex;
	gap: var(--spacing-sm);
	align-items: flex-start;
	flex-direction: column;
}

.student-features-feature-icon {
	width: 40px;
	height: 40px;
	flex-shrink: 0;
	margin-top: 2px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.student-features-grid > .student-features-feature:nth-child(1) .student-features-feature-icon {
	color: var(--color-amber);
}

.student-features-grid > .student-features-feature:nth-child(2) .student-features-feature-icon {
	color: #7B68EE;
}

.student-features-grid > .student-features-feature:nth-child(3) .student-features-feature-icon {
	color: #4A90E2;
}

.student-features-feature-icon svg {
	width: 100%;
	height: 100%;
	display: block;
}

.student-features-feature-text {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
}

.student-features-feature-label {
	font-family: var(--font-primary);
	font-size: var(--font-size-small);
	font-weight: 400;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0;
}

.student-features-feature-heading {
	font-family: var(--font-primary);
	font-size: var(--font-size-h3);
	font-weight: 400;
	color: var(--color-text);
	margin: 0 0 var(--spacing-sm) 0;
	line-height: var(--line-height-tight);
}

.student-features-feature-description {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text);
	line-height: var(--line-height-base);
	margin: 0;
}

/* Responsive */
@media (max-width: 1024px) {
	.student-features-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--spacing-md);
	}
	
	.student-features-heading {
		font-size: 2rem;
	}
}

@media (max-width: 768px) {
	.student-features-section {
		padding: var(--spacing-lg) var(--spacing-sm);
	}

	.student-features-heading {
		font-size: var(--font-size-xl);
	}

	.student-features-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}

	.student-features-feature-heading {
		font-size: var(--font-size-xl);
	}
}

/* Student Housing Grid Section */
.student-housing-section {
	background-color: var(--color-white);
	padding: var(--spacing-2xl) var(--spacing-md);
}

.student-housing-container {
	max-width: 1200px;
	margin: 0 auto;
}

.student-housing-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--spacing-lg);
}

.student-housing-card {
	display: flex;
	flex-direction: column;
	background-color: var(--color-white);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
	transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.student-housing-card:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	transform: translateY(-2px);
}

.student-housing-card-image {
	width: 100%;
	height: 300px;
	overflow: hidden;
	background-color: #f5f5f5;
}

.student-housing-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.student-housing-card:hover .student-housing-card-image img {
	transform: scale(1.05);
}

.student-housing-card-content {
	padding: var(--spacing-md);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
	flex: 1;
}

.student-housing-card-title {
	font-family: var(--font-primary);
	font-size: var(--font-size-xl);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
	line-height: var(--line-height-tight);
}

.student-housing-card-subtitle {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text-light);
	line-height: var(--line-height-base);
	margin: 0;
}

.student-housing-card-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 1.5rem;
	background-color: var(--color-black);
	color: var(--color-white);
	text-decoration: none;
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	border-radius: 50px;
	transition: background-color var(--transition-base), transform var(--transition-base);
	margin-top: var(--spacing-xs);
	align-self: flex-start;
}

.student-housing-card-cta:hover {
	background-color: var(--color-text);
	transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 768px) {
	.student-housing-section {
		padding: var(--spacing-xl) var(--spacing-sm);
	}
	
	.student-housing-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}
	
	.student-housing-card-image {
		height: 250px;
	}
	
	.student-housing-card-content {
		padding: var(--spacing-sm);
	}
	
	.student-housing-card-title {
		font-size: var(--font-size-large);
	}
}

/* Hotel Features Section */
.hotel-features-section {
	width: 100%;
	background-color: var(--color-white);
	padding: var(--spacing-2xl) var(--spacing-md);
}

.hotel-features-container {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	gap: var(--spacing-xl);
}

.hotel-features-heading {
	font-family: var(--font-primary);
	font-size: var(--font-size-h2);
	font-weight: 400;
	color: var(--color-text);
	margin: 0;
	line-height: var(--line-height-tight);
}

.hotel-features-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--spacing-lg);
	align-items: flex-start;
	width: 100%;
}

.hotel-features-feature {
	display: flex;
	flex-direction: column;
}

.hotel-features-feature-content {
	display: flex;
	gap: var(--spacing-sm);
	align-items: flex-start;
	flex-direction: column;
}

.hotel-features-feature-icon {
	width: 40px;
	height: 40px;
	flex-shrink: 0;
	margin-top: 2px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.hotel-features-grid > .hotel-features-feature:nth-child(1) .hotel-features-feature-icon {
	color: var(--color-amber);
}

.hotel-features-grid > .hotel-features-feature:nth-child(2) .hotel-features-feature-icon {
	color: #7B68EE;
}

.hotel-features-grid > .hotel-features-feature:nth-child(3) .hotel-features-feature-icon {
	color: #4A90E2;
}

.hotel-features-feature-icon svg {
	width: 100%;
	height: 100%;
	display: block;
}

.hotel-features-feature-text {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
}

.hotel-features-feature-label {
	font-family: var(--font-primary);
	font-size: var(--font-size-small);
	font-weight: 400;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0;
}

.hotel-features-feature-heading {
	font-family: var(--font-primary);
	font-size: var(--font-size-h3);
	font-weight: 400;
	color: var(--color-text);
	margin: 0 0 var(--spacing-sm) 0;
	line-height: var(--line-height-tight);
}

.hotel-features-feature-description {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text);
	line-height: var(--line-height-base);
	margin: 0;
}

/* Responsive */
@media (max-width: 1024px) {
	.hotel-features-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--spacing-md);
	}
	
	.hotel-features-heading {
		font-size: 2rem;
	}
}

@media (max-width: 768px) {
	.hotel-features-section {
		padding: var(--spacing-lg) var(--spacing-sm);
	}

	.hotel-features-heading {
		font-size: var(--font-size-xl);
	}

	.hotel-features-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}

	.hotel-features-feature-heading {
		font-size: var(--font-size-xl);
	}
}

/* Hotel Amenities Section */
.hotel-amenities-section {
	width: 100%;
	background-color: var(--color-white);
	padding: var(--spacing-2xl) var(--spacing-md);
}

.hotel-amenities-container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-xl);
}

.hotel-amenities-description {
	width: 100%;
	text-align: center;
	max-width: 800px;
}

.hotel-amenities-description p {
	font-family: var(--font-primary);
	font-size: var(--font-size-xl);
	font-weight: 400;
	color: var(--color-text);
	line-height: var(--line-height-base);
	margin: 0;
}

.hotel-amenities-list {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--spacing-sm);
	max-width: 1000px;
}

.hotel-amenity {
	display: flex;
	align-items: center;
	gap: var(--spacing-xs);
	padding: var(--spacing-xs) var(--spacing-sm);
	background-color: var(--color-white);
	border: 1px solid #e0e0e0;
	border-radius: 24px;
	transition: border-color var(--transition-base), background-color var(--transition-base);
}

.hotel-amenity:hover {
	border-color: var(--color-text-light);
	background-color: #f9f9f9;
}

.hotel-amenity-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	color: var(--color-text);
}

.hotel-amenity-icon svg {
	width: 100%;
	height: 100%;
	display: block;
}

.hotel-amenity-text {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-text);
	white-space: nowrap;
}

/* Responsive */
@media (max-width: 768px) {
	.hotel-amenities-section {
		padding: var(--spacing-xl) var(--spacing-sm);
	}
	
	.hotel-amenities-container {
		gap: var(--spacing-lg);
	}
	
	.hotel-amenities-description p {
		font-size: var(--font-size-large);
	}
	
	.hotel-amenities-list {
		gap: var(--spacing-xs);
	}
	
	.hotel-amenity {
		padding: calc(var(--spacing-xs) * 0.75) var(--spacing-sm);
	}
	
	.hotel-amenity-text {
		font-size: var(--font-size-small);
	}
}

/* Hotel Information Section */
.hotel-information-section {
	width: 100%;
	background-color: var(--color-dark);
	padding: var(--spacing-2xl) var(--spacing-md);
}

.hotel-information-container {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	gap: var(--spacing-xl);
}

.hotel-information-heading {
	font-family: var(--font-primary);
	font-size: var(--font-size-h2);
	font-weight: 400;
	color: var(--color-beige);
	margin: 0;
	line-height: var(--line-height-tight);
}

.hotel-information-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--spacing-lg);
	align-items: flex-start;
	width: 100%;
}

.hotel-information-item {
	display: flex;
	flex-direction: column;
}

.hotel-information-item-content {
	display: flex;
	gap: var(--spacing-sm);
	align-items: flex-start;
	flex-direction: column;
}

.hotel-information-item-icon {
	width: 40px;
	height: 40px;
	flex-shrink: 0;
	margin-top: 2px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-beige);
}

.hotel-information-item-icon svg {
	width: 100%;
	height: 100%;
	display: block;
}

.hotel-information-item-text {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
}

.hotel-information-item-label {
	font-family: var(--font-primary);
	font-size: var(--font-size-small);
	font-weight: 400;
	color: var(--color-text-secondary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0;
}

.hotel-information-item-heading {
	font-family: var(--font-primary);
	font-size: var(--font-size-h3);
	font-weight: 400;
	color: var(--color-beige);
	margin: 0 0 var(--spacing-sm) 0;
	line-height: var(--line-height-tight);
}

.hotel-information-item-description {
	font-family: var(--font-primary);
	font-size: var(--font-size-base);
	font-weight: 400;
	color: var(--color-beige);
	line-height: var(--line-height-base);
	margin: 0;
	opacity: 0.9;
}

/* Responsive */
@media (max-width: 1024px) {
	.hotel-information-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--spacing-md);
	}
	
	.hotel-information-heading {
		font-size: 2rem;
	}
}

@media (max-width: 768px) {
	.hotel-information-section {
		padding: var(--spacing-lg) var(--spacing-sm);
	}

	.hotel-information-heading {
		font-size: var(--font-size-xl);
	}

	.hotel-information-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}

	.hotel-information-item-heading {
		font-size: var(--font-size-xl);
	}
}

/* Hotel Gallery Section */
.hotel-gallery-section {
	width: 100%;
	padding: var(--spacing-2xl) var(--spacing-md) var(--spacing-md);
}

.hotel-gallery-grid {
	width: 100%;
	display: grid;
	grid-template-columns: repeat(var(--gallery-columns, 4), 1fr);
	grid-auto-rows: 1fr;
	gap: var(--spacing-sm);
}

.hotel-gallery-item {
	width: 100%;
	position: relative;
	overflow: hidden;
	aspect-ratio: 1 / 1;
}

.hotel-gallery-item .hotel-gallery-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 0;
}

/* Responsive */
@media (max-width: 1024px) {
	.hotel-gallery-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 768px) {
	.hotel-gallery-section {
		padding: var(--spacing-xl) var(--spacing-sm);
	}

	.hotel-gallery-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.hotel-gallery-grid {
		grid-template-columns: 1fr;
	}
}
