  /* ============================================================
    1. LAYOUT GERAL E ESTRUTURA BÁSICA
    ============================================================ */

  body {
    font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
    margin: 0;
    padding: 0;
    background-color: #003366;
    color: #fff;
    text-align: center;

    padding-bottom: 60px; /* altura do footer */
  }

  h1 {
    font-size: 1.6rem;
    margin: 10px 0;
    line-height: 1.3;
    color: #FFD700; /* dourado */
  }

  /* ============================================================
    2. FORMULÁRIO PRINCIPAL
    ============================================================ */

  form {
    display: inline-block;
    background-color: rgba(0, 0, 0, 0.6);
    padding-left: 10px;   /* aumenta espaço à esquerda */
    padding-right: 16px;  /* aumenta espaço à direita */
    padding-top: 8px;    /* mantém o espaçamento vertical */
    padding-bottom: 10px;
    border-radius: 12px;
    border: 1px solid #fff;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.5);
    max-width: 360px;
    width: 100%;
    text-align: left;
    margin-bottom: 5px;
  }

  label {
    font-weight: 600;
    display: block;
    margin: 6px 0 6px 10px;
  }

  /* ============================================================
    3. CAMPOS E INPUTS
    ============================================================ */

  /* Estilo base para campos e botões */
  input {
    box-sizing: border-box;
    border-radius: 6px;
    font-size: 1rem; 
  }

  /* Campo principal branco */
  .input-branco {
    background-color: #fff;
    color: #000;
    width: 98%;
    padding: 8px 10px;
    border: 1px solid #bbb;
    margin-left: 2.5%;
    font-weight: bold;
  }

  /* Campo desabilitado (cinza) */
  .input-desabilitado {
    width: 100%;
    padding: 8px 10px;
    background-color: #bdbdbd;
    color: #4d4d4d;
    font-weight: bold;
  }

  /* Tamanhos específicos de inputs */
  .input-juros { width: 45%; }
  .input-prazo { width: 95%; }

  input::placeholder {
    color: #b3b3b3;
  }

  /* Mensagem de erro */
  .error {
    color: #ff6b6b;
    font-size: 0.85rem;
    margin-top: 3px;
    transition: opacity 0.3s;
    opacity: 1;
    min-height: 4px;
  }

  /* ============================================================
    4. BOTÕES
    ============================================================ */

  button {
    width: 75%;
    display: block;
    margin: 20px auto 0;
    padding: 8px;
    font-size: 1.05rem;
    font-weight: bold;
    background-color: #FFD700;
    border: none;
    color: #003366;
    cursor: pointer;
    transition: 0.3s;
    border-radius: 10px;
  }

  button:hover {
    opacity: 0.85;
  }

  button:disabled {
    background-color: #999;
    cursor: not-allowed;
    opacity: 0.6;
  }

  /* ============================================================
    5. TABELAS E RESULTADOS
    ============================================================ */

  /* Container geral da tabela */
  .table-container {
    margin: 10px auto;
    max-width: 100%;
    overflow-x: auto;
    text-align: center;
  }

  .table-container h2 {
    margin: 5px 0 10px;
    font-size: 1.1rem;
    color: #FFD700;
    text-align: center;
  }

  /* Estrutura base das tabelas */
  table {
    border-collapse: collapse;
    margin: 0 auto 10px;
    font-size: 0.95rem;
    background: rgba(0, 0, 0, 0.6);
    border-radius: 8px;
    color: #fff;
    min-width: 400px;
    overflow: hidden;
  }

  /* Cabeçalho */
  table.tabela-regressiva th {
    background-color: #FFD700;
    color: #003366;
    font-size: 0.9rem;
  }

  /* Corpo: colunas Alíquota IR e IR Devido */
  table.tabela-regressiva td.aliq_ir,
  table.tabela-regressiva td.ir_devido {
    background-color: #c44d4d;
    color: #fff;
    font-size: 0.9rem;
  }

  table.tabela-regressiva th.beneficio,
  table.tabela-regressiva tr:last-child td {
    background-color: #FFD700;
    color: #003366;
    font-weight: bold;
    text-align: center;
  }

  table.tabela-regressiva tr:last-child td.beneficio {
    background-color: #FFD700;
    color: #003366;
    font-weight: bold;
  }

  /* Coluna Aplicação (Aporte) em PGBL azul intermediário */
  table.tabela-regressiva td.aporte {
    background-color: #415ce1 !important;
    color: #fff !important;
    font-size: 0.8rem;
  }

 table.tabela-regressiva td.comjuros,
  table.resumo-final tr.comjuros {
    background-color: #0000FF !important;
    color: #fff !important;
    //font-size: 0.8rem;
  }

  /* Bordas e alinhamento geral */
  th, td {
    border: 1px solid #bbb;
    padding: 4px 6px;
    white-space: nowrap;
  }

  th { text-align: center; }
  td:first-child, th:first-child { text-align: center; }
  td.num { 
    text-align: right;
    padding-left: 2px;   /* reduz espaço à esquerda */
  }

  .linha-dupla-direita {
    border-right: 4px double white;
  }

