/* ============================================================
   CONTACT — prominent call/email CTAs + details + map slot.
   ============================================================ */

/* ── PRIMARY CTAs (click-to-call / click-to-email) ── */
.contact-cta-row {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 64px;
}

.contact-cta {
  flex: 1 1 300px;
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 26px 30px;
  border-radius: 10px;
  text-decoration: none;
  transition: transform 0.3s var(--ease-spring), box-shadow 0.3s var(--ease-out), background 0.2s var(--ease-out), border-color 0.2s var(--ease-out);
}
.contact-cta:hover { transform: translateY(-3px); }

.contact-cta.call { background: var(--navy); color: var(--white); box-shadow: 0 8px 24px -10px rgba(0,83,159,0.5); }
.contact-cta.call:hover { background: #003d77; box-shadow: 0 12px 30px -10px rgba(0,83,159,0.6); }

.contact-cta.email { background: var(--off-white); color: var(--dark); border: 1px solid var(--border); }
.contact-cta.email:hover { border-color: var(--cyan); background: var(--white); }

.contact-cta-icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 22px;
  flex-shrink: 0;
}
.contact-cta.call .contact-cta-icon { background: rgba(255,255,255,0.14); color: var(--white); }
.contact-cta.email .contact-cta-icon { background: var(--cyan); color: var(--white); }

.contact-cta-text { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.contact-cta-label {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.7;
}
.contact-cta-value {
  font-size: clamp(17px, 2vw, 22px);
  font-weight: 600;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

/* ── FIND US: photo + map side by side ── */
.contact-visuals-heading { text-align: center; }

.contact-visuals {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: stretch;
}
.contact-visual { display: flex; }

/* ── ADDRESS + HOURS — each centred under its image ── */
.contact-info {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  text-align: center;
  margin-top: 40px;
}
/* keep day/time pairs tidy, centred within their column */
.contact-info .hours-list { max-width: 280px; margin: 0 auto; }

.contact-block-heading {
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: 16px;
}

.contact-detail { font-size: 16px; line-height: 1.7; color: var(--dark); }
.contact-detail address { font-style: normal; color: var(--mid); }

.hours-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.hours-list li {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  font-size: 15px;
  color: var(--mid);
  padding-bottom: 10px;
  border-bottom: 0.5px solid var(--border);
}
.hours-list li span:first-child { color: var(--dark); }

/* location photo */
.contact-map-img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: 8px;
  display: block;
}

/* embedded interactive Google map */
.contact-map {
  width: 100%;
  aspect-ratio: 16 / 10;
  border: 0;
  border-radius: 8px;
  display: block;
}

/* map slot uses the shared numbered placeholder, widescreen */
.map-placeholder {
  width: 100%;
  aspect-ratio: 16 / 10;
  border-radius: 8px;
  background: #e8edf2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

@media (max-width: 900px) {
  .contact-cta-row { margin-bottom: 48px; }
  .contact-visuals { grid-template-columns: 1fr; gap: 16px; }
  .contact-info { grid-template-columns: 1fr; gap: 40px; margin-top: 40px; }
}
