.detail-layout {
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: var(--space-5);
  align-items: start;
}

.gallery {
  display: grid;
  gap: 1rem;
}

.gallery-main {
  overflow: hidden;
  border-radius: var(--radius-xl);
}

.gallery-main img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.gallery-thumbs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.gallery-thumb {
  display: block;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  background: transparent;
}

.gallery-thumb:focus-visible {
  outline: 2px solid var(--c-ocean);
  outline-offset: 3px;
}

.gallery-thumb.is-active {
  box-shadow: 0 0 0 2px var(--c-ocean);
}

.gallery-thumb img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
}

.program-list {
  display: grid;
  gap: 1rem;
}

.program-item {
  overflow: hidden;
  border-radius: var(--radius-lg);
}

.program-trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  padding: 1rem 1.2rem;
  background: rgba(13, 59, 110, 0.06);
  color: var(--c-ocean);
  font-weight: 700;
}

.program-content {
  display: none;
  padding: 0 1.2rem 1.2rem;
}

.program-item.is-open .program-content {
  display: block;
}

.booking-card {
  position: sticky;
  top: calc(var(--nav-height) + 1rem);
  padding: 1.4rem;
}

.inclusions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.inclusions ul {
  margin: 0;
  padding-left: 1rem;
}

.map-frame {
  width: 100%;
  min-height: 300px;
  border: 0;
  border-radius: var(--radius-lg);
}

@media (max-width: 980px) {
  .detail-layout,
  .inclusions {
    grid-template-columns: 1fr;
  }
}
