:root{
  --primary:#0077BE;
  --secondary:#FF6B35;
  --dark:#0f1222;
  --text:#1a1a2e;
  --muted:#5b6075;
  --light:#f6f8fb;
  --white:#ffffff;
  --border:rgba(15,18,34,.12);
  --shadow: 0 10px 30px rgba(15,18,34,.12);
  --radius:16px;
  --radius-sm:12px;
  --container:1160px;

  /* HERO - contraste general (PC/Tablet/Móvil) */
  --hero-overlay-top: rgba(15,18,34,.68);
  --hero-overlay-bottom: rgba(15,18,34,.86);

  /* toque “anaranjado” (se mezcla en overlay) */
  --hero-orange-1: rgba(255,107,53,.22);
  --hero-orange-2: rgba(255,107,53,.14);

  /* panel texto (glass oscuro, ligeramente cálido) */
  --hero-panel-bg: rgba(15,18,34,.62);
  --hero-panel-border: rgba(255,255,255,.18);
  --hero-panel-shadow: 0 25px 80px rgba(0,0,0,.38);
  --hero-text-shadow: 0 2px 18px rgba(0,0,0,.55);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  color:var(--text);
  background:var(--white);
  line-height:1.5;
}

a{ color:inherit; text-decoration:none; }
a:hover{ text-decoration:underline; }
img{ max-width:100%; height:auto; display:block; }

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

.skiplink{
  position:absolute;
  left:-999px; top:10px;
  background:var(--dark); color:var(--white);
  padding:10px 12px;
  border-radius:10px;
  z-index:9999;
}
.skiplink:focus{ left:10px; }

.small{ font-size:.95rem; }
.muted{ color:var(--muted); }
.h3{ font-size:1.15rem; margin:0; }

/* Header */
.topbar{
  position:sticky; top:0;
  background:rgba(255,255,255,.86);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--border);
  z-index:1000;
}
.nav{
  display:flex; align-items:center; gap:16px;
  padding:14px 0;
}
.logo{
  font-weight:800;
  letter-spacing:.2px;
  font-size:1.1rem;
  white-space:nowrap;
}
.logo span{ color:var(--primary); }

.menu{
  margin-left:auto;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:center;
}
.menu a{
  font-weight:600;
  color:rgba(26,26,46,.9);
  padding:8px 10px;
  border-radius:10px;
}
.menu a.active, .menu a:hover{
  background:rgba(0,119,190,.10);
  text-decoration:none;
}

.lang{
  display:flex; gap:8px;
  margin-left:8px;
  align-items:center;
}
.pill{
  display:inline-flex; align-items:center; justify-content:center;
  height:32px;
  padding:0 10px;
  border:1px solid var(--border);
  border-radius:999px;
  font-weight:700;
  font-size:.85rem;
  color:rgba(26,26,46,.8);
}
.pill.is-current{
  background:rgba(0,119,190,.12);
  border-color:rgba(0,119,190,.25);
  color:rgba(0,119,190,1);
}

/* (Opcional) estilo para iconos de banderas dentro de .pill */
.pill .flag{
  width:18px;
  height:12px;
  border-radius:3px;
  display:inline-block;
  margin-right:8px;
  box-shadow: 0 0 0 1px rgba(15,18,34,.12);
}

/* Mobile menu */
.navToggle{
  display:none;
  margin-left:auto;
  width:44px; height:40px;
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--white);
  align-items:center;
  justify-content:center;
  gap:5px;
}
.navToggle span{
  display:block; width:18px; height:2px;
  background:rgba(26,26,46,.85);
  border-radius:2px;
}

@media (max-width: 980px){
  .nav{ gap:10px; }
  .navToggle{ display:inline-flex; }
  .menu{
    display:none;
    width:100%;
    flex-direction:column;
    align-items:stretch;
    gap:6px;
    margin:10px 0 0;
    padding:10px;
    border:1px solid var(--border);
    border-radius:14px;
    background:var(--white);
  }
  .menu.is-open{ display:flex; }
  .lang{ display:none; }
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius:999px;
  padding:12px 16px;
  font-weight:800;
  border:1px solid var(--border);
  background:var(--white);
  color:rgba(26,26,46,.92);
  box-shadow: 0 1px 0 rgba(15,18,34,.03);
  text-decoration:none !important;
  transition: transform .08s ease, box-shadow .2s ease, border-color .2s ease;
}
.btn:hover{ transform: translateY(-1px); box-shadow: var(--shadow); border-color: rgba(15,18,34,.18); }
.btn:active{ transform: translateY(0px); }

.btn--primary{
  background:var(--primary);
  border-color:rgba(0,119,190,.35);
  color:var(--white);
}
.btn--whatsapp{
  background:var(--secondary);
  border-color:rgba(255,107,53,.35);
  color:var(--white);
}
.btn--ghost{
  background:rgba(255,255,255,.65);
}
.btn--sm{ padding:10px 14px; font-size:.95rem; }

