/* =============================================================
   FREIBURGER HÜTTE · Formarinsee
   "FORMARINSEE MODERN" — premium, rugged alpine hut system
   ============================================================= */

:root{
  /* warmes Hütten-Creme · Lärche · Espresso */
  --bg:#f5ecd9;             /* warmes Creme / Hüttenputz */
  --bg-2:#ece1c4;           /* etwas tieferes Creme */
  --bg-3:#e1d2ad;           /* warmer Sand */
  --fg:#1f1812;             /* dunkles Espresso-Holz für Text */
  --fg-dim:#5e5040;
  --muted:#8d7c63;
  --accent:#b3743a;         /* warmer Lärchen-/Laternenton (auf Hell etwas tiefer) */
  --accent-2:#8d5722;       /* dunklere Akzentvariante für Links auf Hell */
  --accent-soft:#e8c995;
  --mist:#6aa59d;
  --pine:#1d1611;           /* tiefes Holz für dunkle Bänder */
  --pine-fg:#f4ead4;        /* Textfarbe in dunklen Bändern */
  --line:rgba(31,24,18,.16);
  --line-2:rgba(179,116,58,.42);
  --light:#fbf4e2;
  --light-ink:#1f1812;
  --disp:"Bitter",Georgia,"Times New Roman",serif;
  --sans:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --maxw:1320px;
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-soft:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:110px;max-width:100%;overflow-x:hidden}
body{
  font-family:var(--sans);
  color:var(--fg);
  background:
    radial-gradient(circle at 12% 0%,rgba(106,165,157,.1),rgba(106,165,157,0) 32rem),
    linear-gradient(180deg,rgba(255,255,255,.018),rgba(255,255,255,0) 34rem),
    var(--bg);
  line-height:1.65;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  max-width:100%;
}
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(circle at 78% 8%,rgba(106,165,157,.11),transparent 22rem),
    radial-gradient(circle at 16% 44%,rgba(179,116,58,.08),transparent 24rem),
    repeating-linear-gradient(90deg,rgba(31,24,18,.018) 0 1px,transparent 1px 68px);
  opacity:.75
}
body::after{
  content:"";position:fixed;inset:0;z-index:1000;pointer-events:none;
  background-image:
    radial-gradient(circle at 20% 30%,rgba(31,24,18,.12) 0 1px,transparent 1.5px),
    radial-gradient(circle at 70% 60%,rgba(31,24,18,.09) 0 1px,transparent 1.6px);
  background-size:18px 18px,23px 23px;
  mix-blend-mode:multiply;opacity:.045
}
.cursor-aura{
  position:fixed;left:0;top:0;width:380px;height:380px;z-index:80;
  pointer-events:none;border-radius:50%;
  background:radial-gradient(circle,rgba(232,201,149,.18),rgba(106,165,157,.08) 38%,transparent 68%);
  mix-blend-mode:soft-light;opacity:0;
  transform:translate3d(calc(var(--cursor-x,50vw) - 50%),calc(var(--cursor-y,50vh) - 50%),0);
  transition:opacity .45s var(--ease),transform .08s linear
}
body.has-cursor .cursor-aura{opacity:1}
body.menu-open .cursor-aura,body.modal-open .cursor-aura{opacity:0}
body.menu-open{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--accent);color:var(--light-ink)}
a:focus-visible,button:focus-visible{
  outline:2px solid var(--accent);outline-offset:4px
}

/* ---------- Typography ---------- */
h1,h2{font-family:var(--disp);font-weight:600;line-height:1.06;letter-spacing:-.01em}
h3,h4{font-family:var(--disp);font-weight:600;line-height:1.04;letter-spacing:-.005em}
.display{
  font-family:var(--disp);font-weight:700;
  font-size:clamp(3rem,7vw,6.6rem);line-height:1;
  letter-spacing:-.015em;
}
h2{font-size:clamp(2.1rem,4.55vw,4.25rem)}
h3{font-size:clamp(1.25rem,2vw,1.8rem);letter-spacing:0}
h1,h2,h3{overflow-wrap:break-word}
p{max-width:64ch}
.eyebrow{
  font-family:var(--sans);font-size:.72rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--accent-2);
  display:inline-flex;align-items:center;gap:.8rem;
}
.eyebrow::before{
  content:"";width:34px;height:1px;background:currentColor;
  display:inline-block;flex:none
}
.eyebrow.center{justify-content:center}
.lead{font-size:clamp(1.08rem,1.45vw,1.32rem);color:var(--fg-dim);line-height:1.72;font-weight:400}
.serif-quote{
  font-family:var(--disp);font-weight:500;font-style:normal;
  font-size:clamp(1.55rem,3.25vw,2.85rem);line-height:1.22;
  letter-spacing:0
}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.25rem,4.5vw,4rem)}
.wrap-narrow{max-width:900px;margin:0 auto;padding:0 clamp(1.25rem,4.5vw,4rem)}
section{position:relative}
.section{padding:clamp(2.8rem,5.5vw,5.4rem) 0}
.section-sm{padding:clamp(1.6rem,3.4vw,2.8rem) 0}
.section::before{
  content:"";position:absolute;left:clamp(1.25rem,4.5vw,4rem);right:clamp(1.25rem,4.5vw,4rem);
  top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(179,116,58,.18),transparent);
  pointer-events:none
}
.bg-pine{background:var(--pine);color:var(--pine-fg)}
.bg-pine h1,.bg-pine h2,.bg-pine h3,.bg-pine h4{color:var(--pine-fg)}
.bg-pine p,.bg-pine li{color:rgba(244,234,212,.84)}
.bg-pine .eyebrow{color:#e7c79a}
.bg-pine .eyebrow::before{background:#e7c79a}
.bg-pine .link-u{color:var(--pine-fg);border-color:#e7c79a}
.bg-pine .link-u span{color:#e7c79a}
.bg-cream{background:var(--bg-2)}
.bg-paper{background:var(--bg)}
.center{text-align:center}
.center p{margin-left:auto;margin-right:auto}
.mt-s{margin-top:1rem}.mt-m{margin-top:1.6rem}.mt-l{margin-top:2.6rem}
.divider{width:100%;height:1px;background:var(--line)}

/* section index marker */
.section > .wrap{position:relative}

/* ---------- Marquee strip ---------- */
.marquee{
  background:var(--accent);color:var(--light-ink);overflow:hidden;
  border-block:1px solid rgba(0,0,0,.15);padding:.9rem 0
}
.marquee .track{display:flex;gap:3rem;white-space:nowrap;width:max-content;
  animation:marq 32s linear infinite}
.marquee span{font-family:var(--disp);font-weight:700;font-size:.95rem;
  letter-spacing:.18em;text-transform:uppercase;display:flex;align-items:center;gap:3rem}
.marquee span::after{content:"✶";color:rgba(255,255,255,.7)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--sans);font-weight:700;font-size:.75rem;
  letter-spacing:.13em;text-transform:uppercase;
  padding:1rem 1.75rem;border-radius:4px;border:1px solid transparent;
  transition:transform .35s var(--ease),background .35s var(--ease),border-color .35s var(--ease),color .35s var(--ease),box-shadow .35s var(--ease);
  position:relative;overflow:hidden;isolation:isolate
}
.btn::after{
  content:"";position:absolute;inset:-40% -65%;z-index:0;
  background:linear-gradient(100deg,transparent 38%,rgba(255,255,255,.28) 50%,transparent 62%);
  transform:translateX(-65%) rotate(8deg);opacity:0;
  transition:transform .75s var(--ease),opacity .35s var(--ease)
}
.btn:hover{transform:translateY(-2px);box-shadow:0 20px 46px -30px rgba(31,24,18,.8)}
.btn:hover::after{transform:translateX(65%) rotate(8deg);opacity:1}
.btn .arr{transition:transform .4s var(--ease)}
.btn:hover .arr{transform:translateX(6px)}
.btn-primary{background:var(--accent);color:var(--light-ink);font-weight:700;
  box-shadow:0 16px 42px -30px rgba(0,0,0,.9),0 1px 0 rgba(255,255,255,.28) inset}
.btn-primary::before{
  content:"";position:absolute;inset:1px;border:1px solid rgba(255,255,255,.22);
  border-radius:3px;z-index:0;pointer-events:none
}
.btn-primary:hover{background:var(--accent-2);color:var(--light-ink)}
.btn-dark{background:var(--fg);color:var(--bg)}
.btn-dark:hover{background:#fff}
.btn-ghost{border-color:rgba(245,239,228,.5);color:#fff;background:rgba(255,255,255,.03)}
.btn-ghost:hover{background:#fff;color:var(--bg);border-color:#fff}
.btn-outline{border-color:var(--line-2);color:var(--fg);background:transparent}
.btn-outline:hover{background:var(--accent);border-color:var(--accent);color:var(--light-ink)}
.btn-line{border:1px solid rgba(255,255,255,.4);color:var(--fg)}
.btn-line:hover{background:rgba(255,255,255,.1)}
.link-u{
  font-family:var(--sans);font-weight:700;font-size:.76rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fg);
  display:inline-flex;gap:.7rem;align-items:center;
  padding-bottom:6px;border-bottom:1px solid transparent;
  transition:gap .4s var(--ease),color .3s;position:relative
}
.link-u::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg,var(--accent),var(--accent-soft));
  transform-origin:left;transform:scaleX(.58);
  transition:transform .45s var(--ease)
}
.link-u span{color:var(--accent)}
.link-u:hover{gap:1.1rem}
.link-u:hover::after{transform:scaleX(1)}

/* ---------- Header — compact, stable command bar ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:120;
  display:flex;align-items:center;justify-content:center;
  gap:1rem;height:78px;padding:0 clamp(1rem,4vw,3rem);
  background:linear-gradient(180deg,rgba(251,244,226,.96),rgba(245,236,217,.92));
  backdrop-filter:blur(18px) saturate(1.12);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 0 rgba(255,255,255,.55) inset;
  transition:height .4s var(--ease),box-shadow .4s var(--ease),background .4s var(--ease)
}
.site-header::after{
  content:"";position:absolute;left:clamp(1rem,4vw,3rem);right:clamp(1rem,4vw,3rem);bottom:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent-soft),transparent);
  opacity:.36;pointer-events:none
}
.site-header.solid{height:66px;background:rgba(245,236,217,.98);box-shadow:0 18px 60px -38px rgba(31,24,18,.38)}

/* wordmark lockup — slab serif, mit Untertitel */
.brand{
  position:absolute;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.3rem;
  line-height:1;z-index:121;min-width:0;text-align:center
}
.brand-dot{display:none}
.brand b{font-family:var(--disp);font-size:clamp(1.35rem,3.4vw,2.05rem);
  font-weight:700;letter-spacing:.03em;color:var(--fg);white-space:nowrap;
  transition:color .35s var(--ease),text-shadow .35s var(--ease)}
.brand i{display:block;font-family:var(--sans);font-style:normal;
  font-size:clamp(.52rem,1.3vw,.64rem);font-weight:600;letter-spacing:.34em;
  text-transform:uppercase;color:var(--accent);white-space:nowrap}
.brand:hover b{color:var(--accent-2);text-shadow:0 10px 30px rgba(179,116,58,.18)}
.site-header.solid .brand b{font-size:clamp(1.2rem,3vw,1.7rem)}

.nav{display:none}
.nav a{
  font-family:var(--sans);font-size:.76rem;font-weight:600;
  letter-spacing:.11em;text-transform:uppercase;color:var(--fg-dim);
  display:flex;align-items:center;gap:.6rem;padding:.4rem 0;transition:color .3s;
  white-space:nowrap
}
.nav a::before{content:"";width:6px;height:6px;background:var(--accent);
  transform:rotate(45deg) scale(0);transition:transform .3s var(--ease)}
.nav a:hover{color:#fff}
.nav a.active{color:#fff}
.nav a.active::before{transform:rotate(45deg) scale(1)}

.header-actions{
  display:flex;align-items:center;justify-content:space-between;gap:.7rem;
  z-index:121;width:100%;margin-left:0;flex:none;pointer-events:none
}
.header-actions > *{pointer-events:auto}
.booking-cta{
  display:inline-flex;
  padding:.72rem 1.08rem;
  font-size:.64rem;
  min-height:42px;
  white-space:nowrap;
  border-radius:2px
}

/* Menu trigger */
.nav-burger{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;padding:0;border:0;border-radius:0;
  background:transparent;position:relative;flex:none;z-index:121;
  transition:transform .3s var(--ease)
}
.nav-burger:hover{transform:translateY(-1px)}
.nav-burger span{
  display:block;position:absolute;left:8px;width:28px;height:2px;background:var(--fg);
  box-shadow:0 0 0 1px rgba(255,255,255,.16);
  transition:transform .4s var(--ease),opacity .3s,top .3s var(--ease)
}
.nav-burger span:nth-child(1){top:13px}
.nav-burger span:nth-child(2){top:21px}
.nav-burger span:nth-child(3){top:29px}
body.menu-open .nav-burger span:nth-child(1){top:21px;transform:rotate(45deg)}
body.menu-open .nav-burger span:nth-child(2){opacity:0}
body.menu-open .nav-burger span:nth-child(3){top:21px;transform:rotate(-45deg)}

/* ---------- Overlay menu — works for every viewport ---------- */
.mobile-nav{
  position:fixed;inset:0 0 0 auto;z-index:115;width:min(428px,100%);
  max-width:100vw;overflow-y:auto;overscroll-behavior:contain;
  background:
    radial-gradient(120% 70% at 100% 0%,rgba(201,138,75,.22),transparent 55%),
    repeating-linear-gradient(115deg,rgba(31,24,18,.035) 0 1px,transparent 1px 18px),
    linear-gradient(180deg,var(--bg-3) 0%,var(--bg-2) 55%,var(--bg) 100%);
  display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;
  padding:6.5rem 0 2rem;border-left:1px solid var(--line-2);
  box-shadow:-32px 0 80px -56px rgba(0,0,0,.9);
  opacity:1;pointer-events:none;transform:translateX(100%);
  transition:transform .6s var(--ease);counter-reset:nav
}
.mobile-nav::before{
  content:"Freiburger Hütte";
  display:block;padding:0 clamp(1.4rem,5vw,2rem) 1.4rem;
  color:var(--accent);font-size:.66rem;font-weight:700;
  letter-spacing:.28em;text-transform:uppercase
}
body.menu-open .mobile-nav{pointer-events:all;transform:none}
.mobile-nav a{
  font-family:var(--disp);font-weight:650;text-transform:uppercase;
  font-size:clamp(1rem,5vw,1.35rem);letter-spacing:.04em;color:var(--fg);
  padding:1.05rem clamp(1.4rem,5vw,2rem);opacity:0;transform:translateX(18px);
  border-bottom:1px solid rgba(201,138,75,.18);
  position:relative;
  transition:opacity .45s var(--ease),transform .45s var(--ease),
             color .25s,background .25s,padding-left .3s var(--ease)
}
.mobile-nav a:not(.btn){counter-increment:nav}
.mobile-nav a::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--accent);
  transition:width .3s var(--ease)
}
.mobile-nav a:not(.btn)::after{
  content:counter(nav,decimal-leading-zero);
  position:absolute;right:clamp(1.4rem,5vw,2rem);top:50%;
  transform:translateY(-50%);
  font-family:var(--sans);font-size:.62rem;letter-spacing:.16em;
  color:rgba(141,87,34,.5)
}
.mobile-nav a:hover{color:var(--accent-2);background:rgba(201,138,75,.07);
  padding-left:calc(clamp(1.4rem,5vw,2rem) + .5rem)}
.mobile-nav a:hover::before{width:3px}
.mobile-nav a.active{color:var(--accent)}
.mobile-nav a.active::before{width:3px}
body.menu-open .mobile-nav a{opacity:1;transform:none}
.mobile-nav a:nth-child(1){transition-delay:.08s}
.mobile-nav a:nth-child(2){transition-delay:.12s}
.mobile-nav a:nth-child(3){transition-delay:.16s}
.mobile-nav a:nth-child(4){transition-delay:.2s}
.mobile-nav a:nth-child(5){transition-delay:.24s}
.mobile-nav a:nth-child(6){transition-delay:.28s}
.mobile-nav .btn{
  margin:1.3rem clamp(1.4rem,5vw,2rem) 0;padding:1rem 1.2rem;
  justify-content:center;font-family:var(--sans);font-size:.72rem;
  color:var(--light-ink);transition-delay:.34s
}
body.menu-open .mobile-nav::before{animation:navTitleIn .7s var(--ease) both .08s}
@keyframes navTitleIn{
  from{opacity:0;transform:translateX(18px);filter:blur(6px)}
  to{opacity:1;transform:none;filter:none}
}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;
  color:#fff;overflow:hidden}
.hero-seal{position:absolute;z-index:2;top:clamp(100px,12vh,150px);left:clamp(1.5rem,4vw,3.4rem);
  width:clamp(96px,11vw,150px);aspect-ratio:1;pointer-events:none}
.hero-seal img{width:100%;height:100%;object-fit:contain;
  filter:drop-shadow(0 2px 10px rgba(0,0,0,.55));
  animation:seal-rotate 64s linear infinite}
@keyframes seal-rotate{to{transform:rotate(360deg)}}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover;
  position:absolute;inset:0;opacity:0;
  transform:scale(1.045) translate3d(0,var(--hero-shift,0px),0);
  transition:opacity 1.65s var(--ease-soft),transform .18s linear,filter 1.65s var(--ease-soft);
  filter:saturate(1.02) contrast(1.06) brightness(1.08)}
.hero-bg img.is-active{opacity:1;filter:saturate(1.08) contrast(1.08) brightness(1.06)}
.hero-bg img.was-active{opacity:0}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;opacity:.16;
  background:
    radial-gradient(circle at 68% 18%,rgba(231,207,163,.32),transparent 18rem),
    radial-gradient(circle at 28% 70%,rgba(106,165,157,.22),transparent 22rem);
  mix-blend-mode:screen;pointer-events:none;animation:heroGlow 9s var(--ease-soft) infinite alternate}
@keyframes heroGlow{from{opacity:.12;transform:translate3d(-1%,0,0)}to{opacity:.25;transform:translate3d(1.5%,-1%,0)}}
/* Farbverlauf Braun → Grün, deutlich heller damit Bergkonturen sichtbar bleiben */
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(90deg,rgba(86,52,28,.20) 0%,rgba(86,52,28,.06) 38%,rgba(86,52,28,0) 70%),
    linear-gradient(180deg,rgba(118,76,38,.18) 0%,rgba(74,92,52,.06) 42%,rgba(22,32,22,.52) 100%)}
