/* ============================================================
   SIMULE SUAS CONTAS — Estilos
   ============================================================ */

/* ---- Reset e base ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --azul-principal:  #0047AB;
  --azul-escuro:     #003380;
  --azul-claro:      #E8F0FE;
  --azul-borda:      #B3C7F0;
  --verde-resultado: #1B5E20;
  --verde-bg:        #E8F5E9;
  --verde-borda:     #A5D6A7;
  --cinza-bg:        #F4F6F9;
  --cinza-card:      #FFFFFF;
  --cinza-borda:     #DDE3EC;
  --texto-principal: #1A1A2E;
  --texto-secundario:#4A5568;
  --texto-dica:      #718096;
  --vermelho:        #C62828;
  --vermelho-bg:     #FFEBEE;
  --amarelo-aviso:   #7B5800;
  --amarelo-bg:      #FFF8E1;
  --amarelo-borda:   #FFE082;
  --sombra-suave:    0 2px 8px rgba(0,71,171,0.08);
  --sombra-hover:    0 6px 20px rgba(0,71,171,0.16);
  --raio:            12px;
  --raio-pequeno:    8px;
  --transicao:       0.22s ease;
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Segoe UI', system-ui, -apple-system, Arial, sans-serif;
  background: var(--cinza-bg);
  color: var(--texto-principal);
  line-height: 1.6;
  min-height: 100vh;
}

/* ---- Topo ---- */
.topo {
  background: linear-gradient(135deg, var(--azul-escuro) 0%, var(--azul-principal) 100%);
  color: #fff;
  text-align: center;
  padding: 40px 24px 36px;
}

.topo-icone {
  font-size: 2.6rem;
  margin-bottom: 10px;
}

.topo h1 {
  font-size: clamp(1.6rem, 4vw, 2.2rem);
  font-weight: 700;
  letter-spacing: -0.5px;
  margin-bottom: 8px;
}

.topo p {
  font-size: 1.05rem;
  opacity: 0.88;
  max-width: 540px;
  margin: 0 auto;
}

/* ---- Container principal ---- */
.container {
  max-width: 720px;
  margin: 0 auto;
  padding: 32px 16px 60px;
}

/* ---- Tutorial ---- */
.tutorial {
  background: var(--azul-claro);
  border: 1px solid var(--azul-borda);
  border-radius: var(--raio);
  padding: 20px 24px;
  margin-bottom: 28px;
}

.tutorial h2 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.tutorial ol {
  padding-left: 18px;
  color: var(--texto-secundario);
  font-size: 0.93rem;
}

.tutorial ol li { margin-bottom: 4px; }

/* ---- Seções do formulário ---- */
.secao {
  background: var(--cinza-card);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--raio);
  padding: 24px;
  margin-bottom: 20px;
  box-shadow: var(--sombra-suave);
  transition: opacity var(--transicao), transform var(--transicao);
}

.secao.oculto {
  display: none;
}

.secao.entrada {
  opacity: 0;
  transform: translateY(12px);
}

.secao.visivel {
  opacity: 1;
  transform: translateY(0);
}

