/* ============================================================
   BURG LEUK — Website (Maison 13 · Contemporary Alpine Social Club)
   Built on the bound design system. Composition only — the DS
   primitives bring their own styles. Maison 13 palette:
   warm paper + Noir evening + Burgunderrot accent, contour textures,
   single-hue gradients, soft glow. Modern, never medieval.
   ============================================================ */

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:clip; }
body{ margin:0; overflow-x:clip; max-width:100%; }
img{ display:block; max-width:100%; height:auto; }

.site{
  font-family:var(--font-body);
  color:var(--text-body);
  background:var(--surface-page);
  --site-accent: var(--apricot-700);     /* editorial accent (tweakable) */
  --site-accent-on-dark: var(--apricot-300);
  --disp-weight: 700;
  /* ONE GEOMETRY: rectangles are sharp (0). Circles only for logo / avatar / “→” dots. */
  --radius-xs:0; --radius-sm:0; --radius-md:0; --radius-lg:0; --radius-xl:0; --radius-pill:0;
}

.wrap{ max-width:var(--container-xl); margin:0 auto; padding:0 48px; }

/* ---- type atoms ---- */
.eyebrow{ font-family:var(--font-display); font-size:var(--text-overline);
  letter-spacing:var(--tracking-overline); text-transform:uppercase; font-weight:600;
  color:var(--site-accent); display:inline-flex; align-items:center; gap:12px; margin:0; }
.eyebrow.on-dark{ color:var(--site-accent-on-dark); }
.eyebrow.line::before{ content:""; width:28px; height:1px; background:currentColor; opacity:.55; }
.display{ font-family:var(--font-display); font-weight:var(--disp-weight); line-height:var(--leading-tight);
  letter-spacing:var(--tracking-tight); margin:0; text-wrap:balance; }
.lead{ font-size:var(--text-lead); line-height:var(--leading-snug); color:var(--text-muted); margin:0; text-wrap:pretty; }

/* ============================================================
   NAV
   ============================================================ */
.nav{ position:fixed; inset:0 0 auto 0; z-index:50; height:78px; display:flex; align-items:center;
  transition:background .4s var(--ease-standard), border-color .4s, backdrop-filter .4s; border-bottom:1px solid transparent; }
.nav__in{ max-width:var(--container-xl); margin:0 auto; width:100%; padding:0 48px;
  display:flex; align-items:center; justify-content:space-between; gap:24px; }
