/* ===========================================================================
   Lexlane Design System — global entry point.
   Consumers link THIS file only. Keep it as @import lines (no rules here).
   ===========================================================================*/

@import url('./tokens/fonts.css');
@import url('./tokens/colors.css');
@import url('./tokens/typography.css');
@import url('./tokens/spacing.css');
@import url('./tokens/effects.css');
@import url('./tokens/base.css');

/* Story-Sektion (Team-Seite): zwei Spalten am Desktop, gestapelt mobil. */
@media (max-width: 768px) {
  .lx-story-grid { grid-template-columns: 1fr !important; }
  .lx-3p-grid { grid-template-columns: 1fr !important; }
  .lx-pricealt-grid { grid-template-columns: 1fr !important; }
}

@media (max-width: 1000px) {
  .lx-docs-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 560px) {
  .lx-docs-grid { grid-template-columns: 1fr !important; }
}

/* TrustDeep — Linien-Stil. Sticky Header links, Sektionen mit stapelndem Titel rechts.
   Beim Scrollen bleiben die Sektionstitel oben stehen und stapeln sich untereinander
   (durch dünne Linien getrennt); die eingerückten Sub-Bullets scrollen darunter weg
   und werden vom opaken Titel-Hintergrund verdeckt. Der klebende Titel-Stack (top-Offset
   pro Sektion) wird inline in TrustDeep.jsx gesetzt. */
.lx-td-head { position: sticky; top: 96px; }

/* Klebender Sektionstitel — Box exakt so hoch wie der Staffelabstand (120px) und opak,
   damit die gestapelten Titel lückenlos übereinander liegen (kein Durchscheinen der
   dahinter wegscrollenden Bullets). Linie zwischen den Titeln. */
.lx-td-sectitle {
  position: sticky; z-index: 2;
  min-height: 120px;
  display: flex; align-items: center;
  margin: 0; padding: 0;
  background: var(--green-950);
  border-top: 1px solid var(--border-on-brand);
}
.lx-td-sectitle:first-of-type { border-top: none; }

/* Opake Abdeckung oberhalb des ersten klebenden Titels: verhindert, dass
   hochscrollende Bullets im Spalt unter bzw. hinter dem transluzenten Header
   durchscheinen. Die Sektion clippt den Überstand (overflow: clip, inline). */
.lx-td-sectitle:first-of-type::before {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 100%;
  height: 140px;
  background: var(--green-950);
}

/* Sub-Bullets: etwas eingerückt, mit eingerückter Trennlinie */
.lx-td-items { margin-left: clamp(0px, 1.6vw, 22px); }
.lx-td-item { padding: clamp(16px, 1.7vw, 20px) 0; }

@media (max-width: 860px) {
  .lx-td-grid { grid-template-columns: 1fr !important; }
  .lx-td-head { position: static !important; }
  .lx-td-sectitle { position: static !important; top: auto !important; min-height: auto; display: block; padding: 22px 0 14px; }
  .lx-td-sectitle:first-of-type::before { display: none; }
}

/* Legal-Seiten (Datenschutz, Nutzungsbedingungen) — lesbare Prosa */
.lx-legal-prose > :first-child { margin-top: 0; }
.lx-legal-prose h2 {
  font-family: var(--font-serif); font-weight: 500;
  font-size: clamp(22px, 2.6vw, 30px); letter-spacing: -0.015em;
  color: var(--text-strong); line-height: 1.2;
  margin: clamp(44px, 5vw, 68px) 0 0;
}
.lx-legal-prose h3 {
  font-family: var(--font-serif); font-weight: 500;
  font-size: clamp(18px, 2vw, 22px); letter-spacing: -0.01em;
  color: var(--text-strong); line-height: 1.25;
  margin: clamp(28px, 3vw, 40px) 0 0;
}
.lx-legal-prose h2 + p, .lx-legal-prose h3 + p,
.lx-legal-prose h2 + h3 { margin-top: 14px; }
.lx-legal-prose p {
  font-family: var(--font-ui); font-size: var(--text-md); line-height: 1.7;
  color: var(--text-body); margin: 14px 0 0;
}
.lx-legal-prose ul {
  margin: 14px 0 0; padding-left: 1.3em;
  font-family: var(--font-ui); font-size: var(--text-md); line-height: 1.7; color: var(--text-body);
}
.lx-legal-prose li { margin: 7px 0 0; }
.lx-legal-prose strong { font-weight: 700; color: var(--text-strong); }
.lx-legal-prose a { color: var(--text-link); text-decoration: underline; overflow-wrap: anywhere; }
.lx-legal-prose hr {
  border: none; border-top: 1px solid var(--border-default);
  margin: clamp(36px, 4vw, 56px) 0 0;
}
