/* =========================================================
   Unser Eifel-Wochenende – Wald & Sternenhimmel
   Vanilla CSS · Tag- & Nacht-Modus · Animationen
   ========================================================= */

/* ---------- Theme-Variablen ---------- */
:root {
  --bg:        #f3eede;
  --bg-alt:    #e9efe1;
  --card:      #fffdf7;
  --card-2:    #f6f1e5;
  --text:      #253128;
  --text-soft: #55694f;
  --line:      #e0dccb;

  --forest-900:#0f2419;
  --forest-800:#173423;
  --forest-700:#22492f;
  --forest-500:#3a7d53;
  --moss:      #6fa06f;

  --wood:      #a56a41;
  --wood-dark: #6e4327;
  --wood-light:#cf9761;

  --sun:       #f6c445;
  --sun-soft:  #ffe28d;
  --star:      #ffe9a8;
  --accent:    #e07fa0;   /* Franzis pinke Herzbrille */
  --accent-2:  #6fb0b6;   /* Wasser / See */
  --smoke:     #cdd4cc;

  --shadow:    rgba(20,45,30,.14);
  --shadow-lg: rgba(20,45,30,.20);

  /* Karte */
  --map-far:   #b9d6b0;
  --map-near:  #8dbf8c;
  --map-hill1: #a7cc9c;
  --map-hill2: #7bb27e;
  --map-forest:#3f7a4e;
  --map-water: #7cc0d6;
  --map-water-edge:#4f9fbb;
  --map-route: #ffffff;

  --sky-1:     #dff0f4;
  --hero-shade:linear-gradient(180deg, rgba(15,36,25,.15) 0%, rgba(15,36,25,.05) 40%, rgba(15,36,25,.72) 100%);

  --header-bg: rgba(247,244,235,.82);
  --star-opacity: 0;
  --font-serif: "Iowan Old Style","Palatino Linotype",Palatino,Georgia,"Times New Roman",serif;
  --font-sans:  system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

:root[data-theme="night"] {
  --bg:        #0b1428;
  --bg-alt:    #0e1a31;
  --card:      #16223f;
  --card-2:    #1b2a4a;
  --text:      #ecf1ff;
  --text-soft: #a6b4d6;
  --line:      #2a3a5e;

  --forest-900:#060d18;
  --forest-800:#0a1526;
  --forest-700:#122544;
  --forest-500:#2e6a52;
  --moss:      #4d7a6b;

  --wood:      #8a5836;
  --wood-dark: #5a3721;
  --wood-light:#b07f4f;

  --smoke:     #40506e;

  --shadow:    rgba(0,0,0,.4);
  --shadow-lg: rgba(0,0,0,.55);

  --map-far:   #16305a;
  --map-near:  #0f2444;
  --map-hill1: #1c3a63;
  --map-hill2: #142c50;
  --map-forest:#1c4a3b;
  --map-water: #2f6c93;
  --map-water-edge:#4f9fbb;
  --map-route: #93a7d6;

  --hero-shade:linear-gradient(180deg, rgba(6,12,26,.35) 0%, rgba(6,12,26,.25) 35%, rgba(6,12,26,.85) 100%);
  --header-bg: rgba(11,20,40,.85);
  --star-opacity: 1;
}

/* ---------- Reset / Basis ---------- */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--text);
  background: var(--bg);
  line-height: 1.6;
  overflow-x: hidden;
  transition: background .6s ease, color .6s ease;
}
img { max-width: 100%; display: block; }
h1,h2,h3,h4 { font-family: var(--font-serif); line-height: 1.15; margin: 0 0 .5em; }
a { color: inherit; }
.wrap { max-width: 1080px; margin: 0 auto; padding: 0 clamp(18px, 5vw, 40px); }

/* ---------- Hintergrund-Ebenen ---------- */
.sky-layer {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  opacity: var(--star-opacity); transition: opacity .8s ease;
  background: radial-gradient(120% 90% at 70% -10%, rgba(40,60,110,.55), transparent 60%);
}
.stars { position: absolute; inset: 0; }
.stars i {
  position: absolute; width: 2px; height: 2px; border-radius: 50%;
  background: var(--star); box-shadow: 0 0 6px 1px rgba(255,233,168,.6);
  animation: twinkle 3s infinite ease-in-out;
}
@keyframes twinkle { 0%,100%{opacity:.25; transform:scale(.7);} 50%{opacity:1; transform:scale(1.1);} }
.shooting-star {
  position: absolute; top: 12%; left: -10%; width: 140px; height: 2px;
  background: linear-gradient(90deg, transparent, var(--star));
  border-radius: 2px; opacity: 0;
  animation: shoot 9s ease-in infinite; animation-delay: 3s;
}
@keyframes shoot {
  0% { transform: translate(0,0) rotate(18deg); opacity: 0; }
  6% { opacity: 1; }
  16%{ transform: translate(70vw, 30vh) rotate(18deg); opacity: 0; }
  100%{ opacity: 0; }
}

