/* ============================================================
   SSG custom.css (Lader + verbleibende Styles)
   Sophie-Scholl-Gymnasium Oberhausen

   Diese Datei importiert die modularen SSG-Style-Module und
   enthält danach alle verbleibenden allgemeinen Styles, die
   nicht in eigene Module aufgeteilt wurden.

   Lade-Reihenfolge:
     1. ssg/logo.css        — Header + Logo + Responsive
     2. ssg/navigation.css  — Desktop/Tablet/Mobile Navigation
     3. ssg/bottom-tabs.css — Mobile Bottom-Tabs + Bottom-Sheet
     4. (diese Datei)       — Design Tokens, Footer, Typo, Cards etc.
   ============================================================ */

@import url('ssg/logo.css');
@import url('ssg/navigation.css');
@import url('ssg/bottom-tabs.css');
@import url('ssg/schuelerarbeiten-widget.css');
@import url('ssg/home.css');
@import url('ssg/missing.css');
@import url('ssg/termine.css');
@import url('ssg/foto-ordner.css');
@import url('ssg/terminbuchung.css');
@import url('ssg/feedback.css');


/* ============================================================
   LOKALE WEBFONTS — JetBrains Mono (400 + 500)
   TODO: lokale Font-Dateien einbinden
   Bitte folgende Dateien nach fonts/jetbrains-mono/ legen:
     - JetBrainsMono-Regular.woff2    (weight 400)
     - JetBrainsMono-Medium.woff2     (weight 500)
   Download: https://github.com/JetBrains/JetBrainsMono/releases
   ============================================================ */

/* @font-face {
  font-family: 'JetBrains Mono';
  src: url('../fonts/jetbrains-mono/JetBrainsMono-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'JetBrains Mono';
  src: url('../fonts/jetbrains-mono/JetBrainsMono-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
} */


/* ============================================================
   DESIGN TOKENS
   ============================================================ */

:root {
  --ssg-blue-dark: #002364;
  --ssg-blue: #006EE1;
  --ssg-green: #76B900;
  --ssg-amber: #F8AC00;
  --ssg-bg-white: #ffffff;
  --ssg-bg-gray: #f7f7f5;
  --ssg-border: #e5e5e5;
  --ssg-text: #444;
  --ssg-text-muted: #666;
  --ssg-text-light: #888;
  --ssg-radius: 10px;
  --ssg-shadow: 0 2px 8px rgba(0,0,0,0.06);

  /* Typografie */
  --ssg-fs-body: 16px;
  --ssg-fs-small: 13px;
  --ssg-fs-h2: 24px;
  --ssg-fs-h3: 18px;
  --ssg-fs-meta: 12px;
  --ssg-lh-body: 1.6;

  /* Header-Hoehen */
  --ssg-topbar-height: 36px;
  --ssg-header-height: 80px;
  --ssg-header-height-scrolled: 60px;

  /* Hero v3 — Architekturplan-Folio */
  --ssg-paper: #fdfdfc;
  --ssg-muted: #5a5a5a;
  --ssg-rule: rgba(0,35,100,.10);
  --ssg-green-dark: #4d7a00;
  --ssg-blue-ink: #0a2456;
  --ssg-ink-soft: rgba(0,35,100,.55);
  --ssg-ink-hair: rgba(0,35,100,.18);
}


/* ============================================================
   FOOTER
   Zweizeilig: footer1 (Quicklinks + Kontakt),
   footer2 (Copyright).
   ============================================================ */

/* -- Footer-Gesamtbereich -- */
#sp-footer {
  background: var(--ssg-blue-dark);
  color: rgba(255,255,255,0.85);
  font-size: var(--ssg-fs-body);
  line-height: 1.6;
}

/* -- Footer 1: Module nebeneinander (Kontakt, Links, Social) -- */
#sp-footer1 {
  padding: 40px 15px 24px;
}

#sp-footer1 .sp-column,
#sp-footer1 > .container > .row,
#sp-footer1 > .container {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}

#sp-footer1 .sp-module {
  flex: 1 1 200px;
  min-width: 0;
}

#sp-footer1 .sp-module-title,
#sp-footer1 h3 {
  font-size: var(--ssg-fs-small);
  font-weight: 700;
  color: #ffffff;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 12px 0;
}

/* Links */
#sp-footer1 a {
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  transition: color 0.2s ease;
}

#sp-footer1 a:hover {
  color: var(--ssg-green);
  text-decoration: none;
}

#sp-footer1 ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

#sp-footer1 ul li {
  margin-bottom: 6px;
}

#sp-footer1 ul li a {
  font-size: var(--ssg-fs-body);
  padding: 0;
}

/* Adress-Block */
#sp-footer1 address,
#sp-footer1 .ssg-footer-address {
  font-style: normal;
  font-size: var(--ssg-fs-body);
  line-height: 1.7;
}

/* Social Icons */
#sp-footer1 .ssg-footer-social {
  display: flex;
  gap: 12px;
  margin-top: 8px;
}

#sp-footer1 .ssg-footer-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.7);
  transition: all 0.2s ease;
}

#sp-footer1 .ssg-footer-social a:hover {
  color: #ffffff;
  border-color: var(--ssg-green);
  background: rgba(255,255,255,0.08);
}

/* -- Footer 2: Copyright-Zeile -- */
#sp-footer2 {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding: 16px 0;
  text-align: center;
}

#sp-footer2,
#sp-footer2 p,
#sp-footer2 .sp-module {
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  margin: 0;
}

#sp-footer2 a {
  color: rgba(255,255,255,0.45);
  text-decoration: none;
}

#sp-footer2 a:hover {
  color: rgba(255,255,255,0.8);
}

/* -- Footer responsive -- */
@media (max-width: 768px) {
  #sp-footer1 {
    padding: 32px 16px 20px;
  }

  #sp-footer1 .sp-module {
    flex-direction: column;
    gap: 24px;
  }

  #sp-footer2 {
    padding: 12px 16px calc(12px + 56px + env(safe-area-inset-bottom, 0px));
  }
}


/* ============================================================
   GLOBALE TYPOGRAFIE
   ============================================================ */

.sppb-addon-raw-html,
.sppb-addon-text-block,
.sppb-addon-raw-html p,
.sppb-addon-raw-html ul,
.sppb-addon-raw-html ol,
.sppb-addon-raw-html li,
.sppb-addon-text-block p {
  font-size: var(--ssg-fs-body);
  line-height: var(--ssg-lh-body);
  color: var(--ssg-text);
}

.sppb-addon-raw-html ul,
.sppb-addon-raw-html ol {
  padding-left: 20px;
}

.sppb-addon-raw-html li {
  margin-bottom: 4px;
}


/* ============================================================
   BREADCRUMB
   ============================================================ */

.ssg-breadcrumb,
.mod-breadcrumbs {
  font-size: 12px;
  color: var(--ssg-text-light);
  margin: 0 0 12px 0;
}

.ssg-breadcrumb a,
.mod-breadcrumbs a {
  color: var(--ssg-text-light);
  text-decoration: none;
  transition: color .2s;
}

.ssg-breadcrumb a:hover,
.mod-breadcrumbs a:hover {
  color: var(--ssg-blue-dark);
}


/* ============================================================
   HERO
   ============================================================ */

.ssg-hero-breadcrumb {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
  font-size: .78rem;
  color: var(--ssg-text-light);
  margin: 0 0 16px 0;
}

.ssg-hero-breadcrumb a {
  color: var(--ssg-text-light);
  text-decoration: none;
}

.ssg-hero-breadcrumb a:hover {
  color: var(--ssg-blue-dark);
}

.ssg-hero-bar {
  display: block;
  width: 36px;
  height: 3px;
  background: var(--ssg-green);
  border-radius: 2px;
  margin: 0 0 14px 0;
}

.ssg-hero-title {
  font-family: 'Ubuntu', sans-serif;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 700;
  color: var(--ssg-blue-dark);
  margin: 0 0 14px 0;
  line-height: 1.12;
  text-wrap: balance;
}

.ssg-hero-title .accent {
  color: var(--ssg-green);
}

.ssg-hero-desc {
  color: var(--ssg-text-muted);
  line-height: 1.7;
  margin: 0 0 20px 0;
  max-width: 640px;
}


/* ============================================================
   CHIPS
   ============================================================ */

.ssg-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.ssg-chip {
  font-size: 11px;
  font-weight: 600;
  padding: 4px 12px;
  border-radius: 20px;
  border: 1px solid var(--ssg-border);
  color: var(--ssg-text-muted);
  background: transparent;
}

.ssg-chip--active {
  background: var(--ssg-green);
  color: #fff;
  border-color: var(--ssg-green);
}


/* ============================================================
   SECTION HEADER
   ============================================================ */

.ssg-section-header {
  display: block;
  margin-bottom: 28px;
}

.ssg-section-header::before {
  content: "";
  display: block;
  width: 36px;
  height: 3px;
  background: var(--ssg-green);
  border-radius: 2px;
  margin-bottom: 12px;
}

/* Label (klein, uppercase, grün) */
.ssg-section-header span,
.ssg-section-header .ssg-section-header-label {
  display: block;
  font-family: 'Ubuntu', sans-serif;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ssg-green);
  margin-bottom: 6px;
}

/* Titel-H2 innerhalb Section-Header */
.ssg-section-header h2,
.ssg-section-header-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: clamp(1.3rem, 2.5vw, 1.7rem);
  color: var(--ssg-blue-dark);
  line-height: 1.2;
  margin: 0;
}

/* Gel-Header-Override bleibt kompatibel */
.ssg-gel-header .ssg-section-header {
  margin-bottom: 16px;
}


/* ============================================================
   CARDS
   ============================================================ */

.ssg-card {
  background: var(--ssg-bg-white);
  border: 0.5px solid var(--ssg-border);
  border-radius: var(--ssg-radius);
  box-shadow: var(--ssg-shadow);
  overflow: hidden;
}

.ssg-card-body {
  padding: 20px 24px;
}

.ssg-card .ssg-card-tag,
.com-sppagebuilder .ssg-card-tag {
  display: inline-block;
  background: rgba(118,185,0,.1);
  color: var(--ssg-green);
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 20px;
  margin-bottom: 12px;
}

.ssg-card .ssg-card-title,
.com-sppagebuilder .ssg-card-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--ssg-blue-dark);
  margin: 0 0 10px 0;
  line-height: 1.35;
}

.ssg-card .ssg-card-meta {
  font-size: var(--ssg-fs-meta);
  color: var(--ssg-text-light);
  margin: 0 0 6px 0;
}

.ssg-card .ssg-card-desc,
.com-sppagebuilder .ssg-card-desc {
  font-size: .88rem;
  color: #555;
  line-height: 1.65;
  flex: 1;
  margin: 0;
}

.ssg-card-top {
  border-radius: 0;
}

.ssg-card-bottom {
  border-radius: 0;
}


/* ============================================================
   CARD GRID (equal height)
   ============================================================ */

[class*="sppb-col-"]:has(.sppb-addon-feature),
[class*="sppb-col-"].ssg-has-feature {
  display: flex;
  flex-direction: column;
  border: .5px solid var(--ssg-border);
  border-radius: var(--ssg-radius);
  box-shadow: var(--ssg-shadow);
  overflow: hidden;
  background: var(--ssg-bg-white);
  transition: transform .2s, box-shadow .2s;
}

[class*="sppb-col-"]:has(.sppb-addon-feature):hover,
[class*="sppb-col-"].ssg-has-feature:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,.1);
}

/* Doppelten border/shadow von .ssg-card entfernen wenn es im Karten-Spalte sitzt */
[class*="sppb-col-"]:has(.sppb-addon-feature) .ssg-card,
[class*="sppb-col-"].ssg-has-feature .ssg-card {
  border: none;
  box-shadow: none;
  border-radius: 0;
  background: transparent;
}

[class*="sppb-col-"]:has(.sppb-addon-feature) > .sppb-addon-wrapper:first-child,
[class*="sppb-col-"].ssg-has-feature > .sppb-addon-wrapper:first-child {
  flex: 1;
}

[class*="sppb-col-"]:has(.sppb-addon-feature) > .sppb-addon-wrapper:last-child,
[class*="sppb-col-"].ssg-has-feature > .sppb-addon-wrapper:last-child {
  margin-top: auto;
}

[class*="sppb-col-"] .sppb-addon-feature {
  display: flex;
  flex-direction: column;
  height: 100%;
}

[class*="sppb-col-"] .sppb-addon-feature .sppb-btn {
  margin-top: auto !important;
}

/* Farbstreifen oben — Farbe wird per icon_color als inline style gesetzt (SPPB-Addon-Einstellung),
   Fallback: --ssg-green. Greift nur in ssg-h-scroll-section-Kontext. */
.com-sppagebuilder .ssg-h-scroll-section .sppb-addon-feature::before {
  content: '';
  display: block;
  height: 4px;
  background: var(--ssg-green);
}


/* ============================================================
   LINK BUTTONS
   ============================================================ */

.ssg-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--ssg-blue-dark);
  color: #fff;
  padding: 8px 14px;
  border-radius: 6px;
  font-size: var(--ssg-fs-small);
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: background .2s;
  border: none;
}

.ssg-btn:hover {
  background: var(--ssg-blue);
  color: #fff;
}

.ssg-btn i {
  font-size: 11px;
}

.ssg-btn--block {
  width: 100%;
  justify-content: center;
}

.ssg-btn-outline {
  background: transparent;
  color: var(--ssg-blue-dark);
  border: 1px solid var(--ssg-border);
}

.ssg-btn-outline:hover {
  background: var(--ssg-blue-dark);
  color: #fff;
  border-color: var(--ssg-blue-dark);
}

/* BEM-Varianten (Hero v2) */
.ssg-btn--primary {
  background: var(--ssg-green);
  color: #fff;
  border: none;
  box-shadow: 0 4px 14px rgba(118,185,0,.28);
}

.ssg-btn--primary:hover {
  background: var(--ssg-green-dark);
  color: #fff;
}

.ssg-btn--outline {
  background: transparent;
  color: var(--ssg-blue-dark);
  border: 1.5px solid var(--ssg-blue-dark);
}

.ssg-btn--outline:hover {
  background: var(--ssg-blue-dark);
  color: #fff;
  border-color: var(--ssg-blue-dark);
}


/* ============================================================
   GALLERY (mobile-first scroll)
   ============================================================ */

.ssg-gallery {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding: 0 0 8px 0;
  scrollbar-width: thin;
  scrollbar-color: #ccc transparent;
}

.ssg-gallery::-webkit-scrollbar {
  height: 4px;
}

.ssg-gallery::-webkit-scrollbar-thumb {
  background: #ccc;
  border-radius: 4px;
}

.ssg-gallery-item {
  flex: 0 0 75%;
  scroll-snap-align: start;
  border-radius: var(--ssg-radius);
  overflow: hidden;
  position: relative;
  aspect-ratio: 3/2;
}

.ssg-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}

.ssg-gallery-item:hover img {
  transform: scale(1.03);
}

@media (min-width: 768px) {
  .ssg-gallery {
    gap: 12px;
    overflow-x: visible;
    flex-wrap: wrap;
  }
  .ssg-gallery-item {
    flex: 0 0 calc(33.333% - 8px);
  }
}

@media (min-width: 1200px) {
  .ssg-gallery-item {
    flex: 0 0 calc(25% - 9px);
  }
}


/* ============================================================
   COORDINATOR CARD (Tabs)
   ============================================================ */

.ssg-coordinator {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 4px 0;
}

.ssg-coordinator-photo {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 2px solid #f0f0f0;
}

.ssg-coordinator-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--ssg-blue-dark);
  margin: 0 0 2px 0;
}

.ssg-coordinator-role {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .03em;
  color: var(--ssg-text-light);
  margin: 0 0 10px 0;
}


/* ============================================================
   LEHRKRAFT-KARTE (TdoT)
   ============================================================ */

.ssg-teacher-card {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.ssg-teacher-photo {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 2px solid #f0f0f0;
}

.ssg-teacher-name {
  font-size: 16px;
  font-weight: 700;
  color: var(--ssg-blue-dark);
  margin: 0 0 2px 0;
}

.ssg-teacher-role {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--ssg-text-light);
  margin: 0 0 10px 0;
}

.ssg-teacher-text {
  font-size: var(--ssg-fs-body);
  color: var(--ssg-text);
  line-height: 1.6;
  margin: 0;
}


/* ============================================================
   SCHUELERPRODUKTE WIDGET
   ============================================================ */

.ssg-sp-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

@media (min-width: 576px) {
  .ssg-sp-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 992px) {
  .ssg-sp-grid {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

.ssg-sp-card {
  background: var(--ssg-bg-white);
  border: 0.5px solid var(--ssg-border);
  border-radius: var(--ssg-radius);
  overflow: hidden;
  box-shadow: var(--ssg-shadow);
  transition: transform .2s, box-shadow .2s;
}

.ssg-sp-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.1);
}

.ssg-sp-img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  display: block;
  background: #f0f0f0;
}

.ssg-sp-body {
  padding: 14px 16px;
}

.ssg-sp-tag {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--ssg-green);
  margin: 0 0 6px 0;
}

.ssg-sp-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--ssg-blue-dark);
  margin: 0 0 4px 0;
  line-height: 1.3;
}

.ssg-sp-meta {
  font-size: 12px;
  color: var(--ssg-text-light);
  margin: 0 0 6px 0;
}