.anos-parados {
  text-align: left;
  color: #FFFFFF;
  font-size: 00.85rem;
  font-style: italic;

 // background-color: #f7f7f7;
 // border-top: 1px dashed #ccc;
 // border-bottom: 1px dashed #ccc;
}


  /* ============================================================
    6. MENSAGENS, INFO E ELEMENTOS COMPLEMENTARES
    ============================================================ */

  #aliquota-info {
    margin-top: 10px;
    line-height: 0;
    font-size: 0.85rem;
    color: #ccc;
  }

  /* ============================================================
    7. LAYOUTS FLEX E ALINHAMENTOS
    ============================================================ */

  .flex-prazos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding-left: 10px;
    padding-right: 2.5px;
  }

  .campos-renda-limite {
    display: flex;
    align-items: flex-start;
    gap: 15px;
    width: 100%;
  }

  .campos-renda-limite > div {
    display: flex;
    flex-direction: column;
    padding-left: 5px;
  }

  .campos-renda-limite .renda { flex: 2.3; }
  .campos-renda-limite .limite { flex: 2.1; }

  #prazoresgate,
  #prazoinvest {
    margin-left: 0 !important;
  }

  /* ============================================================
    8. RESPONSIVIDADE GERAL
    ============================================================ */

  @media (max-width: 600px) {
    form {
      width: 95%;
      padding: 20px;
    }

    input,
    button {
      font-size: 1rem;
      padding: 12px;
    }

    table {
      font-size: 0.8rem;
    }
  } 

  /* ============================================================
   9. LAYOUT RESPONSIVO DO FORMULÁRIO E TABELA LADO A LADO
   ============================================================ */

  .layout-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }

  /* Desktop: lado a lado, topo alinhado e margens preservadas no formulário */
  @media (min-width: 1100px) {
    .layout-container {
      display: flex;
      flex-direction: row;
      align-items: flex-start;       /* alinha o topo de ambos */
      justify-content: center;       /* centraliza o conjunto na tela */
      gap: 100px;                     /* espaçamento entre form e tabela */
      width: 100%;
    }

    .layout-container > form {
      align-self: flex-start;        /* mantém o topo alinhado */
      margin: 0;                     /* remove margens externas extras */
      padding: 10px;                 /* preserva o espaçamento interno */
      max-width: 400px;
      flex-shrink: 0;                /* impede o formulário de comprimir */
    }

    .layout-container > .table-container {
      align-self: flex-start;        /* mantém o topo alinhado */
      margin: 0;
      max-width: 1200px;
    }

    /* remove margens internas do conteúdo da tabela */
    .table-container h2 {
      margin-top: 0;
      margin-bottom: 10px;
    }

    .table-container table {
      margin-top: 0;
    }
  }   

  /* Mobile/tablet: empilhado e centralizado na tela */
  @media (max-width: 1099px) {
    .layout-container {
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 20px;
    }

    .layout-container > form,
    .layout-container > .table-container {
      align-self: center;
      margin: 0 auto;
    }
  }

  .titulo-formulario,
    h2.titulo-formulario {
    font-size: 1.3rem;
    font-weight: 600;
    text-align: center;
    margin-top: 0;
    margin-bottom: 10px;
    color: #fff; /* mesma cor do título do formulário */
  } 

  /* ================================
    Container Resumo Final
    ================================ */
  #resumo-container {
    display: flex;
    flex-direction: column;      /* sempre coluna */
    align-items: center;         /* centraliza horizontalmente */
    width: 100%;
    max-width: 600px;            /* largura máxima do bloco */
    margin: 2px auto 5px;      /* centralizado e espaçamento acima/abaixo */
  }

  /* ================================
    Tabela Resumo Final
    ================================ */
  .resumo-final {
    display: table;              /* inline-table pode causar comportamentos estranhos */
    width: auto;                 /* ajusta à largura do conteúdo */
    table-layout: auto;          /* colunas ajustam ao conteúdo */
    border-collapse: collapse;   /* colapsa bordas internas */
    /*border-spacing: 0;*/
    border-radius: 4px;     /*ok*/
    /*overflow: hidden;*/
    font-size: 0.95rem;
    color: #fff;                 /* mantém cor do texto */
    background-color: rgba(0,0,0,0.4); /* mantém fundo */
    /*box-shadow: 0 3px 10px rgba(0,0,0,0.4);*/
    margin: 0 auto;              /* centraliza */
  }

  /* ================================
    Células
    ================================ */
  .resumo-final td {
    padding: 6px 8px;            /* diminui largura das células */
    text-align: right;
    /*white-space: nowrap;          /* impede quebra de números */
    border-bottom: 1px solid rgba(255,255,255,0.3); /* borda interna fina */
    word-wrap: break-word;        /* permite quebra de texto longo se necessário */
  }

  /* Primeira coluna alinhada à esquerda */
  .resumo-final td:first-child {
    text-align: left;
    width: auto;                 /* ajustável ao conteúdo */
    max-width: 205px;            /* evita que fique enorme */
  }

  /* Segunda coluna (valores) */
  .resumo-final td:last-child {
    width: auto;
    max-width: 295px;            /* largura máxima para valores */
    text-align: right;
  }

  /* Linhas coloridas */
  .resumo-final .linha-vermelha,
    table.tabela-regressiva td.linha-vermelha { 
    background-color: #c44d4d !important;
    color: #FFFFFF !important;
  }

    table.tabela-regressiva td.linha-verde008000 {
      background-color: #008000 !important;
      color: #FFFFFF !important;
      font-size: 0.8rem;
    }

  .resumo-final .linha-verde,
    table.tabela-regressiva td.linha-verde {
      background-color: rgba(0, 128, 0, 0.5) !important;
      color: #FFFFFF !important;
    }

  table.resumo-final tr.linha-azul,
    table.tabela-regressiva td.linha-azul{ 
      background-color: rgba(0, 102, 204, 0.5) !important;
      color: #FFFFFF !important;  
  }

  table.resumo-final tr.comprendafixa { 
      background-color: #004766 !important;
      color: #FFFFFF !important;  
  }

  /* Última linha: permite quebra de texto longo na primeira célula */
  .resumo-final tr:last-child td:first-child {
    white-space: normal;
  }

  /* Borda dupla abaixo da linha "PGBL Líquido + Benefício Fiscal:" */
  .resumo-final tr.borda-dupla td {
    border-bottom: 4px double #fff;
  }

  /* ===== Rodapé dentro do resumo ===== */
  .resumo-rodape {
    margin-top: 4px;
    padding-top: 8px;
    border-top: 1px solid #ccc;
    font-size: 0.8rem;
    color: #FFFFFF;
    text-align: center;
    font-style: italic;
  }


  #site-footer {
    position: fixed;        /* fixa no fundo da tela */
    bottom: 0;
    left: 0;
    width: 100%;
    text-align: center;
    padding: 8px 10px;
    font-size: 0.85rem;
    background-color: rgba(0,0,0,0.8);
    color: #fff;
    border-top: 1px solid #444;
    z-index: 9999;          /* sempre sobre os elementos */
  }

  #site-footer a {
    color: #FFD700;
    text-decoration: none;
    margin: 0 5px;
  }

  #site-footer a:hover {
    text-decoration: underline;
  }

  /* Ajuste em mobile para não cobrir conteúdo */
  @media (max-width: 600px) {
    #site-footer {
      font-size: 0.8rem;
      padding: 6px 8px;
    }
  }
  

    /* Ícone de ajuda */
  .ajuda-icon {
    cursor: pointer;
    margin-left: 6px;
    font-size: 1.1rem;
    color: #ffd700; /* amarelo ouro */
    text-shadow: 0 0 6px rgba(255,215,0,0.8);
    transition: transform 0.2s, color 0.2s;
  }
  .ajuda-icon:hover {
    transform: scale(1.3);
    color: #fff700;
  }