.hero-inner{
  padding:5.5rem clamp(1.5rem,5vw,4rem) clamp(2.5rem,5vw,4rem);
  width:100%;max-width:1180px;text-align:center;margin-inline:auto;
  animation:heroCopyIn 1.1s var(--ease) both .08s
}
.hero-inner::before{
  content:"";display:block;width:min(78vw,720px);height:1px;margin:0 auto 1.2rem;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.42),transparent);
  transform:scaleX(.72);opacity:.7
}
@keyframes heroCopyIn{from{opacity:0;transform:translateY(28px) scale(.985);filter:blur(8px)}to{opacity:1;transform:none;filter:none}}
.hero h1{margin:1.25rem auto 0;font-size:clamp(2.5rem,5.4vw,5rem);
  max-width:13ch;overflow-wrap:break-word;text-shadow:0 18px 52px rgba(0,0,0,.42)}
.hero .eyebrow{color:var(--accent-2)}
.hero .eyebrow::before,.cta-band .eyebrow::before{display:none}
.hero .eyebrow{justify-content:center}
.hero p{font-size:clamp(1.04rem,1.42vw,1.24rem);color:rgba(255,255,255,.9);
  max-width:54ch;margin:1.45rem auto 0;font-weight:400;line-height:1.68}
.hero-cta{display:flex;flex-wrap:wrap;justify-content:center;gap:.85rem;margin-top:1.8rem}
.hero .btn-ghost{
  padding:0 0 .45rem;border:0;border-bottom:1px solid rgba(255,255,255,.55);
  border-radius:0;background:transparent;color:#fff
}
.hero .btn-ghost:hover{background:transparent;color:var(--accent-2);border-color:var(--accent-2);transform:translateY(-1px)}
.hero-fieldnotes{
  display:flex;justify-content:center;align-items:flex-start;gap:clamp(1.2rem,4vw,3.5rem);
  max-width:880px;margin:2.35rem auto 0;border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  backdrop-filter:blur(10px) saturate(1.08);
  padding:1rem clamp(1rem,3vw,1.8rem);
  box-shadow:0 30px 80px -60px rgba(0,0,0,.72),0 1px 0 rgba(255,255,255,.18) inset
}
.hero-fieldnotes div{padding:0;border-right:0;position:relative;min-width:0;
  transition:transform .4s var(--ease),opacity .4s var(--ease)}
.hero-fieldnotes div+div::before{
  content:"";position:absolute;left:calc(clamp(1.2rem,4vw,3.5rem) / -2);
  top:.24rem;width:1px;height:2.4rem;background:rgba(255,255,255,.22)
}
.hero-fieldnotes b{display:block;font-size:.72rem;font-weight:750;text-transform:uppercase;letter-spacing:.16em;color:#fff}
.hero-fieldnotes span{display:block;margin-top:.45rem;font-size:.78rem;color:rgba(255,255,255,.62)}
.hero-fieldnotes div:hover{transform:translateY(-3px)}
.hero-fieldnotes div:hover b{color:var(--accent-soft)}
.hero-meta{display:flex;flex-wrap:wrap;gap:2.4rem;margin-top:3rem;
  padding-top:1.8rem;border-top:1px solid rgba(255,255,255,.22)}
.hero-meta div{display:flex;flex-direction:column;gap:.35rem}
.hero-meta b{font-family:var(--disp);font-size:1.5rem;font-weight:800;color:#fff}
.hero-meta span{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.6)}
.scroll-hint{position:absolute;bottom:1.8rem;right:clamp(1.25rem,4.5vw,4rem);
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,.55);display:flex;align-items:center;gap:.9rem;
  writing-mode:vertical-rl}
.scroll-hint i{width:1px;height:54px;background:rgba(255,255,255,.4);
  position:relative;overflow:hidden}
.scroll-hint i::after{content:"";position:absolute;top:-60%;left:0;width:100%;
  height:60%;background:var(--accent);animation:sd 2.2s var(--ease) infinite}
@keyframes sd{to{top:100%}}

