/* ================================================================
   campingplatz.camp · Premium Outdoor Design System
   © SEO NW · Alexander Müller
   ================================================================ */

/* ---------- 0. Local Fonts ----------
   Variable Fonts: Fraunces (Display) + Inter Tight (Body)
   Falls statt Variable nur statische Files vorliegen, einfach
   pro Strichstärke ein @font-face mit passendem `font-weight`.
   ------------------------------------------------------------- */
@font-face{
  font-family:'Fraunces';
  src:url('/assets/fonts/fraunces.woff2') format('woff2-variations'),
      url('/assets/fonts/fraunces.woff2') format('woff2');
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'Fraunces';
  src:url('/assets/fonts/fraunces-italic.woff2') format('woff2-variations'),
      url('/assets/fonts/fraunces-italic.woff2') format('woff2');
  font-weight:100 900;
  font-style:italic;
  font-display:swap;
}
@font-face{
  font-family:'Inter Tight';
  src:url('/assets/fonts/inter-tight.woff2') format('woff2-variations'),
      url('/assets/fonts/inter-tight.woff2') format('woff2');
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}

/* ---------- 1. Tokens ---------- */
:root{
  /* Brand */
  --c-forest:        #1c2a23;   /* tiefes Tannengrün, Hauptgrund */
  --c-forest-deep:   #131c17;   /* fast schwarz, Header/Footer */
  --c-forest-soft:   #243a30;   /* Karten-Untergrund */
  --c-moss:          #3a5a47;   /* mittleres Grün, Hovers */
  --c-bark:          #2a1f17;   /* Holz-/Lederbraun */
  --c-gold:          #c8a96e;   /* warmer Gold-Akzent */
  --c-gold-bright:   #e0c089;   /* Hover-Gold */
  --c-gold-deep:     #8c7440;   /* gedämpftes Gold (Borders) */
  --c-cream:         #f4ead9;   /* Pergament/Sand */
  --c-cream-soft:    #ebe0cc;
  --c-ink:           #efe6d3;   /* Body-Text auf Dunkel */
  --c-ink-muted:     #b8ad96;   /* Sekundärtext */
  --c-line:          rgba(200,169,110,.18);
  --c-line-strong:   rgba(200,169,110,.35);
  --c-danger:        #c8553d;
  --c-success:       #6b8e54;

  /* Typo */
  --f-display: 'Fraunces', 'Cormorant Garamond', Georgia, serif;
  --f-body:    'Inter Tight', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --f-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Consolas, monospace;

  /* Skala */
  --fs-xs:   .8125rem;
  --fs-sm:   .9375rem;
  --fs-base: 1.0625rem;
  --fs-md:   1.1875rem;
  --fs-lg:   1.375rem;
  --fs-xl:   1.75rem;
  --fs-2xl:  2.375rem;
  --fs-3xl:  3.25rem;
  --fs-4xl:  4.5rem;

  /* Spacing */
  --sp-1: .25rem; --sp-2: .5rem; --sp-3: .75rem; --sp-4: 1rem;
  --sp-5: 1.5rem; --sp-6: 2rem; --sp-7: 3rem; --sp-8: 4.5rem;
  --sp-9: 6rem;   --sp-10: 9rem;

  /* Container */
  --w-content: 72rem;
  --w-prose:   44rem;
  --w-narrow:  56rem;

  /* Radius */
  --r-sm: 4px; --r-md: 8px; --r-lg: 14px; --r-xl: 22px;

  /* Shadow / Glow */
  --sh-sm: 0 1px 2px rgba(0,0,0,.4);
  --sh-md: 0 8px 24px rgba(0,0,0,.35);
  --sh-lg: 0 24px 64px rgba(0,0,0,.5);
  --glow-gold: 0 0 0 1px rgba(200,169,110,.4), 0 8px 32px rgba(200,169,110,.15);

  /* Motion */
  --t-fast: 160ms cubic-bezier(.4,0,.2,1);
  --t-med:  280ms cubic-bezier(.4,0,.2,1);
  --t-slow: 520ms cubic-bezier(.22,.61,.36,1);
}