.ssg-sp-desc {
  font-size: 12px;
  color: var(--ssg-text-muted);
  line-height: 1.5;
  margin: 0;
}

.ssg-sp-empty {
  border: 1.5px dashed #ddd;
  border-radius: var(--ssg-radius);
  padding: 32px;
  text-align: center;
  color: #999;
}

.ssg-sp-footer {
  display: flex;
  justify-content: center;
  margin-top: 20px;
}


/* ============================================================
   PLACEHOLDER
   ============================================================ */

.ssg-placeholder {
  border: 2px dashed #ccc;
  border-radius: var(--ssg-radius);
  padding: 24px;
  text-align: center;
  color: #999;
  font-size: var(--ssg-fs-small);
  margin: 16px 0;
}


/* ============================================================
   NEWS LIST
   ============================================================ */

.ssg-news-list {
  background: var(--ssg-bg-white);
  border-radius: var(--ssg-radius);
  border: 0.5px solid var(--ssg-border);
  padding: 4px 16px;
}

.ssg-news-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 0;
}

.ssg-news-item:not(:last-child) {
  border-bottom: 0.5px solid #f0f0f0;
}

.ssg-news-dot {
  width: 7px;
  height: 7px;
  min-width: 7px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
  margin-top: 4px;
}

.ssg-news-dot--green { background: var(--ssg-green); }
.ssg-news-dot--blue { background: var(--ssg-blue); }
.ssg-news-dot--amber { background: var(--ssg-amber); }

.ssg-news-date {
  font-size: 11px;
  color: var(--ssg-text-light);
  margin-bottom: 2px;
}

.ssg-news-text {
  font-size: var(--ssg-fs-body);
  font-weight: 500;
  color: #1a1a1a;
}


/* ============================================================
   DIVIDER
   ============================================================ */

.ssg-divider {
  height: 1px;
  background: var(--ssg-border);
  margin: 16px 0;
}


/* ============================================================
   YOUTUBE TWO-CLICK EMBED
   ============================================================ */

.ssg-youtube {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  aspect-ratio: 16/9;
  height: 0;
  border-radius: var(--ssg-radius);
  overflow: hidden;
  background: #000;
}

@supports (aspect-ratio: 16/9) {
  .ssg-youtube {
    padding-bottom: 0;
    height: auto;
  }
}

.ssg-youtube iframe {
  width: 100%;
  height: 100%;
  border: none;
}

.ssg-video-wrapper {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  border-radius: var(--ssg-radius);
  border: 0.5px solid var(--ssg-border);
  box-shadow: var(--ssg-shadow);
}

.ssg-video-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* ── YouTube Two-Click Embed (ssg-yt) ─────────────────── */
.ssg-yt {
  position: relative;
  margin: 0;
  aspect-ratio: 16 / 9;
  background: #0d1c3e;
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
}
.ssg-yt-thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .55;
  transition: opacity .2s;
}
.ssg-yt:hover .ssg-yt-thumb { opacity: .7; }
.ssg-yt-consent {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 24px;
  text-align: center;
}
.ssg-yt-consent p {
  color: rgba(255,255,255,.85);
  font-size: .9rem;
  max-width: 400px;
  line-height: 1.6;
  margin: 0;
}
.ssg-yt-consent .ssg-btn {
  background: var(--ssg-green);
  color: white;
  border: none;
  cursor: pointer;
}
.ssg-yt iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* ── Video-Galerie (mehrere Two-Click-Videos im Raster) ── */
.ssg-video-heading {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  color: var(--ssg-darkblue, #002364);
  margin-bottom: 10px;
}
.ssg-video-galerie {                                    /* Mobile-First: 1 Spalte */
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
@media (min-width: 768px) {
  .ssg-video-galerie { grid-template-columns: repeat(2, 1fr); }
}


/* ============================================================
   MODAL CONTENT
   ============================================================ */

.ssg-modal-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--ssg-blue-dark);
  margin: 0 0 12px 0;
}

.ssg-modal-text {
  font-size: 14px;
  color: var(--ssg-text);
  line-height: 1.7;
  margin: 0 0 10px 0;
}

.ssg-modal-subtitle {
  font-size: 14px;
  font-weight: 700;
  color: var(--ssg-blue-dark);
  margin: 14px 0 6px 0;
}

.ssg-modal-list {
  font-size: 14px;
  color: var(--ssg-text);
  line-height: 1.8;
  padding-left: 18px;
  margin: 0;
}

.ssg-modal-list--spaced {
  margin: 0 0 10px 0;
}

.ssg-modal-note {
  font-size: var(--ssg-fs-small);
  color: var(--ssg-text-light);
  line-height: 1.6;
  margin: 0;
}


/* ============================================================
   HORIZONTAL SCROLL
   ============================================================ */

.ssg-h-scroll {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 8px;
  scrollbar-width: thin;
  scrollbar-color: #ccc transparent;
  flex: 0 0 100%;
  max-width: 100%;
}

.ssg-h-scroll::-webkit-scrollbar {
  height: 4px;
}

.ssg-h-scroll::-webkit-scrollbar-thumb {
  background: #ccc;
  border-radius: 4px;
}

.ssg-h-scroll > [class*="sppb-col-"] {
  flex: 0 0 80%;
  max-width: 80%;
  scroll-snap-align: start;
  width: auto !important;
  padding-left: 0;
  padding-right: 0;
}

@media (max-width: 575.98px) {
  .ssg-h-scroll > [class*="sppb-col-"] {
    flex: 0 0 85%;
    max-width: 85%;
  }
}

@media (min-width: 992px) {
  .ssg-h-scroll {
    overflow-x: visible;
    flex-wrap: nowrap;
    scroll-snap-type: none;
    padding-bottom: 0;
    gap: 16px;
  }

  .ssg-h-scroll > [class*="sppb-col-"] {
    flex: 1 1 0;
    max-width: none;
    min-width: 0;
  }
}

.ssg-h-scroll-outer {
  position: relative;
  flex: 0 0 100%;
  max-width: 100%;
}

.ssg-h-scroll-outer::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 72px;
  background: linear-gradient(to right, transparent 0%, rgba(0, 0, 0, 0.04) 60%, rgba(0, 0, 0, 0.08) 100%);
  pointer-events: none;
  transition: opacity 0.3s ease;
  z-index: 1;
}

.ssg-h-scroll-outer.ssg-scroll-end::after {
  opacity: 0;
}

.ssg-h-scroll-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  padding-top: 14px;
}

.ssg-h-scroll-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #e5e5e5;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background 0.2s ease, width 0.2s ease, border-radius 0.2s ease;
}

.ssg-h-scroll-dot.active {
  background: var(--ssg-green);
  width: 18px;
  border-radius: 4px;
}

@media (min-width: 992px) {
  .ssg-h-scroll-outer::after {
    display: none;
  }
  .ssg-h-scroll-dots {
    display: none;
  }
}


/* ============================================================
   TEACHER CARD INNER WRAPPER
   ============================================================ */

.ssg-teacher-inner {
  background: var(--ssg-bg-white);
  border: 0.5px solid var(--ssg-border);
  border-radius: var(--ssg-radius);
  box-shadow: var(--ssg-shadow);
  padding: 16px;
}


/* ============================================================
   SPPB MODAL – Font-Konsistenz
   ============================================================ */

/* Generischer Modal-Button (alle SPPB-Modal-Addons ohne ssg-card-modal-btn) */
.sppb-addon-modal .sppb-btn {
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  font-size: var(--ssg-fs-small) !important;
  font-weight: 600 !important;
  letter-spacing: 0;
  line-height: 1.4;
  padding: 8px 14px !important;
  border-radius: 6px !important;
  box-sizing: border-box;
}

/* Feature-Card CTA-Link (Mockup-Stil: "Mehr erfahren →", kein Block-Button) */
.com-sppagebuilder .ssg-card-modal-btn .sppb-btn {
  background: transparent !important;
  border: none !important;
  color: var(--ssg-green);
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .85rem;
  padding: 0 !important;
  display: flex !important;
  width: auto !important;
  text-align: left !important;
  align-items: center;
  gap: 5px;
  text-decoration: none;
  margin-top: 16px;
  border-radius: 0 !important;
  line-height: 1.4;
  box-shadow: none !important;
}

/* Pfeil-Icon via CSS (alternativ: → im Button-Text eintragen) */
.com-sppagebuilder .ssg-card-modal-btn .sppb-btn::after {
  content: '→';
}

.com-sppagebuilder .ssg-card-modal-btn .sppb-btn:hover {
  text-decoration: underline;
}

.ssg-card-bottom .ssg-btn {
  border-radius: 6px;
  font-size: var(--ssg-fs-small);
  font-weight: 600;
  padding: 8px 14px;
}

.ssg-card-bottom:not(.ssg-card) {
  border: none;
  box-shadow: none;
  background: transparent;
}

.sppb-popup-content .ssg-modal-text,
.sppb-modal-body .ssg-modal-text,
.sppb-popup-content .ssg-modal-list,
.sppb-modal-body .ssg-modal-list,
.sppb-popup-content .ssg-modal-note,
.sppb-modal-body .ssg-modal-note {
  font-size: var(--ssg-fs-small);
  font-weight: 400;
}

.sppb-popup-content .ssg-modal-title,
.sppb-modal-body .ssg-modal-title {
  font-size: 17px;
  font-weight: 700;
}

.sppb-popup-content .ssg-modal-subtitle,
.sppb-modal-body .ssg-modal-subtitle {
  font-size: var(--ssg-fs-small);
  font-weight: 700;
}


/* ============================================================
   EDITORIAL GALLERY (ssg-gel)
   ============================================================ */

.ssg-gel-wrap {
  position: relative;
}

.ssg-gel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}

.ssg-gel-header .ssg-section-header {
  margin-bottom: 0;
}

.ssg-gel-trip {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--ssg-text-light);
  margin: 0;
  background: var(--ssg-bg-gray);
  padding: 4px 10px;
  border-radius: 20px;
}

.ssg-gel {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: 190px 190px 150px;
  gap: 5px;
  border-radius: var(--ssg-radius);
  overflow: hidden;
}

.ssg-gel-item {
  position: relative;
  overflow: hidden;
  background: #e8e8e6;
  cursor: pointer;
}

.ssg-gel-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s cubic-bezier(.25,.46,.45,.94);
}

.ssg-gel-item:hover img {
  transform: scale(1.06);
}

.ssg-gel-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 28px 12px 10px;
  background: linear-gradient(transparent, rgba(0,0,0,0.6));
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .03em;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
}

.ssg-gel-item:hover .ssg-gel-caption {
  opacity: 1;
  transform: translateY(0);
}

.ssg-gel-item:nth-child(1) { grid-column: 1 / 3; grid-row: 1 / 3; }
.ssg-gel-item:nth-child(2) { grid-column: 3;     grid-row: 1; }
.ssg-gel-item:nth-child(3) { grid-column: 4;     grid-row: 1; }
.ssg-gel-item:nth-child(4) { grid-column: 3 / 5; grid-row: 2; }
.ssg-gel-item:nth-child(5) { grid-column: 1;     grid-row: 3; }
.ssg-gel-item:nth-child(6) { grid-column: 2;     grid-row: 3; }
.ssg-gel-item:nth-child(7) { grid-column: 3;     grid-row: 3; }
.ssg-gel-item:nth-child(8) { grid-column: 4;     grid-row: 3; }

.ssg-gel-counter {
  display: none;
  justify-content: center;
  align-items: center;
  gap: 2px;
  padding-top: 12px;
  font-size: 12px;
  color: var(--ssg-text-light);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.ssg-gel-counter-current {
  color: var(--ssg-blue-dark);
}

@media (max-width: 767px) {
  .ssg-gel {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 180px 140px 180px 140px;
    gap: 4px;
  }

  .ssg-gel-item:nth-child(1) { grid-column: 1 / 3; grid-row: 1; }
  .ssg-gel-item:nth-child(2) { grid-column: 1;     grid-row: 2; }
  .ssg-gel-item:nth-child(3) { grid-column: 2;     grid-row: 2; }
  .ssg-gel-item:nth-child(4) { grid-column: 1 / 3; grid-row: 3; }
  .ssg-gel-item:nth-child(5) { grid-column: 1;     grid-row: 4; }
  .ssg-gel-item:nth-child(6) { grid-column: 2;     grid-row: 4; }
  .ssg-gel-item:nth-child(7) { display: none; }
  .ssg-gel-item:nth-child(8) { display: none; }
}

@media (max-width: 480px) {
  .ssg-gel {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    border-radius: var(--ssg-radius);
    gap: 10px;
    padding-bottom: 0;
    scrollbar-width: none;
  }

  .ssg-gel::-webkit-scrollbar { display: none; }

  .ssg-gel-item {
    flex: 0 0 82%;
    height: 240px;
    scroll-snap-align: center;
    border-radius: var(--ssg-radius);
  }

  .ssg-gel-item:nth-child(n) {
    grid-column: auto;
    grid-row: auto;
    display: block;
  }

  .ssg-gel-caption {
    opacity: 1;
    transform: translateY(0);
  }

  .ssg-gel-counter {
    display: flex;
  }

  .ssg-gel-trip {
    display: none;
  }
}


/* ============================================================
   ACCORDION (native <details>)
   ============================================================ */

.ssg-accordion {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 20px;
  text-align: left;
}

.ssg-accordion-item {
  background: var(--ssg-bg-white);
  border: 0.5px solid var(--ssg-border);
  border-radius: var(--ssg-radius);
  overflow: hidden;
}

.ssg-accordion-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  font-size: 14px;
  font-weight: 600;
  color: var(--ssg-blue-dark);
  cursor: pointer;
  list-style: none;
  transition: background 0.2s ease;
}

.ssg-accordion-header::-webkit-details-marker {
  display: none;
}

.ssg-accordion-header::after {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--ssg-text-muted);
  border-bottom: 2px solid var(--ssg-text-muted);
  transform: rotate(45deg);
  transition: transform 0.25s ease;
  flex-shrink: 0;
  margin-left: 12px;
}

.ssg-accordion-item[open] > .ssg-accordion-header::after {
  transform: rotate(-135deg);
}

.ssg-accordion-item[open] > .ssg-accordion-header {
  background: var(--ssg-bg-gray);
  border-bottom: 0.5px solid var(--ssg-border);
}

.ssg-accordion-header:hover {
  background: var(--ssg-bg-gray);
}

.ssg-accordion-body {
  padding: 16px 18px;
  font-size: var(--ssg-fs-body);
  line-height: 1.7;
  color: var(--ssg-text);
}

.ssg-accordion-body p {
  margin: 0 0 8px 0;
}

.ssg-accordion-body p:last-child {
  margin-bottom: 0;
}


/* ============================================================
   VIDEO + TESTIMONIAL LAYOUT
   ============================================================ */

.ssg-video-testimonial {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: start;
  margin-top: 20px;
}

@media (max-width: 768px) {
  .ssg-video-testimonial {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

.ssg-video-embed .embed-container {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  border-radius: var(--ssg-radius);
}

.ssg-video-embed .embed-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

.ssg-video-caption {
  font-size: 11px;
  color: var(--ssg-text-light);
  margin-top: 8px;
}

.ssg-testimonial {
  margin: 0;
  padding: 20px 24px;
  background: var(--ssg-bg-white);
  border: 0.5px solid var(--ssg-border);
  border-radius: var(--ssg-radius);
  border-left: 3px solid var(--ssg-green);
  font-size: 14px;
  line-height: 1.6;
  color: var(--ssg-text);
  font-style: italic;
}

.ssg-testimonial p {
  margin: 0 0 16px 0;
}

.ssg-testimonial footer {
  display: flex;
  align-items: center;
  gap: 12px;
  font-style: normal;
  font-size: var(--ssg-fs-small);
}

.ssg-testimonial-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
}

.ssg-testimonial-name {
  display: block;
  font-weight: 600;
  color: var(--ssg-blue-dark);
  font-size: var(--ssg-fs-small);
}

.ssg-testimonial-role {
  display: block;
  font-size: 11px;
  color: var(--ssg-text-muted);
}


/* ============================================================
   PROFIL-KARTEN (Dein Weg)
   ============================================================ */

.ssg-profile-card {
  background: var(--ssg-bg-white);
  border: 0.5px solid var(--ssg-border);
  border-radius: var(--ssg-radius);
  padding: 20px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.ssg-profile-badge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 20px;
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 8px;
  align-self: flex-start;
}

.ssg-profile-card .ssg-card-title {
  margin-bottom: 8px;
}

.ssg-profile-card .ssg-card-desc {
  flex: 1;
}

.ssg-profile-card .ssg-video-embed {
  margin-top: auto;
}


/* ============================================================
   UTILITY-KLASSEN
   ============================================================ */

.ssg-section-intro {
  font-size: 14px;
  color: var(--ssg-text-muted);
  margin-bottom: 24px;
  max-width: 640px;
}

.ssg-img-rounded {
  width: 100%;
  border-radius: var(--ssg-radius);
  object-fit: cover;
  max-height: 420px;
  border: .5px solid var(--ssg-border);
  display: block;
}

/* Download-Karten */
.ssg-downloads {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 20px;
}

.ssg-download-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  background: var(--ssg-bg-white);
  border: 0.5px solid var(--ssg-border);
  border-radius: var(--ssg-radius);
  text-decoration: none;
  color: var(--ssg-text);
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

.ssg-download-card:hover {
  border-color: var(--ssg-blue);
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
  text-decoration: none;
  color: var(--ssg-text);
}

.ssg-download-icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: var(--ssg-bg-gray);
  display: flex;
  align-items: center;
  justify-content: center;
}

