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

.contact-panel {
    display: grid;
    grid-template-columns: minmax(320px, .9fr) minmax(0, 1.1fr);
    gap: 46px;
    align-items: center;
    padding-top: 54px;
}

.contact-visual-frame {
    padding: 0;
    border-radius: 16px;
    background: transparent;
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.4);
    overflow: hidden;
}

.contact-visual-frame img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    border-radius: 16px;
}

.contact-panel__content h2 {
    margin-top: 16px;
    font-size: clamp(2.2rem, 4vw, 3.8rem);
}

.contact-list {
    margin-top: 26px;
    display: grid;
    gap: 14px;
}

.contact-list div {
    padding: 18px 20px;
    border-radius: 20px;
    background: var(--surface);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-soft);
}

.contact-list strong,
.contact-list span {
    display: block;
}

.contact-list strong {
    margin-bottom: 8px;
}

.contact-list span {
    color: var(--muted);
}

.contact-support {
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(320px, 1.05fr);
    gap: 24px;
    padding-top: 54px;
}

.contact-form-box,
.map-box {
    padding: 30px;
    border-radius: 30px;
    background: var(--surface);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-soft);
}

.contact-form-box h2,
.map-box h2 {
    margin: 0 0 12px;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: clamp(1.8rem, 3vw, 2.6rem);
}

.contact-form {
    display: grid;
    gap: 14px;
    margin-top: 20px;
}

.contact-form label {
    display: grid;
    gap: 8px;
    font-weight: 700;
}

.contact-form input,
.contact-form textarea {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--line-strong);
    border-radius: 16px;
    background: var(--bg-soft);
    color: var(--text);
}

.contact-form textarea {
    min-height: 140px;
    resize: vertical;
}

.contact-notice {
    margin-top: 18px;
    padding: 14px 16px;
    border-radius: 16px;
    background: var(--gold-soft);
    color: var(--text);
    font-weight: 600;
}

.map-frame {
    overflow: hidden;
    border-radius: 24px;
    min-height: 420px;
}

.map-frame iframe {
    width: 100%;
    height: 420px;
    border: 0;
}

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