/* ==========================================================================
   LOS VIAJES DE RAMSITO v2 — Premium Design System
   ========================================================================== */

/* --- Global overflow fix --- */
html, body {
	overflow-x: hidden;
}

/* --- Design Tokens --- */
:root {
	--primary: #3a1c06;
	--primary-container: #533119;
	--secondary: #85531c;
	--secondary-container: #febc7b;
	--tertiary: #002737;
	--surface: #f1fbfc;
	--surface-container-low: #ebf5f6;
	--on-surface: #141d1e;
	--on-surface-variant: #50443d;
	--outline-variant: #d5c3ba;
	--inverse-primary: #f0bb9a;
	--transition-fast: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	--transition-base: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
	--transition-slow: 0.8s cubic-bezier(0.4, 0, 0.2, 1);
	--transition-elegant: 1s cubic-bezier(0.16, 1, 0.3, 1);
}

/* --- Scroll Reveal Animations --- */
.reveal {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity var(--transition-elegant), transform var(--transition-elegant);
}
.reveal.revealed {
	opacity: 1;
	transform: translateY(0);
}

.reveal-left {
	opacity: 0;
	transform: translateX(-60px);
	transition: opacity var(--transition-elegant), transform var(--transition-elegant);
}
.reveal-left.revealed {
	opacity: 1;
	transform: translateX(0);
}

.reveal-right {
	opacity: 0;
	transform: translateX(60px);
	transition: opacity var(--transition-elegant), transform var(--transition-elegant);
}
.reveal-right.revealed {
	opacity: 1;
	transform: translateX(0);
}

.reveal-scale {
	opacity: 0;
	transform: scale(0.9);
	transition: opacity var(--transition-elegant), transform var(--transition-elegant);
}
.reveal-scale.revealed {
	opacity: 1;
	transform: scale(1);
}

.reveal-fade {
	opacity: 0;
	transition: opacity 1.2s ease;
}
.reveal-fade.revealed {
	opacity: 1;
}

/* Stagger children */
.stagger-children > * {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}
.stagger-children.revealed > *:nth-child(1) { transition-delay: 0.1s; opacity: 1; transform: translateY(0); }
.stagger-children.revealed > *:nth-child(2) { transition-delay: 0.2s; opacity: 1; transform: translateY(0); }
.stagger-children.revealed > *:nth-child(3) { transition-delay: 0.3s; opacity: 1; transform: translateY(0); }
.stagger-children.revealed > *:nth-child(4) { transition-delay: 0.4s; opacity: 1; transform: translateY(0); }
.stagger-children.revealed > *:nth-child(5) { transition-delay: 0.5s; opacity: 1; transform: translateY(0); }
.stagger-children.revealed > *:nth-child(6) { transition-delay: 0.6s; opacity: 1; transform: translateY(0); }

/* --- Hero Slider — Revolution Style --- */
.hero-slider {
	position: relative;
	width: 100%;
	height: 100vh;
	height: 100dvh;
	min-height: 650px;
	max-height: 1100px;
	overflow: hidden;
}

/* Slides */
.hero-slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	visibility: hidden;
	transition: opacity 1.2s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s 1.2s;
	z-index: 0;
}
.hero-slide.active {
	opacity: 1;
	visibility: visible;
	transition: opacity 1.2s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s 0s;
	z-index: 1;
}
.hero-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1);
	transition: transform 8s cubic-bezier(0.2, 0, 0.2, 1);
}
.hero-slide.active img {
	transform: scale(1.08);
}
.hero-slide .hero-overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
}

/* Per-slide content */
.slide-content {
	position: absolute;
	inset: 0;
	z-index: 2;
	display: flex;
	align-items: flex-end;
	padding-bottom: 5rem;
}
@media (min-width: 768px) {
	.slide-content { padding-bottom: 6rem; }
}

/* Slide layers — animated entrance */
.slide-layer {
	opacity: 0;
	transform: translateY(35px);
	transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
	            transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
.hero-slide.active .slide-layer {
	opacity: 1;
	transform: translateY(0);
}
.hero-slide:not(.active) .slide-layer {
	opacity: 0;
	transform: translateY(-20px);
	transition: opacity 0.4s ease, transform 0.4s ease;
}

/* Navigation Arrows */
.hero-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 20;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.06);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid rgba(255, 255, 255, 0.12);
	color: rgba(255, 255, 255, 0.7);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.35s ease;
	padding: 0;
}
.hero-arrow:hover {
	background: rgba(255, 255, 255, 0.15);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.3);
	transform: translateY(-50%) scale(1.08);
}
.hero-arrow--prev { left: 1.5rem; }
.hero-arrow--next { right: 1.5rem; }
@media (min-width: 768px) {
	.hero-arrow--prev { left: 2.5rem; }
	.hero-arrow--next { right: 2.5rem; }
}
@media (max-width: 767px) {
	.hero-arrow { width: 40px; height: 40px; }
}