/* ===== Modal - Renda Fixa (Líquido) ===== */
.modal-ajuda {
  display: none; /* oculto por padrão */
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0, 0, 0, 0.2); /* leve sobreposição */
  backdrop-filter: blur(0.5px);
  animation: fadeIn 0.3s ease;
  overflow: auto;
}

/* Caixa do conteúdo */
.modal-conteudo {
  position: fixed;
  top: 10%;
  left: 10%;       /* valor inicial */
  cursor: grab;
  background: #ffffff;
  color: #333333;
  padding: 24px 26px;
  border-radius: 10px;
  width: auto;
  max-width: 100%;
  min-width: 300px;
  max-height: 90vh;
  overflow: auto;
  box-shadow: 0 10px 12px rgba(0,0,0,0.25);
  font-family: "Segoe UI", Roboto, sans-serif;
  animation: slideIn 0.4s ease forwards;
  touch-action: none;
  transform: none;  /* remover translateX para arraste */
}


/* Título */
.modal-conteudo h3 {
  margin: 0 0 14px;
  text-align: center;
  font-size: 1.2rem;
  font-weight: 600;
  color: #000000;
  border-bottom: 1px solid rgba(100,100,100,0.2);
  padding-bottom: 8px;
}

/* Tabela */
.modal-conteudo table {
  background: #0066CC;       /* azul original */
  color: #FFFFFF;            /* texto branco */
  width: auto;               /* ajusta ao texto */
  max-width: 100%;
  border-collapse: collapse;
  margin-top: 12px;
  font-size: 1rem;
  border-radius: 4px;
  overflow-x: auto;
}

