@import url('https://fonts.googleapis.com/css2?family=Newsreader:opsz,wght@6..72,400;6..72,700&family=DM+Serif+Text&display=swap');

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-family: 'Newsreader', serif;
    background: #f5f5f5;
    color: #3f3b3b;
}

/* ocupa o ecrã e centra o cartão das regras */
.regras-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}

/* cartão com as regras */
.regras-card {
    width: 100%;
    max-width: 720px;
    background: #e8e8e8;
    border-radius: 20px;
    padding: 20px 18px 18px;
}

/* estilo do título dentro do cartão */
.regras-card h1 {
    margin: 0 0 18px;
    text-align: center;
    font-family: 'DM Serif Text', serif;
    font-size: 48px;
    color: #3d0f24;
    font-weight: 400;
}

/* texto das regras */
.regras-texto p {
    margin: 0 0 16px;
    font-size: 30px;
    line-height: 1.25;
}

/* erro quando não aceitas as regras */
.erro {
    color: #b00020;
    text-align: center;
    margin: 4px 0 10px;
    font-size: 20px;
}

/* espaço acima do formulário de aceitação */
.regras-form {
    margin-top: 8px;
}

/* linha com checkbox + texto de aceitação, alinhada ao centro */
.aceite-linha {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 32px;
    color: #3d0f24;
}

/* tamanho do checkbox de aceitar regras */
.aceite-linha input[type="checkbox"] {
    width: 22px;
    height: 22px;
}

/* coisinho de confirmação para aceitar as regras */
.check-icon {
    font-size: 36px;
    line-height: 1;
}

/* botão continuar */
.btn-continuar {
    display: block;
    margin: 12px auto 0;
    border: none;
    border-radius: 30px;
    background: #efefef;
    color: #3d0f24;
    font-family: 'DM Serif Text', serif;
    font-size: 34px;
    padding: 6px 28px;
    cursor: pointer;
}

@media (max-width: 768px) {
    /* reduz o tamanho do título principal */
    .regras-card h1 {
        font-size: 38px;
    }

    /* reduz o tamanho do texto das regras */
    .regras-texto p {
        font-size: 24px;
    }

    /* reduz o texto da linha de aceitação */
    .aceite-linha {
        font-size: 26px;
    }

    /* reduz o tamanho do texto do botão */
    .btn-continuar {
        font-size: 30px;
    }
}
