/* =========================
   BASE
========================= */
*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  background:#FFFFFF;
  color:#2B2B2B;
  font-family:"Nunito", system-ui, sans-serif;
  line-height:1.6;
}

img{ max-width:100%; height:auto; }

.container{
  width:min(1140px, 94%);
  margin:0 auto;
  padding:0 12px;
}

h1,h2,h3,h4{
  font-family:"Fredoka", system-ui, sans-serif;
  color:#2E4FD7;
  margin:0 0 12px;
}

p{
  margin:0 0 12px;
  color:#4A4A4A;
}

/* =========================
   SECTIONS
========================= */
.section{ padding:64px 0; }
.section--alt{ background:#F5F7FB; }

.section__title{ margin-bottom:6px; }

.section__subtitle{
  max-width:60ch;
  margin-bottom:32px;
  color:#5A5A5A;
}

/* =========================
   CARD (BASE)
========================= */
.card{
  background:#FFFFFF;
  border-radius:18px;
  border:1px solid #EAEAF0;
  padding:20px;
  box-shadow: 0 8px 18px rgba(0,0,0,.03);
}

/* =========================
   BUTTONS
========================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 20px;
  border-radius:999px;
  background:#FFD84D;
  color:#1F1F1F;
  font-family:"Fredoka";
  font-weight:700;
  border:none;
  cursor:pointer;
  text-decoration:none;
  transition: transform .15s ease, background .15s ease, color .15s ease, box-shadow .15s ease;
}

.btn:hover{
  background:#2E4FD7;
  color:#FFFFFF;
  transform: translateY(-1px);
}

.btn--ghost{
  background:#FF7A8A;
  color:#FFFFFF;
}

.btn--ghost:hover{
  background:#2E4FD7;
  color:#FFFFFF;
}

.btn--full{ width:100%; }

/* =========================
   TOPBAR
========================= */
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  background:#FFFFFF;
  border-bottom:1px solid #EAEAF0;
  box-shadow:0 2px 0 rgba(0,0,0,0.02);
}

.topbar__inner{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap:16px;
  padding:14px 0;
  min-height:84px;
}

.brand{ justify-self:start; }
.nav{ justify-self:center; }
.topbar__cta{ justify-self:end; }

.brand{
  text-decoration:none;
  display:flex;
  align-items:center;
  gap:12px;
}

.brand__logo{
  height:72px;
  width:auto;
  display:block;
}

.nav{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
}

.nav__link{
  text-decoration:none;
  font-weight:700;
  font-size:1.05rem;
  color:#1F4E79;
  padding:8px 12px;
  border-radius:12px;
  transition: color .15s ease, transform .15s ease, background .15s ease;
}

.nav__link:hover{
  color:#2E4FD7;
  transform: translateY(-2px);
  background: rgba(46,79,215,.06);
}

.nav__link--active{
  color:#2E4FD7;
  background: rgba(46,79,215,.10);
}

/* =========================
   HERO
========================= */

.hero{
  padding: 48px 0 56px;
  background:
    radial-gradient(900px 420px at 82% 18%, rgba(46,79,215,.12), transparent 60%),
    radial-gradient(640px 320px at 10% 20%, rgba(255,216,77,.18), transparent 55%),
    #F5F7FB; /* color bajo el hero */
  border-bottom: 1px solid #EAEAF0;
  overflow: hidden; /* recorta el círculo */
}

.hero__grid{
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 40px;
  align-items: center;
}

.hero__text{
  max-width: 640px;
}

.hero__tag{
  display: inline-block;
  padding: 6px 14px;
  border-radius: 999px;
  background: #EEF2FF;
  color: #2E4FD7;
  font-family: "Fredoka", system-ui, sans-serif;
  font-weight: 600;
  margin-bottom: 14px;
}

.hero__title{
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.15;
  max-width: 22ch;
  margin: 0 0 12px;
  color: #2E4FD7;
}

.accent{
  color: #1F4E79;
  font-weight: 700;
}

.hero__desc{
  font-size: 1.05rem;
  color: #555;
  max-width: 52ch;
  margin: 0 0 12px;
}

.hero__desc--strong{
  margin-top: 6px;
}

.hero__actions{
  display: flex;
  gap: 14px;
  margin: 20px 0 14px;
  flex-wrap: wrap;
}

.hero__checks{
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  font-weight: 600;
  color: #2B2B2B;
}