/* Counter + Progress Bar */
.hero-counter {
	position: absolute;
	bottom: 2rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 20;
	display: flex;
	align-items: center;
	gap: 1rem;
}
.hero-counter__track {
	width: 120px;
	height: 2px;
	background: rgba(255, 255, 255, 0.15);
	border-radius: 2px;
	overflow: hidden;
}
.hero-counter__bar {
	height: 100%;
	width: 0%;
	background: #febc7b;
	border-radius: 2px;
	transition: width 0.3s linear;
}
.hero-counter__bar.animating {
	transition: width linear;
}
@media (min-width: 768px) {
	.hero-counter__track { width: 180px; }
}

/* Scroll indicator */
.scroll-indicator {
	position: absolute;
	bottom: 4rem;
	right: 3rem;
	z-index: 20;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	animation: scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
	0%, 100% { transform: translateY(0); opacity: 0.7; }
	50% { transform: translateY(8px); opacity: 1; }
}

/* --- Parallax --- */
.parallax-bg {
	will-change: transform;
	transition: transform 0.1s linear;
}

/* --- Text animations --- */
.title-reveal {
	overflow: hidden;
}
.title-reveal span {
	display: inline-block;
	transform: translateY(100%);
	transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.title-reveal.revealed span {
	transform: translateY(0);
}

/* --- Image treatments --- */
.img-premium {
	filter: brightness(0.85) saturate(0.75) contrast(1.05) sepia(0.08);
	transition: filter 0.7s ease, transform 0.7s ease;
}
.img-premium:hover,
.group:hover .img-premium {
	filter: brightness(0.92) saturate(0.88) contrast(1.05) sepia(0.04);
}

.img-hero {
	filter: brightness(0.55) saturate(0.6) contrast(1.1) sepia(0.12);
}

/* --- Card hover effects --- */
.card-lift {
	transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
	            box-shadow 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.card-lift:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 60px rgba(83, 49, 25, 0.12);
}

/* --- Button shine effect --- */
.btn-shine {
	position: relative;
	overflow: hidden;
}
.btn-shine::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
	transition: left 0.5s ease;
}
.btn-shine:hover::before {
	left: 100%;
}

/* --- Line draw animation --- */
.line-draw {
	position: relative;
}
.line-draw::after {
	content: '';
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--secondary);
	transition: width 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.line-draw:hover::after,
.line-draw.active::after {
	width: 100%;
}

/* --- Glassmorphism --- */
.glass {
	background: rgba(241, 251, 252, 0.8);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
}
.glass-dark {
	background: rgba(26, 14, 5, 0.6);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
}

/* --- Mobile menu (Premium Fullscreen) --- */
.mobile-menu {
	position: fixed !important;
	inset: 0 !important;
	z-index: 9999 !important;
	pointer-events: none;
	visibility: hidden;
	display: block !important;
}
.mobile-menu.open {
	pointer-events: auto !important;
	visibility: visible !important;
}

/* Background overlay */
.mobile-menu__bg {
	position: absolute !important;
	inset: 0 !important;
	z-index: 0 !important;
	background: linear-gradient(165deg, #2a1303 0%, #3a1c06 40%, #4a2510 100%) !important;
	opacity: 0;
	transition: opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}
.mobile-menu.open .mobile-menu__bg {
	opacity: 1 !important;
}

/* Decorative scarab watermark */
.mobile-menu__scarab {
	position: absolute;
	bottom: 15%;
	right: -10%;
	width: 260px;
	height: 260px;
	opacity: 0;
	transform: rotate(-15deg);
	transition: opacity 0.8s ease 0.3s;
	pointer-events: none;
	filter: brightness(0.4) sepia(0.2);
	mix-blend-mode: soft-light;
	z-index: 0 !important;
}
.mobile-menu.open .mobile-menu__scarab {
	opacity: 0.12;
}

/* Header row */
.mobile-menu__header {
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	z-index: 10 !important;
	display: flex !important;
	justify-content: space-between;
	align-items: center;
	padding: 1.25rem 1.5rem;
	opacity: 0;
	transform: translateY(-10px);
	transition: opacity 0.4s ease 0.15s, transform 0.4s ease 0.15s;
}
.mobile-menu.open .mobile-menu__header {
	opacity: 1 !important;
	transform: translateY(0) !important;
}

.mobile-menu__logo {
	height: 2rem;
	width: auto;
	filter: brightness(0) invert(1);
	opacity: 0.7;
}

/* Close button — custom X with animated lines */
.mobile-menu__close {
	position: relative;
	z-index: 10 !important;
	width: 44px;
	height: 44px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 50%;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
	padding: 0;
}
.mobile-menu__close:hover {
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.2);
	transform: rotate(90deg);
}
.mobile-menu__close:active {
	transform: rotate(90deg) scale(0.9);
}
.mobile-menu__close-icon {
	position: relative;
	width: 18px;
	height: 18px;
}
.mobile-menu__close-icon::before,
.mobile-menu__close-icon::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	height: 1.5px;
	background: rgba(255, 255, 255, 0.85);
	border-radius: 1px;
}
.mobile-menu__close-icon::before {
	transform: rotate(45deg);
}
.mobile-menu__close-icon::after {
	transform: rotate(-45deg);
}