/* ---------- 2. Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:6rem}
body{
  font-family:var(--f-body);
  font-size:var(--fs-base);
  line-height:1.65;
  color:var(--c-ink);
  background:var(--c-forest);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:'ss01','cv11';
  min-height:100vh;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;height:auto;display:block}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:var(--c-gold);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--c-gold-bright)}
ul,ol{list-style:none}

/* ---------- 3. Atmosphäre / Hintergrund-Texturen ---------- */
body::before{
  content:"";
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(200,169,110,.08), transparent 70%),
    radial-gradient(ellipse 60% 40% at 90% 110%, rgba(58,90,71,.4), transparent 70%),
    var(--c-forest);
}
body::after{
  content:"";
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.78 0 0 0 0 0.66 0 0 0 0 0.43 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.6;
  mix-blend-mode:overlay;
}

/* ---------- 4. Skip & A11y ---------- */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:9999;
  background:var(--c-gold);color:var(--c-forest-deep);
  padding:var(--sp-3) var(--sp-5);font-weight:600;
  border-radius:0 0 var(--r-md) 0;
}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--c-gold);outline-offset:3px;border-radius:var(--r-sm)}

/* ---------- 5. Typografie ---------- */
h1,h2,h3,h4,h5,h6{
  font-family:var(--f-display);
  font-weight:500;
  line-height:1.1;
  color:var(--c-cream);
  letter-spacing:-.015em;
  font-feature-settings:'ss01','liga','dlig';
}
h1{font-size:clamp(2.25rem,4.5vw + .5rem,var(--fs-4xl));font-weight:400;letter-spacing:-.025em;font-style:italic}
h2{font-size:clamp(1.75rem,2.6vw + .5rem,var(--fs-3xl));font-weight:400;margin-top:var(--sp-8);margin-bottom:var(--sp-5)}
h3{font-size:clamp(1.35rem,1.4vw + .5rem,var(--fs-xl));margin-top:var(--sp-6);margin-bottom:var(--sp-3)}
p{margin-bottom:var(--sp-4);max-width:var(--w-prose)}
.lead{font-size:var(--fs-md);color:var(--c-cream-soft);font-weight:300;line-height:1.55}

/* Eyebrow / Kicker */
.kicker{
  display:inline-block;
  font-family:var(--f-mono);
  font-size:var(--fs-xs);
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--c-gold);
  margin-bottom:var(--sp-4);
}
.kicker::before{content:"— ";color:var(--c-gold-deep)}

blockquote{
  border-left:2px solid var(--c-gold);
  padding:var(--sp-2) var(--sp-5);
  margin:var(--sp-6) 0;
  font-family:var(--f-display);
  font-style:italic;
  font-size:var(--fs-md);
  color:var(--c-cream);
}

/* ---------- 6. Layout ---------- */
.container{max-width:var(--w-content);margin:0 auto;padding:0 var(--sp-5)}
.container-prose{max-width:var(--w-prose);margin:0 auto;padding:0 var(--sp-5)}
.container-narrow{max-width:var(--w-narrow);margin:0 auto;padding:0 var(--sp-5)}
section{padding:var(--sp-8) 0}
section.tight{padding:var(--sp-7) 0}
.section-divider{height:1px;background:linear-gradient(90deg,transparent,var(--c-line-strong),transparent);margin:var(--sp-8) 0}

