@import url(./geral.css);

/* ===== RESET ===== */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* ===== BODY ===== */
body {
    display: flex;
    justify-content: center;
    background-color: #f5f5f5;
    padding: 15px;
}

/* ===== FORM ===== */
form {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
    padding: 20px;
    background: #f5f5f5;
    border-radius: 10px;
}

/* ===== LOGO ===== */
form img {
    display: block;
    margin: 0 auto 20px auto;
    max-width: 120px;
}

/* ===== LABEL ===== */
.texto-form {
    font-family: 'Roboto', sans-serif;
    font-size: 16px;
    margin-top: 12px;
}

/* ===== INPUTS ===== */
input,
select {
    width: 100%;
    padding: 10px;
    margin-top: 5px;
    margin-bottom: 10px;
}

/* ===== GRID ===== */
.linha {
    display: grid;
    gap: 15px;
    margin-bottom: 10px;
}

.linha div {
    display: flex;
    flex-direction: column;
}

/* ===== MOBILE (PADRÃO) ===== */
.duas-colunas,
.tres-colunas {
    grid-template-columns: 1fr;
}

/* ===== TABLET ===== */
@media (min-width: 768px) {
    .duas-colunas {
        grid-template-columns: 1fr 1fr;
    }
}

/* ===== DESKTOP ===== */
@media (min-width: 1024px) {
    form {
        max-width: 800px;
    }

    .duas-colunas {
        grid-template-columns: 1fr 1fr;
    }

    .tres-colunas {
        grid-template-columns: 1fr 1fr 1fr;
    }
}

/* ===== BOTÃO ===== */
.btn {
    width: 100%;
    padding: 12px;
    margin-top: 15px;
    margin-bottom: 10px;
    border-radius: 5px;
    background-color: var(--cor-botao);
    color: #000;
    font-family: 'Roboto', sans-serif;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
}

.btn:hover {
    background-color: var(--cor-hover);
}

/* ===== MOBILE (max-width: 550px) ===== */
@media (max-width: 550px) {
    body {
        padding: 12px;
    }

    form {
        padding: 14px;
        max-width: 100%;
    }

    form img {
        max-width: 100px;
        margin-bottom: 16px;
    }

    .texto-form {
        font-size: 14px;
        margin-top: 10px;
    }

    input,
    select {
        padding: 8px;
        margin-top: 4px;
        margin-bottom: 8px;
        font-size: 14px;
    }

    .btn {
        padding: 11px;
        margin-top: 12px;
        font-size: 15px;
    }
}
