/* =========================================
   HFC – Rechtsseiten (Impressum / Datenschutz / AGB)
   Nutzt Variablen & Grundstile aus style.css
   ========================================= */

/* Schlanke statische Nav für Rechtsseiten */
.legalnav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(10, 9, 8, .9);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
}
.legalnav__inner {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 32px;
  height: 76px;
  display: flex;
  align-items: center;
  gap: 28px;
}
.legalnav__logo { display: flex; align-items: baseline; gap: 10px; margin-right: auto; }
.legalnav__links { display: flex; gap: 26px; align-items: center; }
.legalnav__links a {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 400;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  transition: color .35s;
  position: relative;
  padding: 4px 0;
}
.legalnav__links a::after {
  content: '';
  position: absolute;
  left: 0; bottom: 0;
  width: 0; height: 1px;
  background: var(--gold);
  transition: width .35s ease;
}
.legalnav__links a:hover,
.legalnav__links a.active { color: var(--cream); }
.legalnav__links a.active::after,
.legalnav__links a:hover::after { width: 100%; }

@media (max-width: 720px) {
  .legalnav__inner { height: 64px; gap: 16px; }
  .legalnav__links { gap: 16px; }
  .legalnav__links a { font-size: 10px; letter-spacing: .12em; }
  .legalnav__logo .logo-sub { display: none; }
}

/* Legal Hero */
.legal-hero {
  padding: 90px 0 50px;
  text-align: center;
  border-bottom: 1px solid var(--line);
  background: radial-gradient(ellipse 70% 100% at 50% 0%, rgba(194,163,94,.07), transparent 70%);
}
.legal-hero__title {
  font-family: var(--font-display);
  font-size: clamp(40px, 7vw, 72px);
  font-weight: 500;
  font-style: italic;
  letter-spacing: .02em;
  color: var(--cream);
  line-height: 1.02;
}
.legal-hero__sub {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 400;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 18px;
}

/* Legal Content */
.legal {
  max-width: 820px;
  margin: 0 auto;
  padding: 80px 32px 120px;
}
.legal h2 {
  font-family: var(--font-display);
  font-size: 30px;
  font-weight: 500;
  font-style: italic;
  letter-spacing: .02em;
  color: var(--cream);
  margin: 56px 0 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.legal h2:first-child { margin-top: 0; }
.legal h3 {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 34px 0 12px;
}
.legal p {
  font-size: 15px;
  font-weight: 300;
  line-height: 1.85;
  color: var(--muted);
  margin-bottom: 16px;
  letter-spacing: .01em;
}
.legal p strong, .legal li strong { color: var(--cream); font-weight: 400; }
.legal a { color: var(--gold); transition: color .3s; word-break: break-word; }
.legal a:hover { color: var(--gold-l); }

.legal ul, .legal ol { margin: 0 0 18px; padding-left: 4px; }
.legal li {
  font-size: 15px;
  font-weight: 300;
  line-height: 1.8;
  color: var(--muted);
  margin-bottom: 10px;
  padding-left: 24px;
  position: relative;
  list-style: none;
}
.legal ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 12px;
  width: 11px; height: 1px;
  background: var(--gold);
}
.legal ol { counter-reset: legalcounter; }
.legal ol > li { counter-increment: legalcounter; }
.legal ol > li::before {
  content: counter(legalcounter) '.';
  position: absolute;
  left: 0; top: 0;
  color: var(--gold);
  font-family: var(--font-display);
  font-size: 15px;
}

/* Definitions-/Adressblock */
.legal-block {
  border: 1px solid var(--line);
  padding: 30px 32px;
  margin: 24px 0 28px;
  background: rgba(255,255,255,.012);
}
.legal-block p { margin-bottom: 6px; }
.legal-block p:last-child { margin-bottom: 0; }

/* Inhaltsverzeichnis */
.legal-toc {
  border: 1px solid var(--line-soft);
  padding: 26px 30px;
  margin-bottom: 48px;
}
.legal-toc__title {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--muted-d);
  margin-bottom: 16px;
}
.legal-toc ol { margin: 0; padding: 0; columns: 2; column-gap: 36px; }
.legal-toc li { margin-bottom: 8px; padding-left: 22px; }
.legal-toc li::before { font-size: 13px; }
.legal-toc a { color: var(--muted); font-weight: 300; }
.legal-toc a:hover { color: var(--gold); }
@media (max-width: 600px) { .legal-toc ol { columns: 1; } }

/* Platzhalter-Markierung */
.placeholder {
  color: #e9c45a;
  background: rgba(233, 196, 90, .1);
  border-bottom: 1px dashed rgba(233, 196, 90, .5);
  padding: 1px 6px;
  font-weight: 400;
  font-style: normal;
}

/* Hinweisbox */
.legal-note {
  border-left: 2px solid var(--gold);
  background: rgba(194,163,94,.05);
  padding: 20px 26px;
  margin: 28px 0;
}
.legal-note p { margin-bottom: 0; font-size: 14px; }
.legal-note strong { color: var(--gold-l); }

/* kleiner Stand-Hinweis unten */
.legal__updated {
  margin-top: 56px;
  padding-top: 24px;
  border-top: 1px solid var(--line-soft);
  font-size: 13px;
  color: var(--muted-d);
  letter-spacing: .04em;
}
