:root{
  --primary:#0098FF;
  /* Neutros: negro ligeramente azulado (más consistente con el brand) */
  --black:#0B1220;
  --white:#fff;
  --muted:#F3F6FA;
  --text-muted:#344054;
  --text-muted-2:#667085;

  --header-bg: var(--white);
  --header-fg: var(--black);
  --border-soft: rgba(11,18,32,.10);
  --border-softer: rgba(11,18,32,.06);

  --radius-12:12px;
  --radius-16:16px;
  --radius-20:20px;

  /* Sombras más suaves para un look más fluido (menos “tarjeta”) */
  --shadow-card: 0 10px 24px rgba(11,18,32,.08);
  --shadow-hover: 0 18px 46px rgba(11,18,32,.12);

  --container:1200px;
  --padX: clamp(16px, 6vw, 120px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--black);
  background:var(--white);
  overflow-x:hidden; /* evita scroll horizontal por elementos anchos en móvil */
}
img{ max-width:100%; height:auto; display:block; }

.skip-link{ position:absolute; left:-999px; top:auto; }
.skip-link:focus{
  left:16px; top:16px;
  padding:10px 12px;
  background:var(--white);
  border-radius:10px;
  outline:2px solid var(--primary);
  z-index:9999;
}

.container{
  max-width: var(--container);
  margin: 0 auto;
  padding-inline: var(--padX);
}

/* Typography */
.h1{ font-size:56px; font-weight:700; line-height:1.15; margin:0 0 16px; }
.h2{ font-size:40px; font-weight:600; line-height:1.2; margin:0 0 12px; }
.h2--white{ color:var(--white); }
.h3{ font-size:28px; font-weight:600; line-height:1.25; margin:0 0 8px; }
.h3--sm{ font-size:22px; }
.body{ font-size:18px; line-height:1.55; margin:0; color:var(--text-muted); }
.caption{ font-size:14px; line-height:1.45; margin:0; color:var(--text-muted-2); }

/* Sections */
.section{ padding-block:96px; }
.section--muted{ background:var(--muted); }
.section--primary{ background:var(--primary); color:var(--white); }
.section{ scroll-margin-top: 92px; }

.section__header{ margin-bottom:32px; }
.section__lead{ margin:0; font-size:18px; color:var(--text-muted); }
.section--primary .section__lead{ color:rgba(255,255,255,.9); }

/* Header */
.header{
  position:sticky; top:0; z-index:50;
  background:var(--header-bg);
  border-bottom:1px solid var(--border-softer);
}
.header__inner{
  height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.header__brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
}
.header__logo{ height:44px; width:auto; }

.nav--desktop{
  display:flex; gap:32px;
  align-items:center;
}
.nav__link{
  text-decoration:none;
  color:var(--header-fg);
  font-weight:600;
  font-size:16px;
  padding:10px 6px;
  border-radius:10px;
  position:relative;
  transition:color .18s ease;
}
.nav__link:focus{ outline:2px solid var(--primary); outline-offset:3px; }
.nav__link::after{
  content:"";
  position:absolute;
  left:8px;
  right:8px;
  bottom:6px;
  height:2px;
  border-radius:999px;
  background:var(--primary);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .18s ease;
  opacity:.9;
}
.nav__link:hover::after{ transform:scaleX(1); }
.nav__link.is-active::after{ transform:scaleX(1); }

.header__actions{ display:flex; align-items:center; gap:12px; }
.header__cta{ display:inline-flex; }

