/* Gemeinsames Layout für Rechtsseiten (AGB, Datenschutz, Impressum)
   – Header + Footer + Rechtstext-Typografie im Pickadoc-Design. */
:root {
  --p3-pink: var(--pink, #d862c8);
  --p3-pink2: var(--pink-light, #e89fdd);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: #fff; color: var(--ink); overflow-x: hidden; }

/* ---- Header ---- */
.l-header {
  position: sticky; top: 0; z-index: 80;
  background: rgba(255, 255, 255, .85);
  border-bottom: 1px solid rgba(30, 28, 70, .08);
  -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px);
}
.l-header__inner {
  max-width: 100%; padding: 0 clamp(16px, 2.2vw, 30px); height: 74px;
  display: flex; align-items: center; gap: 14px;
}
.l-logo { display: inline-flex; align-items: center; gap: 10px; font-weight: 900; letter-spacing: -.02em; color: var(--ink); text-decoration: none; margin-right: auto; }
.l-logo img { width: 34px; height: 34px; }
.l-logo span span { color: var(--p3-pink); }
.l-back { display: inline-flex; align-items: center; gap: 7px; padding: 8px 12px; border-radius: 9px; font-weight: 700; font-size: .9rem; color: var(--ink); text-decoration: none; }
.l-back i { font-size: .8rem; color: var(--font); }
.l-back:hover { color: var(--p3-pink); background: var(--alt); }
.l-demo i { font-size: .72rem; }
@media (max-width: 460px) { .l-back span { display: none; } }

/* ---- Hero / Titelband ---- */
.l-hero {
  position: relative; overflow: hidden; color: #fff;
  padding: clamp(46px, 7vw, 84px) 0 clamp(40px, 6vw, 70px);
  background:
    radial-gradient(820px 460px at 12% -10%, rgba(216, 98, 200, .26), transparent 60%),
    radial-gradient(680px 420px at 96% 120%, rgba(46, 230, 200, .12), transparent 60%),
    linear-gradient(160deg, #100c1a 0%, #07070d 100%);
}
.l-hero::before {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .5;
  background-image:
    linear-gradient(rgba(255, 255, 255, .045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .045) 1px, transparent 1px);
  background-size: 46px 46px;
  -webkit-mask-image: radial-gradient(120% 90% at 50% 0%, #000, transparent 78%);
  mask-image: radial-gradient(120% 90% at 50% 0%, #000, transparent 78%);
}
.l-hero .container { position: relative; z-index: 1; }
.l-crumb { display: inline-flex; align-items: center; gap: 8px; font-size: .8rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--p3-pink2); }
.l-crumb a { color: var(--p3-pink2); text-decoration: none; }
.l-crumb a:hover { color: #fff; }
.l-hero h1 { margin: 16px 0 12px; font-size: clamp(2.1rem, 5vw, 3.6rem); line-height: 1.02; letter-spacing: -.04em; font-weight: 900; color: #fff; }
.l-hero p { margin: 0; max-width: 60ch; color: rgba(255, 255, 255, .68); font-size: 1.02rem; line-height: 1.6; font-weight: 600; }

/* ---- Artikel / Rechtstext ---- */
.l-article { padding: clamp(40px, 6vw, 76px) 0; }
.l-article .container { max-width: 880px; }
.l-doc { color: var(--font); font-size: 1.01rem; line-height: 1.72; }
.l-doc h2 {
  margin: 44px 0 14px; color: var(--ink); font-weight: 900; letter-spacing: -.02em;
  font-size: clamp(1.35rem, 2.4vw, 1.75rem); line-height: 1.2;
  padding-top: 22px; border-top: 1px solid var(--grid);
}
.l-doc h2:first-child { margin-top: 0; padding-top: 0; border-top: none; }
.l-doc h3 { margin: 28px 0 10px; color: var(--ink); font-weight: 800; font-size: 1.1rem; }
.l-doc p { margin: 0 0 16px; }
.l-doc a { color: var(--p3-pink); font-weight: 700; word-break: break-word; }
.l-doc a:hover { color: #c44eb4; }
.l-doc strong, .l-doc b { color: var(--ink); font-weight: 800; }
.l-doc ul { margin: 0 0 18px; padding: 0; list-style: none; display: grid; gap: 10px; }
.l-doc ul li { position: relative; padding-left: 26px; }
.l-doc ul li::before {
  content: ""; position: absolute; left: 6px; top: 11px; width: 7px; height: 7px;
  border-radius: 50%; background: var(--p3-pink);
}
.l-doc__meta { margin-top: 30px; padding: 14px 18px; border-radius: 12px; background: var(--alt); color: var(--font); font-size: .9rem; font-weight: 700; }

/* Hervorgehobene Kontakt-/Adress-Karte (Impressum) */
.l-card {
  margin: 0 0 22px; padding: 22px 24px; border-radius: 18px;
  background: var(--alt); border: 1px solid var(--grid);
}
.l-card b { display: block; color: var(--ink); font-weight: 900; font-size: 1.05rem; margin-bottom: 4px; }
.l-card p { margin: 0; color: var(--font); line-height: 1.65; }
.l-card a { color: var(--p3-pink); font-weight: 700; }

/* ---- Footer (identisch zur Startseite) ---- */
.site-footer {
  position: relative; overflow: hidden; color: #fff;
  padding: clamp(56px, 8vw, 100px) 0 0;
  background:
    radial-gradient(900px 520px at 10% -12%, rgba(216, 98, 200, .24), transparent 60%),
    radial-gradient(760px 440px at 96% 116%, rgba(46, 230, 200, .13), transparent 60%),
    linear-gradient(180deg, #0c0d15 0%, #07070d 100%);
}
.site-footer::before {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .55;
  background-image:
    linear-gradient(rgba(255, 255, 255, .045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .045) 1px, transparent 1px);
  background-size: 46px 46px;
  -webkit-mask-image: radial-gradient(125% 80% at 50% 0%, #000, transparent 76%);
  mask-image: radial-gradient(125% 80% at 50% 0%, #000, transparent 76%);
}
.footer-trust {
  position: relative; z-index: 1; display: grid; gap: 14px; grid-template-columns: 1fr;
  margin-bottom: clamp(40px, 5vw, 56px); padding-bottom: clamp(40px, 5vw, 56px);
  border-bottom: 1px solid rgba(255, 255, 255, .1);
}
@media (min-width: 760px) { .footer-trust { grid-template-columns: repeat(3, 1fr); } }
.ftrust { display: flex; gap: 14px; align-items: flex-start; padding: 18px; border-radius: 16px; background: rgba(255, 255, 255, .04); border: 1px solid rgba(255, 255, 255, .1); }
.ftrust__ic { width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center; flex: none; background: rgba(216, 98, 200, .16); color: var(--p3-pink2); font-size: 18px; }
.ftrust b { display: block; color: #fff; font-size: .98rem; font-weight: 900; margin-bottom: 5px; }
.ftrust p { margin: 0; color: rgba(255, 255, 255, .62); font-size: .85rem; line-height: 1.5; font-weight: 600; }
.ftrust a { color: var(--p3-pink2); font-weight: 800; }
.ftrust a:hover { color: #fff; }
.footer-grid {
  position: relative; z-index: 1;
  display: grid; gap: clamp(34px, 5vw, 56px); grid-template-columns: 1fr;
}
@media (min-width: 600px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .footer-grid { grid-template-columns: 1.7fr 1fr 1fr 1fr; } }
.footer-brand__logo { display: inline-flex; align-items: center; gap: 10px; font-weight: 900; font-size: 1.4rem; letter-spacing: -.02em; color: #fff; text-decoration: none; }
.footer-brand__logo img { width: 36px; height: 36px; }
.footer-brand__logo span span { color: var(--p3-pink2); }
.footer-brand p { margin: 16px 0 0; color: rgba(255, 255, 255, .6); line-height: 1.6; font-weight: 600; max-width: 38ch; }
.footer-badge {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 20px; padding: 8px 14px; border-radius: 999px;
  background: rgba(255, 255, 255, .06); border: 1px solid rgba(255, 255, 255, .12); font-size: .8rem; font-weight: 800; color: rgba(255, 255, 255, .84);
}
.footer-badge i { width: 8px; height: 8px; border-radius: 50%; background: #2fd07a; box-shadow: 0 0 0 4px rgba(47, 208, 122, .2); }
.footer-col h4 { margin: 0 0 16px; font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: var(--p3-pink2); font-weight: 900; }
.footer-col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 12px; }
.footer-col a { color: rgba(255, 255, 255, .72); font-weight: 700; transition: color .2s ease; text-decoration: none; }
.footer-col a:hover { color: #fff; }
.footer-addr { display: grid; gap: 18px; }
.footer-addr .addr { color: rgba(255, 255, 255, .62); line-height: 1.55; font-weight: 600; font-size: .92rem; }
.footer-addr .addr b { display: block; color: #fff; font-weight: 800; margin-bottom: 4px; }
.footer-contact a { display: flex; align-items: center; gap: 10px; }
.footer-contact i { color: var(--p3-pink2); width: 16px; text-align: center; }
.footer-bar {
  position: relative; z-index: 1; margin-top: clamp(40px, 6vw, 64px); padding: 22px 0;
  border-top: 1px solid rgba(255, 255, 255, .1);
  display: flex; flex-wrap: wrap; gap: 12px; align-items: center; justify-content: space-between;
}
.footer-bar small { color: rgba(255, 255, 255, .5); font-weight: 600; }
.footer-bar nav { display: flex; gap: 18px; flex-wrap: wrap; }
.footer-bar nav a { color: rgba(255, 255, 255, .6); font-size: .85rem; font-weight: 700; transition: color .2s ease; text-decoration: none; }
.footer-bar nav a:hover { color: #fff; }