.ssg-download-icon svg {
  width: 22px;
  height: 22px;
  stroke: var(--ssg-blue);
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.ssg-download-info {
  flex: 1;
  min-width: 0;
}

.ssg-download-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--ssg-blue-dark);
  display: block;
}

.ssg-download-meta {
  font-size: 11px;
  color: var(--ssg-text-light);
  margin-top: 2px;
}

.ssg-download-badge {
  flex-shrink: 0;
  padding: 3px 10px;
  border-radius: 20px;
  background: var(--ssg-bg-gray);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ssg-text-muted);
}

.ssg-download-arrow {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  stroke: var(--ssg-text-light);
  fill: none;
  stroke-width: 1.5;
  transition: stroke 0.2s ease, transform 0.2s ease;
}

.ssg-download-card:hover .ssg-download-arrow {
  stroke: var(--ssg-blue);
  transform: translateX(2px);
}

@media (max-width: 768px) {
  .ssg-download-card {
    gap: 12px;
    padding: 14px 16px;
  }
  .ssg-download-badge {
    display: none;
  }
}

/* Info-Banner */
.ssg-info-banner {
  background: var(--ssg-bg-gray);
  border-left: 3px solid var(--ssg-green);
  padding: 16px 20px;
  border-radius: var(--ssg-radius);
  margin-bottom: 20px;
  font-size: 14px;
}

/* Margin-Utilities */
.ssg-mt-8  { margin-top: 8px; }
.ssg-mt-12 { margin-top: 12px; }
.ssg-mt-16 { margin-top: 16px; }
.ssg-mt-20 { margin-top: 20px; }
.ssg-mt-24 { margin-top: 24px; }
.ssg-mb-8  { margin-bottom: 8px; }
.ssg-mb-12 { margin-bottom: 12px; }
.ssg-mb-16 { margin-bottom: 16px; }
.ssg-mb-20 { margin-bottom: 20px; }


/* ============================================================
   FOOTER GRID (alternative Variante)
   ============================================================ */

.ssg-footer-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 32px;
  padding: 24px 0;
}
.ssg-footer-grid h4 {
  color: #fff;
  font-size: 16px;
  margin: 0 0 12px;
}
.ssg-footer-grid address,
.ssg-footer-grid p,
.ssg-footer-grid a,
.ssg-footer-grid li {
  color: rgba(255,255,255,.65);
  font-size: 14px;
  line-height: 1.7;
}
.ssg-footer-grid a:hover { color: var(--ssg-green); }
.ssg-footer-grid ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ssg-footer-grid ul li { margin: 4px 0; }
@media (max-width: 768px) {
  .ssg-footer-grid { grid-template-columns: 1fr; gap: 24px; }
}

/* EOF */


/* =====================================================================
   SSG NEWS TIMELINE (Articles Addon Override)
   Mobile: vertikale Kartenliste mit Dots
   Desktop/Tablet: horizontale Timeline mit Winkel-Connectors
   Alle Selektoren unter .ssg-news-timeline gescoped (kein Konflikt
   mit .ssg-news-list weiter oben).
   ===================================================================== */

.ssg-news-timeline::before {
  background: #d0d0d0; /* statt #e0e0e0 */
}

/* -- Base / Mobile-first: vertikale Kartenliste -- */

.ssg-news-timeline {
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  list-style: none;
}

.ssg-news-timeline .ssg-news-item {
  display: grid;
  grid-template-columns: 16px 1fr;
  gap: 14px;
  padding: 18px 0;
  border-bottom: 1px solid #ececec;
  align-items: start;
}

.ssg-news-timeline .ssg-news-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.ssg-news-timeline .ssg-news-item:first-child {
  padding-top: 0;
}

.ssg-news-timeline .ssg-news-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-top: 8px;
  margin-left: 3px;
  flex-shrink: 0;
}

/* Farbrotation: Orange → Blau → Gruen (wiederholt) */
.ssg-news-timeline .ssg-news-item:nth-child(3n+1) .ssg-news-dot { background: var(--ssg-amber); }
.ssg-news-timeline .ssg-news-item:nth-child(3n+2) .ssg-news-dot { background: var(--ssg-blue); }
.ssg-news-timeline .ssg-news-item:nth-child(3n)   .ssg-news-dot { background: var(--ssg-green); }

/* SVG-Connector: Mobile versteckt, Desktop positioniert */
.ssg-news-timeline .ssg-news-connector {
  display: none;
}

.ssg-news-timeline .ssg-news-content {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ssg-news-timeline .ssg-news-date {
  font-family: 'Ubuntu', sans-serif;
  font-size: var(--ssg-fs-small);
  font-weight: 400;
  color: #8a8a8a;
  line-height: 1.4;
}

.ssg-news-timeline .ssg-news-title {
  font-family: 'Ubuntu', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--ssg-blue-dark);
  line-height: 1.4;
  text-decoration: none;
  transition: color 0.2s ease;
}

.ssg-news-timeline .ssg-news-title:hover,
.ssg-news-timeline .ssg-news-title:focus {
  color: var(--ssg-green);
  text-decoration: none;
}

.ssg-news-empty {
  color: #8a8a8a;
  font-size: 14px;
  margin: 0;
}

/* -- Mobile (<768px): Feinjustierung -- */
@media (max-width: 767px) {
  .ssg-news-timeline .ssg-news-item {
    grid-template-columns: 12px 1fr;
    gap: 12px;
    padding: 12px 0;
  }
  .ssg-news-timeline .ssg-news-dot {
    width: 8px;
    height: 8px;
    margin-top: 7px;
  }
  .ssg-news-timeline .ssg-news-title { font-size: 14px; }
  .ssg-news-timeline .ssg-news-date  { font-size: 12px; }
}

/* -- Desktop/Tablet (>=768px): Horizontale Timeline mit Connectors -- */
@media (min-width: 768px) {
  /* Container bekommt min-height + relative Positionierung */
  .ssg-news-timeline {
    display: block;
    position: relative;
    min-height: 240px;
    padding: 0 20px 60px;
  }

  /* Der innere SPPB-Content-Wrapper wird das Grid */
  .ssg-news-timeline .sppb-addon-content {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    position: relative;
    min-height: 180px;
  }

  /* Horizontale Grundlinie (am Container, nicht am Content-Wrapper) */
  .ssg-news-timeline::before {
    content: '';
    position: absolute;
    left: 20px;
    right: 20px;
    bottom: 60px;
    height: 2px;
    background: #e0e0e0;
    z-index: 0;
  }

  .ssg-news-timeline .ssg-news-item {
    position: relative;
    display: block;
    padding: 0;
    border: none;
    grid-template-columns: none;
    min-height: 180px;
  }

  .ssg-news-timeline .ssg-news-item:last-child,
  .ssg-news-timeline .ssg-news-item:first-child {
    border: none;
    padding: 0;
  }

  /* Punkt sitzt unten am Item, auf Grundlinie */
  .ssg-news-timeline .ssg-news-dot {
    position: absolute;
    bottom: -7px;
    left: 20px;
    width: 14px;
    height: 14px;
    margin: 0;
    z-index: 2;
  }

  /* Schraeger SVG-Connector */
  .ssg-news-timeline .ssg-news-connector {
    display: block;
    position: absolute;
    bottom: 7px;
    left: 34px;
    width: 80px;
    height: 65px;
    z-index: 1;
    pointer-events: none;
    color: var(--ssg-green);
  }

  /* Farbrotation: Punkt UND Connector */
  .ssg-news-timeline .ssg-news-item:nth-child(3n+1) .ssg-news-dot       { background: var(--ssg-amber); }
  .ssg-news-timeline .ssg-news-item:nth-child(3n+1) .ssg-news-connector { color: var(--ssg-amber); }
  .ssg-news-timeline .ssg-news-item:nth-child(3n+2) .ssg-news-dot       { background: var(--ssg-blue); }
  .ssg-news-timeline .ssg-news-item:nth-child(3n+2) .ssg-news-connector { color: var(--ssg-blue); }
  .ssg-news-timeline .ssg-news-item:nth-child(3n)   .ssg-news-dot       { background: var(--ssg-green); }
  .ssg-news-timeline .ssg-news-item:nth-child(3n)   .ssg-news-connector { color: var(--ssg-green); }

  /* Content-Block oberhalb des Connector-Endes */
  .ssg-news-timeline .ssg-news-content {
    position: absolute;
    bottom: 75px;
    left: 105px;
    max-width: 160px;
    gap: 4px;
  }

  .ssg-news-timeline .ssg-news-date {
    font-size: 12px;
  }

  .ssg-news-timeline .ssg-news-title {
    font-size: 14px;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
}
/* -- Tablet (768–991px): Feinjustierung -- */
@media (min-width: 768px) and (max-width: 991px) {
  .ssg-news-timeline {
    min-height: 200px;
    padding: 0 16px 50px;
  }
  .ssg-news-timeline .sppb-addon-content {
    min-height: 150px;
  }
  .ssg-news-timeline .ssg-news-item {
    min-height: 150px;
  }
  .ssg-news-timeline .ssg-news-dot {
    bottom: -6px;
    width: 12px;
    height: 12px;
  }
  .ssg-news-timeline .ssg-news-connector {
    bottom: 6px;
    left: 32px;
    width: 65px;
    height: 55px;
  }
  .ssg-news-timeline .ssg-news-content {
    bottom: 65px;
    left: 90px;
    max-width: 130px;
  }
  .ssg-news-timeline .ssg-news-date  { font-size: 11px; }
  .ssg-news-timeline .ssg-news-title { font-size: var(--ssg-fs-small); }
}

.ssg-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 1.5rem;
}

.ssg-filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid var(--ssg-blue-dark);
  background: transparent;
  color: var(--ssg-blue-dark);
  font-size: 14px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}

.ssg-filter-chip--active {
  background: var(--ssg-blue-dark);
  color: #fff;
}

.ssg-filter-count {
  font-size: 11px;
  opacity: 0.65;
}

.ssg-no-results {
  color: var(--ssg-text-muted);
  font-style: italic;
  padding: 1rem 0;
}

.ssg-filter-chip:hover:not(.ssg-filter-chip--active) {
  background: #e8ecf5;
}

/* ============================================================
   NEWS MODULE — ssg-news-section
   Override: mod_articles_category / ssg_news_cards + ssg_news_list
   Stand: 2026-05-06
   ============================================================ */

/* ── Gemeinsame Basis ────────────────────────────────────────── */
.ssg-news-section {
  width: 100%;
}

.ssg-news-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 24px;
}

.ssg-news-header-left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.ssg-news-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: 28px;
  color: var(--ssg-blue-dark, #002364);
  margin: 0 0 4px 0;
}

.ssg-news-all-btn {
  white-space: nowrap;
}

/* ── Variante A: Card-Grid (Startseite) ──────────────────────── */
.ssg-news-section--cards .ssg-news-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.ssg-news-card {
  position: relative;
  background: var(--ssg-bg-white);
  border: 0.5px solid var(--ssg-border);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.18s, transform 0.18s;
}

.ssg-news-card:hover {
  box-shadow: 0 4px 18px rgba(0, 35, 100, 0.12);
  transform: translateY(-2px);
}

.ssg-news-card-link {
  display: block;
}

.ssg-news-card-image {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

/* aspect-ratio fallback für ältere Browser */
@supports not (aspect-ratio: 1) {
  .ssg-news-card-image {
    padding-bottom: 56.25%;
    height: 0;
    position: relative;
  }
  .ssg-news-card-image img {
    position: absolute;
    inset: 0;
  }
}

.ssg-news-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}

.ssg-news-card:hover .ssg-news-card-image img {
  transform: scale(1.04);
}

.ssg-news-card-image--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
}

.ssg-news-card-image-accent {
  width: 48px;
  height: 4px;
  border-radius: 2px;
  opacity: 0.7;
}

.ssg-news-card-body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}

.ssg-news-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.ssg-news-card-badge {
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 999px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  white-space: nowrap;
}

.ssg-news-card-date {
  font-size: 12px;
  color: var(--ssg-text-light);
}

.ssg-news-card-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.4;
  margin: 0;
  flex: 1;
}

