/* ============================================================
   ECO-BIM · ABellconta — Site de divulgação
   Estilos específicos da landing (complementa css/styles.css)
   ============================================================ */

/* Header CTA extra */
.nav-cta {
  display: inline-flex; align-items: center; gap: 8px; padding: 9px 18px;
  border-radius: var(--raio-sm); background: var(--vermelho); color: #fff;
  font-size: .9rem; font-weight: 700; box-shadow: var(--sombra-forte); transition: var(--transicao);
}
.nav-cta:hover { background: var(--vermelho-escuro); transform: translateY(-1px); }
.nav-cta svg { width: 16px; height: 16px; }

/* Suaviza o scroll com header sticky */
section[id] { scroll-margin-top: 84px; }

/* ---------------- Hero (versão divulgação) ---------------- */
.hero-visual .hv-caption {
  margin-top: 16px; font-size: .78rem; color: var(--cinza-texto); text-align: center;
}
.hero .trust {
  display: flex; align-items: center; gap: 18px; margin-top: 26px; flex-wrap: wrap;
  color: var(--cinza-texto); font-size: .86rem;
}
.hero .trust b { color: var(--preto); }
.hero .trust .sep { width: 1px; height: 20px; background: var(--cinza-borda); }

/* ---------------- Sobre (2 colunas) ---------------- */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.about-grid h2 { font-size: 2rem; margin-bottom: 16px; }
.about-grid p { color: var(--cinza-texto); margin-bottom: 14px; line-height: 1.7; }
.check-list { list-style: none; margin-top: 18px; display: grid; gap: 12px; }
.check-list li { display: flex; gap: 11px; align-items: flex-start; font-size: .95rem; }
.check-list .ck {
  flex: none; width: 24px; height: 24px; border-radius: 7px; margin-top: 1px;
  background: var(--vermelho-suave); color: var(--vermelho); display: grid; place-items: center;
}
.check-list .ck svg { width: 15px; height: 15px; }
.about-visual {
  background: var(--branco); border: 1px solid var(--cinza-borda); border-radius: 20px;
  box-shadow: var(--sombra); padding: 30px; position: relative; overflow: hidden;
}
.about-visual::before {
  content: ""; position: absolute; top: -80px; left: -80px; width: 220px; height: 220px;
  background: radial-gradient(circle, var(--vermelho-suave-2), transparent 70%); z-index: 0;
}
.about-visual > * { position: relative; z-index: 1; }
.donut-wrap { display: grid; grid-template-columns: auto 1fr; gap: 24px; align-items: center; }
.donut { width: 150px; height: 150px; position: relative; }
.donut svg { transform: rotate(-90deg); }
.donut .mid { position: absolute; inset: 0; display: grid; place-items: center; text-align: center; }
.donut .mid b { font-size: 1.6rem; font-weight: 800; color: var(--preto); line-height: 1; }
.donut .mid small { font-size: .68rem; color: var(--cinza-texto); }
.legend { display: grid; gap: 10px; }
.legend .li { display: flex; align-items: center; gap: 10px; font-size: .86rem; }
.legend .sw { width: 12px; height: 12px; border-radius: 4px; flex: none; }
.legend .pc { margin-left: auto; font-weight: 700; }

/* ---------------- Como funciona (passos) ---------------- */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; counter-reset: step; }
.step {
  background: var(--branco); border: 1px solid var(--cinza-borda); border-radius: var(--raio);
  padding: 28px 24px; position: relative; transition: var(--transicao);
}
.step:hover { box-shadow: var(--sombra); transform: translateY(-4px); border-top: 3px solid var(--vermelho); }
.step .n {
  width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--vermelho), var(--vermelho-escuro)); color: #fff;
  font-weight: 800; font-size: 1.15rem; margin-bottom: 16px; box-shadow: var(--sombra-forte);
}
.step h3 { font-size: 1.1rem; margin-bottom: 7px; }
.step p { color: var(--cinza-texto); font-size: .9rem; }

/* ---------------- Materiais em destaque ---------------- */
.mat-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.mat-card {
  background: var(--branco); border: 1px solid var(--cinza-borda); border-radius: var(--raio);
  padding: 22px; transition: var(--transicao);
}
.mat-card:hover { box-shadow: var(--sombra); transform: translateY(-3px); border-color: var(--vermelho-suave-2); }
.mat-card .top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.mat-card .cat { font-size: .7rem; padding: 3px 9px; border-radius: 999px; background: var(--cinza-claro); color: var(--cinza-texto); font-weight: 700; }
.mat-card .score { font-weight: 800; color: #fff; padding: 3px 10px; border-radius: 999px; font-size: .78rem; }
.mat-card h4 { font-size: 1.02rem; margin-bottom: 12px; }
.mat-card .rows { display: grid; gap: 7px; }
.mat-card .r { display: flex; justify-content: space-between; font-size: .82rem; color: var(--cinza-texto); }
.mat-card .r b { color: var(--preto); font-weight: 700; }

/* ---------------- ODS ---------------- */
.ods-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.ods {
  background: var(--branco); border: 1px solid var(--cinza-borda); border-radius: var(--raio);
  padding: 24px; text-align: center; transition: var(--transicao);
}
.ods:hover { box-shadow: var(--sombra); transform: translateY(-3px); }
.ods .num {
  width: 54px; height: 54px; border-radius: 14px; margin: 0 auto 14px; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--vermelho), var(--vermelho-escuro)); color: #fff;
  font-weight: 800; font-size: 1.4rem; box-shadow: var(--sombra-forte);
}
.ods h4 { font-size: 1rem; margin-bottom: 5px; }
.ods p { font-size: .85rem; color: var(--cinza-texto); }

