/* =========================================================
   main-final.css — Sitio IE26
   Mobile-first, ordenado y listo para publicación
   ========================================================= */

/* -----------------------------
   01. Fuentes locales
----------------------------- */
@font-face{
  font-family:'Poppins';
  src:url('../fonts/poppins/Poppins-Regular.woff2') format('woff2');
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'Poppins';
  src:url('../fonts/poppins/Poppins-SemiBold.woff2') format('woff2');
  font-weight:600;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'Poppins';
  src:url('../fonts/poppins/Poppins-Bold.woff2') format('woff2');
  font-weight:700;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'Poppins';
  src:url('../fonts/poppins/Poppins-ExtraBold.woff2') format('woff2');
  font-weight:800;
  font-style:normal;
  font-display:swap;
}

/* -----------------------------
   02. Tokens
----------------------------- */
:root{
  --bg:#f5f7fa;
  --bg-soft:#fafbfc;
  --bg-alt:#eef2f5;

  --surface:#ffffff;
  --surface-soft:rgba(255,255,255,.92);
  --surface-glass:rgba(255,255,255,.10);

  --text:#132238;
  --text-soft:#556577;
  --text-muted:#6c7b8b;

  --primary:#0d3b66;
  --primary-2:#174f82;
  --primary-3:#082742;

  --accent:#8ea4b8;
  --accent-soft:#dde5ec;
  --accent-deep:#5f7387;
  --success:#25d366;
  --accent-aqua:#5b8f95;
  --accent-aqua-soft:#e8f2f3;

  --line:rgba(19,34,56,.10);
  --line-strong:rgba(19,34,56,.16);

  --shadow-xs:0 4px 12px rgba(16,24,40,.04);
  --shadow-sm:0 8px 20px rgba(16,24,40,.055);
  --shadow-md:0 12px 30px rgba(16,24,40,.075);
  --shadow-lg:0 18px 44px rgba(16,24,40,.10);

  --radius-xs:10px;
  --radius-sm:14px;
  --radius-md:20px;
  --radius-lg:28px;
  --radius-xl:34px;

  --container:1680px;
  --container-pad:24px;
  --header-h:72px;
}

/* -----------------------------
   03. Reset / base mobile
----------------------------- */
*,
*::before,
*::after{box-sizing:border-box}

html{
  scroll-behavior:smooth;
  text-size-adjust:100%;
}

body{
  margin:0;
  font-family:'Poppins',system-ui,-apple-system,Arial,sans-serif;
  background:linear-gradient(180deg,#fafbfc 0%,#f1f4f6 100%);
  color:var(--text);
  line-height:1.72;
  font-size:17px;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

body:has(#menu-toggle:checked),
body:has(#search-toggle:checked){overflow:hidden}

a{
  color:inherit;
  text-decoration:none;
}

img,
svg,
video,
iframe{
  display:block;
  max-width:100%;
}

button,
input,
textarea,
select{font:inherit}

.container,
.header-container{
  width:min(calc(100% - var(--container-pad)),var(--container));
  margin-inline:auto;
}

#menu-toggle,
#search-toggle{
  position:absolute;
  left:-9999px;
  opacity:0;
  pointer-events:none;
}

/* -----------------------------
   04. Tipografía / secciones
----------------------------- */
.section{
  position:relative;
  padding:60px 0;
}

.section > .container{
  position:relative;
  z-index:1;
}

.section--soft{
  background:linear-gradient(180deg,rgba(238,242,245,.55),rgba(247,248,250,.72));
}

.section-title{
  max-width:100%;
  margin:0 auto 16px;
  color:var(--text);
  text-align:center;
  font-size:clamp(2rem,8vw,2.5rem);
  font-weight:800;
  letter-spacing:-.025em;
  line-height:1.03;
  text-wrap:balance;
}

.section-subtitle{
  max-width:34ch;
  margin:0 auto 42px;
  color:var(--text-soft);
  text-align:center;
  font-size:1rem;
  line-height:1.68;
  text-wrap:pretty;
}

.narrow-content{max-width:920px}

/* -----------------------------
   05. Header mobile-first
----------------------------- */
header{
  position:sticky;
  top:0;
  z-index:999;
  color:#fff;
  background:rgba(10,25,45,.62);
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 12px 30px rgba(0,0,0,.10);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
}

header nav{
  min-height:var(--header-h);
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:10px;
  padding:0;
}

.brand-group{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}

.logo{
  display:flex;
  flex-direction:column;
  min-width:0;
  color:#fff;
  font-size:1.04rem;
  font-weight:800;
  letter-spacing:-.035em;
  line-height:.95;
}

.logo small{
  align-self:flex-end;
  margin-top:3px;
  font-size:.48rem;
  font-weight:500;
  letter-spacing:.08em;
  opacity:.72;
}

.anniversary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  padding:6px 9px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
  background:rgba(255,255,255,.075);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10);
  color:#fff;
  font-size:.7rem;
  font-weight:600;
  white-space:nowrap;
}

.nav-links{display:none}

.header-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
}

.search-btn,
.menu-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  cursor:pointer;
  color:#fff;
}

.search-btn{
  width:38px;
  height:38px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
  transition:background .22s ease,transform .22s ease;
}

.search-btn:hover{background:rgba(255,255,255,.14);transform:translateY(-1px)}

