/* ============================================================
   DATENSCHUTZ.CSS
   Page-specific styles for the Privacy Policy page
   ============================================================ */

/* --- Hero --- */
.legal-hero {
  padding: var(--space-4xl) 0 var(--space-3xl);
  background: linear-gradient(165deg, var(--color-bg-cool) 0%, var(--color-bg) 50%, var(--color-primary-light) 100%);
  position: relative;
  overflow: hidden;
}
.legal-hero::before {
  content: '';
  position: absolute;
  top: -60%;
  right: -20%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(15,107,94,0.06) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.legal-hero .container {
  position: relative;
  z-index: 1;
}
.legal-hero h1 {
  max-width: 600px;
  margin-bottom: var(--space-lg);
}
.legal-hero-subtitle {
  font-size: 1.125rem;
  max-width: 600px;
  color: var(--color-text-secondary);
  line-height: 1.7;
}

/* --- Content --- */
.legal-content {
  padding: var(--space-4xl) 0;
  background: var(--color-bg);
}

/* --- Table of Contents --- */
.legal-toc {
  background: var(--color-bg-cool);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  margin-bottom: var(--space-3xl);
}
.legal-toc h2 {
  font-size: 1.125rem;
  margin-bottom: var(--space-md);
}
.legal-toc ol {
  list-style: decimal;
  padding-left: 1.5rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xs) var(--space-2xl);
}
.legal-toc li {
  font-size: 0.9375rem;
  line-height: 1.8;
}
.legal-toc a {
  color: var(--color-primary);
  transition: color var(--transition-fast);
}
.legal-toc a:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

@media (max-width: 768px) {
  .legal-toc ol {
    grid-template-columns: 1fr;
  }
}

/* --- Legal Blocks --- */
.legal-block {
  margin-bottom: var(--space-3xl);
  padding-bottom: var(--space-3xl);
  border-bottom: 1px solid var(--color-border-light);
}
.legal-block:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}
.legal-block h2 {
  margin-bottom: var(--space-lg);
  font-size: clamp(1.25rem, 2.5vw, 1.625rem);
}
.legal-block h3 {
  margin-top: var(--space-xl);
  margin-bottom: var(--space-sm);
  font-size: clamp(1.0625rem, 2vw, 1.25rem);
}
.legal-block p {
  font-size: 0.9375rem;
  color: var(--color-text-secondary);
  line-height: 1.8;
}
.legal-block a {
  color: var(--color-primary);
  transition: color var(--transition-fast);
}
.legal-block a:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

/* Lists */
.legal-block ul {
  list-style: none;
  margin: var(--space-md) 0;
  padding: 0;
}
.legal-block ul li {
  position: relative;
  padding-left: 1.5rem;
  margin-bottom: var(--space-sm);
  font-size: 0.9375rem;
  color: var(--color-text-secondary);
  line-height: 1.75;
}
.legal-block ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: var(--color-primary);
  opacity: 0.5;
}
.legal-block ul li strong {
  color: var(--color-text);
}

/* Address block */
.legal-address {
  background: var(--color-bg-cool);
  border-left: 3px solid var(--color-primary);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: var(--space-lg);
  margin: var(--space-md) 0;
}
.legal-address p {
  margin-bottom: var(--space-sm);
}
.legal-address p:last-child {
  margin-bottom: 0;
}
.legal-address a {
  color: var(--color-primary);
  font-weight: 500;
}

/* Highlight box (Widerspruchsrecht) */
.legal-highlight {
  background: var(--color-primary-light);
  border: 1px solid rgba(15,107,94,0.2);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  margin-top: var(--space-md);
}
.legal-highlight p {
  color: var(--color-text);
}
.legal-highlight a {
  color: var(--color-primary);
  font-weight: 600;
}

/* --- Responsive --- */
@media (max-width: 768px) {
  .legal-block {
    margin-bottom: var(--space-2xl);
    padding-bottom: var(--space-2xl);
  }
}