.secao-titulo {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.secao-titulo .passo {
  background: var(--azul-principal);
  color: #fff;
  border-radius: 50%;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.82rem;
  font-weight: 700;
  flex-shrink: 0;
}

/* ---- Cards de seleção ---- */
.grade-cards {
  display: grid;
  gap: 12px;
}

.grade-2 { grid-template-columns: repeat(2, 1fr); }
.grade-4 { grid-template-columns: repeat(2, 1fr); }

@media (min-width: 540px) {
  .grade-4 { grid-template-columns: repeat(4, 1fr); }
}

.card-sel {
  border: 2px solid var(--cinza-borda);
  border-radius: var(--raio-pequeno);
  padding: 16px 12px;
  text-align: center;
  cursor: pointer;
  transition: border-color var(--transicao), background var(--transicao),
              box-shadow var(--transicao), transform var(--transicao);
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.card-sel:hover {
  border-color: var(--azul-principal);
  background: var(--azul-claro);
  box-shadow: var(--sombra-hover);
  transform: translateY(-2px);
}

.card-sel:active { transform: translateY(0); }

.card-sel.selecionado {
  border-color: var(--azul-principal);
  background: var(--azul-claro);
  box-shadow: 0 0 0 3px rgba(0,71,171,0.18);
}

.card-sel .icone {
  font-size: 1.8rem;
  display: block;
  margin-bottom: 6px;
}

.card-sel .nome {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--texto-principal);
  display: block;
}

.card-sel .detalhe {
  font-size: 0.78rem;
  color: var(--texto-dica);
  display: block;
  margin-top: 2px;
}

/* Prestadora — cards maiores */
.card-prestadora { padding: 20px 16px; }
.card-prestadora .nome { font-size: 1.05rem; }
.card-prestadora .detalhe { font-size: 0.82rem; }

/* Logos das prestadoras */
.logo-prestadora {
  display: block;
  max-width: 100%;
  width: 180px;
  height: 72px;
  object-fit: contain;
  margin: 0 auto 8px;
}

.logo-copasa {
  border-radius: 8px;
}

.logo-samotracia {
  /* logo em fundo branco — sem borda arredondada extra */
}

/* ---- Campo de consumo ---- */
.campo-consumo {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.campo-consumo input {
  flex: 1;
  min-width: 150px;
  border: 2px solid var(--cinza-borda);
  border-radius: var(--raio-pequeno);
  padding: 14px 16px;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--texto-principal);
  outline: none;
  transition: border-color var(--transicao);
  -moz-appearance: textfield;
}

.campo-consumo input::-webkit-outer-spin-button,
.campo-consumo input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.campo-consumo input:focus {
  border-color: var(--azul-principal);
  box-shadow: 0 0 0 3px rgba(0,71,171,0.14);
}

.campo-consumo .unidade {
  font-size: 1.1rem;
  color: var(--texto-secundario);
  font-weight: 600;
  white-space: nowrap;
}

/* ---- Bloco economias ---- */
.bloco-economias {
  margin-top: 16px;
  transition: opacity var(--transicao), max-height 0.3s ease;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
}

.bloco-economias.visivel {
  max-height: 120px;
  opacity: 1;
}

.bloco-economias.oculto {
  display: none;
}

.label-campo {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--texto-secundario);
  margin-bottom: 8px;
}

.campo-numero {
  border: 2px solid var(--cinza-borda);
  border-radius: var(--raio-pequeno);
  padding: 12px 16px;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--texto-principal);
  outline: none;
  width: 140px;
  transition: border-color var(--transicao);
  -moz-appearance: textfield;
}

.campo-numero::-webkit-outer-spin-button,
.campo-numero::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.campo-numero:focus {
  border-color: var(--azul-principal);
  box-shadow: 0 0 0 3px rgba(0,71,171,0.14);
}

/* ---- Mensagens de erro ---- */
.msg-erro {
  color: var(--vermelho);
  background: var(--vermelho-bg);
  border-radius: var(--raio-pequeno);
  padding: 8px 12px;
  font-size: 0.87rem;
  font-weight: 500;
  margin-top: 10px;
}

.msg-erro.oculto { display: none; }

/* ---- Botão principal ---- */
.btn-principal {
  display: block;
  width: 100%;
  background: linear-gradient(135deg, var(--azul-principal) 0%, var(--azul-escuro) 100%);
  color: #fff;
  border: none;
  border-radius: var(--raio);
  padding: 18px 24px;
  font-size: 1.15rem;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.3px;
  transition: box-shadow var(--transicao), transform var(--transicao), background var(--transicao);
  margin-top: 8px;
  box-shadow: 0 4px 14px rgba(0,71,171,0.3);
}

