/**
 * Site header + footer chrome — mirrors ya/src/styles.css (dark header + logo).
 */

/* Header logo — production yabo-logo.webp
 * Must beat Tailwind preflight + .elementor-page img { height: auto } (pressgo-hospitality.css). */
#navbar .site-header-brand {
	display: inline-flex;
	align-items: center;
	max-height: 2.25rem;
	overflow: hidden;
}

#navbar img.site-header-logo {
	display: block;
	height: 1.75rem;
	width: auto;
	max-width: none;
	flex-shrink: 0;
	object-fit: contain;
	aspect-ratio: 600 / 193;
}

@media (min-width: 768px) {
	#navbar img.site-header-logo {
		height: 2rem;
	}
}

@media (min-width: 1024px) {
	#navbar img.site-header-logo {
		height: 2.25rem;
	}
}

/*
 * Header shell — mirrors ya Header.tsx.
 * Do not rely on Tailwind arbitrary utilities (bg-[#1a1a1b]/94, backdrop-blur-lg):
 * they are often missing from the compiled tailwind.css build.
 */
#navbar.site-header--dark {
	position: fixed;
	inset-inline: 0;
	top: 0;
	z-index: 50;
	overflow-x: clip;
	color: #fff;
	background: rgb(26 26 27 / 0.94);
	-webkit-backdrop-filter: blur(16px);
	backdrop-filter: blur(16px);
	border-bottom: 1px solid rgb(255 255 255 / 0.06);
	transition: box-shadow 0.3s ease;
}

@media (min-width: 768px) {
	#navbar.site-header--dark {
		overflow-x: visible;
		overflow-y: visible;
	}
}

/* Dark site header — yabohotelep.com */
#navbar.site-header--dark .site-header-nav {
	flex-wrap: nowrap;
	align-items: center;
	justify-content: flex-start;
	gap: 0.125rem;
	overflow-x: auto;
	scrollbar-width: none;
}

#navbar.site-header--dark .site-header-nav::-webkit-scrollbar {
	display: none;
}

@media (min-width: 1280px) {
	#navbar.site-header--dark .site-header-nav {
		justify-content: center;
	}
}

#navbar.site-header--dark .site-header-nav-link {
	position: relative;
	padding: 0.5rem 0.625rem;
	font-size: 0.8125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	color: rgb(255 255 255 / 0.68);
	transition: color 0.2s ease;
}

@media (min-width: 1024px) {
	#navbar.site-header--dark .site-header-nav-link {
		padding: 0.5rem 0.75rem;
		font-size: 0.875rem;
	}
}

#navbar.site-header--dark .site-header-nav-link::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0.125rem;
	width: 0;
	height: 2px;
	border-radius: 1px;
	background: #c9a868;
	transform: translateX(-50%);
	transition: width 0.2s ease;
}

#navbar.site-header--dark .site-header-nav-link:hover {
	color: rgb(255 255 255 / 0.92);
}

#navbar.site-header--dark .site-header-nav-link:hover::after {
	width: 42%;
}

#navbar.site-header--dark .site-header-nav-link--active {
	color: #c9a868;
	font-weight: 600;
}

#navbar.site-header--dark .site-header-nav-link--active::after {
	width: 58%;
}

#navbar.site-header--dark .site-header-actions {
	padding-left: 0.625rem;
	margin-left: 0.125rem;
	border-left: 1px solid rgb(255 255 255 / 0.08);
}

@media (min-width: 768px) {
	#navbar.site-header--dark .site-header-actions {
		gap: 0.5rem;
		padding-left: 0.75rem;
	}
}

#navbar.site-header--dark .site-header-actions__btn {
	border: 1px solid rgb(255 255 255 / 0.1);
	background: rgb(255 255 255 / 0.06);
}

#navbar.site-header--dark .site-header-actions__btn--whatsapp:hover {
	background: rgb(37 211 102 / 0.14);
	border-color: rgb(37 211 102 / 0.35);
}

#navbar.site-header--dark .site-header-actions__btn--instagram:hover {
	background: rgb(230 104 60 / 0.14);
	border-color: rgb(230 104 60 / 0.35);
}

