/* ====================== Component: Location Info ====================== */
.location { background: var(--color-cream); padding-block: 64px; }
.location__grid { display: grid; grid-template-columns: 1fr; gap: 48px; align-items: start; }

/* Map + photo */
.loc-map { background: var(--color-white); padding: 2px; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1); }
.loc-map__img { display: block; width: 100%; aspect-ratio: 704 / 480; object-fit: cover; background: #d9d9d9; }
.loc-photo { margin: 24px 0 0; }
.loc-photo__img { width: 100%; aspect-ratio: 704 / 192; object-fit: cover; display: block; }
.loc-photo__caption { margin-top: 12px; text-align: center; font-size: 12px; line-height: 16px; color: #1d1d1d; }

/* Info blocks */
.loc-info { display: flex; flex-direction: column; gap: 32px; }
.loc-block { display: flex; gap: 8px; align-items: flex-start; }
.loc-block__icon { width: 16px; height: 16px; flex: none; margin-top: 4px; }
.loc-block__content { flex: 1; min-width: 0; }
.loc-block__title { font-size: 16px; line-height: 24px; letter-spacing: -0.16px; }
.loc-block__body { margin-top: 8px; font-size: 14px; line-height: 22.75px; color: var(--color-ink); }
.loc-block__body p + p { margin-top: 8px; }

/* Lists inside the WYSIWYG body (By Road bullets) */
.loc-block__body ul { list-style: none; margin: 10px 0 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.loc-block__body li { position: relative; padding-left: 16px; font-size: 14px; line-height: 20px; color: var(--color-ink); }
.loc-block__body li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--color-yellow);
}
.loc-block__body strong { font-weight: 600; }

@media (min-width: 768px) {
  .location { padding-block: 96px; }
}
@media (min-width: 860px) {
  .location__grid { grid-template-columns: 1.5fr 1fr; gap: 48px; }
}
