:root{
  --bg:#f5f1e8;
  --paper:#fffaf0;
  --ink:#152019;
  --muted:#657267;
  --green:#13251c;
  --green-2:#203a2c;
  --sand:#e8dcc7;
  --accent:#d98a3d;
  --white:#fff;
  --shadow:0 22px 70px rgba(19,37,28,.18);
  --radius:28px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.6}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.container{width:min(calc(100% - 32px),var(--max));margin-inline:auto}.narrow{max-width:760px}.skip-link{position:absolute;left:1rem;top:-4rem;background:var(--green);color:white;padding:.7rem 1rem;border-radius:999px;z-index:50}.skip-link:focus{top:1rem}.site-header{position:fixed;inset:0 0 auto 0;height:74px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(18px,4vw,54px);z-index:20;color:white;transition:background .25s ease,backdrop-filter .25s ease,box-shadow .25s ease}.site-header.is-scrolled{background:rgba(19,37,28,.86);backdrop-filter:blur(16px);box-shadow:0 10px 30px rgba(0,0,0,.18)}.brand{font-weight:800;letter-spacing:.03em}.site-nav{display:flex;gap:28px;text-transform:lowercase;font-size:.95rem}.site-nav a{opacity:.86}.site-nav a:hover{opacity:1}.nav-toggle{display:none;background:none;border:0;width:44px;height:44px;place-items:center;padding:10px}.nav-toggle span{display:block;width:22px;height:2px;background:white;margin:4px 0;border-radius:4px}.hero{min-height:100svh;position:relative;display:grid;place-items:center;overflow:hidden;color:white;text-align:center}.hero__image{position:absolute;inset:0;background:url('../img/hero.webp') center/cover no-repeat;transform:scale(1.03)}.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,15,10,.66),rgba(7,15,10,.28) 38%,rgba(7,15,10,.72));}.hero__content{position:relative;z-index:1;width:min(920px,calc(100% - 32px));padding-top:42px;transform:translateY(-5vh)}.hero__logo{width:clamp(150px,22vw,230px);height:auto;margin:0 auto 20px;border-radius:999px;filter:drop-shadow(0 18px 28px rgba(0,0,0,.38))}.hero__eyebrow{text-transform:uppercase;letter-spacing:.28em;font-size:.74rem;font-weight:800;margin:0 0 16px;color:rgba(255,255,255,.78)}h1,h2{line-height:1.04;margin:0;letter-spacing:-.045em}.hero h1{font-size:clamp(3rem,8vw,7.5rem);max-width:980px;margin:auto;text-wrap:balance}.hero__subtitle{font-size:clamp(1.08rem,2.2vw,1.45rem);max-width:780px;margin:26px auto 34px;color:rgba(255,255,255,.88);text-wrap:balance}.button{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:14px 24px;font-weight:800;text-transform:lowercase;transition:.2s ease}.button--ghost{border:1px solid rgba(255,255,255,.72);color:white;background:rgba(255,255,255,.08)}.button--ghost:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:1;width:42px;height:42px;border:1px solid rgba(255,255,255,.5);border-radius:999px;display:grid;place-items:center;color:white;animation:bob 1.8s ease-in-out infinite}.intro{padding:62px 0 24px}.intro p{font-size:clamp(1.2rem,2.6vw,1.8rem);line-height:1.35;text-align:center;margin:0;color:#2b3a30;text-wrap:balance}.section{padding:72px 0}.section-heading{margin-bottom:28px}.kicker{margin:0 0 10px;text-transform:uppercase;letter-spacing:.22em;color:var(--accent);font-size:.78rem;font-weight:900}.section-heading h2{font-size:clamp(2.1rem,4.8vw,4.2rem)}.tour-card{background:var(--paper);border:1px solid rgba(19,37,28,.08);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.tour-info{display:grid;grid-template-columns:1fr 1.45fr 1fr;gap:1px;background:rgba(19,37,28,.1);border-bottom:1px solid rgba(19,37,28,.08)}.tour-info__item{display:flex;gap:16px;align-items:flex-start;background:rgba(255,250,240,.94);padding:24px}.tour-info__icon{font-size:1.65rem;line-height:1}.tour-info__label{display:block;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;font-weight:900;color:var(--muted);margin-bottom:5px}.tour-info strong{font-size:1.18rem;line-height:1.2}.tour-info small{display:block;color:var(--muted);margin-top:4px}.weather-days{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.weather-day{border-radius:999px;background:#eef0e7;padding:5px 9px;font-size:.82rem;color:#314036;font-weight:750}.difficulty-dots{letter-spacing:.08em;color:var(--green)}.komoot-frame{padding:18px;background:linear-gradient(180deg,#fffaf0,#f3eadb)}.komoot-frame iframe{display:block;width:100%;height:min(720px,78vh);border:0;border-radius:20px;background:white;box-shadow:inset 0 0 0 1px rgba(19,37,28,.08)}.tour-description{padding:0 24px 28px;display:flex;align-items:center;justify-content:space-between;gap:24px}.tour-description p{max-width:760px;margin:0;color:#3d493f}.text-link{font-weight:900;color:var(--green);border-bottom:2px solid var(--accent);white-space:nowrap}.more-tours{padding-top:38px}.more-tours__card{background:linear-gradient(135deg,var(--green),var(--green-2));color:white;border-radius:var(--radius);padding:clamp(34px,7vw,82px);text-align:center;box-shadow:var(--shadow)}.more-tours__card p{margin:0 0 12px;text-transform:uppercase;letter-spacing:.22em;color:rgba(255,255,255,.72);font-weight:900;font-size:.78rem}.more-tours__card h2{font-size:clamp(2rem,4.5vw,4.6rem);max-width:900px;margin:auto;text-wrap:balance}.instagram{padding-top:28px}.instagram .container{background:rgba(255,250,240,.65);border-radius:var(--radius);padding:18px;box-shadow:0 10px 35px rgba(19,37,28,.08)}.site-footer{background:var(--green);color:white;padding:32px 0}.site-footer__inner{display:flex;justify-content:space-between;align-items:center;gap:20px}.site-footer p{margin:0;color:rgba(255,255,255,.76)}.site-footer nav{display:flex;gap:18px;flex-wrap:wrap}.site-footer a{color:rgba(255,255,255,.78)}.site-footer a:hover{color:white}.to-top{position:fixed;right:18px;bottom:18px;width:46px;height:46px;border-radius:999px;border:0;background:var(--green);color:white;font-weight:900;box-shadow:0 12px 30px rgba(0,0,0,.18);opacity:0;pointer-events:none;transform:translateY(12px);transition:.2s ease}.to-top.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}.reveal{opacity:0;transform:translateY(18px);transition:opacity .65s ease,transform .65s ease}.reveal.is-visible{opacity:1;transform:translateY(0)}@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,-8px)}}
@media (max-width:820px){.site-header{height:66px}.nav-toggle{display:block}.site-nav{position:absolute;right:16px;top:66px;background:rgba(19,37,28,.96);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:16px;display:grid;gap:12px;min-width:180px;opacity:0;pointer-events:none;transform:translateY(-8px);transition:.2s ease}.site-nav.is-open{opacity:1;pointer-events:auto;transform:translateY(0)}.hero__content{padding-top:16px}.hero__eyebrow{font-size:.66rem;letter-spacing:.2em}.tour-info{grid-template-columns:1fr}.tour-info__item{padding:20px}.tour-description{display:block}.tour-description p{margin-bottom:18px}.komoot-frame{padding:10px}.komoot-frame iframe{height:620px;border-radius:18px}.site-footer__inner{display:block;text-align:center}.site-footer nav{justify-content:center;margin-top:14px}.section{padding:54px 0}.intro{padding-top:44px}}
@media (max-width:480px){.container{width:min(calc(100% - 24px),var(--max))}.hero__logo{width:150px}.button{width:100%;max-width:320px}.tour-info__item{gap:12px}.tour-info strong{font-size:1.05rem}.komoot-frame iframe{height:560px}.instagram .container{padding:10px;border-radius:20px}}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

/* v2.1 refinements */
.hero__content.reveal{transform:translateY(calc(-5vh + 18px));}
.hero__content.reveal.is-visible{transform:translateY(-5vh);}
.hero .button{margin-top:4px;}
.section-heading h2{text-transform:none;}
.more-tours__subtitle{display:block;max-width:820px;margin:22px auto 0;color:rgba(255,255,255,.78);font-size:clamp(1rem,1.8vw,1.18rem);line-height:1.65;}
@media (max-width:820px){.hero__content{transform:none}.hero__content.reveal{transform:translateY(18px)}.hero__content.reveal.is-visible{transform:translateY(0)}.hero__subtitle{margin-bottom:28px}.more-tours__subtitle{margin-top:18px}}


/* v2.1.1 design-freeze refinements */
.brand{display:inline-flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.03em}
.brand__logo{width:42px;height:42px;border-radius:999px;object-fit:cover;filter:drop-shadow(0 4px 10px rgba(0,0,0,.22))}
.section-heading h2{font-size:clamp(1.45rem,2.4vw,2rem);letter-spacing:-.025em;line-height:1.15;margin-bottom:22px}
@media (max-width:480px){.brand__logo{width:36px;height:36px}.brand{gap:8px}.section-heading h2{font-size:1.38rem}}


/* v2.2.2 global weather + compact tour cards */
.weather-section{padding:56px 0 18px}
.weather-dashboard{background:linear-gradient(135deg,var(--green),var(--green-2));color:white;border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(26px,5vw,54px);display:grid;grid-template-columns:1.1fr 1.25fr 1fr;gap:clamp(18px,4vw,44px);align-items:center}
.weather-dashboard__label{text-transform:uppercase;letter-spacing:.2em;font-size:.78rem;font-weight:900;color:rgba(255,255,255,.72)}
.weather-dashboard__main{font-size:clamp(1.65rem,3vw,3rem);font-weight:900;letter-spacing:-.04em;line-height:1.05}
.weather-dashboard__advice{color:rgba(255,255,255,.84);font-weight:750}
.weather-dashboard__days{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.weather-dashboard .weather-day{background:rgba(255,255,255,.12);color:white;border:1px solid rgba(255,255,255,.18)}
.tours{padding-top:42px}
.tour-card > .section-heading{padding:clamp(24px,4vw,40px) clamp(22px,4vw,38px) 18px;margin:0;border-bottom:1px solid rgba(19,37,28,.08)}
.tour-card > .section-heading h2{margin:0;font-size:clamp(1.55rem,2.7vw,2.2rem);font-weight:850;letter-spacing:-.03em}
.tour-info{grid-template-columns:1fr 1fr}
.tour-info__item{min-height:112px}
@media (max-width:820px){.weather-section{padding:42px 0 10px}.weather-dashboard{grid-template-columns:1fr;text-align:left}.weather-dashboard__days{justify-content:flex-start}.tour-info{grid-template-columns:1fr}.tour-card > .section-heading{padding:24px 22px 16px}}

/* v2.2.3 track badge inside tour info row */
.tour-card > .section-heading{display:none}
.tour-info{grid-template-columns:.72fr 1.14fr 1.14fr;border-bottom:1px solid rgba(19,37,28,.08)}
.tour-info__item--number{background:linear-gradient(135deg,rgba(19,37,28,.98),rgba(32,58,44,.94));color:white;align-items:center}
.tour-info__item--number .tour-info__label{color:rgba(255,255,255,.66)}
.tour-info__item--number strong{color:white}
.tour-badge{position:relative;width:58px;height:58px;flex:0 0 58px;border-radius:999px;display:grid;place-items:center;filter:drop-shadow(0 10px 18px rgba(0,0,0,.24))}
.tour-badge img{width:58px;height:58px;border-radius:999px;object-fit:cover;display:block}
.tour-badge span{position:absolute;right:-7px;bottom:-7px;min-width:30px;height:30px;border-radius:999px;background:var(--accent);color:white;display:grid;place-items:center;font-size:.82rem;font-weight:950;letter-spacing:-.04em;border:2px solid rgba(255,250,240,.98);box-shadow:0 8px 18px rgba(0,0,0,.22)}
@media (max-width:820px){.tour-info{grid-template-columns:1fr}.tour-info__item--number{min-height:92px}.tour-badge{width:52px;height:52px;flex-basis:52px}.tour-badge img{width:52px;height:52px}.tour-badge span{min-width:28px;height:28px;font-size:.78rem}}


/* v2.2.4: two-circle logo + track number badge, no duplicate text */
.tour-info{
  grid-template-columns:minmax(92px,.38fr) 1.35fr 1.35fr;
}
.tour-info__item--number{
  justify-content:center;
  padding:20px 18px;
}
.tour-info__item--number > div:not(.tour-badge){display:none!important}
.tour-badge{
  width:64px;
  height:64px;
  flex:0 0 64px;
}
.tour-badge img{
  width:64px;
  height:64px;
  border:3px solid rgba(255,250,240,.96);
}
.tour-badge span{
  right:-8px;
  bottom:-8px;
  min-width:32px;
  height:32px;
  font-size:.78rem;
  font-weight:950;
  background:var(--accent);
  color:var(--white);
  border:3px solid var(--paper);
}
@media (max-width:820px){
  .tour-info{grid-template-columns:1fr 1fr;}
  .tour-info__item--number{
    grid-column:1 / -1;
    justify-content:flex-end;
    min-height:auto;
    padding:18px 22px 0;
    background:rgba(255,250,240,.94);
    color:var(--ink);
  }
  .tour-badge{width:58px;height:58px;flex-basis:58px;}
  .tour-badge img{width:58px;height:58px;}
  .tour-badge span{min-width:30px;height:30px;font-size:.74rem;}
}
@media (max-width:560px){
  .tour-info{grid-template-columns:1fr;}
  .tour-info__item--number{justify-content:flex-start;padding:20px 22px 0;}
}

/* v2.2.5 zwischensprint: beschreibung + reduzierte icons */
.tour-description{
  align-items:flex-start;
  padding:32px clamp(22px,4vw,42px) 36px;
  border-top:1px solid rgba(19,37,28,.08);
}
.tour-description__text{
  max-width:820px;
}
.tour-description__text > p{
  margin:0;
  color:#3d493f;
  font-size:1.02rem;
  line-height:1.75;
}
.tour-details{
  margin-top:18px;
}
.tour-details summary{
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  color:var(--green);
  font-weight:900;
  border-bottom:2px solid var(--accent);
  list-style:none;
}
.tour-details summary::-webkit-details-marker{display:none}
.tour-details summary::after{
  content:'+';
  display:grid;
  place-items:center;
  width:22px;
  height:22px;
  border-radius:999px;
  background:rgba(19,37,28,.08);
  color:var(--green);
  font-weight:900;
  line-height:1;
}
.tour-details[open] summary::after{content:'−'}
.tour-details__content{
  margin-top:18px;
  color:#3d493f;
  line-height:1.75;
}
.tour-details__content p{
  margin:0 0 16px;
}
.tour-details__content p:last-child{margin-bottom:0}
.tour-info__icon{
  color:var(--green);
  width:30px;
  height:30px;
  display:inline-grid;
  place-items:center;
  flex:0 0 30px;
}
.tour-info__icon svg{
  width:30px;
  height:30px;
  display:block;
}
.signal-bars{
  display:inline-flex;
  align-items:flex-end;
  gap:4px;
  height:30px;
  color:var(--green);
}
.signal-bars__bar{
  display:block;
  width:5px;
  border-radius:999px;
  background:rgba(19,37,28,.18);
}
.signal-bars__bar:nth-child(1){height:9px}
.signal-bars__bar:nth-child(2){height:13px}
.signal-bars__bar:nth-child(3){height:17px}
.signal-bars__bar:nth-child(4){height:22px}
.signal-bars__bar:nth-child(5){height:27px}
.signal-bars__bar.is-active{background:var(--green)}
@media (max-width:820px){
  .tour-description{display:block;padding:28px 22px 32px}
  .tour-description__text > p{font-size:1rem}
  .tour-description .text-link{display:inline-flex;margin-top:20px}
}


/* v2.2.7: wassertemperatur + feinschliff icon-abstände */
.tour-info__item{
  gap:18px;
}
.tour-info__icon--signal{
  margin-right:2px;
}
.weather-dashboard__water{
  display:inline-flex;
  align-items:center;
  gap:9px;
  color:rgba(255,255,255,.84);
  font-weight:800;
  font-size:clamp(.95rem,1.8vw,1.12rem);
  line-height:1.2;
  margin-top:-6px;
}
.weather-dashboard__water[hidden]{display:none!important}

.weather-dashboard__water-spinner{
  width:18px;
  height:18px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.35);
  border-top-color:rgba(255,255,255,.92);
  display:inline-block;
  flex:0 0 18px;
  animation:waterSpin .8s linear infinite;
}
@keyframes waterSpin{to{transform:rotate(360deg)}}
.weather-dashboard__water-icon{
  width:23px;
  height:23px;
  display:inline-grid;
  place-items:center;
  color:rgba(255,255,255,.88);
  flex:0 0 23px;
}
.weather-dashboard__water-icon svg{
  width:23px;
  height:23px;
  display:block;
}
@media (max-width:820px){
  .weather-dashboard__water{margin-top:-2px}
  .tour-info__item{gap:18px}
}

/* v2.2.11: performance polish – skeleton loader, cache-friendly UX */
.sr-only{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  padding:0!important;
  margin:-1px!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
  white-space:nowrap!important;
  border:0!important;
}
.weather-dashboard__water{
  opacity:0;
  transform:translateY(4px);
  transition:opacity .28s ease, transform .28s ease;
}
.weather-dashboard__water.is-loaded,
.weather-dashboard__water.is-loading{
  opacity:1;
  transform:translateY(0);
}
.weather-dashboard__water-skeleton-icon,
.weather-dashboard__water-skeleton-text{
  display:inline-block;
  border-radius:999px;
  background:linear-gradient(90deg,rgba(255,255,255,.20),rgba(255,255,255,.38),rgba(255,255,255,.20));
  background-size:220% 100%;
  animation:waterSkeleton 1.15s ease-in-out infinite;
}
.weather-dashboard__water-skeleton-icon{
  width:23px;
  height:23px;
  flex:0 0 23px;
}
.weather-dashboard__water-skeleton-text{
  width:128px;
  height:1em;
}
@keyframes waterSkeleton{
  0%{background-position:120% 0}
  100%{background-position:-120% 0}
}
@media (prefers-reduced-motion:reduce){
  .weather-dashboard__water,
  .weather-dashboard__water-skeleton-icon,
  .weather-dashboard__water-skeleton-text{animation:none!important;transition:none!important}
}

/* v2.3.0: mehrere Touren – saubere Stapelung und robuste leere Komoot-Cards */
[data-tours-root]{
  display:grid;
  gap:clamp(34px,5vw,64px);
}
.tour-card{
  scroll-margin-top:96px;
}
.komoot-frame--empty{
  min-height:220px;
  display:grid;
  place-items:center;
  color:var(--muted);
  text-align:center;
}
.komoot-frame--empty code{
  color:var(--green);
  font-weight:800;
}
@media (max-width:820px){
  [data-tours-root]{gap:34px;}
  .tour-card{scroll-margin-top:78px;}
}


/* v2.3.6: Tour-Kategorie in der Card, vorbereitet für spätere Filter */
.tour-info{
  grid-template-columns:minmax(92px,.34fr) 1.18fr .92fr .92fr;
}
.tour-info__icon--category{
  color:var(--green);
}
@media (max-width:980px){
  .tour-info{
    grid-template-columns:minmax(92px,.42fr) 1fr 1fr;
  }
  .tour-info__item--number{
    grid-row:1 / span 2;
  }
}
@media (max-width:820px){
  .tour-info{
    grid-template-columns:1fr 1fr;
  }
  .tour-info__item--number{
    grid-column:1 / -1;
    grid-row:auto;
  }
}
@media (max-width:560px){
  .tour-info{
    grid-template-columns:1fr;
  }
}


/* v2.4.0: Tour Engine – dynamische Kategorie-Icons und ruhige Metadatenleiste */
.tour-info{
  grid-template-columns:minmax(92px,.34fr) minmax(220px,1.22fr) minmax(150px,.9fr) minmax(150px,.9fr);
}
.tour-info__item{
  gap:18px;
  align-items:center;
}
.tour-info__icon{
  width:26px;
  height:26px;
  flex:0 0 26px;
  color:var(--green);
  display:inline-grid;
  place-items:center;
}
.tour-info__icon svg{
  width:26px;
  height:26px;
  display:block;
}
.tour-info__icon--category svg,
.tour-info__icon--pin svg{
  stroke:currentColor;
}
.tour-info__icon--signal{
  width:34px;
  flex-basis:34px;
}
.signal-bars{
  width:34px;
}
.tour-info__item--number{
  justify-content:center;
}
.tour-info__item--number .tour-badge{
  margin-inline:auto;
}
@media (max-width:980px){
  .tour-info{grid-template-columns:minmax(92px,.38fr) 1fr 1fr;}
  .tour-info__item--number{grid-row:1 / span 2;}
}
@media (max-width:820px){
  .tour-info{grid-template-columns:1fr 1fr;}
  .tour-info__item--number{grid-column:1 / -1;grid-row:auto;justify-content:flex-end;}
}
@media (max-width:560px){
  .tour-info{grid-template-columns:1fr;}
  .tour-info__item{gap:16px;}
  .tour-info__item--number{justify-content:flex-start;}
}

/* Mobile-only Griffband-Optik für die oberste Tour-Card-Zeile mit Badge.
   Am Ende von assets/css/style.css einfügen. Desktop bleibt unverändert. */
@media (max-width: 820px) {
  .tour-info__item--number {
    position: relative;
    overflow: hidden;
    isolation: isolate;
    grid-column: 1 / -1;
    min-height: 124px;
    padding: 24px 22px;
    justify-content: center;
    align-items: center;
    background:
      radial-gradient(circle at 4px 4px, rgba(5, 12, 8, .60) 0 1.25px, transparent 1.45px) 0 0 / 16px 16px,
      radial-gradient(circle at 12px 12px, rgba(255, 255, 255, .18) 0 .85px, transparent 1.05px) 0 0 / 16px 16px,
      repeating-linear-gradient(104deg,
        rgba(255, 255, 255, .07) 0 26px,
        rgba(255, 255, 255, .18) 27px 29px,
        rgba(5, 12, 8, .22) 30px 32px,
        rgba(255, 255, 255, .04) 33px 58px),
      linear-gradient(180deg, #748362 0%, #556646 42%, #2e402d 100%);
    background-blend-mode: multiply, screen, overlay, normal;
    border-bottom: 1px solid rgba(19, 37, 28, .18);
  }

  .tour-info__item--number::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, .18), transparent 35%, rgba(0, 0, 0, .22)),
      radial-gradient(ellipse at 50% 0%, rgba(255, 255, 255, .25), transparent 55%);
    opacity: .85;
  }

  .tour-info__item--number::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background: repeating-linear-gradient(104deg,
      transparent 0 31px,
      rgba(0, 0, 0, .18) 32px,
      transparent 35px);
    opacity: .55;
  }

  .tour-info__item--number .tour-badge {
    position: relative;
    z-index: 1;
    margin-inline: auto;
    filter: drop-shadow(0 14px 22px rgba(5, 12, 8, .34));
  }
}