.icon-btn{
  height:44px; width:44px;
  border:0; background:transparent;
  border-radius:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.icon-btn:focus{ outline:2px solid var(--primary); outline-offset:3px; }
.icon-btn:hover{ background:rgba(0,0,0,.06); }
.icon-btn__bars{
  width:22px; height:2px; background:var(--header-fg);
  position:relative; display:block; border-radius:2px;
}
.icon-btn__bars::before,
.icon-btn__bars::after{
  content:""; position:absolute; left:0;
  width:22px; height:2px; background:var(--header-fg);
  border-radius:2px;
}
.icon-btn__bars::before{ top:-7px; }
.icon-btn__bars::after{ top:7px; }

.header__burger{ display:none; }

/* Buttons */
.btn{
  text-decoration:none;
  border:0;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  height:48px;
  padding:0 24px;
  border-radius:var(--radius-12);
  font-weight:600;
  font-size:18px;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
}
.btn:focus{ outline:2px solid var(--primary); outline-offset:3px; }

.btn--primary{ background:var(--primary); color:var(--white); }
.btn--primary:hover{ box-shadow:0 0 16px rgba(0,152,255,.35); transform:translateY(-1px); }

.btn--secondary{
  background:transparent;
  color:var(--primary);
  border:2px solid var(--primary);
}
.section--primary .btn--secondary{
  color:var(--white);
  border-color:rgba(255,255,255,.90);
}
.section--primary .btn--secondary:hover{
  background:rgba(255,255,255,.12);
}
.btn--secondary:hover{
  transform:translateY(-1px);
  background:rgba(0,152,255,.10);
}

.btn--glow{
  background:var(--white);
  color:var(--black);
  box-shadow:0 0 16px rgba(255,255,255,.25);
}
.btn--glow:hover{ box-shadow:0 0 24px rgba(255,255,255,.35); transform:translateY(-1px); }

.btn--white{ background:var(--white); color:var(--black); }
.btn--white:hover{ box-shadow:0 0 16px rgba(255,255,255,.35); transform:translateY(-1px); }
.btn--full{ width:100%; }

/* Hero */
.hero{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:40px;
  align-items:center;
}
.hero > *{ min-width:0; } /* evita overflow/cortes en grid en pantallas pequeñas */
.hero__sub{
  font-size:18px;
  margin:0 0 24px;
  color:rgba(255,255,255,.95);
}
.hero__buttons{ display:flex; gap:12px; flex-wrap:wrap; }
.hero__img{
  width:100%;
  max-width:560px;
  margin-left:auto;
}

/* Grids */
.grid{ display:grid; gap:24px; }
.grid--3{ grid-template-columns: repeat(3, 1fr); }
.grid--4{ grid-template-columns: repeat(4, 1fr); }

/* Cards */
.card{
  background:var(--white);
  border-radius:var(--radius-16);
  padding:24px;
  box-shadow:var(--shadow-card);
  border:1px solid var(--border-softer);
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.card:hover{
  transform:none;
  box-shadow:var(--shadow-hover);
  border-color:rgba(0,152,255,.22);
}
.card__img{
  width:100%;
  height:140px;
  object-fit:contain;
  margin-bottom:12px;
  border-radius:14px;
}
.card__img--sm{ height:96px; }

.card--value{
  background:var(--muted);
  box-shadow:none;
  border:1px solid var(--border-softer);
}
.card--value:hover{
  background:var(--white);
  border-color:rgba(0,152,255,.35);
  box-shadow:var(--shadow-hover);
}

/* Valores (sin cards, más fluido) */
.values{ align-items:start; }
.value{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:8px 0;
}
.value__img{
  width:100%;
  height:110px;
  object-fit:contain;
  background:transparent;
  filter: drop-shadow(0 10px 18px rgba(11,18,32,.14));
}

.card--plan{ border-radius:var(--radius-20); }
.card--featured{
  outline:none;
  background:linear-gradient(180deg, rgba(0,152,255,.06), rgba(0,152,255,0));
  border-color:rgba(0,152,255,.22);
}

.badge{
  display:inline-flex;
  align-items:center;
  height:28px;
  padding:0 12px;
  border-radius:999px;
  background:var(--primary);
  color:var(--white);
  font-weight:600;
  font-size:12px;
  margin-bottom:12px;
}

/* Split (About) */
.split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:40px;
  align-items:center;
}
.split > *{ min-width:0; }
.split__img{ max-width:520px; margin-left:auto; }

/* CTA */
.cta{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:32px;
  align-items:center;
}
.cta > *{ min-width:0; }
.section--cta{
  position:relative;
  overflow:hidden;
}
.section--cta::before{
  content:"";
  position:absolute;
  inset:-200px -120px;
  background:
    radial-gradient(520px 520px at 18% 35%, rgba(255,255,255,.18), transparent 60%),
    radial-gradient(520px 520px at 86% 20%, rgba(255,255,255,.14), transparent 62%),
    radial-gradient(640px 420px at 80% 80%, rgba(11,18,32,.18), transparent 60%);
  pointer-events:none;
}
.section--cta::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,0));
  pointer-events:none;
}
.cta > *{ position:relative; z-index:1; }

