/**
 * Media queries — mobile-first overrides para layouts.
 */

/* Tablets (hasta 1024px) */
@media (max-width: 1024px) {
	.wm-hero__inner {
		grid-template-columns: 1fr;
		gap: var(--space-lg);
	}
	.wm-hero__image {
		max-width: 420px;
		margin: 0 auto;
	}
	.wm-grid--4 { grid-template-columns: repeat(2, 1fr); }
	.wm-footer__grid { grid-template-columns: repeat(2, 1fr); }
}

/* Navegación móvil — menú off-canvas (hasta 900px) */
@media (max-width: 900px) {
	.wm-nav-toggle { display: block; }

	/* Logo compacto: el tagline largo empujaba la hamburguesa fuera de pantalla. */
	.wm-logo__tagline { display: none; }
	.wm-logo { min-width: 0; }
	.wm-header__actions { flex-shrink: 0; }

	/* En móvil el header queda con logo + hamburguesa; el CTA vive en el
	   panel del menú y en el botón sticky inferior. */
	.wm-header__actions .wm-cta-reserva { display: none; }

	.wm-nav {
		position: fixed;
		inset: 0 0 0 auto;
		width: min(80vw, 320px);
		flex-direction: column;
		justify-content: flex-start;
		background: var(--color-bg);
		box-shadow: var(--shadow-lg);
		padding: calc(var(--header-height) + var(--space-lg)) var(--space-lg) var(--space-lg);
		transform: translateX(100%);
		transition: transform .3s ease;
		z-index: 99;
		overflow-y: auto;
	}
	.wm-nav.is-open { transform: translateX(0); }

	.wm-nav__list {
		flex-direction: column;
		gap: var(--space-sm);
		width: 100%;
	}
	.wm-nav__list a {
		display: block;
		font-size: 1.05rem;
		padding: 0.6rem 0;
		color: var(--color-text);
		border-bottom: 1px solid var(--color-border);
	}
	.wm-nav__list a::after { display: none; }

	.wm-nav__cta { display: block; margin-top: var(--space-md); }
	.wm-nav__cta .wm-cta-reserva { display: block; text-align: center; }

	/* Submenús inline dentro del panel (no flotantes) */
	.wm-nav__list .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		min-width: 0;
		border: 0;
		box-shadow: none;
		padding: 0 0 0 var(--space-sm);
		background: transparent;
	}
	.wm-nav__list .sub-menu a { font-size: 0.95rem; padding: 0.5rem 0; }

	/* El panel siempre es claro, incluso en modo overlay */
	body.wm-nav-overlay .wm-nav__list a { color: var(--color-text); }

	/* Bloquear scroll del fondo con el menú abierto */
	body.wm-nav-open { overflow: hidden; }
	body.wm-nav-open .wm-topbar { display: none; }
}

/* Mobile (hasta 768px) */
@media (max-width: 768px) {
	:root {
		--fs-base: 1rem;
		--space-xl: 3rem;
		--space-2xl: 4rem;
	}

	.wm-hero--video .wm-hero__overlay {
		background: linear-gradient(180deg,
			rgba(92, 58, 42, 0.72) 0%,
			rgba(92, 58, 42, 0.5) 45%,
			rgba(40, 24, 16, 0.62) 100%);
	}

	.wm-grid--3,
	.wm-grid--2 { grid-template-columns: 1fr; }
	.wm-footer__grid {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.wm-section { padding: var(--space-lg) 0; }
	.wm-hero { padding: var(--space-xl) 0; }

	/* CTA sticky inferior solo en mobile */
	.wm-cta--sticky { display: block; }

	/* Reservar espacio inferior para no tapar contenido con el CTA sticky */
	body { padding-bottom: 5rem; }

	.wm-topbar { font-size: 0.72rem; }
	.wm-topbar__inner { gap: var(--space-md); }
	.wm-topbar__item--addr { display: none; }

	.wm-hero__horarios { font-size: 0.9rem; }
	.wm-hero--video { min-height: 100svh; }
	.wm-hero__actions { gap: var(--space-sm); }
}

/* Mobile chico (hasta 480px) */
@media (max-width: 480px) {
	.wm-logo__tagline { display: none; }
	.wm-hero__title { font-size: 1.75rem; }
	.wm-cta--primary {
		font-size: 0.95rem;
		padding: 0.85rem 1.5rem;
		display: block;
		text-align: center;
	}
	.wm-whatsapp-float {
		bottom: 5.5rem; /* arriba del CTA sticky */
	}
}

/* Print */
@media print {
	.wm-header,
	.wm-footer,
	.wm-cta-reserva,
	.wm-whatsapp-float,
	.wm-cta--sticky { display: none !important; }
}