@media (max-width: 560px) {
  .tour-info__item--number {
    min-height: 116px;
    justify-content: center;
  }
}


/* v2.4.2: Griffband-Identität auch auf Desktop-Badge-Ecke
   Nur CSS, keine zusätzliche Bilddatei. Mobile-Patch bleibt erhalten. */
@media (min-width: 821px) {
  .tour-info__item--number {
    position: relative;
    overflow: hidden;
    isolation: isolate;
    background:
      radial-gradient(circle at 5px 5px, rgba(4, 10, 7, .58) 0 1.15px, transparent 1.35px) 0 0 / 17px 17px,
      radial-gradient(circle at 13px 13px, rgba(255, 255, 255, .16) 0 .75px, transparent .95px) 0 0 / 17px 17px,
      repeating-linear-gradient(104deg,
        rgba(255, 255, 255, .055) 0 24px,
        rgba(255, 255, 255, .16) 25px 27px,
        rgba(5, 12, 8, .24) 28px 31px,
        rgba(255, 255, 255, .035) 32px 56px),
      linear-gradient(145deg, #748362 0%, #556646 42%, #2e402d 100%);
    background-blend-mode: multiply, screen, overlay, normal;
  }

  .tour-info__item--number::before,
  .tour-info__item--number::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
  }

  .tour-info__item--number::before {
    background:
      linear-gradient(180deg, rgba(255, 255, 255, .18), transparent 35%, rgba(0, 0, 0, .24)),
      radial-gradient(ellipse at 42% 0%, rgba(255, 255, 255, .24), transparent 56%);
    opacity: .82;
  }

  .tour-info__item--number::after {
    background: repeating-linear-gradient(104deg,
      transparent 0 30px,
      rgba(0, 0, 0, .18) 31px,
      transparent 34px);
    opacity: .5;
  }

  .tour-info__item--number .tour-badge {
    position: relative;
    z-index: 1;
    filter: drop-shadow(0 14px 22px rgba(5, 12, 8, .35));
  }
}

