/* =========================================
   Kanzlead – LEGAL.CSS (AGB, Datenschutz, Impressum, Cookie-Policy)
   Wrapper: .kl-legal, .datenschutz, .impressum, .cookie-policy
   ========================================= */

/* ---------- Basis & Variablen ---------- */
.kl-legal,
.datenschutz,
.impressum,
.cookie-policy {
  --kl-gold: hsl(42,46%,53%);
  --kl-gold-dark: hsl(42,46%,43%);
  --kl-ivory: hsl(42,45%,96%);
  --kl-ivory-med: hsl(42,45%,90%);
  --kl-text: #2F3336;      /* Anthrazit */
  --kl-muted: #666A6C;     /* Grau */
  --kl-white: #fff;

  --lead-w: 720px;
  --radius: 12px;
  --hairline: 1px solid color-mix(in oklab, var(--kl-gold) 35%, var(--kl-white));

  background: var(--kl-ivory);
  color: var(--kl-text);
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  line-height: 1.65;

  width: 100%;
  max-width: var(--lead-w);
  margin-inline: auto;
  padding: clamp(1.25rem, 2vw, 2rem);
  border-radius: 12px;
  box-shadow: 0 1px 0 rgba(0,0,0,.03), 0 8px 24px rgba(0,0,0,.04);
}

/* ---------- Headings ---------- */
.kl-legal h1, .datenschutz h1, .impressum h1, .cookie-policy h1,
.kl-legal h2, .datenschutz h2, .impressum h2, .cookie-policy h2,
.kl-legal h3, .datenschutz h3, .impressum h3, .cookie-policy h3,
.kl-legal h4, .datenschutz h4, .impressum h4, .cookie-policy h4,
.kl-legal h5, .datenschutz h5, .impressum h5, .cookie-policy h5 {
  font-family: "Outfit", ui-sans-serif, system-ui;
  color: var(--kl-text);
  letter-spacing: .2px;
  margin-top: 0;
}

.kl-legal > h1:first-child,
.datenschutz > h1:first-child,
.impressum > h1:first-child,
.cookie-policy > h1:first-child {
  font-weight: 800;
  font-size: clamp(1.6rem, 2.4vw, 2.1rem);
  line-height: 1.2;
  margin: 0 0 .25rem 0;
}

/* h2 mit goldener Leiste links */
.kl-legal h2, .datenschutz h2, .impressum h2, .cookie-policy h2 {
  font-weight: 700;
  font-size: clamp(1.15rem, 1.7vw, 1.35rem);
  margin: 1.75rem 0 .75rem;
  position: relative;
  padding-left: .9rem;
}
.kl-legal h2::before, .datenschutz h2::before, .impressum h2::before, .cookie-policy h2::before {
  content: "";
  position: absolute;
  left: 0; top: .2em; bottom: .2em;
  width: 4px; border-radius: 2px; background: var(--kl-gold);
}

.kl-legal h3, .datenschutz h3, .impressum h3, .cookie-policy h3 {
  font-weight: 600;
  font-size: clamp(1.05rem, 1.5vw, 1.2rem);
  margin: 1.25rem 0 .5rem;
}
.kl-legal h4, .kl-legal h5,
.datenschutz h4, .datenschutz h5,
.impressum h4, .impressum h5,
.cookie-policy h4, .cookie-policy h5 {
  font-weight: 600; font-size: 1rem; margin: 1rem 0 .4rem;
}

/* ---------- Text, Listen, Betonungen ---------- */
.kl-legal p, .datenschutz p, .impressum p, .cookie-policy p { margin: 0 0 1rem; }
.kl-legal p + p, .datenschutz p + p, .impressum p + p, .cookie-policy p + p { margin-top: .3rem; }
.kl-legal strong, .datenschutz strong, .impressum strong, .cookie-policy strong { font-weight: 700; }
.kl-legal em, .datenschutz em, .impressum em, .cookie-policy em { font-style: italic; }

.kl-legal ul, .kl-legal ol,
.datenschutz ul, .datenschutz ol,
.impressum ul, .impressum ol,
.cookie-policy ul, .cookie-policy ol { margin: .25rem 0 1rem 1.25rem; padding: 0; }
.kl-legal li, .datenschutz li, .impressum li, .cookie-policy li { margin: .35rem 0; }
.kl-legal li::marker, .datenschutz li::marker, .impressum li::marker, .cookie-policy li::marker { color: var(--kl-gold); }
.kl-legal li > ul, .kl-legal li > ol,
.datenschutz li > ul, .datenschutz li > ol,
.impressum li > ul, .impressum li > ol,
.cookie-policy li > ul, .cookie-policy li > ol { margin-top: .35rem; margin-bottom: .35rem; }

