.contact-hero {
    padding-top: 140px !important
}

.contact-grid {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 28px;
}

@media (max-width:980px) {
    .contact-grid {
        grid-template-columns: 1fr
    }
}

.form-card,
.contact-card {
    padding: var(--pad)
}

.field {
    display: grid;
    gap: 8px
}

.field+.field {
    margin-top: 14px
}

.field label {
    font-weight: 500
}

.input,
.textarea {
    width: 100%;
    border-radius: 14px;
    border: 1px solid var(--glass-brd);
    background: rgba(255, 255, 255, .06);
    color: var(--ink);
    padding: 12px 14px;
    outline: 0;
    transition: box-shadow .2s, border-color .2s, background-color .2s;
    backdrop-filter: blur(8px) saturate(120%);
}

.textarea {
    min-height: 250px;
    resize: vertical
}

.input::placeholder,
.textarea::placeholder {
    color: var(--ink-dim)
}

.input:focus,
.textarea:focus {
    border-color: color-mix(in srgb, var(--primary) 80%, var(--secondary) 80%);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 50%, var(--secondary) 50%, 20%);
    background: rgba(255, 255, 255, .08);
}

.contact-card h1 {
    margin: 0 0 12px;
    font-size: clamp(34px, 5vw, 56px);
    line-height: 1.05;
    color: var(--ink);
}

.lead {
    color: var(--ink-dim);
    margin: 0 0 22px
}

.kv {
    margin: 18px 0
}

.kv h3 {
    margin: 0 0 6px;
    font-size: 16px;
    color: var(--ink)
}

.kv p,
.kv a {
    margin: 0;
    color: var(--ink-dim);
    text-decoration: none
}

.kv a:hover {
    text-decoration: underline
}

.form-actions {
    margin-top: 16px;
    display: flex;
    justify-content: flex-end
}

.btn.btn-primary {
    border: 0;
    cursor: pointer
}


/* keep map responsive inside card */
.map-wrap {
    position: relative;
    width: 100%;
    padding-top: 40%;
    border-radius: 14px;
    overflow: hidden;
    margin-top: 16px;
    box-shadow: 0 0 12px rgba(0, 0, 0, 0.25);
}

.map-wrap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

h1 {
    background: linear-gradient(90deg, var(--secondary), var(--primary));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

@media (max-width: 480px) {
    .contact-hero {
        padding-top: 120px !important;
    }
}