.layout {
    display: flex;
    flex-direction: column;
    min-height: 100dvh;
    background: url(../img/photos/old-times.jpeg) no-repeat center/cover;
}




/* --- MAIN SECTION --- */
main {
    flex-grow: 1;
    background-color: #3f404169;
}

.main__title {
    color: aliceblue;
    background-color: var(--main-color);
    width: fit-content;
    font-size: clamp(20px, 2.8dvw, 23px);
    padding: .4em .9em;
    display: inline-block;
    border-radius: 6px;
    margin: 40px 15% 40px;
}

.main__container {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-template-rows: min-content;
    grid-template-areas: 
        "history mvl-container";
    width: 100%;
    margin-bottom: 150px;
}

.history, .mission, .vision, .location  {
    background-color: rgb(241, 241, 241);
    width: 90%;
    box-shadow: 0px 5px 10px -2px rgba(0, 0, 0, 0.151);
    border-radius: 6px;
    background-color: rgb(241, 241, 241);
}

.history {
    grid-area: history;
    margin: auto;
}

.mvl-container {
    grid-area: mvl-container;
    display: flex;
    flex-direction: column;
    gap: 5em;
}

.history__title, .mission__title, .vision__title, .location__title {
    color: var(--main-color);
    font-weight: bold;
    padding: 0;
    margin: 0;
    padding: 20px;
}

.history__img {
    float: left;
    width: 8em;
    height: 11em;
    margin: 15px 20px 0 20px;
}

.history__description, .mission__description, .vision__description, .location__description {
    white-space: pre-wrap;
    text-align: justify;
    padding: 20px;
}

.description__phrase {
    display: block;
    font-weight: bold;
    text-align: center;
    font-style: italic;
}




/* --- RESPONSIVE DESIGN --- */
@media (width <= 768px) {
    /* --- MAIN SECTION --- */
    .main__title {
        display: block;
        margin: 2.1em auto 1.5em;
        text-align: center;
    }
    .main__container {
        grid-template-columns: 1fr;
        grid-template-rows: min-content min-content;
        grid-template-areas:
            "history"
            "mvl-container";
        margin-bottom: 100px;
    }
    .mvl-container {
        margin-top: 2em;
        gap: 2em
    }
    .history, .mission, .vision, .location {
        margin: auto;
        width: 93%;
    }
}