/* ---------- 7. Header / Navigation ---------- */
.site-header{
  position:sticky;top:0;z-index:1100;
  background:rgba(19,28,23,.85);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--c-line);
}
.nav-container{
  max-width:var(--w-content);
  margin:0 auto;
  padding:var(--sp-3) var(--sp-5);
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--sp-5);
}
.logo{
  display:flex;align-items:center;gap:var(--sp-3);
  font-family:var(--f-display);font-size:var(--fs-md);font-weight:500;
  color:var(--c-cream);text-decoration:none;letter-spacing:-.01em;
}
.logo:hover{color:var(--c-gold-bright)}
.logo-icon{width:36px;height:36px;flex-shrink:0;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
.logo-sep{color:var(--c-gold);margin:0 .35em;font-style:italic}

.main-nav>ul{display:flex;align-items:center;gap:var(--sp-2)}
.main-nav a{
  color:var(--c-ink);
  padding:var(--sp-3) var(--sp-4);
  font-size:var(--fs-sm);
  font-weight:500;
  border-radius:var(--r-sm);
  letter-spacing:.01em;
  transition:all var(--t-fast);
  position:relative;
}
.main-nav a:hover{color:var(--c-gold-bright);background:rgba(200,169,110,.06)}
.main-nav a.active::after{
  content:"";position:absolute;left:50%;bottom:6px;
  width:14px;height:1.5px;background:var(--c-gold);
  transform:translateX(-50%);
}

/* Dropdown */
.nav-dropdown{position:relative}
.nav-dropdown-toggle::after{content:" ▾";font-size:.7em;opacity:.6;margin-left:.2em}

/* Dropdown — Desktop only (mobile overrides everything below in 720px breakpoint) */
@media (min-width: 721px){
  .nav-dropdown-menu{
    position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);
    min-width:560px;
    background:linear-gradient(180deg,var(--c-forest-soft),var(--c-forest-deep));
    border:1px solid var(--c-line-strong);
    border-radius:var(--r-lg);
    padding:var(--sp-5);
    box-shadow:var(--sh-lg);
    display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5);
    opacity:0;visibility:hidden;
    transition:all var(--t-med);
  }
  .nav-dropdown:hover .nav-dropdown-menu,
  .nav-dropdown:focus-within .nav-dropdown-menu{
    opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);
  }
  .nav-dropdown-label{
    display:block;
    font-family:var(--f-mono);
    font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
    color:var(--c-gold);
    margin-bottom:var(--sp-3);
    padding-bottom:var(--sp-2);
    border-bottom:1px solid var(--c-line);
  }
  .nav-dropdown-menu ul{display:flex;flex-direction:column;gap:2px}
  .nav-dropdown-menu a{
    padding:var(--sp-2) var(--sp-3);
    font-size:var(--fs-sm);
    color:var(--c-ink);
    border-radius:var(--r-sm);
    display:block;
  }
  .nav-dropdown-menu a em{color:var(--c-gold);font-style:italic}
}

.burger{
  display:none;
  font-size:1.5rem;
  color:var(--c-cream);
  padding:var(--sp-2);
  border-radius:var(--r-sm);
}

/* ---------- 8. Hero ---------- */
.hero{
  position:relative;
  padding:var(--sp-9) 0 var(--sp-8);
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse 60% 80% at 20% 30%, rgba(58,90,71,.5), transparent 60%),
    radial-gradient(ellipse 40% 60% at 90% 70%, rgba(200,169,110,.08), transparent 60%);
}
.hero-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:var(--sp-8);
  align-items:center;
}
.hero h1{margin-bottom:var(--sp-5)}
.hero h1 em{color:var(--c-gold);font-style:italic}
.hero-lead{font-size:var(--fs-md);color:var(--c-cream-soft);max-width:32rem;margin-bottom:var(--sp-6)}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:var(--sp-5);
  font-size:var(--fs-xs);font-family:var(--f-mono);
  color:var(--c-ink-muted);letter-spacing:.1em;text-transform:uppercase;
  margin-top:var(--sp-6);padding-top:var(--sp-5);
  border-top:1px solid var(--c-line);
}
.hero-meta span strong{color:var(--c-gold);font-weight:500}

/* Hero-Visual: stilisiertes Camping-Motiv */
.hero-visual{position:relative;aspect-ratio:1/1;max-width:480px;margin-left:auto}

