/* ================================================================
   Vertrag-Kuendigen.com · Premium Verbraucherrecht Design System
   © SEO NW · Alexander Müller · 2026
   ================================================================ */

/* ---------- 0. Local Font ---------- */
@font-face{
  font-family:'Inter';
  src:url('/assets/fonts/inter.woff2') format('woff2-variations'),
      url('/assets/fonts/inter.woff2') format('woff2');
  font-weight:100 900;font-style:normal;font-display:swap;
}

/* ---------- 1. Tokens ---------- */
:root{
  /* Brand: Anthrazit-Blau + Kupfer-Rot */
  --c-night:         #0f1822;   /* Tiefes Anthrazit-Blau, Hauptgrund */
  --c-night-deep:    #0a1118;   /* fast schwarz, Header/Footer */
  --c-night-soft:    #1a2532;   /* Karten-Untergrund */
  --c-steel:         #2a3848;   /* mittelblau, Hover */
  --c-slate:         #1f2b3a;   /* graublau, sekundär */
  --c-copper:        #c46a3a;   /* warmes Kupfer-Rot, Akzent */
  --c-copper-bright: #e08550;   /* heller, Hover */
  --c-copper-deep:   #8c4824;   /* gedämpft, Borders */
  --c-paper:         #f0ebe2;   /* warmes Pergament */
  --c-paper-soft:    #e3dccd;
  --c-ink:           #e6e0d4;   /* Body-Text auf Dunkel */
  --c-ink-muted:     #9aa3af;   /* Sekundärtext, kühles Grau-Blau */
  --c-line:          rgba(196,106,58,.16);
  --c-line-strong:   rgba(196,106,58,.32);
  --c-danger:        #d65a4a;
  --c-success:       #5e9070;
  --c-warning:       #d4a44a;

  /* Typo */
  --f-display: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --f-body:    '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,.4);
  --sh-lg: 0 24px 64px rgba(0,0,0,.55);
  --glow-copper: 0 0 0 1px rgba(196,106,58,.4), 0 8px 32px rgba(196,106,58,.18);

  /* 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-night);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:'cv11','ss03';
  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-copper);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--c-copper-bright)}
ul,ol{list-style:none}

/* ---------- 3. Atmosphäre ---------- */
body::before{
  content:"";
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(196,106,58,.07), transparent 70%),
    radial-gradient(ellipse 60% 40% at 90% 110%, rgba(42,56,72,.5), transparent 70%),
    var(--c-night);
}
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.77 0 0 0 0 0.42 0 0 0 0 0.23 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:.5;
  mix-blend-mode:overlay;
}

/* ---------- 4. Skip & A11y ---------- */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:9999;
  background:var(--c-copper);color:var(--c-night-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-copper);outline-offset:3px;border-radius:var(--r-sm)}

/* ---------- 5. Typografie ---------- */
h1,h2,h3,h4,h5,h6{
  font-family:var(--f-display);
  font-weight:600;
  line-height:1.15;
  color:var(--c-paper);
  letter-spacing:-.02em;
  font-feature-settings:'ss01','cv11';
}
h1{font-size:clamp(2.25rem,4.5vw + .5rem,var(--fs-4xl));font-weight:700;letter-spacing:-.03em;line-height:1.05}
h2{font-size:clamp(1.75rem,2.6vw + .5rem,var(--fs-3xl));font-weight:600;margin-top:var(--sp-8);margin-bottom:var(--sp-5)}
h3{font-size:clamp(1.35rem,1.4vw + .5rem,var(--fs-xl));font-weight:600;margin-top:var(--sp-6);margin-bottom:var(--sp-3)}
h4{font-size:var(--fs-lg);font-weight:600;margin-top:var(--sp-5);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-paper-soft);font-weight:400;line-height:1.55}

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

blockquote{
  border-left:2px solid var(--c-copper);
  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-paper);
}

