.elementor-theme-builder-content-area{height:400px;}.elementor-location-header:before, .elementor-location-footer:before{content:"";display:table;clear:both;}/* Start custom CSS for html, class: .elementor-element-8daf4be */@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600&family=Lato:wght@300;400;700&display=swap');

:root {
  --ps-bg:     #c5d4b8;   /* aufgehellt von #9CAF88 */
  --ps-dark:   #2b3028;
  --ps-hover:  #635077;
  --ps-text:   rgba(43,48,40,0.75);
  --ps-muted:  rgba(43,48,40,0.55);
  --ps-border: rgba(43,48,40,0.14);
}

/* ── WRAPPER ── */
.ps-footer {
  background: var(--ps-bg);
  font-family: 'Lato', sans-serif;
  color: var(--ps-dark);
  padding: 0;
  width: 100%;
  box-sizing: border-box;
}

/* ── ACCENT BAR ── */
.ps-footer__accent {
  height: 4px;
  background: linear-gradient(90deg, var(--ps-dark) 0%, var(--ps-hover) 60%, transparent 100%);
}

/* ── OBERE ZEILE: 3 Spalten – Breite passt sich dem Inhalt an ── */
.ps-footer__top {
  display: flex;
  justify-content: center; gap: 0;
  align-items: flex-start;
  gap: 0;
  width: 100%;
  padding: 36px 24px 32px;
  box-sizing: border-box;
}

.ps-footer__vdivider {
  width: 1px;
  background: var(--ps-border);
  align-self: stretch;
  margin: 0 40px;
  flex-shrink: 0;
}

/* ── COLUMNS – nur so breit wie nötig ── */
.ps-footer__col {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  flex-shrink: 0;
}

/* ── ICON CIRCLE ── */
.ps-footer__icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  border-radius: 50%;
  border: 1.5px solid var(--ps-dark);
  display: flex;
  align-items: center;
  justify-content: center; gap: 0;
  margin-bottom: 14px;
  flex-shrink: 0;
  transition: background 0.3s, border-color 0.3s, transform 0.3s;
}

.ps-footer__col:hover .ps-footer__icon {
  background: var(--ps-hover);
  border-color: var(--ps-hover);
  transform: translateY(-2px);
}

.ps-footer__col:hover .ps-footer__icon svg {
  stroke: #fff !important;
}

/* ── HEADING ── */
.ps-footer__heading {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--ps-dark);
  margin: 0 0 10px;
  line-height: 1.4;
  transition: color 0.25s;
}

.ps-footer__col:hover .ps-footer__heading {
  color: var(--ps-hover);
}

/* ── BODY TEXT ── */
.ps-footer__body {
  font-size: 0.875rem;
  font-weight: 400;  /* war 300 */
  color: var(--ps-text);
  line-height: 1.8;
  margin: 0;
  max-width: 280px;
}

/* ── HOURS ── */
.ps-footer__hours { width: 100%; margin-top: 4px; }

.ps-footer__hours-row {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  padding: 5px 0;
  border-bottom: 1px solid var(--ps-border);
  font-size: 0.82rem;
  color: var(--ps-text);
}

.ps-footer__hours-row:last-child { border-bottom: none; }

.ps-footer__hours-day {
  font-weight: 700;
  color: var(--ps-dark);
  white-space: nowrap;
}

.ps-footer__hours-time {
  white-space: nowrap;
  font-weight: 400;  /* war implizit 300 */
}

/* ── BADGE ── */
.ps-footer__badge {
  display: inline-block;
  margin-top: 12px;
  padding: 4px 12px;
  background: rgba(43,48,40,0.10);
  font-size: 0.70rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ps-dark);
  border-left: 2px solid var(--ps-dark);
  transition: border-color 0.25s, color 0.25s;
}

.ps-footer__col:hover .ps-footer__badge {
  border-color: var(--ps-hover);
  color: var(--ps-hover);
}

/* ── LINKS ── */
.ps-footer__link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--ps-text);
  text-decoration: none;
  font-size: 0.85rem;
  font-weight: 400;  /* war 300 */
  transition: color 0.25s;
}

.ps-footer__link:hover { color: var(--ps-hover); }

/* ── BUTTON ── */
.ps-footer__email-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  background: transparent;
  border: 1.5px solid var(--ps-dark);
  color: var(--ps-dark);
  font-family: 'Lato', sans-serif;
  font-size: 0.73rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.3s, color 0.3s, border-color 0.3s, transform 0.25s;
}

