/* ============================================================
   CONTACT — Page Styles
   ============================================================ */

.contact-booking { padding: var(--sp-3xl) 0 var(--sp-4xl); }

.contact-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--sp-2xl);
  align-items: start;
}

.contact-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: 12px;
  padding: var(--sp-lg);
}
.contact-card h2 {
  font-family: var(--font-display); font-weight: 600;
  font-size: 1.375rem; letter-spacing: -0.01em;
  margin-bottom: var(--sp-md); line-height: 1.3;
}
.contact-card p {
  font-size: 0.9375rem; color: var(--text-secondary);
  line-height: 1.7; margin-bottom: var(--sp-md);
}
.contact-card p:last-child { margin-bottom: 0; }

.contact-card-booking {
  border-left: 3px solid transparent;
  border-image: var(--gradient) 1;
  border-radius: 0 12px 12px 0;
}

.contact-note {
  font-size: 0.8125rem !important;
  color: var(--text-tertiary) !important;
  font-style: italic;
}

.tidycal-container {
  margin-top: var(--sp-md);
  min-height: 400px;
  border-radius: 8px;
  overflow: hidden;
}

.contact-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--sp-md);
}

.contact-details {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
  margin-bottom: var(--sp-md);
}

.contact-link {
  color: var(--gold);
  text-decoration: none;
  font-size: 1rem;
  font-weight: 500;
  transition: color 0.2s;
}
.contact-link:hover { color: var(--coral); }

.contact-socials {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
}

/* RESPONSIVE */
@media (max-width: 900px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }
}