.nav__brand{ display:flex; align-items:center; gap:12px; background:none; border:0; cursor:pointer; color:var(--nav-ink, #fff); }
.nav__brand img{ width:36px; height:36px; }
.nav__brand .bw{ display:flex; flex-direction:column; line-height:1; }
.nav__brand .bw b{ font-family:var(--font-display); font-weight:700; font-size:19px; letter-spacing:.02em; }
.nav__brand .bw span{ font-size:10px; letter-spacing:.22em; text-transform:uppercase; opacity:.66; margin-top:4px; }
.nav__links{ display:flex; gap:4px; }
.nav__links button, .nav__links a{ background:none; border:0; cursor:pointer; font-family:var(--font-body); font-size:var(--text-body-sm);
  font-weight:500; color:var(--nav-ink, #fff); opacity:.82; padding:8px 14px; border-radius:var(--radius-pill);
  position:relative; transition:opacity .2s, background .2s; text-decoration:none; }
.nav__links button:hover, .nav__links a:hover{ opacity:1; background:color-mix(in srgb, var(--nav-ink,#fff) 12%, transparent); }
.nav__links .nav__fan{ color:var(--apricot-400); opacity:1; font-weight:600; }
.nav.is-stuck .nav__links .nav__fan{ color:var(--apricot-700); }

/* burger button */
.burger{ width:46px; height:46px; border-radius:50%; border:1px solid color-mix(in srgb, var(--nav-ink,#fff) 40%, transparent);
  background:transparent; cursor:pointer; display:grid; place-content:center; gap:5px; transition:background .2s, border-color .2s; padding:0; }
.burger:hover{ background:color-mix(in srgb, var(--nav-ink,#fff) 12%, transparent); }
.burger span{ display:block; width:18px; height:1.6px; background:var(--nav-ink, #fff); border-radius:2px; transition:transform .3s var(--ease-out), opacity .2s; }
.burger.is-open{ border-color:rgba(255,255,255,.5); }
.burger.is-open span{ background:var(--nav-ink, #fff); }

/* full overlay menu (mounted only when open) */
.menu-ov{ position:fixed; inset:0; z-index:60; background:var(--gradient-depth); }
.menu-ov::before{ content:""; position:absolute; inset:0; background:var(--glow-depth); pointer-events:none; }
.menu-ov__in{ position:relative; z-index:1; max-width:var(--container-xl); margin:0 auto; min-height:100%;
  padding:140px 48px 56px; display:flex; flex-direction:column; }
.menu-ov__eyebrow{ font-family:var(--font-display); font-size:12px; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--apricot-300); }
.menu-ov__close{ position:absolute; top:34px; right:48px; width:40px; height:40px;
  background:transparent; border:0; cursor:pointer; display:grid; place-content:center; opacity:.85; transition:opacity .2s, transform .2s; }
.menu-ov__close:hover{ opacity:1; transform:rotate(90deg); }
.menu-ov__close span{ position:absolute; width:24px; height:2px; background:#fff; border-radius:2px; }
.menu-ov__close span:first-child{ transform:rotate(45deg); }
.menu-ov__close span:last-child{ transform:rotate(-45deg); }
@media (max-width:560px){ .menu-ov__close{ top:22px; right:24px; } }
.menu-ov__list{ list-style:none; margin:28px 0 0; padding:0; }
.menu-ov__list li{ border-top:1px solid var(--border-on-dark); }
@media (prefers-reduced-motion: no-preference){
  .menu-ov__list li{ opacity:0; transform:translateY(14px); animation:menuItem .5s var(--ease-out) forwards; animation-delay:calc(.06s + var(--mi) * .05s); }
}
@keyframes menuItem{ to{ opacity:1; transform:none; } }
.menu-ov__list li:last-child{ border-bottom:1px solid var(--border-on-dark); }
.menu-ov__list button, .menu-ov__list a{ width:100%; background:none; border:0; cursor:pointer; text-align:left; text-decoration:none;
  display:flex; align-items:center; justify-content:space-between; gap:20px; padding:clamp(16px,2.4vw,26px) 0;
  font-family:var(--font-display); font-weight:600; font-size:clamp(28px,5vw,56px); letter-spacing:-.02em; color:#fff;
  transition:color .2s, padding-left .25s var(--ease-out); }
.menu-ov__list button:hover, .menu-ov__list a:hover{ color:var(--apricot-300); padding-left:14px; }
.menu-ov__list a.is-fan{ color:var(--apricot-300); }
.menu-ov__list i{ width:24px; height:24px; opacity:.5; transition:opacity .2s, transform .25s var(--ease-out); }
.menu-ov__list button:hover i, .menu-ov__list a:hover i{ opacity:1; transform:translateX(5px); }
.menu-ov__foot{ margin-top:auto; padding-top:40px; display:flex; gap:28px; flex-wrap:wrap; align-items:center;
  font-family:var(--font-mono); font-size:13px; color:var(--blau-200); }
.menu-ov__foot a:hover{ color:#fff; }
@media (max-width:560px){ .menu-ov__in{ padding:110px 24px 40px; } }
.nav__right{ display:flex; align-items:center; gap:10px; }
.nav__fanbtn{ font-family:var(--font-display); font-weight:600; font-size:13px; letter-spacing:.02em; color:#fff;
  padding:10px 18px; border-radius:var(--radius-pill); border:1px solid transparent; background:var(--apricot-600);
  text-decoration:none; transition:all .2s; white-space:nowrap; }
.nav__fanbtn:hover{ background:var(--apricot-700); color:#fff; }
.nav.is-stuck .nav__fanbtn{ color:#fff; background:var(--apricot-600); }
.nav.is-stuck .nav__fanbtn:hover{ background:var(--apricot-700); }
@media (max-width:480px){
  .nav__fanbtn{ display:none; }
  .nav__right button, .nav__right a{ min-height:44px; } /* Tap-Flächen mindestens 44px */
}
/* over hero = light ink; scrolled = solid */
.nav[data-over="hero"]{ --nav-ink:#fff; }
.nav.is-stuck{ background:color-mix(in srgb, var(--blau-900) 90%, transparent); backdrop-filter:blur(14px) saturate(1.2);
  border-bottom-color:var(--border-on-dark); --nav-ink:var(--kalk-50); }
[data-stimmung="tag"] .nav.is-stuck{ background:color-mix(in srgb, var(--kalk-50) 90%, transparent);
  border-bottom-color:var(--hairline); --nav-ink:var(--ink-900); }

/* ============================================================
   HERO — full-bleed photographic (castle as backdrop / the view),
   noir scrim, contour + crosshairs, copy + meta bar overlaid
   ============================================================ */
.hero{ position:relative; min-height:100vh; display:flex; flex-direction:column; justify-content:flex-end;
  overflow:hidden; color:#fff; }
.hero__bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:32% 48%;
  transform:scale(1.05); will-change:transform; }
.hero__scrim{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(14,24,34,.42) 0%, rgba(14,24,34,0) 26%, rgba(14,24,34,0) 46%, rgba(14,24,34,.86) 100%),
    linear-gradient(90deg, rgba(14,24,34,.5) 0%, rgba(14,24,34,0) 58%); }
.hero__pat{ position:absolute; inset:0; z-index:1; width:100%; height:100%; object-fit:cover; opacity:.16; mix-blend-mode:soft-light; pointer-events:none; }
.hero__cross{ position:absolute; z-index:2; width:16px; height:16px; opacity:.7; }
.hero__cross::before, .hero__cross::after{ content:""; position:absolute; background:rgba(255,255,255,.7); }
.hero__cross::before{ left:7px; top:0; width:1px; height:16px; }
.hero__cross::after{ top:7px; left:0; height:1px; width:16px; }
.hero__cross.tl{ top:96px; left:48px; } .hero__cross.tr{ top:96px; right:48px; }
.hero__coord{ position:absolute; z-index:2; top:92px; font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; color:rgba(255,255,255,.7); }
.hero__coord.cl{ left:72px; } .hero__coord.cr{ right:72px; }
.hero__in{ position:relative; z-index:2; width:100%; max-width:var(--container-xl); margin:0 auto; padding:0 48px 44px; }
.hero__copy{ max-width:760px; will-change:transform, opacity; }

/* ============================================================
   SCROLL PROGRESS — thin burgundy line, top of viewport
   ============================================================ */
.scrollprog{ position:fixed; top:0; left:0; right:0; height:2px; z-index:120; transform:scaleX(0); transform-origin:0 50%;
  background:linear-gradient(90deg, var(--apricot-500), var(--apricot-400)); pointer-events:none; }
.hero__title{ font-size:clamp(52px, 7.4vw, 122px); color:#fff; margin:18px 0 0; max-width:12ch; text-shadow:0 2px 40px rgba(0,0,0,.28); }
.hero__title .a{ background:linear-gradient(135deg, var(--apricot-200) 0%, var(--apricot-400) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero__sub{ font-size:var(--text-lead); line-height:var(--leading-snug); color:rgba(255,255,255,.9); margin:26px 0 0; max-width:46ch; }
.hero__cta{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero__bar{ position:relative; z-index:2; max-width:var(--container-xl); margin:36px auto 0; width:100%; padding:22px 48px 0;
  border-top:1px solid rgba(255,255,255,.22); display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.hero__bar-meta{ display:flex; gap:18px; align-items:center; flex-wrap:wrap; color:rgba(255,255,255,.86); font-size:var(--text-body-sm); }
.hero__bar-meta .mi{ display:inline-flex; align-items:center; gap:7px; }
.hero__bar-meta .mi svg, .hero__bar-meta .mi i{ width:16px; height:16px; }
.hero__bar-coord{ font-family:var(--font-mono); font-size:12px; letter-spacing:.08em; color:rgba(255,255,255,.7); }
.hero__scroll{ position:absolute; right:48px; top:50%; z-index:2; transform:translateY(-50%); display:flex; flex-direction:column; align-items:center; gap:12px;
  font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.66); writing-mode:vertical-rl; }
.hero__scroll i{ display:block; width:1px; height:48px; background:linear-gradient(180deg, rgba(255,255,255,.7), transparent);
  animation:scrollN 2.2s var(--ease-in-out) infinite; transform-origin:top; }
@keyframes scrollN{ 0%,100%{ transform:scaleY(.3); opacity:.4 } 50%{ transform:scaleY(1); opacity:1 } }
[data-stimmung="tag"] .hero__scrim{
  background:
    linear-gradient(180deg, rgba(250,248,244,.18) 0%, rgba(20,16,9,0) 30%, rgba(20,16,9,.12) 52%, rgba(20,16,9,.7) 100%),
    linear-gradient(90deg, rgba(20,16,9,.34) 0%, rgba(20,16,9,0) 60%); }
[data-stimmung="tag"] .hero__bg{ object-position:32% 42%; }
@media (max-width:1000px){
  .hero__in{ padding:0 32px 40px; } .hero__bar{ padding:22px 32px 0; }
  .hero__cross.tl, .hero__cross.tr, .hero__coord, .hero__scroll{ display:none; }
}

/* ============================================================
   SIGHTLINE — the elevation / valley line (the "Höhen")
   ============================================================ */
.sightline{ background:var(--surface-page); border-bottom:1px solid var(--hairline); }
.sightline__in{ max-width:var(--container-xl); margin:0 auto; padding:22px 48px; display:flex; align-items:center; gap:22px;
  font-family:var(--font-display); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-subtle); }
.sightline__c{ color:var(--site-accent); font-weight:600; white-space:nowrap; }
.sightline__rule{ flex:1; height:22px; position:relative; opacity:.7; }
.sightline__rule svg{ width:100%; height:100%; }
/* Regionen-Leiste auf Mobile ausblenden — bricht sonst um (Desktop unberührt). */
@media (max-width:480px){ .sightline{ display:none; } }

/* ============================================================
   MARQUEE — cultural ticker (funk / energy), hard-edged band
   ============================================================ */
.marquee{ background:var(--blau-900); color:var(--kalk-50); border-top:1px solid var(--blau-700); border-bottom:1px solid var(--blau-700); overflow:hidden; }
.marquee__track{ display:flex; align-items:center; width:max-content; white-space:nowrap; padding:16px 0; animation:marq 26s linear infinite; }
.marquee__track span{ font-family:var(--font-display); font-weight:700; font-size:clamp(20px,2.3vw,30px); letter-spacing:-.005em;
  text-transform:uppercase; display:inline-flex; align-items:center; padding:0 30px; }
.marquee__track span::after{ content:"•"; color:var(--apricot-400); margin-left:30px; font-size:.7em; }
@keyframes marq{ from{ transform:translateX(0) } to{ transform:translateX(-50%) } }
.marquee:hover .marquee__track{ animation-play-state:paused; }
@media (prefers-reduced-motion: reduce){ .marquee__track{ animation:none; } }

/* ============================================================
   SECTION scaffold
   ============================================================ */
.sec{ padding:clamp(80px,9vw,118px) 0; }
.sec--tight{ padding-top:0; }
.sechead{ display:grid; grid-template-columns:auto 1fr auto; align-items:end; gap:28px;
  border-top:1px solid var(--hairline); padding-top:22px; margin-bottom:48px; }
.sechead__idx{ font-family:var(--font-mono); font-size:13px; color:var(--site-accent); letter-spacing:.06em; padding-top:6px; font-variant-numeric:tabular-nums; }
.sechead__main{ display:flex; flex-direction:column; gap:10px; }
.sechead__title{ font-family:var(--font-display); font-weight:var(--disp-weight); font-size:var(--text-display-lg);
  line-height:1.02; letter-spacing:var(--tracking-tight); color:var(--text-strong); margin:0; }
.sechead__action{ align-self:end; padding-bottom:4px; }
.grid3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }

/* ============================================================
   EVENTS — asymmetric editorial grid (featured + structured list)
   ============================================================ */
.evgrid{ display:grid; grid-template-columns:7fr 5fr; gap:44px; align-items:start; }
.evfeat{ cursor:pointer; background:var(--surface-raised); display:flex; flex-direction:column; }
.evfeat__media{ position:relative; margin:0; aspect-ratio:16/10; overflow:hidden; }
.evfeat__media img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease-out); }
.evfeat:hover .evfeat__media img{ transform:scale(1.05); }
.evfeat__date{ position:absolute; top:0; left:0; background:var(--surface-page); padding:13px 19px; display:flex; align-items:baseline; gap:9px; }
.evfeat__date b{ font-family:var(--font-display); font-weight:700; font-size:36px; line-height:1; color:var(--text-strong); }
.evfeat__date em{ font-family:var(--font-mono); font-style:normal; font-size:12px; color:var(--text-muted); text-transform:uppercase; }
.evfeat__badge{ position:absolute; top:0; right:0; background:var(--apricot-700); color:#fff; font-family:var(--font-display); font-weight:600; font-size:12px; letter-spacing:.04em; padding:9px 15px; }
.evfeat__body{ padding:30px 32px 34px; display:flex; flex-direction:column; gap:12px; }
.evfeat__cat{ font-family:var(--font-display); font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--site-accent); }
.evfeat__title{ font-family:var(--font-display); font-weight:700; font-size:clamp(28px,3vw,42px); line-height:1.0; letter-spacing:-.02em; color:var(--text-strong); margin:0; }
.evfeat__desc{ font-size:var(--text-body); color:var(--text-muted); line-height:1.6; margin:0; max-width:46ch; }
.evfeat__meta{ display:flex; gap:18px; flex-wrap:wrap; font-size:var(--text-body-sm); color:var(--text-strong); margin-top:4px; }
.evfeat__meta span{ display:inline-flex; align-items:center; gap:6px; } .evfeat__meta svg, .evfeat__meta i{ width:15px; height:15px; color:var(--site-accent); }
.evfeat__go{ margin-top:8px; display:inline-flex; align-items:center; gap:9px; font-family:var(--font-display); font-weight:600; font-size:14px; color:var(--site-accent); }
.evfeat__go svg, .evfeat__go i{ width:16px; height:16px; }
.evside{ display:flex; flex-direction:column; border-top:1px solid var(--ink-900); }
.evrow{ display:grid; grid-template-columns:54px 1fr auto; gap:20px; align-items:center; text-align:left;
  background:none; border:0; border-bottom:1px solid var(--hairline); cursor:pointer; padding:22px 4px;
  transition:padding .25s var(--ease-standard), background .25s; }
.evrow:hover{ background:var(--kalk-100); padding-left:16px; padding-right:16px; }
.evrow__date{ display:flex; flex-direction:column; align-items:center; }
.evrow__date b{ font-family:var(--font-display); font-weight:700; font-size:30px; line-height:1; color:var(--text-strong); }
.evrow__date em{ font-family:var(--font-mono); font-style:normal; font-size:10px; text-transform:uppercase; color:var(--text-subtle); margin-top:3px; }
.evrow__main{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.evrow__cat{ font-family:var(--font-display); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--site-accent); }
.evrow__name{ font-family:var(--font-display); font-weight:600; font-size:19px; color:var(--text-strong); }
.evrow__meta{ font-size:13px; color:var(--text-muted); }
.evrow__go{ width:36px; height:36px; border:1px solid var(--border-default); border-radius:50%; display:grid; place-items:center; color:var(--text-strong); transition:background .2s,color .2s,border-color .2s; }
.evrow:hover .evrow__go{ background:var(--site-accent); border-color:var(--site-accent); color:#fff; }
.evrow__go svg, .evrow__go i{ width:15px; height:15px; }
.evside__foot{ display:flex; justify-content:space-between; align-items:center; gap:16px; padding-top:22px; }
.evside__coord{ font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; color:var(--text-subtle); }
.evside__all{ background:none; border:0; cursor:pointer; display:inline-flex; align-items:center; gap:8px; font-family:var(--font-display); font-weight:600; font-size:13px; color:var(--site-accent); }
.evside__all svg, .evside__all i{ width:15px; height:15px; }
@media (max-width:900px){ .evgrid{ grid-template-columns:1fr; gap:30px; } }

/* Promo-Link zur Fan Zone (Spielkalender) — gut sichtbar in der Programm-Section */
.promo{ display:flex; align-items:center; justify-content:space-between; gap:18px 40px; flex-wrap:wrap;
  margin-bottom:40px; padding:24px clamp(22px,3vw,34px); background:var(--ink-900); color:var(--kalk-50);
  text-decoration:none; transition:background .25s var(--ease-standard); }
.promo:hover{ background:var(--apricot-700); }
.promo__l{ display:flex; flex-direction:column; gap:7px; min-width:0; }
.promo__eyebrow{ font-family:var(--font-mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--apricot-300); }
.promo:hover .promo__eyebrow{ color:var(--kalk-100); }
.promo__title{ font-family:var(--font-display); font-weight:700; font-size:clamp(20px,2.4vw,28px); line-height:1.08; letter-spacing:-.01em; }
.promo__cta{ flex:none; display:inline-flex; align-items:center; gap:10px; white-space:nowrap;
  font-family:var(--font-display); font-weight:600; font-size:15px; padding:13px 24px;
  border:1px solid var(--kalk-50); border-radius:var(--radius-pill); }
.promo__cta svg, .promo__cta i{ width:16px; height:16px; }
@media (max-width:560px){ .promo{ flex-direction:column; align-items:flex-start; } .promo__cta{ width:100%; justify-content:center; } }

/* ============================================================
   STATEMENT BAND — Noir gradient + contour + glow
   ============================================================ */
.band{ position:relative; background:var(--gradient-dusk); overflow:hidden; }
.band::before{ content:""; position:absolute; inset:0; background:var(--glow-light); pointer-events:none; }
.band__pat{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.18; }
.band__in{ position:relative; z-index:1; max-width:var(--container-xl); margin:0 auto; padding:clamp(80px,10vw,128px) 48px; text-align:center; }
.band__q{ font-family:var(--font-display); font-weight:600; font-size:var(--text-display-lg); line-height:1.1;
  letter-spacing:var(--tracking-snug); color:#fff; margin:20px auto 0; max-width:20ch; text-wrap:balance; }
.band__q .a{ color:var(--apricot-400); }

/* ============================================================
   DER ORT — castle as context (real photo), modern copy
   ============================================================ */
.ort .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.ort__media{ position:relative; }
.ort__media img{ position:relative; z-index:1; width:100%; aspect-ratio:4/5; object-fit:cover; box-shadow:var(--shadow-lg); will-change:transform; }
.ort__media{ overflow:hidden; }
/* corner-tick frame (consistent cartographic motif) */
.ort__cnr{ position:absolute; z-index:2; font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; color:#fff; text-shadow:0 1px 6px rgba(0,0,0,.6); }
.ort__cnr.tl{ top:14px; left:16px; }
.ort__cnr.br{ bottom:14px; right:16px; color:var(--apricot-200); }
.ort__body h2{ font-family:var(--font-display); font-weight:var(--disp-weight); font-size:var(--text-display-lg);
  line-height:1.02; letter-spacing:var(--tracking-tight); color:var(--text-strong); margin:18px 0 0; }
.ort__body .lead{ margin-top:22px; }
.ort__facts{ display:flex; flex-direction:column; gap:14px; margin:30px 0; }
.ort__facts > div{ display:flex; align-items:center; gap:12px; font-size:var(--text-body); color:var(--text-strong); }
.ort__facts svg, .ort__facts i{ width:18px; height:18px; color:var(--site-accent); flex:none; }
.ort__host{ display:flex; align-items:center; gap:14px; margin:6px 0 30px; padding-top:22px; border-top:1px solid var(--hairline); }
.ort__host-t b{ font-family:var(--font-display); font-weight:600; font-size:16px; color:var(--text-strong); display:block; line-height:1.1; }
.ort__host-t span{ font-size:13px; color:var(--text-muted); }

/* ============================================================
   MODULAR GRID — "Was dich erwartet" / Räume (bordered, sovereign)
   ============================================================ */
.modgrid{ display:grid; grid-template-columns:repeat(3,1fr); border:1px solid var(--hairline);
  border-radius:var(--radius-lg); overflow:hidden; background:var(--surface-raised); }
.modgrid.cols4{ grid-template-columns:repeat(4,1fr); }
.modcell{ position:relative; padding:38px 32px 34px; border-right:1px solid var(--hairline); cursor:default;
  transition:background var(--duration-base) var(--ease-standard); display:flex; flex-direction:column; min-height:230px; }
.modcell:last-child{ border-right:0; }
.modcell__num{ font-family:var(--font-mono); font-size:12px; color:var(--text-subtle); }
.modcell__icon{ position:absolute; top:34px; right:30px; color:var(--salbei-700); transition:transform var(--duration-base) var(--ease-out), color var(--duration-base); }
.modcell__icon svg, .modcell__icon i{ width:24px; height:24px; }
.modcell__title{ font-family:var(--font-display); font-weight:var(--disp-weight); font-size:var(--text-h2); color:var(--text-strong);
  margin:26px 0 10px; line-height:1.04; letter-spacing:var(--tracking-snug); white-space:pre-line; }
.modcell__text{ font-size:var(--text-body-sm); color:var(--text-muted); margin:0; line-height:var(--leading-normal); max-width:26ch; }
.modcell__cap{ margin-top:auto; padding-top:18px; font-family:var(--font-display); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-subtle); }
.modcell:hover{ background:var(--kalk-100); }
.modcell:hover .modcell__icon{ transform:translate(3px,-3px); color:var(--site-accent); }

/* ============================================================
   ATMOSPHERE — full-bleed people moment (image-slot)
   ============================================================ */
.atmos{ position:relative; min-height:74vh; display:flex; align-items:flex-end; overflow:hidden; background:var(--blau-900); }
.atmos image-slot{ position:absolute; inset:0; width:100%; height:100%; }
.atmos__grad{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(20,16,9,.3) 0%, transparent 32%, transparent 50%, rgba(20,16,9,.82) 100%); }
.atmos__in{ position:relative; z-index:2; max-width:var(--container-xl); margin:0 auto; width:100%; padding:0 48px 64px; color:#fff; }
.atmos__q{ font-family:var(--font-display); font-weight:600; font-size:clamp(34px,4.6vw,64px); line-height:1.04;
  letter-spacing:var(--tracking-tight); max-width:16ch; margin:0; }
.atmos__cap{ margin-top:18px; font-size:var(--text-body-sm); color:rgba(255,255,255,.78); display:inline-flex; align-items:center; gap:8px; }

/* ============================================================
   VISIT + NEWSLETTER
   ============================================================ */
.visit .wrap{ display:grid; grid-template-columns:1.05fr .95fr; gap:64px; align-items:center; }
.visit h2{ font-family:var(--font-display); font-weight:var(--disp-weight); font-size:var(--text-display-lg);
  line-height:1.02; letter-spacing:var(--tracking-tight); color:var(--text-strong); margin:18px 0 0; }
.visit .lead{ margin-top:22px; max-width:40ch; }
.visit__facts{ display:flex; flex-direction:column; gap:0; margin-top:34px; }
.visit__facts .r{ display:grid; grid-template-columns:140px 1fr; gap:20px; padding:18px 0; border-top:1px solid var(--hairline); }
.visit__facts .r span{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--text-subtle); padding-top:4px; }
.visit__facts .r b{ font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--text-strong); }
.visit__facts .r b small{ display:block; font-family:var(--font-body); font-weight:400; font-size:14px; color:var(--text-muted); margin-top:3px; letter-spacing:0; text-transform:none; }
.visit__cta{ margin-top:30px; display:flex; gap:14px; flex-wrap:wrap; }
.news{ position:relative; background:var(--gradient-depth); border-radius:var(--radius-xl); padding:48px; overflow:hidden;
  display:grid; grid-template-columns:1.2fr .8fr; gap:40px; align-items:center; }
.news::before{ content:""; position:absolute; inset:0; background:var(--glow-depth); pointer-events:none; }
.news__pat{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.16; }
.news__copy{ position:relative; z-index:1; }
.news h3{ font-family:var(--font-display); font-weight:var(--disp-weight); font-size:var(--text-h1); color:#fff; margin:14px 0 0; letter-spacing:var(--tracking-snug); }
.news p{ color:var(--blau-200); font-size:var(--text-body); line-height:var(--leading-normal); margin:12px 0 0; max-width:36ch; }
.news__form{ position:relative; z-index:1; background:var(--surface-page); padding:24px; border-radius:var(--radius-lg); display:flex; flex-direction:column; gap:14px; }
@media (max-width:760px){ .news{ grid-template-columns:1fr; gap:24px; } }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background:var(--blau-900); color:var(--blau-200); padding:64px 0 32px; position:relative; overflow:hidden; }
.foot__pat{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.08; }
.foot .wrap{ position:relative; z-index:1; }
.foot__big{ font-family:var(--font-display); font-weight:var(--disp-weight); font-size:clamp(38px,6vw,96px); line-height:.98;
  letter-spacing:var(--tracking-tight); color:#fff; max-width:13ch; }
.foot__big .a{ color:var(--apricot-400); }
.foot__grid{ margin-top:64px; display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid var(--border-on-dark); }
.foot__brand img{ width:48px; margin-bottom:18px; }
.foot__brand p{ font-size:var(--text-body-sm); line-height:var(--leading-normal); max-width:30ch; margin:0; color:var(--blau-200); }
.foot__col h5{ font-family:var(--font-display); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--apricot-400); margin:0 0 14px; }
.foot__col a{ display:flex; align-items:center; gap:8px; font-size:var(--text-body-sm); color:var(--blau-200); text-decoration:none; padding:5px 0; cursor:pointer; transition:color .2s; }
.foot__col a:hover{ color:#fff; }
.foot__col svg{ width:15px; height:15px; }
.foot__bot{ margin-top:24px; display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; font-family:var(--font-mono); font-size:12px; color:var(--blau-300); }
.foot__bot .a{ color:var(--kalk-100); }
.foot__credit{ color:var(--blau-400); text-align:center; }
.foot__link{ color:var(--blau-200); cursor:pointer; }
.foot__link:hover{ color:#fff; }

/* ============================================================
   AGENDA — editorial programme list (v1 device: big date numbers)
   ============================================================ */
/* calendar-style programme header (big month + year + month nav) */
.agenda__head{ border-top:1px solid var(--ink-900); padding-top:22px; margin-bottom:38px; }
.agenda__cal{ display:grid; grid-template-columns:auto 1fr auto; align-items:baseline; gap:24px; margin-top:14px; }
.agenda__month{ font-family:var(--font-display); font-weight:700; font-size:clamp(48px,8vw,112px); line-height:.84; letter-spacing:-.03em; color:var(--text-strong); }
.agenda__year{ font-family:var(--font-display); font-weight:300; font-size:clamp(36px,5.4vw,84px); line-height:.84; letter-spacing:-.02em; color:var(--text-subtle); }
.agenda__months{ display:flex; flex-wrap:wrap; gap:22px; align-self:center; justify-content:center; }
.agenda__months button{ background:none; border:0; cursor:pointer; font-family:var(--font-body); font-size:14px; color:var(--text-muted); letter-spacing:.02em; padding:4px 0; transition:color .2s; }
.agenda__months button:hover{ color:var(--site-accent); }
.agenda__list{ border-top:1px solid var(--hairline); }
.agenda__more{ display:inline-flex; align-items:center; gap:10px; margin-top:32px; padding:14px 26px; background:none;
  border:1px solid var(--border-default); border-radius:var(--radius-pill); font-family:var(--font-display); font-weight:600;
  font-size:14px; color:var(--text-strong); cursor:pointer; transition:background .2s, color .2s, border-color .2s; }
.agenda__more:hover{ background:var(--ink-900); color:var(--kalk-50); border-color:var(--ink-900); }
.agenda__more-n{ font-family:var(--font-mono); font-size:12px; color:var(--text-subtle); }
.agenda__more:hover .agenda__more-n{ color:var(--kalk-200); }
.arow{ display:grid; grid-template-columns:120px minmax(0,1fr) 132px 180px 40px; align-items:center; gap:28px; width:100%;
  padding:24px 8px; border-bottom:1px solid var(--hairline); background:none; border-left:0; border-right:0; cursor:pointer; text-align:left;
  font-family:var(--font-body); transition:background var(--duration-base) var(--ease-standard), padding var(--duration-base) var(--ease-standard); }
.arow:hover{ background:var(--page-bg-2, var(--kalk-100)); padding-left:20px; padding-right:20px; }
.arow__date{ display:flex; align-items:baseline; gap:8px; font-family:var(--font-mono); font-size:12px; color:var(--text-subtle); letter-spacing:.04em; }
.arow__date b{ font-family:var(--font-display); font-weight:var(--disp-weight); font-size:34px; color:var(--text-strong); letter-spacing:-.01em; }
.arow__name{ font-family:var(--font-display); font-weight:600; font-size:var(--text-h3); color:var(--text-strong); }
.arow__name small{ display:block; font-family:var(--font-body); font-weight:400; font-size:var(--text-body-sm); color:var(--text-muted); margin-top:4px; }
.arow__tag{ justify-self:start; }
.arow__meta{ justify-self:start; text-align:left; font-size:var(--text-body-sm); color:var(--text-muted); white-space:normal; line-height:1.35; }
.arow__go{ display:grid; place-items:center; width:40px; height:40px; border-radius:50%; border:1.5px solid var(--border-default); color:var(--text-strong);
  transition:background .25s, color .25s, border-color .25s, transform .25s var(--ease-out); }
.arow__go svg, .arow__go i{ width:16px; height:16px; }
.arow:hover .arow__go{ background:var(--site-accent); border-color:var(--site-accent); color:var(--kalk-50); transform:translateX(3px); }
/* Fan Zone rows in the agenda */
.arow--fan .arow__date b{ color:var(--apricot-700); }
.arow--fan .arow__go{ border-color:var(--apricot-700); color:var(--apricot-700); }
.arow--fan:hover .arow__go{ background:var(--apricot-700); border-color:var(--apricot-700); color:var(--kalk-50); }
.arow__thumb{ display:none; }   /* Thumbnails entfernt (Agenda zeigt nur Datum/Titel/Info/Pfeil) */

/* Fan Zone teaser band */
.fanteaser{ padding:clamp(72px,9vw,118px) 0 0; }
.fanteaser__in{ position:relative; display:grid; grid-template-columns:1.4fr 0.9fr; gap:40px; align-items:center;
  max-width:var(--container-xl); margin:0 auto; padding:clamp(40px,6vw,76px) 48px; background:var(--gradient-ember); color:#fff;
  overflow:hidden; cursor:pointer; transition:filter .3s; }
.fanteaser__in:hover{ filter:brightness(1.06); }
.fanteaser__in, .fanteaser__in *{ text-decoration:none !important; }
.fanteaser__pat{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.16; mix-blend-mode:soft-light; }
.fanteaser__l, .fanteaser__r{ position:relative; z-index:1; }
.fanteaser__logo{ position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; gap:10px; justify-self:center; }
.fanteaser__mark{ width:clamp(54px,6vw,80px); height:auto; filter:drop-shadow(0 4px 22px rgba(0,0,0,.35)); }
.fanteaser__type{ display:flex; flex-direction:column; align-items:center; line-height:.84; font-family:var(--font-display); font-weight:800; letter-spacing:.01em; text-transform:uppercase; }
.fanteaser__type span{ font-size:clamp(38px,5vw,72px); }
.fanteaser__type .fz1{ color:#fff; }
.fanteaser__type .fz2{ background:linear-gradient(180deg,#fff,var(--apricot-200)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.fanteaser__title{ font-size:clamp(30px,4vw,56px); color:#fff; margin:14px 0 0; line-height:1.0; letter-spacing:-.02em; }
.fanteaser__sig{ margin:0; font-family:var(--font-display); font-weight:700; font-size:clamp(20px,2.4vw,30px); letter-spacing:.01em; line-height:1.05; color:#fff; }
.fanteaser__sub{ margin:18px 0 0; font-size:var(--text-body-lg); line-height:1.55; color:rgba(255,255,255,.92); max-width:44ch; }
.fanteaser__r{ display:flex; flex-direction:column; align-items:flex-start; gap:16px; }
.fanteaser__date{ font-family:var(--font-mono); font-size:14px; letter-spacing:.02em; color:var(--apricot-200); border:1px solid rgba(255,255,255,.3); border-radius:var(--radius-pill); padding:9px 16px; }
.fanteaser__cta{ display:inline-flex; align-items:center; gap:9px; font-family:var(--font-display); font-weight:600; font-size:16px; color:#fff; }
.fanteaser__cta svg, .fanteaser__cta i{ width:18px; height:18px; }
.fanteaser__in:hover .fanteaser__cta{ gap:13px; }
@media (max-width:860px){ .fanteaser__in{ grid-template-columns:1fr; gap:24px; padding:40px 32px; } }
@media (max-width:760px){
  /* Mobile: Zeile gestapelt — Datum klein, Titel, Badge, Zeit; Pfeil klein rechts. Kein Overflow. */
  .arow{ grid-template-columns:1fr auto; column-gap:12px; row-gap:4px; align-items:center; padding:16px 2px; }
  .arow__date{ display:flex; align-items:baseline; gap:6px; grid-column:1; grid-row:1; }
  .arow__date b{ font-size:15px; font-weight:700; line-height:1; }
  .arow__date em{ font-size:12px; font-style:normal; }
  .arow__name{ grid-column:1; grid-row:2; font-size:var(--text-h3); }
  .arow__name small{ display:none; }
  .arow__tag{ grid-column:1; grid-row:3; justify-self:start; }
  .arow__meta{ grid-column:1; grid-row:4; display:block; white-space:normal; min-width:0; }
  .arow__go{ grid-column:2; grid-row:1 / span 4; display:grid; width:34px; height:34px; align-self:center; }
  .arow__go svg, .arow__go i{ width:14px; height:14px; }
}

/* ============================================================
   MAP PLATE — cartographic device (v1): coordinates + crosshairs + topo
   ============================================================ */
.visit__plate{ display:flex; }
.plate{ position:relative; flex:1; aspect-ratio:1/1; border:1px solid var(--line-strong, var(--ink-900)); background:var(--surface-raised);
  overflow:hidden; display:grid; place-items:center; }
.plate__topo{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.5; }
.plate__pin{ position:relative; z-index:2; width:46%; max-width:200px; opacity:.9; display:grid; place-items:center; }
.plate__pin img{ width:64px; height:64px; opacity:.55; }
.plate__cnr{ position:absolute; z-index:2; font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; color:var(--text-muted); }
.plate__cnr.tl{ top:16px; left:18px; } .plate__cnr.tr{ top:16px; right:18px; }
.plate__cnr.bl{ bottom:16px; left:18px; } .plate__cnr.br{ bottom:16px; right:18px; color:var(--site-accent); }
.plate__cross{ position:absolute; z-index:2; width:13px; height:13px; }
.plate__cross::before, .plate__cross::after{ content:""; position:absolute; background:var(--ink-900); opacity:.7; }
.plate__cross::before{ left:6px; top:0; width:1px; height:13px; }
.plate__cross::after{ top:6px; left:0; height:1px; width:13px; }
.plate__cross.a{ top:46px; left:46px; } .plate__cross.b{ bottom:46px; right:46px; }

/* ============================================================
   FEATURE — bold burgundy block + overlapping photo (urbane vibes)
   ============================================================ */
.feature{ position:relative; max-width:var(--container-xl); margin:0 auto; padding:clamp(48px,6vw,86px) 48px; }
.feature__block{ position:relative; background:var(--gradient-ember); color:#fff; border-radius:var(--radius-lg);
  padding:clamp(44px,5vw,76px); width:70%; min-height:420px; overflow:hidden; display:flex; align-items:center; box-shadow:var(--shadow-lg); }
.feature__pat{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.16; mix-blend-mode:soft-light; }
.feature__coord{ position:absolute; top:24px; right:30px; z-index:1; font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; color:rgba(255,255,255,.6); }
.feature__copy{ position:relative; z-index:1; max-width:32ch; }
.feature__title{ font-size:clamp(34px,4.4vw,62px); color:#fff; margin:16px 0 0; line-height:1.0; }
.feature__title .u{ font-style:italic; color:var(--apricot-200); }
.feature__copy p{ font-size:var(--text-body-lg); line-height:var(--leading-normal); color:rgba(255,255,255,.92); margin:22px 0 0; max-width:38ch; }
.feature__cta{ margin-top:30px; display:flex; gap:14px; flex-wrap:wrap; }
.feature__media{ position:absolute; right:48px; top:50%; transform:translateY(-50%); width:40%; max-width:520px; aspect-ratio:4/3;
  margin:0; overflow:hidden; box-shadow:var(--shadow-lg); z-index:2; }
.feature__media img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease-out); }
.feature__media:hover img{ transform:scale(1.05); }
.feature__media figcaption{ position:absolute; left:14px; bottom:14px; display:inline-flex; align-items:center; gap:7px;
  font-family:var(--font-mono); font-size:11px; color:#fff; background:rgba(20,16,9,.55); backdrop-filter:blur(4px); padding:6px 11px; border-radius:var(--radius-pill); }
.feature__media figcaption svg, .feature__media figcaption i{ width:13px; height:13px; }

/* ============================================================
   MOSAIK — dense asymmetric photo grid (magazine / editorial)
   ============================================================ */
.mosaik__grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:212px; gap:3px; background:var(--ink-900); border:3px solid var(--ink-900); }
.mtile{ position:relative; margin:0; overflow:hidden; background:var(--surface-sunken); }
.mtile img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease-out); }
.mtile:hover img{ transform:scale(1.06); }
.mtile::after{ content:""; position:absolute; inset:0; background:linear-gradient(transparent 52%, rgba(20,16,9,.5)); pointer-events:none; }
.mtile.big{ grid-column:span 2; grid-row:span 2; }
.mtile.wide{ grid-column:span 2; }
.mtile figcaption{ position:absolute; left:14px; bottom:13px; z-index:2; display:inline-flex; align-items:center; gap:7px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; color:#fff; }
.mtile figcaption svg, .mtile figcaption i{ width:13px; height:13px; }

/* ============================================================
   ANGEBOT — full-width editorial offer block (on white)
   ============================================================ */
.angebot{ background:var(--surface-raised); padding:clamp(76px,10vw,148px) 0; border-bottom:1px solid var(--hairline); }
.angebot__lead{ font-family:var(--font-display); font-weight:500; font-size:clamp(28px,3.8vw,56px); line-height:1.16;
  letter-spacing:-.02em; color:var(--text-strong); margin:0; max-width:22ch; text-wrap:balance; }
.angebot__lead em{ font-style:normal; color:var(--site-accent); }
.angebot__offer{ margin-top:clamp(52px,6vw,88px); display:grid; grid-template-columns:auto 1fr; gap:36px 64px;
  align-items:start; border-top:1px solid var(--ink-900); padding-top:42px; }
.angebot__offer-head{ display:flex; align-items:baseline; gap:16px; }
.angebot__plus{ font-family:var(--font-display); font-weight:300; font-size:clamp(40px,5vw,76px); line-height:.78; color:var(--site-accent); }
.angebot__offer-label{ font-family:var(--font-mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); max-width:13ch; }
.angebot__list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:4px; }
.angebot__list li{ display:grid; grid-template-columns:0.82em 1fr; align-items:center; gap:24px; font-family:var(--font-display); font-weight:600;
  font-size:clamp(26px,3.4vw,48px); line-height:1.04; letter-spacing:-.02em; color:var(--text-strong); }
.angebot__listplus{ font-family:var(--font-display); font-weight:400; font-size:.62em; line-height:1; color:var(--site-accent); justify-self:start; }
.angebot__offer-text{ grid-column:2; font-size:var(--text-body); color:var(--text-muted); line-height:1.6; margin:14px 0 0; max-width:42ch; }
@media (max-width:760px){ .angebot__offer{ grid-template-columns:1fr; gap:24px; } .angebot__offer-text{ grid-column:1; } }

/* ============================================================
   TISCHE — asymmetric big-number rows (Restaurant & Terrasse)
   ============================================================ */
.trows{ border-top:1px solid var(--ink-900); }
.trow{ display:grid; grid-template-columns:auto 1fr auto; gap:48px; align-items:start; padding:40px 0; border-bottom:1px solid var(--hairline); }
.trow__num{ font-family:var(--font-display); font-weight:700; font-size:clamp(40px,5.5vw,88px); line-height:.82; letter-spacing:-.03em; color:var(--site-accent); }
.trow__title{ font-family:var(--font-display); font-weight:600; font-size:clamp(24px,2.6vw,38px); line-height:1.02; letter-spacing:-.02em; color:var(--text-strong); margin:0; }
.trow__text{ font-size:var(--text-body); color:var(--text-muted); line-height:1.6; margin:12px 0 0; max-width:52ch; }
.trow__cap{ font-family:var(--font-mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--text-subtle); white-space:nowrap; padding-top:6px; }
.trow:nth-child(2){ padding-left:6%; } .trow:nth-child(3){ padding-left:12%; }
@media (max-width:760px){ .trow{ grid-template-columns:auto 1fr; gap:20px; } .trow__cap{ grid-column:2; white-space:normal; } .trow:nth-child(2),.trow:nth-child(3){ padding-left:0; } }

/* ============================================================
   MOSAIK 2 — spacious asymmetric, parallax (Höhen & Tiefen)
   ============================================================ */
.mosaik2__grid{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:28px; row-gap:64px; align-items:start; }
.m2tile{ margin:0; }
.m2tile__media{ overflow:hidden; }
.m2tile__media img{ display:block; width:100%; height:100%; object-fit:cover; transform:scale(1.16); will-change:transform; }
.m2tile figcaption{ margin-top:16px; display:flex; align-items:baseline; gap:12px; font-family:var(--font-mono); font-size:12px; letter-spacing:.05em; color:var(--text-muted); }
.m2tile__num{ color:var(--site-accent); }
.m1{ grid-column:1 / 7; grid-row:1; } .m1 .m2tile__media{ aspect-ratio:4/5; }
.m2{ grid-column:8 / 13; grid-row:1; margin-top:96px; } .m2 .m2tile__media{ aspect-ratio:3/4; }
.m3{ grid-column:2 / 7; grid-row:2; } .m3 .m2tile__media{ aspect-ratio:1/1; }
.m4{ grid-column:8 / 13; grid-row:2; margin-top:48px; } .m4 .m2tile__media{ aspect-ratio:16/10; }
@media (max-width:900px){
  .mosaik2__grid{ grid-template-columns:1fr 1fr; column-gap:18px; }
  .m1,.m2,.m3,.m4{ grid-column:auto; margin-top:0; }
  .m1 .m2tile__media,.m2 .m2tile__media,.m3 .m2tile__media,.m4 .m2tile__media{ aspect-ratio:4/5; }
}
@media (max-width:560px){ .mosaik2__grid{ grid-template-columns:1fr; } }

/* ============================================================
   CUSTOM CURSOR (desktop) — follows pointer, grows on interactive
   ============================================================ */
.cursor{ position:fixed; top:0; left:0; z-index:300; width:16px; height:16px; margin:-8px 0 0 -8px;
  border:1.5px solid var(--apricot-500); border-radius:50%; pointer-events:none; opacity:0;
  transition:width .25s var(--ease-out), height .25s var(--ease-out), margin .25s var(--ease-out), background .25s, border-color .25s; }
.cursor.is-hot{ width:48px; height:48px; margin:-24px 0 0 -24px; background:color-mix(in srgb, var(--apricot-500) 16%, transparent); border-color:var(--apricot-400); }
@media (pointer:coarse){ .cursor{ display:none !important; } }

/* feature copy: stacked short lines (Burg Leuk voice) */
.feature__lead{ font-size:var(--text-body-lg); color:rgba(255,255,255,.92); margin:18px 0 0 !important; }
.feature__list{ list-style:none; margin:24px 0 0; padding:0; display:flex; flex-direction:column; gap:2px; }
.feature__list li{ font-family:var(--font-display); font-weight:600; font-size:clamp(20px,2.2vw,32px); line-height:1.2; letter-spacing:-.01em; color:#fff; }
.feature__more{ margin:22px 0 0 !important; font-size:var(--text-body); color:var(--apricot-200); }

/* animated locator logo in the map plate */
.plate__pin{ animation:plateFloat 5.5s var(--ease-in-out) infinite; }
.plate__pin::before{ content:""; position:absolute; left:50%; top:50%; width:64px; height:64px; margin:-32px 0 0 -32px;
  border:1px solid var(--site-accent); border-radius:50%; opacity:0; animation:platePulse 3.2s var(--ease-out) infinite; }
@keyframes plateFloat{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(-9px) } }
@keyframes platePulse{ 0%{ transform:scale(.55); opacity:.55 } 100%{ transform:scale(2.6); opacity:0 } }
.plate__topo{ animation:plateDrift 34s linear infinite alternate; filter:url(#wobble); }
@keyframes plateDrift{ from{ transform:translateX(0) } to{ transform:translateX(-14px) } }
@media (prefers-reduced-motion: reduce){ .plate__pin, .plate__pin::before, .plate__topo{ animation:none !important; } }

/* ============================================================
   MODAL (reservation)
   ============================================================ */
.modal{ position:fixed; inset:0; z-index:80; background:rgba(20,16,9,.58); backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center; padding:24px; animation:mfade var(--duration-base) var(--ease-out); }
@keyframes mfade{ from{opacity:0} to{opacity:1} }
.modal__box{ position:relative; background:var(--surface-page); border-radius:var(--radius-xl); padding:36px; width:100%; max-width:560px;
  box-shadow:var(--shadow-lg); animation:mrise var(--duration-slow) var(--ease-out); }
@keyframes mrise{ from{transform:translateY(14px); opacity:0} to{transform:none; opacity:1} }
.modal__x{ position:absolute; top:14px; right:14px; }
.modal__title{ font-family:var(--font-display); font-weight:var(--disp-weight); font-size:var(--text-h2); color:var(--text-strong); margin:6px 0 22px; }
.modal__grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.modal__done{ text-align:center; padding:14px 0; display:flex; flex-direction:column; align-items:center; gap:8px; }
.modal__check{ width:56px; height:56px; border-radius:50%; background:var(--salbei-600); color:var(--kalk-50);
  display:flex; align-items:center; justify-content:center; margin-bottom:6px; }
.modal__check svg{ width:28px; height:28px; }
.modal__done h3{ font-family:var(--font-display); font-weight:var(--disp-weight); font-size:var(--text-h2); color:var(--text-strong); margin:0; }
.modal__done p{ font-size:var(--text-body); color:var(--text-muted); margin:0 0 12px; max-width:38ch; line-height:var(--leading-normal); }

/* ============================================================
   reveal
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  .reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); transition-delay:calc(var(--i,0)*80ms); }
  .reveal.in{ opacity:1; transform:none; }
}

/* ============================================================
   responsive
   ============================================================ */
@media (max-width:1000px){
  .wrap{ padding:0 32px; } .nav__in{ padding:0 32px; }
  .hero__in{ padding:0 32px 40px; } .hero__bar{ padding:22px 32px 0; }
  .hero__cross.tl, .hero__cross.tr{ display:none; } .hero__coord{ display:none; } .hero__scroll{ display:none; }
  .grid3{ grid-template-columns:1fr; }
  .modgrid, .modgrid.cols4{ grid-template-columns:1fr 1fr; }
  .ort .wrap, .visit .wrap{ grid-template-columns:1fr; gap:40px; }
  .feature__block{ width:100%; }
  .feature__media{ position:static; transform:none; width:auto; max-width:none; margin:-44px 24px 0; aspect-ratio:16/9; }
  .mosaik__grid{ grid-auto-rows:180px; }
  .foot__grid{ grid-template-columns:1fr 1fr; }
  .nav__links{ display:none; }
}
@media (max-width:560px){
  .wrap{ padding-left:max(22px, env(safe-area-inset-left)); padding-right:max(22px, env(safe-area-inset-right)); }
  .nav__in{ padding-left:max(22px, env(safe-area-inset-left)); padding-right:max(22px, env(safe-area-inset-right)); }
  .nav__brand{ min-width:0; } .nav__brand .bw{ min-width:0; } .nav__brand .bw b{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .nav__right{ flex:none; }
  .modgrid, .modgrid.cols4{ grid-template-columns:1fr; }
  .modcell{ border-right:0; border-bottom:1px solid var(--hairline); }
  .agenda__cal{ grid-template-columns:1fr auto; }
  .agenda__months{ grid-column:1 / -1; order:3; justify-content:flex-start; }
  .mosaik__grid{ grid-template-columns:1fr 1fr; grid-auto-rows:150px; }
  .mtile.big{ grid-row:span 2; }
  .sechead{ grid-template-columns:auto 1fr; } .sechead__action{ grid-column:1/-1; }
  .modal__grid{ grid-template-columns:1fr; }
  .foot__grid{ grid-template-columns:1fr; }
  .hero__scroll{ display:none; }
  .fanteaser__type span{ font-size:clamp(34px,11vw,52px); }
  /* Agenda-Reihen werden ab ≤760px als Thumbnail-Karten dargestellt (siehe oben). */
  .feature__media{ margin:-30px 16px 0; }
  .statement__title, .band__q{ font-size:clamp(22px,6.5vw,30px); }
}
/* Hero auf kleinen Screens entschaerfen: niedriger, Titel eine Stufe kleiner, kein Crop */
@media (max-width:600px){
  .hero{ min-height:max(440px, 66vh); }
  .hero__title{ font-size:clamp(40px, 11vw, 62px); }   /* Display-Headline mit klarer Hierarchie, prominent */
  .hero__in{ padding-bottom:48px; }
  /* Punkt 3: kompaktere Mobile-Skala — grosse Headlines deutlich kleiner */
  .angebot__lead{ font-size:clamp(21px, 6vw, 30px); }
  .agenda__month{ font-size:clamp(28px, 7vw, 40px); }
  .feature__title{ font-size:clamp(25px, 7vw, 36px); }
  /* Bilder deutlich verkleinern: hohe Portrait-Medien flacher, Mosaik niedriger */
  .ort__media img{ aspect-ratio:4 / 3; }
  .mosaik__grid{ grid-auto-rows:128px; }
  /* Hero-Eyebrow + Headline über dem Bild lesbar machen: Verlaufs-Scrim hinter dem Textblock, Eyebrow voller Kontrast */
  .hero__scrim{ background:
    linear-gradient(180deg, rgba(14,24,34,.45) 0%, rgba(14,24,34,0) 26%, rgba(14,24,34,.42) 56%, rgba(14,24,34,.97) 100%); }
  .hero__copy .eyebrow, .hero__copy .eyebrow.on-dark{ color:#fff; text-shadow:0 1px 16px rgba(0,0,0,.9), 0 0 3px rgba(0,0,0,.55); }
  .hero__copy .eyebrow.line::before{ opacity:.85; }
  /* Vertikaler Rhythmus: konsistente Sektions-Abstandsskala (alle Section-Typen 88px) */
  .sec{ padding:88px 0; }
  .angebot{ padding:88px 0; }          /* Angebot klar vom Hero/der Agenda getrennt */
  .agenda__head{ margin-bottom:26px; }
}
