*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Poppins', sans-serif; color: #525461; background: #fff; overflow-x: hidden; }

/* ── UTILS ── */
.badge {
  display: inline-block;
  background: #dbe8f7;
  color: #1a47c8;
  font-size: 12px;
  font-weight: 600;
  padding: 6px 20px;
  border-radius: 16px;
  margin-bottom: 18px;
}
.section-title { font-size: 36px; font-weight: 700; color: #0d2e8a; line-height: 1.34; margin-bottom: 16px; }
.section-desc { font-size: 15px; color: #525461; line-height: 1.7; }
.feature-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px 40px; margin-top: 32px; }
.feature-item .feature-title { font-size: 14px; font-weight: 600; color: #0d2e8a; margin-bottom: 4px; }
.feature-item .feature-desc { font-size: 13px; color: #525461; line-height: 1.6; }

/* ── NAVBAR ── */
nav {
  background: #0d2e8a;
  position: sticky; top: 0; z-index: 100;
  padding: 16px 80px;
  display: flex; align-items: center; justify-content: space-between;
}
nav .logo { font-size: 18px; font-weight: 700; color: #fff; }
nav ul { list-style: none; display: flex; gap: 32px; }
nav ul li a { color: #ccdbf5; text-decoration: none; font-size: 14px; transition: color .2s; }
nav ul li a:hover { color: #fff; }
nav .nav-cta {
  background: #c8192e; color: #fff; font-size: 14px; font-weight: 600;
  padding: 10px 22px; border-radius: 22px; text-decoration: none; transition: opacity .2s;
}
nav .nav-cta:hover { opacity: .88; }

/* ── HERO ── */
#hero { background: #0d2e8a; padding: 80px 80px 100px; }
.hero-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: 560px 1fr; gap: 60px; align-items: center;
}
.hero-badge {
  display: inline-block; background: #c8192e; color: #fff;
  font-size: 14px; font-weight: 700; padding: 10px 24px;
  border-radius: 22px; margin-bottom: 28px; letter-spacing: .3px;
}
.hero-title { font-size: 46px; font-weight: 700; color: #fff; line-height: 1.18; margin-bottom: 22px; }
.hero-desc { font-size: 16px; color: #ccdbf5; line-height: 1.7; margin-bottom: 36px; max-width: 520px; }
.btn-red {
  display: inline-flex; align-items: center; gap: 10px;
  background: #c8192e; color: #fff; font-size: 16px; font-weight: 700;
  padding: 16px 32px; border-radius: 29px; text-decoration: none;
  transition: opacity .2s; margin-bottom: 28px;
}
.btn-red:hover { opacity: .9; }
.btn-red img { width: 28px; height: 28px; }
.hero-tags { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.hero-tag {
  background: #0f2e7a; color: #ccdbf5; font-size: 13px;
  padding: 12px 18px; border-radius: 12px; display: flex; align-items: center; gap: 8px;
}
.hero-images {
  display: grid; grid-template-columns: 1fr 1fr;
  grid-template-rows: 272px 276px; gap: 14px;
}
.hero-images img { width: 100%; height: 100%; object-fit: cover; border-radius: 16px; }

/* ── SOBRE ── */
#sobre { background: #f8f8fc; padding: 80px; }
.sobre-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: 548px 1fr; gap: 90px; align-items: center;
}
.sobre-img { width: 100%; height: 580px; object-fit: cover; border-radius: 20px; }

/* ── DIFERENCIAIS ── */
#diferenciais { background: #fff; padding: 60px 80px 80px; }
.diferenciais-header { text-align: center; margin-bottom: 50px; }
.cards-grid { max-width: 1440px; margin: 0 auto; display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.card { background: #f6f8fc; border-radius: 18px; overflow: hidden; }
.card-img { width: 100%; height: 198px; object-fit: cover; }
.card-body { padding: 20px 18px 28px; }
.card-icon { font-size: 22px; margin-bottom: 8px; display: block; }
.card-title { font-size: 14px; font-weight: 600; color: #0d2e8a; margin-bottom: 8px; }
.card-desc { font-size: 13px; color: #525461; line-height: 1.6; margin-bottom: 20px; }
.card-link {
  display: inline-block; background: #dbe8f7; color: #1a47c8;
  font-size: 14px; font-weight: 700; padding: 8px 24px; border-radius: 19px; text-decoration: none;
}

/* ── METODOLOGIA ── */
#metodologia { background: #f8f8fc; padding: 80px; }
.metodologia-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 632px; gap: 90px; align-items: center;
}
.metodologia-img { width: 100%; height: 610px; object-fit: cover; border-radius: 20px; }

/* ── ATIVIDADES ── */
#atividades { background: #fff; padding: 80px; }
.atividades-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: 548px 1fr; gap: 90px; align-items: center;
}
.atividades-img { width: 100%; height: 580px; object-fit: cover; border-radius: 20px; }

/* ── ESPAÇOS ── */
#espacos { background: #f8f8fc; padding: 80px; }
.espacos-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 632px; gap: 90px; align-items: start;
}
.btn-primary {
  display: inline-block; background: #1a47c8; color: #fff;
  font-size: 17px; font-weight: 700; padding: 18px 48px;
  border-radius: 32px; text-decoration: none; margin-top: 32px; transition: opacity .2s;
}
.btn-primary:hover { opacity: .9; }
.espacos-images { display: flex; flex-direction: column; gap: 16px; }
.espaco-img-wrap { position: relative; border-radius: 16px; overflow: hidden; }
.espaco-img-wrap img { width: 100%; height: 210px; object-fit: cover; display: block; }
.espaco-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: rgba(5,18,56,.85); color: #fff;
  font-size: 14px; font-weight: 600; padding: 12px 20px;
}

/* ── DEPOIMENTOS ── */
#depoimentos { background: #fff; padding: 70px 80px 80px; }
.depoimentos-header { text-align: center; margin-bottom: 50px; }
.depoimentos-grid {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(4,1fr); gap: 24px;
}
.depo-card { background: #f6f8fc; border-radius: 18px; padding: 24px 20px; }
.depo-header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.depo-avatar { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; }
.depo-name { font-size: 14px; font-weight: 600; color: #0d2e8a; }
.depo-role { font-size: 12px; color: #525461; }
.depo-stars { color: #f5a623; font-size: 14px; margin-bottom: 10px; }
.depo-text { font-size: 13px; color: #525461; line-height: 1.6; margin-bottom: 16px; }
.depo-verified { background: #f0fcf5; color: #12ba54; font-size: 11px; font-weight: 600; padding: 8px 12px; border-radius: 8px; }

/* ── FAQ ── */
#faq { background: #f8f8fc; padding: 80px; }
.faq-inner { max-width: 1440px; margin: 0 auto; }
.faq-inner .section-title { font-size: 42px; margin-bottom: 40px; }
.faq-list { display: flex; flex-direction: column; gap: 12px; }
.faq-item { border: 2px solid #e6eaf4; border-radius: 20px; overflow: hidden; }
.faq-question {
  background: #eef2fb; padding: 28px 32px;
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer;
}
.faq-question-text { font-size: 18px; font-weight: 700; color: #0d2e8a; }
.faq-toggle {
  width: 44px; height: 44px; border-radius: 50%;
  background: #1a47c8; color: #fff; font-size: 24px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-left: 24px; transition: transform .25s;
}
.faq-answer { padding: 24px 32px; font-size: 16px; color: #525461; line-height: 1.7; }
.faq-item.open .faq-toggle { transform: rotate(45deg); background: #c8192e; }


/* ── FALE CONOSCO ── */
#contato { background: #0d2e8a; padding: 80px; }
.contato-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 760px; gap: 80px; align-items: center;
}
.contato-left .badge { background: #dbe8f7; color: #1a47c8; }
.contato-title { font-size: 48px; font-weight: 700; color: #fff; line-height: 1.2; margin-bottom: 20px; }
.contato-desc { font-size: 16px; color: #e6e6e6; line-height: 1.7; margin-bottom: 36px; max-width: 600px; }
.btn-whatsapp {
  display: inline-flex; align-items: center; gap: 10px;
  background: #12ba54; color: #fff; font-size: 16px; font-weight: 600;
  padding: 18px 36px; border-radius: 10px; text-decoration: none; margin-bottom: 18px; transition: opacity .2s;
}
.btn-whatsapp:hover { opacity: .9; }
.contato-phone { font-size: 14px; color: #ccc; }
.contato-img { width: 100%; height: 520px; object-fit: cover; border-radius: 16px; }

/* ── FOOTER ── */
footer { background: #091c54; padding: 50px 80px 30px; }
.footer-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 60px;
  padding-bottom: 40px; border-bottom: 1px solid #1f386b; margin-bottom: 24px;
}
.footer-brand-name { font-size: 22px; font-weight: 700; color: #fff; margin-bottom: 8px; }
.footer-brand-tagline { font-size: 14px; color: #ccdbf5; margin-bottom: 24px; }
.footer-address { font-size: 13px; color: #adc7eb; line-height: 1.8; border-left: 2px solid #1a4085; padding-left: 16px; }
.footer-links-title { font-size: 13px; color: #ccdbf5; line-height: 1.8; margin-bottom: 12px; }
.footer-links-sub { font-size: 13px; color: #8ca6cc; line-height: 1.8; }
.footer-social { font-size: 13px; color: #ccdbf5; line-height: 1.8; }
.footer-copy { max-width: 1440px; margin: 0 auto; font-size: 12px; color: #617a9e; }

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .hero-inner, .sobre-inner, .metodologia-inner, .atividades-inner,
  .espacos-inner, .contato-inner { grid-template-columns: 1fr; }
  .cards-grid, .depoimentos-grid { grid-template-columns: repeat(2,1fr); }
  .footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 700px) {
  nav, #hero, #sobre, #diferenciais, #metodologia, #atividades,
  #espacos, #depoimentos, #faq, #contato, footer { padding-left: 24px; padding-right: 24px; }
  nav ul { display: none; }
  .hero-title { font-size: 32px; }
  .section-title { font-size: 26px !important; }
  .cards-grid, .depoimentos-grid { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; }
}
