/* Chalet-Seite — seiten-spezifische Layouts.
   Alle Klassen sind mit `.chalet-` geprefixt. Verwendet ausschließlich Tokens
   aus tokens.css sowie die shared Helper aus base.css / sections.css. */

/* --- Hero -------------------------------------------------------------- */

.chalet-hero {
  position: relative;
  padding-block: var(--space-8) var(--space-9);
  background: var(--color-surface-soft);
  overflow: hidden;
}

.chalet-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  align-items: center;
  gap: var(--space-8);
}

.chalet-hero__copy h1 {
  font-family: var(--font-display);
  font-size: var(--fs-4xl);
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-5);
}

.chalet-hero__lead {
  font-size: var(--fs-lg);
  color: var(--color-text-muted);
  max-width: 52ch;
  margin: 0 0 var(--space-6);
}

.chalet-hero__lead a {
  color: var(--color-primary-dark);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.chalet-hero__cta {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.chalet-hero__media picture,
.chalet-hero__media img {
  width: 100%;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
}

@media (max-width: 900px) {
  .chalet-hero {
    padding-block: var(--space-7) var(--space-8);
  }
  .chalet-hero__inner {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
  .chalet-hero__copy h1 {
    font-size: var(--fs-3xl);
  }
}

/* --- Intro (Text + 2 Info-Karten + 5-Zimmer-Preview) ------------------- */

.chalet-intro__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  gap: var(--space-8);
  align-items: start;
}

.chalet-intro__text .prose h3 {
  font-family: var(--font-body);
  font-size: var(--fs-xl);
  margin-top: 0;
}

.chalet-info-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-top: var(--space-6);
}

.chalet-info-card {
  background: var(--color-surface-soft);
  padding: var(--space-6);
  border-radius: var(--radius-md);
}

.chalet-info-card__title {
  font-size: var(--fs-md);
  font-weight: 600;
  margin: 0 0 var(--space-3);
  color: var(--color-text);
}

.chalet-info-card p {
  margin: 0;
  color: var(--color-text-muted);
}

.chalet-intro__rooms {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.chalet-intro__rooms .chalet-gallery__item--wide {
  grid-column: 1 / -1;
}

@media (max-width: 900px) {
  .chalet-intro__grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
  .chalet-info-cards {
    grid-template-columns: 1fr;
  }
}

/* --- 3-Spalten-Feature-Block ------------------------------------------- */

.chalet-features {
  background: var(--color-surface-soft);
}

.chalet-features__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-6);
}

.chalet-feature {
  background: var(--color-surface);
  padding: var(--space-6);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-3);
}

.chalet-feature__number {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  color: var(--color-primary);
  line-height: 1;
}

.chalet-feature__title {
  font-size: var(--fs-lg);
  font-weight: 600;
  margin: 0;
  color: var(--color-text);
}

.chalet-feature p {
  margin: 0;
  color: var(--color-text-muted);
}

.chalet-feature__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-primary-dark);
  font-weight: 600;
  text-decoration: none;
  margin-top: auto;
}

.chalet-feature__link:hover,
.chalet-feature__link:focus {
  text-decoration: underline;
}

.chalet-feature__badge {
  display: inline-block;
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  margin-top: auto;
}

@media (max-width: 900px) {
  .chalet-features__grid {
    grid-template-columns: 1fr;
  }
}

/* --- Galerie ----------------------------------------------------------- */

.chalet-gallery__header {
  margin-bottom: var(--space-6);
}

.chalet-gallery__header h2 {
  font-size: var(--fs-2xl);
  margin-top: 0;
}

.chalet-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-4);
}

.chalet-gallery__item {
  position: relative;
  display: block;
  padding: 0;
  margin: 0;
  border: 0;
  background: var(--color-surface-soft);
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  aspect-ratio: 4 / 3;
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.chalet-gallery__item:hover,
.chalet-gallery__item:focus-visible {
  box-shadow: var(--shadow-md);
}

.chalet-gallery__item picture,
.chalet-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}

