.contact { padding: 54px 0; background: #FCF1F3; color: var(--ink); }
.contact-grid { position: relative; display: grid; grid-template-columns: 1.2fr 1.15fr .95fr 1.2fr; gap: 34px; align-items: start; }
.contact-grid > * + * { position: relative; }
.contact-grid > * + *::before { content: ""; position: absolute; left: -34px; top: 12.5%; width: 1px; height: 174px; background: #fdeaf4; pointer-events: none; }
.contact-brand { display: inline-grid; justify-items: stretch; width: max-content; }
.contact-brand p { display: flex; align-items: center; justify-content: center; width: 100%; min-height: 24px; margin: 0; padding: 30px 0 20px; color: var(--ink); font-family: "Cormorant Garamond", Georgia, serif; font-size: calc(1.45rem); font-weight: 700; line-height: 1; text-align: center; }
.contact strong { display: block; color: var(--fuchsia); text-transform: uppercase; font-size: calc(.82rem + 2px); font-weight: 760; letter-spacing: .08em; }
.contact .logo strong { margin-bottom: 0; font-size: 1.05rem; font-weight: 560; letter-spacing: .06em; }
.contact .logo small { margin-top: 5px; font-size: calc(.885rem + 2px); letter-spacing: .04em; }
.contact-call { display: inline-flex; align-items: center; justify-content: center; gap: 10px; width: 100%; min-height: 48px; margin-top: 20px; padding: 0 22px; border: 1px solid #A92154; border-radius: 6px; background: linear-gradient(180deg, var(--fuchsia), #C21959); color: #fff; font-weight: 620; letter-spacing: .045em; text-transform: none; box-shadow: none; transition: transform .25s ease; }
.contact-call:hover { transform: translateY(-1px); box-shadow: none; }
.contact-call svg, .contact-row svg { fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.contact-call svg { width: 20px; height: 20px; color: #fff; }
.contact-details, .contact-hours, .contact-place { display: grid; gap: 10px; align-content: start; color: var(--ink); }
.contact-details strong, .contact-hours strong, .contact-place strong { margin-bottom: 8px; }
.contact-details { margin: 0; font-style: normal; }
.contact-row { display: grid; grid-template-columns: 22px minmax(0, 1fr); gap: 10px; align-items: start; color: var(--ink); line-height: 1.55; }
.contact-row svg, .contact-row img { width: 18px; height: 18px; margin-top: 3px; color: var(--fuchsia); }
.contact-hours p { margin: 0; display: grid; grid-template-columns: 104px 1fr; gap: 12px; color: var(--ink); line-height: 1.55; text-align: left; }
.contact-map { position: relative; display: block; overflow: hidden; min-height: 150px; border: 1px solid #fdeaf4; border-radius: 8px; background: #FCF1F3; transition: transform .25s ease, border-color .25s ease; }
.contact-map img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(.85) contrast(.96) brightness(1.04); transition: filter .25s ease, transform .25s ease; }
.contact-map:hover { transform: translateY(-1px); border-color: #F4D3DA; }
.contact-map:hover img { filter: saturate(.95) contrast(1) brightness(1.06); transform: scale(1.02); }
.map-link { width: max-content; color: var(--ink); font-weight: 500; transition: color .25s ease, transform .25s ease; }
.map-link:hover { color: var(--fuchsia); transform: translateX(6px); }
@media (max-width: 1020px) { .contact-grid { grid-template-columns: repeat(2, 1fr); } .contact-grid > * + *::before { display: none; } .contact-map { min-height: 220px; } }
@media (max-width: 720px) { .contact-grid { width: min(100% - 40px, 1240px); grid-template-columns: 1fr; gap: 30px; } .contact-map { min-height: 240px; } }
