/* =========================================================
   HOME.CSS
   Owner: home/index runtime
   Scope: html[data-page="home"]
   Nota:
   - Aqui viven SOLO reglas propias del home.
   - NO mover aqui banner compartido ni tokens globales de botones.
========================================================= */

html[data-page="home"]{
  --home-max: 1100px;
  --home-pad: 18px;
  --home-gap: 14px;
}

html[data-page="home"] .container{
  max-width: var(--home-max);
  margin: 0 auto;
  padding: 14px;
  display: grid;
  gap: 12px;
}

@media (min-width: 768px){
  html[data-page="home"] .container{
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }

  html[data-page="home"] .container > .card:first-child{
    grid-column: 1 / -1;
  }

  html[data-page="home"] .container > .card:last-child{
    grid-column: 1 / -1;
  }
}

html[data-page="home"] .card{
  border-radius: 18px;
}

html[data-page="home"] .card h1{
  margin: 0 0 6px 0;
}

html[data-page="home"] .card h2{
  margin: 0 0 6px 0;
}

html[data-page="home"] .card p{
  margin: 10px 0;
}

html[data-page="home"] .card p + p{
  margin-top: var(--ma-gap-cta);
}

html[data-page="home"] .card a.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}

html[data-page="home"] .container > .card:first-child{
  padding-bottom: 10px;
  text-align: center;
}

html[data-page="home"] .container > .card:first-child h1{
  font-size: 24px;
  line-height: 1.15;
}

html[data-page="home"] .container > .card:first-child p{
  color: var(--muted);
  margin: 10px 0;
}

html[data-page="home"] a.btn{
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 14px;
}

html[data-page="home"] .container > .card:nth-child(2) h2,
html[data-page="home"] .container > .card:nth-child(3) h2{
  font-size: 18px;
  margin-bottom: 6px;
}

@media (min-width: 768px){
  html[data-page="home"] .container > .card:first-child p{
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
  }

  html[data-page="home"] .container > .card:first-child p a.btn{
    width: auto;
  }

  html[data-page="home"] .container > .card:nth-child(2),
  html[data-page="home"] .container > .card:nth-child(3){
    display: flex;
    flex-direction: column;
  }

  html[data-page="home"] .container > .card:nth-child(2) p:last-of-type,
  html[data-page="home"] .container > .card:nth-child(3) p:last-of-type{
    margin-top: auto;
  }
}

html[data-page="home"] .homeFooter{
  margin-top: 10px;
  padding: 10px 6px;
  text-align: center;
  opacity: .75;
}

html[data-page="home"] .homeLead{
  margin-top: 6px;
  margin-bottom: 10px;
}

html[data-page="home"] .homeNote{
  margin-top: 6px;
  margin-bottom: 10px;
  opacity: .9;
}

html[data-page="home"] .container > .card.homeCard h2{
  text-align: center;
}

html[data-page="home"] .container > .card.homeCard .homeLead,
html[data-page="home"] .container > .card.homeCard .homeNote{
  text-align: center;
}

html[data-page="home"] .container > .card.homeCard p{
  text-align: center;
  margin: 10px 0;
}

html[data-page="home"] .container > .card.homeCard .btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: min(420px, 100%);
}

html[data-page="home"] .waFloat{
  position: fixed;
  right: 16px;
  bottom: calc(16px + env(safe-area-inset-bottom));
  z-index: var(--z-fab, 240);
  background: var(--whatsapp);
  color: var(--card);
  border: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  box-shadow: 0 12px 28px rgba(0,0,0,.22);
  transition: transform .15s ease, filter .15s ease, box-shadow .15s ease;
  will-change: transform;
  line-height: 1;
}

html[data-page="home"] .waFloat:hover{
  transform: translateY(-2px);
  filter: brightness(.95);
}

html[data-page="home"] .waFloat:active{
  transform: scale(.97);
}

@media (max-width: 767px){
  html[data-page="home"] .waFloat{
    width: auto;
    height: auto;
    padding: 10px 14px;
    border-radius: 999px;
    font-size: 14px;
    gap: 8px;
    white-space: nowrap;
  }
}

@media (min-width: 768px){
  html[data-page="home"] .waFloat{
    width: auto;
    height: auto;
    padding: 10px 14px;
    border-radius: 999px;
    font-size: 14px;
    gap: 8px;
  }
}