.cta__text{ max-width:560px; }
.cta__sub{
  margin:0 0 18px;
  font-size:18px;
  line-height:1.55;
  color:rgba(255,255,255,.92);
}
.cta__points{
  margin:0 0 22px;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.cta__points li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:rgba(255,255,255,.92);
}
.cta__points li::before{
  content:"";
  width:10px;
  height:10px;
  margin-top:6px;
  border-radius:999px;
  background:rgba(255,255,255,.95);
  box-shadow:0 0 0 6px rgba(255,255,255,.14);
  flex:0 0 auto;
}
.cta__actions{ display:flex; gap:12px; flex-wrap:wrap; }
.cta__stats{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:12px;
  margin: 0 0 22px;
}
.cta__stat{
  border-radius:18px;
  padding:14px 14px 12px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(6px);
}
.cta__statValue{
  font-weight:800;
  font-size:18px;
  line-height:1.1;
  color:var(--white);
}
.cta__statLabel{
  margin-top:6px;
  font-size:13px;
  line-height:1.35;
  color:rgba(255,255,255,.88);
}
.cta__img{
  max-width:520px;
  margin-left:auto;
}

/* Contact */
.contact__grid{
  display:grid;
  grid-template-columns: 1fr .9fr;
  gap:32px;
  align-items:start;
}
.contact__grid > *{ min-width:0; }
.contact__img{
  width:100%;
  max-width:520px;
  margin-left:auto;
}
.form{ display:flex; flex-direction:column; gap:14px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field__label{ font-size:14px; color:var(--text-muted-2); font-weight:500; }

.input, .textarea{
  width:100%;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.14);
  padding:12px 14px;
  font-family:inherit;
  font-size:16px;
  outline:none;
  transition:box-shadow .15s ease, border-color .15s ease;
}
.input:focus, .textarea:focus{
  border-color:rgba(0,152,255,.9);
  box-shadow:0 0 0 2px rgba(0,152,255,.35);
}
.form__note{ margin-top:4px; }

/* Footer */
.footer{
  background:var(--black);
  color:var(--white);
  padding-block:40px;
}
.footer__brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
  padding:0;
  border-radius:0;
  background:transparent;
  text-decoration:none;
}
.footer__inner{
  display:grid;
  gap:18px;
}
.footer__brand{ flex:0 0 auto; }
.footer__mark{ height:40px; width:auto; flex:0 0 auto; }
.footer__logo{
  height:40px;
  width:auto;
  max-width:none;
  flex:0 0 auto;
}
.footer__brandText{
  color:var(--white);
  font-weight:700;
  font-size:24px;
  line-height:1;
  letter-spacing:.2px;
}
.footer__brandBlue{ color:var(--primary); }
.footer__brandDot{ color:var(--white); }
.footer__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.footer__nav{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  align-items:center;
}
.footer__nav a{
  color:var(--white);
  text-decoration:none;
  opacity:.9;
  font-weight:600;
}
.footer__nav a:hover{ opacity:1; }

.footer__social{ display:flex; align-items:center; }
.footer__socialLink{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  color:var(--white);
  text-decoration:none;
  transition:background .18s ease, transform .18s ease, border-color .18s ease;
}
.footer__socialLink:hover{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.24);
  transform:translateY(-1px);
}
.footer__icon{ display:inline-flex; }
.footer__icon svg{ display:block; }
.footer__socialText{ font-weight:700; }
.footer__socialHandle{ opacity:.85; font-weight:600; }

.footer__bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  padding-top:16px;
  border-top:1px solid rgba(255,255,255,.12);
}
.footer__copy{ margin:0; color:rgba(255,255,255,.85); }
.footer__backToTop{
  color:var(--white);
  text-decoration:none;
  opacity:.9;
  font-weight:600;
}
.footer__backToTop:hover{ opacity:1; }

/* Mobile Menu */
.mobile-menu{
  position:fixed;
  inset:0;
  display:none;
  z-index:100;
}
.mobile-menu.is-open{ display:block; }
.mobile-menu__overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.25);
}
.mobile-menu__panel{
  position:absolute;
  top:0; right:0;
  height:100%;
  width:min(280px, 86vw);
  background:var(--white);
  box-shadow:-4px 0 16px rgba(0,0,0,.15);
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:24px;
  transform:translateX(100%);
  transition:transform .25s ease;
}
.mobile-menu.is-open .mobile-menu__panel{ transform:translateX(0); }

.mobile-menu__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.mobile-menu__logo{ height:34px; width:auto; }