/* ---------- 9. Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-4) var(--sp-6);
  font-family:var(--f-body);font-size:var(--fs-sm);font-weight:600;
  letter-spacing:.04em;
  border-radius:var(--r-sm);
  transition:all var(--t-fast);
  cursor:pointer;
  text-decoration:none;
}
.btn-primary{
  background:var(--c-gold);color:var(--c-forest-deep);
  box-shadow:0 4px 14px rgba(200,169,110,.25);
}
.btn-primary:hover{background:var(--c-gold-bright);transform:translateY(-1px);box-shadow:0 6px 20px rgba(200,169,110,.35);color:var(--c-forest-deep)}
.btn-ghost{
  background:transparent;color:var(--c-cream);
  border:1px solid var(--c-line-strong);
}
.btn-ghost:hover{border-color:var(--c-gold);color:var(--c-gold-bright);background:rgba(200,169,110,.05)}
.btn-arrow::after{content:"→";transition:transform var(--t-fast)}
.btn-arrow:hover::after{transform:translateX(3px)}

/* ---------- 10. Cards & Grids ---------- */
.card-grid{display:grid;gap:var(--sp-5);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.card-grid-3{grid-template-columns:repeat(3,1fr)}
.card-grid-2{grid-template-columns:repeat(2,1fr)}
.card-grid-4{grid-template-columns:repeat(4,1fr)}

.card{
  background:linear-gradient(165deg,var(--c-forest-soft),rgba(36,58,48,.4));
  border:1px solid var(--c-line);
  border-radius:var(--r-lg);
  padding:var(--sp-6);
  transition:all var(--t-med);
  position:relative;
  overflow:hidden;
  display:flex;flex-direction:column;
  gap:var(--sp-3);
  height:100%;
}
.card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 0% 0%, rgba(200,169,110,.08), transparent 50%);
  opacity:0;transition:opacity var(--t-med);
  pointer-events:none;
}
.card:hover{
  border-color:var(--c-gold-deep);
  transform:translateY(-3px);
  box-shadow:var(--sh-md);
}
.card:hover::before{opacity:1}
.card a{color:inherit;text-decoration:none;display:block}
.card-kicker{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-gold);letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:var(--sp-2);
}
.card-title{
  font-family:var(--f-display);font-size:var(--fs-lg);font-weight:500;
  color:var(--c-cream);margin-bottom:var(--sp-2);line-height:1.25;
}
.card-text{font-size:var(--fs-sm);color:var(--c-ink-muted);line-height:1.55;margin:0}
.card-meta{
  margin-top:auto;padding-top:var(--sp-4);
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-ink-muted);letter-spacing:.1em;text-transform:uppercase;
  border-top:1px solid var(--c-line);
}
.card-meta .arrow{color:var(--c-gold);font-size:1.1em;transition:transform var(--t-fast)}
.card:hover .card-meta .arrow{transform:translateX(4px)}

/* Hub-Cards größer */
.hub-card{
  padding:var(--sp-7);
  background:linear-gradient(165deg,var(--c-forest-soft) 0%,var(--c-bark) 100%);
}
.hub-card .card-title{font-size:var(--fs-2xl);font-style:italic}
.hub-icon{
  width:48px;height:48px;
  color:var(--c-gold);
  margin-bottom:var(--sp-4);
}

/* ---------- 11. Section-Header ---------- */
.section-head{
  text-align:center;
  max-width:var(--w-prose);
  margin:0 auto var(--sp-7);
}
.section-head .kicker{margin-bottom:var(--sp-3)}
.section-head h2{margin-top:0;margin-bottom:var(--sp-4)}
.section-head p{margin:0 auto;color:var(--c-ink-muted)}

.section-head-asym{
  display:grid;grid-template-columns:1fr 1.4fr;gap:var(--sp-7);
  align-items:end;margin-bottom:var(--sp-7);
}
.section-head-asym h2{margin:0}
.section-head-asym p{margin:0;color:var(--c-ink-muted);max-width:30rem}

/* ---------- 12. Featured-Region (große Karten mit Layered-Effect) ---------- */
.featured-region{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--c-line);
  border-radius:var(--r-xl);
  overflow:hidden;
  background:var(--c-forest-soft);
}
.featured-region-visual{
  background:linear-gradient(135deg,var(--c-moss),var(--c-bark));
  min-height:380px;
  position:relative;overflow:hidden;
}
.featured-region-content{padding:var(--sp-7)}