/* v2.4.3: Rechtliches + Kontaktformular */
.legal-page {
  background: linear-gradient(180deg, #fffaf0 0%, #f3eadb 100%);
  min-height: 100vh;
}
.legal-hero {
  padding-top: 138px;
  padding-bottom: 36px;
}
.legal-hero h1 {
  font-size: clamp(2.35rem, 6vw, 5.4rem);
  color: var(--green);
  text-wrap: balance;
}
.legal-jumpnav {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 28px;
}
.legal-jumpnav a {
  border: 1px solid rgba(19, 37, 28, .14);
  border-radius: 999px;
  padding: 10px 16px;
  font-weight: 900;
  color: var(--green);
  background: rgba(255, 250, 240, .76);
}
.legal-jumpnav a:hover {
  background: var(--green);
  color: white;
}
.legal-content {
  padding-top: 20px;
}
.legal-card {
  scroll-margin-top: 96px;
  background: rgba(255, 250, 240, .9);
  border: 1px solid rgba(19, 37, 28, .08);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: clamp(26px, 5vw, 52px);
  margin-bottom: 28px;
}
.legal-card h2 {
  color: var(--green);
  font-size: clamp(1.85rem, 4vw, 3.2rem);
  margin-bottom: 24px;
}
.legal-card h3 {
  color: var(--green);
  margin: 32px 0 12px;
  font-size: 1.18rem;
}
.legal-card p {
  color: #3d493f;
  line-height: 1.75;
  margin: 0 0 16px;
}
.legal-date {
  color: var(--muted) !important;
  font-weight: 800;
  margin-top: 24px !important;
}
.contact-form {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}
.contact-form label {
  color: var(--green);
  font-weight: 900;
  font-size: .82rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.contact-form input,
.contact-form textarea {
  width: 100%;
  border: 1px solid rgba(19, 37, 28, .14);
  border-radius: 18px;
  background: white;
  color: var(--ink);
  font: inherit;
  padding: 14px 16px;
  outline: none;
}
.contact-form input:focus,
.contact-form textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(195, 123, 68, .14);
}
.contact-form textarea {
  resize: vertical;
}
.contact-form__row {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.button--solid {
  border: 0;
  background: var(--green);
  color: white;
  cursor: pointer;
  justify-self: start;
  margin-top: 8px;
}
.button--solid:hover {
  background: var(--accent);
  transform: translateY(-2px);
}
.form-success {
  display: none;
  border-radius: 18px;
  padding: 14px 16px;
  background: rgba(19, 37, 28, .08);
  font-weight: 850;
}
.form-success:target {
  display: block;
}
@media (max-width: 820px) {
  .legal-hero {
    padding-top: 112px;
  }
  .legal-card {
    scroll-margin-top: 78px;
  }
  .button--solid {
    width: 100%;
  }
}

/* v2.4.5: Kontaktformular Toast-Bestätigung */
.toast {
  position: fixed;
  left: 50%;
  bottom: 24px;
  z-index: 80;
  display: flex;
  align-items: center;
  gap: 10px;
  max-width: min(420px, calc(100vw - 32px));
  padding: 14px 18px;
  border-radius: 999px;
  background: var(--green);
  color: white;
  font-weight: 900;
  box-shadow: 0 18px 42px rgba(19, 37, 28, .24);
  transform: translate(-50%, 18px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s ease, transform .22s ease;
}
.toast.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}
.toast__icon {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  flex: 0 0 auto;
}
@media (prefers-reduced-motion: reduce) {
  .toast {
    transition: none !important;
  }
}


/* v2.4.6: GPX Download auf Tour-Cards */
.tour-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
  flex: 0 0 auto;
}
.tour-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(19, 37, 28, .12);
  font-weight: 900;
  text-transform: lowercase;
  white-space: nowrap;
  transition: background .18s ease, color .18s ease, border-color .18s ease, transform .18s ease;
}
.tour-action:hover {
  transform: translateY(-1px);
}
.tour-action--komoot {
  background: var(--green);
  border-color: var(--green);
  color: white;
}
.tour-action--komoot:hover {
  background: var(--accent);
  border-color: var(--accent);
}
.tour-action--gpx {
  background: rgba(255,255,255,.72);
  color: var(--green);
}
.tour-action--gpx:hover {
  background: var(--green);
  border-color: var(--green);
  color: white;
}
.tour-action__icon {
  width: 18px;
  height: 18px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
}
.tour-action__icon svg {
  width: 18px;
  height: 18px;
  display: block;
}
@media (max-width: 820px) {
  .tour-actions {
    justify-content: stretch;
  }
  .tour-action {
    width: 100%;
  }
}