.cta-top{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:42px;
  padding:0 12px;
  border-radius:999px;
  color:#fff;
  background:linear-gradient(180deg,#29d96f,#1fbe5d);
  box-shadow:0 12px 24px rgba(37,211,102,.20);
  font-size:.82rem;
  font-weight:800;
  letter-spacing:-.01em;
  white-space:nowrap;
  transition:transform .22s ease,box-shadow .22s ease;
  animation:ctaGlow 2.8s ease-in-out infinite;
}

.cta-top:hover{
  transform:translateY(-2px) scale(1.02);
  box-shadow:0 16px 28px rgba(37,211,102,.26);
}

.cta-top svg{flex:0 0 auto;transition:transform .25s ease}
.cta-top:hover svg{transform:translateX(2px)}

@keyframes ctaGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.35)}
  50%{box-shadow:0 0 0 10px rgba(37,211,102,0)}
}

@media (max-width:430px){
  header .cta-top span{display:none}
  header .cta-top{width:42px;padding:0}
}

/* Botón flotante mobile fuera o dentro del header */
body > .menu-btn,
.menu-btn{
  position:fixed !important;
  top:auto !important;
  left:auto !important;
  right:18px !important;
  bottom:calc(18px + env(safe-area-inset-bottom)) !important;
  z-index:99999 !important;
  width:58px !important;
  height:58px !important;
  min-width:58px !important;
  min-height:58px !important;
  border:1px solid rgba(255,255,255,.16) !important;
  background:linear-gradient(180deg,var(--primary-2),var(--primary)) !important;
  box-shadow:0 18px 38px rgba(0,0,0,.28),0 6px 14px rgba(0,0,0,.16) !important;
  font-size:1.25rem;
  transform:none !important;
}

body > .menu-btn:hover,
.menu-btn:hover{transform:translateY(-2px) !important}

#menu-toggle:checked ~ .menu-btn{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}

/* -----------------------------
   06. Search overlay
----------------------------- */
.search-backdrop{
  position:fixed;
  inset:0;
  z-index:1004;
  background:transparent;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}

#search-toggle:checked ~ .search-backdrop{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.search-bar{
  position:fixed;
  top:calc(var(--header-h) + 8px);
  left:50%;
  z-index:1005;
  width:min(92%,620px);
  max-height:calc(100vh - 110px);
  overflow-y:auto;
  padding:14px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.98);
  box-shadow:var(--shadow-lg);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateX(-50%) translateY(-10px);
  transition:.25s ease;
}

#search-toggle:checked ~ .search-bar{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}

.search-close{
  position:absolute;
  top:12px;
  right:12px;
  width:38px;
  height:38px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:#f3f6f9;
  color:#5b6670;
  cursor:pointer;
  font-size:1.5rem;
  line-height:1;
  transition:background .2s ease,transform .2s ease;
}