/* page hero (interior) */
.page-hero{position:relative;min-height:50vh;display:flex;align-items:center;
  color:#fff;overflow:hidden;text-align:center}
.page-hero img.bgi{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:-2;
  transform:scale(1.035) translate3d(0,var(--hero-shift,0px),0);
  transition:transform .18s linear;
  filter:saturate(1.02) contrast(1.08) brightness(1.08)}
.page-hero--anreise img.bgi{object-position:center 54%}
/* Farbverlauf Braun → Grün auch auf Unterseiten, heller */
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(circle at 50% 42%,rgba(8,11,9,.18),rgba(8,11,9,0) 22rem),
    linear-gradient(180deg,rgba(18,17,12,.46) 0%,rgba(29,22,17,.26) 44%,rgba(17,24,17,.72) 100%),
    linear-gradient(90deg,rgba(8,11,9,.32),rgba(8,11,9,.06) 52%,rgba(8,11,9,.34))}
/* Klickbare Hero-Fläche → Startseite (über dem Bild, hinter dem Text) */
.page-hero-home{position:absolute;inset:0;z-index:0;display:block;
  text-indent:-9999px;overflow:hidden}
.page-hero-home:focus{outline:none}
.page-hero-home:focus-visible{outline:2px solid var(--accent);outline-offset:-6px;z-index:1}
.page-hero .wrap{width:100%;max-width:1080px;margin-inline:auto;position:relative;z-index:1;pointer-events:none;
  padding:5rem clamp(1.5rem,5vw,4rem) clamp(2.4rem,4.6vw,3.6rem)}
.page-hero .wrap a,.page-hero .wrap button{pointer-events:auto}
.page-hero .eyebrow{justify-content:center;color:#f0d09b;text-shadow:0 2px 18px rgba(0,0,0,.55)}
.page-hero .eyebrow::before{background:currentColor}
.page-hero h1{font-size:clamp(2.6rem,6vw,5rem);margin:1.1rem auto 0;
  max-width:16ch;overflow-wrap:break-word;text-shadow:0 4px 28px rgba(0,0,0,.62)}
.page-hero p{color:rgba(255,255,255,.84);margin:1.2rem auto 0;
  font-size:clamp(1.05rem,1.5vw,1.22rem);font-weight:500;max-width:58ch;line-height:1.7;
  text-shadow:0 3px 22px rgba(0,0,0,.62)}
.photo-credit{
  position:absolute;right:.7rem;bottom:.55rem;z-index:2;
  max-width:min(46ch,calc(100% - 1.7rem));
  padding:.22rem .34rem;border-radius:2px;
  background:rgba(8,11,9,.28);color:rgba(255,255,255,.68);
  font-size:.48rem;font-weight:500;line-height:1.3;
  letter-spacing:.02em;text-align:right;pointer-events:none
}

/* ---------- Saison-Hinweis ---------- */
.season{background:
  radial-gradient(circle at 18% 0%,rgba(232,201,149,.22),transparent 23rem),
  linear-gradient(135deg,rgba(255,255,255,.22),rgba(255,255,255,0) 48%),
  var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.season .wrap{padding:clamp(2.2rem,4.5vw,3.4rem) clamp(1.25rem,4.5vw,3rem);
  display:flex;align-items:center;justify-content:space-between;gap:2rem 3rem;
  flex-wrap:wrap}
.season .s-main{display:flex;align-items:flex-start;gap:1.4rem;
  flex:1 1 520px;min-width:min(100%,420px)}
.season .s-dot{width:14px;height:14px;background:var(--accent);flex:none;
  margin-top:.45rem;transform:rotate(45deg);
  box-shadow:0 0 0 6px rgba(179,116,58,.18)}
.season h2{font-family:var(--disp);font-weight:600;
  font-size:clamp(1.35rem,2.4vw,2rem);color:var(--fg);letter-spacing:0;
  line-height:1.12}
.season p{margin:.65rem 0 0;color:var(--fg-dim);font-size:.96rem;
  max-width:64ch;line-height:1.65}
.season .btn{flex:none}
@media (max-width:760px){
  .season .wrap{flex-direction:column;align-items:flex-start;justify-content:flex-start}
  .season .s-main{flex:0 0 auto;min-width:0}
  .season .btn{width:100%;justify-content:center}
}

/* ---------- Split / editorial ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,6rem);
  align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative}
.split-media img{width:100%;height:100%;max-height:700px;object-fit:cover;
  border-radius:4px;filter:saturate(.92) contrast(1.03);
  box-shadow:0 42px 92px -62px rgba(0,0,0,.86),0 1px 0 rgba(255,255,255,.35) inset;
  transform:translate3d(0,var(--img-shift,0px),0) scale(1.01);
  transition:transform 1.2s var(--ease),filter .7s var(--ease)}
.split-media::before{display:none}
.split-media::after{display:none}
.split-media:hover img{transform:translate3d(0,var(--img-shift,0px),0) scale(1.035);filter:saturate(1) contrast(1.05)}
.split-media .badge{
  position:absolute;background:rgba(8,24,21,.9);color:#fff;
  padding:1.4rem 1.7rem;bottom:1rem;left:1rem;max-width:240px;
  border:1px solid var(--line-2);border-radius:3px;
  box-shadow:0 18px 40px -28px rgba(0,0,0,.8)
}
.split-media .badge b{font-family:var(--disp);font-size:2.4rem;display:block;
  line-height:1;font-weight:800}
.split-media .badge span{font-size:.66rem;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.68);margin-top:.3rem;display:block}
.split-body h2{margin:1.5rem 0 1.5rem}
.split-body p+p{margin-top:1.1rem}
@media (min-width:980px){
  .story-section .split{align-items:start}
  .story-section .split-body{position:sticky;top:118px}
  .story-section .split-media{transform:translateY(var(--story-lift,0px));
    transition:transform .18s linear}
}

/* ---------- Editorial image story ---------- */
.alpine-editorial{overflow:hidden}
.alpine-editorial::after{
  content:"";position:absolute;inset:auto 0 0 0;height:42%;
  background:linear-gradient(180deg,transparent,rgba(179,116,58,.08));
  pointer-events:none
}
.editorial-grid{display:grid;grid-template-columns:minmax(260px,.78fr) 1.22fr;
  gap:clamp(2rem,6vw,6rem);align-items:center;position:relative;z-index:1}
.editorial-copy h2{margin:1.4rem 0 1.2rem}
.editorial-media{
  display:grid;grid-template-columns:1fr .58fr;grid-template-rows:auto auto;
  gap:clamp(.8rem,1.8vw,1.4rem);align-items:end;perspective:1400px
}
.editorial-media figure{position:relative;overflow:hidden;border-radius:6px;
  border:1px solid rgba(179,116,58,.26);
  box-shadow:0 38px 90px -62px rgba(31,24,18,.78);
  isolation:isolate;background:#1f1812;
  transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
  transition:transform .65s var(--ease),box-shadow .65s var(--ease),border-color .65s var(--ease),
             clip-path 1.1s var(--ease)}
.editorial-media figure:hover{border-color:rgba(232,201,149,.55);
  box-shadow:0 48px 110px -64px rgba(31,24,18,.9)}
.editorial-media figure::before{
  content:"";position:absolute;inset:-25% -70%;z-index:2;pointer-events:none;
  background:linear-gradient(105deg,transparent 38%,rgba(255,255,255,.3) 50%,transparent 62%);
  transform:translateX(-62%) rotate(8deg);opacity:0;
  transition:transform .95s var(--ease),opacity .35s var(--ease)
}
.editorial-media figure:hover::before{transform:translateX(62%) rotate(8deg);opacity:1}
.editorial-media figure::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(31,24,18,0) 55%,rgba(31,24,18,.62));
  z-index:1;pointer-events:none
}
.editorial-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transform:translate3d(0,var(--img-shift,0px),0) scale(1.035);
  transition:transform 1.15s var(--ease),filter .75s var(--ease);
  filter:saturate(.94) contrast(1.03)}
.editorial-media figure:hover img{transform:translate3d(0,var(--img-shift,0px),0) scale(1.075);
  filter:saturate(1.03) contrast(1.06)}
.editorial-media figcaption{position:absolute;left:1rem;right:1rem;bottom:.9rem;z-index:2;
  color:#fff;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:750;text-shadow:0 8px 28px rgba(0,0,0,.55)}
.editorial-media figure.motion-item{clip-path:inset(12% 0 12% 0)}
.editorial-media figure.motion-item.motion-in{clip-path:inset(0 0 0 0)}
.em-large{grid-row:1 / span 2;min-height:clamp(420px,46vw,620px)}
.em-small{min-height:clamp(190px,20vw,270px)}
.em-two{transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg))}
@media (max-width:980px){
  .editorial-grid{grid-template-columns:1fr}
  .editorial-media{grid-template-columns:1fr 1fr}
  .em-large{grid-column:1 / -1;min-height:360px}
  .em-two{transform:none}
  .editorial-media figure.em-two.motion-item.motion-in{
    transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg))
  }
}
@media (max-width:620px){
  .editorial-media{grid-template-columns:1fr}
  .em-large,.em-small{min-height:260px}
}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,0))}
.stat{padding:2.9rem 1.8rem;border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);position:relative;overflow:hidden}
.stat::before{
  content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.22),transparent 46%);
  opacity:0;transition:opacity .45s var(--ease)
}
.stat:hover::before{opacity:1}
.stat:first-child{border-left:1px solid var(--line)}
.stat b{font-family:var(--disp);font-size:clamp(2.6rem,4.4vw,3.8rem);
  color:var(--fg);display:block;line-height:1;font-weight:800}
.stat span{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-2);margin-top:.9rem;display:block;font-weight:700}

/* ---------- Teaser cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.25rem,2.6vw,2.6rem);
  perspective:1400px}
.card{position:relative;overflow:hidden;min-height:480px;display:flex;
  align-items:flex-end;color:#fff;border:1px solid rgba(120,90,40,.18);border-radius:6px;
  box-shadow:0 26px 70px -48px rgba(31,24,18,.66),0 1px 0 rgba(255,255,255,.25) inset;
  isolation:isolate;transform-style:preserve-3d;
  transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(0);
  transition:transform .65s var(--ease),box-shadow .65s var(--ease),border-color .65s var(--ease)}
.card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform 1.1s var(--ease),filter .6s;z-index:0;
  filter:saturate(1.05) brightness(.94)}
.card::before{
  content:"";position:absolute;inset:0;z-index:1;opacity:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,55%),rgba(232,201,149,.32),transparent 26rem);
  transition:opacity .5s var(--ease)
}
.card::after{content:"";position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(8,11,9,.04) 0%,rgba(8,11,9,.08) 34%,rgba(8,11,9,.84) 100%),
    linear-gradient(90deg,rgba(0,0,0,.24),rgba(0,0,0,0) 56%)}
.card-body{position:relative;z-index:2}
.card-body::before{
  content:"";display:block;width:58px;height:1px;margin:0 0 1.05rem;
  background:linear-gradient(90deg,var(--accent-soft),transparent);
  transform:scaleX(.64);transform-origin:left;
  transition:transform .5s var(--ease),opacity .5s var(--ease)
}
.card:hover{transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(-10px);
  border-color:rgba(232,201,149,.55);
  box-shadow:0 42px 110px -58px rgba(31,24,18,.9),0 0 0 1px rgba(232,201,149,.16) inset}
.card:hover::before{opacity:1}
.card:hover .card-body::before{transform:scaleX(1)}
.card:hover img{transform:scale(1.08);filter:saturate(1.04) brightness(.98)}
.card-body{padding:clamp(1.8rem,3vw,2.6rem)}
.card-body .k{font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--accent-soft);font-weight:700}
.card-body h3{color:#fff;margin:.9rem 0 .7rem}
.card-body p{color:rgba(255,255,255,.78);font-size:.95rem}
.card-body .link-u{color:#fff;margin-top:1.4rem}

/* ---------- Feature list ---------- */
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.feat .item{border-top:1px solid var(--line-2);padding:2rem 2rem 2rem 0;
  margin-right:2rem;position:relative}