/* Navigation container */
.mobile-menu__nav {
	position: relative !important;
	z-index: 5 !important;
	height: auto !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	padding: 5rem 2rem 2rem;
	gap: 0;
}

/* Individual link */
.mobile-menu__link,
#mobile-menu .mobile-menu__link,
.mobile-menu .mobile-menu__nav .mobile-menu__link {
	display: flex !important;
	align-items: baseline !important;
	gap: 1rem;
	text-decoration: none !important;
	color: #ffffff !important;
	padding: 0.85rem 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	transform: translateX(-30px);
	opacity: 0;
	transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
	            opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.mobile-menu__link:first-child {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.mobile-menu.open .mobile-menu__link,
#mobile-menu.open .mobile-menu__link {
	transform: translateX(0) !important;
	opacity: 1 !important;
	visibility: visible !important;
	display: flex !important;
}
/* Stagger using nth-of-type (avoids img/div sibling offset) */
.mobile-menu.open .mobile-menu__link:nth-of-type(1) { transition-delay: 0.12s; }
.mobile-menu.open .mobile-menu__link:nth-of-type(2) { transition-delay: 0.17s; }
.mobile-menu.open .mobile-menu__link:nth-of-type(3) { transition-delay: 0.22s; }
.mobile-menu.open .mobile-menu__link:nth-of-type(4) { transition-delay: 0.27s; }
.mobile-menu.open .mobile-menu__link:nth-of-type(5) { transition-delay: 0.32s; }
.mobile-menu.open .mobile-menu__link:nth-of-type(6) { transition-delay: 0.37s; }

/* Reset delays on close for snappy exit */
.mobile-menu:not(.open) .mobile-menu__link {
	transition-delay: 0s !important;
	transition-duration: 0.25s;
}

.mobile-menu__link-number,
#mobile-menu .mobile-menu__link-number {
	font-family: 'Manrope', sans-serif;
	font-size: 0.65rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	color: #febc7b !important;
	min-width: 1.5rem;
}
.mobile-menu__link-text,
#mobile-menu .mobile-menu__link-text {
	font-family: 'Marcellus SC', serif;
	font-size: 1em;
	color: #ffffff !important;
	letter-spacing: 0.04em;
	transition: color 0.3s ease, letter-spacing 0.3s ease;
}
.mobile-menu__link:hover .mobile-menu__link-text,
.mobile-menu__link:active .mobile-menu__link-text {
	color: #febc7b !important;
	letter-spacing: 0.08em;
}
.mobile-menu__link:hover .mobile-menu__link-number,
.mobile-menu__link:active .mobile-menu__link-number {
	color: #febc7b !important;
}

/* Divider between nav and footer */
.mobile-menu__divider {
	width: 40px;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(254, 188, 123, 0.4), transparent);
	margin: 1.5rem auto;
	opacity: 0;
	transition: opacity 0.5s ease 0.4s;
}
.mobile-menu.open .mobile-menu__divider {
	opacity: 1 !important;
}

/* Footer section — inside flow, below links */
.mobile-menu__footer {
	position: relative !important;
	z-index: 5 !important;
	padding: 0 2rem 2rem;
	padding-bottom: calc(2rem + env(safe-area-inset-bottom, 0px));
	display: flex !important;
	flex-direction: column !important;
	align-items: center;
	gap: 1.25rem;
	opacity: 0;
	transform: translateY(15px);
	transition: opacity 0.5s ease 0.42s, transform 0.5s ease 0.42s;
}
.mobile-menu.open .mobile-menu__footer {
	opacity: 1 !important;
	transform: translateY(0) !important;
}
.mobile-menu:not(.open) .mobile-menu__footer {
	transition-delay: 0s;
	transition-duration: 0.2s;
}

