/* ============================================================
   Herodeals – Legal Pages (legal.css)
   Layout for Impressum, Datenschutz, AGB.
   Requires: tokens.css  components.css
   ============================================================ */

/* ── PAGE LAYOUT ── */
.legal-page {
  padding-top: var(--nav-height);
  min-height:  100vh;
}

.legal-container {
  max-width: 860px;
  margin:    0 auto;
  padding:   var(--sp-24) var(--page-gutter) var(--sp-25);
}

/* ── BREADCRUMB ── */
.legal-breadcrumb {
  display:       flex;
  align-items:   center;
  gap:           var(--sp-2);
  font-size:     var(--text-xs);
  color:         var(--color-muted);
  margin-bottom: var(--sp-8);
}

.legal-breadcrumb a {
  color:           var(--color-accent);
  text-decoration: none;
  transition:      color var(--t-base);
}

.legal-breadcrumb a:hover { color: var(--color-accent-h); }

/* ── HEADER ── */
.legal-header {
  margin-bottom: var(--sp-10);
}

.legal-title {
  font-size:      clamp(2rem, 4vw, 3rem);
  font-weight:    var(--fw-black);
  letter-spacing: -0.5px;
  line-height:    1.15;
  margin-top:     var(--sp-2);
}

/* ── TABLE OF CONTENTS ── */
.legal-toc {
  background:    var(--color-surface-1);
  border:        1px solid var(--color-border);
  border-left:   3px solid var(--color-accent);
  border-radius: var(--radius-lg);
  padding:       var(--sp-6) var(--sp-8);
  margin-bottom: var(--sp-12);
}

.legal-toc-title {
  font-size:      var(--text-xs);
  font-weight:    var(--fw-black);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color:          var(--color-accent);
  margin-bottom:  var(--sp-4);
}

.legal-toc-list {
  list-style:     none;
  display:        flex;
  flex-direction: column;
  gap:            var(--sp-2);
  padding:        0;
}

.legal-toc-list > li {
  font-size:   var(--text-sm);
  font-weight: var(--fw-semi);
}

.legal-toc-list > li > a {
  color:           var(--color-text);
  text-decoration: none;
  transition:      color var(--t-base);
}

.legal-toc-list > li > a:hover { color: var(--color-accent); }

/* Nested items */
.legal-toc-list ol {
  list-style: none;
  padding:    0;
  margin:     var(--sp-2) 0 0 var(--sp-5);
  display:    flex;
  flex-direction: column;
  gap:        var(--sp-1);
}

.legal-toc-list ol li {
  font-size:   var(--text-xs);
  font-weight: var(--fw-regular);
}

.legal-toc-list ol li a {
  color:           var(--color-muted);
  text-decoration: none;
  transition:      color var(--t-base);
}

.legal-toc-list ol li a:hover { color: var(--color-text); }

/* ── LEGAL CONTENT ── */
.legal-content {
  display:        flex;
  flex-direction: column;
  gap:            var(--sp-5);
}

/* ── LEGAL CARD ── */
.legal-card {
  background:    var(--color-surface-1);
  border:        1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding:       var(--sp-8) var(--sp-10);
  transition:    border-color var(--t-base);
}

.legal-card:hover {
  border-color: rgba(232, 160, 32, 0.18);
}

.legal-card h2 {
  font-size:      1.1rem;
  font-weight:    var(--fw-bold);
  color:          var(--color-text);
  margin-bottom:  var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom:  1px solid var(--color-border);
  scroll-margin-top: calc(var(--nav-height) + var(--sp-5));
}

.legal-card h3 {
  font-size:         var(--text-sm);
  font-weight:       var(--fw-bold);
  color:             var(--color-text);
  margin-top:        var(--sp-6);
  margin-bottom:     var(--sp-3);
  scroll-margin-top: calc(var(--nav-height) + var(--sp-5));
}

.legal-card p {
  font-size:     var(--text-sm);
  color:         var(--color-muted);
  line-height:   1.8;
  margin-bottom: var(--sp-4);
}

.legal-card p:last-child { margin-bottom: 0; }

.legal-card a {
  color:           var(--color-accent);
  text-decoration: none;
  font-weight:     var(--fw-medium);
  transition:      color var(--t-base);
}

.legal-card a:hover {
  color:           var(--color-accent-h);
  text-decoration: underline;
}

.legal-card address {
  font-style:    normal;
  font-size:     var(--text-sm);
  color:         var(--color-muted);
  line-height:   1.8;
  margin-bottom: var(--sp-4);
}

.legal-card ul,
.legal-card ol {
  padding-left:  var(--sp-6);
  margin-bottom: var(--sp-4);
}

.legal-card li {
  font-size:     var(--text-sm);
  color:         var(--color-muted);
  line-height:   1.8;
  margin-bottom: var(--sp-2);
}

.legal-card li:last-child { margin-bottom: 0; }

.legal-card ul ul,
.legal-card ol ol {
  margin-top:    var(--sp-2);
  margin-bottom: 0;
}

/* ── HIGHLIGHT BOX ── */
.legal-highlight-box {
  background:    var(--color-surface-2);
  border:        1px solid var(--color-accent-border);
  border-left:   3px solid var(--color-accent);
  border-radius: var(--radius-md);
  padding:       var(--sp-5) var(--sp-6);
  margin:        var(--sp-5) 0 var(--sp-4);
}

.legal-highlight-box p {
  margin-bottom: var(--sp-3);
}

.legal-highlight-box p:last-child { margin-bottom: 0; }

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .legal-container { padding: var(--sp-16) 5% var(--sp-24); }
  .legal-card      { padding: var(--sp-6); }
  .legal-toc       { padding: var(--sp-5) var(--sp-6); }
}