.feat .item::after{
  content:"";position:absolute;top:-1px;left:0;height:1px;width:0;
  background:linear-gradient(90deg,var(--accent),transparent);
  transition:width .55s var(--ease)
}
.feat .item:hover::after{width:100%}
.feat .item:last-child{margin-right:0}
.feat .item .n{font-family:var(--disp);font-size:1rem;color:var(--accent);
  font-weight:700;letter-spacing:0}
.feat .item h3{font-size:1.55rem;margin:1rem 0 .8rem}
.feat .item p{font-size:.95rem;color:var(--fg-dim)}

/* ---------- Price table ---------- */
.price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.price-grid{perspective:1400px}
.price-card{background:rgba(255,255,255,.018);border:1px solid var(--line);
  border-radius:2px;overflow:hidden;
  display:flex;flex-direction:column;position:relative;isolation:isolate;
  transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(0);
  transition:border-color .4s,transform .5s var(--ease),box-shadow .5s var(--ease)}
.price-card::before{
  content:"";position:absolute;inset:0;z-index:-1;opacity:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,20%),rgba(232,201,149,.28),transparent 22rem);
  transition:opacity .45s var(--ease)
}
.price-card:hover{transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(-8px);
  border-color:var(--line-2);
  box-shadow:0 30px 80px -58px rgba(31,24,18,.8)}
.price-card:hover::before{opacity:1}
.price-card .ph{height:240px;position:relative;overflow:hidden}
.price-card .ph img{width:100%;height:100%;object-fit:cover;
  filter:saturate(.9) brightness(.85);transition:transform 1s var(--ease)}
.price-card:hover .ph img{transform:scale(1.06)}
.price-card .pb{padding:2rem 2rem 2.3rem;flex:1;display:flex;flex-direction:column}
.price-card h3{font-size:1.75rem}
.price-card .desc{color:var(--fg-dim);font-size:.94rem;margin:.8rem 0 1.5rem;flex:1}
.ptable{width:100%;border-collapse:collapse;font-size:.9rem}
.ptable th{text-align:left;font-family:var(--sans);font-weight:700;font-size:.64rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
  padding:.6rem .3rem;border-bottom:1px solid var(--line)}
.ptable td{padding:.62rem .3rem;border-bottom:1px solid var(--line);color:var(--fg)}
.ptable td:not(:first-child){text-align:right;font-variant-numeric:tabular-nums;
  font-family:var(--disp);font-weight:600}
.ptable .av{color:var(--accent-2)}
.ptable tr:last-child td{border-bottom:0}
.note{font-size:.84rem;color:var(--muted)}

/* simple info table */
.info-table{width:100%;border-collapse:collapse}
.info-table td{padding:1.1rem .3rem;border-bottom:1px solid var(--line);
  vertical-align:top;color:var(--fg-dim)}
.info-table td:first-child{font-family:var(--disp);font-weight:700;width:34%;
  color:var(--fg);font-size:1.15rem;letter-spacing:0}
.info-table tr:last-child td{border-bottom:0}

/* ---------- Timeline ---------- */
.timeline{margin-top:3rem}
.tl-row{display:grid;grid-template-columns:150px 1fr;gap:2.6rem;padding:2rem 0;
  border-bottom:1px solid var(--line);align-items:start}
.tl-row:first-child{border-top:1px solid var(--line)}
.tl-year{font-family:var(--disp);font-size:2.35rem;color:var(--accent);
  line-height:1;font-weight:700}
.tl-c h3{font-size:1.3rem;margin-bottom:.6rem}
.tl-c p{color:var(--fg-dim);font-size:.96rem}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:12px}
.gallery a{overflow:hidden;display:block;position:relative;border-radius:2px}
.gallery a::after{
  content:"";position:absolute;inset:0;border:1px solid rgba(251,244,226,.22);
  opacity:0;transition:opacity .45s var(--ease);pointer-events:none
}
.gallery img{width:100%;height:110%;object-fit:cover;
  transform:translate3d(0,var(--img-shift,0px),0) scale(1.015);
  filter:saturate(.9) brightness(.86);transition:transform 1.1s var(--ease),filter .5s}
.gallery a:hover img{transform:translate3d(0,var(--img-shift,0px),0) scale(1.085);filter:saturate(1) brightness(1)}
.gallery a:hover::after{opacity:1}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}

/* ---------- Quote band ---------- */
.quote-band{position:relative;color:#fff;overflow:hidden}
.quote-band img.bgi{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:-2;filter:saturate(.78) brightness(.5);
  transform:translate3d(0,var(--img-shift,0px),0) scale(1.045);
  transition:transform .18s linear}
.quote-band::after{content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 22% 34%,rgba(232,201,149,.14),transparent 20rem),
    linear-gradient(90deg,rgba(8,11,9,.8),rgba(8,11,9,.42));z-index:-1}
.quote-band .wrap-narrow{padding:clamp(6rem,13vw,10.5rem) clamp(1.25rem,4.5vw,4rem);
  text-align:left}
.quote-band .serif-quote{max-width:18ch}
.quote-band cite{display:block;margin-top:2.2rem;font-style:normal;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-2);
  font-weight:700}

/* ---------- CTA band ---------- */
.cta-band{position:relative;color:#fff;overflow:hidden;text-align:center}
.cta-band img.bgi{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:-2;filter:saturate(.9) brightness(.66);
  transform:translate3d(0,var(--img-shift,0px),0) scale(1.045);
  transition:transform .18s linear}
.cta-band::after{content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 50% 18%,rgba(232,201,149,.17),transparent 24rem),
    linear-gradient(90deg,rgba(8,11,9,.6),rgba(8,11,9,.18),rgba(8,11,9,.62)),
    linear-gradient(180deg,rgba(8,11,9,.34),rgba(8,11,9,.68));z-index:-1}
.cta-band .wrap{padding:clamp(3.8rem,8vw,6.7rem) clamp(1.25rem,4.5vw,4rem)}
.cta-band h2{margin:1rem auto 1rem;max-width:18ch}
.cta-band p{margin:0 auto;color:rgba(255,255,255,.82);font-weight:400}
.cta-band .hero-cta{justify-content:center}

/* ---------- Routes list ---------- */
.routes{display:grid;grid-template-columns:repeat(2,1fr);gap:0 4rem}
.route{display:flex;justify-content:space-between;gap:1.5rem;align-items:baseline;
  padding:1.3rem 0;border-bottom:1px solid var(--line);position:relative;
  transition:padding-left .35s var(--ease),border-color .35s var(--ease)}
.route::before{
  content:"";position:absolute;left:0;top:50%;width:0;height:1px;background:var(--accent);
  transition:width .35s var(--ease)
}
.route:hover{padding-left:1rem;border-color:var(--line-2)}
.route:hover::before{width:.55rem}
.route .rn{font-family:var(--disp);font-weight:600;color:var(--fg);
  font-size:1.2rem;letter-spacing:0}
.route .rn small{display:block;font-family:var(--sans);color:var(--muted);
  font-weight:400;font-size:.82rem;margin-top:.25rem;text-transform:none;letter-spacing:0}
.route .rt{font-family:var(--disp);font-size:1.6rem;color:var(--accent);
  white-space:nowrap;font-weight:700}

/* ---------- Map ---------- */
.map-shell{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:6px;
  min-height:480px;background:var(--bg-2)}
.map-shell iframe{width:100%;height:100%;min-height:480px;border:0;display:block;
  filter:grayscale(.25)}
.map-consent{position:absolute;inset:0;display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;gap:1.1rem;padding:2rem;
  background:var(--bg-2)}
.map-consent p{color:var(--fg-dim);max-width:44ch;font-size:.93rem}
.map-consent h3{color:var(--fg)}

/* ---------- Legal pages ---------- */
.legal{padding-top:clamp(8rem,14vw,12rem)}
.legal h1{font-size:clamp(2.4rem,6vw,4.4rem);margin-bottom:.8rem}
.legal h2{font-size:1.4rem;margin:2.8rem 0 1rem;color:var(--fg)}
.legal h3{font-size:1.1rem;margin:1.8rem 0 .6rem}
.legal p,.legal li{color:var(--fg-dim);font-size:.98rem;margin-bottom:.7rem;
  max-width:74ch;font-weight:400}
.legal ul{list-style:none;padding-left:0;margin-bottom:1rem}
.legal ul li{padding-left:1.3rem;position:relative}
.legal ul li::before{content:"";position:absolute;left:0;top:.65em;width:7px;
  height:7px;background:var(--accent);transform:rotate(45deg)}