#navbar.site-header--dark .site-header-actions__menu,
#navbar.site-header--dark .yb-lang-trigger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.3rem;
	border: 1px solid rgb(255 255 255 / 0.1);
	border-radius: 9999px;
	background: rgb(255 255 255 / 0.05);
	color: rgb(255 255 255 / 0.82);
	box-shadow: none;
	transition: color 0.15s ease, background-color 0.15s ease, border-color 0.15s ease;
}

#navbar.site-header--dark .yb-lang-trigger {
	height: 2.25rem;
	padding: 0.375rem 0.625rem;
	font-size: 0.8125rem;
	font-weight: 500;
}

#navbar.site-header--dark .yb-lang-trigger .yb-lang-label,
#navbar.site-header--dark .yb-lang-trigger .yb-lang-chevron {
	color: rgb(255 255 255 / 0.82);
}

#navbar.site-header--dark .site-header-actions__menu:hover,
#navbar.site-header--dark .yb-lang-trigger:hover {
	color: #c9a868;
	background: rgb(255 255 255 / 0.08);
	border-color: rgb(201 168 104 / 0.25);
}

#navbar.site-header--dark .site-header-actions__menu {
	width: 2.25rem;
	height: 2.25rem;
	padding: 0;
	border-radius: 0.625rem;
}

#navbar.site-header--dark .yb-lang-panel {
	border-color: rgb(255 255 255 / 0.15);
	background: #2b2b2c;
	box-shadow: 0 16px 40px rgb(0 0 0 / 0.35);
}

#navbar.site-header--dark .yb-lang-option {
	color: rgb(255 255 255 / 0.88);
}

#navbar.site-header--dark .yb-lang-option:hover {
	background: rgb(255 255 255 / 0.08);
	color: #c9a868;
}

#navbar.site-header--dark .yb-lang-option.bg-gold\/10 {
	background: rgb(201 168 104 / 0.12) !important;
	color: #c9a868 !important;
}

/* Mobile drawer — dark (production) */
.yb-mobile-nav-panel {
	background: #2b2b2c;
	color: #fff;
}

.yb-mobile-menu-header {
	border-bottom: 1px solid rgb(255 255 255 / 0.08);
}

.yb-mobile-menu-header .site-header-actions__menu {
	border: 1px solid rgb(255 255 255 / 0.1);
	background: rgb(255 255 255 / 0.05);
	color: rgb(255 255 255 / 0.7);
}

.yb-mobile-menu-header .site-header-actions__menu:hover {
	color: #c9a868;
}

:root {
	--mobile-tab-bar-height: 3.25rem;
	--public-contact-bar-offset: 0px;
}

@media (max-width: 767px) {
	:root {
		--public-contact-bar-offset: calc(
			var(--mobile-tab-bar-height) + env(safe-area-inset-bottom, 0px)
		);
	}
}