.ssg-news-card-title a {
  color: var(--ssg-blue-dark, #002364);
  text-decoration: none;
}

.ssg-news-card-title a:hover {
  color: var(--ssg-blue, #006EE1);
}

.ssg-news-card-excerpt {
  font-size: var(--ssg-fs-body);
  color: #555;
  line-height: 1.55;
  margin: 0;
}

.ssg-news-card-readmore {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--ssg-fs-small);
  font-weight: 700;
  text-decoration: none;
  margin-top: auto;
}

.ssg-news-card-readmore:hover {
  text-decoration: underline;
}

.ssg-news-card-accent-bar {
  height: 3px;
  width: 100%;
  flex-shrink: 0;
}

.ssg-news-section--cards .ssg-news-footer-btn {
  text-align: center;
  margin-top: 32px;
}

.ssg-news-all-btn {
  display: inline-block;
  padding: 12px 40px;
  border: 2px solid var(--ssg-blue-dark, #002364);
  border-radius: 8px;
  color: var(--ssg-blue-dark, #002364);
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  background: transparent;
  transition: background .2s, color .2s;
}

.ssg-news-all-btn:hover {
  background: var(--ssg-blue-dark, #002364);
  color: #fff;
}

/* ── Variante A: Mobile (horizontal scroll + Stack) ─────────── */
@media (max-width: 991px) {
  .ssg-news-section--cards .ssg-news-cards-grid {
    grid-template-columns: repeat(2, minmax(260px, 1fr));
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px;
    scrollbar-width: thin;
    gap: 16px;
  }

  .ssg-news-card {
    scroll-snap-align: start;
  }

  .ssg-news-all-btn {
    display: none;
  }

  .ssg-news-section--cards .ssg-news-footer-btn {
    display: block;
  }
}

@media (max-width: 767px) {
  .ssg-news-section--cards .ssg-news-cards-grid {
    grid-template-columns: repeat(2, minmax(240px, 1fr));
  }
}

@media (max-width: 479px) {
  .ssg-news-section--cards .ssg-news-cards-grid {
    grid-template-columns: minmax(260px, 90vw);
  }
}

/* ── Variante B: List mit Seitenstreifen (Fachschaft) ────────── */
.ssg-news-section--list .ssg-news-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ssg-news-list-item {
  display: flex;
  align-items: stretch;
  background: var(--ssg-bg-white);
  border: 0.5px solid var(--ssg-border);
  border-radius: 8px;
  overflow: hidden;
  transition: box-shadow 0.15s;
}

.ssg-news-list-item:hover {
  box-shadow: 0 2px 10px rgba(0, 35, 100, 0.1);
}

.ssg-news-list-stripe {
  width: 4px;
  flex-shrink: 0;
}

.ssg-news-list-body {
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-width: 0;
}

.ssg-news-list-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.ssg-news-list-badge {
  font-size: 11px;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 999px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  white-space: nowrap;
}

.ssg-news-list-date {
  font-size: 12px;
  color: var(--ssg-text-light);
}

.ssg-news-list-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: var(--ssg-fs-small);
  line-height: 1.4;
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ssg-news-list-title a {
  color: var(--ssg-blue-dark, #002364);
  text-decoration: none;
}

.ssg-news-list-title a:hover {
  color: var(--ssg-blue, #006EE1);
}

.ssg-news-list-footer {
  margin-top: 12px;
}

.ssg-news-list-all-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--ssg-fs-small);
  font-weight: 700;
  color: var(--ssg-blue, #006EE1);
  text-decoration: none;
}

.ssg-news-list-all-link:hover {
  text-decoration: underline;
}

@media (max-width: 767px) {
  .ssg-news-list-title {
    white-space: normal;
  }
}
/* ── News-Header: Accent, Label, Title ── */
.ssg-section-accent {
  display: block;
  width: 32px;
  height: 3px;
  background: var(--ssg-green, #76B900);
  border-radius: 2px;
  margin-bottom: 8px;
}

.ssg-section-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ssg-green, #76B900);
}

.ssg-section-description {
  font-size: 15px;
  color: #6b7280;
  margin: 6px 0 0 0;
}

.ssg-section-title {
  font-family: Ubuntu, sans-serif;
  font-weight: 700;
  font-size: 28px;
  color: var(--ssg-blue-dark, #002364);
  margin: 4px 0 0 0;
}

/* ============================================================
   ARTIKEL-EINZELANSICHT (com_content / article / default.php)
   ============================================================ */

/* Breadcrumb */
.ssg-art-breadcrumb {
  font-size: var(--ssg-fs-small);
  color: #6b7280;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
}
.ssg-art-breadcrumb a {
  color: #6b7280;
  text-decoration: none;
}
.ssg-art-breadcrumb a:hover { color: var(--ssg-blue, #006EE1); }
.ssg-art-breadcrumb-sep { color: #c0c5cf; margin: 0 2px; }
.ssg-art-breadcrumb-current {
  color: var(--ssg-blue, #006EE1);
  font-weight: 700;
}

/* Header-Block (weißer Bereich über dem Bild) */
.ssg-art-header { margin-bottom: 24px; }

/* Badge + Meta Zeile */
.ssg-art-badge-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.ssg-art-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  font-family: 'Ubuntu', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #7A5500;
  background: #FFF3CC;
  border: 1.5px solid var(--ssg-amber);
  border-radius: 999px;
  padding: 4px 12px;
  line-height: 1;
}
.ssg-art-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ssg-amber);
  flex-shrink: 0;
}
.ssg-art-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: var(--ssg-fs-small);
  color: rgba(0,0,0,0.45);
  flex-wrap: wrap;
}
.ssg-art-meta-item {
  display: flex;
  align-items: center;
  gap: 5px;
}
.ssg-art-meta svg { flex-shrink: 0; vertical-align: middle; }

/* Titel */
.ssg-art-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.1;
  color: var(--ssg-blue-dark);
  margin: 12px 0 16px 0;
}

/* Autorenzeile */
.ssg-art-author {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 28px;
}
.ssg-art-author-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--ssg-blue-dark);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  font-family: 'Ubuntu', sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ssg-art-author-info { display: flex; flex-direction: column; line-height: 1.3; }
.ssg-art-author-name { font-weight: 700; font-size: 14px; color: #1a1a2e; }
.ssg-art-author-school { font-size: 12px; color: rgba(0,0,0,0.45); }

/* Hero-Bild */
.ssg-art-hero {
  width: 100%;
  aspect-ratio: 16 / 8;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  margin-bottom: 32px;
  background: #dce1ec;
  max-width: 100%;
}
.ssg-art-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ssg-art-hero-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 40%;
  background: linear-gradient(to top, rgba(0,35,100,0.18), transparent);
  pointer-events: none;
}
@media (max-width: 575px) {
  .ssg-art-hero { aspect-ratio: 16 / 9; border-radius: 8px; }
}

/* Artikel-Body */
.ssg-art-body {
  font-size: 16px;
  line-height: 1.75;
  color: #1a1a2e;
  margin-bottom: 32px;
}
.ssg-art-body p { margin: 0 0 1.2em 0; }

/* Tags + Drucken-Button */
.ssg-art-footer-tags {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding-bottom: 20px;
  border-bottom: 1px solid #eaeaea;
  margin-bottom: 40px;
}
.ssg-art-tags-left {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.ssg-art-tags-label {
  font-size: var(--ssg-fs-meta);
  color: rgba(0,0,0,0.45);
  white-space: nowrap;
}
.ssg-art-tag {
  display: inline-block;
  font-size: 0.82rem;
  color: #1a1a2e;
  background: var(--ssg-bg-white);
  border: 1px solid rgba(0,0,0,0.15);
  border-radius: 20px;
  padding: 4px 14px;
  text-decoration: none;
  transition: background 0.15s, border-color 0.15s;
}
.ssg-art-tag:hover {
  background: #f5f5f5;
  border-color: rgba(0,0,0,0.25);
  color: #1a1a2e;
  text-decoration: none;
}
.ssg-art-print-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: var(--ssg-blue-dark);
  background: var(--ssg-bg-white);
  border: 1px solid var(--ssg-blue-dark);
  border-radius: 6px;
  padding: 8px 20px;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.ssg-art-print-btn:hover {
  background: #f0f3fa;
  color: var(--ssg-blue-dark);
  text-decoration: none;
}

/* Ähnliche Beiträge */
.ssg-art-related { margin-top: 8px; }
.ssg-art-related-header { margin-bottom: 0; }
.ssg-art-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 28px;
}
@media (min-width: 768px) and (max-width: 991px) {
  .ssg-art-related-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .ssg-art-related-grid { grid-template-columns: 1fr; gap: 16px; }
  .ssg-art-footer-tags { flex-direction: column; align-items: flex-start; }
  .ssg-art-title { font-size: 1.75rem; }
}

/* Zweispaltiges Layout: Body + Sidebar */
.ssg-art-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 32px;
  align-items: start;
  margin-bottom: 32px;
}
.ssg-art-main { min-width: 0; }
.ssg-art-body { margin-bottom: 0; }

/* Sidebar */
.ssg-art-sidebar {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: sticky;
  top: 100px;
}
.ssg-art-sidebar-box {
  background: #f8f8f6;
  border-radius: 10px;
  padding: 20px;
}
.ssg-art-sidebar-label {
  font-size: 11px;
  font-weight: 700;
  font-family: 'Ubuntu', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ssg-green, #76B900);
  margin-bottom: 14px;
}

/* Artikel-Info Liste */
.ssg-art-info-list {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ssg-art-info-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.ssg-art-info-row dt {
  font-size: var(--ssg-fs-meta);
  color: rgba(0,0,0,0.45);
  min-width: 72px;
  flex-shrink: 0;
}
.ssg-art-info-row dd {
  font-size: var(--ssg-fs-small);
  font-weight: 600;
  color: #1a1a2e;
  margin: 0;
}

/* Share-Buttons */
.ssg-art-share-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.ssg-art-share-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  background: var(--ssg-bg-white);
  border: 1px solid var(--ssg-border);
  border-radius: 8px;
  font-size: var(--ssg-fs-small);
  font-family: inherit;
  color: #1a1a2e;
  text-decoration: none;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  white-space: nowrap;
}
.ssg-art-share-btn:hover {
  border-color: #c0c5cf;
  background: #f5f5f5;
  color: #1a1a2e;
  text-decoration: none;
}
.ssg-art-share-btn--copied {
  border-color: var(--ssg-green, #76B900);
  color: var(--ssg-green, #76B900);
}
.ssg-art-share-btn--native {
  grid-column: 1 / -1;
}

/* Drucken in Sidebar */
.ssg-art-print-btn--sidebar {
  width: 100%;
  justify-content: center;
}

/* Mobile: Sidebar unter dem Body */
@media (max-width: 991px) {
  .ssg-art-layout {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .ssg-art-sidebar {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .ssg-art-sidebar-box { flex: 1 1 220px; }
  .ssg-art-print-btn--sidebar { flex: 1 1 100%; }
}

/* ============================================================
   NEWS ÜBERSICHT — ssg-news-overview
   Override: com_content/category/blog.php
   Stand: 2026-05-15
   ============================================================ */

/* Container */
.ssg-news-overview {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 16px 40px;
}

/* ── Kopfbereich ──────────────────────────────────────────────────────────── */
.ssg-page-header { margin-bottom: 24px; }

.ssg-ph-eyebrow {
  display: block;
  position: relative;
  padding-left: 12px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--ssg-green);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.ssg-ph-eyebrow::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 14px;
  background: var(--ssg-green);
  border-radius: 2px;
}
.ssg-ph-title {
  font-size: 32px;
  font-weight: 700;
  color: var(--ssg-blue-dark);
  line-height: 1.15;
  margin: 0 0 6px;
}
.ssg-ph-sub {
  font-size: 14px;
  color: var(--ssg-text-muted);
  margin: 0;
}
@media (max-width: 768px) {
  .ssg-ph-title { font-size: 24px; }
}

/* ── Filterleiste ─────────────────────────────────────────────────────────── */
.ssg-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 16px;
}
.ssg-dropdown {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--ssg-bg-white);
  border: 1.5px solid var(--ssg-border);
  border-radius: 6px;
  padding: 6px 12px;
  cursor: pointer;
  white-space: nowrap;
}
.ssg-dropdown.is-active {
  border-color: var(--ssg-blue-dark);
  background: #eef2fb;
}
.ssg-dropdown--right { margin-left: auto; }
.ssg-dropdown .label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--ssg-text-light);
  text-transform: uppercase;
}
.ssg-dropdown .val {
  font-size: 14px;
  font-weight: 600;
  color: var(--ssg-blue-dark);
}
.ssg-dropdown .chev {
  font-size: 11px;
  color: var(--ssg-blue-dark);
}
.ssg-select-overlay {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  opacity: 0;
  cursor: pointer;
}
@media (max-width: 768px) {
  .ssg-filter-bar { flex-direction: column; align-items: stretch; }
  .ssg-dropdown { width: 100%; }
  .ssg-dropdown--right { margin-left: 0; }
}

/* ── Aktive Filter-Pills ─────────────────────────────────────────────────── */
.ssg-active-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 12px;
}
.ssg-active-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #eef2fb;
  border: 1px solid #c5d0e8;
  border-radius: 999px;
  padding: 4px 12px;
  font-size: var(--ssg-fs-small);
  font-weight: 600;
  color: var(--ssg-blue-dark);
  text-decoration: none;
}
.ssg-active-pill__x { color: var(--ssg-text-muted); font-size: 15px; }
.ssg-active-pill--reset {
  background: none;
  border: none;
  padding: 4px 0;
  font-size: var(--ssg-fs-small);
  color: var(--ssg-text-muted);
  text-decoration: underline;
  margin-left: 4px;
}
.ssg-active-pill--reset:hover { color: var(--ssg-blue-dark); }

/* ── Ergebniszeile ────────────────────────────────────────────────────────── */
.ssg-result-count {
  font-size: 12px;
  color: var(--ssg-text-light);
  margin-bottom: 12px;
}

