body {
    font-family: Arial, sans-serif;
    background-color: #f4f4f9;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

.location-container {
    text-align: center;
    padding: 20px;
}

.map-container {
    width: 100%;
    height: 50vh;
    margin-bottom: 20px;
    overflow: hidden;
}

.contact-info {
    display: flex;
    flex-direction: column;
    justify-content: center; 
    padding: 20px;
    text-align: left; 
    line-height: 1.4; 
}

.contact-info h2 {
    font-family: "Charm", cursive;
    font-weight: 300;
    color: #E42518;
    font-size: 35px;
    margin-bottom: 20px; 
}

.contact-info a {
    font-family: Arial, sans-serif; 
    font-size: 15px;
    font-weight: 700;
    color: inherit; 
}

.contact-info p {
    margin: 5px 0; 
}

footer{
    margin-top: 20px;
}

@media (min-width: 1024px) {
    body {
        display: flex;
        flex-direction: column;
        min-height: 100vh;
    }

    header {
        flex-shrink: 0;
    }

    .location-container {
        flex-grow: 1;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
    }

    .map-container, .contact-info {
        width: 50%;
        height: auto;
        display: flex;
        justify-content: center;
        align-items: center;
        margin: auto;
    }

    .map-container iframe {
        margin-top: 20px;
        width: 90%;
        height: 70vh;
        border: none; 
    }

    .contact-info {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: flex-start; 
        padding: 20px;
        text-align: left;
        line-height: 1.4;
        width: 40%; 
        max-width: 400px; 
    }

    .contact-info h2 {
        margin-bottom: 10px;
        align-self: flex-start; 
    }

    .contact-info p {
        margin: 5px 0;
        align-self: flex-start; 
    }

    .contact-info > div {
        width: 100%; 
    }
}
