.contact { padding: 54px 0; background: linear-gradient(135deg, #06356d, #0870df); color: #fff; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr 1.25fr; gap: 48px; align-items: stretch; }
.contact h2 { display: inline-block; color: #fff; font-size: clamp(1.45rem, 2.2vw, 2.05rem); font-weight: 600; line-height: 1.18; }
.contact h2 span { display: block; }
.contact h2 span:first-child { font-size: calc(1em + 1px); }
.contact h2::after { content: ""; display: block; width: 54px; height: 1px; margin-top: 16px; border-radius: 999px; background: #fff; transition: width .45s ease; }
.contact h2:hover::after { width: 50%; }
.contact-call { display: inline-flex; align-items: center; gap: 10px; min-height: 52px; margin-top: 24px; padding: 0 22px; border: 1px solid rgba(255,255,255,.75); border-radius: 6px; background: #fff; color: var(--blue-dark); font-weight: 550; transition: transform .25s ease, box-shadow .25s ease, background .25s ease; }
.contact-call:hover { transform: translateY(-3px); background: #f5f8fd; box-shadow: 0 14px 30px rgba(2, 28, 68, .22); }
.contact-call svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.contact-details { display: grid; gap: 6px; align-content: start; margin: 0; color: #fff; font-style: normal; }
.contact-details strong { margin-bottom: 8px; color: #fff; text-transform: uppercase; font-size: .78rem; font-weight: 660; letter-spacing: .08em; }
.contact-row { display: grid; grid-template-columns: 22px minmax(0, 1fr); gap: 10px; align-items: center; color: #fff; line-height: 1.55; transition: color .25s ease; }
.contact-row svg { width: 18px; height: 18px; color: #d8e9ff; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.contact-row:hover { color: #d8e9ff; }
.contact-indent span { grid-column: 2; }
.contact-row.muted { color: #d8e9ff; }
.contact-map { position: relative; overflow: hidden; align-self: stretch; min-height: 0; border: 1px solid rgba(255,255,255,.28); border-radius: 8px; background: #eef5ff; }
.contact-map img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(.72) contrast(.92) brightness(1.08); opacity: .94; transition: transform .35s ease, filter .35s ease, opacity .35s ease; }
.contact-map:hover img { filter: saturate(.86) contrast(.96) brightness(1.04); opacity: 1; }
.contact-map:hover img { transform: scale(1.04); }
.contact-map span { position: absolute; right: 16px; bottom: 14px; padding: 8px 12px; border-radius: 5px; color: var(--blue-dark); background: #fff; font-size: .9rem; font-weight: 650; }
@media (max-width: 1020px) { .contact-grid { grid-template-columns: 1fr; } .contact-map { min-height: 280px; } }
@media (max-width: 720px) { .contact-grid { width: min(100% - 40px, 1240px); gap: 30px; } .contact-about { text-align: center; } .contact h2 span { display: inline; } .contact-call { justify-content: center; margin-left: auto; margin-right: auto; } }