.chalet-gallery__item:hover img,
.chalet-gallery__item:focus-visible img {
  transform: scale(1.04);
}

/* --- Checkliste -------------------------------------------------------- */

.chalet-checklist__header {
  margin-bottom: var(--space-6);
}

.chalet-checklist__header h2 {
  font-size: var(--fs-2xl);
  margin-top: 0;
}

.chalet-checklist {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-6);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-3) var(--space-5);
}

.chalet-checklist li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  color: var(--color-text);
  font-size: var(--fs-md);
  line-height: 1.5;
}

.chalet-checklist__icon {
  color: var(--color-primary);
  flex-shrink: 0;
  margin-top: 3px;
}

.chalet-checklist--secondary {
  margin-top: var(--space-3);
  margin-bottom: var(--space-4);
}

.chalet-checklist__sub {
  font-weight: 600;
  color: var(--color-text);
  margin-top: var(--space-6);
  margin-bottom: var(--space-3);
}

.chalet-checklist__note {
  color: var(--color-text-muted);
  font-style: italic;
  margin-top: var(--space-4);
}

/* --- Abschluss-CTA ----------------------------------------------------- */

.chalet-cta {
  background: var(--color-primary);
  color: var(--color-on-dark);
  text-align: center;
}

.chalet-cta__inner {
  max-width: 760px;
}

.chalet-cta h2 {
  color: var(--color-on-dark);
  font-size: var(--fs-2xl);
  margin-top: 0;
}

.chalet-cta p {
  color: rgba(255, 255, 255, 0.92);
  font-size: var(--fs-lg);
  margin-bottom: var(--space-6);
}

.chalet-cta .btn--primary {
  background: var(--color-surface);
  color: var(--color-primary-dark);
}

.chalet-cta .btn--primary:hover,
.chalet-cta .btn--primary:focus {
  background: var(--color-text);
  color: var(--color-on-dark);
}

/* --- Lightbox ---------------------------------------------------------- */

html.is-lightbox-open {
  overflow: hidden;
}

.chalet-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(20, 38, 28, 0.93);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  padding: var(--space-5);
}

.chalet-lightbox[hidden] {
  display: none;
}

.chalet-lightbox__figure {
  margin: 0;
  max-width: 92vw;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}

.chalet-lightbox__image {
  max-width: 92vw;
  max-height: 84vh;
  object-fit: contain;
  border-radius: var(--radius-md);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
}

.chalet-lightbox__caption {
  color: var(--color-on-dark);
  font-size: var(--fs-sm);
  text-align: center;
  margin: 0;
  max-width: 80ch;
}

.chalet-lightbox__close,
.chalet-lightbox__prev,
.chalet-lightbox__next {
  position: absolute;
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  color: var(--color-on-dark);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.15s ease;
}

.chalet-lightbox__close:hover,
.chalet-lightbox__prev:hover,
.chalet-lightbox__next:hover,
.chalet-lightbox__close:focus-visible,
.chalet-lightbox__prev:focus-visible,
.chalet-lightbox__next:focus-visible {
  background: rgba(255, 255, 255, 0.3);
}

.chalet-lightbox__close {
  top: var(--space-5);
  right: var(--space-5);
}

.chalet-lightbox__prev {
  left: var(--space-5);
  top: 50%;
  transform: translateY(-50%);
}

.chalet-lightbox__next {
  right: var(--space-5);
  top: 50%;
  transform: translateY(-50%);
}

@media (max-width: 600px) {
  .chalet-lightbox__prev {
    left: var(--space-3);
  }
  .chalet-lightbox__next {
    right: var(--space-3);
  }
  .chalet-lightbox__close {
    top: var(--space-3);
    right: var(--space-3);
  }
  .chalet-lightbox__image {
    max-height: 74vh;
  }
}