.mobile-menu__nav{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.mobile-menu__link{
  text-decoration:none;
  color:var(--black);
  font-weight:600;
  font-size:18px;
  padding:10px 10px;
  border-radius:12px;
}
.mobile-menu__link:hover{ background:rgba(0,152,255,.08); }
.mobile-menu__cta{ margin-top:auto; }

/* Modal (Plans) */
.modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:200;
}
.modal.is-open{ display:block; }
.modal__overlay{
  position:absolute;
  inset:0;
  background:rgba(11,18,32,.45);
}
.modal__panel{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  width:min(560px, calc(100vw - 32px));
  max-height:min(640px, calc(100vh - 32px));
  overflow:auto;
  background:var(--white);
  border-radius:24px;
  box-shadow:0 24px 70px rgba(11,18,32,.35);
  padding:22px;
}
.modal__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.modal__kicker{
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--text-muted-2);
}
.modal__title{
  margin:4px 0 0;
  font-size:26px;
  line-height:1.2;
}
.modal__desc{
  margin:10px 0 14px;
  color:var(--text-muted);
  font-size:16px;
  line-height:1.6;
}
.modal__list{
  margin:0 0 18px;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.modal__list li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:10px 12px;
  border-radius:14px;
  background:var(--muted);
  border:1px solid var(--border-softer);
}
.modal__list li::before{
  content:"";
  width:10px;
  height:10px;
  margin-top:6px;
  border-radius:999px;
  background:var(--primary);
  box-shadow:0 0 0 6px rgba(0,152,255,.14);
  flex:0 0 auto;
}
.modal__actions{
  display:grid;
  gap:10px;
}
.modal__note{ margin-top:12px; }

/* Responsive */
@media (max-width: 980px){
  .grid--4{ grid-template-columns: repeat(2, 1fr); }
  .grid--3{ grid-template-columns: repeat(2, 1fr); }
  .hero, .split, .cta, .contact__grid{ grid-template-columns: 1fr; }
  .hero__img, .split__img, .cta__img{ margin:0; max-width:520px; }
  .contact__img{ margin:0; max-width:520px; }
  .hero__buttons{ justify-content:flex-start; }

  /* En layouts de 1 columna, centrar visuales para evitar “pegado” a un lado */
  .hero__visual,
  .split__visual,
  .cta__visual{
    display:flex;
    justify-content:center;
  }
}
@media (max-width: 760px){
  .nav--desktop{ display:none; }
  .header__cta{ display:none; }
  .header__burger{ display:inline-flex; }
  .grid--3{ grid-template-columns: 1fr; }
  .section{ padding-block:64px; }
  .h1{ font-size:40px; }
  .h2{ font-size:30px; }
  .h3{ font-size:24px; }

  .header__logo{ height:40px; }
  .btn{
    height:46px;
    font-size:17px;
    max-width:100%;
  }
  .btn--full{ height:48px; }
  .card{ padding:20px; }
  .card__img{ height:128px; padding:10px; }
  .card__img--sm{ height:90px; }

  .footer__mark{ height:36px; }
  .footer__logo{ height:36px; }
  .footer__brandText{ font-size:22px; }

  .footer__top{
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
  }
  .footer__bottom{
    flex-direction:column;
    align-items:flex-start;
  }

  .cta__sub{ font-size:17px; }
  .cta__stats{ grid-template-columns: 1fr; }

  .modal__panel{ padding:18px; }
  .modal__title{ font-size:22px; }

  /* CTA: fondo decorativo menos agresivo en pantallas chicas (evita recortes raros) */
  .section--cta::before{ inset:-160px -60px; }
}

@media (max-width: 480px){
  .section{ padding-block:56px; }
  .h1{ font-size:34px; line-height:1.15; }
  .h2{ font-size:26px; }
  .h3{ font-size:22px; }
  .body{ font-size:16px; }

  /* Botones largos: mejor apilados */
  .hero__buttons,
  .cta__actions{
    flex-direction:column;
    align-items:stretch;
  }
  .hero__buttons .btn,
  .cta__actions .btn{
    width:100%;
  }

  /* Centrar visuales en layouts de 1 columna */
  .hero__img,
  .split__img,
  .cta__img,
  .contact__img{
    margin-inline:auto;
  }

  /* Ilustraciones: limita tamaño para que el texto/CTA no se sienta “cortado” */
  .hero__img,
  .split__img,
  .cta__img{
    max-width:min(360px, 100%);
  }

  /* Evitar que el logo del footer fuerce ancho */
  .footer__logo{
    height:auto;
    width:min(240px, 72vw);
    max-width:100%;
  }
}