/* ---------- Links (Boutique-Hover, kein Blau) ---------- */
.kl-legal a, .kl-legal a:link, .kl-legal a:visited,
.datenschutz a, .datenschutz a:link, .datenschutz a:visited,
.impressum a, .impressum a:link, .impressum a:visited,
.cookie-policy a, .cookie-policy a:link, .cookie-policy a:visited {
  color: var(--kl-text) !important;
  text-decoration: none;
  border-bottom: 1px dotted rgba(0,0,0,.25);
  transition: color .25s ease, border-color .25s ease, background .25s ease;
  position: relative;
}
.kl-legal a:hover, .kl-legal a:focus, .kl-legal a:active,
.datenschutz a:hover, .datenschutz a:focus, .datenschutz a:active,
.impressum a:hover, .impressum a:focus, .impressum a:active,
.cookie-policy a:hover, .cookie-policy a:focus, .cookie-policy a:active {
  color: var(--kl-gold) !important;
  border-bottom-color: var(--kl-gold);
  outline: none;
}
.kl-legal a::after, .datenschutz a::after, .impressum a::after, .cookie-policy a::after {
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background: var(--kl-gold); transition: width .25s ease;
}
.kl-legal a:hover::after, .kl-legal a:focus::after,
.datenschutz a:hover::after, .datenschutz a:focus::after,
.impressum a:hover::after, .impressum a:focus::after,
.cookie-policy a:hover::after, .cookie-policy a:focus::after { width: 100%; }

/* ---------- Info-Boxen ---------- */
.kl-legal .box, .datenschutz .box, .impressum .box, .cookie-policy .box {
  background: var(--kl-ivory);
  border: 1px solid var(--kl-ivory-med);
  border-left: 4px solid var(--kl-gold);
  padding: 1rem; border-radius: var(--radius); margin: 1rem 0;
}

/* ---------- Tabellen (klassisch) ---------- */
.kl-legal table, .datenschutz table, .impressum table, .cookie-policy table {
  width: 100%;
  border-collapse: collapse;
  background: var(--kl-white);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 8px;
  overflow: hidden;
  margin: 1rem 0;
  font-size: .95rem;
}
.kl-legal th, .kl-legal td,
.datenschutz th, .datenschutz td,
.impressum th, .impressum td,
.cookie-policy th, .cookie-policy td {
  padding: .75rem .9rem;
  border-bottom: 1px solid var(--kl-ivory-med);
  vertical-align: top;
}
.kl-legal th, .datenschutz th, .impressum th, .cookie-policy th {
  text-align: left;
  background: rgba(0,0,0,.02);
  font-weight: 600; color: var(--kl-text);
}

/* ---------- Code/Pre & Zitate ---------- */
.kl-legal code, .kl-legal pre,
.datenschutz code, .datenschutz pre,
.impressum code, .impressum pre,
.cookie-policy code, .cookie-policy pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: .925rem;
  background: var(--kl-ivory);
  border: 1px solid var(--kl-ivory-med);
  border-radius: 8px;
}
.kl-legal code, .datenschutz code, .impressum code, .cookie-policy code { padding: .1rem .35rem; }
.kl-legal pre,  .datenschutz pre,  .impressum pre,  .cookie-policy pre  { padding: .75rem; overflow-x: auto; }

.kl-legal blockquote, .datenschutz blockquote, .impressum blockquote, .cookie-policy blockquote {
  margin: 1rem 0; padding: .75rem 1rem;
  border-left: 4px solid var(--kl-gold);
  background: var(--kl-ivory);
  border-radius: var(--radius);
  color: var(--kl-text);
}

/* ---------- Cookie-Policy – Grid.js (Real Cookie Banner) ---------- */
/* Flex-Eltern zähmen, Wrapper bleibt 720px */
.brxe-section.flex .cookie-policy,
.brxe-container.flex .cookie-policy,
.brxe-shortcode.flex .cookie-policy {
  max-width: var(--lead-w) !important;
  align-self: center;
}
.cookie-policy { overflow-x: visible; }

