/* ===== LEGAL.CSS - NUR Farben & minimale Overrides ===== */

/* Divider mit Farbverlauf */
.legal-divider{
  width: 100%;
  height: 0px;
  margin: 0;
  background:
    radial-gradient(800px 260px at 20% 0%, rgba(255,212,0,.18), transparent 55%),
    radial-gradient(820px 260px at 90% 100%, rgba(255,46,166,.14), transparent 58%),
    #fff;
  border-top: 1px solid rgba(10,10,20,.10);
  border-bottom: 1px solid rgba(10,10,20,.10);
}

/* Content-Bereich mit Farbverlauf */
.legal-content{
  width: 100%;
  padding: 2.5rem 0 5rem;
  background:
    radial-gradient(800px 260px at 20% 0%, rgba(255,212,0,.18), transparent 55%),
    radial-gradient(820px 260px at 90% 100%, rgba(255,46,166,.14), transparent 58%),
    #fff;
}

/* Überschriften-Trenner */
.legal-section h2::after{
  position:absolute;
  left:0;
  bottom:0;
  width:100%;
  height:2px;
  border-radius:2px;
  background: linear-gradient(90deg, #ff00cc, #7a00ff, transparent);
  opacity: .9;
}

/* Fix: Impressum nicht zentrieren (überschreibt styles.css) */
.legal-layout .impressum{
  max-width: 100% !important;
  margin: 0 !important;
}

/* Fix: Container braucht Padding auf Legal-Seiten */
.legal .container{
  padding: 0 1.5rem !important;
}


/* Mobile Responsive */
@media (max-width: 640px){
  .legal .container{
    padding: 0 1rem !important;
  }
  
  .legal .hero{
    padding: 2rem 0 1rem;
  }
  
  .legal .hero-inner{
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  
  .legal .hero h1{
    font-size: 1.8rem;
    line-height: 1.2;
  }
  
  .legal .hero .lead{
    font-size: 0.95rem;
  }
  
  .legal .legal-content{
    padding: 1.5rem 0 2.5rem;

  }
  .nav.is-open{
	display:flex;
	position: absolute;
	top: 58px;
	right: 16px;
	left: 16px;
	flex-direction: column;
	background:#fff;
	border: 1px solid var(--line);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 10px;
	box-shadow: var(--shadow);
}
.impressum,
.datenschutz{
  width: min(var(--container), calc(100% - 32px));
  margin-inline: auto;
}
