/* Formulário de cadastro - etapas e sucesso */
* {
    box-sizing: border-box;
}

/* [hidden] precisa prevalecer sobre .form-row { display: flex } (esconde blocos condicionais) */
[hidden] {
    display: none !important;
}

body {
    font-family: Arial, sans-serif;
    margin: 0;
    background: #f5f5f5;
}

.form-header {
    background: #2a5a8c;
    color: #fff;
    padding: 12px 20px;
    font-weight: bold;
    font-size: 1.1rem;
}

.form-header-band {
    background: #2a7ab8;
    color: #fff;
    padding: 14px 20px;
    margin: 0 0 1.5rem 0;
    text-align: center;
    font-size: 1.15rem;
    font-weight: bold;
    letter-spacing: 0.02em;
}
.form-header-band-text {
    text-transform: capitalize;
}
.form-main {
    background: #fff;
    background-image: radial-gradient(circle at 1px 1px, rgba(0,0,0,0.03) 1px, transparent 0);
    background-size: 24px 24px;
}
.form-header-inner {
    font-size: 1.25rem;
    font-weight: 600;
    color: #1e293b;
    margin: 0 0 1rem 0;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid #e2e8f0;
}
.form-section-title {
    font-size: 1rem;
    font-weight: bold;
    color: #333;
    margin: 0 0 1.25rem 0;
    text-transform: capitalize;
    display: flex;
    align-items: center;
    gap: 10px;
}
.form-section-icon {
    font-size: 1.25rem;
}
.form-step-pessoal .form-inline-hint {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 200px;
}
.form-step-pessoal .form-inline-hint .hint {
    margin: 0;
    font-size: 0.8rem;
    color: #666;
    white-space: nowrap;
}
.form-step-pessoal .form-inline-hint input {
    width: 140px;
}

.form-container {
    max-width: 100%;
    background: #fff;
    min-height: 40vh;
    padding: 1.5rem;
    border-radius: 12px;
    box-shadow: 0 4px 6px -1px rgba(0,0,0,0.08), 0 2px 4px -2px rgba(0,0,0,0.06);
    border: 1px solid rgba(0,0,0,0.04);
}

.section-title {
    font-size: 1rem;
    font-weight: bold;
    color: #333;
    margin-bottom: 20px;
    text-transform: capitalize;
}

.form-row {
    display: flex;
    align-items: center;
    margin-bottom: 14px;
    flex-wrap: wrap;
    gap: 8px;
}

.form-row label {
    flex: 0 0 280px;
    font-size: 0.9rem;
    color: #333;
    text-transform: capitalize;
}

.form-row .required {
    color: #c00;
}

.form-row input[type="text"],
.form-row input[type="email"],
.form-row select,
.form-row textarea {
    flex: 1;
    min-width: 200px;
    padding: 8px;
    border: 1px solid #ccc;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    text-transform: capitalize;
}

.form-row textarea {
    text-transform: none;
    resize: vertical;
    min-height: 5rem;
    line-height: 1.45;
    font-family: inherit;
    font-size: 0.95rem;
}

/* E-mail: sem capitalização automática (preserva caixa digitada) */
.form-row input[type="email"],
.form-row input.email-sem-capitalizacao {
    text-transform: none;
}

/* Garantir que o campo de e-mail tenha a mesma largura e altura dos demais */
.form-row input[type="email"] {
    flex: 1;
    min-width: 200px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.form-row input[type="checkbox"] {
    margin-right: 6px;
}

.form-buttons {
    margin-top: 28px;
    display: flex;
    gap: 12px;
}

.form-buttons button,
.form-buttons a.btn {
    padding: 12px 24px;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    text-decoration: none;
    display: inline-block;
    text-transform: capitalize;
}

.form-container .checkbox-item label {
    text-transform: capitalize;
}

.form-container > form > p strong,
.form-container form > p strong {
    text-transform: capitalize;
}

/* Frase completa no HTML (só primeira letra maiúscula); prevalece sobre a regra acima */
.form-container > form > p strong.form-question-sentence,
.form-container form > p strong.form-question-sentence {
    text-transform: none;
}

/* Redes sociais: rótulos com caixa mista no HTML, sem capitalize por palavra */
#redes-sociais-grupo .checkbox-item label {
    text-transform: none;
}