.legal a{color:var(--accent);border-bottom:1px solid var(--accent)}
.legal .meta{color:var(--muted);font-size:.86rem}
.legal .btn{color:var(--fg)}
.legal .btn-outline:hover{color:#fff}
@media (max-width:560px){
  .legal{padding-top:6.9rem}
  .legal h1{font-size:clamp(2rem,10vw,2.75rem);overflow-wrap:anywhere;hyphens:auto}
  .legal h2,.legal h3{overflow-wrap:anywhere;hyphens:auto}
  .legal p,.legal li{overflow-wrap:anywhere}
  .legal .btn{white-space:normal}
}

/* ---------- Footer ---------- */
.site-footer{background:#1d1611;color:rgba(244,234,212,.8);
  padding:clamp(1.8rem,3.5vw,2.8rem) 0 1.1rem;border-top:1px solid var(--line-2);
  background:
    radial-gradient(circle at 18% 0%,rgba(232,201,149,.08),transparent 22rem),
    linear-gradient(180deg,#211912,#1d1611 58%,#16110d)}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:1.4rem 1.8rem;
  padding-bottom:1.3rem;border-bottom:1px solid rgba(244,234,212,.13)}
.foot-brand b{font-family:var(--disp);font-size:1.45rem;color:var(--pine-fg);display:block;
  font-weight:700;letter-spacing:0}
.foot-brand span{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;
  color:#e7c79a;display:block;margin-top:.4rem;font-weight:700}
.foot-brand p{font-size:.85rem;margin-top:.7rem;color:rgba(244,234,212,.65);max-width:34ch;line-height:1.5}
.foot-col h4{font-family:var(--sans);font-size:.66rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--pine-fg);margin-bottom:.55rem;font-weight:700}
.foot-col a,.foot-col p{display:block;font-size:.86rem;padding:.16rem 0;
  color:rgba(244,234,212,.78);transition:color .3s;line-height:1.45}
.foot-col a:hover{color:#e7c79a}
.foot-season{font-size:.76rem!important;line-height:1.45;
  color:rgba(244,234,212,.62)!important;
  margin-top:.45rem;padding-top:.5rem!important;border-top:1px solid rgba(244,234,212,.13)}
.foot-season::first-line{color:#e7c79a;font-weight:700;letter-spacing:.04em}
.foot-logos{display:flex;gap:.6rem;align-items:center;margin-top:.75rem}
.foot-logos img{height:38px;width:auto;background:#fff;padding:5px;
  filter:saturate(.2)}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.7rem;
  padding-top:.95rem;font-size:.75rem;color:rgba(244,234,212,.6)}
.foot-bottom a{transition:color .3s}.foot-bottom a:hover{color:var(--accent)}
.foot-bottom .fb-links{display:flex;gap:1.6rem;flex-wrap:wrap}

/* ---------- Cookie banner ---------- */
.cookie{
  position:fixed;left:50%;bottom:0;transform:translateX(-50%) translateY(110%);
  width:min(1100px,100%);z-index:200;
  background:rgba(29,22,17,.98);color:var(--pine-fg);border-top:2px solid var(--accent);
  padding:1.7rem clamp(1.5rem,4vw,3rem);
  display:flex;gap:2rem;align-items:center;flex-wrap:wrap;
  transition:transform .55s var(--ease)
}
.cookie.show{transform:translateX(-50%) translateY(0)}
.cookie .ct{flex:1;min-width:260px}
.cookie .ct b{font-family:var(--disp);font-size:1.35rem;color:var(--pine-fg);display:block;
  margin-bottom:.45rem;letter-spacing:0}
.cookie .ct p{font-size:.86rem;color:rgba(244,234,212,.78);max-width:64ch}
.cookie .ct a{color:var(--accent);border-bottom:1px solid var(--accent)}
.cookie .cbtns{display:flex;gap:.7rem;flex-wrap:wrap}
.cookie .btn{padding:.9rem 1.6rem;font-size:.7rem}
.cookie .btn-line{border:1.5px solid var(--pine-fg);color:var(--pine-fg);
  background:transparent;font-weight:700}
.cookie .btn-line:hover{background:var(--pine-fg);color:#1d1611;border-color:var(--pine-fg)}

/* ---------- Reveal animation (visible by default; JS-gated) ---------- */
.js [data-reveal]{opacity:0;transform:translateY(36px) scale(.985);
  transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
.js [data-reveal].in{opacity:1;transform:none}
.js [data-reveal][data-delay="1"]{transition-delay:.1s}
.js [data-reveal][data-delay="2"]{transition-delay:.2s}
.js [data-reveal][data-delay="3"]{transition-delay:.3s}
.js [data-reveal][data-delay="4"]{transition-delay:.4s}
.js [data-reveal][data-delay="5"]{transition-delay:.5s}
.motion-item{
  opacity:0;transform:translateY(34px) scale(.985);
  transition:
    opacity .9s var(--ease),
    transform 1.05s var(--ease);
  transition-delay:var(--stagger-delay,0ms)
}
.motion-item.motion-in{opacity:1;transform:none}
.motion-item.motion-in.card,
.motion-item.motion-in.tour-card,
.motion-item.motion-in.price-card{
  transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(0)
}
.editorial-media figure.motion-item.motion-in{
  transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg))
}
.editorial-media figure.em-two.motion-item.motion-in{
  transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg))
}
.motion-item.motion-in.card:hover{
  transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(-10px)
}
.motion-item.motion-in.tour-card:hover,
.motion-item.motion-in.price-card:hover{
  transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(-8px)
}
.alive-pulse{animation:alivePulse .9s var(--ease) both}
@keyframes alivePulse{
  0%{transform:scale(.985);filter:brightness(.96)}
  55%{transform:scale(1.012);filter:brightness(1.05)}
  100%{transform:none;filter:none}
}
@media (prefers-reduced-motion:reduce){
  .js [data-reveal],.motion-item{opacity:1;transform:none;filter:none;transition:none}
  .hero-bg img,.page-hero img.bgi{animation:none;transform:none;transition:none}
  .hero::before{animation:none}
  .hero-seal img{animation:none}
  .marquee .track{animation:none}
  .alive-pulse{animation:none}
}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .foot-top{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .feat{grid-template-columns:1fr 1fr}
}
@media (max-width:1320px){
  .brand i{display:none}
  .nav{gap:.8rem;margin-right:1rem}
}
@media (max-width:960px){
  .nav{display:none}
  .nav-burger{display:inline-flex}
}
@media (max-width:880px){
  .split{grid-template-columns:1fr;gap:2.5rem}
  .split.rev .split-media{order:0}
  .split-media::before{transform:translate(12px,12px)}
  .split-media img{height:auto;max-height:none;aspect-ratio:4 / 3;object-fit:cover}
  .split-media .badge{padding:1rem 1.1rem;max-width:210px}
  .split-media .badge b{font-size:1.9rem}
  .editorial-media figure.em-two.motion-item.motion-in{
    transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg))
  }
  .cards{grid-template-columns:1fr}
  .feat{grid-template-columns:1fr}
  .feat .item{margin-right:0}
  .stats{grid-template-columns:1fr 1fr}
  .stat:nth-child(odd){border-left:1px solid var(--line)}
  .price-grid{grid-template-columns:1fr}
  .routes{grid-template-columns:1fr;gap:0}
  .tl-row{grid-template-columns:90px 1fr;gap:1.5rem}
  .tl-year{font-size:1.6rem}
  .scroll-hint{display:none}
  .hero{min-height:100vh;min-height:100svh}
  .hero-fieldnotes{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
    gap:0;margin-top:1.9rem;padding:.9rem clamp(.5rem,2vw,1.4rem);width:100%}
  .hero-fieldnotes div{padding:0 .4rem;border:0;text-align:center;
    display:flex;flex-direction:column;align-items:center;justify-content:center}
  .hero-fieldnotes div+div::before{display:block;left:0;top:.15rem;height:2.6rem}
}
@media (max-width:560px){
  body{font-size:16px}
  .hero-seal{width:64px;top:92px;left:1rem}
  .site-header{padding-inline:.85rem}
  .stats{grid-template-columns:1fr}
  .stat{border-left:1px solid var(--line)}
  .gallery{grid-template-columns:1fr;grid-auto-rows:240px}
  .g-wide{grid-column:span 1}
  .foot-top{grid-template-columns:1fr}
  .cookie{flex-direction:column;align-items:flex-start;
    left:1rem;right:1rem;width:auto;
    bottom:calc(1rem + env(safe-area-inset-bottom,0px));
    transform:translateY(220%);border-radius:16px;border:2px solid var(--accent);
    padding:1.25rem 1.3rem;gap:1rem}
  .cookie.show{transform:translateY(0)}
  .hero-cta .btn{width:100%;justify-content:center}
  .hero-meta{gap:1.5rem}
  .hero{min-height:100vh;min-height:100svh}
  .hero-inner{padding-top:6.4rem;padding-bottom:3rem}
  .hero h1{font-size:clamp(2.25rem,12vw,3.6rem)}
  .hero p{font-size:1rem;line-height:1.65}
  .hero-fieldnotes{
    display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
    gap:0;margin-top:1.35rem;padding:.78rem .45rem;
    width:100%;border-color:rgba(255,255,255,.22)
  }
  .hero-fieldnotes div{
    padding:0 .32rem;border:0;text-align:center;
    display:flex;flex-direction:column;align-items:center;justify-content:center
  }
  .hero-fieldnotes div+div::before{
    display:block;left:0;top:.1rem;width:1px;height:2.75rem;
    background:rgba(255,255,255,.2)
  }
  .hero-fieldnotes b{font-size:.58rem;letter-spacing:.1em}
  .hero-fieldnotes span{font-size:.62rem;line-height:1.25;margin-top:.25rem}
  .editorial-media{gap:.85rem}
  .em-large{min-height:320px}
  .em-small{min-height:245px}
  .card{min-height:430px}
  .card-body{padding:1.55rem}
  .card-body p{font-size:.92rem;line-height:1.58}
  .cookie{
    padding:1rem 1rem 1.1rem;gap:.85rem;max-height:44svh;overflow-y:auto
  }
  .cookie .ct{min-width:0;width:100%}
  .cookie .ct b{font-size:1.12rem;margin-bottom:.28rem}
  .cookie .ct p{font-size:.78rem;line-height:1.5}
  .cookie .cbtns{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:.55rem}
  .cookie .btn{width:100%;justify-content:center;padding:.78rem .55rem;font-size:.62rem}
}
@media (max-width:680px){
  .brand i{display:none}
}
@media (max-width:460px){
  .brand{gap:.55rem;max-width:43vw}
  .brand b,.site-header.solid .brand b{font-size:clamp(1.3rem,5.5vw,1.65rem);letter-spacing:.02em}
  .site-header{height:72px;padding-inline:.72rem}
  .site-header.solid{height:66px}
  .mobile-nav{padding-top:5.8rem}
  .booking-cta{
    display:inline-flex;width:auto;min-width:78px;min-height:42px;padding:0 .78rem;
    align-items:center;justify-content:center;gap:0;font-size:0;border-radius:999px;
    background:#1f1812;color:var(--pine-fg);
    border:1px solid rgba(179,116,58,.58);
    box-shadow:0 12px 28px -20px rgba(31,24,18,.88),0 1px 0 rgba(255,255,255,.18) inset
  }
  .booking-cta::before{
    content:"Buchen";position:static;inset:auto;display:block;
    border:0;width:auto;height:auto;background:none;
    font-size:.66rem;line-height:1;letter-spacing:.1em;text-indent:.1em;color:var(--pine-fg)
  }
  .booking-cta::after{display:none}
  .booking-cta:hover{background:var(--accent-2);color:var(--light-ink)}
  .nav-burger{width:42px;height:42px}
  .nav-burger span{left:8px;width:26px}
}

/* =============================================================
   WANDERN — Tourenportal-Komponenten (gleiche Tokens & Typo)
   ============================================================= */
:root{
  --d-leicht:#8a9a5b;   /* leicht  – Lodengrün */
  --d-mittel:#c98a4b;   /* mittel  – Lärche/Akzent */
  --d-schwer:#b45a3c;   /* schwer  – warmes Terrakotta */
}

/* Schwierigkeits-Legende */
.legend{display:flex;flex-wrap:wrap;gap:1.6rem;justify-content:center;
  margin-top:1.8rem}
.legend span{display:inline-flex;align-items:center;gap:.6rem;
  font-size:.78rem;letter-spacing:.04em;color:var(--fg-dim)}
.legend i{width:11px;height:11px;border-radius:50%;flex:none}
.lg-leicht{background:var(--d-leicht)}
.lg-mittel{background:var(--d-mittel)}
.lg-schwer{background:var(--d-schwer)}

/* Tourenraster */
.tour-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem;perspective:1400px}
.tour-card{background:var(--bg-2);border:1px solid var(--line);
  border-radius:6px;overflow:hidden;display:flex;flex-direction:column;
  position:relative;isolation:isolate;
  transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(0);
  transition:transform .5s var(--ease),border-color .5s var(--ease),box-shadow .5s var(--ease)}
.tour-card::before{
  content:"";position:absolute;inset:0;z-index:-1;opacity:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,20%),rgba(232,201,149,.24),transparent 24rem);
  transition:opacity .45s var(--ease)
}
.tour-card:hover{transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(-8px);
  border-color:var(--line-2);
  box-shadow:0 30px 90px -62px rgba(31,24,18,.78)}
.tour-card:hover::before{opacity:1}
.tour-fig{position:relative;height:230px;overflow:hidden}
.tour-fig img{width:100%;height:100%;object-fit:cover;
  filter:saturate(.92) brightness(.82);transition:transform 1s var(--ease)}
.tour-card:hover .tour-fig img{transform:scale(1.06)}
.tour-fig::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,20,17,0) 40%,rgba(8,20,17,.7))}
.diff{position:absolute;top:1rem;left:1rem;z-index:1;
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(8,20,17,.72);backdrop-filter:blur(4px);
  border:1px solid var(--line-2);color:#fff;
  font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:.5rem .85rem;border-radius:999px}