.gradient-gold {
	background: linear-gradient(135deg, #ead098 0%, #c9a868 48%, #b89452 100%);
}

/* ya .wrap — shared content width */
.wrap {
	box-sizing: border-box;
	width: 100%;
	max-width: 1320px;
	min-width: 0;
	margin-inline: auto;
	padding-inline: 1rem;
}

.yb-site-footer {
	margin-top: 0;
	border-top: 1px solid rgba(229, 231, 235, 0.85);
	background-color: #fafaf8;
}

/* Desktop / tablet footer — pure CSS breakpoints (no Tailwind md:*) */
.yb-site-footer__desktop {
	display: none;
}

.yb-site-footer__mobile {
	display: block;
}

.yb-site-footer__bottom {
	display: none;
}

/* Tablet: brand full-width + 2×2 nav */
@media (min-width: 768px) {
	.yb-site-footer__desktop {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		column-gap: clamp(1.75rem, 4vw, 2.75rem);
		row-gap: clamp(1.75rem, 3vw, 2.25rem);
		padding-block: clamp(2.25rem, 4vw, 3.25rem);
		align-items: start;
	}

	.yb-site-footer__brand {
		grid-column: 1 / -1;
		max-width: 40rem;
	}

	.yb-site-footer__col--contact {
		grid-column: 1 / -1;
		max-width: 24rem;
	}

	.yb-site-footer__mobile {
		display: none;
	}

	.yb-site-footer__bottom {
		display: block;
		border-top: 1px solid rgba(229, 231, 235, 0.85);
		background: rgba(250, 250, 248, 0.95);
	}
}

/* Desktop: ~40% brand · ~14% explore · ~14% markets · ~32% contact */
@media (min-width: 1024px) {
	.yb-site-footer__desktop {
		grid-template-columns:
			minmax(0, 2.35fr)
			minmax(0, 0.95fr)
			minmax(0, 0.95fr)
			minmax(0, 1.35fr);
		column-gap: clamp(2rem, 3.5vw, 3rem);
		row-gap: 0;
		padding-block: clamp(3rem, 5vw, 4.5rem);
	}

	.yb-site-footer__brand {
		grid-column: auto;
		max-width: 34rem;
		padding-right: clamp(0.5rem, 2vw, 1.5rem);
	}

	.yb-site-footer__col--explore,
	.yb-site-footer__col--markets,
	.yb-site-footer__col--contact {
		grid-column: auto;
		max-width: none;
	}

	.yb-site-footer__col--contact {
		padding-left: clamp(0.25rem, 1.5vw, 1rem);
	}
}

@media (min-width: 1280px) {
	.yb-site-footer__desktop {
		grid-template-columns:
			minmax(0, 2.5fr)
			minmax(0, 1fr)
			minmax(0, 1fr)
			minmax(0, 1.45fr);
	}
}

.yb-site-footer__col {
	min-width: 0;
}

.yb-site-footer__view-all {
	margin: 0.875rem 0 0;
	padding: 0;
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.4;
}

.yb-site-footer__view-all a {
	color: rgba(31, 41, 55, 0.82);
	text-decoration: none;
	transition: color 0.2s ease;
}

.yb-site-footer__view-all a:hover {
	color: #c9a868;
}

.yb-site-footer__brand-row {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 1.25rem;
}

.yb-site-footer__mark {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 0.125rem;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: Georgia, "Times New Roman", serif;
	font-weight: 700;
	font-size: 1.125rem;
	color: #fff;
}

.yb-site-footer__logo-text {
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.5rem;
	letter-spacing: 0.12em;
	color: #39393f;
}

.yb-site-footer__positioning {
	max-width: 36rem;
	margin: 0 0 0.5rem;
	line-height: 1.65;
	color: #4b5563;
	font-size: clamp(0.875rem, 1.1vw, 0.9375rem);
}

.yb-site-footer__clarity {
	max-width: 36rem;
	margin: 0 0 0.75rem;
	font-size: 0.75rem;
	line-height: 1.6;
	color: rgba(107, 114, 128, 0.85);
}

.yb-site-footer__trust {
	margin: 0.75rem 0 0;
	padding-top: 0.75rem;
	border-top: 1px solid rgba(229, 231, 235, 0.6);
	font-size: 0.75rem;
	line-height: 1.625;
	color: rgba(107, 114, 128, 0.9);
}

.yb-site-footer__social {
	margin-top: 1.5rem;
}

.yb-site-footer__heading {
	margin: 0 0 1rem;
	font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #b89452;
}

.yb-site-footer__links,
.yb-site-footer__contacts {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	font-size: 0.875rem;
	line-height: 1.45;
	color: #6b7280;
}

.yb-site-footer__links a,
.yb-site-footer__contacts a {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
}

.yb-site-footer__links a:hover,
.yb-site-footer__contacts a:hover {
	color: #c9a868;
}

.yb-site-footer__links-emphasis {
	font-weight: 500;
	color: rgba(31, 41, 55, 0.8) !important;
}

.yb-site-footer__contacts li {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
}

.yb-site-footer__contacts a {
	line-height: 1.45;
}

.yb-site-footer__contact-icon {
	color: #c9a868;
	flex-shrink: 0;
	width: 1rem;
	margin-top: 0.15rem;
}

.yb-site-footer__email {
	word-break: break-word;
	overflow-wrap: anywhere;
}

.yb-site-footer__bottom-inner {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	padding-block: clamp(1.25rem, 2.5vw, 1.75rem);
	font-size: 0.75rem;
	line-height: 1.5;
	color: #6b7280;
}

@media (min-width: 768px) {
	.yb-site-footer__bottom-inner {
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto;
		align-items: end;
		column-gap: clamp(1.5rem, 4vw, 3rem);
		row-gap: 0.75rem;
	}
}

.yb-site-footer__bottom-meta {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	max-width: 42rem;
}

.yb-site-footer__translate-hint {
	margin: 0;
	color: rgba(107, 114, 128, 0.82);
	max-width: 38rem;
}

.yb-site-footer__legal {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem 1.25rem;
}

@media (min-width: 768px) {
	.yb-site-footer__legal {
		justify-content: flex-end;
		text-align: right;
	}
}

.yb-site-footer__legal a {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
}

.yb-site-footer__legal a:hover {
	color: #c9a868;
}

.browser-translate-menu__label {
	display: flex;
	align-items: center;
	gap: 0.375rem;
	margin: 0.5rem 0 0.25rem;
	font-size: 0.75rem;
	color: #6b7280;
}

.browser-translate-menu__label--dark {
	color: rgba(255, 255, 255, 0.7);
}

.browser-translate-menu__icon {
	font-size: 0.875rem;
}

.browser-translate-menu__select {
	margin-top: 0.25rem;
	max-width: 20rem;
	border-radius: 0.125rem;
	border: 1px solid #e5e7eb;
	background: #fff;
	padding: 0.375rem 0.5rem;
	font-size: 0.75rem;
	color: #39393f;
}

.browser-translate-menu__select--footer-dark {
	border-color: rgba(255, 255, 255, 0.2);
	background: rgba(0, 0, 0, 0.2);
	color: #fff;
}

.browser-translate-menu__select:focus {
	outline: 2px solid #c9a868;
	outline-offset: 1px;
}

#navbar .site-header-actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 0.375rem;
	flex-shrink: 0;
}