/* ── Kategorie-Farbpalette ────────────────────────────────────────────────── */
.ssg-cat--schulleben { --cat-accent: #6B8CAE; --cat-bg: #EEF2F6; --cat-text: #2D4A6B; }
.ssg-cat--abitur     { --cat-accent: #002364; --cat-bg: #E6E9F0; --cat-text: #001440; }
.ssg-cat--anmeldung  { --cat-accent: #F8AC00; --cat-bg: #FFF3CC; --cat-text: #7A5500; }
.ssg-cat--sprachen   { --cat-accent: #006EE1; --cat-bg: #D6E8FB; --cat-text: #0C447C; }
.ssg-cat--mint       { --cat-accent: #76B900; --cat-bg: #EAF3DE; --cat-text: #3B6D11; }
.ssg-cat--musisch    { --cat-accent: #F8AC00; --cat-bg: #FFF3CC; --cat-text: #7A5500; }
.ssg-cat--sport      { --cat-accent: #002364; --cat-bg: #E6E9F0; --cat-text: #001440; }
.ssg-cat--sv         { --cat-accent: #002364; --cat-bg: #E6E9F0; --cat-text: #001440; }
.ssg-cat--default    { --cat-accent: #6B8CAE; --cat-bg: #EEF2F6; --cat-text: #2D4A6B; }

/* ── Artikelliste ─────────────────────────────────────────────────────────── */
.ssg-news-overview .ssg-news-list {
  border: 0.5px solid var(--ssg-border);
  border-radius: 10px;
  overflow: hidden;
  padding: 0;
  margin-bottom: 24px;
}
.ssg-news-overview .ssg-news-item {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 0;
  padding: 0;
  border-bottom: 0.5px solid var(--ssg-border);
  text-decoration: none;
  color: inherit;
  background: var(--ssg-bg-white);
  transition: background .1s;
}
.ssg-news-overview .ssg-news-item:last-child { border-bottom: none; }
.ssg-news-overview .ssg-news-item:hover { background: #f8f9fc; }

/* Thumbnail */
.ssg-news-overview .ssg-news-thumb {
  width: 80px;
  height: 80px;
  flex-shrink: 0;
  overflow: hidden;
  align-self: stretch;
  display: flex;
  align-items: stretch;
}
.ssg-news-overview .ssg-news-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ssg-news-thumb--placeholder {
  width: 80px;
  min-height: 80px;
  background: var(--cat-accent, #6B8CAE);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  flex-shrink: 0;
}

/* Inhalt */
.ssg-news-content {
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.ssg-news-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  align-items: center;
}
.ssg-news-cat-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 4px;
  padding: 2px 8px;
  background: var(--cat-bg, #EEF2F6);
  color: var(--cat-text, #2D4A6B);
  white-space: nowrap;
}
.ssg-news-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  border-radius: 4px;
  padding: 2px 8px;
  background: var(--cat-bg, #EEF2F6);
  color: var(--cat-text, #2D4A6B);
  border: 0.5px solid currentColor;
  opacity: .85;
}
.ssg-news-overview .ssg-news-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--ssg-blue);
  margin: 0;
  line-height: 1.35;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.ssg-news-teaser {
  font-size: 13px;
  color: #555;
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.ssg-news-overview .ssg-news-meta {
  font-size: 12px;
  color: var(--ssg-text-light);
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: auto;
  padding-top: 4px;
  flex-wrap: wrap;
}
.ssg-news-overview .ssg-news-meta .dot { color: var(--ssg-border); }
.ssg-news-overview .ssg-news-readmore {
  margin-left: auto;
  font-size: 12px;
  font-weight: 600;
  color: var(--ssg-blue);
  text-decoration: none;
  white-space: nowrap;
}

/* Leer-Zustand */
.ssg-news-empty {
  font-size: var(--ssg-fs-small);
  color: var(--ssg-text-muted);
  padding: 32px 16px;
  text-align: center;
}
.ssg-news-empty a { color: var(--ssg-blue); }

/* ── Pagination ───────────────────────────────────────────────────────────── */
.ssg-pagination { margin-top: 24px; }
.ssg-news-overview .pagination,
.ssg-pagination .pagination {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 4px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.ssg-news-overview .pagination .page-item .page-link,
.ssg-pagination .pagination .page-item .page-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 8px;
  border: 0.5px solid var(--ssg-border);
  border-radius: 6px;
  font-size: var(--ssg-fs-small);
  color: #333;
  text-decoration: none;
  background: var(--ssg-bg-white);
  transition: background .12s, border-color .12s;
}
.ssg-news-overview .pagination .page-item .page-link:hover,
.ssg-pagination .pagination .page-item .page-link:hover {
  background: var(--ssg-bg-gray);
  border-color: var(--ssg-blue-dark);
}
.ssg-news-overview .pagination .page-item.active .page-link,
.ssg-pagination .pagination .page-item.active .page-link {
  background: var(--ssg-blue-dark);
  color: #fff;
  border-color: var(--ssg-blue-dark);
}
.ssg-news-overview .pagination .page-item.disabled .page-link,
.ssg-pagination .pagination .page-item.disabled .page-link {
  color: #ccc;
  pointer-events: none;
}

/* ================================================================
   SSG HEADER — headers/ssg/header.php — 2026-05-08
   ================================================================ */

/* =================================================================
   SSG Header — Sophie-Scholl-Gymnasium Oberhausen
   Standalone-Stylesheet. Alle Selektoren sind mit .ssg- gepräfixt,
   damit nichts mit bestehenden Styles kollidiert.
   ================================================================= */

/* ── Designtokens ───────────────────────────────────────────────── */
.ssg-header,
.ssg-header *,
.ssg-header *::before,
.ssg-header *::after{
  box-sizing:border-box;
  margin:0;
  padding:0;
}

.ssg-header{
  /* Nur header-spezifische Abweichungen von :root (keine Duplikate!) */
  --ssg-blue-deep:  #001847;              /* kein :root-Äquivalent          */
  --ssg-text:       #2b2b2b;             /* etwas dunkler als :root (#444)  */
  --ssg-page:       var(--ssg-bg-gray);  /* Alias auf Design-System-Grau    */
  --ssg-fs-body:    13px;               /* kompakte Navigation, kein 16px  */

  --ssg-container:  1200px;
  --ssg-pad-x:      28px;

  position:sticky;
  top:0;
  z-index:200;
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',sans-serif;
  -webkit-font-smoothing:antialiased;
  transition:box-shadow .3s ease;
}
.ssg-header.is-scrolled{
  box-shadow:0 2px 16px rgba(0,35,100,.16);
}

/* Container */
.ssg-container{
  max-width:var(--ssg-container);
  margin:0 auto;
  padding:0 var(--ssg-pad-x);
}

/* ── Topbar ─────────────────────────────────────────────────────── */
.ssg-topbar{
  background:var(--ssg-blue-dark);
  color:rgba(255,255,255,.78);
  font-size:.78rem;
  padding:7px 0;
  border-bottom:3px solid var(--ssg-green);
}
.ssg-topbar-inner{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:20px;
  padding-left:16px;
  padding-right:16px;
}
.ssg-topbar-item{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:rgba(255,255,255,.78);
}
.ssg-topbar-item a{
  color:inherit;
  text-decoration:none;
}
.ssg-topbar-item a:hover{
  color:#fff;
  text-decoration:underline;
}
.ssg-topbar-links{
  margin-left:auto;
  display:flex;
  gap:6px;
  padding-right:8px;
}
.ssg-topbar-link{
  color:#fff;
  font-family:'Ubuntu',sans-serif;
  font-weight:700;
  letter-spacing:.06em;
  font-size:.72rem;
  text-transform:uppercase;
  text-decoration:none;
  padding:4px 12px;
  border:1px solid rgba(255,255,255,.28);
  border-radius:4px;
  transition:background .15s, border-color .15s;
}
.ssg-topbar-link:hover{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.55);
}
.ssg-icon{
  width:11px;
  height:11px;
  flex-shrink:0;
}

/* ── Navigationsleiste ──────────────────────────────────────────── */
.ssg-nav{
  background:linear-gradient(180deg, #fafafa 0%, #ffffff 60%);
  color:var(--ssg-blue);
  border-bottom:1px solid var(--ssg-border);
}
.ssg-nav-inner{
  display:flex;
  align-items:center;
  min-height:72px;
  gap:18px;
  position:relative;
}

/* Logo + Brand-Text */
.ssg-brand{
  display:flex;
  align-items:center;
  gap:18px;
  text-decoration:none;
  flex-shrink:0;
  position:relative;
  align-self:stretch;
}
.ssg-logo-wrap{
  display:flex;
  align-items:flex-start;
  position:relative;
  flex-shrink:0;
  margin-top:8px;
  margin-bottom:-60px;
  z-index:2;
}
.ssg-logo{
  height:148px;
  width:auto;
  display:block;
  filter:drop-shadow(0 4px 8px rgba(0,35,100,.12));
}
.ssg-brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.2;
  gap:2px;
}
.ssg-brand-title{
  font-family:'Ubuntu',sans-serif;
  font-weight:700;
  font-size:1.45rem;
  color:var(--ssg-blue-dark);
  letter-spacing:-.005em;
  white-space:nowrap;
}
.ssg-brand-sub{
  font-size:.88rem;
  color:var(--ssg-text-muted);
  letter-spacing:.01em;
}

/* Desktop-Menü */
.ssg-menu{
  list-style:none;
  display:flex;
  align-items:center;
  margin-left:auto;
  gap:1px;
}
.ssg-menu-item{
  position:relative;
}
.ssg-menu-link{
  display:flex;
  align-items:center;
  gap:4px;
  color:var(--ssg-blue-dark);
  padding:8px 11px;
  border-radius:4px;
  font-size:16px;
  font-family:'Ubuntu',sans-serif;
  font-weight:500;
  text-decoration:none;
  background:transparent;
  transition:background .15s, color .15s;
  cursor:pointer;
  white-space:nowrap;
}
.ssg-menu-item:hover > .ssg-menu-link,
.ssg-menu-item:focus-within > .ssg-menu-link{
  background:var(--ssg-page);
  color:var(--ssg-blue);
}
.ssg-chev{
  width:10px;
  height:10px;
  opacity:.5;
  margin-top:1px;
  transition:transform .15s;
}
.ssg-menu-item:hover > .ssg-menu-link .ssg-chev,
.ssg-menu-item:focus-within > .ssg-menu-link .ssg-chev{
  transform:rotate(180deg);
}

/* Submenü (Dropdown) */
.ssg-submenu{
  position:absolute;
  top:100%;
  left:0;
  min-width:190px;
  background:var(--ssg-bg-white);
  border-radius:8px;
  border:.5px solid var(--ssg-border);
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  padding:6px 0;
  list-style:none;
  z-index:300;
  opacity:0;
  visibility:hidden;
  transform:translateY(-4px);
  pointer-events:none;
  transition:opacity .15s ease, transform .15s ease, visibility .15s;
}
.ssg-has-sub:hover > .ssg-submenu,
.ssg-has-sub:focus-within > .ssg-submenu{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}
.ssg-submenu a{
  display:block;
  padding:8px 16px;
  color:var(--ssg-text);
  font-size:.85rem;
  text-decoration:none;
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  transition:background .12s;
}
.ssg-submenu a:hover,
.ssg-submenu a:focus{
  background:var(--ssg-page);
}

/* Suchbutton */
.ssg-search-item{
  margin-left:2px;
}
.ssg-search-btn{
  background:none;
  border:none;
  color:var(--ssg-blue);
  cursor:pointer;
  padding:8px 10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:4px;
  transition:color .15s, background .15s;
}
.ssg-search-btn:hover{
  background:var(--ssg-page);
}
.ssg-search-btn svg{
  width:15px;
  height:15px;
}

/* ── Mega-Menü ────────────────────────────────────────────────── */
.ssg-has-mega{position:static}
.ssg-mega{
  position:absolute;
  top:100%;
  left:var(--ssg-pad-x);
  right:var(--ssg-pad-x);
  transform:translateY(-4px);
  width:auto;
  max-width:980px;
  margin-left:auto;
  margin-right:0;
  background:var(--ssg-bg-white);
  border:.5px solid var(--ssg-border);
  border-radius:10px;
  box-shadow:0 14px 40px rgba(0,35,100,.14), 0 2px 6px rgba(0,0,0,.04);
  padding:0;
  z-index:300;
  overflow:hidden;
  opacity:0;
  visibility:hidden;
  transition:opacity .18s ease .35s, transform .18s ease .35s, visibility 0s linear .55s;
}
.ssg-mega::after{
  content:"";
  position:absolute;
  top:-12px;
  left:0;
  right:0;
  height:12px;
}
.ssg-mega::before{
  content:"";
  display:block;
  height:3px;
  background:linear-gradient(90deg, var(--ssg-green) 0%, var(--ssg-blue) 100%);
}
.ssg-has-mega:hover > .ssg-mega,
.ssg-has-mega:focus-within > .ssg-mega{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
  transition:opacity .18s ease 0s, transform .18s ease 0s, visibility 0s linear 0s;
}
.ssg-mega-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  padding:24px 8px;
}
.ssg-mega-col{
  padding:6px 24px;
  border-right:1px solid var(--ssg-border);
}
.ssg-mega-col:last-child{
  border-right:none;
}
.ssg-mega-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
  padding-bottom:10px;
  border-bottom:2px solid var(--ssg-page);
}
.ssg-mega-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:6px;
  background:var(--ssg-page);
  color:var(--ssg-blue);
  flex-shrink:0;
}
.ssg-mega-icon svg{
  width:18px;
  height:18px;
}
.ssg-mega-title{
  font-family:'Ubuntu',sans-serif;
  font-weight:700;
  font-size:.92rem;
  color:var(--ssg-blue);
  text-decoration:none;
  letter-spacing:.01em;
}
.ssg-mega-title:hover{
  color:var(--ssg-green);
}
.ssg-mega-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:1px;
}
.ssg-mega-list a{
  display:block;
  padding:8px 12px 8px 14px;
  margin:0 -12px;
  color:var(--ssg-text);
  font-size:.88rem;
  text-decoration:none;
  border-radius:6px;
  position:relative;
  transition:background .14s ease, color .14s ease, padding-left .18s ease;
}
.ssg-mega-list a::before{
  content:"";
  position:absolute;
  left:6px;
  top:50%;
  width:0;
  height:2px;
  background:var(--ssg-green);
  transform:translateY(-50%);
  transition:width .18s ease;
  border-radius:1px;
}
.ssg-mega-list a:hover,
.ssg-mega-list a:focus-visible{
  background:rgba(0,110,225,.08);
  color:var(--ssg-blue);
  padding-left:24px;
  font-weight:500;
}
.ssg-mega-list a:hover::before,
.ssg-mega-list a:focus-visible::before{
  width:12px;
}
.ssg-mega-foot{
  background:var(--ssg-page);
  padding:12px 32px;
  border-top:1px solid var(--ssg-border);
  display:flex;
  justify-content:flex-end;
}
.ssg-mega-foot-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'Ubuntu',sans-serif;
  font-weight:700;
  font-size:.82rem;
  color:var(--ssg-blue);
  text-decoration:none;
  letter-spacing:.02em;
}
.ssg-mega-foot-link svg{width:13px;height:13px}
.ssg-mega-foot-link:hover{color:var(--ssg-green)}
.ssg-mega-foot-link:hover svg{transform:translateX(2px);transition:transform .15s}

/* ── Mobile: verschachtelte Untermenüs ─────────────────────────── */
.ssg-mobile-nested{
  border-bottom:none;
  border-top:1px solid rgba(255,255,255,.06);
  margin-left:0;
}
.ssg-mobile-nested:first-of-type{
  border-top:none;
  margin-top:4px;
}
.ssg-mobile-sub-summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 0 10px 18px;
  color:rgba(255,255,255,.82);
  font-family:'Ubuntu',sans-serif;
  font-weight:500;
  font-size:.9rem;
  cursor:pointer;
  list-style:none;
}
.ssg-mobile-sub-summary::-webkit-details-marker{display:none}
.ssg-mobile-nested[open] > .ssg-mobile-sub-summary .ssg-chev{
  transform:rotate(180deg);
}
.ssg-mobile-subsublink{
  display:block;
  padding:8px 0 8px 36px;
  color:rgba(255,255,255,.65);
  font-size:.84rem;
  text-decoration:none;
  position:relative;
}
.ssg-mobile-subsublink::before{
  content:"";
  position:absolute;
  left:24px;
  top:50%;
  width:6px;
  height:1px;
  background:rgba(255,255,255,.3);
}
.ssg-mobile-subsublink:hover{
  color:#fff;
}

/* ── Mobile-Burger ──────────────────────────────────────────────── */
.ssg-burger{
  margin-left:auto;
  background:none;
  border:none;
  cursor:pointer;
  padding:8px;
  display:none;
  flex-direction:column;
  gap:5px;
}
.ssg-burger span{
  display:block;
  width:22px;
  height:2px;
  background:var(--ssg-blue);
  border-radius:1px;
  transition:transform .25s, opacity .25s;
}
.ssg-burger[aria-expanded="true"] span:nth-child(1){
  transform:rotate(45deg) translate(5px,5px);
}
.ssg-burger[aria-expanded="true"] span:nth-child(2){
  opacity:0;
}
.ssg-burger[aria-expanded="true"] span:nth-child(3){
  transform:rotate(-45deg) translate(5px,-5px);
}

/* ── Mobile-Menü ────────────────────────────────────────────────── */
.ssg-mobile-menu{
  background:var(--ssg-blue-deep);
  border-top:1px solid rgba(255,255,255,.08);
  max-height:0;
  overflow:hidden;
  transition:max-height .3s ease;
}
.ssg-mobile-menu[hidden]{
  display:block;
  max-height:0;
  border-top-width:0;
}
.ssg-mobile-menu.is-open{
  max-height:80vh;
  overflow-y:auto;
}
.ssg-mobile-menu .ssg-container{
  padding-top:8px;
  padding-bottom:8px;
}
.ssg-mobile-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 0;
  color:rgba(255,255,255,.85);
  border-bottom:1px solid rgba(255,255,255,.06);
  font-family:'Ubuntu',sans-serif;
  font-weight:500;
  font-size:.95rem;
  text-decoration:none;
  cursor:pointer;
  list-style:none;
}
.ssg-mobile-link::-webkit-details-marker{display:none}
.ssg-mobile-group{
  border-bottom:1px solid rgba(255,255,255,.06);
}
.ssg-mobile-group > .ssg-mobile-link{
  border-bottom:none;
}
.ssg-mobile-group[open] > .ssg-mobile-link .ssg-chev{
  transform:rotate(180deg);
}
.ssg-mobile-group .ssg-chev{
  color:rgba(255,255,255,.5);
  transition:transform .2s;
}
.ssg-mobile-sublink{
  display:block;
  padding:9px 0 9px 18px;
  color:rgba(255,255,255,.7);
  font-size:.88rem;
  text-decoration:none;
}
.ssg-mobile-sublink:hover{
  color:#fff;
}

/* ── Responsive ─────────────────────────────────────────────────── */
@media(max-width:1280px){
  .ssg-mega{max-width:none}
}

/* Burger erst unter 768px (echte Mobile). 768–991: vereinfachtes Desktop-Menue, ab 992: volles Mega. */
@media(max-width:767px){
  .ssg-menu{display:none}
  .ssg-burger{display:flex}
  .ssg-brand-title{font-size:1.2rem}
  .ssg-logo{height:120px}
  .ssg-logo-wrap{margin-bottom:-46px;margin-top:6px}
}
@media(max-width:700px){
  .ssg-header{--ssg-pad-x:18px}
  .ssg-topbar{font-size:.72rem}
  .ssg-topbar-item{gap:4px}
  .ssg-topbar-item:first-child{display:none}
  .ssg-nav-inner{min-height:64px;gap:12px}
  .ssg-logo{height:96px}
  .ssg-logo-wrap{margin-bottom:-34px;margin-top:4px}
  .ssg-brand{gap:12px}
  .ssg-brand-title{font-size:1rem;white-space:normal;line-height:1.15}
  .ssg-brand-sub{font-size:.78rem}
}
@media(max-width:420px){
  .ssg-brand-text{display:none}
}

/* Logo-Schrumpf beim Scrollen */
.ssg-header .ssg-logo { transition: height .3s ease; }
.ssg-header.is-scrolled .ssg-logo { height: 96px; }
.ssg-header.is-scrolled .ssg-logo-wrap { margin-bottom: -28px; }
@media (max-width: 767px) {
  .ssg-header.is-scrolled .ssg-logo { height: 80px; }
  .ssg-header.is-scrolled .ssg-logo-wrap { margin-bottom: -22px; }
}
@media (max-width: 700px) {
  .ssg-header.is-scrolled .ssg-logo { height: 64px; }
  .ssg-header.is-scrolled .ssg-logo-wrap { margin-bottom: -14px; }
}

/* Tablet-Tap (Touch-Geräte ohne Hover) */
.ssg-has-sub.is-tapped > .ssg-submenu,
.ssg-has-mega.is-tapped > .ssg-mega {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

/* ============================================================
   SSG Mega-Menü Design A — Master-Detail Panel
   Angelegt: 2026-05-09 | Version: 1.0
   Präfix ssg-mm- ist neu — kein Override bestehender Klassen.
   Farben: CSS-Variablen aus :root wo vorhanden.
   ============================================================ */

/* Breite-Override für Design-A-Variante */
.ssg-mega--design-a {
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

/* 3-Spalten-Grid: Rail | Detail | Promo */
.ssg-mm-grid {
  display: grid;
  grid-template-columns: 219px 1fr 1fr;
}

/* ---- Rail (links) ---- */
.ssg-mm-rail-col {
  background: var(--ssg-bg-gray);
  padding: 18px 10px;
  border-right: 1px solid var(--ssg-border);
}
.ssg-mm-rail-head {
  font-size: 11px;
  font-weight: 700;
  color: var(--ssg-text-muted);
  padding: 0 12px 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.ssg-mm-rail-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.ssg-mm-rail-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 9px 12px;
  font-family: 'Ubuntu', sans-serif;
  font-size: 14px;
  font-weight: 400;
  color: var(--ssg-text);
  background: transparent;
  border: none;
  border-left: 2px solid transparent;
  border-radius: 0 4px 4px 0;
  text-align: left;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.ssg-mm-rail-item:hover,
.ssg-mm-rail-item.is-active {
  background: var(--ssg-bg-white);
  color: var(--ssg-blue-dark);
  font-weight: 600;
  border-left-color: var(--ssg-green);
}
.ssg-mm-rail-text {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ssg-mm-rail-item svg {
  flex-shrink: 0;
  width: 14px;
  height: 14px;
  opacity: 0.3;
  transition: opacity 0.15s;
}
.ssg-mm-rail-item.is-active svg,
.ssg-mm-rail-item:hover svg {
  opacity: 1;
}

/* ---- Detail-Bereich (Mitte) ---- */
.ssg-mm-detail-area {
  position: relative;
}
.ssg-mm-detail-col {
  display: none;
  padding: 24px 28px;
}
.ssg-mm-detail-col.is-active {
  display: block;
}
.ssg-mm-eyebrow {
  font-size: 11px;
  font-weight: 700;
  color: var(--ssg-green);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 4px;
}
.ssg-mm-heading {
  font-family: 'Ubuntu', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--ssg-blue-dark);
  margin: 0 0 16px;
}
.ssg-mm-heading a {
  color: inherit;
  text-decoration: none;
}
.ssg-mm-heading a:hover {
  text-decoration: underline;
}
.ssg-mm-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.ssg-mm-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--ssg-bg-white);
  border: 0.5px solid var(--ssg-border);
  border-radius: 8px;
  text-decoration: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.ssg-mm-card:hover {
  border-color: var(--ssg-blue-dark);
  box-shadow: 0 2px 8px rgba(0, 35, 100, 0.08);
}
.ssg-mm-flag {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
  color: #ffffff;
}
.ssg-mm-card-body {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.ssg-mm-card-title {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--ssg-blue-dark);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ssg-mm-card-sub {
  font-size: 11.5px;
  color: var(--ssg-text-muted);
}

/* ---- Hero-Block (Rail-Item ohne Kinder, z.B. Schulleben) ---- */
.ssg-mm-hero {
  padding: 32px;
  max-width: 480px;
}
.ssg-mm-hero-title {
  font-family: 'Ubuntu Bold', system-ui, sans-serif;
  font-size: 22px;
  color: var(--ssg-blue-dark);
  margin: 0 0 12px;
}
.ssg-mm-hero-desc {
  font-size: 13px;
  line-height: 1.7;
  color: var(--ssg-text);
  margin: 0 0 20px;
}

/* ---- Leitsatz (mittlere Spalte, über der Linkliste) ---- */
.ssg-mm-lead {
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--ssg-text-muted);
  margin: -8px 0 16px;
  padding-left: 10px;
  border-left: 2px solid var(--ssg-green);
}

/* ---- Sub-Item-Liste (Rail-Item mit Kindern, nicht Fachkarten) ---- */
/* Zweispaltig: nutzt die Breite der Detail-Spalte besser aus (Top-Down-Fluss). */
.ssg-mm-sublist {
  list-style: none;
  margin: 0;
  padding: 0;
  columns: 2;
  column-gap: 14px;
}
.ssg-mm-sublist li {
  break-inside: avoid;
}
.ssg-mm-sublist-link {
  display: block;
  padding: 7px 10px;
  font-size: 13.5px;
  color: var(--ssg-text);
  text-decoration: none;
  border-radius: 5px;
  transition: background 0.12s, color 0.12s;
}
.ssg-mm-sublist-link:hover {
  background: var(--ssg-bg-gray);
  color: var(--ssg-blue-dark);
}

/* ---- Promo-Spalte (rechts) ---- */
.ssg-mm-promo-area {
  background: linear-gradient(135deg, var(--ssg-blue-dark) 0%, #003A9E 100%);
}
.ssg-mm-promo-col {
  display: none;
  flex-direction: column;
  gap: 10px;
  padding: 24px 28px;
  height: 100%;
  box-sizing: border-box;
}
.ssg-mm-promo-col.is-active {
  display: flex;
}
.ssg-mm-promo-eyebrow {
  font-size: 10px;
  font-weight: 700;
  color: var(--ssg-green);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
/* Schwerpunktprofil-Badge: hebt die drei Profile (BiLi/MINT/Musik) prominent hervor */
.ssg-mm-profil-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: 'Ubuntu', sans-serif;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #002364;
  background: var(--ssg-yellow, #F8AC00);
  padding: 5px 11px;
  border-radius: 999px;
  margin-bottom: 4px;
  box-shadow: 0 2px 8px rgba(248, 172, 0, 0.35);
}
/* Promo-Bild (oben im blauen Fenster, „Bild + Teaser + Link"-Variante) */
.ssg-mm-promo-col img {
  display: block;
  width: 100%;
  height: 96px;
  object-fit: cover;
  border-radius: 6px;
  margin-bottom: 4px;
}
/* Teaser-Badge (Pendant zum Profil-Badge, aber für Schulleben-Highlights) */
.ssg-mm-promo-badge {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  font-family: 'Ubuntu', sans-serif;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #002364;
  background: var(--ssg-yellow, #F8AC00);
  padding: 4px 10px;
  border-radius: 999px;
}
/* Modul-Inhalt: h3 + p + a (kein Klassen-Coupling) */
.ssg-mm-promo-col h3 {
  font-family: 'Ubuntu', sans-serif;
  font-size: 17px;
  font-weight: 700;
  color: #ffffff;
  margin: 0;
}
.ssg-mm-promo-col p {
  font-size: var(--ssg-fs-small);
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.85);
  margin: 0;
}
.ssg-mm-promo-col p strong {
  color: #ffffff;
}
.ssg-mm-promo-col a {
  font-size: var(--ssg-fs-small);
  font-weight: 600;
  color: #ffffff;
  text-decoration: none;
  margin-top: auto;
  padding-bottom: 2px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.4);
  align-self: flex-start;
  transition: border-color 0.15s;
}
.ssg-mm-promo-col a:hover {
  border-bottom-color: #ffffff;
}

/* ---- Footer ---- */
.ssg-mm-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 32px;
  background: var(--ssg-bg-gray);
  border-top: 1px solid var(--ssg-border);
}
.ssg-mm-footer-label {
  font-size: 11px;
  font-weight: 400;
  color: var(--ssg-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.ssg-mm-footer-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'Ubuntu', sans-serif;
  font-size: var(--ssg-fs-small);
  font-weight: 700;
  color: var(--ssg-blue-dark);
  text-decoration: none;
}
.ssg-mm-footer-cta svg {
  width: 13px;
  height: 13px;
}
.ssg-mm-footer-cta:hover {
  color: var(--ssg-green);
}

/* Mobile: Design A ausblenden — Bottom-Nav übernimmt */
@media (max-width: 768px) {
  .ssg-mega--design-a {
    display: none !important;
  }
}


/* === FOOTER FIXES 2026-05-10 === */

/* -- Problem 1: Footer-Menü ausblenden --
   bottom-tabs.js nutzt document.querySelector('.ssg-bottom-tabs') als
   JS-Selektor. Das Modul (mainmenu2 in Footer-Position) rendert Block 1
   (.ssg-main-nav – Desktop-Nav-Duplikat) und Block 2 (.ssg-bottom-tabs /
   .ssg-bottom-sheet – DOM-Quelle für die Mobile-Navigation).
   Block 2 bleibt im DOM (display:none entfernt aus dem Layout, nicht aus dem
   DOM – querySelector funktioniert trotzdem). Block 1 und .ssg-mega-overlay
   werden vollständig ausgeblendet. */
#sp-footer .ssg-main-nav,
#sp-footer .ssg-mega-overlay {
  display: none !important;
  height: 0;
  overflow: hidden;
}

/* -- Problem 2: Footer-Abstände --
   Desktop: padding-top 48px, horizontal 32px, unten 40px; Gap 48px.
   Mobile: horizontal 16px (unverändert), Gap bleibt. */
#sp-footer1 {
  padding: 48px 32px 40px;
}

#sp-footer1 .sp-column,
#sp-footer1 > .container > .row,
#sp-footer1 > .container {
  gap: 48px;
}

@media (max-width: 768px) {
  #sp-footer1 {
    padding: 32px 16px 20px;
  }
}

/* -- Problem 3: Grüner Akzentbalken oben am Footer -- */
#sp-footer {
  border-top: 3px solid var(--ssg-green);
}

/* Footer-Spaltenüberschriften: grüne Farbe + Akzentlinie darunter */
#sp-footer .sp-module-title,
#sp-footer h3,
#sp-footer h4 {
  color: var(--ssg-green);
  padding-bottom: 8px;
  border-bottom: 2px solid var(--ssg-green);
  margin-bottom: 16px;
  /* display: inline-block; */
}

/* ================================================================
   SSG-HEADER — position:fixed Strategie
   position:sticky scheitert wegen .body-innerwrapper{overflow-x:hidden}
   in template.css. Workaround: position:fixed + body padding-top.

   ≥ 992px (Desktop):  ganzer .ssg-header fixed (Topbar + Nav)
   < 992px  (Mobile/Tablet): .ssg-header scrollt normal weg;
                              isoliertes .ssg-sticky-shield bleibt fixed
   ================================================================ */

/* Desktop: ganzer Header fixed */
@media (min-width: 992px) {
  .ssg-header {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
  }
  body {
    padding-top: calc(var(--ssg-topbar-height) + var(--ssg-header-height));
  }
}

/* Nav-Brand auf Mobile/Tablet ausblenden — Sticky Shield übernimmt */
@media (max-width: 991px) {
  .ssg-header .ssg-brand {
    display: none !important;
  }
}

/* === MOBILE/TABLET STICKY WAPPEN (< 992px) ===
   Initial: sichtbar, zentriert, auf Höhe + Größe des Original-Nav-Logos.
   Gescrollt: oben links, kompakt (56px). */
.ssg-sticky-shield {
  display: none;
}
@media (max-width: 991px) {
  .ssg-sticky-shield {
    display: block;
    position: fixed;
    top: calc(var(--ssg-topbar-height) + 72px);
    left: 50%;
    transform: translateX(-50%);
    z-index: 1001;
    width: auto;
    height: 120px; /* entspricht .ssg-logo height für < 767px */
    opacity: 1;
    transition: top .3s ease, height .3s ease, left .3s ease, transform .3s ease;
    pointer-events: auto;
  }
  .ssg-sticky-shield img {
    width: auto;
    height: 100%;
    display: block;
  }
  body.is-scrolled .ssg-sticky-shield {
    top: 12px;
    left: 16px;
    transform: none;
    height: 56px;
  }
}
@media (max-width: 700px) {
  /* Kleinere Größe auf sehr kleinen Phones — entspricht .ssg-logo height */
  .ssg-sticky-shield {
    height: 96px;
  }
}
.ssg-bottom-nav {
  z-index: 1000;
}


/* ============================================================
   NAVIGATION-BREAKPOINTS — Burger global deaktiviert
   < 992px: nur Bottom-Nav  |  ≥ 992px: nur Mega-Menü
   ============================================================ */

/* Burger + Off-Canvas in JEDER Größe ausblenden */
#sp-header .sp-menu-toggle-btn,
#sp-header .burger-icon,
#sp-header #offcanvas-toggler,
#sp-header .offcanvas-toggler-pos-right,
#sp-header .offcanvas-menu-toggler,
.ssg-burger,
.offcanvas-menu,
.offcanvas-overlay { display: none !important; }

/* < 992px: Mega-Menü weg, Bottom-Tabs an */
@media (max-width: 991px) {
  #sp-header .sp-megamenu-wrapper,
  #sp-header .ssg-menu { display: none !important; }
  .ssg-bottom-tabs { display: flex !important; }
}

/* ≥ 992px: Mega-Menü an, Bottom-Tabs weg */
@media (min-width: 992px) {
  #sp-header .sp-megamenu-wrapper,
  #sp-header .ssg-menu { display: flex !important; }
  .ssg-bottom-tabs { display: none !important; }
}

@media (max-width: 991px) {
  #sp-header .sp-logo,
  #sp-header .sp-logo img {
    background: transparent !important;
  }
}

/* ============================================================
   DEIN WEG AM SOPHIE — 2026-05-16
   ============================================================ */

/* ssg-section-header-label: Alias für den Label-Span im Section-Header */
.com-sppagebuilder .ssg-section-header .ssg-section-header-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--ssg-text-light);
}