.btn-principal:hover {
  box-shadow: 0 8px 24px rgba(0,71,171,0.4);
  transform: translateY(-2px);
}

.btn-principal:active { transform: translateY(0); }

/* ---- Seção de resultado ---- */
.secao-resultado {
  background: var(--verde-bg);
  border: 1px solid var(--verde-borda);
  border-radius: var(--raio);
  padding: 28px;
  margin-bottom: 20px;
  box-shadow: 0 4px 16px rgba(27,94,32,0.10);
  transition: opacity var(--transicao), transform var(--transicao);
}

.resultado-titulo {
  font-size: 1rem;
  font-weight: 700;
  color: var(--verde-resultado);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.resultado-titulo::before {
  content: "✓";
  background: var(--verde-resultado);
  color: #fff;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  flex-shrink: 0;
}

.resultado-grade {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 20px;
}

@media (max-width: 460px) {
  .resultado-grade { grid-template-columns: 1fr; }
}

.resultado-item {
  background: #fff;
  border-radius: var(--raio-pequeno);
  padding: 12px 16px;
  border: 1px solid var(--verde-borda);
}

.resultado-item .label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--texto-dica);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  display: block;
  margin-bottom: 4px;
}

.resultado-item .valor {
  font-size: 0.97rem;
  font-weight: 600;
  color: var(--texto-principal);
}

.resultado-total {
  background: var(--verde-resultado);
  color: #fff;
  border-radius: var(--raio);
  padding: 20px 24px;
  text-align: center;
  margin-bottom: 20px;
}

.resultado-total .label-total {
  font-size: 0.9rem;
  opacity: 0.88;
  margin-bottom: 6px;
}

.resultado-total .valor-total {
  font-size: clamp(1.8rem, 5vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -1px;
}

/* ---- Aviso de estimativa ---- */
.aviso-estimativa {
  background: var(--amarelo-bg);
  border: 1px solid var(--amarelo-borda);
  border-radius: var(--raio-pequeno);
  padding: 12px 16px;
  font-size: 0.83rem;
  color: var(--amarelo-aviso);
  line-height: 1.5;
  margin-bottom: 16px;
}

/* ---- Botão nova simulação ---- */
.btn-secundario {
  display: block;
  width: 100%;
  background: #fff;
  color: var(--azul-principal);
  border: 2px solid var(--azul-principal);
  border-radius: var(--raio);
  padding: 14px 24px;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: background var(--transicao), color var(--transicao);
}

.btn-secundario:hover {
  background: var(--azul-claro);
}

/* ---- Bloco regulatório ---- */
.bloco-regulatorio {
  background: var(--cinza-card);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--raio);
  padding: 24px;
  margin-top: 8px;
  box-shadow: var(--sombra-suave);
}

.bloco-regulatorio h2 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--texto-principal);
  margin-bottom: 10px;
}

.bloco-regulatorio p {
  font-size: 0.88rem;
  color: var(--texto-secundario);
  margin-bottom: 12px;
  line-height: 1.6;
}

.bloco-regulatorio a {
  color: var(--azul-principal);
  font-weight: 600;
  text-decoration: none;
  word-break: break-all;
}

.bloco-regulatorio a:hover { text-decoration: underline; }

/* ---- Rodapé ---- */
.rodape {
  text-align: center;
  padding: 24px 16px;
  font-size: 0.82rem;
  color: var(--texto-dica);
  border-top: 1px solid var(--cinza-borda);
  margin-top: 12px;
}

/* ---- Responsividade ---- */
@media (max-width: 480px) {
  .topo { padding: 28px 16px 24px; }
  .secao { padding: 18px 16px; }
  .btn-principal { font-size: 1.05rem; padding: 16px; }
  .resultado-total .valor-total { font-size: 1.9rem; }
  .grade-2 { grid-template-columns: 1fr 1fr; }
}