.diff i{width:9px;height:9px;border-radius:50%;flex:none}
.diff.is-leicht i{background:var(--d-leicht)}
.diff.is-mittel i{background:var(--d-mittel)}
.diff.is-schwer i{background:var(--d-schwer)}
.tour-tag{position:absolute;bottom:1rem;left:1rem;z-index:1;color:#fff;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  opacity:.85}
.tour-body{padding:1.8rem 1.9rem 2rem;flex:1;display:flex;flex-direction:column}
.tour-body h3{font-size:1.45rem;color:var(--fg)}
.tour-body .t-desc{color:var(--fg-dim);font-size:.95rem;margin:.7rem 0 1.3rem;
  flex:1;line-height:1.6}
.tour-meta{display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);border-left:1px solid var(--line)}
.tour-stat{border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:.85rem .9rem}
.tour-stat span{display:block;font-size:.6rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted)}
.tour-stat b{display:block;margin-top:.3rem;font-size:.98rem;font-weight:600;
  color:var(--fg)}
/* Höhenschema (illustrativ) */
.profile{margin-top:1.3rem}
.profile svg{width:100%;height:64px;display:block;overflow:visible}
.profile .pf-line{fill:rgba(131,185,177,.14);stroke:var(--accent);
  stroke-width:2}
.profile .pf-dot{fill:var(--accent)}
.profile .pf-cap{font:600 9px/1 var(--sans);fill:var(--muted);
  letter-spacing:.04em}
.profile .pf-note{margin-top:.5rem;font-size:.7rem;color:var(--muted);
  letter-spacing:.04em}

/* Bergwetter (Open-Meteo, live) */
.weather{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  overflow:hidden}
.wx-head{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;
  justify-content:space-between;padding:1.8rem 2rem;
  border-bottom:1px solid var(--line)}
.wx-now{display:flex;align-items:center;gap:1.4rem}
.wx-ico{font-size:2.8rem;line-height:1}
.wx-temp{font-size:2.6rem;font-weight:600;color:var(--fg);line-height:1}
.wx-meta span{display:block;font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted)}
.wx-meta b{display:block;margin-top:.25rem;font-weight:600;color:var(--fg-dim);
  font-size:.95rem}
.wx-loc{text-align:right}
.wx-loc b{display:block;font-weight:600;color:var(--fg)}
.wx-loc span{font-size:.78rem;color:var(--muted)}
.wx-grid{display:grid;grid-template-columns:repeat(5,1fr)}
.wx-day{padding:1.4rem 1rem;text-align:center;border-right:1px solid var(--line)}
.wx-day:last-child{border-right:0}
.wx-day .d{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted)}
.wx-day .i{font-size:1.7rem;margin:.6rem 0}
.wx-day .t{font-size:.95rem;color:var(--fg);font-weight:600}
.wx-day .t small{color:var(--muted);font-weight:400}
.wx-day .p{font-size:.72rem;color:var(--accent-2);margin-top:.3rem}
.wx-msg{padding:1.6rem 2rem;color:var(--muted);font-size:.9rem}
.wx-foot{padding:1rem 2rem;border-top:1px solid var(--line);
  font-size:.74rem;color:var(--muted);display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:.5rem}
.wx-foot a{color:var(--accent);border-bottom:1px solid var(--accent)}

/* Alpiner Sicherheitshinweis */
.alp-note{display:flex;gap:1.4rem;align-items:flex-start;
  background:var(--bg-2);border:1px solid var(--line);
  border-left:3px solid var(--accent);border-radius:4px;
  padding:1.8rem 2rem}
.alp-note .ico{font-size:1.6rem;flex:none;line-height:1.2}
.alp-note h3{font-size:1.15rem;margin-bottom:.5rem}
.alp-note p{color:var(--fg-dim);font-size:.95rem;line-height:1.65;max-width:none}

@media (max-width:880px){
  .tour-grid{grid-template-columns:1fr}
  .wx-grid{grid-template-columns:repeat(5,1fr)}
  .wx-head{padding:1.4rem}
  .wx-day{padding:1.1rem .5rem}
  .wx-loc{text-align:left}
}
@media (max-width:560px){
  .wx-grid{grid-template-columns:1fr 1fr}
  .wx-day:nth-child(odd){border-right:1px solid var(--line)}
  .wx-temp{font-size:2.1rem}.wx-ico{font-size:2.2rem}
  .legend{gap:1rem}
  .alp-note{flex-direction:column;gap:.8rem;padding:1.5rem}
}

/* =============================================================
   INTERAKTIVE TOURENKARTE (Animation, self-contained)
   ============================================================= */
.trailmap{position:relative;border:1px solid var(--line);border-radius:10px;
  overflow:hidden;background:
   radial-gradient(120% 90% at 30% 10%,rgba(201,138,75,.12),transparent 60%),
   linear-gradient(180deg,var(--bg-3),var(--bg-2))}
.tm-canvas{position:relative;width:100%}
.tm-canvas svg{display:block;width:100%;height:auto;
  transform:scale(1.05);opacity:0;
  transition:transform 1.4s var(--ease),opacity 1s var(--ease)}
.trailmap.in .tm-canvas svg{transform:scale(1);opacity:1}

.tm-terrain{fill:none;stroke:rgba(244,236,219,.07);stroke-width:1.5}
.tm-lake{fill:rgba(120,150,150,.30);stroke:rgba(199,224,224,.35);stroke-width:1.5}
.tm-ridge{fill:rgba(201,138,75,.13);stroke:rgba(201,138,75,.5);stroke-width:1.5}
.tm-label{font:600 14px/1 var(--sans);fill:var(--fg-dim);letter-spacing:.04em}
.tm-label.sm{font-size:12px;fill:var(--muted)}

.tm-trail{fill:none;stroke-width:3;stroke-linecap:round;
  stroke-dasharray:1;stroke-dashoffset:1;opacity:.5;
  transition:stroke-dashoffset 1.5s var(--ease),opacity .35s var(--ease),
    stroke-width .25s var(--ease)}
.tm-trail.t-leicht{stroke:var(--d-leicht)}
.tm-trail.t-mittel{stroke:var(--d-mittel)}
.tm-trail.t-schwer{stroke:var(--d-schwer)}
.trailmap.in .tm-trail{stroke-dashoffset:0}
.tm-trail.is-hl{opacity:1;stroke-width:5}
.trailmap.filtering .tm-trail{opacity:.08}
.trailmap.filtering .tm-trail.is-show{opacity:.85}

.tm-node{cursor:pointer}
.tm-node .nd{transition:r .25s var(--ease),fill .25s var(--ease)}
.tm-node .ring{fill:none;stroke-width:2;opacity:.45;
  transform-box:fill-box;transform-origin:center;transition:opacity .25s}
.tm-node.n-leicht .nd{fill:var(--d-leicht)} .tm-node.n-leicht .ring{stroke:var(--d-leicht)}
.tm-node.n-mittel .nd{fill:var(--d-mittel)} .tm-node.n-mittel .ring{stroke:var(--d-mittel)}
.tm-node.n-schwer .nd{fill:var(--d-schwer)} .tm-node.n-schwer .ring{stroke:var(--d-schwer)}
.tm-node:hover .nd,.tm-node:focus-visible .nd{r:11}
.tm-node:hover .ring,.tm-node:focus-visible .ring{opacity:.9}
.tm-node:focus{outline:none}
.tm-node.dim{opacity:.12;pointer-events:none}
.tm-ntxt{font:700 13px/1 var(--sans);fill:var(--fg);
  paint-order:stroke;stroke:var(--bg);stroke-width:4px}

/* Hütte-Marker */
.tm-hut .hx{fill:var(--accent)}
.tm-hut .pulse{fill:var(--accent);opacity:.5;transform-box:fill-box;
  transform-origin:center;animation:tmpulse 2.6s var(--ease) infinite}
@keyframes tmpulse{0%{transform:scale(.6);opacity:.55}
  70%{transform:scale(2.4);opacity:0}100%{opacity:0}}
.tm-hlabel{font:700 15px/1 var(--disp);fill:var(--fg)}

/* Tooltip */
.tm-tip{position:absolute;z-index:5;min-width:170px;max-width:240px;
  background:var(--bg);border:1px solid var(--line-2);border-radius:8px;
  padding:.85rem 1rem;box-shadow:0 22px 50px -28px rgba(0,0,0,.95);
  transform:translate(-50%,-118%);pointer-events:none;
  opacity:0;transition:opacity .2s var(--ease)}
.tm-tip.show{opacity:1}
.tm-tip b{display:block;font-family:var(--disp);font-size:1rem;color:var(--fg)}
.tm-tip .m{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem;
  font-size:.74rem;color:var(--fg-dim)}
.tm-tip .m em{font-style:normal;color:var(--accent-2);
  border:1px solid var(--line-2);border-radius:999px;padding:.15rem .55rem}

/* Legende / Filter */
.tm-legend{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;
  padding:1.1rem;border-top:1px solid var(--line);background:rgba(0,0,0,.18)}
.tm-fl{display:inline-flex;align-items:center;gap:.5rem;
  font-size:.74rem;font-weight:600;letter-spacing:.06em;color:var(--fg-dim);
  border:1px solid var(--line-2);border-radius:999px;padding:.5rem 1rem;
  transition:background .25s,color .25s}
.tm-fl i{width:9px;height:9px;border-radius:50%}
.tm-fl:hover{color:var(--fg)}
.tm-fl.is-on{background:var(--accent);border-color:var(--accent);
  color:var(--light-ink)}
@media (max-width:560px){
  .tm-label{font-size:12px}.tm-label.sm{display:none}
  .tm-ntxt{font-size:12px}
  .tm-tip{min-width:140px}
}
@media (prefers-reduced-motion:reduce){
  .tm-canvas svg{transition:none;opacity:1;transform:none}
  .tm-trail{transition:none;stroke-dashoffset:0}
  .tm-hut .pulse{animation:none}
}

/* =============================================================
   ECHTE INTERAKTIVE KARTE (Leaflet, lazy)
   ============================================================= */
.fmap{position:relative;border:1px solid var(--line-2);border-radius:12px;
  overflow:hidden;background:var(--bg-2);
  box-shadow:0 26px 60px -36px rgba(0,0,0,.9)}
.fmap-canvas{width:100%;height:clamp(420px,42vw,560px);background:
  radial-gradient(120% 90% at 20% 10%,rgba(201,138,75,.10),transparent 60%),
  linear-gradient(180deg,var(--bg-3),var(--bg-2))}
.fmap-consent{position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;gap:1rem;padding:2rem;
  background:radial-gradient(80% 60% at 50% 40%,rgba(43,33,23,.85),rgba(22,17,12,.95));
  backdrop-filter:blur(2px);transition:opacity .35s var(--ease)}
.fmap-consent.hide{opacity:0;pointer-events:none}
.fmap-consent h3{color:var(--fg);font-size:1.4rem}
.fmap-consent p{color:var(--fg-dim);max-width:46ch;font-size:.95rem;line-height:1.6}

