/* Reset / Base */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif; color: #1f2937; background: #ffffff; line-height: 1.6; }

/* Navbar */
.navbar {
  position: fixed; top: 0; left: 0; right: 0;
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 20px; z-index: 1000;
  background: #004080;
  backdrop-filter: saturate(150%) blur(6px);
  transition: background 0.3s ease;
}
.navbar.is-scrolled { background: rgba(0, 64, 128, 0.6); }
.logo { display: flex; align-items: center; gap: 10px; }
.logo img { width: 64px; height: 64px; border-radius: 10px; object-fit: cover; box-shadow: 0 4px 10px rgba(0,0,0,.25); }
.logo-text { display: flex; flex-direction: column; }
.logo-text span:first-child { color: #fff; font-weight: 700; font-size: 1.25rem; letter-spacing: .3px; text-shadow: 0 1px 2px rgba(0,0,0,.6); }
.logo-text .subtitle { color: #ffdd57; font-size: .85rem; text-shadow: 0 1px 2px rgba(0,0,0,.5); }

/* Menu */
.menu-toggle { display: none; font-size: 1.75rem; background: transparent; border: 0; color: #fff; cursor: pointer; }
#menu { display: flex; gap: 16px; align-items: center; }
#menu a { color: #fff; font-weight: 600; text-decoration: none; padding: 8px 10px; border-radius: 8px; }
#menu a:hover, #menu a:focus { background: rgba(255,255,255,.12); outline: none; }

/* Hero / Carousel */
.hero { margin-top: 84px; }
.carousel { position: relative; height: calc(100vh - 84px); overflow: hidden; }
.slides { display: none; position: relative; height: 100%; }
.slides img { width: 100%; height: 100%; object-fit: cover; }
.caption { position: absolute; z-index: 2; inset: 0; display: grid; place-content: center; text-align: center; color: #fff; text-shadow: 1px 1px 3px rgba(0,0,0,.7); padding: 0 16px; }
.caption h1 { font-size: clamp(1.8rem, 3.5vw, 3rem); margin-bottom: .5rem; }
.caption p { font-size: clamp(1rem, 2vw, 1.25rem); margin-bottom: 1rem; }
.btn { background: #ff6f61; color: #fff; padding: 12px 18px; border-radius: 10px; text-decoration: none; border: 0; cursor: pointer; font-weight: 700; }
.btn:hover { background: #e65b50; }
.btn.ghost { background: #f3f4f6; color: #111827; }

.fade { animation: fadeEffect 1.2s ease-in-out; }
@keyframes fadeEffect { from { opacity: .4 } to { opacity: 1 } }

/* Paquetes */
.paquetes { padding: 64px 20px; max-width: 1200px; margin: 0 auto; }
.paquetes h2 { text-align: center; color: #004080; margin-bottom: 24px; }
.grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.card { border: 1px solid #e5e7eb; border-radius: 14px; overflow: hidden; box-shadow: 0 4px 16px rgba(0,0,0,.06); background: #fff; transition: transform .2s, box-shadow .2s, border-color .2s; display:flex; flex-direction:column;}
.card:hover, .card:focus-within { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(0,0,0,.12); border-color: #ff6f61; }
.card img { width: 100%; height: 200px; object-fit: cover; transform: }
.card-body{display:flex;flex-direction:column;gap:8px; padding: 12px 16px; flex:1}
.card-body h3 { margin: 0; color: #ff6f61; font-size: 1.15rem; text-align:center; min-height:2.6em; display:flex; align-items:center; justify-content:center; }
.card-body p { margin: 0; color: #4b5563; text-align:center; min-height:2.6em; display:flex; align-items:center; justify-content:center; }
.card .precio { font-weight: 700; color: #004080; }
.card .btn { margin-top:auto; display:block; width:100%; text-align:center; }

/* Galería */
.galeria{padding:48px 20px; max-width:1200px; margin:0 auto;}
.galeria h2{text-align:center;color:#004080;margin-bottom:16px}
.gallery-viewport{position: relative; overflow: hidden; border-radius: 16px}
.gallery-track{display:flex; transition:transform .5s ease; will-change: transform;}
.gallery-slide{min-width:100%; flex: 0 0 100%; }
.gallery-track img{width:100%;height:420px;object-fit: cover; object-position: center 80%;  transform: scale(1.0); display:block}
.gallery-controls{display:flex;gap:10px;justify-content:center;margin-top:10px}

/* Modal / Form */
dialog::backdrop { background: rgba(0,0,0,.4); }
dialog { border: none; border-radius: 16px; padding: 0; width: min(720px, 92vw); }
#bookingForm { padding: 0; } /* on package.html we use inline form grid */
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 14px; }
.form-field { display: flex; flex-direction: column; gap: 6px; }
.form-field input, .form-field select, .form-field textarea {
  border: 1px solid #d1d5db; border-radius: 10px; padding: 10px 12px; font-size: 1rem;
}
.form-field input[readonly] { background: #f3f4f6; }
.form-field.full { grid-column: 1 / -1; }
.checkbox { display: flex; align-items: flex-start; gap: 10px; }
.form-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 12px; }
.btn.primary { background: #004080; }

/* Pago */
.pago { text-align: center; margin: 60px auto; padding: 0 20px; max-width: 900px; }
.pago h2 { color: #004080; margin-bottom: 12px; }
.pago p { color: #4b5563; }

/* Footer */
.footer { background: #004080; color: white; text-align: center; padding: 20px; }
.footer a { color: #ffdd57; }

/* Floating contact */
.floating-menu { position: fixed; bottom: 20px; right: 20px; display: flex; flex-direction: column; align-items: center; z-index: 1000; }
.whatsapp-btn { background: #25D366; color: white; width: 60px; height: 60px; border-radius: 50%; display: grid; place-content: center; font-size: 28px; cursor: pointer; box-shadow: 0 4px 10px rgba(0,0,0,0.3); border: 0; }
.menu-icons { display: flex; flex-direction: column; align-items: center; margin-bottom: 10px; }
.menu-icons a { background: #fff; width: 50px; height: 50px; border-radius: 50%; display: grid; place-content: center; font-size: 22px; color: #333; box-shadow: 0 3px 8px rgba(0,0,0,0.2); margin-bottom: 10px; opacity: 0; transform: translateY(20px); pointer-events: none; transition: all 0.35s ease; }
.menu-icons.show a { opacity: 1; transform: translateY(0); pointer-events: auto; }
.menu-icons.show a:nth-child(1) { transition-delay: .1s; color: #25D366; }
.menu-icons.show a:nth-child(2) { transition-delay: .2s; color: #0084FF; }
.menu-icons.show a:nth-child(3) { transition-delay: .3s; color: #FFD43B; }

/* Responsive */
@media (max-width: 1024px) {
  .grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .menu-toggle { display: inline-block; }
  #menu { position: absolute; top: 72px; right: 16px; background: #004080; padding: 12px; border-radius: 12px; display: none; flex-direction: column; min-width: 220px; }
  #menu a { padding: 10px 12px; }
  #menu.active { display: flex; }
  .grid { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .logo img { width: 56px; height: 56px; }
  .gallery-track img{height:300px;}
}


/* Fallbacks/robustness */
.slides:first-child { display:block; } /* por si el JS no carga, se ve la primera diapositiva */
.pkg-hero .overlay{z-index:2}


/* === Info de la galería seleccionada === */
.gallery-info{max-width:900px;margin:12px auto 0;padding:10px 14px;border:1px solid #e5e7eb;border-radius:12px;background:#fafafa}
.gallery-info h3{margin:0 0 4px;font-size:1.1rem;color:#0f172a}
.gallery-info p{margin:0;color:#334155}

/* === Mini carrusel (lugares visitados) === */
.mini-title{margin:16px 0 10px; text-align:center; color:#004080; font-size:1.15rem}
.mini-carousel{display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:10px; margin-top:12px}
.mini-viewport{overflow:hidden; border-radius:12px}
.mini-track{display:flex; gap:8px; transition:transform .45s ease}
.mini-slide{flex:0 0 var(--miniW,160px)}
.mini-slide img{width:100%; height:110px; object-fit: cover; object-position: center 60%; border-radius:10px; display:block; cursor:pointer;}
.mini-btn{background:#f3f4f6; border:1px solid #e5e7eb; border-radius:10px; padding:8px 10px; cursor:pointer; font-size:18px}
.mini-btn:hover{background:#e9eaec}
@media (max-width: 1024px){
  .mini-slide{flex-basis:var(--miniW,140px)}
  .mini-slide img{height:100px}
}
@media (max-width: 768px){
  .mini-slide{flex-basis:var(--miniW,120px)}
  .mini-slide img{height:90px}
}

/* Evitar scroll de fondo cuando el menú está abierto en móvil */
body.no-scroll { overflow: hidden; }

/* Refuerzo menú móvil */
@media (max-width: 768px) {
  #menu { display: none; }
  #menu.active { display: flex; }
}


/* === Grid & card small variants (Más destinos) === */
.grid.grid-sm { grid-template-columns: repeat(6, 1fr); gap: 16px; }
.card-sm img { height: 150px; }
.card-sm .card-body h3 { font-size: 1rem; }
.card-sm .card-body p { font-size: .95rem; min-height: 2.2em; }
.card-sm .precio { font-size: .95rem; }
.card-sm .btn { padding: 10px 12px; font-size: .95rem; }

@media (max-width: 1280px) {
  .grid.grid-sm { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 1024px) {
  .grid.grid-sm { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .grid.grid-sm { grid-template-columns: repeat(2, 1fr); }
  .card-sm img { height: 130px; }
}
.cta-more { display: flex; justify-content: center; margin-top: 16px; }
.paquetes-extra { padding-top: 24px; padding-bottom: 64px; }

/* Footer social icons */
.footer .social{margin-top:10px; display:flex; gap:12px; justify-content:center; align-items:center}
.footer .social a{width:36px; height:36px; display:grid; place-content:center; border-radius:50%; background:#ffffff22; color:#fff; text-decoration:none; transition:transform .2s ease, background .2s ease}
.footer .social a:hover{transform:translateY(-2px); background:#ffffff33}
.footer .social i{font-size:18px; line-height:1}

/* Lock navbar height and menu font-size */
.navbar{height:84px}
#menu a{font-size:1rem; line-height:1}

/* Lock logo size */
.logo img{
  height: 60px;
  width: auto;
}
@media (max-width:768px){
  .logo img{
    height:56px;
    width:auto;
  }
}

/* === Quetzalito animado === */
#quetzalito{
  position: fixed;
  bottom: 18%;
  left: -220px;
  width: 50px;
  height: 50px;
  z-index: 900;
  pointer-events: auto;
  animation: quetzal-fly 14s linear infinite;
}
#quetzalito img{ width: 100%; height: auto; display:block; }

@keyframes quetzal-fly{
  0%   { transform: translateX(0) translateY(0) rotate(0deg); opacity: 0; }
  5%   { opacity: 1; }
  50%  { transform: translateX(calc(100vw + 260px)) translateY(-30px) rotate(1.5deg); opacity: 1; }
  95%  { opacity: 1; }
  100% { transform: translateX(calc(100vw + 260px)) translateY(0) rotate(0deg); opacity: 0; }
}

/* aleteo sutil */
#quetzalito { filter: drop-shadow(0 4px 12px rgba(0,0,0,.25)); }
#quetzalito img { animation: quetzal-flap 0.9s ease-in-out infinite; transform-origin: 60% 50%; }
@keyframes quetzal-flap{
  0%,100% { transform: rotate(0deg) scale(1); }
  50% { transform: rotate(-3deg) scale(1.02); }
}

/* Respeta preferencias de reducción de movimiento */
@media (prefers-reduced-motion: reduce){
  #quetzalito{ animation: none; left: 12px; bottom: 12px; }
  #quetzalito img{ animation: none; }
}
