:root {
  --azul: #0056D2;
  --azul-escuro: #003C99;
  --preto: #1D1D1D;
  --cinza-claro: #F5F7FA;
  --cinza-medio: #E3E7EF;
  --branco: #FFFFFF;
  --radius: 12px;
  font-family: "DM Sans", sans-serif;
}

/* RESET BÁSICO */
* { box-sizing: border-box; margin: 0; padding: 0; }
body {
  background: var(--branco);
  color: var(--preto);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.5;
}

/* CONTAINER */
.container {
  width: 90%;
  max-width: 1140px;
  margin: 0 auto;
}

/* NAVBAR */
.navbar {
  background: var(--branco);
  border-bottom: 1px solid var(--cinza-medio);
  position: sticky;
  top: 0;
  z-index: 50;
}

nav { display: flex; align-items: center; justify-content: space-between; padding: .9rem 0; }

.logo img { height: 45px; display: block; }

/* MENU */
.menu { display: flex; gap: 1.25rem; align-items: center; }
.menu a { color: var(--azul); text-decoration: none; font-weight: 600; }
.menu a:hover { color: var(--azul-escuro); }

.btn-outline {
  padding: .45rem .9rem;
  border-radius: 999px;
  border: 2px solid var(--azul);
  color: var(--azul);
  font-weight: 700;
  text-decoration: none;
}

/* HAMBURGER */
.hamburger { display: none; background: none; border: 0; cursor: pointer; padding: .25rem; }
.hamburger span { display: block; width: 22px; height: 3px; background: var(--azul); margin: 4px 0; border-radius: 3px; }

/* HEADER HERO DA PÁGINA */
.comparativo-header {
  background: var(--cinza-claro);
  padding: 2.25rem 0;
  text-align: center;
  border-bottom: 1px solid var(--cinza-medio);
}

.comparativo-header h1 {
  margin-bottom: .25rem;
  font-size: 2rem;
  color: var(--preto);
  font-weight: 800;
}

.comparativo-header .lead {
  color: #4b5563;
  margin-top: .5rem;
  font-size: 1rem;
}

/* PLANOS TOPO (CARDS) */
.planos {
  padding: 2.25rem 0;
}

.planos-topo {
  display: flex;
  gap: 1.5rem;
  align-items: stretch;
  justify-content: center;
  margin-bottom: 1.75rem;
  flex-wrap: wrap;
}

.plano {
  background: var(--branco);
  border: 1px solid var(--cinza-medio);
  border-radius: var(--radius);
  padding: 1.6rem;
  width: 100%;
  max-width: 420px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.03);
  display: flex;
  flex-direction: column;
  gap: .8rem;
  text-align: left;
}

.plano.destaque {
  border: 2px solid var(--azul);
  transform: translateY(-6px);
}

.plano h2 {
  font-size: 1.4rem;
  margin-bottom: .25rem;
  color: var(--preto);
  font-weight: 800;
}

.plano .descricao { color: #555; font-size: .95rem; margin-bottom: .5rem; }

.preco {
  margin-top: .35rem;
  font-weight: 800;
  color: var(--azul);
  font-size: 1.6rem;
}

.preco .valor { font-size: 2.2rem; margin-right: .25rem; }
.preco .periodo { font-size: .9rem; color:#666; margin-left: .35rem; }

.extra { color: #444; font-size: .95rem; margin-bottom: .6rem; }

.cta-wrap { margin-top: auto; }
.btn-contratar {
  background: var(--azul);
  color: var(--branco);
  border: none;
  padding: .75rem 1rem;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 700;
}
.btn-contratar:hover { background: var(--azul-escuro); }

/* TABELA COMPARATIVA */
.comparativo-tabela { padding: 1.5rem 0 3.5rem; }

.table-wrap {
  overflow-x: auto;
  border-radius: 8px;
  background: var(--white, var(--branco));
  padding: .5rem;
  box-shadow: 0 6px 18px rgba(0,0,0,0.02);
}

.tabela-comparativa {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px; /* permite rolagem em telas pequenas */
}

.tabela-comparativa thead th {
  text-align: left;
  padding: .9rem 1rem;
  background: var(--cinza-medio);
  font-weight: 700;
  color: var(--preto);
  border-bottom: 1px solid rgba(0,0,0,0.05);
}

.tabela-comparativa td {
  padding: .9rem 1rem;
  border-bottom: 1px solid var(--cinza-medio);
  color: #333;
  vertical-align: middle;
}

.tabela-comparativa td.center { text-align: center; }

/* linhas de seção */
.secao {
  background: var(--cinza-claro);
  font-weight: 700;
  color: var(--preto);
  text-align: left;
  padding: .9rem 1rem;
}

/* INFO FINAL */
.info-final { margin-top: 1.25rem; }
.info-final a { color: var(--azul); text-decoration: none; font-weight: 700; }

/* RESPONSIVO */
@media (max-width: 980px) {
  .planos-topo { gap: 1rem; justify-content: center; }
  .plano { max-width: 420px; width: 48%; }
}

@media (max-width: 720px) {
  .menu { display: none; }
  .hamburger { display: inline-flex; }

  .plano { width: 100%; }
  .tabela-comparativa { min-width: 600px; }
}

@media (max-width: 480px) {
  .comparativo-header h1 { font-size: 1.4rem; }
  .comparativo-header .lead { font-size: .9rem; }
  .preco .valor { font-size: 1.6rem; }
}