.ctaRow{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; }

/* Fixed CTA */
.fixedCTA{
  position:fixed;
  right:16px;
  bottom:16px;
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:1100;
}
@media (max-width: 700px){
  .fixedCTA{
    left:16px; right:16px;
    flex-direction:row;
  }
  .fixedCTA .btn{ flex:1; }
}

/* Hero */
.hero{
  position:relative;
  overflow:hidden;
  padding: clamp(44px, 6vw, 90px) 0;
}
.heroBg{
  position:absolute;
  inset:0;
  z-index:-2;
}
.heroBg img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform: scale(1.02);
  filter: contrast(1.03) saturate(1.06);
}

/* Overlay con toque anaranjado + sombra oscura (mejor contraste en TODAS las pantallas) */
.heroOverlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 560px at 12% 18%, rgba(0,119,190,.18), transparent 62%),
    radial-gradient(820px 520px at 88% 12%, var(--hero-orange-2), transparent 60%),
    radial-gradient(900px 520px at 70% 72%, var(--hero-orange-1), transparent 62%),
    linear-gradient(180deg, var(--hero-overlay-top), var(--hero-overlay-bottom));
  z-index:-1;
}

.heroGrid{
  display:grid;
  grid-template-columns: 1.2fr .9fr;
  gap:24px;
  align-items:stretch;
}

.heroText{
  position:relative;
  color:var(--white);
  padding:22px;
  border:1px solid var(--hero-panel-border);
  border-radius: var(--radius);
  background: var(--hero-panel-bg);
  box-shadow: var(--hero-panel-shadow);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Capa interna: añade un “warm tint” + gradiente para legibilidad */
.heroText::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255,107,53,.10), rgba(15,18,34,.22)),
    linear-gradient(180deg, rgba(15,18,34,.08), rgba(15,18,34,.22));
  pointer-events:none;
  opacity:.9;
}
.heroText > *{ position:relative; z-index:1; }

.heroText h1{
  margin:8px 0 10px;
  line-height:1.08;
  font-size: clamp(2.0rem, 3.8vw, 3.1rem);
  letter-spacing:-.6px;
  text-shadow: var(--hero-text-shadow);
}
.eyebrow{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.20);
  font-weight:800;
  letter-spacing:.3px;
  font-size:.85rem;
  margin:0;
  text-shadow: 0 2px 14px rgba(0,0,0,.45);
}

/* ✅ ARREGLO: .lead ya no es blanco por defecto (para que funcione en fondos claros) */
.lead{
  margin:0 0 16px;
  font-size: 1.12rem;
  color: var(--muted);
  max-width: 68ch;
}

/* ✅ Solo dentro del HERO, .lead mantiene estilo blanco */
.hero .lead{
  color: rgba(255,255,255,.95);
  text-shadow: 0 2px 14px rgba(0,0,0,.45);
  max-width: 62ch;
}

.trust{
  margin-top:14px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:10px;
}
.trustItem{
  border:1px solid rgba(255,255,255,.18);
  background: rgba(15,18,34,.28);
  border-radius: 14px;
  padding:12px;
}
.trustItem b{ display:block; text-shadow: 0 2px 14px rgba(0,0,0,.45); }
.trustItem span{ display:block; color: rgba(255,255,255,.86); font-size:.95rem; text-shadow: 0 2px 14px rgba(0,0,0,.35); }

.chips{ margin-top:14px; display:flex; flex-wrap:wrap; gap:8px; }
.chip{
  border:1px solid rgba(255,255,255,.18);
  background: rgba(15,18,34,.24);
  color: rgba(255,255,255,.92);
  border-radius: 999px;
  padding:7px 10px;
  font-weight:700;
  font-size:.9rem;
  text-shadow: 0 2px 12px rgba(0,0,0,.35);
  text-decoration:none !important;
}

.heroMedia{ display:flex; align-items:stretch; }
.mediaCard{
  width:100%;
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.16);
  background: rgba(15,18,34,.32);
  overflow:hidden;
  box-shadow: var(--hero-panel-shadow);
  color: var(--white);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.mediaHeader{ padding:16px 16px 0; }
.mediaFooter{ padding: 12px 16px 16px; }

@media (max-width: 980px){
  .heroGrid{ grid-template-columns: 1fr; }
  .trust{ grid-template-columns: 1fr; }
}

/* En móvil lo reforzamos un poco más todavía */
@media (max-width: 620px){
  :root{
    --hero-panel-bg: rgba(15,18,34,.74);
    --hero-overlay-top: rgba(15,18,34,.76);
    --hero-overlay-bottom: rgba(15,18,34,.90);
  }
  .heroText{ padding:18px; }
  .hero .lead{ font-size:1.06rem; }
}