.modal-conteudo td {
  padding: 6px 8px;
  border-bottom: 1px solid rgba(255,255,255,0.3);
  white-space: nowrap; /* impede quebra dentro das células */
}

.modal-conteudo td:first-child {
  text-align: left;
  color: #FFFFFF; /* branco */
}

.modal-conteudo td:last-child {
  text-align: right;
  font-weight: 600;
  color: #FFFFFF; /* branco */
}

/* ===== Rodapé dentro do modal ===== */
.modal-rodape {
  margin-top: 12px;
  padding-top: 8px;
  border-top: 1px solid #ccc;
  font-size: 0.8rem;
  color: #666;
  text-align: center;
  font-style: italic;
}

/* Botão de fechar (X) */
.modal-conteudo .fechar {
  color: #777777;
  float: right;
  font-size: 32px;
  cursor: pointer;
  transition: color 0.2s ease;
  pointer-events: auto; /* garante que eventos passem para o botão */
}

.modal-conteudo .fechar:hover {
  color: #000000;
}

/* Animações */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideIn {
  from { opacity: 0; transform: translateY(-20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Responsividade */
@media (max-width: 768px) {
  .modal-conteudo {
    top: 5%;
    left: 50%;
    transform: translateX(-50%);
    width: 95%;
    padding: 18px;
    max-height: 88vh;
    overflow: auto;
  }


  .modal-conteudo table {
    font-size: 0.95rem;
  }

  .modal-conteudo td {
    padding: 8px 6px;
  }
}