 /* Joomla "Featured"-Badge ausblenden */
.featured-article-badge {
  display: none !important;
}

/* Hamburger-Icon auf Desktop ausblenden */
@media (min-width: 992px) {
  .burger-icon {
    display: none !important;
  }
}


/* Header-Bild auf volle Breite strecken */
.logo-image {
  width: 100%;
  height: 220px;
  max-width: 100%;
  object-fit: cover;
  object-position: center 60%;
}

/* Kontakt */
.sts-contact-h2 {
  font-size: clamp(1.6rem,2.5vw,2.2rem);
  font-weight: 800; color: #0f2444 !important;
  margin-bottom: 14px;
}
.sts-contact-lead {
  font-size: .95rem; line-height: 1.7;
  color: #64748b; margin-bottom: 28px;
}
.sts-contact-item {
  display: flex !important; align-items: flex-start !important;
  gap: 14px !important; padding: 12px 0 !important;
  border-bottom: 1px solid #e2e8f0 !important;
}
.sts-contact-item:first-of-type { border-top: 1px solid #e2e8f0; }
.sts-ci-icon { font-size: 1.3rem !important; flex-shrink: 0 !important; width: 28px !important; }

.sts-ci-label { font-size: .72rem; color: #64748b; }
.sts-ci-value {
  font-size: .9rem; font-weight: 600;
  color: #0f2444; text-decoration: none;
}
.sts-linkedin-btn {
  display: inline-block !important; margin-top: 24px !important;
  background: #0077b5 !important; color: #fff !important;
  font-weight: 600 !important; font-size: .875rem !important;
  padding: 12px 22px !important; border-radius: 10px !important;
  text-decoration: none !important;
}

/* Seitentitel nur auf Artikelseiten ausblenden */
.view-featured .page-header,
.view-article .page-header { 
  display: none !important; 
}

/* Hero Section */
.sts-hero-content { padding: 20px 0; max-width: 700px; }

.sts-hero-tag {
  display: inline-block;
  background: rgba(245,158,11,.15);
  color: #f59e0b;
  border: 1px solid rgba(245,158,11,.3);
  font-size: .75rem; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  padding: 6px 14px; border-radius: 20px; margin-bottom: 24px;
}

* Hero stats */
.hero-stats { display: flex; gap: 28px; margin-top: 44px; }
.hero-stat .num {
  font-size: 2rem; font-weight: 800; color: var(--white); line-height: 1;
}
.hero-stat .num span { color: var(--accent); }
.hero-stat .desc { font-size: 1.0rem; color: rgba(255,255,255,255); margin-top: 3px; }



.sts-hero-h1 {
  font-size: clamp(2rem,4vw,3.2rem);
  line-height: 1.18; color: #fff;
  margin-bottom: 22px; font-weight: 800;
  color: #ffffff !important;
}

.sts-hero-h1 em { font-style: normal; color: #f59e0b; }

.sts-hero-lead {
  font-size: 1.05rem; line-height: 1.7;
  color: rgba(255,255,255,.75);
  margin-bottom: 36px; max-width: 620px;
}

.sts-hero-btns {
  display: flex; gap: 14px;
  flex-wrap: wrap; margin-bottom: 48px;
}

.sts-hero-accent { color: #f59e0b; }

.sts-btn-primary {
  background: #1d4ed8; color: #fff !important;
  font-weight: 600; font-size: .9rem;
  padding: 14px 28px; border-radius: 10px;
  text-decoration: none !important; display: inline-block;
  box-shadow: 0 4px 16px rgba(29,78,216,.4);
  transition: transform .15s;
}

.sts-btn-primary:hover {
  transform: translateY(-1px); color: #fff !important;
}

.sts-btn-ghost {
  background: rgba(255,255,255,.1); color: #fff !important;
  font-weight: 500; font-size: .9rem;
  padding: 14px 28px; border-radius: 10px;
  border: 1px solid rgba(255,255,255,.2);
  text-decoration: none !important; display: inline-block;
  transition: background .2s;
}

.sts-btn-ghost:hover {
  background: rgba(255,255,255,.18); color: #fff !important;
}

.sts-hero-stats { display: flex; gap: 36px; flex-wrap: wrap; }

.sts-stat-num {
  font-size: 2.2rem; font-weight: 800;
  color: #fff; line-height: 1;
}

.sts-stat-num span { color: #f59e0b; }

.sts-stat-desc {
  font-size: .75rem;
  color: rgba(255,255,255,.55); margin-top: 4px;
}

/* Service Cards */
.sts-card {
  background: #ffffff;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  padding: 28px 24px;
  box-shadow: 0 4px 24px rgba(15,36,68,.08);
  height: 100%;
}
.sts-card-icon { font-size: 2rem; margin-bottom: 16px; }
.sts-card-title {
  font-size: 1.1rem; font-weight: 700;
  color: #0f2444; margin-bottom: 12px;
}
.sts-card-text {
  font-size: .875rem; line-height: 1.65; color: #64748b;
}

/* CTA Section */
.sts-cta { text-align: center; max-width: 640px; margin: 0 auto; }

.sts-cta .sts-cta-eyebrow {
  display: block; font-size: .75rem; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: rgba(255,255,255,.8) !important; margin-bottom: 16px;
}
.sts-cta .sts-cta-h2 {
  font-size: clamp(1.6rem,3vw,2.2rem); font-weight: 800;
  color: #ffffff !important; margin-bottom: 16px; line-height: 1.25;
}
.sts-cta .sts-cta-text {
  font-size: 1rem; line-height: 1.7;
  color: rgba(255,255,255,.85) !important; margin-bottom: 32px;
}
.sts-cta .sts-cta-btn {
  display: inline-block; background: #ffffff;
  color: #1e3a8a !important; font-weight: 700; font-size: .95rem;
  padding: 16px 36px; border-radius: 10px;
  text-decoration: none !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
}

.sts-section-header { text-align: center; margin-bottom: 48px; }
.sts-eyebrow {
  font-size: .75rem; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: #1d4ed8; display: block; margin-bottom: 10px;
}
.sts-section-h2 {
  font-size: clamp(1.8rem,3vw,2.4rem);
  font-weight: 800; color: #0f2444;
}

/* Profil / About */
.sts-about-h2 {
  font-size: clamp(1.6rem,2.5vw,2.2rem);
  font-weight: 800; color: #0f2444 !important;
  margin-bottom: 18px; line-height: 1.25;
}
.sts-about-text {
  font-size: .95rem; line-height: 1.75;
  color: #64748b; margin-bottom: 14px;
}
.sts-tags {
  display: flex !important; flex-wrap: wrap !important;
  gap: 8px !important; margin: 22px 0 28px !important;
}
.sts-tag {
  display: inline-block !important;
  background: #f1f5f9 !important; color: #1a3560 !important;
  font-size: .78rem !important; font-weight: 600 !important;
  padding: 6px 14px !important; border-radius: 20px !important;
  border: 1px solid #e2e8f0 !important;
}
.sts-btn-outline {
  display: inline-block;
  border: 2px solid #1d4ed8; color: #1d4ed8 !important;
  font-size: .875rem; font-weight: 600;
  padding: 12px 24px; border-radius: 10px;
  text-decoration: none !important;
  transition: background .2s, color .2s;
}
.sts-btn-outline:hover {
  background: #1d4ed8; color: #fff !important;
}

/* Kontakt */

.sts-contact-box {
  background: #f8fafc; border: 1px solid #e2e8f0;
  border-radius: 16px; padding: 36px 32px;
  text-align: center; margin-top: 0px;
}
.sts-contact-box-h2 {
  font-size: clamp(1.6rem,2.5vw,2.2rem); font-weight: 800;
  color: #0f2444 !important; margin-bottom: 12px;
  margin-top: 28px;
}
.sts-contact-box-text {
  font-size: .95rem; line-height: 1.7;
  color: #64748b; margin-bottom: 28px;
}
.sts-contact-box-btn {
  display: inline-block; background: #0f2444 !important;
  color: #fff !important; font-weight: 700;
  font-size: .95rem; padding: 16px 32px;
  border-radius: 10px; text-decoration: none !important;
  box-shadow: 0 4px 16px rgba(15,36,68,.25);
}
.sts-contact-box-divider {
  margin: 20px 0; color: #94a3b8; font-size: .85rem;
}
.sts-contact-box-tel {
  font-size: 1rem; font-weight: 600;
  color: #0f2444 !important; text-decoration: none !important;
}


/* ============================================
   PROJEKTE - Archivierte Beiträge
   ============================================ */

/* Filter-Bereich */
.com-content-archive__filters {
  border: none !important;
  background: #f8fafc;
  border-radius: 12px;
  padding: 16px 20px !important;
  margin-bottom: 32px;
  display: flex !important;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.com-content-archive__filters .btn,
.com-content-archive__filters button {
  background: #0f2444 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 8px 20px !important;
  font-weight: 600 !important;
}
.com-content-archive__filters select {
  border: 1px solid #e2e8f0 !important;
  border-radius: 8px !important;
  padding: 6px 12px !important;
  color: #334155 !important;
  background: #fff !important;
}

/* Jedes Projekt als Card */
.com-content-archive__items .row0,
.com-content-archive__items .row1 {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 24px 28px;
  margin-bottom: 20px;
  box-shadow: 0 2px 12px rgba(15,36,68,.06);
  transition: box-shadow .2s;
}
.com-content-archive__items .row0:hover,
.com-content-archive__items .row1:hover {
  box-shadow: 0 6px 24px rgba(15,36,68,.12);
}

/* Projekttitel */
.com-content-archive__items .page-header {
  display: block !important;
  margin-bottom: 12px !important;
  border-bottom: 2px solid #e2e8f0 !important;
  padding-bottom: 10px !important;
}
.com-content-archive__items .page-header h2,
.com-content-archive__items .page-header a {
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  color: #0f2444 !important;
  text-decoration: none !important;
}
.com-content-archive__items .page-header a:hover {
  color: #1d4ed8 !important;
}

/* Tabelle im Projekt-Inhalt */
.com-content-archive__items .intro table {
  width: 100% !important;
}
.com-content-archive__items .intro td {
  vertical-align: top;
  padding: 4px 12px 4px 0;
  font-size: .875rem;
  color: #64748b;
  border: none !important;
}
.com-content-archive__items .intro td:first-child {
  width: 160px !important;
  font-size: .8rem;
  font-weight: 600;
  color: #94a3b8;
  white-space: nowrap;
}

/* Bullet Points */
.com-content-archive__items .intro ul {
  margin: 0 !important; padding-left: 18px !important;
}
.com-content-archive__items .intro li {
  font-size: .875rem !important;
  line-height: 1.6 !important;
  color: #64748b !important;
  margin-bottom: 4px !important;
}

.com-content-archive__items .intro > p:first-child {
  display: none !important;
}


/* "..." Textknoten unsichtbar machen */
.com-content-archive__items .intro {
  font-size: 0 !important;
}

/* Schriftgröße für alle Elemente darin wiederherstellen */
.com-content-archive__items .intro table,
.com-content-archive__items .intro table td,
.com-content-archive__items .intro table p,
.com-content-archive__items .intro table li,
.com-content-archive__items .intro table ul,
.com-content-archive__items .intro table span,
.com-content-archive__items .intro table a {
  font-size: .875rem !important;
}

/* Tabellenbreite auf 100% erzwingen */
.com-content-archive__items .intro table {
  width: 100% !important;
}