/* Get in Touch section: themed cards and responsive grid */
.getintouch { padding: clamp(24px, 4vw, 48px) 0; }
.getintouch .section-title h2 { color: var(--tg-navy); }

.getintouch-grid {
  display: grid;
  gap: clamp(12px, 2.5vw, 20px);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (min-width: 777px) {
  .getintouch-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

.contact-card {
  background: #fff;
  border: 1px solid rgba(12,35,64, 0.10);
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 8px 20px rgba(12,35,64, 0.10);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  cursor: pointer;
  position: relative;
  border-top: 4px solid var(--card-accent, var(--tg-navy));
}

.contact-card:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(12,35,64, 0.14); }
.contact-card:focus-visible { outline: 3px solid var(--card-accent, var(--tg-navy)); outline-offset: 2px; }

.icon-orb {
  width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center;
  border: 2px solid var(--card-accent, var(--tg-navy)); color: var(--card-accent, var(--tg-navy));
  background: rgba(255,255,255,0.6);
}

.contact-card h3 { margin: 10px 0 6px; font-size: 1.05rem; color: var(--tg-navy); }
.contact-card p { margin: 0 0 8px; color: var(--tg-charcoal); font-size: .95rem; }
.card-cta {
  font-weight: 600; color: var(--card-accent, var(--tg-navy));
  display: inline-block; max-width: 100%;
  white-space: normal; overflow-wrap: anywhere; word-break: break-word; hyphens: auto;
}

@media (max-width: 500px) {
  .contact-card h3 { font-size: 0.98rem; }
  .contact-card p { font-size: 0.9rem; }
  .card-cta { font-size: 0.9rem; }
}

.contact-card.navy { --card-accent: var(--tg-navy); }
.contact-card.beer { --card-accent: var(--tg-beer); }
.contact-card.pine { --card-accent: var(--tg-pine); }
.contact-card.teal { --card-accent: var(--tg-teal); }
.contact-card.coral { --card-accent: var(--tg-coral); }