.search-close:hover{background:#e8eef3;transform:scale(1.05)}

.search-bar form{display:grid;gap:12px}

.search-bar input{
  width:100%;
  padding:13px 56px 13px 14px;
  border:1px solid #d7dde3;
  border-radius:12px;
  outline:none;
  background:#fff;
  font-size:.96rem;
  transition:border-color .2s ease,box-shadow .2s ease;
}

.search-bar input:focus{
  border-color:rgba(13,59,102,.35);
  box-shadow:0 0 0 4px rgba(13,59,102,.08);
}

.search-results{
  display:none;
  overflow:hidden;
  border:1px solid #e5ebf0;
  border-radius:14px;
  background:#f8fafc;
}
.search-results.active{display:block}

.search-result-link{
  display:block;
  padding:13px 15px;
  border-bottom:1px solid #e5ebf0;
}
.search-result-link:last-child{border-bottom:none}
.search-result-link strong{display:block;margin-bottom:4px;font-size:.95rem}
.search-result-link span{display:block;color:#5a6672;font-size:.86rem}
.search-empty{display:none;padding:12px 14px;color:#5a6672;font-size:.9rem}
.search-empty.active{display:block}

/* -----------------------------
   07. Drawer mobile
----------------------------- */
.drawer{
  position:fixed;
  inset:0;
  z-index:1002;
  width:100%;
  height:100vh;
  display:flex;
  flex-direction:column;
  gap:0;
  overflow-y:auto;
  overscroll-behavior:contain;
  padding:calc(env(safe-area-inset-top) + 26px) 24px calc(env(safe-area-inset-bottom) + 44px);
  color:#fff;
  background:linear-gradient(135deg,rgba(8,39,66,.985),rgba(13,59,102,.965));
  box-shadow:none;
  transform:translateX(100%);
  transition:transform .32s cubic-bezier(.22,.8,.2,1);
}

#menu-toggle:checked ~ .drawer{transform:translateX(0)}

.overlay{
  position:fixed;
  inset:0;
  z-index:1000;
  background:rgba(2,8,16,.54);
  opacity:0;
  visibility:hidden;
  transition:.25s ease;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}

#menu-toggle:checked ~ .overlay{
  opacity:1;
  visibility:visible;
}

.drawer-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:0;
  padding:0 0 34px;
  border:0;
  color:#fff;
}

.drawer-logo{
  display:flex;
  flex-direction:column;
  padding:0 !important;
  border:0 !important;
  color:#fff !important;
  font-size:1.2rem;
  font-weight:800;
  letter-spacing:-.035em;
  line-height:.95;
}

.drawer-logo small{
  margin-top:4px;
  font-size:.52rem;
  letter-spacing:.08em;
  opacity:.72;
}

.drawer-kicker{
  display:block;
  margin:0 0 12px;
  color:rgba(255,255,255,.72);
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.drawer-close{
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#fff;
  cursor:pointer;
  font-size:2.2rem;
  font-weight:300;
  line-height:1;
}
.drawer-close:hover{background:rgba(255,255,255,.14)}

.drawer a,
.drawer summary{
  color:#fff;
  border-radius:0;
  background:transparent !important;
}

.drawer-link,
.drawer-group summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:62px;
  padding:18px 0;
  border-bottom:1px solid rgba(255,255,255,.16);
  font-size:1.32rem;
  font-weight:700;
  letter-spacing:-.028em;
  line-height:1.05;
}

.drawer-group{
  border:0;
  border-radius:0;
  background:transparent;
  overflow:visible;
}

.drawer-group summary{
  cursor:pointer;
  list-style:none;
}
.drawer-group summary::-webkit-details-marker{display:none}

.drawer-group summary::after{
  content:'→';
  color:rgba(255,255,255,.86);
  font-size:1.45rem;
  font-weight:400;
  transition:transform .22s ease,opacity .22s ease;
}
.drawer-group summary:hover::after{transform:translateX(4px)}
.drawer-group[open] summary::after{content:'−';transform:none}

.drawer-submenu{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  padding:14px 0 22px;
  border-bottom:1px solid rgba(255,255,255,.16);
}

.drawer-submenu a{
  padding:10px 0;
  border:0;
  color:rgba(255,255,255,.78);
  font-size:.95rem;
  font-weight:600;
  line-height:1.35;
}
.drawer-submenu a:hover{color:#fff}

.drawer-submenu--grouped{grid-template-columns:1fr !important;gap:0 !important}

.drawer-submenu-title{
  display:block;
  margin:18px 0 6px;
  color:rgba(255,255,255,.58);
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.drawer-submenu-title:first-child{margin-top:4px}
.drawer .drawer-submenu-status{color:#79e7a5 !important}

.drawer .drawer-whatsapp,
.drawer .drawer-whatsapp:visited{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:9px !important;
  width:min(420px,100%) !important;
  min-height:56px !important;
  margin-top:28px !important;
  padding:0 22px !important;
  border:0 !important;
  border-radius:999px !important;
  background:#25d366 !important;
  color:#fff !important;
  box-shadow:none !important;
  font-size:1rem !important;
  font-weight:800 !important;
  margin-left:auto !important;
margin-right:auto !important;
}

.drawer .drawer-whatsapp:hover,
.drawer .drawer-whatsapp:focus-visible,
.drawer .drawer-whatsapp:active{
  background:#25d366 !important;
  color:#fff !important;
  opacity:.94;
  transform:translateY(-1px);
}

.drawer-whatsapp::before{
  content:'';
  width:20px;
  height:20px;
  flex:0 0 auto;
  background:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20.52 3.48A11.86 11.86 0 0 0 12.08 0C5.54 0 .22 5.32.22 11.86c0 2.09.55 4.14 1.6 5.94L.12 24l6.35-1.66a11.82 11.82 0 0 0 5.61 1.43h.01c6.54 0 11.86-5.32 11.86-11.86 0-3.17-1.23-6.15-3.43-8.43ZM12.09 21.76h-.01a9.85 9.85 0 0 1-5.03-1.38l-.36-.22-3.77.99 1.01-3.67-.24-.38a9.84 9.84 0 0 1-1.5-5.24c0-5.45 4.44-9.89 9.9-9.89a9.83 9.83 0 0 1 6.99 2.9 9.83 9.83 0 0 1 2.9 7c0 5.45-4.44 9.89-9.89 9.89Zm5.43-7.4c-.3-.15-1.76-.87-2.03-.97-.27-.1-.47-.15-.67.15-.2.3-.77.97-.95 1.17-.17.2-.35.22-.65.07-.3-.15-1.25-.46-2.39-1.47-.88-.79-1.48-1.76-1.65-2.06-.17-.3-.02-.46.13-.61.13-.13.3-.35.45-.52.15-.17.2-.3.3-.5.1-.2.05-.37-.02-.52-.07-.15-.67-1.61-.92-2.21-.24-.58-.49-.5-.67-.51h-.57c-.2 0-.52.07-.8.37-.27.3-1.05 1.02-1.05 2.49s1.07 2.89 1.22 3.09c.15.2 2.1 3.2 5.08 4.49.71.31 1.26.49 1.69.63.71.23 1.36.2 1.87.12.57-.09 1.76-.72 2.01-1.42.25-.7.25-1.3.17-1.42-.07-.13-.27-.2-.57-.35Z'/%3E%3C/svg%3E") center/contain no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20.52 3.48A11.86 11.86 0 0 0 12.08 0C5.54 0 .22 5.32.22 11.86c0 2.09.55 4.14 1.6 5.94L.12 24l6.35-1.66a11.82 11.82 0 0 0 5.61 1.43h.01c6.54 0 11.86-5.32 11.86-11.86 0-3.17-1.23-6.15-3.43-8.43ZM12.09 21.76h-.01a9.85 9.85 0 0 1-5.03-1.38l-.36-.22-3.77.99 1.01-3.67-.24-.38a9.84 9.84 0 0 1-1.5-5.24c0-5.45 4.44-9.89 9.9-9.89a9.83 9.83 0 0 1 6.99 2.9 9.83 9.83 0 0 1 2.9 7c0 5.45-4.44 9.89-9.89 9.89Zm5.43-7.4c-.3-.15-1.76-.87-2.03-.97-.27-.1-.47-.15-.67.15-.2.3-.77.97-.95 1.17-.17.2-.35.22-.65.07-.3-.15-1.25-.46-2.39-1.47-.88-.79-1.48-1.76-1.65-2.06-.17-.3-.02-.46.13-.61.13-.13.3-.35.45-.52.15-.17.2-.3.3-.5.1-.2.05-.37-.02-.52-.07-.15-.67-1.61-.92-2.21-.24-.58-.49-.5-.67-.51h-.57c-.2 0-.52.07-.8.37-.27.3-1.05 1.02-1.05 2.49s1.07 2.89 1.22 3.09c.15.2 2.1 3.2 5.08 4.49.71.31 1.26.49 1.69.63.71.23 1.36.2 1.87.12.57-.09 1.76-.72 2.01-1.42.25-.7.25-1.3.17-1.42-.07-.13-.27-.2-.57-.35Z'/%3E%3C/svg%3E") center/contain no-repeat;
}

.drawer-social{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
  justify-content:center;
}

.drawer .drawer-social a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:rgba(255,255,255,.075) !important;
  color:rgba(255,255,255,.92) !important;
  font-size:.9rem;
  font-weight:750;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  transition:background .22s ease,border-color .22s ease,transform .22s ease,color .22s ease;
}
.drawer .drawer-social a:hover{color:#fff !important;background:rgba(255,255,255,.14) !important;border-color:rgba(255,255,255,.24);transform:translateY(-1px)}

/* -----------------------------
   08. Hero
----------------------------- */
.hero{
  position:relative;
  min-height:clamp(420px,58vh,560px);
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  padding-top:var(--header-h);
  color:#fff;
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
}

.hero::before{
  content:'';
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(180deg,rgba(10,20,35,.65) 0%,rgba(10,20,35,.55) 20%,rgba(10,20,35,.35) 45%,rgba(10,20,35,.65) 75%,rgba(10,20,35,.88) 100%);
}

.hero::after{
  content:'';
  position:absolute;
  inset:auto 0 0;
  z-index:1;
  height:140px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.10));
}

.hero > .container{
  position:relative;
  z-index:2;
  width:100%;
}

.hero-inner{
  width:100%;
  max-width:100%;
  padding:56px 0 56px 14px;
}

.hero-breadcrumb,
.eyebrow{
  display:inline-block;
  margin:0 0 12px;
  padding:8px 12px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
  color:#fff;
  font-size:.7rem;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}

.hero-breadcrumb{width:max-content;margin-bottom:18px}
.hero-breadcrumb a{color:#fff;font-weight:600;opacity:.92}
.eyebrow{text-transform:uppercase;letter-spacing:.08em}
.eyebrow--light{color:var(--primary);background:#eef3f8;border-color:rgba(19,34,56,.08);box-shadow:none}

.hero h1{
  max-width:100%;
  margin:0 0 18px;
  font-size:2.1rem;
  font-weight:800;
  line-height:.94;
  letter-spacing:-.04em;
  text-shadow:0 14px 40px rgba(0,0,0,.35);
}

.hero p{
  max-width:100%;
  margin:0 0 20px;
  color:rgba(255,255,255,.92);
  font-size:1rem;
}

.hero .cta-btn{display:inline-flex;margin-top:10px}

.trust,
.hero-quick-info,
.meta-tags--hero{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}

.chip,
.hero-quick-info span,
.meta-tags--hero span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  background:rgba(255,255,255,.10);
  color:#fff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 8px 20px rgba(0,0,0,.18);
  font-size:.84rem;
  font-weight:600;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}

.meta-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:0 0 12px;
}

.meta-tags span{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 11px;
  border:1px solid rgba(19,34,56,.06);
  border-radius:999px;
  background:#eef3f8;
  color:#425566;
  font-size:.8rem;
  font-weight:700;
}

.scroll-indicator{
  position:absolute;
  left:50%;
  bottom:14px;
  z-index:2;
  width:40px;
  height:40px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:rgba(255,255,255,.10);
  color:#fff;
  font-size:1rem;
  transform:translateX(-50%);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

/* -----------------------------
   09. Grids y cards
----------------------------- */
.grid{display:grid;gap:24px}
.two,.three,.quick-grid,.pillar-grid{grid-template-columns:1fr}
.quick-grid{gap:24px}

.card,
.review-card{
  background:#fff;
  border:1px solid rgba(19,34,56,.07);
  border-radius:24px;
  box-shadow:var(--shadow-sm);
}

.card{
  overflow:hidden;
  margin-top:14px;
  transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease;
}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:rgba(91,143,149,.20)}
.card-link{display:block;overflow:hidden}

.card > img{
  width:100%;
  height:280px;
  object-fit:cover;
  transition:transform .7s ease;
}
.card:hover > img{transform:scale(1.045)}

.card-content,
.rich-card .card-body{
  padding:18px 18px 20px;
  text-align:center;
}

.card h3{
  margin:0 0 10px;
  color:var(--text);
  font-size:1.26rem;
  line-height:1.08;
  letter-spacing:-.025em;
  text-wrap:balance;
}

.card p{
  margin:0 0 18px;
  color:var(--text-soft);
  font-size:1rem;
  line-height:1.68;
  text-wrap:pretty;
}

.card-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0 0 14px;
  padding:8px 12px;
  border:1px solid rgba(91,143,149,.14);
  border-radius:999px;
  background:var(--accent-aqua-soft);
  box-shadow:none;
  color:#49686d;
  font-size:.78rem;
  font-weight:700;
}

.card-note{margin-top:10px;color:var(--text-soft);font-size:.92rem}
.rich-card{padding:0;overflow:hidden}
.rich-card img{width:100%;height:220px;object-fit:cover;transition:transform .7s ease}
.rich-card:hover img{transform:scale(1.05)}
.click-card{display:block;transition:transform .22s ease,box-shadow .22s ease}
.click-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}