.ps-footer__email-btn:hover {
  background: var(--ps-hover);
  border-color: var(--ps-hover);
  color: #fff;
  transform: translateY(-2px);
}

/* ── UNTERE ZEILE: Info-Bar ── */
.ps-footer__infobar {
  border-top: 1px solid var(--ps-border);
  padding: 18px 24px 24px;
  box-sizing: border-box;
}

.ps-footer__infobar-inner {
  display: flex;
  align-items: center;
  gap: 0;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}

.ps-footer__infobar-label {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  padding-right: 20px;
  border-right: 1px solid var(--ps-border);
  min-width: 0;
}

.ps-footer__infobar-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  flex: 1;
}

/* ── INFO ROWS ── */
.ps-info-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 6px 0;
}

.ps-info-row--inline {
  border-bottom: none;
  border-right: 1px solid var(--ps-border);
  padding: 0 20px;
  align-items: flex-start;
}

.ps-info-row--inline:first-child { padding-left: 20px; }

.ps-info-row:hover .ps-info-title    { color: var(--ps-hover); }
.ps-info-row:hover .ps-info-icon     { background: var(--ps-hover); }
.ps-info-row:hover .ps-info-icon svg { stroke: #fff !important; }

.ps-info-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  min-width: 18px;
  min-height: 18px;
  max-width: 18px;
  max-height: 18px;
  border-radius: 50%;
  background: rgba(43,48,40,0.12);
  display: flex;
  align-items: center;
  justify-content: center; gap: 0;
  margin-top: 2px;
  transition: background 0.25s;
}

.ps-info-title {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ps-dark);
  margin: 0 0 3px;
  font-family: 'Lato', sans-serif;
  transition: color 0.25s;
}

.ps-info-sub {
  font-size: 0.75rem;
  font-weight: 400;  /* war 300 */
  color: var(--ps-muted);
  margin: 0;
  line-height: 1.6;
  font-family: 'Lato', sans-serif;
}

/* ── BOTTOM BAR ── */
.ps-footer__bottom {
  width: 100%;
  padding: 16px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  box-sizing: border-box;
}

.ps-footer__copy {
  font-size: 0.72rem;
  font-weight: 400;  /* war 300 */
  color: rgba(43,48,40,0.45);
  letter-spacing: 0.04em;
}

.ps-footer__dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--ps-dark);
  flex-shrink: 0;
}

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .ps-footer__top {
    flex-wrap: wrap;
    gap: 28px;
    padding: 32px 24px 28px;
  }

  .ps-footer__vdivider { display: none; }

  .ps-footer__col {
    width: calc(50% - 14px);
  }

  .ps-footer__infobar {
    padding: 16px 24px 24px;
  }

  .ps-footer__infobar-inner {
    flex-direction: column;
    gap: 16px;
  }

  .ps-footer__infobar-label {
    border-right: none;
    border-bottom: 1px solid var(--ps-border);
    padding: 0 0 14px;
    width: 100%;
  }

  .ps-footer__infobar-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }

  .ps-info-row--inline {
    border-right: none;
    padding: 0;
  }
}

@media (max-width: 560px) {
  .ps-footer__top {
    flex-direction: column;
    padding: 28px 20px 24px;
  }

  .ps-footer__col {
    width: 100%;
    border-bottom: 1px solid var(--ps-border);
    padding-bottom: 24px;
  }

  .ps-footer__col:last-child {
    border-bottom: none;
    padding-bottom: 0;
  }

  .ps-footer__infobar-grid {
    grid-template-columns: 1fr;
  }

  .ps-footer__bottom {
    flex-direction: column;
    text-align: center;
    gap: 6px;
    padding: 14px 0;
  }

  .ps-footer__dot { display: none; }
}

/* ── INFOBAR LABEL HOVER ── */
.ps-footer__infobar-label:hover .ps-footer__heading {
  color: var(--ps-hover);
}

.ps-footer__infobar-label:hover .ps-footer__icon {
  background: var(--ps-hover);
  border-color: var(--ps-hover);
  transform: translateY(-2px);
}

.ps-footer__infobar-label:hover .ps-footer__icon svg {
  stroke: #fff !important;
}/* End custom CSS */