/* ── Feature-Card (Stripe + Body) ── */
.com-sppagebuilder .ssg-feature-card {
  background: white;
  border-radius: 10px;
  border: .5px solid #e5e5e5;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  transition: transform .2s, box-shadow .2s;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  height: 100%;
}
.com-sppagebuilder .ssg-feature-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,.1);
}
.com-sppagebuilder .ssg-feature-card-stripe {
  height: 4px;
  background: var(--ssg-green, #76B900);
}
.com-sppagebuilder .ssg-feature-card-stripe--blue  { background: #006EE1; }
.com-sppagebuilder .ssg-feature-card-stripe--green { background: #76B900; }
.com-sppagebuilder .ssg-feature-card-stripe--amber { background: #F8AC00; }
.com-sppagebuilder .ssg-feature-card-body {
  padding: 20px 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

/* ── Card-Tag Farbvarianten ── */
.com-sppagebuilder .ssg-card-tag--blue  { background: rgba(0,110,225,.1);  color: #006EE1; }
.com-sppagebuilder .ssg-card-tag--green { background: rgba(118,185,0,.1); color: #76B900; }
.com-sppagebuilder .ssg-card-tag--amber { background: rgba(248,172,0,.1); color: #F8AC00; }

/* ── Card-CTA (Textlink mit Pfeil) ── */
.com-sppagebuilder .ssg-card-cta {
  margin-top: 16px;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .85rem;
  display: flex;
  align-items: center;
  gap: 5px;
  text-decoration: none;
  color: #76B900;
}
.com-sppagebuilder .ssg-card-cta--blue  { color: #006EE1; }
.com-sppagebuilder .ssg-card-cta--green { color: #76B900; }
.com-sppagebuilder .ssg-card-cta--amber { color: #F8AC00; }
.com-sppagebuilder .ssg-card-cta:hover  { text-decoration: underline; }

/* ── Profil-Card v2 (farbiger Header-Block) ── */
.com-sppagebuilder .ssg-profile-card-v2 {
  border-radius: 10px;
  border: .5px solid #e5e5e5;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  transition: transform .2s, box-shadow .2s;
}
.com-sppagebuilder .ssg-profile-card-v2:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,.1);
}
.com-sppagebuilder .ssg-profile-card-v2-header {
  padding: 22px 24px 18px;
  color: white;
  position: relative;
  overflow: hidden;
}
.com-sppagebuilder .ssg-profile-card-v2-header::after {
  content: "";
  position: absolute;
  top: -16px;
  right: -16px;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: rgba(255,255,255,.1);
}
.com-sppagebuilder .ssg-profile-card-v2-header--blue  { background: #006EE1; }
.com-sppagebuilder .ssg-profile-card-v2-header--green { background: #76B900; }
.com-sppagebuilder .ssg-profile-card-v2-header--amber { background: #F8AC00; }
.com-sppagebuilder .ssg-profile-card-v2-badge {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background: rgba(255,255,255,.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  margin-bottom: 10px;
  letter-spacing: .02em;
}
.com-sppagebuilder .ssg-profile-card-v2-header h3 {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: 1.1rem;
  line-height: 1.25;
  color: white;
  margin: 0;
}
.com-sppagebuilder .ssg-profile-card-v2-body {
  padding: 18px 22px;
  background: white;
  display: flex;
  flex-direction: column;
}

/* GE-05 Anker-/Home-Variante: ganze Karte klickbar, Sub-Titel, Chips, gleiche Höhe */
.com-sppagebuilder a.ssg-profile-card-v2 {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}
.com-sppagebuilder a.ssg-profile-card-v2 .ssg-profile-card-v2-body { flex: 1; gap: 12px; }
.com-sppagebuilder .ssg-profile-card-v2-sub {
  font-size: .83rem;
  opacity: .9;
  margin-top: 4px;
  line-height: 1.3;
}
.com-sppagebuilder .ssg-profile-card-v2-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
}
.com-sppagebuilder .ssg-profile-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
}

/* ── Info-Banner mit linkem Farbstreifen ── */
.com-sppagebuilder .ssg-info-banner-left {
  background: white;
  border-left: 4px solid #76B900;
  border-radius: 0 8px 8px 0;
  padding: 16px 20px;
  margin-bottom: 28px;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.com-sppagebuilder .ssg-info-banner-left-icon {
  font-size: 1.2rem;
  color: #76B900;
  line-height: 1;
  flex-shrink: 0;
}

/* ── CTA-Box grün (Beratung) ── */
.com-sppagebuilder .ssg-cta-box--green {
  background: #f0f9e8;
  border-radius: 10px;
  border: 1px solid #c8e6a0;
  padding: 24px;
}

/* ── Sidebar Info-Box (Key-Value) ── */
.com-sppagebuilder .ssg-sidebar-infobox {
  background: white;
  border-radius: 8px;
  border: .5px solid #e5e5e5;
  padding: 16px 18px;
  box-shadow: 0 1px 4px rgba(0,0,0,.04);
  margin-top: 16px;
}
.com-sppagebuilder .ssg-sidebar-infobox-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  color: #002364;
  font-size: .9rem;
  margin-bottom: 10px;
}
/* Festes Zwei-Spalten-Raster statt flex/space-between: Key-Spalte links,
   Value-Spalte beginnt bei ALLEN Zeilen an derselben x-Position. So entsteht
   eine ruhige, einheitliche Kante – auch wenn Keys oder Values umbrechen
   (z.B. "Vermittlungssprache"). Früher per space-between rechtsbündig, was bei
   unterschiedlich langen Werten unruhig wirkte. */
.com-sppagebuilder .ssg-sidebar-infobox-row {
  display: grid;
  grid-template-columns: 38% 1fr;
  column-gap: 12px;
  align-items: baseline;
  padding: 7px 0;
  border-bottom: .5px solid #f0f0f0;
  font-size: .83rem;
}
.com-sppagebuilder .ssg-sidebar-infobox-row:last-child { border-bottom: none; }
.com-sppagebuilder .ssg-sidebar-infobox-key   { color: #666; }
.com-sppagebuilder .ssg-sidebar-infobox-value { font-weight: 700; color: #002364; }

/* ============================================================
   DEIN WEG — DISKREPANZ-FIXES 2026-05-20
   ============================================================ */

/* D-02: Chip-Styling (ssg-chip aktiv = blau, nicht grün) */
.com-sppagebuilder .ssg-chip {
  padding: 5px 14px;
  border-radius: 20px;
  font-size: .78rem;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  background: #f0f4fb;
  color: #006EE1;
  border: 1px solid #d0e0f5;
  display: inline-block;
}
.com-sppagebuilder .ssg-chip--active {
  background: #006EE1;
  color: white;
  border-color: #006EE1;
}
.com-sppagebuilder .ssg-chip--active-green {
  background: #76B900;
  color: white;
  border-color: #76B900;
}

/* D-03/D-04: Hero-Typografie */
.com-sppagebuilder .ssg-hero-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  color: #002364;
  line-height: 1.12;
  margin-bottom: 14px;
}
.com-sppagebuilder .ssg-hero-title .accent {
  color: #76B900;
}
.com-sppagebuilder .ssg-hero-desc {
  font-size: 1rem !important;
  color: #555;
  line-height: 1.7;
  max-width: 680px;
  margin-bottom: 22px;
}

/* D-05: YouTube Two-Click — neues CSS-Schema */
.com-sppagebuilder .ssg-yt {
  position: relative;
  padding-bottom: 56.25%;
  border-radius: 8px;
  overflow: hidden;
  background: #0d1c3e;
}
.com-sppagebuilder .ssg-yt iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}
.com-sppagebuilder .ssg-yt-consent {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 28px;
  text-align: center;
}
.com-sppagebuilder .ssg-yt-btn {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.2);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
  cursor: pointer;
  flex-shrink: 0;
}
.com-sppagebuilder .ssg-yt-btn:hover {
  background: rgba(255,255,255,.18);
}
.com-sppagebuilder .ssg-yt-desc {
  color: rgba(255,255,255,.7) !important;
  font-size: .85rem !important;
  max-width: 380px;
  line-height: 1.6;
}
.com-sppagebuilder .ssg-yt-link {
  color: #76B900 !important;
}
.com-sppagebuilder .ssg-yt-load {
  background: #76B900;
  color: white;
  border: none;
  border-radius: 6px;
  padding: 10px 22px;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .88rem;
  cursor: pointer;
  transition: background .15s;
}
.com-sppagebuilder .ssg-yt-load:hover {
  background: #68a500;
}

/* Mobile: Two-Click-Consent kompakt und vollständig sichtbar.
   - Play-Button entfällt (rein dekorativ), schafft Platz für Text + Button.
   - Consent läuft im Fluss (position:static), min-height hält das 16:9-Verhältnis
     fürs später geladene (absolut positionierte) iframe.
   - min-width:0 / overflow-wrap verhindern, dass der Kasten als Grid-Item über
     die Spaltenbreite hinaus wächst (horizontaler Überlauf). */
@media (max-width: 600px) {
  .com-sppagebuilder .ssg-video-testimonial > * {
    min-width: 0;
  }
  .com-sppagebuilder .ssg-yt-btn {
    display: none;
  }
  .com-sppagebuilder .ssg-yt {
    padding-bottom: 0;
    min-height: 56.25vw;
    min-width: 0;
    max-width: 100%;
  }
  .com-sppagebuilder .ssg-yt-consent {
    position: static;
    min-height: 56.25vw;
    box-sizing: border-box;
    max-width: 100%;
    padding: 18px 16px;
    gap: 16px;
  }
  .com-sppagebuilder .ssg-yt-desc {
    font-size: .82rem !important;
    max-width: 100%;
    overflow-wrap: anywhere;
  }
}

/* D-18: Download-Karten — neues Schema ssg-dw-* */
.com-sppagebuilder .ssg-dw-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
}

.com-sppagebuilder .ssg-dw-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  background: white;
  border-radius: 8px;
  border: .5px solid #e5e5e5;
  box-shadow: 0 1px 4px rgba(0,0,0,.05);
  text-decoration: none;
  transition: box-shadow .18s, transform .18s;
}
.com-sppagebuilder .ssg-dw-card:hover {
  box-shadow: 0 4px 14px rgba(0,0,0,.1);
  transform: translateY(-2px);
  text-decoration: none;
}
.com-sppagebuilder .ssg-dw-icon {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background: #e6f0fd;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.com-sppagebuilder .ssg-dw-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  color: #002364;
  font-size: .88rem;
  line-height: 1.3;
}
.com-sppagebuilder .ssg-dw-meta {
  font-size: .75rem;
  color: #aaa;
  margin-top: 3px;
}

/* D-21/D-22: Section-Header mit Akzentbalken (com-sppagebuilder-Overrides) */
.com-sppagebuilder .ssg-section-header {
  margin-bottom: 28px;
}
.com-sppagebuilder .ssg-section-header::before {
  content: '';
  display: block;
  width: 36px;
  height: 3px;
  background: #76B900;
  border-radius: 2px;
  margin-bottom: 12px;
}
.com-sppagebuilder .ssg-section-header-label {
  display: block;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #76B900;
  margin-bottom: 6px;
}
.com-sppagebuilder .ssg-section-header h2,
.com-sppagebuilder .ssg-section-header > span:last-child:not(.ssg-section-header-label) {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: clamp(1.3rem, 2.5vw, 1.7rem);
  color: #002364;
  line-height: 1.2;
  display: block;
  margin: 0;
}

/* ============================================================
   SSG-FACH-SYSTEM – Generische Fachschaft-Bausteine
   CSS-Variablen werden inline auf .ssg-fach gesetzt:
     --ssg-fach-accent  (Hauptakzentfarbe)
     --ssg-fach-deep    (dunklere Variante)
     --ssg-fach-light   (heller Hintergrund)
     --ssg-fach-mid     (Mittelton / Placeholder)
   Stand: 2026-06-06
   ============================================================ */

/* ── Hero ── */
.com-sppagebuilder .ssg-fach-top-bar {
  height: 4px;
  background: var(--ssg-fach-accent);
}

.com-sppagebuilder .ssg-hero-bar--fach {
  display: block;
  width: 36px;
  height: 3px;
  background: var(--ssg-fach-accent);
  border-radius: 2px;
  margin: 14px 0;
}

.com-sppagebuilder .ssg-fach-label {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ssg-fach-accent);
  margin-bottom: 4px;
}

.com-sppagebuilder .ssg-fach-accent-text {
  color: var(--ssg-fach-accent);
}

/* ── Chip-Variante Fach ── */
.com-sppagebuilder .ssg-chip--fach {
  background: var(--ssg-fach-accent);
  border-color: var(--ssg-fach-accent);
  color: white;
}

/* ── Sibling-Navigation ── */
/* Sidebar-Infobox im fach-Kontext: Titelbalken in Akzentfarbe */
.com-sppagebuilder .ssg-fach .ssg-sidebar-infobox-title {
  border-bottom: 2px solid var(--ssg-fach-accent);
}

.com-sppagebuilder .ssg-fach-sibling-strip {
  background: var(--ssg-fach-light);
  border-top: 1px solid var(--ssg-fach-mid);
  border-bottom: 1px solid var(--ssg-fach-mid);
  padding: 12px 0;
  box-sizing: border-box;
  /* KEIN Full-bleed (100vw) mehr: Die 100vw-/margin-Hack war fragil – innerhalb
     der SPPB-Column verrutschte er und schnitt links den Label-Text ab. Die
     vollflächige helle Fläche liefert ohnehin die SPPB-Section (background_color
     = accent_light). Hier definieren Strip-Fläche + die dunkleren Begrenzungs-
     bänder (border-top/bottom) genau die Content-Breite – bündig zum übrigen
     Seiteninhalt. */
}

/* Horizontales Scrollen passiert NUR hier (Bootstrap-.container). Dadurch
   startet das Label bündig zum übrigen Seiteninhalt und wird links nicht
   abgeschnitten; die Begrenzungsbänder des Strips bleiben unberührt. */
.com-sppagebuilder .ssg-fach-sibling-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.com-sppagebuilder .ssg-fach-sibling-inner {
  display: flex;
  gap: 8px;
  flex-wrap: nowrap;
  min-width: max-content;
  align-items: center;
}

.com-sppagebuilder .ssg-fach-sibling-label {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ssg-fach-deep);
  margin-right: 8px;
  white-space: nowrap;
}

.com-sppagebuilder .ssg-sibling-nav-item--fach {
  background: white;
  border-color: var(--ssg-fach-accent);
  color: var(--ssg-fach-deep);
}

.com-sppagebuilder .ssg-sibling-nav-item--fach:hover {
  background: var(--ssg-fach-light);
  border-color: var(--ssg-fach-deep);
}

.com-sppagebuilder .ssg-sibling-nav-item--fach.is-active {
  background: var(--ssg-fach-accent);
  border-color: var(--ssg-fach-accent);
  color: white;
}

/* ── Leitmotto-Karte ── */
.com-sppagebuilder .ssg-fach-leitmotto {
  background: var(--ssg-fach-light);
  border-radius: 10px;
  padding: 28px 26px;
  border: 1px solid var(--ssg-fach-mid);
  position: relative;
}

.com-sppagebuilder .ssg-fach-leitmotto-quote {
  position: absolute;
  top: 14px;
  left: 18px;
  font-family: 'Ubuntu', sans-serif;
  font-size: 4rem;
  color: var(--ssg-fach-accent);
  opacity: .25;
  line-height: .8;
  pointer-events: none;
}

.com-sppagebuilder .ssg-fach-leitmotto-label {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .72rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ssg-fach-accent);
  margin-bottom: 14px;
  margin-top: 14px;
}

.com-sppagebuilder .ssg-fach-leitmotto-text {
  font-family: 'Ubuntu', sans-serif;
  font-size: 1.1rem;
  line-height: 1.45;
  color: #002364;
  font-weight: 500;
  margin-bottom: 14px;
}

.com-sppagebuilder .ssg-fach-leitmotto-sub {
  font-size: .88rem;
  color: #555;
  line-height: 1.6;
  margin: 0;
}

/* ── Themenfelder-Grid ── */
.com-sppagebuilder .ssg-fach-themenfeld-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}

.com-sppagebuilder .ssg-fach-themenfeld-card {
  background: white;
  border-radius: 10px;
  padding: 24px 22px;
  border: .5px solid #e5e5e5;
  box-shadow: 0 2px 6px rgba(0,0,0,.04);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform .2s, box-shadow .2s, border-color .2s;
}

.com-sppagebuilder .ssg-fach-themenfeld-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
  border-color: var(--ssg-fach-accent);
}

.com-sppagebuilder .ssg-fach-themenfeld-nr {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: 2.4rem;
  color: var(--ssg-fach-mid);
  line-height: 1;
  transition: color .2s;
}

.com-sppagebuilder .ssg-fach-themenfeld-card:hover .ssg-fach-themenfeld-nr {
  color: var(--ssg-fach-accent);
}

/* ── Curriculum-Reise ── */
.com-sppagebuilder .ssg-fach-reise-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 18px;
  position: relative;
  overflow: hidden;
}

/* Rail-Linie als Segment PRO Station (nicht einmal pro Grid): funktioniert
   auch, wenn der Zeitstrahl über mehrere Zeilen umbricht (>5 Stationen,
   z.B. „Dein Weg"-Stufenseiten, Fix 2026-06-12). Jedes Segment überbrückt
   die Grid-Lücke (18px); overflow:hidden am Grid kappt den Überhang des
   jeweils letzten Segments einer Zeile, :last-child endet am letzten Dot. */
.com-sppagebuilder .ssg-fach-reise-step {
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
}

.com-sppagebuilder .ssg-fach-reise-step::before {
  content: '';
  position: absolute;
  left: 0;
  top: 7px;
  width: calc(100% + 18px);
  height: 2px;
  background: var(--ssg-fach-deep);
  opacity: .3;
  border-radius: 1px;
}

.com-sppagebuilder .ssg-fach-reise-step:last-child::before {
  width: 20px;
}

.com-sppagebuilder .ssg-fach-reise-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 3px solid white;
  box-shadow: 0 0 0 2px currentColor;
  margin-left: 8px;
  position: relative;
  z-index: 1;
}

.com-sppagebuilder .ssg-fach-reise-jg {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .7rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ssg-fach-accent);
  margin-top: 8px;
}