.card .card-content[style*='text-align:left'],
.rich-card .card-body,
.quick-grid .card .card-content{text-align:left !important}

.card-image{
  width:100%;
  height:200px;
  overflow:hidden;
  border-radius:18px 18px 0 0;
}
.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.card-link:hover .card-image img{transform:scale(1.05)}

.step{
  width:34px;
  height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:10px;
  border-radius:50%;
  background:#eef3f8;
  color:var(--primary);
  font-size:.9rem;
  font-weight:600;
}

/* Tours */
.tours-grid{align-items:stretch}
.tour-card{display:flex;flex-direction:column;height:100%}
.tour-card > img{height:220px}
.tour-card__body{display:flex;flex:1;flex-direction:column;gap:14px;padding:18px;text-align:left}
.tour-card__topline{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.tour-card__topline .card-badge{margin:0}
.tour-card__category{padding:7px 10px;border:1px solid rgba(19,34,56,.08);border-radius:999px;background:#eef3f8;color:var(--accent-deep);font-size:.76rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.tour-card h3,.tour-card p{margin:0}
.tour-card__meta{display:grid;grid-template-columns:1fr;gap:8px;margin-top:2px}
.tour-card__meta span{display:flex;align-items:center;gap:8px;min-height:38px;padding:8px 11px;border:1px solid rgba(19,34,56,.07);border-radius:14px;background:#f4f7fa;color:#435466;font-size:.88rem;font-weight:650}
.tour-card__tags,.filter-pills{display:flex;flex-wrap:wrap;gap:8px}
.tour-card__tags span,.filter-pills span{display:inline-flex;align-items:center;min-height:32px;padding:6px 10px;border:1px solid rgba(13,59,102,.08);border-radius:999px;background:rgba(13,59,102,.07);color:var(--primary);font-size:.78rem;font-weight:700}
.filter-pills{justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;margin:-18px auto 28px;padding-bottom:8px}
.filter-pills span{flex:0 0 auto}
.tour-card__actions{display:flex;flex-direction:column;align-items:stretch;gap:12px;margin-top:auto;padding-top:4px}
.tour-card__actions .btn-card,.tour-card__link{width:100%;justify-content:center;text-align:center}
.tour-card__link{display:inline-flex;align-items:center;min-height:42px;border-bottom:2px solid rgba(13,59,102,.18);color:var(--primary);font-size:.9rem;font-weight:800;transition:color .22s ease,border-color .22s ease,transform .22s ease}
.tour-card__link:hover{color:var(--primary-2);border-color:rgba(13,59,102,.42);transform:translateY(-1px)}

/* -----------------------------
   10. Botones / callouts
----------------------------- */
.card-btn,
.section-cta a,
.cta-btn,
.btn-card{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:48px;
  padding:0 18px;
  border:1px solid transparent;
  border-radius:999px;
  background:#1565a7;
  box-shadow:0 8px 18px rgba(9,45,106,.14);
  color:#fff;
  font-size:.94rem;
  font-weight:700;
  transition:transform .22s ease,box-shadow .22s ease,background .22s ease;
}
.card-btn:hover,.section-cta a:hover,.cta-btn:hover,.btn-card:hover{background:#1a74bd;transform:translateY(-1px);box-shadow:0 10px 22px rgba(9,45,106,.18)}
.section-cta{margin-top:28px;text-align:center}

.highlight{
  max-width:920px;
  margin:auto;
  padding:26px 22px;
  border:1px solid rgba(19,34,56,.08);
  border-radius:24px;
  background:#fff;
  box-shadow:var(--shadow-sm);
  text-align:left;
}
.highlight p{margin:0 0 14px;color:var(--text-soft)}

.info-list{
  max-width:760px;
  margin:18px auto 0;
  padding-left:0;
  list-style:none;
  color:var(--text-soft);
}
.info-list li{position:relative;margin:12px 0;padding-left:26px;line-height:1.72}
.info-list li::before{content:'';position:absolute;left:2px;top:.82em;width:6px;height:6px;border-radius:999px;background:var(--accent-aqua);box-shadow:none;transform:translateY(-50%)}

.note{max-width:880px;margin:18px auto 0;color:var(--text-soft);font-size:.9rem;text-align:center}
.note strong{color:var(--text)}

.cta-box{
  max-width:960px;
  margin:auto;
  padding:34px 22px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  background:#092d6a;
  box-shadow:0 14px 32px rgba(9,45,106,.18);
  color:#fff;
  text-align:center;
}
.cta-box h2{margin:0 0 12px;font-size:clamp(1.7rem,2.8vw,2.3rem);line-height:1.08;letter-spacing:-.03em}
.cta-box p{max-width:58ch;margin:0 auto 18px;color:rgba(255,255,255,.90)}
.legal-note{margin-top:16px !important;margin-bottom:0 !important;font-size:.88rem;opacity:.82}

.split-highlight{display:grid;grid-template-columns:1fr;gap:28px;align-items:center}
.split-highlight h2{margin:0 0 12px;font-size:clamp(1.8rem,3vw,2.55rem);line-height:1.08;letter-spacing:-.04em}

/* -----------------------------
   11. Tablas / FAQ / reviews
----------------------------- */
.table-wrap{
  overflow:auto;
  padding:14px;
  border:1px solid rgba(19,34,56,.08);
  border-radius:24px;
  background:#fff;
  box-shadow:var(--shadow-sm);
  -webkit-overflow-scrolling:touch;
}
.table{width:100%;min-width:620px;border-collapse:collapse;background:#fff}
.table tr:not(:last-child){border-bottom:1px solid #e8edf2}
.table td{padding:16px 12px;vertical-align:top}
.table td:first-child{width:auto;color:var(--text);font-weight:700}

.faq{max-width:980px;margin:auto}
.faq details{margin-bottom:14px;padding:16px;border:1px solid rgba(19,34,56,.08);border-radius:16px;background:#fff;box-shadow:var(--shadow-sm);transition:border-color .25s ease,box-shadow .25s ease,transform .25s ease,background .25s ease}
.faq details[open]{background:#fff;box-shadow:0 10px 24px rgba(16,24,40,.06)}
.faq summary{position:relative;padding-right:30px;color:var(--text);cursor:pointer;font-size:.98rem;font-weight:700;line-height:1.5;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';position:absolute;right:0;top:50%;width:22px;height:22px;display:grid;place-items:center;border:1px solid rgba(19,34,56,.08);border-radius:999px;background:#eef3f8;color:var(--primary);font-size:.92rem;font-weight:700;transform:translateY(-50%)}
.faq details[open] summary::after{content:'−'}
.faq p{margin:14px 0 0;color:#4f6070;font-size:.96rem}
.faq .info-list{max-width:100%;margin-top:14px;padding-left:0}
.faq .info-list li{margin:10px 0;color:var(--text-soft);font-size:.95rem}
.faq details > *:last-child{margin-bottom:0}

.review-card{position:relative;padding:20px}
.review-card::before{content:'“';position:absolute;top:10px;right:16px;color:rgba(13,59,102,.06);font-size:4rem;font-weight:800;line-height:1}
.review-stars{margin-bottom:10px;font-size:1rem;letter-spacing:.08em}
.review-name{margin-bottom:10px;color:var(--text);font-weight:700}
.review-text{color:var(--text-soft);line-height:1.72}

/* -----------------------------
   12. Media / galería / mapa
----------------------------- */
.map-intro{margin-top:16px;color:var(--text-soft);text-align:center}
.map-wrapper,.map-embed{overflow:hidden;margin-top:20px;border:1px solid rgba(19,34,56,.08);border-radius:24px;background:#fff;box-shadow:var(--shadow-md)}
.map-wrapper iframe,.map-embed iframe{width:100%;height:320px;border:0}

.gallery{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:26px}
.gallery img{width:100%;height:150px;object-fit:cover;border:1px solid rgba(19,34,56,.06);border-radius:12px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .35s ease,box-shadow .35s ease}
.gallery img:hover{transform:scale(1.028);box-shadow:var(--shadow-lg)}
.section-title + .gallery,.section-subtitle + .gallery{margin-top:24px}

.lightbox{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(0,0,0,.92)}
.lightbox.active{display:flex}
.lightbox-img{max-width:100%;max-height:90vh;border-radius:16px;box-shadow:var(--shadow-lg)}
.lightbox-close{position:absolute;top:20px;right:30px;color:#fff;cursor:pointer;font-size:42px}

/* -----------------------------
   13. Footer
----------------------------- */
.site-footer{
  margin-top:80px;
  padding:50px 20px 24px;
  background:#092d6a;
  color:#fff;
}
.footer-content{max-width:800px;margin:0 auto;text-align:center}
.site-footer h3{margin:0 0 18px;font-size:24px;font-weight:700}
.site-footer p{margin:0 0 24px;color:#cbd5e1;font-size:15px;line-height:1.7}
.footer-social{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:28px}
.footer-social a{padding:10px 18px;border-radius:999px;background:rgba(255,255,255,.08);color:#fff;font-size:15px;transition:all .2s ease}
.footer-social a:hover{background:rgba(255,255,255,.16);transform:translateY(-2px)}
.footer-whatsapp{display:inline-block;width:100%;max-width:320px;margin-bottom:36px;padding:14px 28px;border-radius:999px;background:#22c55e;color:#fff;font-weight:600;transition:all .2s ease}
.footer-whatsapp:hover{opacity:.92;transform:translateY(-2px)}
.footer-bottom{padding-top:22px;border-top:1px solid rgba(255,255,255,.1);color:#94a3b8;text-align:center;font-size:14px}
.footer-bottom span{margin:0 10px;opacity:.4}

/* -----------------------------
   14. Accesibilidad / motion
----------------------------- */
.search-btn:focus-visible,
.cta-top:focus-visible,
.menu-btn:focus-visible,
.drawer a:focus-visible,
.drawer summary:focus-visible,
.drawer-close:focus-visible,
.search-close:focus-visible,
.card:focus-visible,
.section-cta a:focus-visible,
.cta-btn:focus-visible,
.btn-card:focus-visible,
.card-btn:focus-visible,
a:focus-visible{
  outline:2px solid #fff;
  outline-offset:3px;
}

.card-btn:focus-visible,
.section-cta a:focus-visible,
.cta-btn:focus-visible,
.btn-card:focus-visible,
.tour-card__link:focus-visible,
.faq summary:focus-visible{
  outline-color:var(--primary);
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    scroll-behavior:auto !important;
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
}

/* =========================================================
   15. Breakpoints mobile-first
   ========================================================= */

@media (min-width:481px){
  .container,.header-container{width:calc(100% - 40px)}
  .hero h1{font-size:2.45rem}
  .gallery img{height:180px}
}

@media (min-width:641px){
  :root{--header-h:72px}
  .brand-group{gap:10px}
  .logo{font-size:1.12rem}
  .logo small{font-size:.52rem}
  .anniversary{font-size:.74rem;padding:6px 10px}
  .cta-top{font-size:.9rem;padding:0 13px}
  .drawer-submenu{grid-template-columns:repeat(2,minmax(0,1fr));gap:0 22px}
}

@media (min-width:769px){
  body{font-size:18px}
  .section{padding:72px 0}
  .section-title{font-size:clamp(2.15rem,4vw,3.25rem);letter-spacing:-.028em;max-width:18ch}
  .section-subtitle{max-width:60ch;font-size:1.06rem}
  .hero{min-height:clamp(460px,62vh,620px)}
  .hero-inner{padding:56px 0 56px 8px}
  .hero h1{font-size:clamp(3rem,5.8vw,5.4rem);max-width:13ch}
  .hero p{font-size:1.08rem;max-width:66ch}
  .two,.quick-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .three{grid-template-columns:repeat(2,minmax(0,1fr))}
  .card > img{height:320px}
  .rich-card img{height:240px}
  .card-image{height:210px}
  .card-content,.rich-card .card-body{padding:22px 22px 24px}
  .card h3{font-size:1.38rem}
  .tour-card > img{height:240px}
  .tour-card__body{padding:22px 22px 24px}
  .tour-card__actions{flex-direction:row;align-items:center;flex-wrap:wrap}
  .tour-card__actions .btn-card,.tour-card__link{width:auto}
  .filter-pills{justify-content:center;flex-wrap:wrap;overflow:visible;margin:-18px auto 34px;padding-bottom:0}
  .highlight{padding:34px 30px;border-radius:28px}
  .cta-box{padding:42px 28px;border-radius:30px}
  .table-wrap{padding:18px}
  .table td:first-child{width:56%}
  .faq details{padding:18px 20px;border-radius:18px}
  .faq summary{font-size:1rem;padding-right:32px}
  .faq summary::after{width:24px;height:24px;font-size:1rem}
  .review-card{padding:24px}
  .gallery{grid-template-columns:repeat(2,1fr);gap:14px}
  .gallery img{height:230px;border-radius:16px}
  .map-wrapper iframe,.map-embed iframe{height:420px}
  .site-footer{padding:60px 20px 30px}
  .site-footer h3{font-size:28px}
  .site-footer p{font-size:16px}
  .footer-whatsapp{width:auto;max-width:none}
}

@media (min-width:901px){
  .section{padding:84px 0}
  .three{grid-template-columns:repeat(3,minmax(0,1fr))}
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .split-highlight{grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr)}
}

@media (min-width:1101px){
  .pillar-grid{grid-template-columns:repeat(5,minmax(0,1fr))}
}

@media (min-width:1281px){
  :root{--header-h:92px}

  body > .menu-btn,
  .menu-btn{display:none !important}

  header nav{
    min-height:92px;
    display:grid;
    grid-template-columns:minmax(210px,.9fr) auto minmax(210px,.9fr);
    gap:22px;
  }

  header .brand-group{gap:14px}
  header .logo{font-size:1.34rem}
  header .logo small{font-size:.58rem}
  header .anniversary{font-size:.74rem;padding:7px 10px}

  .nav-links{
    display:flex !important;
    align-items:center;
    justify-self:center;
    gap:2px;
    min-width:0;
  }

  .nav-item{
    position:static !important;
    min-height:92px;
    display:flex;
    align-items:center;
  }

  .nav-item > a{
    position:relative;
    display:flex;
    align-items:center;
    min-height:48px;
    padding:0 16px;
    border:1px solid transparent;
    border-radius:999px;
    color:#fff;
    font-size:1rem;
    font-weight:700;
    letter-spacing:-.01em;
    opacity:.94;
    white-space:nowrap;
    transition:background .22s ease,opacity .22s ease,border-color .22s ease;
  }

  .nav-item > a::after{
    content:'';
    position:absolute;
    left:18px;
    right:18px;
    bottom:8px;
    height:1px;
    background:rgba(255,255,255,.42);
    transform:scaleX(0);
    transform-origin:center;
    transition:transform .22s ease;
  }

  .nav-item:hover > a{background:rgba(255,255,255,.075);border-color:rgba(255,255,255,.08);opacity:1}
  .nav-item:hover > a::after{transform:scaleX(1)}

  .header-actions{justify-self:end;gap:8px}
  header .search-btn{width:42px;height:42px}
  header .cta-top{min-height:44px;padding:0 15px;font-size:1rem}

  header{overflow:visible}
  header nav{position:relative}

  .dropdown{
    position:absolute !important;
    left:50% !important;
    right:auto !important;
    top:100% !important;
    z-index:20;
    width:100vw !important;
    min-width:100vw !important;
    max-height:min(74vh,660px);
    display:grid;
    grid-template-columns:repeat(4,minmax(180px,1fr));
    gap:10px 14px;
    overflow:auto;
    padding:30px max(32px,calc((100vw - 1280px) / 2)) !important;
    border:0 !important;
    border-top:1px solid rgba(19,34,56,.08) !important;
    border-radius:0 !important;
    background:#fff !important;
    box-shadow:0 28px 70px rgba(6,18,33,.18) !important;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateX(-50%) translateY(10px) !important;
    transition:opacity .22s ease,transform .22s ease,visibility 0s linear .32s;
  }

  .nav-item:hover .dropdown,
  .nav-item:focus-within .dropdown,
  .dropdown:hover{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateX(-50%) translateY(0) !important;
    transition-delay:0s;
  }

  .dropdown::before,
  .dropdown--right::before{display:none !important}

  .dropdown--wide,
  .dropdown--right{
    left:50% !important;
    right:auto !important;
    width:100vw !important;
    min-width:100vw !important;
    transform:translateX(-50%) translateY(10px) !important;
  }

  .nav-item:hover .dropdown--wide,
  .nav-item:focus-within .dropdown--wide,
  .nav-item:hover .dropdown--right,
  .nav-item:focus-within .dropdown--right{transform:translateX(-50%) translateY(0) !important}

  .dropdown a{
    position:relative;
    display:flex;
    align-items:center;
    min-height:44px;
    padding:10px 12px 10px 14px;
    border:1px solid transparent;
    border-radius:14px;
    background:transparent;
    color:var(--text);
    font-size:.92rem;
    font-weight:700;
    letter-spacing:-.015em;
    line-height:1.25;
  }

  .dropdown a:hover{background:linear-gradient(180deg,#f7fafc,#eef4f8);border-color:rgba(13,59,102,.08)}
  .dropdown a:first-child{grid-column:1 / -1;min-height:50px;background:linear-gradient(180deg,rgba(13,59,102,.09),rgba(13,59,102,.045));color:var(--primary);border-color:rgba(13,59,102,.08)}

  .dropdown--parks{
    grid-template-columns:minmax(280px,360px) minmax(260px,1fr) minmax(260px,1fr) !important;
    align-items:start;
    justify-content:center;
    gap:20px;
    max-width:none;
  }

  .dropdown-section{display:grid;align-content:start;gap:8px}
  .dropdown-section-title{display:block;margin:0 0 8px;padding:0 2px;color:var(--accent-deep);font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
  .dropdown-section a{width:100%}
  .dropdown--parks a:first-child{grid-column:auto;min-height:44px;background:transparent;color:var(--text);border-color:transparent}
  .dropdown-featured-link{min-height:56px !important;padding:13px 16px !important;border:1px solid rgba(13,59,102,.09) !important;border-radius:18px !important;background:linear-gradient(180deg,rgba(13,59,102,.09),rgba(13,59,102,.045)) !important;color:var(--primary) !important;font-size:.96rem !important;line-height:1.25 !important}
  .dropdown-featured-link:hover{background:linear-gradient(180deg,rgba(13,59,102,.13),rgba(13,59,102,.065)) !important;border-color:rgba(13,59,102,.14) !important}
  .dropdown-featured-link--status{background:linear-gradient(180deg,rgba(37,211,102,.14),rgba(37,211,102,.07)) !important;border-color:rgba(37,211,102,.18) !important;color:#11743d !important}

  .hero{min-height:clamp(520px,68vh,760px);padding-top:84px}
  .hero-inner{max-width:1100px;padding:72px 0 72px 24px}
  .quick-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .gallery{grid-template-columns:repeat(4,1fr)}
}

@media (min-width:1441px){
  header nav{grid-template-columns:minmax(210px,.9fr) auto minmax(210px,.9fr);gap:22px}
}


/* ============================
   FINAL PATCH — desktop dropdown hover stability
   Evita que el mega menú se cierre al bajar desde el botón.
============================ */
@media (min-width:1281px){
  .nav-links{
    align-self:stretch;
    height:92px;
  }

  .nav-item{
    min-height:92px;
    display:flex;
    align-items:center;
  }

  .nav-item::after{
  content:"";
  position:absolute;
  left:50%;
  top:100%;
  width:70%;
  height:10px;
  transform:translateX(-50%);
  pointer-events:auto;
}

  .dropdown{
    top:100% !important;
    transform:translateX(-50%) translateY(0) !important;
    transition:
      opacity .18s ease,
      transform .18s ease,
      visibility 0s linear .34s !important;
  }

  .nav-item:hover .dropdown,
  .nav-item:focus-within .dropdown,
  .dropdown:hover{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateX(-50%) translateY(0) !important;
    transition-delay:0s !important;
  }
}

/* ============================
   ESTÉTICA FINAL MINIMAL AQUA
   Sin tocar menú desktop ni footer
============================ */

.section-title strong,
.hero h1 strong,
.split-highlight h2 strong,
.cta-box h2 strong{
  color:var(--accent-aqua);
}

.card h3,
.split-highlight h2,
.cta-box h2{
  letter-spacing:-.022em;
}

.card p,
.section-subtitle,
.hero p,
.note,
.review-text{
  line-height:1.64;
}

.card-badge,
.meta-tags span,
.tour-card__tags span,
.filter-pills span,
.tour-card__category,
.tour-card__meta span{
  box-shadow:none;
}

.meta-tags span,
.tour-card__category,
.tour-card__meta span,
.tour-card__tags span,
.filter-pills span{
  background:#f3f7f8;
  border-color:rgba(91,143,149,.12);
}

.tour-card__category,
.tour-card__tags span,
.filter-pills span{
  color:#49686d;
}

.card > img,
.rich-card img,
.card-image img{
  filter:saturate(.96);
}

.card:hover > img{
  transform:scale(1.025);
}

.review-card::before{
  color:rgba(91,143,149,.08);
}

.faq summary::after{
  background:var(--accent-aqua-soft);
  color:var(--accent-aqua);
}

.map-wrapper,
.map-embed{
  box-shadow:var(--shadow-sm);
}

@media (max-width:1280px){
  body > .menu-btn,
  .menu-btn{
    box-shadow:0 12px 28px rgba(0,0,0,.22),0 4px 10px rgba(0,0,0,.12) !important;
  }
}


/* ============================
   FIX DEFINITIVO LOGO HEADER MOBILE/TABLET
   Mantiene IGUAZÚ EXCURSIONES + by WondersFalls® como en referencia
============================ */
@media (max-width:1280px){
  header nav{
    grid-template-columns:minmax(0,1fr) auto;
  }

  .brand-group{
    display:flex;
    align-items:center;
    gap:16px;
    min-width:0;
  }

  .logo{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
    min-width:max-content;
    color:#fff;
    font-size:1.02rem;
    font-weight:800;
    line-height:.9;
    letter-spacing:-.035em;
    white-space:nowrap;
  }

  .logo small{
    display:block;
    align-self:flex-end;
    margin-top:5px;
    font-size:.46rem;
    font-weight:500;
    line-height:1;
    letter-spacing:.11em;
    opacity:.78;
    white-space:nowrap;
  }

  .anniversary{
    flex:0 0 auto;
    padding:7px 12px;
    font-size:.74rem;
  }

  .header-actions{
    gap:10px;
  }
}

/* Ajuste extra para celulares angostos: mantiene el logo completo y evita que se comprima */
@media (max-width:430px){
  .brand-group{
    gap:10px;
  }

  .logo{
    font-size:.94rem;
  }

  .logo small{
    display:block;
    font-size:.42rem;
    margin-top:5px;
  }

  .anniversary{
    padding:6px 9px;
    font-size:.7rem;
  }
}