/* Imagen / Media */
.hero__media{
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Círculo decorativo (controlado) */
.hero__media::before{
  content: "";
  position: absolute;
  width: 520px;
  height: 520px;
  right: -60px;
  top: -40px;
  z-index: 0;
  border-radius: 50%;
  pointer-events: none;
  background:
    radial-gradient(circle at 35% 35%, rgba(46,79,215,.22), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(255,216,77,.28), transparent 58%);
}

/* Marco / tarjeta de imagen */
.hero__card{
  position: relative;
  z-index: 1;
  max-width: 520px;
  width: 100%;
  background: rgba(255,255,255,.75);
  padding: 16px;
  border-radius: 26px;
  border: 1px solid rgba(234,234,240,.95);
  box-shadow: 0 22px 40px rgba(0,0,0,.12);
}

.hero__card img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 18px;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 900px){
  .hero{
    padding: 40px 0 48px;
  }

  .hero__grid{
    grid-template-columns: 1fr;
    gap: 26px;
  }

  .hero__media::before{
    width: 320px;
    height: 320px;
    right: -120px;
    top: -140px;
    opacity: .55;
  }

  .hero__card{
    padding: 12px;
  }
}

@media (max-width: 520px){
  .hero__media::before{
    width: 260px;
    height: 260px;
    right: -140px;
    top: -160px;
    opacity: .45;
  }
}
/* =========================
   CATALOGO
   ========================= */

/* Grid */
.catalogo{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

@media (max-width: 900px){
  .catalogo{
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px){
  .catalogo{
    grid-template-columns: 1fr;
  }
}

/* Tarjeta producto */
.product{
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 360px;
  cursor: pointer;

  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.product:hover{
  transform: translateY(-6px);
  border-color: rgba(46,79,215,.22);
  box-shadow: 0 16px 34px rgba(0,0,0,.10);
}

/* Click feedback  */
.product:active{
  transform: translateY(-3px);
}

/* Contenedor imagen */
.product__img{
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 14px;
  background: #F5F7FB;
  border: 1px solid #EAEAF0;
  overflow: hidden;
}

.product__img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform-origin: center;
  transition: transform .25s ease;
}

.product:hover .product__img img{
  transform: scale(1.06);
}

/* Título “clickeable” */
.product h3{
  margin-top: 6px;
  display: inline-block;
  transition: transform .18s ease;
  position: relative;
}

/* subrayado animado */
.product h3::after{
  content:"";
  position: absolute;
  left: 0;
  bottom: -4px;
  width: 100%;
  height: 2px;
  background: #FFD84D;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .18s ease;
}

.product:hover h3{
  transform: translateY(-2px);
}

.product:hover h3::after{
  transform: scaleX(1);
}

/* Texto info */
.product__info{
  font-weight: 600;
  color: #5A5A5A;
}

/* Botón al fondo */
.product .btn{
  margin-top: auto;
}

/* Badges */
.badge{
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  padding: 7px 12px;
  border-radius: 999px;
  font-family: "Fredoka", system-ui, sans-serif;
  font-weight: 700;
  font-size: .82rem;
  line-height: 1;
  box-shadow: 0 10px 18px rgba(0,0,0,.10);
}

.badge + .badge{
  left: auto;
  right: 12px;
}

.badge--hot{
  background: #2E4FD7;
  color: #fff;
}

.badge--new{
  background: #FFD84D;
  color: #1F1F1F;
}

.product:focus-within{
  outline: 3px solid rgba(46,79,215,.25);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce){
  .product,
  .product__img img,
  .product h3,
  .product h3::after{
    transition: none !important;
  }
  .product:hover{
    transform: none;
  }
  .product:hover .product__img img{
    transform: none;
  }
}

/* =========================
   NOSOTROS
========================= */
.about__intro{
  max-width:72ch;
  font-size:1.05rem;
  color:#4A4A4A;
  margin-bottom:18px;
}

.aboutMain{
  padding:24px;
  margin-bottom:22px;
}

.aboutMain__title{ margin:0 0 8px; }

.aboutMain__text{
  margin:0 0 14px;
  color:#555;
  font-weight:600;
}

.about__zones{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:10px;
}

.zone{
  padding:7px 14px;
  border-radius:999px;
  background:#F1F4FF;
  color:#2E4FD7;
  font-weight:700;
  font-size:.95rem;
  line-height:1;
}

.zone--main{
  background:#2E4FD7;
  color:#FFFFFF;
}

.aboutCards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:22px;
}

.aboutCard{
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:8px;
  min-height: 170px;
}

.aboutCard__icon{
  width:44px;
  height:44px;
  border-radius:12px;
  background:#F5F7FB;
  border:1px solid #EAEAF0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.35rem;
}

.aboutCard h3{
  margin:0;
  font-size:1.15rem;
}

.aboutCard p{
  margin:0;
  color:#5A5A5A;
  font-weight:600;
}

.nosotros__features{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 22px;
}


/* =========================
   FAQ
========================= */
.faq{
  display:grid;
  gap:12px;
  max-width: 920px;
}

.faq__item{
  border:1px solid #EAEAF0;
  border-radius:16px;
  background:#fff;
  overflow:hidden;
}

.faq__q{
  list-style:none;
  cursor:pointer;
  padding:16px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  font-family:"Fredoka";
  font-weight:700;
  color:#1F4E79;
}

.faq__q::-webkit-details-marker{ display:none; }

.faq__icon{
  width:34px;
  height:34px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#F5F7FB;
  border:1px solid #EAEAF0;
  color:#2E4FD7;
  flex: 0 0 auto;
  transition: transform .15s ease;
}

.faq__a{
  padding: 0 18px 16px;
  color:#555;
  font-weight:600;
}

.faq__item[open] .faq__icon{
  transform: rotate(45deg);
}

/* =========================
   WHATSAPP FLOTANTE
========================= */
.wa-float{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 999;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 999px;
  background: #25D366;
  color: #fff;
  text-decoration: none;
  font-family: "Fredoka";
  font-weight: 700;
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
  transition: transform .15s ease, box-shadow .15s ease;
}

.wa-float:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 26px rgba(0,0,0,.22);
}