/* ---------- 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(10,17,24,.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:600;
  color:var(--c-paper);text-decoration:none;letter-spacing:-.015em;
}
.logo:hover{color:var(--c-copper-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-copper);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-copper-bright);background:rgba(196,106,58,.06)}
.main-nav a.active::after{
  content:"";position:absolute;left:50%;bottom:6px;
  width:14px;height:1.5px;background:var(--c-copper);
  transform:translateX(-50%);
}

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

@media (min-width: 721px){
  .nav-dropdown-menu{
    position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);
    min-width:680px;
    background:linear-gradient(180deg,var(--c-night-soft),var(--c-night-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-copper);
    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-copper);font-style:italic}
}

.burger{
  display:none;
  font-size:1.5rem;
  color:var(--c-paper);
  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(42,56,72,.6), transparent 60%),
    radial-gradient(ellipse 40% 60% at 90% 70%, rgba(196,106,58,.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-copper);font-style:italic}
.hero-lead{font-size:var(--fs-md);color:var(--c-paper-soft);max-width:34rem;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-copper);font-weight:500}

.hero-visual{position:relative;aspect-ratio:1/1;max-width:480px;margin-left:auto}
.hero-illustration{width:100%;height:100%;filter:drop-shadow(0 12px 40px rgba(0,0,0,.5))}

/* ---------- 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-copper);color:var(--c-night-deep);
  box-shadow:0 4px 14px rgba(196,106,58,.28);
}
.btn-primary:hover{background:var(--c-copper-bright);transform:translateY(-1px);box-shadow:0 6px 20px rgba(196,106,58,.4);color:var(--c-night-deep)}
.btn-ghost{
  background:transparent;color:var(--c-paper);
  border:1px solid var(--c-line-strong);
}
.btn-ghost:hover{border-color:var(--c-copper);color:var(--c-copper-bright);background:rgba(196,106,58,.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-night-soft),rgba(26,37,50,.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(196,106,58,.08), transparent 50%);
  opacity:0;transition:opacity var(--t-med);
  pointer-events:none;
}
.card:hover{
  border-color:var(--c-copper-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-copper);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:600;
  color:var(--c-paper);margin-bottom:var(--sp-2);line-height:1.25;letter-spacing:-.015em;
}
.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-copper);font-size:1.1em;transition:transform var(--t-fast)}
.card:hover .card-meta .arrow{transform:translateX(4px)}

.hub-card{
  padding:var(--sp-7);
  background:linear-gradient(165deg,var(--c-night-soft) 0%,var(--c-slate) 100%);
}
.hub-card .card-title{font-size:var(--fs-2xl);font-weight:700;letter-spacing:-.025em}
.hub-icon{
  width:48px;height:48px;
  color:var(--c-copper);
  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 ---------- */
.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-night-soft);
}
.featured-region-visual{
  background:linear-gradient(135deg,var(--c-steel),var(--c-slate));
  min-height:380px;
  position:relative;overflow:hidden;
}
.featured-region-content{padding:var(--sp-7)}

/* ---------- 13. Outline-Liste ---------- */
.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(196,106,58,.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-copper);
  letter-spacing:.1em;
}
.outline-list .title{font-family:var(--f-display);font-size:var(--fs-md);font-weight:600;color:var(--c-paper);letter-spacing:-.01em}
.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. Stats ---------- */
.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:700;
  color:var(--c-copper);line-height:1;letter-spacing:-.03em;
}
.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 ---------- */
.author-box{
  display:grid;grid-template-columns:auto 1fr;gap:var(--sp-5);
  padding:var(--sp-6);
  background:linear-gradient(135deg,var(--c-night-soft),var(--c-slate));
  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-copper),var(--c-copper-deep));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-size:1.75rem;color:var(--c-night-deep);font-weight:500;
  box-shadow:var(--sh-md);
}
.author-name{font-family:var(--f-display);font-size:var(--fs-lg);color:var(--c-paper);font-weight:600;letter-spacing:-.01em}
.author-role{font-family:var(--f-mono);font-size:var(--fs-xs);color:var(--c-copper);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-copper)}
.breadcrumb .sep{color:var(--c-copper-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-copper);
}
.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-copper);
  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-copper);letter-spacing:.05em;
}
.article-body strong{color:var(--c-paper);font-weight:600}
.article-body em{color:var(--c-copper-bright);font-style:italic}
.article-body a{color:var(--c-copper);text-decoration:underline;text-decoration-color:var(--c-copper-deep);text-underline-offset:3px}
.article-body a:hover{text-decoration-color:var(--c-copper)}

/* ---------- 18. Callouts ---------- */
.callout{
  margin:var(--sp-6) 0;padding:var(--sp-5) var(--sp-6);
  background:rgba(196,106,58,.06);
  border-left:3px solid var(--c-copper);
  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-copper);letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:var(--sp-2);
}
.callout p{max-width:none;margin-bottom:0}
.callout p + p{margin-top:var(--sp-3)}

.callout-warning{
  background:rgba(214,90,74,.07);
  border-left-color:var(--c-danger);
}
.callout-warning .callout-title{color:var(--c-danger)}