/* Grid.js-Container darf schrumpfen, scrollt bei Bedarf horizontal */
.cookie-policy .gridjs-container,
.cookie-policy .gridjs-wrapper {
  min-width: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* Tabelle selbst: volle Breite im Wrapper, harte Umbrüche */
.cookie-policy .gridjs-table {
  width: 100% !important;
  table-layout: fixed !important;
  border-collapse: collapse;
}

/* Spalten: keine Inline-Widths, sauber umbrechen */
.cookie-policy .gridjs-th,
.cookie-policy .gridjs-td {
  width: auto !important;
  white-space: normal !important;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
  hyphens: auto;
  padding: .6rem .75rem;
  border-bottom: 1px solid var(--kl-ivory-med);
  color: var(--kl-text);
  vertical-align: top;
}

/* Kopfzeile hübsch & sticky */
.cookie-policy .gridjs-th {
  position: sticky; top: 0; z-index: 1;
  background: color-mix(in oklab, var(--kl-ivory) 70%, #fff);
  font-weight: 600; text-align: left;
}

/* Zebra + Hover */
.cookie-policy .gridjs-tr:nth-child(even) .gridjs-td {
  background: color-mix(in oklab, var(--kl-ivory) 40%, #fff);
}
.cookie-policy .gridjs-tr:hover .gridjs-td {
  background: color-mix(in oklab, var(--kl-ivory) 60%, #fff);
}

/* Links in Zellen */
.cookie-policy .gridjs-td a {
  color: var(--kl-text) !important;
  text-decoration: none;
  border-bottom: 1px dotted rgba(0,0,0,.25);
  position: relative;
  transition: color .2s, border-color .2s;
}
.cookie-policy .gridjs-td a:hover {
  color: var(--kl-gold) !important;
  border-bottom-color: var(--kl-gold);
}
.cookie-policy .gridjs-td a::after {
  content:""; position:absolute; left:0; bottom:-2px;
  width:0; height:2px; background: var(--kl-gold); transition: width .2s;
}
.cookie-policy .gridjs-td a:hover::after { width: 100%; }

/* Kopf-/Fußbereiche von Grid.js */
.cookie-policy .gridjs-head,
.cookie-policy .gridjs-footer {
  padding: .5rem .5rem;
  color: var(--kl-muted);
  background: var(--kl-ivory);
  border-bottom: 1px solid var(--kl-ivory-med);
}
.cookie-policy .gridjs-footer { border-top: 1px solid var(--kl-ivory-med); border-bottom: 0; }

/* Pagination */
.cookie-policy .gridjs-pages button {
  background: #fff;
  border: 1px solid var(--kl-ivory-med);
  padding: .35rem .6rem;
  border-radius: 6px;
  margin-right: .35rem;
  color: var(--kl-text);
  cursor: pointer;
  transition: border-color .2s, color .2s;
}
.cookie-policy .gridjs-pages button:hover { border-color: var(--kl-gold); color: var(--kl-gold); }
.cookie-policy .gridjs-pages .gridjs-currentPage {
  background: var(--kl-ivory);
  border-color: var(--kl-gold);
  color: var(--kl-gold);
}

/* ---------- Responsive ---------- */
@media (max-width: 640px) {
  .kl-legal, .datenschutz, .impressum, .cookie-policy { padding: 1rem; }
  .kl-legal > h1:first-child, .datenschutz > h1:first-child, .impressum > h1:first-child, .cookie-policy > h1:first-child { font-size: 1.35rem; }
  .kl-legal h2, .datenschutz h2, .impressum h2, .cookie-policy h2 { font-size: 1.1rem; }
}
@media (max-width: 1024px) {
  .cookie-policy .gridjs-th, .cookie-policy .gridjs-td { padding: .5rem .6rem; font-size: .9rem; }
}
@media (max-width: 480px) {
  .cookie-policy .gridjs-th, .cookie-policy .gridjs-td { padding: .45rem .5rem; font-size: .88rem; }
}

/* ---------- Print ---------- */
@media print {
  .kl-legal, .datenschutz, .impressum, .cookie-policy {
    box-shadow: none; background: #fff; color: #000;
    padding: 0; max-width: 100%;
  }
  .kl-legal h2::before, .datenschutz h2::before, .impressum h2::before, .cookie-policy h2::before { background: #000; }
  .kl-legal a, .kl-legal a:visited,
  .datenschutz a, .datenschutz a:visited,
  .impressum a, .impressum a:visited,
  .cookie-policy a, .cookie-policy a:visited {
    color: #000 !important; border-bottom: 1px solid #000;
  }
  .kl-legal a::after, .datenschutz a::after, .impressum a::after, .cookie-policy a::after { display: none; }
}