/* ---------------- Faixa CTA ---------------- */
.cta-band {
  background: linear-gradient(135deg, var(--vermelho), var(--vermelho-escuro));
  border-radius: 22px; padding: 54px 40px; text-align: center; color: #fff;
  position: relative; overflow: hidden; box-shadow: var(--sombra-forte);
}
.cta-band::before {
  content: ""; position: absolute; top: -100px; right: -60px; width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(255,255,255,.16), transparent 70%);
}
.cta-band > * { position: relative; z-index: 1; }
.cta-band h2 { font-size: 2.1rem; margin-bottom: 12px; }
.cta-band p { font-size: 1.08rem; opacity: .92; max-width: 560px; margin: 0 auto 26px; }
.cta-band .btn-white { background: #fff; color: var(--vermelho); box-shadow: 0 8px 30px rgba(0,0,0,.2); }
.cta-band .btn-white:hover { transform: translateY(-2px); background: #fff; }
.cta-band .btn-outline { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.6); }
.cta-band .btn-outline:hover { border-color: #fff; background: rgba(255,255,255,.1); }

/* ---------------- Contactos ---------------- */
.contact-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 40px; align-items: start; }
.contact-info h3 { font-size: 1.5rem; margin-bottom: 12px; }
.contact-info p { color: var(--cinza-texto); margin-bottom: 24px; line-height: 1.7; }
.contact-item { display: flex; gap: 14px; align-items: center; margin-bottom: 18px; }
.contact-item .ic {
  flex: none; width: 44px; height: 44px; border-radius: 12px; background: var(--vermelho-suave);
  color: var(--vermelho); display: grid; place-items: center;
}
.contact-item .ic svg { width: 22px; height: 22px; }
.contact-item .tx small { display: block; font-size: .76rem; color: var(--cinza-texto); text-transform: uppercase; letter-spacing: .06em; }
.contact-item .tx b { font-size: .98rem; }
.contact-item a.tx-link { color: var(--preto); }
.contact-item a.tx-link:hover { color: var(--vermelho); }

.contact-form {
  background: var(--branco); border: 1px solid var(--cinza-borda); border-radius: var(--raio);
  box-shadow: var(--sombra); padding: 30px;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contact-form .field { margin-bottom: 16px; }
.contact-form label { display: block; font-size: .84rem; font-weight: 600; margin-bottom: 6px; }
.contact-form label .req { color: var(--vermelho); }
.contact-form input, .contact-form select, .contact-form textarea {
  width: 100%; padding: 12px 14px; border: 1.5px solid var(--cinza-borda); border-radius: var(--raio-sm);
  font-size: .93rem; background: var(--branco); color: var(--preto); transition: var(--transicao);
}
.contact-form textarea { resize: vertical; min-height: 120px; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus {
  outline: none; border-color: var(--vermelho); box-shadow: 0 0 0 3px var(--vermelho-suave);
}
.contact-form .btn-primary { width: 100%; justify-content: center; }
.form-note { font-size: .78rem; color: var(--cinza-texto); margin-top: 12px; text-align: center; }
.form-msg { margin-top: 14px; padding: 12px 14px; border-radius: var(--raio-sm); font-size: .88rem; font-weight: 600; display: none; }
.form-msg.ok { display: block; background: #e8f7ee; color: var(--verde); border: 1px solid #bfe6cd; }
.form-msg.err { display: block; background: var(--vermelho-suave); color: var(--vermelho-escuro); border: 1px solid var(--vermelho-suave-2); }

/* ---------------- Responsivo ---------------- */
@media (max-width: 980px) {
  .about-grid, .contact-grid { grid-template-columns: 1fr; }
  .steps, .mat-cards, .ods-grid { grid-template-columns: repeat(2, 1fr); }
  .about-grid { gap: 32px; }
}
@media (max-width: 720px) {
  .nav-cta { display: none; }
  .nav-links.open .nav-cta { display: inline-flex; justify-content: center; }
  .steps, .mat-cards, .ods-grid, .form-row { grid-template-columns: 1fr; }
  .cta-band { padding: 40px 24px; }
  .donut-wrap { grid-template-columns: 1fr; justify-items: center; text-align: center; }
}
