/* ── Contact ── */
.contact {
  background: var(--cream-dark);
  position: relative;
  overflow: hidden;
}
.contact::before {
  content: '';
  position: absolute;
  bottom: -120px; right: -120px;
  width: 480px; height: 480px;
  background: radial-gradient(circle, rgba(196,163,90,.1) 0%, transparent 70%);
  pointer-events: none;
}

.contact__inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

/* Section header */
.contact .section-header { margin-bottom: 48px; }

/* Grid */
.contact__grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 56px;
  align-items: start;
}

/* ── Info column ── */
.contact__info-title {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--dark);
  margin-bottom: 28px;
}

.contact__item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 24px;
  padding: 18px 20px;
  background: var(--white);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--t-fast);
}
.contact__item:hover { box-shadow: var(--shadow-md); }

.contact__item-icon {
  width: 44px; height: 44px;
  background: var(--sage-pale);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.contact__item-label {
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--light);
  margin-bottom: 4px;
}
.contact__item-value {
  font-size: .95rem;
  font-weight: 500;
  color: var(--dark);
  line-height: 1.5;
}
.contact__item-value a:hover { color: var(--burgundy); }

/* Hours table */
.contact__hours {
  width: 100%;
  border-collapse: collapse;
  font-size: .85rem;
}
.contact__hours tr + tr td { border-top: 1px solid var(--cream-darker); }
.contact__hours td { padding: 5px 0; color: var(--medium); }
.contact__hours td:last-child { text-align: right; font-weight: 500; color: var(--dark); }
.contact__hours .closed td   { color: var(--light); }

/* Call buttons */
.contact__buttons {
  display: flex;
  gap: 12px;
  margin-top: 28px;
  flex-wrap: wrap;
}
.contact__buttons .btn {
  flex: 1;
  min-width: 140px;
  justify-content: center;
  gap: 8px;
}

/* ── Form column ── */
.contact__form-wrap {
  background: var(--white);
  border-radius: var(--radius-xl);
  padding: 40px;
  box-shadow: var(--shadow-md);
}

.contact__form-title {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--dark);
  margin-bottom: 6px;
}
.contact__form-subtitle {
  font-size: .85rem;
  color: var(--medium);
  margin-bottom: 28px;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
.form-group:last-of-type { margin-bottom: 0; }

.form-label {
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--medium);
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: 13px 16px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: .9rem;
  color: var(--dark);
  background: var(--cream);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  outline: none;
  appearance: none;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--sage);
  box-shadow: 0 0 0 3px rgba(122,158,126,.18);
}
.form-textarea { resize: vertical; min-height: 120px; }

.form-submit {
  width: 100%;
  margin-top: 8px;
  padding: 15px;
  font-size: .85rem;
}

.form-notice {
  font-size: .74rem;
  color: var(--light);
  text-align: center;
  margin-top: 12px;
  line-height: 1.5;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .contact__grid { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 580px) {
  .contact__form-wrap { padding: 28px 20px; }
  .form-row { grid-template-columns: 1fr; }
  .contact__buttons .btn { min-width: 0; }
}