/* fallende Blätter */
.leaves { position: fixed; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.leaf {
  position: absolute; top: -6vh; font-size: 1.1rem; opacity: .0;
  animation: fall linear forwards;
}
@keyframes fall {
  0%   { transform: translateY(-8vh) translateX(0) rotate(0deg); opacity: 0; }
  10%  { opacity: .9; }
  100% { transform: translateY(112vh) translateX(var(--drift,40px)) rotate(540deg); opacity: 0; }
}

/* ---------- Topbar ---------- */
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: 14px;
  padding: 10px clamp(14px,4vw,26px);
  background: var(--header-bg); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  transition: background .6s ease, border-color .6s ease;
}
.brand { display: flex; align-items: center; gap: 8px; font-weight: 700; text-decoration: none; font-family: var(--font-serif); font-size: 1.05rem; white-space: nowrap; }
.brand-paw { font-size: 1.2rem; animation: wiggle 4s ease-in-out infinite; }
.brand-amp { color: var(--accent); }
@keyframes wiggle { 0%,92%,100%{transform:rotate(0);} 94%{transform:rotate(-18deg);} 96%{transform:rotate(14deg);} 98%{transform:rotate(-8deg);} }
.pillnav {
  display: flex; gap: 4px; margin-left: auto; overflow-x: auto; scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.pillnav::-webkit-scrollbar { display: none; }
.pillnav a {
  text-decoration: none; font-size: .86rem; font-weight: 600; color: var(--text-soft);
  padding: 6px 12px; border-radius: 999px; white-space: nowrap; transition: .2s;
}
.pillnav a:hover { background: var(--forest-500); color: #fff; }
.nav-toggle {
  display: none; width: 40px; height: 34px; flex-shrink: 0; border: 1px solid var(--line);
  border-radius: 10px; background: var(--card-2); color: var(--text); cursor: pointer;
  padding: 8px; margin-left: auto;
}
.nav-toggle span { display: block; height: 2px; background: currentColor; border-radius: 2px; transition: transform .25s ease, opacity .25s ease; }
.nav-toggle span + span { margin-top: 5px; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.mode-toggle {
  flex-shrink: 0; width: 44px; height: 30px; border: 1px solid var(--line);
  border-radius: 999px; background: var(--card-2); cursor: pointer; position: relative;
  padding: 0; overflow: hidden; transition: .3s;
}
.mode-toggle span { position: absolute; top: 50%; transform: translateY(-50%); transition: .35s ease; font-size: .8rem; }
.mode-icon-sun { left: 6px; opacity: 1; }
.mode-icon-moon { right: 6px; opacity: .35; }
:root[data-theme="night"] .mode-icon-sun { opacity: .35; }
:root[data-theme="night"] .mode-icon-moon { opacity: 1; }

/* ---------- HERO ---------- */
.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; overflow: hidden; z-index: 2; }
.hero-img, .hero-img img { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-img img { object-fit: cover; object-position: center 42%; animation: kenburns 26s ease-in-out infinite alternate; }
@keyframes kenburns { from { transform: scale(1.03) translate(0, 0); } to { transform: scale(1.13) translate(-1.5%, -1.5%); } }
.hero-shade { position: absolute; inset: 0; background: var(--hero-shade); }
.hero-vignette { position: absolute; inset: 0; pointer-events: none; background: radial-gradient(130% 105% at 50% 24%, transparent 42%, rgba(6,12,20,.5) 100%); }
.hero-sparkles { position: absolute; inset: 0; z-index: 2; pointer-events: none; overflow: hidden; }
.hero-sparkles span { position: absolute; opacity: 0; animation: heroSparkle 4.5s ease-in-out infinite; }
@keyframes heroSparkle { 0%, 100% { opacity: 0; transform: scale(.4) rotate(0deg); } 50% { opacity: .9; transform: scale(1) rotate(25deg); } }

/* Hero-Badge + Einblend-Choreografie */
.hero-badge { display: inline-flex; align-items: center; gap: 6px; font-size: .8rem; font-weight: 700; padding: 6px 14px; border-radius: 999px; background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.32); backdrop-filter: blur(6px); margin: 0 0 14px; box-shadow: 0 4px 16px rgba(0,0,0,.25); }
@media (prefers-reduced-motion: no-preference) {
  .hero-content > * { animation: heroRise .85s cubic-bezier(.2,.7,.2,1) both; }
  .hero-content > *:nth-child(1) { animation-delay: .12s; }
  .hero-content > *:nth-child(2) { animation-delay: .26s; }
  .hero-content > *:nth-child(3) { animation-delay: .40s; }
  .hero-content > *:nth-child(4) { animation-delay: .54s; }
  .hero-content > *:nth-child(5) { animation-delay: .70s; }
  .hero-content > *:nth-child(6) { animation-delay: .86s; }
}
@keyframes heroRise { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: none; } }
.hero-content { position: relative; z-index: 3; width: 100%; max-width: 1080px; margin: 0 auto; padding: 0 clamp(18px,5vw,40px) clamp(80px,12vh,120px); color: #fff; }
.hero-kicker { text-transform: uppercase; letter-spacing: .22em; font-size: .78rem; font-weight: 700; margin: 0 0 .4em; color: var(--sun-soft); background: linear-gradient(100deg, var(--sun-soft) 25%, #fff 45%, var(--sun-soft) 65%); background-size: 240% auto; -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; animation: shimmerText 5s linear infinite; }
@keyframes shimmerText { to { background-position: 240% center; } }
.hero-title { font-size: clamp(2.3rem, 7vw, 4.6rem); margin: 0; text-shadow: 0 3px 30px rgba(0,0,0,.4); }
.hero-names { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; font-size: clamp(1rem,2.6vw,1.4rem); font-weight: 600; margin: .5em 0 0; text-shadow: 0 2px 12px rgba(0,0,0,.5); }
.hero-names i { color: var(--accent); font-style: normal; }

/* Countdown */
.countdown { margin-top: clamp(20px, 4vh, 34px); }
.cd-label { font-weight: 700; font-size: 1.05rem; margin: 0 0 .6em; text-shadow: 0 2px 10px rgba(0,0,0,.5); }
.cd-clock { display: flex; gap: 10px; }
.cd-unit {
  background: rgba(255,255,255,.14); backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.25); border-radius: 14px;
  padding: 10px 6px; min-width: 62px; text-align: center;
}
.cd-num { display: block; font-family: var(--font-serif); font-size: clamp(1.5rem,4vw,2.1rem); font-weight: 700; line-height: 1; font-variant-numeric: tabular-nums; }
.cd-num.pop { animation: pop .4s ease; }
@keyframes pop { 0%{transform:scale(1);} 40%{transform:scale(1.28); color:var(--sun-soft);} 100%{transform:scale(1);} }
.cd-cap { display: block; font-size: .68rem; text-transform: uppercase; letter-spacing: .12em; opacity: .85; margin-top: 4px; }
.cd-progress { max-width: 460px; }
.cd-bar { height: 12px; border-radius: 999px; background: rgba(255,255,255,.22); overflow: hidden; border: 1px solid rgba(255,255,255,.3); }
.cd-bar span { display: block; height: 100%; width: 0; border-radius: 999px; background: linear-gradient(90deg, var(--sun), var(--accent)); transition: width 1s ease; }
.cd-daytext { font-weight: 700; margin: .7em 0 0; font-size: 1.05rem; }

.scroll-hint {
  display: inline-flex; align-items: center; gap: 8px; margin-top: clamp(22px,4vh,34px);
  color: #fff; text-decoration: none; font-weight: 600; font-size: .9rem;
  padding: 8px 16px; border: 1px solid rgba(255,255,255,.4); border-radius: 999px;
  background: rgba(255,255,255,.1); transition: .25s;
}
.scroll-hint:hover { background: rgba(255,255,255,.22); }
.scroll-hint svg { animation: bob 1.8s ease-in-out infinite; }
@keyframes bob { 0%,100%{transform:translateY(0);} 50%{transform:translateY(5px);} }
.hero-trees { position: absolute; bottom: -1px; left: 0; width: 100%; z-index: 3; line-height: 0; }

/* ---------- Sections ---------- */
.section { position: relative; z-index: 2; padding: clamp(56px,9vh,96px) 0; background: var(--bg); transition: background .6s ease; }
.section-alt { background: var(--bg-alt); }
.eyebrow { text-transform: uppercase; letter-spacing: .18em; font-size: .78rem; font-weight: 700; color: var(--forest-500); margin: 0 0 .5em; }
:root[data-theme="night"] .eyebrow { color: var(--moss); }
.section h2 { font-size: clamp(1.8rem, 4.5vw, 2.8rem); margin-bottom: .5em; }
.section-intro { max-width: 620px; color: var(--text-soft); font-size: 1.05rem; margin: 0 0 2em; }
.lead { font-size: 1.12rem; }

/* ---------- Buttons ---------- */
.btn { display: inline-flex; align-items: center; gap: 8px; text-decoration: none; font-weight: 700; font-size: .92rem; padding: 11px 20px; border-radius: 999px; border: none; cursor: pointer; transition: transform .18s ease, box-shadow .18s ease, background .25s; }
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: var(--forest-500); color: #fff; box-shadow: 0 6px 18px var(--shadow); }
.btn-primary:hover { background: var(--forest-700); box-shadow: 0 10px 24px var(--shadow-lg); }
.btn-ghost { background: var(--card); color: var(--text); border: 1.5px solid var(--line); }
.btn-ghost:hover { border-color: var(--forest-500); color: var(--forest-500); }
.btn-sm { padding: 8px 14px; font-size: .84rem; }
.btn-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 1.4em; }

/* ---------- Blockhaus ---------- */
.cabin-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px,4vw,48px); align-items: center; }
.cabin-art { background: var(--card); border-radius: 22px; padding: 18px; box-shadow: 0 12px 30px var(--shadow); border: 1px solid var(--line); }
.cabin-art .moon-cut { fill: var(--card); }
.cabin-stars circle { fill: var(--star); animation: twinkle 3.5s infinite ease-in-out; }
.cabin-window { animation: glow 4s ease-in-out infinite; transform-origin: center; }
@keyframes glow { 0%,100%{opacity:.85;} 50%{opacity:1; filter:drop-shadow(0 0 6px var(--sun));} }
.smoke-1 { stroke-dasharray: 60; animation: rise 4s linear infinite; opacity: .7; }
@keyframes rise { 0%{opacity:0; transform:translateY(6px);} 30%{opacity:.7;} 100%{opacity:0; transform:translateY(-14px);} }
.info-list { list-style: none; padding: 0; margin: 1.2em 0 0; display: grid; gap: 14px; }
.info-list li { display: flex; gap: 12px; align-items: flex-start; }
.info-list .ico { font-size: 1.3rem; flex-shrink: 0; margin-top: 2px; }

