: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}
}