/* Texto livre: primeira letra de cada palavra em maiúscula (exceto e-mail, docs, datas, URLs, ano). */
.form-container input[type="text"]:not(#email):not(#cpf):not(#rg):not(#cep):not(#telefone):not(#whatsapp):not(#data_nascimento):not(.filho-data-nasc):not(#endereco_numero):not([name*="[ano]"]):not(#rs_modal_perfil):not(.email-sem-capitalizacao) {
    text-transform: capitalize;
}

.form-footer-required-note {
    margin: 1rem 0 0 0;
    font-size: 0.85rem;
    color: #555;
}

.btn-anterior {
    background: #6ba3d0;
    color: #fff;
}

.btn-proxima {
    background: #2a5a8c;
    color: #fff;
}

.form-container .btn-proxima,
.form-container .btn-anterior {
    text-transform: capitalize;
}

.form-error {
    color: #c00;
    font-size: 0.9rem;
    margin-top: 4px;
}

.form-alert {
    padding: 12px 14px;
    border-radius: 8px;
    margin: 0 0 1rem 0;
    font-size: 0.95rem;
    line-height: 1.45;
}
.form-alert-error {
    background: #ffebee;
    border: 1px solid #ef9a9a;
    color: #b71c1c;
}

.form-row-dois-campos {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    align-items: end;
}
@media (max-width: 560px) {
    .form-row-dois-campos {
        grid-template-columns: 1fr;
    }
}

.form-inline-hint-data-idade {
    flex-wrap: wrap;
}
.idade-calculada {
    font-size: 0.9rem;
    color: #333;
    white-space: nowrap;
}
.idade-calculada strong {
    font-weight: 700;
}

.form-table-filhos .filho-idade-valor {
    font-weight: 600;
    color: #1a4a6e;
}

.checkbox-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin: 8px 0;
}

.checkbox-item {
    display: flex;
    align-items: center;
    gap: 8px;
}

.checkbox-item.bank-row {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 10px 16px;
}

.bank-main {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1 1 200px;
    min-width: 0;
}

.bank-tipos-conta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 14px;
    flex: 1 1 280px;
    padding-left: 4px;
}

.bank-tipo-opt {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.88rem;
    font-weight: normal;
    cursor: pointer;
    white-space: nowrap;
}

.bank-tipo-opt input[type="checkbox"] {
    margin: 0;
}

.checkbox-item input[type="text"] {
    width: 200px;
    padding: 6px;
}

table.form-table {
    width: 100%;
    border-collapse: collapse;
    margin: 10px 0;
}

table.form-table th,
table.form-table td {
    border: 1px solid #ddd;
    padding: 8px;
    text-align: left;
}

table.form-table th {
    background: #e8e8e8;
    font-size: 0.85rem;
    text-transform: capitalize;
}

table.form-table input,
table.form-table select {
    width: 100%;
    padding: 6px;
}

.hint {
    font-style: italic;
    font-size: 0.85rem;
    color: #666;
    margin-top: 2px;
}

/* Mensagens da página de sucesso */
.sucesso-mensagem {
    padding: 1rem 1.25rem;
    margin: 0 0 1rem 0;
    border-radius: 8px;
    line-height: 1.5;
}
.sucesso-mensagem p {
    margin: 0 0 0.5rem 0;
}
.sucesso-mensagem p:last-child {
    margin-bottom: 0;
}
.sucesso-destaque {
    background: #e8f5e9;
    border: 1px solid #a5d6a7;
    color: #1b5e20;
}
.sucesso-info {
    background: #e3f2fd;
    border: 1px solid #90caf9;
    color: #0d47a1;
}

/* Perfis de redes sociais — campos inline (etapa final) */
.rs-rede-item {
    margin-bottom: 2px;
}
.rs-perfil-inline {
    margin: 6px 0 10px 28px;
    max-width: 100%;
    box-sizing: border-box;
}
.rs-perfil-inline-label {
    display: block;
    font-size: 0.88rem;
    color: #475569;
    margin-bottom: 0.35rem;
    font-weight: normal;
    text-transform: none;
}
.rs-perfil-inline input[type="text"] {
    width: 100%;
    max-width: 420px;
    padding: 10px 12px;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    font-size: 1rem;
    text-transform: none;
    box-sizing: border-box;
}
.rs-perfil-inline input[type="text"]:focus {
    outline: none;
    border-color: #2a7ab8;
    box-shadow: 0 0 0 3px rgba(42, 122, 184, 0.2);
}
.form-question-sentence {
    text-transform: none;
    font-weight: 700;
    color: #333;
}

