.contact-page {
    padding: 60px 20px;
}

.contact-intro {
    text-align: center;
    padding: 70px 20px;
    max-width: 1080px;
    margin: 0 auto;
    position: relative;
}

.contact-intro h1 {
    font-size: clamp(80px, 12vw, 100px);
    font-weight: 900;
    margin: 0;
    color: #dededeff;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 0.8;
    position: relative;
    z-index: 1;
}

.contact-intro h2 {
    font-size: clamp(28px, 4vw, 42px);
    font-weight: 600;
    margin: -50px 0 40px 0;
    color: #111;
    position: relative;
    z-index: 2;
}

.contact-subtitle {
    font-size: clamp(16px, 3vw, 22px);
    font-weight: 600;
    color: #555;
    margin: 0;
}

.contact-image {
    text-align: center;
    margin: 10px auto; 
    max-width: 1200px;
}

.contact-image img {
    max-width: 100%;
    height: auto;
    display: block;       
    margin: 0 auto; 
}

.contact-content {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    max-width: 1200px;
    margin: 0 auto;
}

.contact-block {
    background: #fff;
    text-align: center;
    padding: 45px 30px;
    box-shadow: 0 0 15px rgba(233, 233, 233, 0.75);
    transition: all 300ms ease;
    min-height: 375px;
    font-size: 17px;
    line-height: 26px;
}

.contact-block:hover {
    box-shadow: 0 0 15px rgba(134, 131, 131, 0.61);
}

.contact-block p {
    margin: 0;
    font-weight: 300;
}

.contact-block strong {
    font-weight: 600;
}

.contact-block a {
    color: #348dcc;
    text-decoration: none;
}

.contact-block a:hover {
    text-decoration: underline;
}

/* Mobile responsive for contact */
@media (max-width: 991px) {
    .contact-content {
        grid-template-columns: 1fr;
    }

    .contact-block {
        min-height: 0;
        padding: 45px 10px;
    }
}

@media (max-width: 767px) {

    .contact-intro h1 {
        font-size: clamp(50px, 15vw, 80px);
    }

        .contact-intro h2 {
        font-size: clamp(22px, 5vw, 28px);
    }
}