/* ---------- Wetter ---------- */
.weather-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.wcard { background: var(--card); border: 1px solid var(--line); border-radius: 20px; padding: 20px 14px; text-align: center; box-shadow: 0 8px 22px var(--shadow); transition: transform .2s; position: relative; overflow: hidden; }
.wcard:hover { transform: translateY(-4px); }
.wcard.is-today { border-color: var(--sun); box-shadow: 0 0 0 3px var(--sun-soft), 0 10px 26px var(--shadow-lg); }
.wcard.is-today::after { content: "Heute"; position: absolute; top: 10px; right: -30px; background: var(--sun); color: #4a3607; font-size: .66rem; font-weight: 800; padding: 3px 34px; transform: rotate(38deg); letter-spacing: .08em; }
.wday { font-weight: 700; font-family: var(--font-serif); font-size: 1.1rem; margin: 0 0 10px; }
.wday span { display: block; font-family: var(--font-sans); font-size: .72rem; font-weight: 600; color: var(--text-soft); text-transform: uppercase; letter-spacing: .08em; }
.wicon { width: 76px; height: 76px; margin: 4px auto 10px; }
.wtemp { font-family: var(--font-serif); font-size: 2rem; font-weight: 700; margin: 0; }
.wnight { font-size: .82rem; color: var(--text-soft); margin: 2px 0 6px; }
.wdesc { font-size: .88rem; font-weight: 600; color: var(--forest-500); margin: 0; }
:root[data-theme="night"] .wdesc { color: var(--moss); }
/* Wetter-Icon-Animationen */
.wi-sun-core { transform-origin: center; animation: sunpulse 4s ease-in-out infinite; }
.wi-rays { transform-origin: center; animation: spin 22s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes sunpulse { 0%,100%{transform:scale(1);} 50%{transform:scale(1.06);} }
.wi-cloud { animation: drift 5s ease-in-out infinite; }
@keyframes drift { 0%,100%{transform:translateX(0);} 50%{transform:translateX(5px);} }
.wi-rain line { animation: raindrop 1.1s linear infinite; }
.wi-rain line:nth-child(2) { animation-delay: .35s; }
.wi-rain line:nth-child(3) { animation-delay: .7s; }
@keyframes raindrop { 0%{opacity:0; transform:translateY(-4px);} 40%{opacity:1;} 100%{opacity:0; transform:translateY(6px);} }
.wx-note { text-align: center; font-size: .84rem; font-weight: 600; color: var(--text-soft); margin: 1.6em 0 0; }

/* ---------- Timeline ---------- */
.timeline { display: grid; gap: 16px; position: relative; }
.tl-day { background: var(--card); border: 1px solid var(--line); border-radius: 20px; box-shadow: 0 8px 22px var(--shadow); overflow: hidden; transition: box-shadow .3s, border-color .3s; }
.tl-day.is-today { border-color: var(--forest-500); box-shadow: 0 0 0 2px var(--forest-500), 0 12px 30px var(--shadow-lg); }
.tl-head { width: 100%; display: flex; align-items: center; gap: 16px; padding: 18px 20px; background: none; border: none; cursor: pointer; text-align: left; font: inherit; color: inherit; }
.tl-dot { font-size: 1.5rem; width: 48px; height: 48px; flex-shrink: 0; display: grid; place-items: center; background: var(--card-2); border-radius: 50%; border: 1px solid var(--line); }
.tl-day.is-today .tl-dot { background: var(--forest-500); }
.tl-headline { flex: 1; }
.tl-date { display: block; font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--forest-500); }
:root[data-theme="night"] .tl-date { color: var(--moss); }
.tl-day.is-today .tl-date::after { content: " · heute"; color: var(--accent); }
.tl-title { display: block; font-family: var(--font-serif); font-size: 1.2rem; font-weight: 700; }
.tl-chevron { font-size: 1.4rem; color: var(--text-soft); transition: transform .3s ease; }
.tl-head[aria-expanded="true"] .tl-chevron { transform: rotate(180deg); }
.tl-body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .4s ease; }
.tl-body-inner { overflow: hidden; }
.tl-head[aria-expanded="true"] + .tl-body { grid-template-rows: 1fr; }
.stop { padding: 0 20px 20px 84px; }
.stop:first-child { padding-top: 4px; }
.stop h4 { font-size: 1.05rem; margin: 0 0 .3em; }
.stop p { margin: 0 0 .6em; color: var(--text-soft); }
.tl-tip { background: var(--card-2); border-left: 3px solid var(--accent); padding: 8px 12px; border-radius: 8px; font-size: .9rem; }
.badges { display: flex; flex-wrap: wrap; gap: 8px; margin: .4em 0; }
.badge { font-size: .76rem; font-weight: 700; padding: 4px 11px; border-radius: 999px; background: var(--card-2); border: 1px solid var(--line); color: var(--text-soft); }
.badge-dog { background: #eaf5e8; color: #2f6a3a; border-color: #cfe6cb; }
.badge-star { background: #fff2cf; color: #8a6a10; border-color: #f4e2a8; }
:root[data-theme="night"] .badge-dog { background: #16321f; color: #8fd39a; border-color: #285138; }
:root[data-theme="night"] .badge-star { background: #322a12; color: #f2d98a; border-color: #514627; }
.link-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: .75em; }
.maplink { display: inline-flex; align-items: center; gap: 5px; font-size: .84rem; font-weight: 700; color: var(--forest-500); text-decoration: none; border: 1px solid var(--line); background: var(--card); border-radius: 999px; padding: 6px 11px; transition: transform .18s ease, border-color .18s ease, background .18s ease; }
.maplink:hover { transform: translateY(-1px); border-color: var(--forest-500); background: var(--card-2); }
.maplink-info { color: #6f5572; }
:root[data-theme="night"] .maplink { color: var(--moss); }
:root[data-theme="night"] .maplink-info { color: #d7b8df; }

/* ---------- Karte ---------- */
.map-shell { position: relative; background: var(--card); border: 1px solid var(--line); border-radius: 24px; padding: 12px; box-shadow: 0 12px 34px var(--shadow); overflow: hidden; }
.map-svg { width: 100%; height: auto; display: block; border-radius: 16px; }
.map-route { animation: dash 40s linear infinite; }
@keyframes dash { to { stroke-dashoffset: -400; } }
.pin { cursor: pointer; }
.pin-body { fill: var(--accent); stroke: #fff; stroke-width: 2; filter: drop-shadow(0 3px 4px rgba(0,0,0,.3)); transform-origin: center bottom; animation: pinbob 3s ease-in-out infinite; }
.pin:nth-child(2n) .pin-body { animation-delay: .6s; }
.pin:nth-child(3n) .pin-body { animation-delay: 1.1s; }
.pin-home .pin-body { fill: var(--forest-500); }
.pin:hover .pin-body, .pin.active .pin-body { fill: var(--sun); transform: scale(1.15); }
@keyframes pinbob { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-4px);} }
.pin-emoji { font-size: 15px; text-anchor: middle; dominant-baseline: middle; pointer-events: none; }
.pin-pulse { fill: var(--forest-500); opacity: .35; transform-origin: center; animation: pulse 2.4s ease-out infinite; }
@keyframes pulse { 0%{transform:scale(.5); opacity:.5;} 100%{transform:scale(1.6); opacity:0;} }
.map-info { position: absolute; left: 16px; bottom: 16px; right: 16px; max-width: 340px; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 16px 18px; box-shadow: 0 12px 30px var(--shadow-lg); animation: infopop .3s ease; }
@keyframes infopop { from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:translateY(0);} }
.map-info h4 { margin: 0 0 .3em; font-size: 1.1rem; }
.map-info p { margin: 0 0 .9em; color: var(--text-soft); font-size: .92rem; }
.map-info-close { position: absolute; top: 8px; right: 10px; background: none; border: none; font-size: 1.4rem; cursor: pointer; color: var(--text-soft); line-height: 1; }
.map-info-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.map-legend { text-align: center; color: var(--text-soft); font-size: .86rem; margin-top: 1.2em; }

/* ---------- Marla ---------- */
.marla-grid { display: grid; grid-template-columns: 320px 1fr; gap: clamp(24px,4vw,44px); align-items: start; }
.marla-card { background: var(--card); border: 1px solid var(--line); border-radius: 24px; padding: 26px; text-align: center; box-shadow: 0 12px 30px var(--shadow); }
.marla-face { width: 190px; height: 190px; margin: 0 auto 10px; background: radial-gradient(circle at 50% 40%, var(--card-2), var(--card)); border-radius: 50%; display: grid; place-items: center; box-shadow: inset 0 0 0 6px var(--bg-alt); }
.marla-tail { transform-origin: 150px 150px; animation: wag .5s ease-in-out infinite alternate; }
@keyframes wag { from{transform:rotate(-14deg);} to{transform:rotate(14deg);} }
.marla-tongue { transform-origin: 100px 140px; animation: pant 1.4s ease-in-out infinite; }
@keyframes pant { 0%,100%{transform:scaleY(1);} 50%{transform:scaleY(1.35);} }
.marla-card h3 { font-size: 1.6rem; margin: .2em 0 0; }
.marla-sub { color: var(--text-soft); font-weight: 600; margin: .2em 0 1em; }
.marla-stats { list-style: none; display: flex; justify-content: center; gap: 8px; padding: 0; margin: 0; }
.marla-stats li { flex: 1; background: var(--card-2); border-radius: 14px; padding: 12px 6px; }
.marla-stats strong { display: block; font-family: var(--font-serif); font-size: 1.5rem; color: var(--forest-500); }
:root[data-theme="night"] .marla-stats strong { color: var(--moss); }
.marla-stats span { font-size: .68rem; color: var(--text-soft); text-transform: uppercase; letter-spacing: .05em; }
.marla-tips { background: var(--card); border: 1px solid var(--line); border-radius: 24px; padding: clamp(22px,3vw,32px); box-shadow: 0 12px 30px var(--shadow); }
.marla-tips h3 { font-size: 1.4rem; }
.tip-list { list-style: none; padding: 0; margin: 1em 0 1.5em; display: grid; gap: 12px; }
.tip-list li { display: flex; gap: 12px; align-items: flex-start; }
.tip-list span { font-size: 1.25rem; flex-shrink: 0; }
.tip-list strong { color: var(--text); }

/* ---------- Weitere Ausflugsziele ---------- */
.idea-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 18px; align-items: stretch; }
.idea-card { background: var(--card); border: 1px solid var(--line); border-radius: 20px; padding: 22px 24px; box-shadow: 0 8px 22px var(--shadow); transition: transform .2s, box-shadow .2s; display: flex; flex-direction: column; }
.idea-card:hover { transform: translateY(-4px); box-shadow: 0 14px 30px var(--shadow-lg); }
.idea-emoji { font-size: 2rem; display: block; }
.idea-card h3 { font-size: 1.18rem; margin: .35em 0 .25em; }
.idea-card p { color: var(--text-soft); font-size: .93rem; margin: 0 0 .8em; }
.idea-card .link-row { margin-top: auto; padding-top: .4em; }

/* ---------- Kochen: Rezept + Ofen-Timer ---------- */
.cook-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 4vw, 40px); align-items: stretch; }
.recipe-card, .timer-card { background: var(--card); border: 1px solid var(--line); border-radius: 22px; padding: 26px 28px; box-shadow: 0 10px 26px var(--shadow); }
.recipe-emoji { font-size: 2.4rem; display: block; }
.recipe-card h3, .timer-card h3 { font-size: 1.3rem; margin: .3em 0 .7em; }
.recipe-steps { list-style: none; padding: 0; margin: 0; counter-reset: step; display: grid; gap: 13px; }
.recipe-steps li { position: relative; padding-left: 40px; color: var(--text-soft); }
.recipe-steps li::before { counter-increment: step; content: counter(step); position: absolute; left: 0; top: -2px; width: 27px; height: 27px; background: var(--forest-500); color: #fff; border-radius: 50%; display: grid; place-items: center; font-weight: 800; font-size: .85rem; font-family: var(--font-sans); }
.recipe-steps strong { color: var(--text); }

.timer-card { text-align: center; }
.timer-presets { display: flex; gap: 8px; justify-content: center; margin-bottom: 18px; }
.timer-presets button { border: 1.5px solid var(--line); background: var(--card-2); color: var(--text); font-weight: 700; font-size: .85rem; padding: 7px 15px; border-radius: 999px; cursor: pointer; transition: .2s; font-family: inherit; }
.timer-presets button.active, .timer-presets button:hover { background: var(--forest-500); color: #fff; border-color: var(--forest-500); }
.timer-ring-wrap { position: relative; width: 200px; height: 200px; margin: 0 auto 18px; }
.timer-ring { width: 100%; height: 100%; transform: rotate(-90deg); }
.timer-ring .ring-bg { fill: none; stroke: var(--card-2); stroke-width: 9; }
.timer-ring .ring-fg { fill: none; stroke: url(#ringGrad); stroke-width: 9; stroke-linecap: round; transition: stroke-dashoffset .3s linear; }
.timer-center { position: absolute; inset: 0; display: grid; place-content: center; gap: 2px; }
.timer-emoji { font-size: 2rem; }
.timer-time { font-family: var(--font-serif); font-size: 2rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.timer-controls { display: flex; gap: 10px; justify-content: center; }
.timer-done { margin: 15px 0 0; font-weight: 800; color: var(--forest-500); font-size: 1.05rem; }
:root[data-theme="night"] .timer-done { color: var(--moss); }
.timer-card.done .timer-ring-wrap { animation: wobble .6s ease; }
.timer-card.done .timer-emoji { animation: pop .5s ease; }
@keyframes wobble { 0%,100% { transform: rotate(0); } 25% { transform: rotate(-5deg); } 75% { transform: rotate(5deg); } }

/* ---------- Footer ---------- */
.footer { position: relative; z-index: 2; background: var(--forest-900); color: #eaf3ec; text-align: center; padding: clamp(46px,7vh,72px) 20px; }
.paw-trail-foot { font-size: 1.2rem; letter-spacing: .3em; opacity: .5; margin-bottom: 1em; }
.footer-heart { font-family: var(--font-serif); font-size: 1.5rem; margin: 0 0 .3em; }
.footer-heart strong { color: var(--accent); }
.footer-sub { color: #b8ccbd; max-width: 480px; margin: 0 auto 1.4em; font-size: .95rem; }

/* ---------- Galerie (Polaroid-Wand) ---------- */
.gallery { display: flex; flex-wrap: wrap; gap: 30px 24px; justify-content: center; padding-top: 10px; }
.photo { position: relative; background: #fffdf9; padding: 12px 12px 0; border-radius: 5px; box-shadow: 0 12px 28px var(--shadow); transition: transform .3s ease, box-shadow .3s ease; will-change: transform; }
.photo .pin-tack { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); font-size: 1.2rem; filter: drop-shadow(0 2px 2px rgba(0,0,0,.3)); }
.photo .frame { width: 232px; height: 200px; border-radius: 3px; overflow: hidden; background: var(--card-2); }
.photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.photo figcaption { font-family: var(--font-serif); font-style: italic; text-align: center; padding: 12px 6px 15px; color: #3d3a33; font-size: 1.02rem; }
.photo.clickable { cursor: zoom-in; }
.photo:hover { transform: rotate(0deg) translateY(-7px) scale(1.03) !important; box-shadow: 0 20px 44px var(--shadow-lg); z-index: 2; }
.photo.placeholder .frame { display: grid; place-content: center; justify-items: center; border: 2px dashed var(--line); background: repeating-linear-gradient(45deg, var(--card-2), var(--card-2) 10px, var(--card) 10px, var(--card) 20px); }
.photo.placeholder .ph-icon { font-size: 2.6rem; opacity: .55; }
.photo.placeholder .ph-text { font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; color: var(--text-soft); margin-top: 8px; font-weight: 700; }

/* ---------- Lightbox ---------- */
.lightbox { position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 24px; background: rgba(8,14,26,.88); backdrop-filter: blur(5px); animation: infopop .25s ease; }
.lightbox[hidden] { display: none; }
.lightbox figure { margin: 0; max-width: min(920px, 92vw); }
.lightbox img { width: 100%; max-height: 78vh; object-fit: contain; border-radius: 10px; box-shadow: 0 24px 70px rgba(0,0,0,.6); background: #fff; }
.lightbox figcaption { color: #fff; text-align: center; font-family: var(--font-serif); font-style: italic; margin-top: 16px; font-size: 1.15rem; }
.lb-close { position: absolute; top: 18px; right: 22px; width: 46px; height: 46px; border: none; border-radius: 50%; background: rgba(255,255,255,.16); color: #fff; font-size: 1.7rem; line-height: 1; cursor: pointer; transition: background .2s; }
.lb-close:hover { background: rgba(255,255,255,.3); }

/* ---------- Sterne-gucken-Uhr ---------- */
.starclock { display: grid; grid-template-columns: 260px 1fr; margin-top: clamp(24px, 4vw, 40px); border: 1px solid var(--line); border-radius: 22px; overflow: hidden; box-shadow: 0 10px 26px var(--shadow); background: var(--card); }
.sky { position: relative; min-height: 190px; overflow: hidden; transition: background 1.2s ease; background: linear-gradient(#8ec0e6, #d3ebf5); }
.sky.gold { background: linear-gradient(#f6b25f, #ffd9a0 70%, #ffe9c2); }
.sky.dusk { background: linear-gradient(#38406f, #b57e9c); }
.sky.night { background: linear-gradient(#0a1230, #223a63); }
.sky-sun { position: absolute; left: 50%; top: 18%; transform: translateX(-50%); font-size: 2.1rem; transition: top 1.2s ease; }
.sky-stars { position: absolute; inset: 0; opacity: 0; transition: opacity 1.2s ease; }
.sky.night .sky-stars, .sky.dusk .sky-stars { opacity: 1; }
.sky-stars i { position: absolute; width: 2px; height: 2px; background: #fff; border-radius: 50%; box-shadow: 0 0 5px 1px rgba(255,255,255,.7); animation: twinkle 3s infinite ease-in-out; }
.starclock-info { padding: 22px 26px; }
.starclock-info h3 { font-size: 1.3rem; margin: 0 0 .2em; }
.sc-phase { font-weight: 800; color: var(--forest-500); margin: 0 0 1em; }
:root[data-theme="night"] .sc-phase { color: var(--moss); }
.sc-times { list-style: none; padding: 0; margin: 0 0 1em; display: grid; gap: 9px; }
.sc-times li { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; border-bottom: 1px dashed var(--line); padding-bottom: 7px; color: var(--text-soft); font-size: .95rem; }
.sc-times strong { font-family: var(--font-serif); font-size: 1.25rem; color: var(--text); }
.sc-tip { font-size: .88rem; color: var(--text-soft); margin: 0; }

/* ---------- Wunschliste ---------- */
.wish-progress { display: flex; align-items: center; flex-wrap: wrap; gap: 14px; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 14px 18px; box-shadow: 0 6px 18px var(--shadow); margin-bottom: 1.6em; }
.wish-bar { flex: 1; min-width: 160px; height: 14px; background: var(--card-2); border-radius: 999px; overflow: hidden; }
.wish-bar span { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--accent), var(--sun)); border-radius: 999px; transition: width .5s ease; }
.wish-count { font-weight: 700; margin: 0; white-space: nowrap; }
.wish-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 4px 24px; }
.wish-list label { display: flex; align-items: center; gap: 12px; padding: 10px; border-radius: 12px; cursor: pointer; transition: background .18s; user-select: none; }
.wish-list label:hover { background: var(--card-2); }
.wish-list input { appearance: none; -webkit-appearance: none; width: 24px; height: 24px; flex-shrink: 0; border: 2px solid var(--accent); border-radius: 50%; cursor: pointer; position: relative; transition: .2s; }
.wish-list input:checked { background: var(--accent); border-color: var(--accent); }
.wish-list input:checked::after { content: "✓"; position: absolute; inset: 0; color: #fff; font-weight: 900; font-size: .8rem; display: grid; place-items: center; animation: pop .3s ease; }
.wish-list input:checked + span { opacity: .55; text-decoration: line-through; }
.wish-list span { font-size: .98rem; transition: .2s; }
.confetti { position: fixed; top: -24px; z-index: 120; pointer-events: none; will-change: transform; animation: conffall linear forwards; }
@keyframes conffall { 0% { transform: translateY(-24px) rotate(0); opacity: 1; } 100% { transform: translateY(104vh) rotate(680deg); opacity: .85; } }

/* ---------- Urlaubs-Tagebuch ---------- */
.diary-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.diary-card { background: var(--card); border: 1px solid var(--line); border-radius: 20px; padding: 20px 22px; box-shadow: 0 8px 22px var(--shadow); }
.diary-card.is-today { border-color: var(--forest-500); box-shadow: 0 0 0 2px var(--forest-500), 0 10px 26px var(--shadow-lg); }
.diary-card h3 { font-size: 1.15rem; margin: 0 0 .55em; }
.diary-card h3 span { font-family: var(--font-sans); font-weight: 600; font-size: .78rem; color: var(--text-soft); text-transform: uppercase; letter-spacing: .06em; margin-left: 6px; }
.diary-card.is-today h3::after { content: " · heute"; color: var(--accent); font-family: var(--font-sans); font-size: .8rem; }
.diary-card textarea { width: 100%; min-height: 96px; resize: vertical; border: 1.5px solid var(--line); border-radius: 12px; padding: 12px 14px; font: inherit; font-size: .95rem; background: var(--bg); color: var(--text); transition: border-color .2s; }
.diary-card textarea:focus { outline: none; border-color: var(--forest-500); }
.diary-saved { font-size: .78rem; font-weight: 700; color: var(--forest-500); margin: .5em 0 0; opacity: 0; transition: opacity .3s; }
:root[data-theme="night"] .diary-saved { color: var(--moss); }
.diary-saved.show { opacity: 1; }

/* ---------- Gut zu wissen ---------- */
.info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 18px; }
.infobox { background: var(--card); border: 1px solid var(--line); border-radius: 20px; padding: 22px 24px; box-shadow: 0 8px 22px var(--shadow); }
.ib-ico { font-size: 2rem; display: block; margin-bottom: 6px; }
.infobox h3 { font-size: 1.12rem; margin: 0 0 .3em; }
.infobox p { color: var(--text-soft); font-size: .92rem; margin: 0 0 1em; }
.ib-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.ib-emergency { border-color: #e7c9c9; }
:root[data-theme="night"] .ib-emergency { border-color: #5a2e2e; }
#copyAddr.copied { background: var(--forest-500); color: #fff; border-color: var(--forest-500); }

/* ---------- Entfernungs-Chip ---------- */
.dist { display: inline-flex; align-items: center; gap: 5px; font-size: .76rem; font-weight: 700; color: #7a5230; background: #f4e7d7; border: 1px solid #e7d4bf; border-radius: 999px; padding: 4px 11px; white-space: nowrap; }
:root[data-theme="night"] .dist { color: #e6b98a; background: #33251580; border-color: #4f3d22; }
.map-info-dist { margin: -.4em 0 .9em !important; font-size: .82rem; font-weight: 700; color: #7a5230; }
:root[data-theme="night"] .map-info-dist { color: #e6b98a; }

/* ---------- Wander- & Spazierwege ---------- */
.trail-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 18px; align-items: stretch; }
.trail-card { background: var(--card); border: 1px solid var(--line); border-radius: 20px; padding: 22px 24px; box-shadow: 0 8px 22px var(--shadow); transition: transform .2s, box-shadow .2s; display: flex; flex-direction: column; }
.trail-card:hover { transform: translateY(-4px); box-shadow: 0 14px 30px var(--shadow-lg); }
.trail-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .4em; }
.trail-emoji { font-size: 1.9rem; }
.trail-level { font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; padding: 4px 10px; border-radius: 999px; }
.level-easy { background: #eaf5e8; color: #2f6a3a; }
.level-mid { background: #fdf0d6; color: #8a6410; }
.level-hard { background: #fbe2df; color: #a23b34; }
:root[data-theme="night"] .level-easy { background: #16321f; color: #8fd39a; }
:root[data-theme="night"] .level-mid { background: #322a12; color: #f2d98a; }
:root[data-theme="night"] .level-hard { background: #3a1f1d; color: #f0a59c; }
.trail-card h3 { font-size: 1.16rem; margin: 0 0 .25em; }
.trail-card p { color: var(--text-soft); font-size: .93rem; margin: 0 0 .7em; }
.trail-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; font-size: .82rem; font-weight: 700; color: var(--text); }
.trail-card .link-row { margin-top: auto; padding-top: .4em; }

/* ---------- Reveal-Animation ---------- */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
  .cabin-grid, .marla-grid, .cook-grid, .starclock, .diary-grid { grid-template-columns: 1fr; }
  .weather-grid { grid-template-columns: repeat(2, 1fr); }
  .wish-list { grid-template-columns: 1fr; }
  .marla-card { max-width: 340px; margin: 0 auto; }
  .topbar { position: sticky; flex-wrap: wrap; }
  .nav-toggle { display: block; }
  .pillnav {
    display: none; order: 4; width: 100%; margin: 4px 0 0; padding: 8px;
    background: var(--card); border: 1px solid var(--line); border-radius: 14px;
    box-shadow: 0 12px 28px var(--shadow); overflow: visible; scrollbar-width: auto;
  }
  .pillnav.is-open { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px; }
  .pillnav a { text-align: center; background: var(--card-2); padding: 9px 10px; }
}
@media (max-width: 640px) {
  /* Hero als Foto-Banner + gemütliches Panel (ganze Gruppe sichtbar) */
  .hero { min-height: auto; display: block; overflow: visible; background: linear-gradient(180deg, var(--forest-700), var(--forest-900)); }
  .hero-img, .hero-img img { position: relative; inset: auto; width: 100%; height: auto; }
  .hero-img img { aspect-ratio: 4 / 3; object-fit: cover; object-position: center 40%; animation: none; }
  .hero-shade, .hero-vignette, .hero-sparkles, .hero-trees { display: none; }
  .hero-content { position: relative; z-index: 3; padding: 24px 20px 44px; }
}
@media (max-width: 460px) {
  .weather-grid { grid-template-columns: 1fr 1fr; }
  .cd-unit { min-width: 0; flex: 1; padding: 8px 2px; }
  .cd-clock { gap: 6px; }
  .stop { padding-left: 20px; }
}

/* ---------- Reduced Motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; }
  .leaves, .shooting-star { display: none; }
}