.com-sppagebuilder .ssg-fach-reise-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  color: #002364;
  font-size: 1rem;
  line-height: 1.25;
  margin: 0;
}

/* <900px: Stationen untereinander, vertikale Rail-Linie neben den Dots –
   analog zur horizontalen Desktop-Darstellung (Test 2026-06-12). Dot wandert
   absolut nach links, Inhalt rückt ein, jedes Segment überbrückt die
   24px-Lücke zur nächsten Station, :last-child endet am letzten Dot. */
@media (max-width: 900px) {
  .com-sppagebuilder .ssg-fach-reise-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .com-sppagebuilder .ssg-fach-reise-step {
    padding-left: 36px;
  }
  .com-sppagebuilder .ssg-fach-reise-dot {
    position: absolute;
    left: 0;
    top: 2px;
    margin-left: 0;
  }
  .com-sppagebuilder .ssg-fach-reise-jg {
    margin-top: 0;
  }
  .com-sppagebuilder .ssg-fach-reise-step::before {
    left: 7px;
    top: 2px;
    width: 2px;
    height: calc(100% + 24px);
  }
  .com-sppagebuilder .ssg-fach-reise-step:last-child::before {
    width: 2px;
    height: 16px;
  }
}

/* ── Mobile: Generator-Karten-Reihen horizontal scrollbar + Snap (statt Stacking) ──
   Greift für die Inline-Grid-Bausteine (angebote, video_galerie), die – anders
   als die spaltenbasierten Demo-Sections – kein ssg-h-scroll-section/JS nutzen.
   Reine CSS-Lösung über die bestehenden Grid-Klassen.
   curriculum_reise seit 2026-06-12 NICHT mehr dabei: stackt vertikal mit
   Rail-Linie (siehe @media max-width:900px oben). */
@media (max-width: 767px) {
  .com-sppagebuilder .ssg-fach-themenfeld-grid,
  .com-sppagebuilder .ssg-video-galerie {
    display: flex;
    grid-template-columns: none;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 14px;
    margin: 0 -16px;
    padding: 4px 16px 14px;
    scroll-padding-left: 16px;
    scrollbar-width: none;
  }
  .com-sppagebuilder .ssg-fach-themenfeld-grid::-webkit-scrollbar,
  .com-sppagebuilder .ssg-video-galerie::-webkit-scrollbar { display: none; }

  .com-sppagebuilder .ssg-fach-themenfeld-grid > .ssg-fach-themenfeld-card,
  .com-sppagebuilder .ssg-video-galerie > .ssg-video-embed {
    flex: 0 0 82%;
    scroll-snap-align: start;
  }
}

/* ── Oberstufe-Stats ── */
.com-sppagebuilder .ssg-fach-stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.com-sppagebuilder .ssg-fach-stat-card {
  background: var(--ssg-fach-light);
  border: 1px solid var(--ssg-fach-mid);
  border-radius: 10px;
  padding: 22px 20px;
}

.com-sppagebuilder .ssg-fach-stat-nr {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: 2.1rem;
  color: var(--ssg-fach-accent);
  line-height: 1;
  margin-bottom: 8px;
}

/* ── Accordion-Nummer ── */
.com-sppagebuilder .ssg-fach-acc-nr {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .85rem;
  color: var(--ssg-fach-accent);
  min-width: 28px;
  flex-shrink: 0;
  margin-right: 10px;
}

/* ── Team ── */
.com-sppagebuilder .ssg-fach-team-lead {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  background: var(--ssg-fach-light);
  border-radius: 10px;
  padding: 20px;
  border: 1px solid var(--ssg-fach-mid);
  margin-bottom: 16px;
}