.wa-float__icon{
  width: 34px;
  height: 34px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 12px;
  background: rgba(255,255,255,.18);
}

@media (max-width: 520px){
  .wa-float__text{ display:none; }
  .wa-float{ padding: 12px; }
}

/* =========================
   PACKS
========================= */
.packs{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:24px;
  margin-top: 8px;
}

.pack{
  display:flex;
  flex-direction:column;
  gap:14px;
  position:relative;
}

.pack__list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:8px;
  font-weight:600;
  color:#4A4A4A;
}

.pack__list li{
  display:flex;
  gap:8px;
}

.pack--highlight{
  border:2px solid #FFD84D;
  box-shadow: 0 12px 26px rgba(0,0,0,.08);
  transform: translateY(-6px);
}

.pack__badge{
  position:absolute;
  top:-12px;
  right:16px;
  background:#FFD84D;
  color:#1F1F1F;
  font-family:"Fredoka";
  font-weight:700;
  padding:6px 12px;
  border-radius:999px;
  font-size:.85rem;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 900px){
  .nav{ display:none; }

  .hero{
    padding: 40px 0 48px;
  }

  .hero__grid{
    grid-template-columns: 1fr;
    gap: 26px;
  }

  .hero__image img{
    max-width: 520px;
  }

  .catalogo{ grid-template-columns: 1fr; }
  .aboutCards{ grid-template-columns: 1fr; }
  .packs{ grid-template-columns: 1fr; }
  .pack--highlight{ transform:none; }
}


/* responsive */
@media (max-width: 900px){
  .nosotros__features{
    grid-template-columns: 1fr;
  }
}
/* ===== CONTACTO ===== */
.contactCard{
  max-width: 520px;
  margin: 0 auto;
  text-align: center;
  padding: 28px;
}

.contactCard p{
  font-size: 1.05rem;
  font-weight: 600;
  margin-bottom: 18px;
}

/* ===== FOOTER ===== */
.footer{
  background:#F5F7FB;
  border-top:1px solid #EAEAF0;
  padding: 36px 0 0;
}

.footer__grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr .8fr;
  gap: 28px;
  align-items:start;
}

.footer__logo{
  height: 56px;
  width:auto;
  display:block;
  margin-bottom: 10px;
}

.footer__desc{
  margin:0;
  color:#4A4A4A;
  font-weight:600;
  max-width: 46ch;
}

.footer__title{
  font-size: 1.05rem;
  margin: 6px 0 12px;
  color:#1F4E79;
}

.footer__link{
  display:flex;
  align-items:center;
  gap:10px;
  color:#1F4E79;
  text-decoration:none;
  font-weight:700;
  padding: 8px 10px;
  border-radius: 12px;
  transition: background .15s ease, transform .15s ease, color .15s ease;
}

.footer__link:hover{
  background: rgba(46,79,215,.08);
  color:#2E4FD7;
  transform: translateY(-1px);
}

.footer__icon{
  width: 34px;
  height: 34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 12px;
  background: #FFFFFF;
  border: 1px solid #EAEAF0;
}

.footer__bottom{
  margin-top: 26px;
  border-top:1px solid #EAEAF0;
  background: rgba(255,255,255,.55);
}

.footer__bottomInner{
  padding: 14px 0;
  display:flex;
  justify-content:center;
  color:#5A5A5A;
  font-weight:700;
}

/* Responsive */
@media (max-width:900px){
  .footer__grid{
    grid-template-columns: 1fr;
  }
  .footer__desc{
    max-width: none;
  }
  .footer__bottomInner{
    justify-content:flex-start;
  }
}
.product{
  cursor:pointer;
}

.product:hover h3{
  text-decoration: underline;
}