/* v2.4.7: Mobile Polish – mehr Luft zwischen Beschreibung und Aktionen */
@media (max-width: 820px) {
  .tour-description {
    padding: 30px 22px 36px;
  }

  .tour-description__text {
    margin-bottom: 22px;
  }

  .tour-details {
    margin-top: 18px;
    margin-bottom: 22px;
  }

  .tour-details summary {
    line-height: 1.35;
  }

  .tour-actions {
    gap: 10px;
    margin-top: 0;
  }

  .tour-action {
    min-height: 46px;
    padding: 12px 18px;
  }
}

@media (max-width: 420px) {
  .tour-description {
    padding-inline: 20px;
  }

  .tour-action {
    min-height: 48px;
  }
}

/* v2.4.11: Semantischer Tourtitel – sichtbar auf Tablet/Mobile, optisch verborgen auf Desktop */
.tour-info__title {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: 0;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

@media (max-width: 980px) {
  .tour-info__title {
    position: static;
    width: auto;
    height: auto;
    overflow: visible;
    clip: auto;
    clip-path: none;
    white-space: normal;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
    background: rgba(255,250,240,.94);
    padding: 22px 24px;
    border-bottom: 1px solid rgba(19,37,28,.08);
    line-height: 1.18;
  }

  .tour-info__title-type {
    color: var(--accent);
  }

  .tour-info__title-name {
    font-size: clamp(1.22rem, 3.2vw, 1.55rem);
    font-weight: 850;
    letter-spacing: -0.035em;
  }
}

@media (max-width: 820px) {
  .tour-info__title {
    grid-column: 1 / -1;
    padding: 4px 22px 22px;
  }
}

@media (max-width: 560px) {
  .tour-info__title {
    padding: 2px 22px 22px;
  }
}


/* v2.4.12: Info-Boxen neu gruppiert + mehr Luft über mobilem Tourtitel */
.tour-info__item--stacked {
  display: grid;
  gap: 16px;
  align-content: center;
}

.tour-info__row {
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 0;
}

.tour-info__row strong {
  display: block;
}

.tour-info__icon--distance svg,
.tour-info__icon--elevation svg {
  stroke: currentColor;
}

@media (max-width: 980px) {
  .tour-info {
    grid-template-columns: minmax(92px, .38fr) 1fr 1fr;
  }

  .tour-info__item--number {
    grid-row: 1 / span 2;
  }
}

@media (max-width: 820px) {
  .tour-info {
    grid-template-columns: 1fr 1fr;
  }

  .tour-info__item--number {
    grid-column: 1 / -1;
    grid-row: auto;
  }

  .tour-info__title {
    grid-column: 1 / -1;
    padding: 18px 22px 24px;
  }

  .tour-info__item--stacked {
    gap: 18px;
  }
}

@media (max-width: 560px) {
  .tour-info {
    grid-template-columns: 1fr;
  }

  .tour-info__title {
    padding: 16px 22px 24px;
  }

  .tour-info__row {
    gap: 16px;
  }
}

/* v2.4.15: Einheitliche Icon-Spalte in gestapelten Tour-Info-Zeilen */
.tour-info__row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  column-gap: 16px;
  align-items: center;
}