/* ---------- 13. Liste mit Bullet-Linien ---------- */
.outline-list{display:flex;flex-direction:column}
.outline-list li{
  padding:var(--sp-4) 0;
  border-bottom:1px solid var(--c-line);
  display:grid;grid-template-columns:auto 1fr auto;gap:var(--sp-5);
  align-items:center;
  transition:background var(--t-fast),padding var(--t-fast);
}
.outline-list li:hover{background:rgba(200,169,110,.04);padding-left:var(--sp-3);padding-right:var(--sp-3)}
.outline-list .num{
  font-family:var(--f-mono);font-size:var(--fs-xs);color:var(--c-gold);
  letter-spacing:.1em;
}
.outline-list .title{font-family:var(--f-display);font-size:var(--fs-md);color:var(--c-cream)}
.outline-list .meta{font-family:var(--f-mono);font-size:var(--fs-xs);color:var(--c-ink-muted);letter-spacing:.08em;text-transform:uppercase}
.outline-list a{color:inherit;display:contents}

/* ---------- 14. Stat-Block ---------- */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-5);
  padding:var(--sp-7);
  border-top:1px solid var(--c-line);
  border-bottom:1px solid var(--c-line);
}
.stat-num{
  font-family:var(--f-display);font-size:var(--fs-3xl);font-weight:400;
  color:var(--c-gold);line-height:1;letter-spacing:-.02em;
  font-style:italic;
}
.stat-label{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-ink-muted);letter-spacing:.15em;text-transform:uppercase;
  margin-top:var(--sp-3);
}

/* ---------- 15. Author / E-E-A-T-Box ---------- */
.author-box{
  display:grid;grid-template-columns:auto 1fr;gap:var(--sp-5);
  padding:var(--sp-6);
  background:linear-gradient(135deg,var(--c-forest-soft),var(--c-bark));
  border:1px solid var(--c-line-strong);
  border-radius:var(--r-lg);
  align-items:center;
}
.author-avatar{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,var(--c-gold),var(--c-gold-deep));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-size:1.75rem;color:var(--c-forest-deep);font-weight:500;
  box-shadow:var(--sh-md);
}
.author-name{font-family:var(--f-display);font-size:var(--fs-lg);color:var(--c-cream)}
.author-role{font-family:var(--f-mono);font-size:var(--fs-xs);color:var(--c-gold);letter-spacing:.15em;text-transform:uppercase;margin-top:var(--sp-1)}
.author-bio{margin-top:var(--sp-2);font-size:var(--fs-sm);color:var(--c-ink-muted)}

/* ---------- 16. Breadcrumb ---------- */
.breadcrumb{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-ink-muted);letter-spacing:.1em;text-transform:uppercase;
  padding:var(--sp-5) 0;
}
.breadcrumb a{color:var(--c-ink-muted)}
.breadcrumb a:hover{color:var(--c-gold)}
.breadcrumb .sep{color:var(--c-gold-deep);margin:0 var(--sp-2)}

/* ---------- 17. Article-Body ---------- */
.article-body h2{
  position:relative;
  padding-top:var(--sp-6);margin-top:var(--sp-7);
}
.article-body h2::before{
  content:"";position:absolute;top:0;left:0;
  width:48px;height:2px;background:var(--c-gold);
}
.article-body p,.article-body ul,.article-body ol{max-width:var(--w-prose)}
.article-body ul,.article-body ol{margin:0 0 var(--sp-5) var(--sp-5)}
.article-body li{margin-bottom:var(--sp-2);position:relative;list-style:none;padding-left:var(--sp-5)}
.article-body ul li::before{
  content:"";position:absolute;left:0;top:.7em;
  width:8px;height:8px;border:1px solid var(--c-gold);
  transform:rotate(45deg);
}
.article-body ol{counter-reset:n}
.article-body ol li{counter-increment:n}
.article-body ol li::before{
  content:counter(n,decimal-leading-zero);
  position:absolute;left:0;top:0;
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-gold);letter-spacing:.05em;
}
.article-body strong{color:var(--c-cream);font-weight:600}
.article-body em{color:var(--c-gold-bright);font-style:italic}
.article-body a{color:var(--c-gold);text-decoration:underline;text-decoration-color:var(--c-gold-deep);text-underline-offset:3px}
.article-body a:hover{text-decoration-color:var(--c-gold)}

/* Info-Callout */
.callout{
  margin:var(--sp-6) 0;padding:var(--sp-5) var(--sp-6);
  background:rgba(200,169,110,.06);
  border-left:3px solid var(--c-gold);
  border-radius:0 var(--r-md) var(--r-md) 0;
}
.callout-title{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-gold);letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:var(--sp-2);
}