.com-sppagebuilder .ssg-fach-team-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.com-sppagebuilder .ssg-fach-team-card {
  display: flex;
  gap: 14px;
  align-items: center;
  background: white;
  border-radius: 8px;
  padding: 12px 14px;
  border: .5px solid var(--ssg-border, #e5e5e5);
}

@media (max-width: 768px) {
  .com-sppagebuilder .ssg-fach-team-grid {
    grid-template-columns: 1fr;
  }
}

/* ── CTA-Link Fach ── */
.com-sppagebuilder .ssg-card-cta--fach {
  color: var(--ssg-fach-deep);
  font-weight: 700;
  text-decoration: none;
  font-size: .88rem;
}

.com-sppagebuilder .ssg-card-cta--fach:hover {
  color: var(--ssg-fach-accent);
  text-decoration: underline;
}

/* ── Kontakt-CTA-Box ── */
.com-sppagebuilder .ssg-fach-cta-box {
  background: var(--ssg-fach-accent);
  border-radius: 10px;
  padding: 22px;
  color: white;
}

.com-sppagebuilder .ssg-fach-cta-box .ssg-card-desc {
  opacity: .9;
  color: white;
}

/* ── Zwei-Spalten-Grid (responsive) ── */
.com-sppagebuilder .ssg-two-col {
  /* Desktop: inline grid-template-columns greift */
}

@media (max-width: 900px) {
  .com-sppagebuilder .ssg-two-col {
    grid-template-columns: 1fr !important;
  }
}

/* ============================================================
   NEWS MODUL v2 – ssg-news-tl-* (Timeline-Rail)
   Override: html/mod_articles/ssg-news-list-new.php
   Aktivierung: Modul-Layout = ssg-news-list-new
   Stand: 2026-06-06
   ============================================================ */

/* ── Rail: vertikale gestrichelte Linie ── */
.ssg-news-tl-rail {
  position: relative;
  padding-left: 30px;
}

.ssg-news-tl-rail::before {
  content: '';
  position: absolute;
  left: 7px;
  top: 10px;
  bottom: 10px;
  width: 0;
  border-left: 2px dashed var(--ssg-border, #e5e5e5);
}

/* ── Einzelnes Timeline-Item ── */
.ssg-news-tl-item {
  position: relative;
  margin-bottom: 26px;
}

.ssg-news-tl-item:last-child {
  margin-bottom: 0;
}

/* ── Dot ── */
.ssg-news-tl-dot {
  position: absolute;
  left: -30px;
  top: 5px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid #fff;
  box-shadow: 0 0 0 2px rgba(0,0,0,.10);
}

/* ── Body: Metaelemente in Flex-Zeile + Titel darunter ── */
.ssg-news-tl-body {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

/* ── Datum-Badge ── */
.ssg-news-tl-date {
  font-size: .76rem;
  color: var(--ssg-text-light, #666);
  font-weight: 600;
  white-space: nowrap;
  min-width: 72px;
  letter-spacing: .01em;
}

/* ── Kategorie-Tag ── */
.ssg-news-tl-tag {
  font-size: .68rem;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 20px;
  border: 1.5px solid;
  white-space: nowrap;
  background: transparent;
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* ── Artikel-Titel ── */
.ssg-news-tl-title {
  font-family: 'Ubuntu', sans-serif;
  font-size: .92rem;
  font-weight: 700;
  color: var(--ssg-blue, #006EE1);
  line-height: 1.45;
  margin: 4px 0 0;
  width: 100%;
}

.ssg-news-tl-title a {
  color: inherit;
  text-decoration: none;
}

.ssg-news-tl-title a:hover {
  color: var(--ssg-lb, #006EE1);
  text-decoration: underline;
}

/* ── "Alle Neuigkeiten"-Link ── */
.ssg-news-list-more {
  display: inline-block;
  margin-top: 22px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--ssg-lb, #006EE1);
  text-decoration: none;
}

.ssg-news-list-more:hover {
  text-decoration: underline;
}

/* ── Mobile (<768px): Linie entfällt, Items als weiße Karten ──
   Dot bleibt als farbiger Badge-Punkt links neben Datum + Tag (inline). */
@media (max-width: 767px) {
  .ssg-news-tl-rail {
    padding-left: 0;
  }
  .ssg-news-tl-rail::before {
    display: none;
  }
  .ssg-news-tl-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    background: #fff;
    border: .5px solid var(--ssg-border, #e5e5e5);
    border-radius: 10px;
    padding: 14px 16px;
    margin-bottom: 12px;
    box-shadow: 0 2px 6px rgba(0,0,0,.06);
  }
  /* Dot vom absoluten Rail-Marker zum inline Badge-Punkt umstellen */
  .ssg-news-tl-dot {
    position: static;
    left: auto;
    top: auto;
    flex: 0 0 auto;
    width: 11px;
    height: 11px;
    margin-top: 4px;
    border: none;
    box-shadow: none;
  }
  .ssg-news-tl-body {
    flex: 1 1 auto;
  }
}

/* ============================================================
   FOTO-BAUSTEINE (2026-06-07)
   bild_text_split · foto_band · foto_raster · zitat_auf_foto
   Platzhalterfotos aus catalog/fotokatalog.yaml
   ============================================================ */

/* ── Bild-Text-Split ── */
.com-sppagebuilder .ssg-bild-text {
  display: flex;
  gap: 40px;
  align-items: center;
}
.com-sppagebuilder .ssg-bild-text--rechts {
  flex-direction: row-reverse;
}
.com-sppagebuilder .ssg-bild-text-media {
  flex: 0 0 46%;
  max-width: 46%;
}
.com-sppagebuilder .ssg-bild-text-media img {
  width: 100%;
  height: 100%;
  max-height: 420px;
  object-fit: cover;
  border-radius: 10px;
  border: 0.5px solid #e5e5e5;
  display: block;
}
.com-sppagebuilder .ssg-bild-text-body {
  flex: 1 1 auto;
}
.com-sppagebuilder .ssg-bild-text-text {
  font-size: 1rem;
  line-height: 1.7;
  color: #333;
}
.com-sppagebuilder .ssg-bild-text-text > *:first-child { margin-top: 0; }

@media (max-width: 767px) {
  .com-sppagebuilder .ssg-bild-text,
  .com-sppagebuilder .ssg-bild-text--rechts {
    flex-direction: column;
    gap: 20px;
  }
  .com-sppagebuilder .ssg-bild-text-media {
    flex-basis: auto;
    max-width: 100%;
    width: 100%;
  }
  .com-sppagebuilder .ssg-bild-text-media img { max-height: 260px; }
}

/* ── Foto-Band (Full-Bleed) ── */
.com-sppagebuilder .ssg-foto-band {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  overflow: hidden;
}
.com-sppagebuilder .ssg-foto-band-img {
  width: 100%;
  height: 340px;
  object-fit: cover;
  display: block;
}
.com-sppagebuilder .ssg-foto-band--kompakt .ssg-foto-band-img { height: 200px; }
.com-sppagebuilder .ssg-foto-band--hoch .ssg-foto-band-img { height: 480px; }
.com-sppagebuilder .ssg-foto-band-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 24px;
  background: linear-gradient(rgba(0,35,100,0.28), rgba(0,35,100,0.42));
}
.com-sppagebuilder .ssg-foto-band-titel {
  color: #fff;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: clamp(1.5rem, 4vw, 2.4rem);
  margin: 0;
  text-shadow: 0 2px 16px rgba(0,0,0,0.35);
}
.com-sppagebuilder .ssg-foto-band-text {
  color: #fff;
  font-size: 1.05rem;
  margin: 10px 0 0;
  max-width: 720px;
  text-shadow: 0 1px 10px rgba(0,0,0,0.4);
}
@media (max-width: 767px) {
  .com-sppagebuilder .ssg-foto-band-img { height: 230px; }
  .com-sppagebuilder .ssg-foto-band--hoch .ssg-foto-band-img { height: 320px; }
}

/* ── Foto-Raster (Masonry via CSS-Columns) ── */
.com-sppagebuilder .ssg-foto-raster {
  column-count: var(--ssg-raster-cols, 3);
  column-gap: 14px;
  margin-top: 8px;
}
.com-sppagebuilder .ssg-foto-raster-tile {
  margin: 0 0 14px;
  break-inside: avoid;
  border-radius: 10px;
  overflow: hidden;
  border: 0.5px solid #e5e5e5;
}
.com-sppagebuilder .ssg-foto-raster-tile img {
  width: 100%;
  height: auto;
  display: block;
}
@media (max-width: 991px) {
  .com-sppagebuilder .ssg-foto-raster { column-count: 2; }
}
@media (max-width: 575px) {
  .com-sppagebuilder .ssg-foto-raster { column-count: 1; }
}

/* ── Zitat-auf-Foto ── */
.com-sppagebuilder .ssg-zitat-foto {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  overflow: hidden;
}
.com-sppagebuilder .ssg-zitat-foto-img {
  width: 100%;
  height: 380px;
  object-fit: cover;
  display: block;
}
.com-sppagebuilder .ssg-zitat-foto--kompakt .ssg-zitat-foto-img { height: 260px; }
.com-sppagebuilder .ssg-zitat-foto--hoch .ssg-zitat-foto-img { height: 500px; }
.com-sppagebuilder .ssg-zitat-foto-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 32px 24px;
  background: linear-gradient(rgba(0,0,0,0.30), rgba(0,0,0,0.55));
}
.com-sppagebuilder .ssg-zitat-foto-text {
  color: #fff;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: clamp(1.25rem, 3.2vw, 2rem);
  line-height: 1.35;
  margin: 0;
  max-width: 880px;
  border: none;
  padding: 0;
  quotes: "\201E" "\201C";
}
.com-sppagebuilder .ssg-zitat-foto-text::before { content: open-quote; }
.com-sppagebuilder .ssg-zitat-foto-text::after { content: close-quote; }
.com-sppagebuilder .ssg-zitat-foto-autor {
  display: block;
  margin-top: 16px;
  color: #fff;
  font-style: normal;
  font-size: 0.95rem;
  opacity: 0.92;
}
@media (max-width: 767px) {
  .com-sppagebuilder .ssg-zitat-foto-img { height: 300px; }
}

/* ── Hero mit optionalem Foto (hero.py, slot 'bild') ── */
.com-sppagebuilder .ssg-hero--mit-bild {
  display: flex;
  gap: 36px;
  align-items: center;
}
.com-sppagebuilder .ssg-hero--mit-bild .ssg-hero-text {
  flex: 1 1 56%;
  min-width: 0;
}
.com-sppagebuilder .ssg-hero-bild {
  flex: 0 0 40%;
  max-width: 40%;
}
.com-sppagebuilder .ssg-hero-bild img {
  width: 100%;
  height: 100%;
  max-height: 360px;
  object-fit: cover;
  border-radius: 12px;
  border: 0.5px solid #e5e5e5;
  display: block;
}
@media (max-width: 767px) {
  .com-sppagebuilder .ssg-hero--mit-bild {
    flex-direction: column;
    gap: 22px;
    align-items: stretch;
  }
  .com-sppagebuilder .ssg-hero-bild {
    flex-basis: auto;
    max-width: 100%;
    order: -1;
  }
  .com-sppagebuilder .ssg-hero-bild img { max-height: 220px; }
}

/* ================================================================
   TdoT-COUNTDOWN — (digitaler) Tag der offenen Tür  (2026-06-12)
   Block standardmäßig hidden (Section visibility=false im SPPB).
   Zieldatum: SSG_TOFT_COUNTDOWN_TARGET in js/custom.js
   ================================================================ */
.com-sppagebuilder .ssg-toft {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  background: linear-gradient(135deg, #002364 0%, #001847 60%, #00337a 100%);
  color: #fff;
  padding: 40px 32px;
  text-align: center;
  box-shadow: 0 14px 40px rgba(0, 35, 100, .25);
}
.com-sppagebuilder .ssg-toft::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 34px 34px;
  pointer-events: none;
}
.com-sppagebuilder .ssg-toft > * { position: relative; z-index: 1; }
.com-sppagebuilder .ssg-toft-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(118,185,0,.18);
  color: #aede5a;
  border: 1px solid rgba(118,185,0,.45);
  border-radius: 30px;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .74rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 6px 16px;
  margin-bottom: 18px;
}
.com-sppagebuilder .ssg-toft-badge::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #76B900;
  box-shadow: 0 0 0 0 rgba(118,185,0,.7);
  animation: ssgToftPulse 1.8s infinite;
}
@keyframes ssgToftPulse {
  0%   { box-shadow: 0 0 0 0 rgba(118,185,0,.6); }
  70%  { box-shadow: 0 0 0 10px rgba(118,185,0,0); }
  100% { box-shadow: 0 0 0 0 rgba(118,185,0,0); }
}
.com-sppagebuilder .ssg-toft-title {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: clamp(1.5rem, 3.4vw, 2.3rem);
  line-height: 1.15;
  margin: 0 0 10px;
  color: #fff;
}
.com-sppagebuilder .ssg-toft-sub {
  font-size: clamp(.92rem, 1.7vw, 1.05rem);
  color: rgba(255,255,255,.82);
  max-width: 560px;
  margin: 0 auto 28px;
  line-height: 1.6;
}
.com-sppagebuilder .ssg-toft-clock {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 30px;
}
.com-sppagebuilder .ssg-toft-cell {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 12px;
  min-width: 84px;
  padding: 16px 10px 12px;
  backdrop-filter: blur(2px);
}
.com-sppagebuilder .ssg-toft-num {
  display: block;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: clamp(1.8rem, 5vw, 2.8rem);
  line-height: 1;
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.com-sppagebuilder .ssg-toft-cell-label {
  display: block;
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
  margin-top: 8px;
}
.com-sppagebuilder .ssg-toft-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #76B900;
  color: #fff;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .95rem;
  padding: 12px 26px;
  border-radius: 8px;
  text-decoration: none;
  transition: background .16s, transform .16s;
}
.com-sppagebuilder .ssg-toft-cta:hover {
  background: #6aa800;
  color: #fff;
  transform: translateY(-2px);
  text-decoration: none;
}
.com-sppagebuilder .ssg-toft-done {
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: 1.1rem;
  color: #aede5a;
}
@media (max-width: 600px) {
  .com-sppagebuilder .ssg-toft { padding: 30px 18px; }
  .com-sppagebuilder .ssg-toft-cell { min-width: 64px; padding: 12px 6px 9px; }
  .com-sppagebuilder .ssg-toft-clock { gap: 9px; }
}

/* ── Profil-Karten als ganze Links (Startseite) ── */
.com-sppagebuilder a.ssg-profile-card {
  text-decoration: none;
  cursor: pointer;
  transition: transform .18s, box-shadow .18s;
}
.com-sppagebuilder a.ssg-profile-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(0,35,100,.14);
}

/* ================================================================
   STARTSEITE — Weitere Angebote (klickbare Link-Chips)  (2026-06-12)
   ================================================================ */
.com-sppagebuilder .ssg-angebote-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.com-sppagebuilder .ssg-angebote-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  border-radius: 50px;
  background: #fff;
  border: 1.5px solid currentColor;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  transition: background .16s, color .16s, transform .16s;
  box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
.com-sppagebuilder .ssg-angebote-chip > span { color: inherit; transition: color .16s; }
.com-sppagebuilder .ssg-angebote-chip:hover {
  background: currentColor;
  transform: translateY(-2px);
  text-decoration: none;
}
.com-sppagebuilder .ssg-angebote-chip:hover > span { color: #fff; }
.com-sppagebuilder .ssg-angebote-chip--blue  { color: #002364; }
.com-sppagebuilder .ssg-angebote-chip--lb    { color: #006EE1; }
.com-sppagebuilder .ssg-angebote-chip--green { color: #76B900; }
.com-sppagebuilder .ssg-angebote-chip--amber { color: #F8AC00; }

/* ================================================================
   STARTSEITE — Kooperationspartner-Logos (größer)  (2026-06-12)
   ================================================================ */
.com-sppagebuilder .ssg-partner-logos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 20px;
  align-items: stretch;
  margin-top: 8px;
}
.com-sppagebuilder .ssg-partner-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: .5px solid #e5e5e5;
  border-radius: 10px;
  padding: 26px 28px;
  min-height: 130px;
  box-shadow: 0 1px 4px rgba(0,0,0,.05);
  transition: transform .18s, box-shadow .18s;
}
.com-sppagebuilder .ssg-partner-logo:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 22px rgba(0,0,0,.1);
}
.com-sppagebuilder .ssg-partner-logo img {
  max-width: 100%;
  max-height: 76px;
  width: auto;
  height: auto;
  object-fit: contain;
}
@media (max-width: 600px) {
  .com-sppagebuilder .ssg-partner-logos { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .com-sppagebuilder .ssg-partner-logo { min-height: 100px; padding: 18px; }
}

/* ================================================================
   MENSCHEN AM SOPHIE — Kollegium-Verzeichnis (Runtime: custom.js)
   ================================================================ */
.com-sppagebuilder #ssg-kollegium { font-family: Ubuntu, sans-serif; }

.com-sppagebuilder .ssg-k-controls {
  display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
  justify-content: space-between; margin-bottom: 14px;
}
.com-sppagebuilder .ssg-k-search-wrap { flex: 1; min-width: 220px; }
.com-sppagebuilder .ssg-k-search {
  width: 100%; max-width: 380px; padding: 10px 16px;
  border: .5px solid var(--ssg-border); border-radius: 8px;
  font-size: .9rem; font-family: Ubuntu, sans-serif; outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.com-sppagebuilder .ssg-k-search:focus {
  border-color: #006EE1; box-shadow: 0 0 0 3px rgba(0,110,225,.12);
}
.com-sppagebuilder .ssg-k-sort {
  display: flex; align-items: center; gap: 8px;
  font-size: .82rem; color: #888;
}
.com-sppagebuilder .ssg-k-sort-sel {
  padding: 8px 12px; border: .5px solid var(--ssg-border);
  border-radius: 8px; font-size: .85rem; font-family: Ubuntu, sans-serif;
  background: #fff; color: #002364; cursor: pointer; outline: none;
}

.com-sppagebuilder .ssg-k-chips {
  display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px;
}
.com-sppagebuilder .ssg-k-chip {
  padding: 6px 14px; border-radius: 20px; cursor: pointer;
  font-size: .8rem; font-weight: 700; color: #555;
  background: #f0f0ee; border: .5px solid var(--ssg-border);
  transition: background .15s, color .15s, border-color .15s; user-select: none;
}
.com-sppagebuilder .ssg-k-chip:hover { background: #e6e6e3; }
.com-sppagebuilder .ssg-k-chip.is-active {
  background: #002364; color: #fff; border-color: #002364;
}

.com-sppagebuilder .ssg-k-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 12px;
}
.com-sppagebuilder .ssg-k-card {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 18px 12px 16px; background: #fff;
  border-radius: 10px; border: .5px solid var(--ssg-border);
  box-shadow: var(--ssg-shadow);
}
.com-sppagebuilder .ssg-k-avatar {
  width: 46px; height: 46px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .82rem; margin-bottom: 9px;
  border: 1.5px solid; letter-spacing: .02em;
}
.com-sppagebuilder .ssg-k-name {
  font-weight: 700; color: #002364; font-size: .82rem;
  line-height: 1.3; margin-bottom: 2px;
}
.com-sppagebuilder .ssg-k-role {
  font-size: .68rem; font-weight: 700; color: #76B900;
  text-transform: uppercase; letter-spacing: .03em; margin-bottom: 3px;
}
.com-sppagebuilder .ssg-k-faecher {
  font-size: .72rem; color: #888; line-height: 1.4;
}
.com-sppagebuilder .ssg-k-count {
  font-size: .8rem; color: #aaa; text-align: center; margin-top: 18px;
}
.com-sppagebuilder .ssg-k-empty {
  grid-column: 1 / -1; text-align: center; color: #888;
  padding: 32px 0; font-size: .9rem;
}
@media (max-width: 480px) {
  .com-sppagebuilder .ssg-k-grid { grid-template-columns: repeat(2, 1fr); }
  .com-sppagebuilder .ssg-k-controls { flex-direction: column; align-items: stretch; }
  .com-sppagebuilder .ssg-k-sort { justify-content: flex-end; }
}

/* ================================================================
   TEMP-NOTICE-RELAUNCH — temporäre Relaunch-Hinweisleiste (Startseite)
   ENTFERNEN sobald die Seite vollständig ist (zugehöriger JS-IIFE
   `TEMP-NOTICE-RELAUNCH` in custom.js ebenfalls löschen).
   ================================================================ */
.ssg-relaunch-notice {
  background: #fff8e6;
  border-bottom: 3px solid #F8AC00;
  color: #002364;
  font-size: 0.95rem;
  line-height: 1.45;
}
.ssg-relaunch-notice__inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 12px 20px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
}
.ssg-relaunch-notice__text { flex: 1; }
.ssg-relaunch-notice__text strong { color: #002364; }
.ssg-relaunch-notice__close {
  flex: 0 0 auto;
  background: none;
  border: none;
  font-size: 1.5rem;
  line-height: 1;
  color: #002364;
  cursor: pointer;
  padding: 0 4px;
  opacity: 0.6;
}
.ssg-relaunch-notice__close:hover { opacity: 1; }
@media (max-width: 480px) {
  .ssg-relaunch-notice { font-size: 0.85rem; }
  .ssg-relaunch-notice__inner { padding: 10px 14px; }
}
