/* Alpenlodge Seasons Pages – Hero + Gallery + Lightbox
   Keep it simple and predictable. No booking iframe remnants.
*/

.al-season-wrap{padding:28px 0 44px}

/* HERO */
.al-season-hero{position:relative;border-radius:22px;overflow:hidden;min-height:360px;background:#e9ecef;box-shadow:0 18px 40px rgba(0,0,0,.18)}
.al-season-hero img{width:100%;height:100%;object-fit:cover;position:absolute;top:0;right:0;bottom:0;left:0}
.al-season-hero::after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(0,0,0,.18),rgba(0,0,0,.55))}
.al-season-hero .inner{position:relative;z-index:2;padding:54px 42px;max-width:980px;margin:0 auto;text-align:center}
.al-season-hero .kicker{letter-spacing:.12em;text-transform:uppercase;font-weight:600;font-size:12px;opacity:.9;color:#eaf2ff}
.al-season-hero h1{margin:10px 0 10px;color:#fff;font-size:44px;line-height:1.05}
.al-season-hero p{margin:0 auto 18px;color:rgba(255,255,255,.92);font-size:18px;max-width:720px}
.al-season-hero .cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:center;margin-top:14px}
.al-season-hero .cta-row a{display:inline-flex;align-items:center;justify-content:center;height:44px;padding:0 18px;border-radius:999px;text-decoration:none;font-weight:600}
.al-season-hero .cta-primary{background:#6bbf7a;color:#0b1a12}
.al-season-hero .cta-secondary{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);color:#fff}

/* TIP CARDS */
.al-season-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.al-season-card{background:#fff;border-radius:16px;padding:16px 16px 14px;box-shadow:0 10px 22px rgba(0,0,0,.08)}
.al-season-card h3{margin:0 0 6px;font-size:16px}
.al-season-card p{margin:0;font-size:14px;line-height:1.45;color:#333}

/* GALLERY GRID */
.al-season-gallery{margin-top:18px}
.al-season-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.al-season-grid a{position:relative;display:block;border-radius:16px;overflow:hidden;aspect-ratio:4/3;background:#f1f3f5}
.al-season-grid img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease}
.al-season-grid a:hover img{transform:scale(1.03)}
.al-season-grid .badge{position:absolute;left:10px;bottom:10px;background:rgba(0,0,0,.55);color:#fff;font-size:12px;padding:6px 10px;border-radius:999px;backdrop-filter:blur(6px)}

/* LIGHTBOX */
#al-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.78);display:none;z-index:99999}
#al-lightbox.is-open{display:flex;align-items:center;justify-content:center;padding:28px}
#al-lightbox .frame{position:relative;max-width:min(1100px,96vw);max-height:86vh}
#al-lightbox img{max-width:100%;max-height:86vh;border-radius:18px;display:block}
#al-lightbox .close{position:absolute;top:-14px;right:-14px;width:44px;height:44px;border-radius:999px;border:0;background:#fff;color:#111;font-size:22px;cursor:pointer;box-shadow:0 12px 26px rgba(0,0,0,.35)}
#al-lightbox .caption{margin-top:10px;color:#fff;font-size:14px;opacity:.9;text-align:center}

/* --- Seasons pages (BEM markup used in aktivitaeten-*.html) --- */
.al-season-hero__content{
  position:relative;
  z-index:2;
  padding:54px 42px;
  max-width:980px;
  margin:0 auto;
  text-align:center;
}
.al-season-hero__kicker{letter-spacing:.14em;text-transform:uppercase;font-size:12px;color:rgba(255,255,255,.8)}
.al-season-hero__title{margin:8px 0 10px;color:#fff;font-size:46px;line-height:1.05}
.al-season-hero__lead{margin:0 auto 18px;color:rgba(255,255,255,.92);font-size:18px;max-width:720px}
.al-season-hero__cta{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap;justify-content:center;align-items:center}

/* RESPONSIVE */
@media (max-width: 980px){
  .al-season-hero .inner{padding:42px 22px}
  .al-season-hero h1{font-size:36px}
  .al-season-cards{grid-template-columns:1fr}
  .al-season-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 560px){
  .al-season-hero{min-height:320px}
  .al-season-hero h1{font-size:30px}
  .al-season-hero p{font-size:16px}
  /* Keep a real grid on mobile: 2 columns, then 1 on very small screens */
  .al-season-grid{grid-template-columns:repeat(2,1fr); gap:10px}
}

@media (max-width: 380px){
  .al-season-grid{grid-template-columns:1fr}
}

/* Season tabs inside hero (same feel as homepage) */
.al-season-hero__tabs{
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:14px;
  padding:10px 12px;
  background: rgba(0,0,0,.22);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
}
.al-season-tab{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background: rgba(0,0,0,.35);
  color:#fff;
  text-decoration:none;
  font-weight:700;
  font-size:14px;
  letter-spacing:.2px;
  border: 1px solid rgba(255,255,255,.18);
}
.al-season-tab:hover{ background: rgba(0,0,0,.5); }
.al-season-tab.is-active{
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.35);
}
@media (max-width: 520px){
  .al-season-hero__tabs{ gap:8px; padding:8px 10px; }
  .al-season-tab{ padding:8px 12px; font-size:13px; }
}