/* Tabelle */
.article-body table{
  width:100%;border-collapse:collapse;margin:var(--sp-5) 0;
  font-size:var(--fs-sm);
}
.article-body th,.article-body td{
  padding:var(--sp-3) var(--sp-4);
  text-align:left;
  border-bottom:1px solid var(--c-line);
}
.article-body th{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  letter-spacing:.12em;text-transform:uppercase;color:var(--c-gold);
  font-weight:500;
  border-bottom:1px solid var(--c-gold-deep);
}

/* ---------- 18. FAQ-Akkordeon (HTML <details>) ---------- */
.faq{margin:var(--sp-6) 0}
.faq details{
  border-bottom:1px solid var(--c-line);
  padding:var(--sp-2) 0;
}
.faq summary{
  cursor:pointer;
  padding:var(--sp-4) 0;
  font-family:var(--f-display);
  font-size:var(--fs-md);
  color:var(--c-cream);
  list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:var(--sp-4);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";color:var(--c-gold);font-size:1.5rem;
  transition:transform var(--t-fast);
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details[open]{padding-bottom:var(--sp-4)}
.faq details > p,.faq details > div{
  color:var(--c-ink-muted);
  font-size:var(--fs-sm);
  padding:0 0 var(--sp-3);
  max-width:var(--w-prose);
}

/* ---------- 19. Footer ---------- */
.site-footer{
  background:var(--c-forest-deep);
  border-top:1px solid var(--c-line);
  padding:var(--sp-8) 0 var(--sp-5);
  margin-top:var(--sp-9);
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:var(--sp-7);margin-bottom:var(--sp-7);
}
.footer-brand{font-family:var(--f-display);font-size:var(--fs-xl);color:var(--c-cream);font-style:italic;margin-bottom:var(--sp-3)}
.footer-tagline{color:var(--c-ink-muted);font-size:var(--fs-sm);max-width:24rem}
.footer-col h4{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-gold);letter-spacing:.18em;text-transform:uppercase;
  font-weight:500;margin-bottom:var(--sp-4);
}
.footer-col ul{display:flex;flex-direction:column;gap:var(--sp-2)}
.footer-col a{color:var(--c-ink-muted);font-size:var(--fs-sm);transition:color var(--t-fast)}
.footer-col a:hover{color:var(--c-gold-bright)}
.footer-bottom{
  padding-top:var(--sp-5);
  border-top:1px solid var(--c-line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-4);
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-ink-muted);letter-spacing:.1em;text-transform:uppercase;
}
.footer-bottom nav{display:flex;gap:var(--sp-5);flex-wrap:wrap}

/* ---------- 20. Hero-SVG / Visual ---------- */
.camp-illustration{width:100%;height:100%;filter:drop-shadow(0 12px 40px rgba(0,0,0,.5))}