#navbar .site-header-actions__social {
	display: none;
	align-items: center;
	gap: 0.375rem;
}

#navbar .site-header-actions__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 9999px;
	background: rgba(255, 255, 255, 0.06);
	text-decoration: none;
	transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}

#navbar .site-header-actions__btn--whatsapp {
	color: #25d366;
}

#navbar .site-header-actions__btn--whatsapp:hover {
	background: rgba(37, 211, 102, 0.12);
	border-color: rgba(37, 211, 102, 0.35);
}

#navbar .site-header-actions__btn--instagram {
	color: #e6683c;
}

#navbar .site-header-actions__btn--instagram:hover {
	background: rgba(230, 104, 60, 0.12);
	border-color: rgba(230, 104, 60, 0.35);
}

#navbar .site-header-actions__icon {
	font-size: 1rem;
	line-height: 1;
}

@media (min-width: 768px) {
	#navbar .site-header-actions__social {
		display: inline-flex;
	}
}

.social-contact__label {
	margin: 0 0 0.625rem;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.social-contact__row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.625rem;
}

.social-contact__icon {
	width: 1.125rem;
	height: 1.125rem;
	flex-shrink: 0;
	font-size: 0.875rem;
	line-height: 1;
}

.social-contact__text {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.0625rem;
	min-width: 0;
}

.social-contact__title {
	font-size: 0.8125rem;
	font-weight: 700;
	line-height: 1.2;
}

.social-contact__subtitle {
	font-size: 0.6875rem;
	font-weight: 500;
	line-height: 1.2;
	opacity: 0.92;
}

.social-contact__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	border: none;
	touch-action: manipulation;
	transition: transform 0.15s ease, filter 0.15s ease, box-shadow 0.15s ease;
}

.social-contact__btn--labeled {
	gap: 0.5rem;
	padding: 0.5rem 0.875rem;
	border-radius: 9999px;
	min-height: 2.5rem;
}

.social-contact__btn:active {
	transform: scale(0.98);
}

