/* ===== GRID PRINCIPAL ===== */
.parent {
    display: grid;
    grid-template-columns: 240px 1fr;
    grid-template-rows: auto 1fr auto;
    min-height: 100vh;
    gap: 12px;
    padding: 12px;
}

/* ===== HEADER ===== */
.titulo {
    grid-column: 1 / 3;
    background: #4CAF50;
    color: #fff;
    padding: 15px 20px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* ===== BOTÃO HAMBURGER ===== */
.menu-toggle {
    display: none;
    font-size: 22px;
    background: none;
    color: white;
}

/* ===== MENU ===== */
.menu {
    background: #ffffff;
    padding: 15px;
    border-radius: 8px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}

.menu a {
    display: block;
    padding: 10px;
    margin-bottom: 8px;
    border-radius: 4px;
}

.menu a:hover {
    background: #4CAF50;
    color: white;
}

/* ===== CONTEÚDO ===== */
.body {
    background: #ffffff;
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.1);
    overflow-x: auto;
}

/* ===== FOOTER ===== */
.footer {
    grid-column: 1 / 3;
    background: #eaeaea;
    padding: 10px;
    text-align: center;
    border-radius: 8px;
    font-size: 14px;
}

/* ===== RESPONSIVO ===== */
@media (max-width: 900px) {
    .parent {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto 1fr auto;
    }

    .menu {
        display: none;
    }

    .menu.active {
        display: block;
    }

    .menu-toggle {
        display: block;
    }

    .titulo,
    .body,
    .footer {
        grid-column: 1;
    }
}


/* ===========================
   Layout sem menu (login, register, confirmar)
=========================== */
.parent.no-menu {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
}

.parent.no-menu .menu {
    display: none !important;
}

.parent.no-menu .body {
    grid-column: 1 / 2;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