/* CTA WhatsApp button */
.mobile-menu__cta,
#mobile-menu .mobile-menu__cta {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 0.6rem;
	width: 100%;
	background: linear-gradient(135deg, #25D366 0%, #128C7E 100%) !important;
	color: #ffffff !important;
	font-family: 'Manrope', sans-serif;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-decoration: none !important;
	padding: 0.85rem 1.6rem;
	border-radius: 2rem;
	box-shadow: 0 4px 15px rgba(37, 211, 102, 0.25);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.mobile-menu__cta:hover,
.mobile-menu__cta:active {
	transform: scale(1.02);
	box-shadow: 0 6px 25px rgba(37, 211, 102, 0.35);
}
.mobile-menu__cta-icon {
	width: 18px;
	height: 18px;
	fill: currentColor;
}

/* Social row */
.mobile-menu__social-row {
	display: flex !important;
	align-items: center;
	gap: 1rem;
	opacity: 0.6;
}
.mobile-menu__social-label {
	font-family: 'Manrope', sans-serif;
	font-size: 0.6rem;
	font-weight: 600;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.4) !important;
}

/* Social links */
.mobile-menu__social {
	display: flex !important;
	gap: 0.6rem;
}
.mobile-menu__social-link,
#mobile-menu .mobile-menu__social-link {
	width: 36px;
	height: 36px;
	display: flex !important;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.12) !important;
	background: rgba(255, 255, 255, 0.04);
	color: rgba(255, 255, 255, 0.6) !important;
	text-decoration: none !important;
	transition: all 0.3s ease;
}
.mobile-menu__social-link:hover {
	color: #febc7b !important;
	border-color: rgba(254, 188, 123, 0.4) !important;
	background: rgba(254, 188, 123, 0.1);
	transform: translateY(-2px);
}
.mobile-menu__social-link .material-symbols-outlined {
	font-size: 16px;
	color: inherit !important;
}

/* --- Divider decorations --- */
.divider-scarab {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1.5rem;
	padding: 2rem 0;
}
.divider-scarab::before,
.divider-scarab::after {
	content: '';
	flex: 1;
	max-width: 120px;
	height: 1px;
	background: linear-gradient(to right, transparent, var(--outline-variant), transparent);
}

/* --- WhatsApp floating button --- */
.whatsapp-float {
	position: fixed;
	bottom: 2rem;
	right: 2rem;
	z-index: 90;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: #25D366;
	color: white;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	text-decoration: none;
}
.whatsapp-float:hover {
	transform: scale(1.1);
	box-shadow: 0 6px 30px rgba(37, 211, 102, 0.5);
}
.whatsapp-float svg {
	width: 28px;
	height: 28px;
	fill: currentColor;
}

/* --- Smooth page transitions --- */
.page-transition {
	animation: pageIn 0.6s ease forwards;
}
@keyframes pageIn {
	from { opacity: 0; transform: translateY(10px); }
	to { opacity: 1; transform: translateY(0); }
}

/* --- Custom scrollbar --- */
::-webkit-scrollbar {
	width: 8px;
}
::-webkit-scrollbar-track {
	background: var(--surface);
}
::-webkit-scrollbar-thumb {
	background: var(--outline-variant);
	border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
	background: var(--secondary);
}

/* --- Selection color --- */
::selection {
	background: rgba(254, 188, 123, 0.3);
	color: var(--primary);
}

/* --- Capitular / drop cap --- */
.capitular::first-letter {
	float: left;
	font-family: 'Marcellus SC', serif;
	font-size: 4.5rem;
	line-height: 1;
	padding-right: 0.75rem;
	color: #BD8348;
	font-weight: 700;
}

/* --- Gradient text --- */
.gradient-text {
	background: linear-gradient(135deg, #febc7b, #BD8348);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

/* --- Image zoom on scroll --- */
.zoom-on-scroll {
	transition: transform 8s ease-out;
}
.zoom-on-scroll.zoomed {
	transform: scale(1.15);
}

/* --- Horizontal scrollbar hide --- */
.scrollbar-hide {
	-ms-overflow-style: none;
	scrollbar-width: none;
}
.scrollbar-hide::-webkit-scrollbar {
	display: none;
}
