/* ─── How to book ─── */

.how-to-book {
  background-color: var(--neutral-0);
}

.how-to-book__header {
  margin-bottom: var(--space-12);
}

.steps-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background-color: var(--neutral-300);
  margin-bottom: var(--space-12);
}

.step-item {
  background-color: var(--neutral-50);
  padding: var(--space-10) var(--space-8);
  position: relative;
}

.step-item__number {
  display: block;
  font-family: var(--font-display);
  font-size: var(--text-7xl);
  font-weight: 300;
  color: var(--accent-100);
  line-height: 1;
  margin-bottom: var(--space-6);
  letter-spacing: -0.04em;
}

.step-item__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 500;
  color: var(--primary-900);
  margin-bottom: var(--space-3);
}

.step-item__desc {
  font-size: var(--text-base);
  color: var(--primary-700);
  line-height: 1.7;
}

.how-to-book__cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  padding-block: var(--space-8);
}

.how-to-book__note {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  color: var(--neutral-500);
}

@media (max-width: 768px) {
  .steps-grid {
    grid-template-columns: 1fr;
  }
}

/* ─── Locations full ─── */

.locations-full {
  background-color: var(--neutral-50);
}

.locations-full__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-12);
}

.location-full-card {
  background-color: var(--neutral-0);
  border: 1px solid var(--neutral-300);
  overflow: hidden;
  transition: box-shadow var(--duration-base) var(--ease-smooth);
}

.location-full-card:hover {
  box-shadow: var(--shadow-lg);
}

.location-full-card__header {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  padding: var(--space-6) var(--space-8);
  border-bottom: 1px solid var(--neutral-100);
}

.location-full-card__number {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  color: var(--accent-500);
}

.location-full-card__name {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 500;
  color: var(--primary-900);
}

.location-full-card__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.location-full-card__image {
  aspect-ratio: 1;
  overflow: hidden;
}

.location-full-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(20%);
  transition: all var(--duration-slow) var(--ease-smooth);
}

.location-full-card:hover .location-full-card__image img {
  filter: grayscale(0%);
  transform: scale(1.05);
}

.location-full-card__info {
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  justify-content: center;
}

.location-info-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  color: var(--primary-700);
}

.location-info-row svg {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--accent-500);
}

.location-info-row p,
.location-info-row a {
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--primary-700);
}

.location-info-row a {
  font-family: var(--font-mono);
  color: var(--medical-500);
  transition: color var(--duration-base);
}

.location-info-row a:hover {
  color: var(--accent-500);
}

@media (max-width: 960px) {
  .locations-full__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .location-full-card__body {
    grid-template-columns: 1fr;
  }

  .location-full-card__image {
    aspect-ratio: 16/9;
  }
}