.fmap-legend{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1.6rem;
  padding:1rem clamp(1rem,3vw,1.6rem);
  border-top:1px solid rgba(145,103,48,.22);background:rgba(181,171,142,.82);
  font-size:.78rem;color:#635846;position:relative;z-index:3}
.fmap-legend span{display:inline-flex;align-items:center;gap:.5rem}
.fmap-legend i{width:11px;height:11px;border-radius:50%;display:inline-block;
  box-shadow:0 0 0 3px rgba(255,248,229,.82) inset,0 0 0 2px rgba(80,62,38,.28)}
.fl-hut{background:#c4452b}   /* Hüttendach-Rot */
.fl-peak{background:#c98a4b}  /* Lärchen-Amber */
.fl-lake{background:#3f7bb0}  /* Alpensee-Blau */
.fmap-ext{margin-left:auto;color:#9c642e;border-bottom:1px solid #9c642e;
  padding-bottom:1px;font-weight:600;letter-spacing:.04em}
.fmap-ext:hover{color:var(--accent-2);border-color:var(--accent-2)}
.fmap-credit{font-size:.68rem;opacity:.78}

@media (max-width:560px){
  .fmap-canvas{height:560px}
  .fmap-legend{gap:.4rem 1rem;font-size:.74rem}
  .fmap-ext{margin-left:0}
}

/* Tour-Info-Panel unterhalb der Karte */
.fmap-hint{color:var(--muted);font-style:italic}
.tour-panel{
  position:relative;margin-top:1.2rem;padding:1.6rem 1.8rem 1.4rem;
  background:linear-gradient(180deg,var(--bg-2),var(--bg-3));
  border:1px solid var(--line-2);border-left:4px solid var(--accent);
  border-radius:10px;box-shadow:0 22px 50px -32px rgba(31,24,18,.35)
}
.tour-panel.is-leicht{border-left-color:var(--d-leicht)}
.tour-panel.is-mittel{border-left-color:var(--d-mittel)}
.tour-panel.is-schwer{border-left-color:var(--d-schwer)}
.tour-panel .tp-close{
  position:absolute;top:.75rem;right:.85rem;
  width:30px;height:30px;border-radius:50%;
  background:rgba(31,24,18,.06);color:var(--fg);
  font-size:1.2rem;line-height:1;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .25s
}
.tour-panel .tp-close:hover{background:var(--accent);color:var(--light-ink)}
.tour-panel .tp-eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent)
}
.tour-panel .tp-chip{
  width:9px;height:9px;border-radius:50%;display:inline-block;
  box-shadow:0 0 0 2px var(--bg-2)
}
.tp-chip.is-leicht{background:var(--d-leicht)}
.tp-chip.is-mittel{background:var(--d-mittel)}
.tp-chip.is-schwer{background:var(--d-schwer)}
.tour-panel .tp-title{
  font-family:var(--disp);font-weight:700;color:var(--fg);
  font-size:clamp(1.25rem,2.2vw,1.7rem);margin:.55rem 0 1rem
}
.tour-panel .tp-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);border-left:1px solid var(--line)
}
.tour-panel .tp-stats > div{
  padding:.85rem 1rem;
  border-right:1px solid var(--line);border-bottom:1px solid var(--line)
}
.tour-panel .tp-stats span{
  display:block;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);font-weight:700
}
.tour-panel .tp-stats b{
  display:block;margin-top:.3rem;font-family:var(--disp);font-weight:600;
  color:var(--fg);font-size:1rem
}
.tour-panel .tp-note{
  margin-top:1rem;font-size:.78rem;color:var(--muted);font-style:italic;line-height:1.55
}
@media (max-width:760px){
  .tour-panel .tp-stats{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .tour-panel{padding:1.2rem 1.2rem 1rem}
  .tour-panel .tp-stats{grid-template-columns:1fr}
}

/* =============================================================
   TOUR-KACHELN + DETAIL-POPUP
   ============================================================= */
.tour-tiles{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem
}
.tour-tile{
  display:flex;flex-direction:column;text-align:left;cursor:pointer;
  background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  overflow:hidden;color:var(--fg);font:inherit;padding:0;
  transition:transform .4s var(--ease),border-color .4s var(--ease),
             box-shadow .4s var(--ease)
}
.tour-tile:hover,.tour-tile:focus-visible{
  transform:translateY(-4px);border-color:var(--line-2);
  box-shadow:0 22px 50px -32px rgba(31,24,18,.35);outline:none
}
.tt-fig{display:block;position:relative;height:170px;overflow:hidden}
.tt-fig img{width:100%;height:100%;object-fit:cover;
  transition:transform .9s var(--ease);filter:saturate(1.04) brightness(1.06)}
.tour-tile:hover .tt-fig img{transform:scale(1.06)}
.tt-fig::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(31,24,18,0) 65%,rgba(31,24,18,.35))}
.tt-info{display:flex;flex-direction:column;gap:.4rem;padding:1.1rem 1.2rem 1.2rem;position:relative}
.tour-tile .diff{position:absolute;top:-1.1rem;left:1rem;z-index:1;
  font-size:.62rem;letter-spacing:.18em;padding:.4rem .75rem;
  background:var(--bg-3);border:1px solid var(--line-2);border-radius:999px;
  display:inline-flex;align-items:center;gap:.45rem;text-transform:uppercase;
  color:var(--fg);font-weight:700}
.tour-tile .diff i{width:8px;height:8px;border-radius:50%}
.tt-name{font-family:var(--disp);font-weight:700;font-size:1.2rem;
  color:var(--fg);line-height:1.2}
.tt-meta{font-size:.84rem;color:var(--muted)}

/* Detail-Popup */
body.modal-open{overflow:hidden}
.tour-modal{position:fixed;inset:0;z-index:300;
  display:flex;align-items:center;justify-content:center;
  padding:max(.75rem,env(safe-area-inset-top)) 1rem
          max(.75rem,env(safe-area-inset-bottom)) 1rem;
  animation:tmFadeIn .25s var(--ease)}
.tour-modal[hidden]{display:none !important}
.tm-backdrop{position:absolute;inset:0;background:rgba(15,11,7,.75);
  backdrop-filter:blur(6px);cursor:pointer}
.tm-card{position:relative;width:min(640px,100%);
  /* immer in den sichtbaren Viewport passen — auch auf macOS/iOS */
  max-height:calc(100vh - 1.5rem);
  max-height:calc(100svh - 1.5rem);
  max-height:calc(100dvh - 1.5rem);
  display:flex;flex-direction:column;
  background:var(--bg);border:1px solid var(--line-2);border-radius:12px;
  box-shadow:0 40px 90px -36px rgba(0,0,0,.65);
  animation:tmCardIn .35s var(--ease);overflow:hidden}
@keyframes tmFadeIn{from{opacity:0}to{opacity:1}}
@keyframes tmCardIn{from{opacity:0;transform:translateY(20px) scale(.98)}
  to{opacity:1;transform:none}}
.tm-close{position:absolute;top:.7rem;right:.7rem;z-index:2;
  width:38px;height:38px;border-radius:50%;
  background:var(--bg-2);color:var(--fg);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:1.4rem;line-height:1;cursor:pointer;
  border:1px solid var(--line);transition:background .25s,color .25s}
.tm-close:hover{background:var(--accent);color:var(--light-ink);
  border-color:var(--accent)}
.tm-content{
  flex:1 1 auto;min-height:0;overflow-y:auto;
  padding:1.2rem clamp(1rem,2.6vw,1.6rem) 1.2rem;
  scrollbar-width:thin
}
.tm-content::-webkit-scrollbar{width:8px}
.tm-content::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:4px}
.tm-content .tm-tags{display:none}
.tm-content .tm-title{font-family:var(--disp);font-weight:700;
  font-size:clamp(1.3rem,2.2vw,1.75rem);color:var(--fg);margin:.2rem 0 .9rem;
  padding-right:3rem}
.tm-content .tm-img{width:100%;height:auto;
  max-height:clamp(140px,26vh,220px);object-fit:cover;
  border-radius:6px;margin-bottom:1rem}
.tm-content .tm-desc{color:var(--fg-dim);font-size:.93rem;line-height:1.55;
  margin-bottom:1rem}
.tm-content .tour-meta{margin-bottom:1rem;border-radius:6px;overflow:hidden}
.tm-content .tour-stat{padding:.7rem .8rem}
.tm-content .tour-stat span{font-size:.58rem}
.tm-content .tour-stat b{font-size:.95rem;margin-top:.2rem}
.tm-content .profile{margin-bottom:1.1rem}
.tm-content .profile svg{height:50px}
.tm-content .tm-actions{display:flex;gap:.6rem;flex-wrap:wrap;
  position:sticky;bottom:-1.2rem;
  margin:0 -1rem -1.2rem;padding:.9rem 1rem;
  background:linear-gradient(180deg,rgba(245,236,217,0),var(--bg) 35%);
  z-index:2}
.tm-content .tm-actions .btn{flex:1 1 auto;justify-content:center;min-width:160px;
  padding:.8rem 1.1rem;font-size:.74rem}
.tm-content .diff{display:inline-flex;align-items:center;gap:.45rem;
  font-size:.66rem;letter-spacing:.16em;font-weight:700;text-transform:uppercase;
  padding:.35rem .7rem;border-radius:999px;
  background:var(--bg-2);border:1px solid var(--line-2);color:var(--fg)}
.tm-content .diff i{width:8px;height:8px;border-radius:50%}

@media (max-width:880px){
  .tour-tiles{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .tour-tiles{grid-template-columns:1fr}
  .tt-fig{height:200px}
  .tm-content{padding:1rem 1rem .8rem}
  .tm-content .tm-img{max-height:clamp(120px,22vh,180px)}
  .tm-content .tm-actions{margin:0 -.8rem -1rem;padding:.8rem .8rem}
  .tm-content .tm-actions .btn{min-width:0;width:100%}
}
@media (max-height:640px){
  .tm-content .tm-img{max-height:clamp(100px,18vh,160px)}
  .tm-content .profile{margin-bottom:.7rem}
  .tm-content .profile svg{height:36px}
}

/* Bergmomente-Liste innerhalb des Popups */
.bm-list{display:flex;flex-direction:column;gap:.85rem;margin-bottom:1.2rem}
.bm-item{display:grid;grid-template-columns:120px 1fr;gap:1rem;
  background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  overflow:hidden;transition:border-color .25s,transform .25s var(--ease)}
.bm-item:hover{border-color:var(--line-2);transform:translateX(2px)}
.bm-item img{width:100%;height:100%;object-fit:cover;display:block}
.bm-body{padding:.85rem .9rem .9rem 0;display:flex;flex-direction:column;
  justify-content:center}
.bm-tag{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-2);font-weight:700;margin-bottom:.25rem}
.bm-body h3{font-family:var(--disp);font-weight:700;font-size:1.05rem;
  color:var(--fg);margin:0 0 .35rem;line-height:1.2}
.bm-body p{font-size:.84rem;color:var(--fg-dim);line-height:1.5;margin:0}
@media (max-width:520px){
  .bm-item{grid-template-columns:90px 1fr;gap:.7rem}
  .bm-body{padding:.7rem .8rem .7rem 0}
  .bm-body p{font-size:.8rem}
}

/* Preistabelle im Zimmer-Popup */
.tm-content .tm-ptable{margin-bottom:.8rem}
.tm-content .tm-ptable th,.tm-content .tm-ptable td{padding:.5rem .6rem}
.tm-content .tm-note{font-size:.78rem;color:var(--muted);
  font-style:italic;margin-bottom:1rem;line-height:1.5}

/* =============================================================
   PAGE-ÜBERGÄNGE · SCROLL-FORTSCHRITT · NACH-OBEN-BUTTON
   ============================================================= */

