/* ====== Portal Prospera — mesma família visual dos sistemas (#11436c) ====== */
:root {
  --brand: #11436c;
  --brand-hover: #0d3656;
  --fundo: #f2f5f9;
  --carta: #ffffff;
  --texto: #24303e;
  --texto-suave: #64748b;
  --borda: #e2e8f0;
  --verde: #1e8e5a;
  --ambar: #b97324;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  background: var(--fundo);
  color: var(--texto);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ---- topo ---- */
.topo {
  background: var(--brand);
  text-align: center;
  padding: 46px 20px 38px;
}
.logo { width: 250px; max-width: 80%; filter: brightness(0) invert(1); }
.subtitulo {
  color: #cdd9ea; margin: 10px 0 0; font-size: 16px; letter-spacing: 2.5px;
  text-transform: uppercase;
}

/* ---- cards ---- */
.conteudo { flex: 1; max-width: 1020px; margin: -26px auto 40px; padding: 0 20px; width: 100%; }
.grade {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}
.cartao {
  background: var(--carta); border: 1px solid var(--borda); border-radius: 14px;
  padding: 24px; text-decoration: none; color: var(--texto);
  box-shadow: 0 2px 8px rgb(17 67 108 / 8%);
  display: flex; flex-direction: column; gap: 8px;
  transition: transform .15s, box-shadow .15s, border-color .15s;
}
.cartao:hover {
  transform: translateY(-3px);
  border-color: var(--brand);
  box-shadow: 0 8px 22px rgb(17 67 108 / 16%);
}
.cartao-cab { display: flex; justify-content: space-between; align-items: center; }
.icone { font-size: 30px; }
.cartao h2 { margin: 4px 0 0; font-size: 18.5px; color: var(--brand); }
.cartao p { margin: 0; color: var(--texto-suave); font-size: 14px; line-height: 1.55; flex: 1; }
.nota-cartao { font-size: 12px; color: var(--texto-suave); }
.nota-cartao code { background: #eef2f7; padding: 1px 5px; border-radius: 4px; font-size: 11px; }
.acessar { color: var(--brand); font-weight: 700; font-size: 14.5px; margin-top: 6px; }
.cartao-suave { opacity: .92; }

.selo {
  font-size: 11px; font-weight: 700; letter-spacing: .6px;
  padding: 3px 10px; border-radius: 999px; text-transform: uppercase;
}
.selo-nuvem { background: #e5f5ec; color: var(--verde); }
.selo-local { background: #fdf2e2; color: var(--ambar); }

/* ---- rodapé ---- */
.rodape {
  text-align: center; color: var(--texto-suave); font-size: 12.5px;
  padding: 18px 16px 26px;
}

@media (max-width: 640px) {
  .topo { padding: 34px 16px 30px; }
  .logo { width: 200px; }
  .conteudo { margin-top: -18px; }
}
