.contact-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 64px;
  align-items: flex-start;
}
.contact-map {
  border-radius: 18px;
  overflow: hidden;
  background: var(--mist);
  aspect-ratio: 6/5;
  position: relative;
}
.map-frame { width: 100%; height: 100%; position: relative; }
.map-frame svg { display: block; }

.map-pin-label {
  position: absolute;
  bottom: 24px; left: 24px;
  background: var(--sage);
  padding: 16px 20px;
  border-radius: 12px;
  box-shadow: var(--shadow-2);
  display: flex; gap: 12px; align-items: center;
  max-width: 280px;
}
html[dir="rtl"] .map-pin-label { left: auto; right: 24px; }
.pin-bull { color: var(--forest); font-size: 22px; line-height: 1; }
.pin-title { font-family: var(--font-display-en); font-weight: 800; color: var(--forest); font-size: 16px; letter-spacing: -0.02em; }
html[dir="rtl"] .pin-title { font-family: var(--font-display-ar); font-size: 18px; letter-spacing: -0.005em; }
.pin-sub { color: var(--fg-3); font-size: 13px; margin-top: 2px; }

.contact-info { display: flex; flex-direction: column; gap: 40px; }
.info-block p {
  margin: 0;
  color: var(--fg);
  line-height: 1.7;
  font-size: 16px;
}
.info-h {
  font-family: var(--font-body-en);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin: 0 0 14px 0;
}
html[dir="rtl"] .info-h { font-family: var(--font-body-ar); text-transform: none; letter-spacing: 0.04em; font-size: 13px; font-weight: 700; }

.info-block a { color: var(--ink); font-weight: 500; }
.info-block a:hover { color: var(--forest); }
.info-link {
  margin-top: 12px;
  display: inline-block;
  color: var(--forest) !important;
  font-weight: 600 !important;
  position: relative;
}

.hours-table { width: 100%; border-collapse: collapse; }
.hours-table td {
  padding: 10px 0;
  font-size: 15px;
  border-bottom: 1px solid var(--line);
  font-variant-numeric: tabular-nums;
}
.hours-table tr:last-child td { border-bottom: none; }
.hours-table td:first-child { color: var(--fg-2); }
.hours-table td:last-child { text-align: right; color: var(--ink); font-weight: 500; }
html[dir="rtl"] .hours-table td:last-child { text-align: left; }

.contact-form-wrap {
  background: var(--mist);
  border-radius: 18px;
  padding: 56px;
  max-width: 760px;
  margin: 0 auto;
}
.contact-form-wrap .field input,
.contact-form-wrap .field textarea { background: var(--sage); }

.form-done {
  display: flex; align-items: center; gap: 18px;
  padding: 24px 0;
}
.form-done p { margin: 0; font-size: 18px; color: var(--forest); font-weight: 500; }

@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .contact-form-wrap { padding: 28px 24px; }
}