.site-loader{
  position:fixed;inset:0;z-index:500;background:
    radial-gradient(circle at 50% 18%,rgba(232,201,149,.12),transparent 24rem),
    linear-gradient(180deg,#211912,#15100c);
  color:var(--pine-fg);display:grid;place-items:center;
  transition:opacity .42s var(--ease),visibility .42s var(--ease);
  pointer-events:none
}
.site-loader.is-hidden{opacity:0;visibility:hidden}
.loader-mark{text-align:center;letter-spacing:.04em}
.loader-mark b{font-family:var(--disp);font-size:clamp(1.8rem,5vw,3.2rem);
  font-weight:650;display:block;color:var(--pine-fg)}
.loader-mark span{display:block;margin-top:.7rem;font-size:.62rem;font-weight:750;
  letter-spacing:.32em;text-transform:uppercase;color:var(--accent-soft)}
.loader-line{width:min(54vw,360px);height:1px;background:rgba(244,234,212,.18);
  margin:1.4rem auto 0;overflow:hidden}
.loader-line i{display:block;width:42%;height:100%;background:linear-gradient(90deg,transparent,var(--accent-soft),transparent);
  animation:loaderLine 1.05s var(--ease) infinite}
@keyframes loaderLine{from{transform:translateX(-110%)}to{transform:translateX(260%)}}

/* Seiten-Fade beim Laden + Wechsel */
.js body{animation:pageIn .32s var(--ease) both}
@keyframes pageIn{
  from{opacity:0}
  to{opacity:1}
}
.js body.is-leaving{
  opacity:0;
  transition:opacity .2s var(--ease);
  animation:none
}
@media (prefers-reduced-motion:reduce){
  .js body{animation:none}
  .js body.is-leaving{transition:none}
}

/* Scroll-Fortschrittsbalken */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  z-index:200;pointer-events:none;
  transition:width .12s ease-out;
  box-shadow:0 0 8px rgba(179,116,58,.45)
}

/* Nach-oben-Button */
.to-top{
  position:fixed;right:1.25rem;bottom:1.25rem;z-index:150;
  width:44px;height:44px;border-radius:50%;
  background:var(--accent);color:var(--light-ink);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:1.2rem;font-weight:700;cursor:pointer;
  border:1px solid var(--line-2);
  box-shadow:0 14px 30px -14px rgba(31,24,18,.55),
             0 1px 0 rgba(255,255,255,.25) inset;
  opacity:0;transform:translateY(14px);pointer-events:none;
  transition:opacity .35s var(--ease),transform .35s var(--ease),
             background .25s,color .25s
}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{background:var(--accent-2)}
.to-top:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
@media (max-width:560px){.to-top{right:1rem;bottom:1rem;width:40px;height:40px}}

/* =============================================================
   EIGENE TOPO-WANDERKARTE (SVG, kein externes Material)
   ============================================================= */
.fmap{position:relative;border:1px solid rgba(120,90,40,.35);border-radius:8px;
  overflow:hidden;background:#f5e9c8;
  box-shadow:0 24px 56px -32px rgba(31,24,18,.5)}
.fmap::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.32),transparent 22rem),
    linear-gradient(115deg,transparent 36%,rgba(255,255,255,.13) 50%,transparent 64%);
  opacity:.42;mix-blend-mode:soft-light;
  transform:translateX(var(--scan,0));
  transition:opacity .45s var(--ease)
}
.fmap.is-tour-active::before{opacity:.7}
.fmap-svg{display:block;width:100%;height:auto;
  font-family:Georgia,"Times New Roman",serif;
  user-select:none;cursor:grab;touch-action:none}
.fmap-svg.is-grabbing{cursor:grabbing}

/* Höhenlinien (echte, via Marching Squares) */
.fmap-svg .contours .ct{stroke:#9a703f;stroke-width:.45;fill:none;opacity:.75;
  vector-effect:non-scaling-stroke}
.fmap-svg .contours .ct-idx{stroke:#6e4621;stroke-width:.95;fill:none;opacity:.92;
  vector-effect:non-scaling-stroke}

/* Höhen-Beschriftungen */
.fmap-svg .ct-label{font-family:Georgia,serif;font-style:italic;font-size:9px;
  fill:#6e4621;font-weight:600;letter-spacing:.5px;
  paint-order:stroke;stroke:#f5e9c8;stroke-width:2.5px;stroke-linejoin:round}

/* Forst — semi-transparentes Grün */
.fmap-svg .forest-zone{fill:rgba(146,184,113,.55);stroke:rgba(98,138,72,.35);stroke-width:.6}

/* Bäche */
.fmap-svg .streams path{fill:none;stroke:#3e7aa2;stroke-width:1.1;
  stroke-linecap:round;opacity:.85;vector-effect:non-scaling-stroke}

/* Straße / Mautstraße */
.fmap-svg .road{fill:none;stroke:#2a2014;stroke-width:1.6;
  stroke-linecap:round;opacity:.78;vector-effect:non-scaling-stroke}
.fmap-svg .road-label{font-family:Georgia,serif;font-style:italic;font-size:9.5px;
  fill:#2a2014;font-weight:600;
  paint-order:stroke;stroke:#f5e9c8;stroke-width:2px;stroke-linejoin:round}

/* See */
.fmap-svg .lake-shape{stroke:#2c5675;stroke-width:1.3}
.fmap-svg .lake-label{font-style:italic;font-weight:700;font-size:13.5px;
  fill:#1f4763;letter-spacing:.3px;
  paint-order:stroke;stroke:#e3eef7;stroke-width:2.5px;stroke-linejoin:round}

/* Gipfel-Symbol */
.fmap-svg .peak-name{font-style:italic;font-weight:700;font-size:12px;
  fill:#1a1108;letter-spacing:.2px;
  paint-order:stroke;stroke:#f5e9c8;stroke-width:2.5px;stroke-linejoin:round}
.fmap-svg .peak-alt{font-style:italic;font-size:10px;fill:#3a2014;font-weight:600;
  paint-order:stroke;stroke:#f5e9c8;stroke-width:2px;stroke-linejoin:round}

/* Kompass + Maßstab + Titel */
.fmap-svg .compass-label{font-family:Georgia,serif;font-weight:700;font-size:13px;fill:#3a2918}
.fmap-svg .scale-label{font-family:Arial,sans-serif;font-size:9.5px;fill:#1a1108;font-weight:600}
.fmap-svg .mt-eyebrow{font-family:Georgia,serif;font-weight:700;font-size:11px;
  fill:#3a2014;letter-spacing:.18em}
.fmap-svg .mt-sub{font-family:Arial,sans-serif;font-size:9.5px;fill:#6e4621;font-weight:600}

/* Hütten-Label */
.fmap-svg .m-label{font-style:italic;font-weight:700;font-size:11.5px;
  fill:#1a1108;paint-order:stroke;stroke:#f5e9c8;stroke-width:2.8px;stroke-linejoin:round}

/* Wanderpfade — rot gestrichelt, nach Schwierigkeit gefärbt */
.fmap-svg .trail{
  stroke:#c4452b;stroke-width:2.3;stroke-dasharray:.035 .028;fill:none;
  opacity:.38;vector-effect:non-scaling-stroke;
  transition:opacity .35s,stroke-width .35s,filter .35s;
  filter:drop-shadow(0 0 1px rgba(255,255,255,.7));
}
.fmap-svg .trail.t-leicht{stroke:#4f7a3a}
.fmap-svg .trail.t-mittel{stroke:#c4452b}
.fmap-svg .trail.t-schwer{stroke:#7d2f18}
.fmap-svg .trail.is-hover{opacity:1;stroke-width:3.4}
.fmap-svg .trail.is-active{opacity:1;stroke-width:3.8;
  filter:drop-shadow(0 0 5px rgba(196,69,43,.65)) drop-shadow(0 0 12px rgba(232,201,149,.25));
  animation:trailLive 5.6s ease-in-out infinite 4.2s}
@keyframes trailLive{50%{stroke-width:4.2;opacity:.92}}

/* Marker */
.fmap-svg .map-marker{cursor:pointer;outline:none}
.fmap-svg .m-ring{fill:#fffaf0;stroke:#3a2014;stroke-width:1.3;
  transition:r .25s,stroke-width .25s,fill .25s;vector-effect:non-scaling-stroke}
.fmap-svg .m-bg{fill:#c98a4b;transition:fill .25s,r .25s}
.fmap-svg .m-ico{fill:#fffaf0;transition:fill .25s}
.fmap-svg .m-peak .m-bg{fill:#c98a4b}
.fmap-svg .m-lake .m-bg{fill:#3f7bb0}
.fmap-svg .map-marker:hover .m-ring,
.fmap-svg .map-marker:focus-visible .m-ring,
.fmap-svg .map-marker.is-hover .m-ring,
.fmap-svg .map-marker.is-active .m-ring{r:16;stroke-width:1.7}
.fmap-svg .map-marker:hover .m-bg,
.fmap-svg .map-marker:focus-visible .m-bg,
.fmap-svg .map-marker.is-hover .m-bg,
.fmap-svg .map-marker.is-active .m-bg{r:12}
.fmap-svg .m-peak.is-active .m-bg{fill:#b45a3c}
.fmap-svg .map-marker:hover,
.fmap-svg .map-marker:focus-visible,
.fmap-svg .map-marker.is-active{filter:drop-shadow(0 4px 9px rgba(31,24,18,.34))}

/* Hütten-Puls */
.fmap-svg .m-hut .m-pulse{fill:#c4452b;opacity:.32;transform-box:fill-box;
  transform-origin:center;animation:hutPulse 2.6s ease-out infinite}
@keyframes hutPulse{
  0%{transform:scale(.6);opacity:.5}
  70%{transform:scale(1.9);opacity:0}
  100%{opacity:0}
}

/* Zoom-Buttons */
.fmap-controls{position:absolute;right:14px;top:14px;display:flex;flex-direction:column;
  gap:6px;z-index:5}
.fmap-btn{width:36px;height:36px;border:1px solid rgba(120,90,40,.35);
  background:rgba(255,250,238,.92);color:#3a2014;font-size:17px;font-weight:700;
  border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;
  justify-content:center;backdrop-filter:blur(6px);
  box-shadow:0 6px 14px -8px rgba(31,24,18,.4);
  transition:background .2s,color .2s,transform .15s}
.fmap-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.fmap-btn:active{transform:scale(.95)}
.fmap-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

@media (max-width:560px){
  .fmap-svg .peak-name{font-size:10px}
  .fmap-svg .peak-alt{font-size:8.5px}
  .fmap-svg .lake-label{font-size:11px}
  .fmap-svg .m-label{font-size:10px}
  .fmap-svg .ct-label{font-size:8px}
  .fmap-controls{right:8px;top:8px}
  .fmap-btn{width:32px;height:32px;font-size:15px}
}
@media (prefers-reduced-motion:reduce){
  .fmap-svg .trail{transition:none}
  .fmap-svg .trail.is-active{animation:none}
  .fmap-svg .m-hut .m-pulse{animation:none}
  .fmap::before{display:none}
}

/* ---------- Foto-Credit (Bildnachweis am Bild) ---------- */
.split-media{position:relative}
.photo-credit{
  position:absolute;right:8px;bottom:8px;z-index:4;
  font-family:var(--sans);font-size:.6rem;font-weight:600;letter-spacing:.03em;
  color:rgba(255,255,255,.9);background:rgba(20,15,10,.46);
  padding:.22rem .5rem;border-radius:4px;backdrop-filter:blur(3px);
  pointer-events:none;line-height:1.2;max-width:90%
}
.tm-img-wrap{position:relative;display:block}
.tm-img-wrap .photo-credit{right:6px;bottom:6px;font-size:.58rem}

/* Credit auf CTA-Bändern über dem Overlay */
.cta-band > .photo-credit{z-index:3;right:10px;bottom:10px}