/* Etapa final (complementares): rótulos em frase legível e negrito */
#form-etapa-complementares .form-row label,
#form-etapa-complementares .checkbox-item label {
    text-transform: none;
    font-weight: 700;
}
#form-etapa-complementares .form-row select {
    text-transform: none;
}
#form-etapa-complementares .rs-perfil-inline-label {
    font-weight: normal;
}
#form-etapa-complementares label .form-cb-note {
    font-weight: normal;
}

.form-payment-notice {
    font-size: 0.9rem;
    line-height: 1.5;
    color: #444;
    background: #f0f7fc;
    border: 1px solid #b8d4e8;
    border-radius: 8px;
    padding: 12px 14px;
    margin: 0 0 1rem 0;
}

.form-row-stack {
    flex-direction: column;
    align-items: stretch;
}
.form-row-stack label {
    flex: none;
    max-width: none;
}

/* Etapa sócio-econômicas: frase com só a primeira letra maiúscula; rótulos em negrito */
.form-step-socioeconomicas .section-title,
.form-step-socioeconomicas .form-row label {
    text-transform: none;
    font-weight: bold;
}
.form-step-socioeconomicas .form-row select {
    text-transform: none;
}

/* Perguntas em frase (não forçar capitalize em cada palavra) */
.form-row label.form-label-frase {
    text-transform: none;
}

.form-cb-intro {
    font-size: 0.95rem;
    line-height: 1.5;
    color: #333;
    margin: 0 0 1rem 0;
}
.form-cb-subtitle {
    margin: 0 0 0.5rem 0;
    color: #333;
    font-weight: 600;
}
.form-cb-note {
    font-size: 0.9rem;
    color: #555;
    margin: 0 0 1.25rem 0;
}
.form-cb-block {
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 12px 14px 14px;
    margin: 0 0 1rem 0;
    background: #fafafa;
}
.form-cb-block legend {
    font-weight: 700;
    font-size: 0.95rem;
    padding: 0 6px;
}
.form-cb-hint {
    font-size: 0.82rem;
    color: #666;
    margin: 0 0 8px 0;
}
.form-cb-radios {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
}
.form-cb-radios-stack {
    flex-direction: column;
    align-items: flex-start;
}
.form-cb-radios label {
    font-weight: normal;
    text-transform: none;
    display: flex;
    align-items: center;
    gap: 6px;
}
.form-cb-radios input[type="radio"] {
    accent-color: #444;
}
.form-cb-score-panel {
    position: sticky;
    bottom: 0;
    margin: 1.25rem -1.5rem -1.5rem;
    padding: 14px 1.5rem;
    background: linear-gradient(180deg, #f3f4f6 0%, #e5e7eb 100%);
    border-top: 2px solid #9ca3af;
    font-size: 0.95rem;
    z-index: 5;
}
[data-theme="dark"] .form-cb-score-panel {
    background: linear-gradient(180deg, #1f2937 0%, #111827 100%);
    border-top-color: #6b7280;
}

.form-section-title {
    font-size: 1.05rem;
    margin: 0 0 0.75rem 0;
    color: #1e3a5f;
    border-bottom: 1px solid #dbeafe;
    padding-bottom: 0.35rem;
}
[data-theme="dark"] .form-section-title {
    color: #e5e7eb;
    border-bottom-color: #374151;
}
.radio-inline-group {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 20px;
    margin: 0.5rem 0 1rem 0;
}
.radio-inline {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-weight: normal;
    cursor: pointer;
}
.form-row-aval-bairro .select-aval-bairro {
    max-width: 8rem;
}
.form-indicacao-sim {
    margin-top: 1rem;
    padding: 1rem;
    background: #f8fafc;
    border-radius: 8px;
    border: 1px solid #e2e8f0;
}
[data-theme="dark"] .form-indicacao-sim {
    background: #111827;
    border-color: #374151;
}