.callout-success{
  background:rgba(94,144,112,.07);
  border-left-color:var(--c-success);
}
.callout-success .callout-title{color:var(--c-success)}

.callout-paragraph{
  background:rgba(42,56,72,.4);
  border-left-color:var(--c-copper);
}
.callout-paragraph .callout-title::before{content:"§ "}

/* ---------- 19. Mustertext-Box ---------- */
.muster-box{
  margin:var(--sp-6) 0;
  border:1px solid var(--c-line-strong);
  border-radius:var(--r-lg);
  background:var(--c-paper);
  color:#1a2532;
  overflow:hidden;
  box-shadow:var(--sh-md);
}
.muster-box .muster-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:var(--sp-3) var(--sp-5);
  background:var(--c-paper-soft);
  border-bottom:1px solid rgba(0,0,0,.1);
  font-family:var(--f-mono);font-size:var(--fs-xs);
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--c-copper-deep);
}
.muster-box .muster-body{
  padding:var(--sp-6);
  font-family:var(--f-body);
  font-size:var(--fs-sm);
  line-height:1.7;
  white-space:pre-wrap;
}
.muster-box .muster-body strong{color:#0f1822}
.muster-box .muster-body .placeholder{
  background:rgba(196,106,58,.18);
  color:var(--c-copper-deep);
  padding:1px 6px;border-radius:3px;
  font-weight:600;
}
.muster-box .muster-actions{
  padding:var(--sp-3) var(--sp-5);
  background:var(--c-paper-soft);
  border-top:1px solid rgba(0,0,0,.08);
  display:flex;gap:var(--sp-3);justify-content:flex-end;flex-wrap:wrap;
}
.muster-box .btn-mini{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  letter-spacing:.1em;text-transform:uppercase;
  padding:var(--sp-2) var(--sp-4);
  background:var(--c-night);color:var(--c-paper);
  border-radius:var(--r-sm);
  cursor:pointer;
  transition:background var(--t-fast);
}
.muster-box .btn-mini:hover{background:var(--c-copper);color:var(--c-night-deep)}

/* ---------- 20. Frist-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);
  vertical-align:top;
}
.article-body th{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  letter-spacing:.12em;text-transform:uppercase;color:var(--c-copper);
  font-weight:500;
  border-bottom:1px solid var(--c-copper-deep);
}
.article-body tbody tr:hover{background:rgba(196,106,58,.04)}

/* Frist-Tag (z.B. "3 Monate", "14 Tage") */
.frist-tag{
  display:inline-block;
  font-family:var(--f-mono);font-size:var(--fs-xs);
  letter-spacing:.08em;
  padding:2px 10px;
  border-radius:99px;
  background:rgba(196,106,58,.14);
  color:var(--c-copper-bright);
  border:1px solid var(--c-copper-deep);
  white-space:nowrap;
}
.frist-tag.short{background:rgba(214,90,74,.14);color:var(--c-danger);border-color:rgba(214,90,74,.4)}
.frist-tag.long{background:rgba(94,144,112,.14);color:var(--c-success);border-color:rgba(94,144,112,.4)}

/* ---------- 21. FAQ ---------- */
.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);
  font-weight:600;
  letter-spacing:-.01em;
  color:var(--c-paper);
  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-copper);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);
}

/* ---------- 22. Footer ---------- */
.site-footer{
  background:var(--c-night-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-paper);font-weight:700;letter-spacing:-.02em;margin-bottom:var(--sp-3)}
.footer-tagline{color:var(--c-ink-muted);font-size:var(--fs-sm);max-width:24rem}
.footer-col-title{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-copper);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-copper-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}

/* ---------- 23. Tag-Pills ---------- */
.tag-pills{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin:var(--sp-4) 0}
.tag-pill{
  display:inline-block;
  padding:var(--sp-1) var(--sp-3);
  background:rgba(196,106,58,.08);
  border:1px solid var(--c-line);
  border-radius:99px;
  font-family:var(--f-mono);font-size:var(--fs-xs);
  letter-spacing:.08em;
  color:var(--c-copper);
  transition:all var(--t-fast);
}
a.tag-pill:hover{background:var(--c-copper);color:var(--c-night-deep);border-color:var(--c-copper)}

