/* assets/css/home.css */

/* HERO */
.hero-home{
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding-top: 90px; /* compensa header fixo */
  background: var(--gradient-hero);
  overflow: hidden;
}

.hero-bg{ position:absolute; inset:0; z-index:1; }
.floating-elements{ position:absolute; inset:0; }
.floating-element{
  position:absolute;
  width: 120px; height: 120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,102,0,.14) 0%, transparent 70%);
  animation: float 7s ease-in-out infinite;
}
.floating-element:nth-child(1){ top: 18%; left: 8%; }
.floating-element:nth-child(2){ top: 55%; right: 12%; animation-delay: 1.5s; }
.floating-element:nth-child(3){ bottom: 12%; left: 22%; animation-delay: 3s; }

@keyframes float{
  0%,100%{ transform: translateY(0) rotate(0); }
  50%{ transform: translateY(-18px) rotate(180deg); }
}

.hero-grid{
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.25fr .85fr;
  gap: 2.5rem;
  align-items: start;
  padding: 2rem 0;
}

.hero-left{ color: var(--white); }

.hero-title{
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  line-height: 1.1;
  margin: 1rem 0;
}

.hero-subtitle{
  opacity: .92;
  max-width: 60ch;
}

.hero-points{
  margin: 1.25rem 0 1.5rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}

.point{
  padding: .75rem .85rem;
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  font-weight: 600;
  font-size: .95rem;
}

.hero-cta{
  display:flex;
  gap: .75rem;
  flex-wrap: wrap;
  margin-top: .5rem;
}

.hero-note{
  margin-top: 1rem;
  opacity: .85;
  font-size: .95rem;
}

/* CARD DA DIREITA */
.hero-card{
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(12px);
  border-radius: 16px;
  padding: 1.5rem;
  color: var(--white);
  box-shadow: var(--shadow-lg);
}

.hero-card-title{ margin-bottom: .75rem; }

.hero-list{
  list-style: none;
  display:grid;
  gap: .4rem;
  opacity: .92;
}

.hero-card-btn{
  width: 100%;
  margin-top: 1rem;
}

.hero-card-mini{
  margin-top: .75rem;
  opacity: .8;
  font-size: .9rem;
}

/* SEÇÕES */
.section{
  padding: 4rem 0;
  background: var(--white);
}

.section.light{
  background: linear-gradient(135deg, var(--gray-100) 0%, var(--white) 100%);
}

.section-title{
  text-align:center;
  margin-bottom: 2rem;
}

/* CARDS 3 COLUNAS */
.cards-3{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1rem;
}

.info-card{
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: 14px;
  padding: 1.25rem;
  box-shadow: var(--shadow-md);
}

.info-card p{
  color: var(--gray-600);
  margin-top: .5rem;
}

/* PASSOS */
.steps{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1rem;
}

.step{
  border-radius: 14px;
  border: 1px solid var(--gray-200);
  padding: 1.25rem;
  box-shadow: var(--shadow-md);
  background: var(--white);
}

.step-number{
  width: 40px; height: 40px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 12px;
  background: var(--gradient-primary);
  color: var(--white);
  font-weight: 900;
  margin-bottom: .75rem;
}

.step-text{
  color: var(--gray-700);
  font-weight: 600;
}

/* CTA STRIP */
.cta-strip{
  margin-top: 1.5rem;
  padding: 1rem 1.25rem;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--gray-100) 0%, var(--white) 100%);
  border: 1px solid var(--gray-200);
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.cta-strip-text{
  color: var(--gray-800);
  font-weight: 600;
}

/* RESPONSIVO */
@media (max-width: 900px){
  .hero-grid{ grid-template-columns: 1fr; }
  .hero-points{ grid-template-columns: 1fr; }

  .cards-3{ grid-template-columns: 1fr; }
  .steps{ grid-template-columns: 1fr; }
}
