/* ============================================================
   FOOTER CTA
   ============================================================ */
.footer-cta {
  background: var(--blue-primary);
  padding: 60px 0;
  margin-top: 0;
}
.footer-cta__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
}
.footer-cta__text { flex: 1; min-width: 240px; }
.footer-cta__title { font-size: clamp(1.5rem,2.5vw,2rem); color: var(--white); margin-bottom: 8px; }
.footer-cta__text p { color: rgba(255,255,255,0.85); font-size: 1.05rem; }
.footer-cta__actions { display:flex; gap:16px; flex-wrap:wrap; }

/* ============================================================
   FOOTER MAIN
   ============================================================ */
.footer-main {
  background: var(--wst-navy-dark);
  padding: 64px 0 48px;
}
.footer-main__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
}
.footer-col--brand { }
.footer-logo { display:inline-block; margin-bottom:16px; }
.footer-logo img { height: 44px; }
.footer-tagline {
  color: rgba(255,255,255,0.6);
  font-size: 0.9rem;
  margin-bottom: 24px;
  line-height: 1.6;
}
.footer-address {
  color: rgba(255,255,255,0.7);
  font-size: 1rem;
  line-height: 1.8;
  font-style: normal;
  margin-bottom: 20px;
}
.footer-contact-items { display:flex; flex-direction:column; gap:8px; }
.footer-contact-item {
  display: flex;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,0.7);
  font-size: 0.875rem;
  transition: color var(--trans);
}
.footer-contact-item:hover { color: var(--blue-primary); }
.footer-contact-item .icon { color: var(--blue-primary); }

.footer-col__title {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.4);
  margin-bottom: 20px;
}
.footer-col__list { display:flex; flex-direction:column; gap:8px; }
.footer-col__list a {
  color: rgba(255,255,255,0.7);
  font-size: 0.875rem;
  transition: color var(--trans);
  line-height: 1.5;
}
.footer-col__list a:hover { color: var(--blue-primary); }

/* ============================================================
   FOOTER BOTTOM
   ============================================================ */
.footer-bottom {
  background: var(--wst-navy-dark);
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 20px 0;
}
.footer-bottom__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  gap: 24px;
}
.footer-copyright { color: rgba(255,255,255,0.4); font-size: 0.82rem; margin: 0; line-height: 1; }
.footer-legal-nav { display:flex; gap:24px; }
.footer-legal-nav a { color: rgba(255,255,255,0.5); font-size:0.82rem; transition:color var(--trans); }
.footer-legal-nav a:hover { color: var(--white); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .footer-main__grid { grid-template-columns: 1fr 1fr; }
  .footer-col--brand { grid-column: span 2; }
}
@media (max-width: 640px) {
  .footer-main__grid { grid-template-columns: 1fr; }
  .footer-col--brand { grid-column: span 1; }
  .footer-cta__inner { flex-direction: column; align-items: flex-start; }
  .footer-bottom__inner { flex-direction: column; align-items: flex-start; }
  .footer-legal-nav { flex-wrap: wrap; gap: 16px; }
}

/* ── Social Icons ─────────────────────────────────────────── */
.footer-social {
    background: var(--wst-navy-dark);
    padding: 20px 0 25px;
    border-top: 1px solid rgba(255,255,255,0.08);
}
.footer-social__inner {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
}
.footer-social__link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.6);
    transition: background 0.2s, color 0.2s;
}
.footer-social__link:hover {
    background: var(--blue-primary);
    color: #fff;
}
.footer-social__link svg { display: block; }

/* YouTube Play-Triangle weiß */
.icon-youtube polygon { fill: var(--wst-navy-dark); }
.footer-social__link:hover .icon-youtube polygon { fill: var(--blue-primary); }

/* Footer CTA: Telefon-Button weiß */
.footer-cta .btn--ghost {
    color: #ffffff !important;
    border-color: rgba(255,255,255,0.5);
    background: transparent;
}
.footer-cta .btn--ghost svg {
    stroke: #ffffff !important;
}
.footer-cta .btn--ghost:hover {
    color: rgba(255,255,255,0.7) !important;
    border-color: rgba(255,255,255,0.7);
}
.footer-cta .btn--ghost:hover svg {
    stroke: rgba(255,255,255,0.7) !important;
}