/* ---------- 24. TOC ---------- */
.toc{
  background:var(--c-night-soft);
  border:1px solid var(--c-line);
  border-radius:var(--r-lg);
  padding:var(--sp-5) var(--sp-6);
  margin:var(--sp-6) 0;
}
.toc-title{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-copper);letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:var(--sp-3);
}
.toc ol{margin:0;padding:0;list-style:none;counter-reset:toc}
.toc ol li{counter-increment:toc;padding-left:var(--sp-5);position:relative;margin-bottom:var(--sp-2)}
.toc ol li::before{
  content:counter(toc,decimal-leading-zero);
  position:absolute;left:0;top:0;
  font-family:var(--f-mono);font-size:var(--fs-xs);
  color:var(--c-copper-deep);
}
.toc ol li a{color:var(--c-paper);text-decoration:none;font-size:var(--fs-sm)}
.toc ol li a:hover{color:var(--c-copper-bright)}

/* ---------- 25. Schritt-Liste (Step-by-Step) ---------- */
.steps{counter-reset:step;margin:var(--sp-7) 0;display:flex;flex-direction:column;gap:var(--sp-5)}
.step{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:var(--sp-5);
  padding:var(--sp-5);
  background:linear-gradient(165deg,var(--c-night-soft),rgba(26,37,50,.4));
  border:1px solid var(--c-line);
  border-radius:var(--r-lg);
  counter-increment:step;
}
.step::before{
  content:counter(step,decimal-leading-zero);
  font-family:var(--f-display);font-weight:700;
  font-size:var(--fs-2xl);
  color:var(--c-copper);line-height:1;letter-spacing:-.03em;
}
.step-title{font-family:var(--f-display);font-size:var(--fs-lg);color:var(--c-paper);margin:0 0 var(--sp-2);font-weight:600;letter-spacing:-.01em}
.step-text{color:var(--c-ink);font-size:var(--fs-sm);margin:0;max-width:none}

/* ---------- 26. Pro-/Contra-Listen ---------- */
.pro-contra{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5);
  margin:var(--sp-6) 0;
}
.pro-list, .contra-list{
  padding:var(--sp-5);
  border:1px solid var(--c-line);
  border-radius:var(--r-lg);
}
.pro-list{background:rgba(94,144,112,.05);border-color:rgba(94,144,112,.2)}
.contra-list{background:rgba(214,90,74,.05);border-color:rgba(214,90,74,.2)}
.pro-list h4, .contra-list h4{
  font-family:var(--f-mono);font-size:var(--fs-xs);
  letter-spacing:.18em;text-transform:uppercase;
  margin:0 0 var(--sp-3);
}
.pro-list h4{color:var(--c-success)}
.contra-list h4{color:var(--c-danger)}
.pro-list ul, .contra-list ul{margin:0;padding:0}
.pro-list li, .contra-list li{
  list-style:none;padding-left:var(--sp-5);position:relative;
  margin-bottom:var(--sp-2);font-size:var(--fs-sm);
  color:var(--c-ink);max-width:none;
}
.pro-list li::before{content:"✓";position:absolute;left:0;color:var(--c-success);font-weight:700}
.contra-list li::before{content:"✗";position:absolute;left:0;color:var(--c-danger);font-weight:700}

/* ---------- 27. Print ---------- */
@media print{
  body::before,body::after{display:none}
  .site-header,.site-footer,.burger,.muster-actions{display:none}
  body{background:#fff;color:#000}
  h1,h2,h3{color:#000}
  a{color:#000;text-decoration:underline}
  .muster-box{box-shadow:none;border:1px solid #999}
}

/* ---------- 28. 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;
  }
}

/* ---------- 29. Utilities ---------- */
.text-copper{color:var(--c-copper)}
.text-paper{color:var(--c-paper)}
.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}

/* ---------- 30. Responsive ---------- */
@media (max-width: 960px){
  .hero-grid,.featured-region,.section-head-asym,.pro-contra{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}
  .site-header{
    backdrop-filter:none;-webkit-backdrop-filter:none;
    background:var(--c-night-deep);
  }
  .main-nav{
    position:fixed;inset:0;z-index:1000;
    background:var(--c-night-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)}

  .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-copper);
    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-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);
  }
  .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-copper);
    margin-bottom:var(--sp-2);padding-bottom:var(--sp-2);padding-top:var(--sp-3);
    border-bottom:1px solid var(--c-line);
  }
  .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;margin:0;padding:0}
  .nav-dropdown-menu ul li::before{display:none}
  .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-copper-bright);background:rgba(196,106,58,.08);
  }
  .nav-dropdown-menu a em{color:var(--c-copper);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)}
  .step{grid-template-columns:1fr;gap:var(--sp-3)}
  .article-body table{font-size:var(--fs-xs);display:block;overflow-x:auto}

  body.nav-open{overflow:hidden}
}
