:root {
  --hero-overlap: 88px;

  /* Text */
  --text:        #1D2433;
  --text-muted:  #5B6578;
  --text-soft:   #8E8676;
  --text-bright: #FAF9F7;

  /* Brand */
  --brand-pv:          #97BF0D; /* Photovoltaik */
  --brand-ob:          #15724C; /* Oberflaechentechnik */
  --brand-neutral:     #C8C8C8; /* Neutral */
  --brand-contrast:    #FFFFFF;
  --back-to-top-hover: var(--brand-neutral);

    /* Flächen & Ränder */
  --border-soft:  #E2E0DA;
  --border-strong:#D0D7DE;
  --bg-banner:    #F2F4F2;
  --bg-soft:      #F2F5F7;
  --bg-card:      #FAF9F7;
  --bg-footer:    #2D2D2D;
}

/* Generic site header - energycare logo */
.generic-site-header {
  background: var(--brand-contrast);
  padding: var(--space-4) 0 0;
  margin-bottom: 0;
}
.generic-logo {
  max-width: 220px;  
  height: auto;
  display: block;
  opacity: 0.9;
}
.generic-logo-link {
  display: inline-block;
}
.generic-site-header .container {
  display: flex;
  justify-content: center;
  max-width: 960px;
  margin-inline: auto;
  padding-inline: var(--space-4);
}

/* Legal specific styles */
.page-main.legal-main {
    padding: 0 0 var(--space-4);
  background:
    linear-gradient(to bottom, var(--bg-soft) 0, var(--bg-soft) 60px, var(--brand-contrast) 60px, var(--brand-contrast) 100%);
}
.legal-header {
  max-width: 100%;
  margin: 0;
  /*padding: var(--space-8) var(--space-4) var(--space-4);*/
  padding: var(--space-4) var(--space-4) 0;
  background: var(--bg-banner);
}
.legal-header h1 {
  margin:0 0 var(--space-4);
  font-size: clamp(26px, 3vw, 32px);
  color: var(--text);
}
.legal-content{
  max-width:960px;
  margin:0 auto;
  padding:var(--space-6) var(--space-6);
  text-align:left;
}
.legal-content ul {
  list-style:none; 
  padding-left:var(--space-5);
}
.legal-content ul ul {
  margin-bottom:var(--space-5);
}
.legal-content h2{
  margin-top:var(--space-6);
}
.legal-content h3{
  margin-top:var(--space-4);
}
.legal-content p{
  font-size:15px;
  color:var(--text-muted);
}
.legal-source{
  font-size:13px;
  color:var(--text-soft);
  margin-top:var(--space-4);
}

/* Landing specific styles */

.landing-main {
  display: flex;
  flex-direction: column;
  padding: 0 0 var(--space-4);
  text-align: center;
  background: var(--brand-contrast);
}

.landing-header {
  max-width: 100%;
  margin: 0 0 var(--space-6);
  padding: var(--space-8) var(--space-4) calc(var(--space-9) + var(--hero-overlap));
  background: var(--bg-banner);
}

.landing-header h1 {
  margin-bottom: var(--space-2);
  font-size: clamp(26px, 3vw, 32px);
}

.landing-header h2 {
  margin: 0 auto;
  max-width: 46ch;
  font-size: 18px;
  color: var(--text-muted);
}

/* Karten-Farben pro Bereich */
.card--pv h3 { color: var(--brand-pv); }
.card--ob h3 { color: var(--brand-ob); }

.landing-cards {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  margin: 0 auto var(--space-12);
  max-width: 960px;
  gap: var(--space-5);
  margin-top: calc(-1 * var(--hero-overlap));
  position: relative;
  z-index: 2;
}