.tour-info__row .tour-info__icon {
  width: 34px;
  min-width: 34px;
  height: 28px;
  flex-basis: 34px;
  display: inline-grid;
  place-items: center;
}

.tour-info__row .tour-info__icon svg,
.tour-info__row .signal-bars {
  max-width: 34px;
  max-height: 28px;
}

@media (max-width: 560px) {
  .tour-info__row {
    grid-template-columns: 34px minmax(0, 1fr);
    column-gap: 16px;
  }
}

/* v2.4.16: Desktop polish für Wetter-/Wasserbox */
@media (min-width:821px){
  .weather-dashboard{
    grid-template-columns:minmax(160px,.95fr) minmax(280px,1.25fr) minmax(300px,1fr);
    grid-template-areas:
      "weather-label weather-main weather-days"
      "weather-water weather-note weather-days";
    column-gap:clamp(28px,4vw,56px);
    row-gap:10px;
    align-items:center;
  }
  .weather-dashboard__label{
    grid-area:weather-label;
    align-self:end;
    margin:0;
  }
  .weather-dashboard__main{
    grid-area:weather-main;
    align-self:end;
    margin:0;
  }
  .weather-dashboard__water{
    grid-area:weather-water;
    align-self:start;
    justify-self:start;
    margin-top:0;
  }
  .weather-dashboard__advice{
    grid-area:weather-note;
    align-self:start;
    margin:0;
    max-width:36ch;
  }
  .weather-dashboard__days{
    grid-area:weather-days;
    justify-content:flex-end;
    align-content:center;
    align-self:center;
    margin:0;
  }
}

/* v2.4.17: Weather header vertical alignment polish on wider screens */
@media (min-width:821px){
  .weather-dashboard{
    grid-template-rows:auto auto;
    align-items:center;
  }

  .weather-dashboard__label{
    align-self:center;
    transform:translateY(-2px);
    line-height:1.15;
  }

  .weather-dashboard__main{
    align-self:center;
  }

  .weather-dashboard__water{
    align-self:start;
  }
}