/* ---------- 21. Responsive ---------- */
@media (max-width: 960px){
  .hero-grid,.featured-region,.section-head-asym{grid-template-columns:1fr}
  .hero-visual{margin:var(--sp-5) auto 0;max-width:340px}
  .card-grid-3,.card-grid-4{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .author-box{grid-template-columns:1fr;text-align:center}
  .author-avatar{margin:0 auto}
}

@media (max-width: 720px){
  :root{--fs-base:1rem}
  section{padding:var(--sp-7) 0}
  .hero{padding:var(--sp-7) 0 var(--sp-6)}

  .burger{
    display:block;
    position:relative;
    z-index:1001;
  }

  /* Header bleibt sticky, aber backdrop-filter wird auf mobile entfernt,
     damit der Stacking-Context die fixed-Nav nicht einsperrt. */
  .site-header{
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    background:var(--c-forest-deep);
  }

  .main-nav{
    position:fixed;
    inset:0;
    z-index:1000;
    background:var(--c-forest-deep);
    transform:translateX(100%);
    transition:transform var(--t-med);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    padding:5rem var(--sp-5) var(--sp-7);
    visibility:hidden;
  }
  .main-nav.open{
    transform:translateX(0);
    visibility:visible;
  }
  .main-nav>ul{flex-direction:column;align-items:stretch;gap:0}
  .main-nav>ul>li{border-bottom:1px solid var(--c-line)}
  .main-nav a{padding:var(--sp-4);font-size:var(--fs-md)}

  /* Dropdown auf mobile: kollabiert per Default, öffnet auf Tap */
  .nav-dropdown{position:relative}
  .nav-dropdown-toggle{
    display:flex;
    align-items:center;
    justify-content:space-between;
  }
  .nav-dropdown-toggle::after{
    content:"+";
    display:inline-block;
    font-size:1.4rem;
    color:var(--c-gold);
    transition:transform var(--t-fast);
    margin-left:auto;
  }
  .nav-dropdown.open > .nav-dropdown-toggle::after{
    transform:rotate(45deg);
  }
  .nav-dropdown-menu{
    position:static;
    transform:none;
    opacity:0;
    visibility:hidden;
    max-height:0;
    overflow:hidden;
    display:block;            /* Grid-Layout aufheben */
    grid-template-columns:1fr;
    background:rgba(0,0,0,.25);
    border:0;
    padding:0 0 0 var(--sp-4);
    box-shadow:none;
    min-width:0;
    gap:var(--sp-4);
    transition:max-height var(--t-med),opacity var(--t-med),padding var(--t-med);
  }
  .nav-dropdown.open .nav-dropdown-menu{
    opacity:1;
    visibility:visible;
    max-height:1500px;
    padding:var(--sp-3) 0 var(--sp-4) var(--sp-4);
  }

  /* Mobile: Sektions-Labels sichtbar machen */
  .nav-dropdown-menu > div{
    margin-bottom:var(--sp-4);
  }
  .nav-dropdown-menu > div:last-child{
    margin-bottom:0;
  }
  .nav-dropdown-label{
    display:block;
    font-family:var(--f-mono);
    font-size:.75rem;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:var(--c-gold);
    margin-bottom:var(--sp-2);
    padding-bottom:var(--sp-2);
    padding-top:var(--sp-3);
    border-bottom:1px solid var(--c-line);
  }
  /* Mobile: Verschachtelte Untermenü-Links als Block */
  .nav-dropdown-menu ul{
    display:flex;
    flex-direction:column;
    gap:0;
    margin:0;
    padding:0;
    list-style:none;
  }
  .nav-dropdown-menu ul li{
    border-bottom:0;          /* nur die Top-Level-LIs hatten Border */
    margin:0;
    padding:0;
  }
  .nav-dropdown-menu ul li::before{
    display:none;             /* Pfeil-Bullet aus article-body unterdrücken */
  }
  .nav-dropdown-menu a{
    display:block;
    padding:var(--sp-3) var(--sp-2);
    font-size:var(--fs-base);
    color:var(--c-ink);
    border-radius:var(--r-sm);
  }
  .nav-dropdown-menu a:hover,
  .nav-dropdown-menu a:focus{
    color:var(--c-gold-bright);
    background:rgba(200,169,110,.08);
  }
  .nav-dropdown-menu a em{
    color:var(--c-gold);
    font-style:italic;
  }

  .card-grid-3,.card-grid-4,.card-grid-2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:var(--sp-4);padding:var(--sp-5)}
  .stat-num{font-size:var(--fs-2xl)}
  .footer-grid{grid-template-columns:1fr;gap:var(--sp-5)}
  .footer-bottom{flex-direction:column;gap:var(--sp-3)}
  .hero h1{font-size:clamp(2rem,8vw,2.75rem)}

  /* Body-Scroll sperren wenn Menü offen */
  body.nav-open{overflow:hidden}
}

/* ---------- 22. Print ---------- */
@media print{
  body::before,body::after{display:none}
  .site-header,.site-footer,.burger{display:none}
  body{background:#fff;color:#000}
  h1,h2,h3{color:#000}
  a{color:#000;text-decoration:underline}
}

/* ---------- 23. Reduced Motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}

/* ---------- 24. Utility ---------- */
.text-gold{color:var(--c-gold)}
.text-cream{color:var(--c-cream)}
.text-muted{color:var(--c-ink-muted)}
.italic{font-style:italic}
.center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