.social-contact__btn--whatsapp {
	background: #25d366;
	color: #fff;
}

.social-contact__btn--instagram {
	background: linear-gradient(135deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
	color: #fff;
}

.social-contact__btn--facebook {
	background: #1877f2;
	color: #fff;
}

.social-contact--footer-light .social-contact__label {
	color: #b89452;
}

.social-contact--footer-light .social-contact__row {
	gap: 0.5rem;
}

.social-contact--footer-light .social-contact__icon {
	width: 0.875rem;
	height: 0.875rem;
	font-size: 0.875rem;
}

.social-contact--footer-light .social-contact__text {
	display: none;
}

.social-contact--footer-light .social-contact__btn--labeled {
	width: 2rem;
	height: 2rem;
	min-height: 2rem;
	padding: 0;
	gap: 0;
	border-radius: 50%;
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

.social-contact--footer-light .social-contact__btn--whatsapp:hover {
	filter: brightness(1.05);
	box-shadow: 0 4px 14px rgba(37, 211, 102, 0.35);
}

.social-contact--footer-light .social-contact__btn--instagram:hover {
	filter: brightness(1.06);
	box-shadow: 0 4px 14px rgba(220, 39, 67, 0.35);
}

.social-contact--footer-light .social-contact__btn--facebook:hover {
	filter: brightness(1.06);
	box-shadow: 0 4px 14px rgba(24, 119, 242, 0.35);
}

.social-contact--footer-dark {
	margin-bottom: 0.75rem;
}

.social-contact--footer-dark .social-contact__label {
	color: rgba(234, 208, 152, 0.95);
}

.social-contact--footer-dark .social-contact__row {
	gap: 0.5rem;
}

.social-contact--footer-dark .social-contact__icon {
	width: 0.875rem;
	height: 0.875rem;
	font-size: 0.875rem;
}

.social-contact--footer-dark .social-contact__text {
	display: none;
}

.social-contact--footer-dark .social-contact__btn--labeled {
	width: 2rem;
	height: 2rem;
	min-height: 2rem;
	padding: 0;
	gap: 0;
	border-radius: 50%;
	justify-content: center;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

.footer-mobile-hero {
	position: relative;
	background-color: #1f2937;
	background-size: cover;
	background-position: center;
	color: #fff;
}

.footer-mobile-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(24, 28, 36, 0.82) 0%, rgba(16, 18, 24, 0.9) 100%);
	pointer-events: none;
}

.footer-mobile-hero__content {
	position: relative;
	z-index: 1;
	padding-top: 1.75rem;
	padding-bottom: calc(var(--public-contact-bar-offset) + 1rem);
}

.footer-mobile-hero__title {
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	margin-bottom: 0.5rem;
}

.footer-mobile-hero__desc {
	font-size: 0.875rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.92);
	margin-bottom: 0.875rem;
	max-width: 36rem;
}

.footer-mobile-hero__contacts {
	list-style: none;
	margin: 0.75rem 0 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.footer-mobile-hero__contacts li {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.4;
}

.footer-mobile-hero__icon {
	width: 1.125rem;
	color: #fff;
	flex-shrink: 0;
}

.footer-mobile-hero__link {
	color: #fff;
	text-decoration: none;
}

.footer-mobile-hero__link:hover {
	color: #c9a868;
}

.footer-mobile-hero__rule {
	border: none;
	border-top: 1px solid rgba(255, 255, 255, 0.28);
	margin: 1rem 0 0.75rem;
}

.footer-mobile-hero__copyright {
	text-align: center;
	font-size: 0.75rem;
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.88);
	margin-bottom: 0.5rem;
}

.footer-mobile-hero__translate-hint {
	margin: 0.5rem 0 0;
	font-size: 0.75rem;
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.6);
	text-align: center;
}

.footer-mobile-hero__legal {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.375rem;
	margin-bottom: 0.25rem;
}

.footer-mobile-hero__legal-link {
	font-size: 0.8125rem;
	color: rgba(255, 255, 255, 0.95);
	text-decoration: none;
}

.footer-mobile-hero__legal-link:hover {
	color: #c9a868;
}
