/* Estilos para o autocompletar de cidades */
.sugestoes-autocompletar {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: white;
    border: 1px solid #ddd;
    border-top: none;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    max-height: 200px;
    overflow-y: auto;
    z-index: 1000;
    display: none;
}

.sugestao-item {
    padding: 10px 15px;
    cursor: pointer;
    border-bottom: 1px solid #f0f0f0;
    transition: background-color 0.2s ease;
}

.sugestao-item:hover {
    background-color: #f8f9fa;
}

.sugestao-item:last-child {
    border-bottom: none;
}

/* Estilos para o campo data de nascimento */
#data_nascimento {
    font-weight: 500;
}

/* Estilos para o campo idade */
#idade {
    font-weight: 500;
}

/* Estilos para campos com validação */
.campo-valido {
    border-color: #28a745 !important;
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25) !important;
}

.campo-invalido {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
}

/* Feedback de validação */
.feedback-validacao {
    margin-top: 5px;
    font-size: 0.875rem;
}

.feedback-valido {
    color: #28a745;
}

.feedback-invalido {
    color: #dc3545;
}

/* Container relativo para posicionamento do autocompletar */
.form-group {
    position: relative;
}

/* Estilos para o campo estado */
#estado {
    font-weight: 500;
}

/* Estilos para o campo cidade */
#cidade {
    font-weight: 500;
}

/* Estilos para o campo CPF */
#cpf {
    font-family: 'Courier New', monospace;
    letter-spacing: 1px;
}

/* Estilos para o campo email */
#email {
    font-weight: 500;
}

/* Responsividade */
@media (max-width: 768px) {
    .sugestoes-autocompletar {
        max-height: 150px;
    }
    
    .sugestao-item {
        padding: 12px 15px;
        font-size: 16px; /* Evita zoom no iOS */
    }
}