/* Video responsive */
.video{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  border-radius: 14px;
  overflow:hidden;
  margin: 12px 16px 0;
  border:1px solid rgba(255,255,255,.16);
}
.video iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* Sections */
.section{ padding: clamp(42px, 5vw, 72px) 0; }
.section--alt{ background: var(--light); }
.sectionHead{ margin-bottom:18px; }
.sectionHead h2{ margin:0 0 6px; font-size: clamp(1.5rem, 2.4vw, 2rem); letter-spacing:-.4px; }
.sectionFoot{ margin-top:18px; display:flex; gap:10px; flex-wrap:wrap; }

.grid{ display:grid; gap:14px; }

/* Cards */
.cards{ grid-template-columns: repeat(12, 1fr); }
.card{ grid-column: span 4; }
@media (max-width: 980px){ .card{ grid-column: span 6; } }
@media (max-width: 620px){ .card{ grid-column: span 12; } }

.cardLink{
  display:block;
  border:1px solid var(--border);
  background: var(--white);
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: 0 2px 0 rgba(15,18,34,.03);
  transition: transform .12s ease, box-shadow .25s ease, border-color .2s ease;
  text-decoration:none !important;
}
.cardLink:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: rgba(15,18,34,.18);
}
.thumb{
  width:100%;
  height: 190px;
  object-fit:cover;
  background: #dde7f1;
}
.cardBody{ padding:14px; }
.cardBody h3{ margin:0 0 6px; letter-spacing:-.2px; }
.cardBody p{ margin:0 0 10px; color:var(--muted); }
.cardCta{ font-weight:900; color: var(--primary); }

/* Packs */
.packs{
  grid-template-columns: repeat(12, 1fr);
  gap:14px;
}
.pack{
  grid-column: span 4;
  border:1px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
  padding:16px;
  box-shadow: 0 2px 0 rgba(15,18,34,.03);
  position:relative;
}
.pack--featured{
  border-color: rgba(0,119,190,.30);
  box-shadow: 0 18px 45px rgba(0,119,190,.12);
}
.ribbon{
  position:absolute;
  top:14px; right:14px;
  background: rgba(0,119,190,.12);
  color: rgba(0,119,190,1);
  border: 1px solid rgba(0,119,190,.25);
  border-radius: 999px;
  padding:6px 10px;
  font-weight:900;
  font-size:.85rem;
}
.pack h3{ margin:4px 0 6px; }
.list{ margin:10px 0 0; padding-left:18px; color: var(--muted); }
.packBottom{ margin-top:14px; }
@media (max-width: 980px){ .pack{ grid-column: span 6; } }
@media (max-width: 620px){ .pack{ grid-column: span 12; } }

/* Banner */
.ctaBanner{
  margin-top:18px;
  border:1px solid rgba(0,119,190,.22);
  background: rgba(0,119,190,.06);
  border-radius: var(--radius);
  padding:16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
@media (max-width: 780px){
  .ctaBanner{ flex-direction:column; align-items:flex-start; }
}

/* Steps */
.steps{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
}
.step{
  border:1px solid var(--border);
  background: var(--white);
  border-radius: var(--radius-sm);
  padding:14px;
}
.step b{ display:block; margin-bottom:6px; }
.step p{ margin:0; color:var(--muted); }
@media (max-width: 980px){ .steps{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 620px){ .steps{ grid-template-columns: 1fr; } }

/* FAQ */
.faq{
  display:grid;
  gap:10px;
  max-width: 920px;
}
details{
  border:1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--white);
  padding: 12px 14px;
}
summary{
  cursor:pointer;
  font-weight:900;
  letter-spacing:-.2px;
}
details p{ margin:10px 0 0; color:var(--muted); }

/* Contact */
.contactCard{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
  padding:16px;
  box-shadow: 0 2px 0 rgba(15,18,34,.03);
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
  align-items:stretch;
}
.contactRow{ display:flex; flex-wrap:wrap; gap:10px; margin: 10px 0 6px; }
.map{
  border-radius: 14px;
  overflow:hidden;
  border:1px solid var(--border);
  min-height: 260px;
}
.map iframe{ width:100%; height:100%; border:0; }
@media (max-width: 980px){
  .contactCard{ grid-template-columns: 1fr; }
}

/* Footer */
.footer{
  padding: 42px 0 28px;
  border-top: 1px solid var(--border);
  background: #0e1222;
  color: rgba(255,255,255,.92);
}
.footer a{ color: rgba(255,255,255,.92); }
.footer a:hover{ color: var(--white); }
.footerGrid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap:14px;
}
.footerBottom{
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.12);
}
.footer .muted{ color: rgba(255,255,255,.70); }
@media (max-width: 980px){
  .footerGrid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 620px){
  .footerGrid{ grid-template-columns: 1fr; }
}