/* =====================================================
   SB THEMEN & PROJEKTE – Frontend Design
   Version 1.1.0
   Referenzlayout: freigegebene Mockups vom 04.06.2026
   Plugin URI: https://sbdruck.com
   Author: SBDruck / Siegfried Birl
   ===================================================== */

:root {
    --sbtp-orange: #F5A623;
    --sbtp-orange-dark: #d99012;
    --sbtp-black: #111111;
    --sbtp-text: #333333;
    --sbtp-muted: #6f6f6f;
    --sbtp-border: #e7e7e7;
    --sbtp-soft: #f7f7f7;
    --sbtp-cream: #fffaf0;
    --sbtp-white: #ffffff;
    --sbtp-green: #1f8a3b;
    --sbtp-red: #b30000;
    --sbtp-blue: #1873d3;
    --sbtp-radius: 14px;
    --sbtp-shadow: 0 12px 34px rgba(0,0,0,.075);
    --sbtp-shadow-soft: 0 7px 22px rgba(0,0,0,.055);
}

body .sbtp-container,
body .sbtp-start-inner {
    width: min(100% - 72px, 1500px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box !important;
}

body .sbtp-kicker {
    display: inline-block !important;
    margin: 0 0 12px !important;
    color: var(--sbtp-orange) !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
}

body .sbtp-button,
body .sbtp-more-button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-height: 42px !important;
    padding: 12px 22px !important;
    background: var(--sbtp-orange) !important;
    border: 2px solid var(--sbtp-orange) !important;
    border-radius: 7px !important;
    color: #111111 !important;
    font-size: 13px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    box-shadow: none !important;
    transition: background .22s ease, border-color .22s ease, color .22s ease, transform .22s ease, box-shadow .22s ease !important;
}

body .sbtp-button:hover,
body .sbtp-more-button:hover {
    background: var(--sbtp-black) !important;
    border-color: var(--sbtp-black) !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
}

body .sbtp-button-outline,
body .sbtp-button-light {
    background: transparent !important;
    color: var(--sbtp-orange) !important;
}

body .sbtp-button-full { width: 100% !important; }

body .sbtp-text-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--sbtp-black) !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    margin-top: 14px !important;
}
body .sbtp-text-link:hover { color: var(--sbtp-orange) !important; }

/* Status-Badges */
body .sbtp-badge {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    max-width: 100% !important;
    padding: 7px 12px !important;
    border-radius: 999px !important;
    color: var(--sbtp-black) !important;
    background: rgba(245,166,35,.16) !important;
    font-size: 11px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .055em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
}
body .sbtp-status-new { color: var(--sbtp-blue) !important; background: rgba(24,115,211,.13) !important; }
body .sbtp-status-review,
body .sbtp-status-progress,
body .sbtp-status-request,
body .sbtp-status-application,
body .sbtp-status-waiting,
body .sbtp-status-partly { color: #b96b00 !important; background: rgba(245,166,35,.20) !important; }
body .sbtp-status-done { color: var(--sbtp-green) !important; background: rgba(31,138,59,.14) !important; }
body .sbtp-status-blocked,
body .sbtp-status-noresponse { color: var(--sbtp-red) !important; background: rgba(179,0,0,.10) !important; }

/* =====================================================
   STARTSEITEN-TEASER – [sb_themen_startseite]
   Layout exakt wie freigegebene Startseiten-Vorlage
   ===================================================== */
body .sbtp-start-section {
    position: relative !important;
    overflow: hidden !important;
    margin: 0 auto !important;
    padding: 48px 0 40px !important;
    background: linear-gradient(180deg, #ffffff 0%, #fffaf0 100%) !important;
    border-radius: 16px 16px 0 0 !important;
    box-shadow: 0 -5px 20px rgba(0,0,0,.035) !important;
}
body .sbtp-start-inner {
    display: grid !important;
    grid-template-columns: minmax(310px, 410px) 1fr !important;
    gap: 34px !important;
    align-items: stretch !important;
}
body .sbtp-start-copy {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    min-width: 0 !important;
}
body .sbtp-start-copy h2 {
    margin: 0 0 14px !important;
    color: var(--sbtp-black) !important;
    font-size: clamp(30px, 2.35vw, 42px) !important;
    line-height: 1.08 !important;
    font-weight: 900 !important;
    letter-spacing: -.02em !important;
    text-transform: none !important;
}
body .sbtp-start-copy p {
    max-width: 440px !important;
    margin: 0 0 24px !important;
    color: #555555 !important;
    font-size: 16px !important;
    line-height: 1.7 !important;
}
body .sbtp-start-stats {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
    margin: 0 0 24px !important;
}
body .sbtp-start-stats div {
    display: grid !important;
    grid-template-columns: auto 1fr !important;
    align-items: center !important;
    gap: 10px !important;
    min-height: 74px !important;
    padding: 15px 14px !important;
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 11px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
}
body .sbtp-start-stats strong {
    color: var(--sbtp-black) !important;
    font-size: 31px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
}
body .sbtp-start-stats span {
    color: #333333 !important;
    font-size: 12px !important;
    line-height: 1.12 !important;
    font-weight: 800 !important;
}
body .sbtp-start-copy .sbtp-button-outline {
    width: fit-content !important;
    min-width: 205px !important;
    background: transparent !important;
    color: var(--sbtp-orange) !important;
}
body .sbtp-start-copy .sbtp-button-outline:hover {
    background: var(--sbtp-orange) !important;
    color: #111111 !important;
    border-color: var(--sbtp-orange) !important;
}
body .sbtp-start-cards {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 24px !important;
    align-items: stretch !important;
}
body .sbtp-focus-card {
    position: relative !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 13px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease !important;
}
body .sbtp-focus-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 16px 36px rgba(0,0,0,.105) !important;
    border-color: rgba(245,166,35,.56) !important;
}
body .sbtp-focus-image {
    position: relative !important;
    display: block !important;
    flex: 0 0 auto !important;
    height: 220px !important;
    background-color: #eeeeee !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    text-decoration: none !important;
}
body .sbtp-focus-image .sbtp-badge {
    position: absolute !important;
    left: 18px !important;
    top: 16px !important;
    z-index: 2 !important;
    background: rgba(255,255,255,.90) !important;
    backdrop-filter: blur(4px) !important;
}
body .sbtp-focus-body {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    padding: 28px 22px 22px !important;
}
body .sbtp-focus-icon {
    position: absolute !important;
    left: 22px !important;
    top: -24px !important;
    width: 56px !important;
    height: 56px !important;
    display: grid !important;
    place-items: center !important;
    background: #fff8ea !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 50% !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    color: var(--sbtp-orange) !important;
    font-size: 24px !important;
    font-weight: 900 !important;
}
body .sbtp-focus-icon svg { width: 28px !important; height: 28px !important; display: block !important; }
body .sbtp-focus-body h3 {
    margin: 0 0 10px !important;
    padding-left: 72px !important;
    color: var(--sbtp-black) !important;
    font-size: 23px !important;
    line-height: 1.16 !important;
    font-weight: 900 !important;
    text-transform: none !important;
}
body .sbtp-focus-body h3 a { color: var(--sbtp-black) !important; text-decoration: none !important; }
body .sbtp-focus-body h3 a:hover { color: var(--sbtp-orange) !important; }
body .sbtp-focus-body p {
    margin: 0 0 15px !important;
    color: #444444 !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
}
body .sbtp-focus-body .sbtp-card-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 14px !important;
    margin: auto 0 14px !important;
    color: #777777 !important;
    font-size: 13px !important;
}
body .sbtp-focus-body .sbtp-card-meta span { display: inline-flex !important; align-items: center !important; gap: 5px !important; }
body .sbtp-focus-body .sbtp-card-meta i { font-style: normal !important; color: var(--sbtp-orange) !important; }
body .sbtp-focus-card .sbtp-button {
    width: 100% !important;
    min-height: 42px !important;
    margin-top: 0 !important;
}
body .sbtp-focus-link {
    display: inline-flex !important;
    align-items: center !important;
    color: var(--sbtp-orange) !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
}
body .sbtp-focus-link:hover { color: var(--sbtp-black) !important; }

/* =====================================================
   1.0.7: Plugin-CSS bringt nur das neutrale Grundgeruest +
   die CSS-Hooks (.sbtp-counter, .sbtp-counter-item, .sbtp-focus-card,
   .sbtp-grid, .sbtp-card, .sbtp-badge usw.).
   Theme-spezifische Wrapper-Klassen wie fg-themen-row-2601,
   fg-themen-counter-2601, fg-themen-blocke-2601 werden NICHT mehr
   im Plugin gestylt - das macht der Nutzer im Theme-CSS
   (WP-Customizer > Zusaetzliches CSS oder Theme-Stylesheet).
   ===================================================== */

/* Stacked-Variante (Shortcode-Param variant="stacked"): vier Zaehl-Boxen
   untereinander mit Icon links - ideal fuer schmale 1/3-Spalten. */
body .sbtp-counter-stacked .sbtp-counter-stats {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
}
body .sbtp-counter-stacked .sbtp-counter-item {
    display: grid !important;
    grid-template-columns: 44px auto 1fr !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 14px 16px !important;
}
body .sbtp-counter-stacked .sbtp-counter-item .sbtp-counter-icon {
    width: 44px !important;
    height: 44px !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 50% !important;
    background: #fff8ea !important;
    color: var(--sbtp-orange) !important;
}
body .sbtp-counter-stacked .sbtp-counter-item .sbtp-counter-icon svg { width: 24px !important; height: 24px !important; display: block !important; }
body .sbtp-counter-stacked .sbtp-counter-item strong {
    font-size: 34px !important;
    color: var(--sbtp-orange) !important;
    line-height: 1 !important;
}
body .sbtp-counter-stacked .sbtp-counter-item span {
    margin-top: 0 !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    color: #333 !important;
}

/* =====================================================
   ARCHIVSEITE /themen/ – exakte Referenz-Optik
   ===================================================== */
body .sbtp-archive-page {
    background: #ffffff !important;
    color: var(--sbtp-text) !important;
}
body .sbtp-archive-hero {
    position: relative !important;
    overflow: hidden !important;
    min-height: 290px !important;
    padding: 64px 0 54px !important;
    background-image:
        linear-gradient(90deg, #ffffff 0%, rgba(255,255,255,.95) 36%, rgba(255,255,255,.65) 58%, rgba(255,255,255,.18) 100%),
        url('sbtp-rathaus-hero.jpg') !important;
    background-size: cover !important;
    background-position: center right !important;
}
body .sbtp-archive-hero::after {
    content: "" !important;
    position: absolute !important;
    inset: auto 0 0 0 !important;
    height: 70px !important;
    background: linear-gradient(180deg, rgba(255,255,255,0), #ffffff) !important;
    pointer-events: none !important;
}
body .sbtp-archive-hero .sbtp-container { position: relative !important; z-index: 2 !important; }
body .sbtp-archive-hero h1 {
    max-width: 680px !important;
    margin: 0 0 16px !important;
    color: var(--sbtp-black) !important;
    font-size: clamp(52px, 5.2vw, 78px) !important;
    line-height: .92 !important;
    font-weight: 900 !important;
    letter-spacing: -.03em !important;
    text-transform: uppercase !important;
}
body .sbtp-archive-hero h1 span { color: var(--sbtp-orange) !important; }
body .sbtp-archive-hero p {
    max-width: 575px !important;
    margin: 0 !important;
    color: #444444 !important;
    font-size: 17px !important;
    line-height: 1.75 !important;
}
body .sbtp-archive-main {
    position: relative !important;
    z-index: 3 !important;
    margin-top: -28px !important;
    padding: 0 0 72px !important;
}
body .sbtp-statsbar-wide,
body .sbtp-statsbar {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    overflow: hidden !important;
    margin: 0 0 26px !important;
    background: rgba(255,255,255,.95) !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    backdrop-filter: blur(3px) !important;
}
body .sbtp-statbox,
body .sbtp-statsbar > div {
    min-height: 94px !important;
    padding: 22px 28px !important;
    border-right: 1px solid var(--sbtp-border) !important;
    display: grid !important;
    grid-template-columns: auto 1fr auto !important;
    align-items: center !important;
    gap: 14px !important;
}
body .sbtp-statbox:last-child,
body .sbtp-statsbar > div:last-child { border-right: none !important; }
body .sbtp-statbox strong,
body .sbtp-statsbar strong {
    color: var(--sbtp-orange) !important;
    font-size: 37px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
}
body .sbtp-statbox span,
body .sbtp-statsbar span {
    color: var(--sbtp-black) !important;
    font-size: 14px !important;
    line-height: 1.18 !important;
    font-weight: 800 !important;
}
body .sbtp-statbox i {
    color: var(--sbtp-orange) !important;
    font-style: normal !important;
    font-size: 31px !important;
    line-height: 1 !important;
    opacity: .96 !important;
}
body .sbtp-filter-pills {
    display: grid !important;
    grid-template-columns: minmax(300px, auto) 1fr !important;
    gap: 26px 74px !important;
    align-items: start !important;
    margin: 0 0 32px !important;
}
body .sbtp-filter-group > strong {
    display: block !important;
    margin: 0 0 10px !important;
    color: #222222 !important;
    font-size: 14px !important;
    font-weight: 900 !important;
}
body .sbtp-filter-options {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}
body .sbtp-filter-options a {
    min-width: 70px !important;
    padding: 9px 16px !important;
    background: #f2f2f2 !important;
    border-radius: 9px !important;
    color: #333333 !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    text-align: center !important;
    text-decoration: none !important;
    transition: background .2s ease, color .2s ease, transform .2s ease !important;
}
body .sbtp-filter-options a:hover,
body .sbtp-filter-options a.is-active {
    background: var(--sbtp-orange) !important;
    color: #111111 !important;
    transform: translateY(-1px) !important;
}
body .sbtp-grid,
body .sbtp-archive-grid {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 24px !important;
}
body .sbtp-grid-wrap .sbtp-grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
body .sbtp-card {
    position: relative !important;
    overflow: hidden !important;
    min-width: 0 !important;
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease !important;
}
body .sbtp-card:hover {
    transform: translateY(-4px) !important;
    border-color: rgba(245,166,35,.55) !important;
    box-shadow: 0 16px 38px rgba(0,0,0,.10) !important;
}
body .sbtp-card-image {
    display: block !important;
    height: 148px !important;
    background-color: #eeeeee !important;
    background-size: cover !important;
    background-position: center !important;
    text-decoration: none !important;
}
body .sbtp-card-body {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 258px !important;
    padding: 18px 20px 18px !important;
}
body .sbtp-card-icon {
    position: absolute !important;
    left: 18px !important;
    top: -22px !important;
    width: 48px !important;
    height: 48px !important;
    display: grid !important;
    place-items: center !important;
    background: #fff8ea !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 50% !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    color: var(--sbtp-orange) !important;
}
body .sbtp-card-icon svg { width: 24px !important; height: 24px !important; display: block !important; }
body .sbtp-card.has-image .sbtp-card-body { padding-top: 30px !important; }
body .sbtp-card h3 {
    margin: 0 0 10px !important;
    color: var(--sbtp-black) !important;
    font-size: 21px !important;
    line-height: 1.16 !important;
    font-weight: 900 !important;
    letter-spacing: -.01em !important;
    text-transform: uppercase !important;
}
body .sbtp-card h3 a { color: var(--sbtp-black) !important; text-decoration: none !important; }
body .sbtp-card h3 a:hover { color: var(--sbtp-orange) !important; }
body .sbtp-card .sbtp-badge { margin: 0 0 12px !important; }
body .sbtp-card p {
    margin: 0 0 14px !important;
    color: #444444 !important;
    font-size: 15px !important;
    line-height: 1.48 !important;
}
body .sbtp-card-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 14px !important;
    margin: auto 0 16px !important;
    color: #777777 !important;
    font-size: 13px !important;
}
body .sbtp-card-meta span { display: inline-flex !important; align-items: center !important; gap: 5px !important; }
body .sbtp-card-meta i { font-style: normal !important; color: #777 !important; }
body .sbtp-card .sbtp-button {
    width: 100% !important;
    min-height: 38px !important;
    padding: 10px 16px !important;
    margin-top: 0 !important;
}
body .sbtp-more-wrap { text-align: center !important; margin-top: 30px !important; }
body .sbtp-more-button {
    min-width: 340px !important;
    background: #ffffff !important;
    border-color: var(--sbtp-border) !important;
    color: #222222 !important;
}

/* =====================================================
   EINZELANSICHT – genaue Referenz-Optik
   ===================================================== */
body .sbtp-single-page {
    background: #ffffff !important;
    color: var(--sbtp-text) !important;
    padding: 0 0 72px !important;
}
body .sbtp-breadcrumb {
    padding: 20px 0 18px !important;
    color: #777777 !important;
    font-size: 13px !important;
}
body .sbtp-breadcrumb a { color: #555555 !important; text-decoration: none !important; }
body .sbtp-breadcrumb a:hover { color: var(--sbtp-orange) !important; }
body .sbtp-single-layout-top {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 390px !important;
    gap: 34px !important;
    align-items: start !important;
}
body .sbtp-single-main-head h1 {
    max-width: 840px !important;
    margin: 0 0 12px !important;
    color: var(--sbtp-black) !important;
    font-size: clamp(40px, 4vw, 58px) !important;
    line-height: .96 !important;
    font-weight: 900 !important;
    letter-spacing: -.025em !important;
    text-transform: uppercase !important;
}
body .sbtp-lead {
    max-width: 790px !important;
    margin: 12px 0 18px !important;
    color: #444444 !important;
    font-size: 16px !important;
    line-height: 1.65 !important;
}
body .sbtp-single-image {
    width: 100% !important;
    height: 315px !important;
    margin: 18px 0 0 !important;
    background-color: #eeeeee !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: 12px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
}
body .sbtp-side-stack { display: grid !important; gap: 18px !important; }
body .sbtp-side-card,
body .sbtp-content-card,
body .sbtp-linked-card,
body .sbtp-timeline-card,
body .sbtp-related-topics {
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    padding: 24px !important;
}
body .sbtp-side-card h2,
body .sbtp-content-card h2,
body .sbtp-linked-card h2,
body .sbtp-timeline-card h2,
body .sbtp-related-topics h2 {
    margin: 0 0 18px !important;
    color: var(--sbtp-black) !important;
    font-size: 18px !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
}
body .sbtp-side-card dl { display: grid !important; gap: 18px !important; margin: 0 !important; }
body .sbtp-side-card dl div {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    gap: 18px !important;
    align-items: center !important;
}
body .sbtp-side-card dt { color: #555555 !important; font-weight: 800 !important; }
body .sbtp-side-card dt span { color: var(--sbtp-orange) !important; margin-right: 8px !important; }
body .sbtp-side-card dd { margin: 0 !important; color: var(--sbtp-black) !important; font-weight: 800 !important; text-align: right !important; }
body .sbtp-related-application-card {
    border-color: rgba(245,166,35,.55) !important;
    background: linear-gradient(180deg, #ffffff 0%, #fffaf0 100%) !important;
}
body .sbtp-related-application {
    display: grid !important;
    grid-template-columns: 48px 1fr !important;
    gap: 14px !important;
    align-items: center !important;
    margin-bottom: 18px !important;
}
body .sbtp-doc-symbol,
body .sbtp-pdf-icon {
    display: grid !important;
    place-items: center !important;
    width: 46px !important;
    height: 46px !important;
    border: 2px solid var(--sbtp-orange) !important;
    border-radius: 8px !important;
    color: var(--sbtp-orange) !important;
    font-weight: 900 !important;
}
body .sbtp-related-application strong { display: block !important; color: #111 !important; line-height: 1.25 !important; }
body .sbtp-related-application span { display: block !important; margin-top: 4px !important; color: #777 !important; font-size: 13px !important; }
body .sbtp-mini-update {
    display: grid !important;
    grid-template-columns: 70px 1fr !important;
    gap: 12px !important;
    align-items: center !important;
    padding: 0 0 14px !important;
    margin: 0 0 14px !important;
    border-bottom: 1px solid var(--sbtp-border) !important;
    text-decoration: none !important;
}
body .sbtp-mini-update img { width: 70px !important; height: 52px !important; object-fit: cover !important; border-radius: 7px !important; }
body .sbtp-mini-update strong { color: #111 !important; display: block !important; line-height: 1.25 !important; }
body .sbtp-mini-update em { color: #777 !important; font-style: normal !important; font-size: 13px !important; }
body .sbtp-single-chips {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 14px !important;
    margin: 20px 0 22px !important;
}
body .sbtp-single-chips div {
    display: grid !important;
    grid-template-columns: auto 1fr !important;
    align-items: center !important;
    gap: 8px !important;
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 10px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    padding: 16px 18px !important;
}
body .sbtp-single-chips strong { color: #111 !important; font-size: 18px !important; font-weight: 900 !important; }
body .sbtp-single-chips span { color: #666 !important; font-size: 13px !important; }
body .sbtp-single-bottom-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 390px !important;
    gap: 34px !important;
    align-items: start !important;
}
body .sbtp-single-main-content { display: grid !important; gap: 0 !important; }
body .sbtp-section-row {
    display: grid !important;
    grid-template-columns: 58px 1fr !important;
    gap: 18px !important;
    padding: 22px 0 !important;
    border-bottom: 1px solid var(--sbtp-border) !important;
}
body .sbtp-section-row:first-child { padding-top: 0 !important; }
body .sbtp-section-row h2 {
    margin: 0 0 8px !important;
    color: #111111 !important;
    font-size: 18px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
}
body .sbtp-section-row p,
body .sbtp-the-content {
    color: #444444 !important;
    line-height: 1.65 !important;
}
body .sbtp-section-icon {
    display: grid !important;
    place-items: center !important;
    width: 38px !important;
    height: 38px !important;
    color: var(--sbtp-orange) !important;
    font-size: 30px !important;
    line-height: 1 !important;
}
body .sbtp-quote {
    margin: 20px 0 !important;
    padding: 18px 22px !important;
    background: #fff7eb !important;
    border-left: 5px solid var(--sbtp-orange) !important;
    border-radius: 8px !important;
    color: #222222 !important;
    font-weight: 700 !important;
}
body .sbtp-linked-card { margin-top: 18px !important; }
body .sbtp-linked-item {
    display: grid !important;
    grid-template-columns: 54px 1fr auto !important;
    gap: 16px !important;
    align-items: center !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 10px !important;
    padding: 14px !important;
}
body .sbtp-linked-item strong { display: block !important; color: #111 !important; }
body .sbtp-linked-item span { display: block !important; color: #777 !important; font-size: 13px !important; margin-top: 3px !important; }
body .sbtp-linked-actions { display: flex !important; gap: 10px !important; flex-wrap: wrap !important; justify-content: flex-end !important; }
body .sbtp-timeline-card { position: sticky !important; top: 110px !important; }
body .sbtp-timeline {
    position: relative !important;
    display: grid !important;
    gap: 20px !important;
    padding-left: 18px !important;
}
body .sbtp-timeline::before {
    content: "" !important;
    position: absolute !important;
    left: 6px !important;
    top: 6px !important;
    bottom: 6px !important;
    width: 2px !important;
    background: #dddddd !important;
}
body .sbtp-timeline-item {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 100px 1fr !important;
    gap: 16px !important;
}
body .sbtp-timeline-item::before {
    content: "" !important;
    position: absolute !important;
    left: -17px !important;
    top: 4px !important;
    width: 13px !important;
    height: 13px !important;
    border-radius: 50% !important;
    background: var(--sbtp-orange) !important;
    box-shadow: 0 0 0 4px #ffffff !important;
}
body .sbtp-timeline-item span { color: #777 !important; font-size: 13px !important; }
body .sbtp-timeline-item strong { color: #111 !important; font-weight: 900 !important; }
body .sbtp-timeline-item p { grid-column: 2 !important; margin: -8px 0 0 !important; color: #555 !important; line-height: 1.45 !important; }
body .sbtp-related-topics { margin-top: 22px !important; }
body .sbtp-related-topic-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 12px !important;
}
body .sbtp-related-topic-grid a {
    display: block !important;
    padding: 13px 15px !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 9px !important;
    color: #111111 !important;
    text-decoration: none !important;
}
body .sbtp-related-topic-grid strong { display: block !important; font-size: 14px !important; line-height: 1.2 !important; }
body .sbtp-related-topic-grid span { color: #777 !important; font-size: 12px !important; }
body .sbtp-related-all { display: flex !important; align-items: center !important; justify-content: center !important; font-weight: 900 !important; text-transform: uppercase !important; }

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media (max-width: 1400px) {
    body .sbtp-grid,
    body .sbtp-archive-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
}
@media (max-width: 1280px) {
    body .sbtp-grid,
    body .sbtp-archive-grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
    body .sbtp-start-cards { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 1050px) {
    body .sbtp-start-inner,
    body .sbtp-single-layout-top,
    body .sbtp-single-bottom-grid { grid-template-columns: 1fr !important; }
    body .sbtp-side-stack,
    body .sbtp-timeline-card { position: static !important; }
    body .sbtp-statsbar-wide { grid-template-columns: repeat(2, 1fr) !important; }
    body .sbtp-filter-pills { grid-template-columns: 1fr !important; gap: 18px !important; }
}
@media (max-width: 778px) {
    body .sbtp-container,
    body .sbtp-start-inner { width: min(100% - 28px, 1500px) !important; }
    body .sbtp-archive-hero { min-height: 0 !important; padding: 44px 0 42px !important; background-position: center right !important; }
    body .sbtp-archive-hero h1 { font-size: 46px !important; }
    body .sbtp-statsbar-wide,
    body .sbtp-statsbar { grid-template-columns: 1fr !important; }
    body .sbtp-statbox,
    body .sbtp-statsbar > div { border-right: none !important; border-bottom: 1px solid var(--sbtp-border) !important; }
    body .sbtp-statbox:last-child,
    body .sbtp-statsbar > div:last-child { border-bottom: none !important; }
    body .sbtp-grid,
    body .sbtp-archive-grid,
    body .sbtp-grid-wrap .sbtp-grid,
    body .sbtp-start-cards { grid-template-columns: 1fr !important; }
    body .sbtp-start-stats,
    body .sbtp-single-chips,
    body .sbtp-related-topic-grid { grid-template-columns: 1fr !important; }
    body .sbtp-single-image { height: 230px !important; }
    body .sbtp-linked-item { grid-template-columns: 1fr !important; }
    body .sbtp-linked-actions { justify-content: flex-start !important; }
    body .sbtp-timeline-item { grid-template-columns: 1fr !important; gap: 5px !important; }
    body .sbtp-timeline-item p { grid-column: 1 !important; margin: 0 !important; }
    body .sbtp-section-row { grid-template-columns: 44px 1fr !important; }
    body .sbtp-focus-body h3 { padding-left: 0 !important; padding-top: 38px !important; }
}


/* =====================================================
   SB THEMEN & PROJEKTE – REFERENZLAYOUT FINAL OVERRIDE
   Version 1.1.0
   Ziel: Optik exakt an die freigegebenen Referenzbilder angleichen.
   Wichtig für Drittanbieter/KI:
   - Alle Selektoren bleiben mit .sbtp-* gekapselt.
   - WordPress-Baukasten-Wrapper des Nutzers werden zusätzlich unterstützt:
     .fg-themen-row-2601, .fg-themen-counter-2601, .fg-themen-blocke-2601
   - Diese Regeln sind bewusst am Ende der CSS-Datei platziert und nutzen
     !important, damit The7/WPBakery/Avada/Elementor sie nicht überschreiben.
   ===================================================== */

:root {
    --sbtp-orange: var(--fg-farbe-primary, #f5a623);
    --sbtp-orange-dark: #d99012;
    --sbtp-black: var(--fg-farbe-secondary, #111111);
    --sbtp-text: #333333;
    --sbtp-muted: #666666;
    --sbtp-border: #e8e8e8;
    --sbtp-soft: #f7f7f7;
    --sbtp-cream: #fffaf0;
    --sbtp-white: #ffffff;
    --sbtp-green: #1f8a3b;
    --sbtp-red: #b30000;
    --sbtp-blue: #1873d3;
    --sbtp-radius: 14px;
    --sbtp-font-headline: var(--fg-font-headline, "Oswald", sans-serif);
    --sbtp-font-text: var(--fg-font-text, "Open Sans", sans-serif);
    --sbtp-shadow: 0 14px 34px rgba(0,0,0,.085);
    --sbtp-shadow-soft: 0 8px 24px rgba(0,0,0,.060);
}

body .sbtp-container,
body .sbtp-start-inner {
    width: min(100% - 72px, 1500px) !important;
    max-width: 1500px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box !important;
}

body .sbtp-kicker,
body .sbtp-counter .sbtp-kicker {
    display: inline-block !important;
    margin: 0 0 12px 0 !important;
    font-family: var(--sbtp-font-text) !important;
    color: var(--sbtp-orange) !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
}

/* -----------------------------
   STARTSEITE – einteiliger Shortcode [sb_themen_startseite]
   ----------------------------- */
body .sbtp-start-section {
    position: relative !important;
    overflow: visible !important;
    margin: 0 auto !important;
    padding: 56px 0 50px !important;
    background: linear-gradient(180deg, #ffffff 0%, #fffaf0 100%) !important;
    border-radius: 16px 16px 0 0 !important;
    box-shadow: 0 -5px 20px rgba(0,0,0,.030) !important;
}
body .sbtp-start-inner {
    display: grid !important;
    grid-template-columns: minmax(320px, 400px) 1fr !important;
    gap: 34px !important;
    align-items: stretch !important;
}
body .sbtp-start-copy {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    min-width: 0 !important;
    padding: 4px 0 !important;
}
body .sbtp-start-copy h2 {
    max-width: 395px !important;
    margin: 0 0 16px !important;
    font-family: var(--sbtp-font-headline) !important;
    color: var(--sbtp-black) !important;
    font-size: clamp(30px, 2.4vw, 44px) !important;
    line-height: 1.08 !important;
    font-weight: 900 !important;
    letter-spacing: -.02em !important;
    text-transform: none !important;
}
body .sbtp-start-copy p {
    max-width: 430px !important;
    margin: 0 0 26px !important;
    font-family: var(--sbtp-font-text) !important;
    color: #555555 !important;
    font-size: 16px !important;
    line-height: 1.68 !important;
}
body .sbtp-start-stats {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 12px !important;
    margin: 0 0 26px !important;
}
body .sbtp-start-stats div {
    display: grid !important;
    grid-template-columns: auto 1fr !important;
    align-items: center !important;
    gap: 10px !important;
    min-height: 78px !important;
    padding: 16px 14px !important;
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
}
body .sbtp-start-stats strong {
    color: var(--sbtp-black) !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 33px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
}
body .sbtp-start-stats span {
    color: #333333 !important;
    font-size: 12px !important;
    line-height: 1.12 !important;
    font-weight: 800 !important;
}
body .sbtp-start-copy .sbtp-button-outline,
body .sbtp-start-copy .sbtp-button {
    width: fit-content !important;
    min-width: 210px !important;
    background: transparent !important;
    border: 2px solid var(--sbtp-orange) !important;
    color: var(--sbtp-orange) !important;
    border-radius: 6px !important;
    text-decoration: none !important;
}
body .sbtp-start-copy .sbtp-button-outline:hover,
body .sbtp-start-copy .sbtp-button:hover {
    background: var(--sbtp-orange) !important;
    color: #111111 !important;
    border-color: var(--sbtp-orange) !important;
}
body .sbtp-start-cards {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 24px !important;
    align-items: stretch !important;
}
body .sbtp-focus-card {
    position: relative !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 13px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease !important;
}
body .sbtp-focus-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 16px 36px rgba(0,0,0,.105) !important;
    border-color: rgba(245,166,35,.56) !important;
}
body .sbtp-focus-image {
    position: relative !important;
    display: block !important;
    height: 215px !important;
    background-color: #eeeeee !important;
    background-size: cover !important;
    background-position: center !important;
    text-decoration: none !important;
}
body .sbtp-focus-image .sbtp-badge {
    position: absolute !important;
    left: 18px !important;
    top: 16px !important;
    z-index: 2 !important;
    background: rgba(255,255,255,.92) !important;
    backdrop-filter: blur(4px) !important;
}
body .sbtp-focus-body {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    padding: 28px 22px 22px !important;
}
body .sbtp-focus-icon {
    position: absolute !important;
    left: 22px !important;
    top: -24px !important;
    width: 58px !important;
    height: 58px !important;
    display: grid !important;
    place-items: center !important;
    background: #fff8ea !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 50% !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    color: var(--sbtp-orange) !important;
}
body .sbtp-focus-icon svg { width: 28px !important; height: 28px !important; display: block !important; }
body .sbtp-focus-body h3 {
    margin: 0 0 10px !important;
    padding-left: 72px !important;
    font-family: var(--sbtp-font-headline) !important;
    color: var(--sbtp-black) !important;
    font-size: 24px !important;
    line-height: 1.15 !important;
    font-weight: 900 !important;
    text-transform: none !important;
}
body .sbtp-focus-body h3 a { color: var(--sbtp-black) !important; text-decoration: none !important; }
body .sbtp-focus-body h3 a:hover { color: var(--sbtp-orange) !important; }
body .sbtp-focus-body p {
    margin: 0 0 18px !important;
    color: #444444 !important;
    font-size: 15px !important;
    line-height: 1.58 !important;
}
body .sbtp-focus-body .sbtp-card-meta { display: none !important; }
body .sbtp-focus-link,
body .sbtp-start-cards .sbtp-button {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    min-height: 0 !important;
    margin-top: auto !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    color: var(--sbtp-orange) !important;
    box-shadow: none !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
}
body .sbtp-focus-link:hover,
body .sbtp-start-cards .sbtp-button:hover { color: var(--sbtp-black) !important; transform: none !important; }

/* -----------------------------
   WPBakery-Startseitenaufbau mit 1/3 + 2/3 Spalten
   ----------------------------- */
body .fg-themen-row-2601 {
    position: relative !important;
    padding: 56px 0 50px !important;
    background: linear-gradient(180deg, #ffffff 0%, #fffaf0 100%) !important;
    border-radius: 16px 16px 0 0 !important;
}
body .fg-themen-counter-2601 .sbtp-counter {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
}
body .fg-themen-counter-2601 .sbtp-counter-head h3,
body .fg-themen-counter-2601 .sbtp-counter h3 {
    max-width: 395px !important;
    margin: 0 0 16px !important;
    font-family: var(--sbtp-font-headline) !important;
    color: var(--sbtp-black) !important;
    font-size: clamp(30px, 2.4vw, 44px) !important;
    line-height: 1.08 !important;
    font-weight: 900 !important;
    text-transform: none !important;
}
body .fg-themen-counter-2601 .sbtp-counter-stats {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 12px !important;
    margin: 26px 0 !important;
}
body .fg-themen-counter-2601 .sbtp-counter-item {
    display: grid !important;
    grid-template-columns: auto 1fr !important;
    align-items: center !important;
    gap: 10px !important;
    min-height: 78px !important;
    padding: 16px 14px !important;
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
}
body .fg-themen-counter-2601 .sbtp-counter-icon { display: none !important; }
body .fg-themen-counter-2601 .sbtp-counter-item strong {
    color: var(--sbtp-black) !important;
    font-size: 33px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
}
body .fg-themen-counter-2601 .sbtp-counter-item span:last-child {
    color: #333 !important;
    font-size: 12px !important;
    line-height: 1.12 !important;
    font-weight: 800 !important;
}
body .fg-themen-counter-2601 .sbtp-counter-link {
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 42px !important;
    padding: 12px 22px !important;
    border: 2px solid var(--sbtp-orange) !important;
    border-radius: 6px !important;
    color: var(--sbtp-orange) !important;
    background: transparent !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
    font-size: 13px !important;
    font-weight: 900 !important;
}
body .fg-themen-counter-2601 .sbtp-counter-link:hover { background: var(--sbtp-orange) !important; color: #111 !important; }
body .fg-themen-blocke-2601 .sbtp-grid-wrap { margin: 0 !important; padding: 0 !important; background: transparent !important; }
body .fg-themen-blocke-2601 .sbtp-grid-wrap .sbtp-grid,
body .fg-themen-blocke-2601 .sbtp-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 24px !important;
}
body .fg-themen-blocke-2601 .sbtp-card-meta,
body .fg-themen-blocke-2601 .sbtp-card-icon { display: none !important; }
body .fg-themen-blocke-2601 .sbtp-card .sbtp-button {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    min-height: 0 !important;
    width: fit-content !important;
    color: var(--sbtp-orange) !important;
    box-shadow: none !important;
}

/* -----------------------------
   ARCHIV /themen/ – Referenzlayout mit Hero, Stats, Filtern, 5 Karten
   ----------------------------- */
body .sbtp-archive-page { background: #ffffff !important; color: var(--sbtp-text) !important; }
body .sbtp-archive-hero {
    position: relative !important;
    overflow: hidden !important;
    min-height: 305px !important;
    padding: 70px 0 58px !important;
    background-image:
        linear-gradient(90deg, #ffffff 0%, rgba(255,255,255,.96) 35%, rgba(255,255,255,.68) 60%, rgba(255,255,255,.18) 100%),
        url('sbtp-rathaus-hero.jpg') !important;
    background-size: cover !important;
    background-position: center right !important;
}
body .sbtp-archive-hero::after {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    height: 78px !important;
    background: linear-gradient(180deg, rgba(255,255,255,0), #ffffff) !important;
    pointer-events: none !important;
}
body .sbtp-archive-hero .sbtp-container { position: relative !important; z-index: 2 !important; }
body .sbtp-archive-hero h1 {
    max-width: 700px !important;
    margin: 0 0 18px !important;
    font-family: var(--sbtp-font-headline) !important;
    color: var(--sbtp-black) !important;
    font-size: clamp(54px, 5.2vw, 82px) !important;
    line-height: .92 !important;
    font-weight: 900 !important;
    letter-spacing: -.03em !important;
    text-transform: uppercase !important;
}
body .sbtp-archive-hero h1 span { color: var(--sbtp-orange) !important; }
body .sbtp-archive-hero p {
    max-width: 600px !important;
    margin: 0 !important;
    color: #444 !important;
    font-size: 17px !important;
    line-height: 1.75 !important;
}
body .sbtp-archive-main {
    position: relative !important;
    z-index: 4 !important;
    margin-top: -32px !important;
    padding: 0 0 78px !important;
}
body .sbtp-statsbar-wide,
body .sbtp-statsbar {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    overflow: hidden !important;
    margin: 0 0 26px !important;
    background: rgba(255,255,255,.97) !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    backdrop-filter: blur(3px) !important;
}
body .sbtp-statbox,
body .sbtp-statsbar > div {
    min-height: 94px !important;
    padding: 22px 28px !important;
    border-right: 1px solid var(--sbtp-border) !important;
    display: grid !important;
    grid-template-columns: auto 1fr auto !important;
    align-items: center !important;
    gap: 14px !important;
}
body .sbtp-statbox:last-child,
body .sbtp-statsbar > div:last-child { border-right: none !important; }
body .sbtp-statbox strong,
body .sbtp-statsbar strong {
    color: var(--sbtp-orange) !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 38px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
}
body .sbtp-statbox span,
body .sbtp-statsbar span {
    color: var(--sbtp-black) !important;
    font-size: 14px !important;
    line-height: 1.18 !important;
    font-weight: 800 !important;
}
body .sbtp-statbox i { color: var(--sbtp-orange) !important; font-style: normal !important; font-size: 31px !important; }
body .sbtp-filter-pills {
    display: grid !important;
    grid-template-columns: minmax(310px, auto) 1fr !important;
    gap: 26px 74px !important;
    align-items: start !important;
    margin: 0 0 34px !important;
}
body .sbtp-filter-group > strong {
    display: block !important;
    margin: 0 0 10px !important;
    color: #222 !important;
    font-size: 14px !important;
    font-weight: 900 !important;
}
body .sbtp-filter-options { display: flex !important; flex-wrap: wrap !important; gap: 10px !important; }
body .sbtp-filter-options a {
    min-width: 70px !important;
    padding: 9px 16px !important;
    background: #f2f2f2 !important;
    border-radius: 9px !important;
    color: #333 !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    text-align: center !important;
    text-decoration: none !important;
}
body .sbtp-filter-options a:hover,
body .sbtp-filter-options a.is-active { background: var(--sbtp-orange) !important; color: #111 !important; transform: translateY(-1px) !important; }
body .sbtp-grid,
body .sbtp-archive-grid {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 24px !important;
}
body .sbtp-grid-wrap .sbtp-grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
body .sbtp-card {
    position: relative !important;
    overflow: hidden !important;
    min-width: 0 !important;
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease !important;
}
body .sbtp-card:hover { transform: translateY(-4px) !important; border-color: rgba(245,166,35,.55) !important; box-shadow: 0 16px 38px rgba(0,0,0,.10) !important; }
body .sbtp-card-image {
    display: block !important;
    height: 148px !important;
    background-color: #eee !important;
    background-size: cover !important;
    background-position: center !important;
    text-decoration: none !important;
}
body .sbtp-card-body {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 258px !important;
    padding: 18px 20px 18px !important;
}
body .sbtp-archive-grid .sbtp-card-icon { display: none !important; }
body .sbtp-card h3 {
    margin: 0 0 10px !important;
    font-family: var(--sbtp-font-headline) !important;
    color: var(--sbtp-black) !important;
    font-size: 21px !important;
    line-height: 1.16 !important;
    font-weight: 900 !important;
    letter-spacing: -.01em !important;
    text-transform: uppercase !important;
}
body .sbtp-card h3 a { color: var(--sbtp-black) !important; text-decoration: none !important; }
body .sbtp-card h3 a:hover { color: var(--sbtp-orange) !important; }
body .sbtp-card .sbtp-badge { margin: 0 0 12px !important; }
body .sbtp-card p {
    margin: 0 0 14px !important;
    color: #444 !important;
    font-size: 15px !important;
    line-height: 1.48 !important;
}
body .sbtp-card-meta { display: flex !important; flex-wrap: wrap !important; gap: 14px !important; margin: auto 0 16px !important; color: #777 !important; font-size: 13px !important; }
body .sbtp-card-meta span { display: inline-flex !important; align-items: center !important; gap: 5px !important; }
body .sbtp-card-meta i { font-style: normal !important; color: #777 !important; }
body .sbtp-card .sbtp-button {
    width: 100% !important;
    min-height: 38px !important;
    padding: 10px 16px !important;
    margin-top: 0 !important;
    background: var(--sbtp-orange) !important;
    border-color: var(--sbtp-orange) !important;
    color: #111 !important;
}
body .sbtp-more-wrap { text-align: center !important; margin-top: 30px !important; }
body .sbtp-more-button {
    min-width: 340px !important;
    background: #ffffff !important;
    border-color: var(--sbtp-border) !important;
    color: #222 !important;
}

/* -----------------------------
   EINZELANSICHT – Referenzlayout
   ----------------------------- */
body .sbtp-single-page { background: #fff !important; color: var(--sbtp-text) !important; padding: 0 0 72px !important; }
body .sbtp-breadcrumb { padding: 20px 0 18px !important; color: #777 !important; font-size: 13px !important; }
body .sbtp-breadcrumb a { color: #555 !important; text-decoration: none !important; }
body .sbtp-breadcrumb a:hover { color: var(--sbtp-orange) !important; }
body .sbtp-single-layout-top {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 390px !important;
    gap: 34px !important;
    align-items: start !important;
}
body .sbtp-single-main-head h1 {
    max-width: 840px !important;
    margin: 0 0 12px !important;
    font-family: var(--sbtp-font-headline) !important;
    color: var(--sbtp-black) !important;
    font-size: clamp(40px, 4vw, 58px) !important;
    line-height: .96 !important;
    font-weight: 900 !important;
    letter-spacing: -.025em !important;
    text-transform: uppercase !important;
}
body .sbtp-lead { max-width: 790px !important; margin: 12px 0 18px !important; color: #444 !important; font-size: 16px !important; line-height: 1.65 !important; }
body .sbtp-single-image {
    width: 100% !important;
    height: 315px !important;
    margin: 18px 0 0 !important;
    background-color: #eee !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: 12px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
}
body .sbtp-side-stack { display: grid !important; gap: 18px !important; }
body .sbtp-side-card,
body .sbtp-content-card,
body .sbtp-linked-card,
body .sbtp-timeline-card,
body .sbtp-related-topics {
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--sbtp-shadow-soft) !important;
    padding: 24px !important;
}
body .sbtp-side-card h2,
body .sbtp-content-card h2,
body .sbtp-linked-card h2,
body .sbtp-timeline-card h2,
body .sbtp-related-topics h2 {
    margin: 0 0 18px !important;
    font-family: var(--sbtp-font-headline) !important;
    color: var(--sbtp-black) !important;
    font-size: 18px !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
}
body .sbtp-side-card dl { display: grid !important; gap: 18px !important; margin: 0 !important; }
body .sbtp-side-card dl div { display: grid !important; grid-template-columns: 1fr auto !important; gap: 18px !important; align-items: center !important; }
body .sbtp-side-card dt { color: #555 !important; font-weight: 800 !important; }
body .sbtp-side-card dt span { color: var(--sbtp-orange) !important; margin-right: 8px !important; }
body .sbtp-side-card dd { margin: 0 !important; color: var(--sbtp-black) !important; font-weight: 800 !important; text-align: right !important; }
body .sbtp-related-application-card { border-color: rgba(245,166,35,.55) !important; background: linear-gradient(180deg, #ffffff 0%, #fffaf0 100%) !important; }
body .sbtp-related-application { display: grid !important; grid-template-columns: 48px 1fr !important; gap: 14px !important; align-items: center !important; margin-bottom: 18px !important; }
body .sbtp-doc-symbol,
body .sbtp-pdf-icon { display: grid !important; place-items: center !important; width: 46px !important; height: 46px !important; border: 2px solid var(--sbtp-orange) !important; border-radius: 8px !important; color: var(--sbtp-orange) !important; font-weight: 900 !important; }
body .sbtp-related-application strong { display: block !important; color: #111 !important; line-height: 1.25 !important; }
body .sbtp-related-application span { display: block !important; margin-top: 4px !important; color: #777 !important; font-size: 13px !important; }
body .sbtp-mini-update { display: grid !important; grid-template-columns: 70px 1fr !important; gap: 12px !important; align-items: center !important; padding: 0 0 14px !important; margin: 0 0 14px !important; border-bottom: 1px solid var(--sbtp-border) !important; text-decoration: none !important; }
body .sbtp-mini-update img { width: 70px !important; height: 52px !important; object-fit: cover !important; border-radius: 7px !important; }
body .sbtp-mini-update strong { color: #111 !important; display: block !important; line-height: 1.25 !important; }
body .sbtp-mini-update em { color: #777 !important; font-style: normal !important; font-size: 13px !important; }
body .sbtp-single-chips { display: grid !important; grid-template-columns: repeat(4, minmax(0, 1fr)) !important; gap: 14px !important; margin: 20px 0 22px !important; }
body .sbtp-single-chips div { display: grid !important; grid-template-columns: auto 1fr !important; align-items: center !important; gap: 8px !important; background: #ffffff !important; border: 1px solid var(--sbtp-border) !important; border-radius: 10px !important; box-shadow: var(--sbtp-shadow-soft) !important; padding: 16px 18px !important; }
body .sbtp-single-chips strong { color: #111 !important; font-size: 18px !important; font-weight: 900 !important; }
body .sbtp-single-chips span { color: #666 !important; font-size: 13px !important; }
body .sbtp-single-bottom-grid { display: grid !important; grid-template-columns: minmax(0, 1fr) 390px !important; gap: 34px !important; align-items: start !important; }
body .sbtp-single-main-content { display: grid !important; gap: 0 !important; }
body .sbtp-section-row { display: grid !important; grid-template-columns: 58px 1fr !important; gap: 18px !important; padding: 22px 0 !important; border-bottom: 1px solid var(--sbtp-border) !important; }
body .sbtp-section-row:first-child { padding-top: 0 !important; }
body .sbtp-section-row h2 { margin: 0 0 8px !important; font-family: var(--sbtp-font-headline) !important; color: #111 !important; font-size: 18px !important; font-weight: 900 !important; text-transform: uppercase !important; }
body .sbtp-section-row p,
body .sbtp-the-content { color: #444 !important; line-height: 1.65 !important; }
body .sbtp-section-icon { display: grid !important; place-items: center !important; width: 38px !important; height: 38px !important; color: var(--sbtp-orange) !important; font-size: 30px !important; line-height: 1 !important; }
body .sbtp-quote { margin: 20px 0 !important; padding: 18px 22px !important; background: #fff7eb !important; border-left: 5px solid var(--sbtp-orange) !important; border-radius: 8px !important; color: #222 !important; font-weight: 700 !important; }
body .sbtp-linked-card { margin-top: 18px !important; }
body .sbtp-linked-item { display: grid !important; grid-template-columns: 54px 1fr auto !important; gap: 16px !important; align-items: center !important; border: 1px solid var(--sbtp-border) !important; border-radius: 10px !important; padding: 14px !important; }
body .sbtp-linked-item strong { display: block !important; color: #111 !important; }
body .sbtp-linked-item span { display: block !important; color: #777 !important; font-size: 13px !important; margin-top: 3px !important; }
body .sbtp-linked-actions { display: flex !important; gap: 10px !important; flex-wrap: wrap !important; justify-content: flex-end !important; }
body .sbtp-timeline-card { position: sticky !important; top: 110px !important; }
body .sbtp-timeline { position: relative !important; display: grid !important; gap: 20px !important; padding-left: 18px !important; }
body .sbtp-timeline::before { content: "" !important; position: absolute !important; left: 6px !important; top: 6px !important; bottom: 6px !important; width: 2px !important; background: #ddd !important; }
body .sbtp-timeline-item { position: relative !important; display: grid !important; grid-template-columns: 100px 1fr !important; gap: 16px !important; }
body .sbtp-timeline-item::before { content: "" !important; position: absolute !important; left: -17px !important; top: 4px !important; width: 13px !important; height: 13px !important; border-radius: 50% !important; background: var(--sbtp-orange) !important; box-shadow: 0 0 0 4px #fff !important; }
body .sbtp-timeline-item span { color: #777 !important; font-size: 13px !important; }
body .sbtp-timeline-item strong { color: #111 !important; font-weight: 900 !important; }
body .sbtp-timeline-item p { grid-column: 2 !important; margin: -8px 0 0 !important; color: #555 !important; line-height: 1.45 !important; }
body .sbtp-related-topics { margin-top: 22px !important; }
body .sbtp-related-topic-grid { display: grid !important; grid-template-columns: repeat(4, minmax(0, 1fr)) !important; gap: 12px !important; }
body .sbtp-related-topic-grid a { display: block !important; padding: 13px 15px !important; border: 1px solid var(--sbtp-border) !important; border-radius: 9px !important; color: #111 !important; text-decoration: none !important; }
body .sbtp-related-topic-grid strong { display: block !important; font-size: 14px !important; line-height: 1.2 !important; }
body .sbtp-related-topic-grid span { color: #777 !important; font-size: 12px !important; }
body .sbtp-related-all { display: flex !important; align-items: center !important; justify-content: center !important; font-weight: 900 !important; text-transform: uppercase !important; }

@media (max-width: 1400px) {
    body .sbtp-grid,
    body .sbtp-archive-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
}
@media (max-width: 1280px) {
    body .sbtp-grid,
    body .sbtp-archive-grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
    body .sbtp-start-cards { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 1050px) {
    body .sbtp-start-inner,
    body .sbtp-single-layout-top,
    body .sbtp-single-bottom-grid { grid-template-columns: 1fr !important; }
    body .sbtp-side-stack,
    body .sbtp-timeline-card { position: static !important; }
    body .sbtp-statsbar-wide { grid-template-columns: repeat(2, 1fr) !important; }
    body .sbtp-filter-pills { grid-template-columns: 1fr !important; gap: 18px !important; }
    body .fg-themen-blocke-2601 .sbtp-grid-wrap .sbtp-grid,
    body .fg-themen-blocke-2601 .sbtp-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 778px) {
    body .sbtp-container,
    body .sbtp-start-inner { width: min(100% - 28px, 1500px) !important; }
    body .sbtp-start-section,
    body .fg-themen-row-2601 { padding: 38px 0 42px !important; }
    body .sbtp-archive-hero { min-height: 0 !important; padding: 44px 0 42px !important; background-position: center right !important; }
    body .sbtp-archive-hero h1 { font-size: 46px !important; }
    body .sbtp-statsbar-wide,
    body .sbtp-statsbar { grid-template-columns: 1fr !important; }
    body .sbtp-statbox,
    body .sbtp-statsbar > div { border-right: none !important; border-bottom: 1px solid var(--sbtp-border) !important; }
    body .sbtp-statbox:last-child,
    body .sbtp-statsbar > div:last-child { border-bottom: none !important; }
    body .sbtp-grid,
    body .sbtp-archive-grid,
    body .sbtp-grid-wrap .sbtp-grid,
    body .sbtp-start-cards,
    body .fg-themen-blocke-2601 .sbtp-grid-wrap .sbtp-grid,
    body .fg-themen-blocke-2601 .sbtp-grid { grid-template-columns: 1fr !important; }
    body .sbtp-start-stats,
    body .fg-themen-counter-2601 .sbtp-counter-stats,
    body .sbtp-single-chips,
    body .sbtp-related-topic-grid { grid-template-columns: 1fr !important; }
    body .sbtp-start-copy h2,
    body .fg-themen-counter-2601 .sbtp-counter h3 { font-size: 30px !important; }
    body .sbtp-single-image { height: 230px !important; }
    body .sbtp-linked-item { grid-template-columns: 1fr !important; }
    body .sbtp-linked-actions { justify-content: flex-start !important; }
    body .sbtp-timeline-item { grid-template-columns: 1fr !important; gap: 5px !important; }
    body .sbtp-timeline-item p { grid-column: 1 !important; margin: 0 !important; }
    body .sbtp-section-row { grid-template-columns: 44px 1fr !important; }
    body .sbtp-focus-body h3 { padding-left: 0 !important; padding-top: 38px !important; }
}

/* =====================================================
   SB THEMEN & PROJEKTE – STARTSEITE ENTWURF FINAL
   Version 1.0.9 – 05.06.2026
   Ziel: Startseitenblock exakt als geschlossener, breiter
   Beige-Bereich wie freigegebener Entwurf.

   Wichtig:
   - Diese Regeln müssen ganz am Ende der Plugin-CSS stehen.
   - Sie überschreiben ältere v1.0.7/v1.0.8-Styles und WPBakery.
   - Haupt-Shortcode: [sb_themen_startseite]
   ===================================================== */

:root {
    --sbtp-orange: var(--fg-farbe-primary, #f5a623);
    --sbtp-black: var(--fg-farbe-secondary, #111111);
    --sbtp-font-headline: var(--fg-font-headline, "Oswald", sans-serif);
    --sbtp-font-text: var(--fg-font-text, "Open Sans", sans-serif);
    --sbtp-cream-bg: #fbf3e6;
    --sbtp-card-bg: #ffffff;
    --sbtp-card-border: rgba(0,0,0,0.075);
    --sbtp-shadow-card: 0 8px 24px rgba(0,0,0,0.085);
    --sbtp-shadow-card-hover: 0 16px 36px rgba(0,0,0,0.13);
}

/* WPBakery-Zeile, wenn der Nutzer sie so benannt hat */
html body .fg-themen-startseite-full-2601,
html body .fg-themen-startseite-full-2601.vc_row,
html body .fg-themen-row-2601,
html body .fg-themen-row-2601.vc_row {
    background: var(--sbtp-cream-bg) !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    overflow: visible !important;
}

html body .fg-themen-startseite-full-2601 > .vc_column_container > .vc_column-inner,
html body .fg-themen-row-2601 > .vc_column_container > .vc_column-inner {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Der Shortcode selbst erzeugt den kompletten Bereich */
html body .sbtp-start-section {
    position: relative !important;
    overflow: visible !important;

    /* volle Breite, auch wenn WPBakery/Page-Container begrenzt */
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;

    padding: 58px 0 64px 0 !important;

    background: var(--sbtp-cream-bg) !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;

    box-sizing: border-box !important;
}

/* Kein weißer Innenkasten mehr */
html body .sbtp-start-section::before,
html body .sbtp-start-section::after {
    content: none !important;
    display: none !important;
}

html body .sbtp-start-inner {
    width: min(100% - 140px, 1500px) !important;
    max-width: 1500px !important;
    margin: 0 auto !important;
    padding: 0 !important;

    display: grid !important;
    grid-template-columns: minmax(360px, 0.34fr) minmax(0, 0.66fr) !important;
    gap: 38px !important;
    align-items: stretch !important;
    box-sizing: border-box !important;
}

/* Linke Text-/Counter-Spalte */
html body .sbtp-start-copy {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: flex-start !important;
    min-width: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

html body .sbtp-start-copy .sbtp-kicker,
html body .sbtp-start-section .sbtp-kicker {
    display: block !important;
    margin: 0 0 14px 0 !important;
    color: var(--sbtp-orange) !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

html body .sbtp-start-copy h2 {
    max-width: 430px !important;
    margin: 0 0 18px 0 !important;
    padding: 0 !important;
    color: var(--sbtp-black) !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: clamp(32px, 2.45vw, 44px) !important;
    line-height: 1.10 !important;
    font-weight: 900 !important;
    letter-spacing: -0.02em !important;
    text-transform: none !important;
}

html body .sbtp-start-copy p {
    max-width: 455px !important;
    margin: 0 0 28px 0 !important;
    color: #4d4d4d !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 16px !important;
    line-height: 1.68 !important;
    font-weight: 400 !important;
    text-align: left !important;
}

html body .sbtp-start-stats {
    width: 100% !important;
    max-width: 420px !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 12px !important;
    margin: 0 0 28px 0 !important;
}

html body .sbtp-start-stats div {
    min-width: 0 !important;
    min-height: 76px !important;
    display: grid !important;
    grid-template-columns: auto 1fr !important;
    align-items: center !important;
    gap: 9px !important;
    padding: 15px 13px !important;
    background: #ffffff !important;
    border: 1px solid rgba(0,0,0,0.08) !important;
    border-radius: 12px !important;
    box-shadow: 0 6px 18px rgba(0,0,0,0.06) !important;
    box-sizing: border-box !important;
}

html body .sbtp-start-stats strong {
    margin: 0 !important;
    color: var(--sbtp-black) !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 32px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
}

html body .sbtp-start-stats span {
    margin: 0 !important;
    color: #222222 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 11.5px !important;
    line-height: 1.12 !important;
    font-weight: 800 !important;
    text-align: left !important;
    text-transform: none !important;
}

html body .sbtp-start-copy .sbtp-button,
html body .sbtp-start-copy .sbtp-button-outline {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 220px !important;
    min-height: 48px !important;
    margin: 0 !important;
    padding: 13px 23px !important;
    background: transparent !important;
    border: 2px solid var(--sbtp-orange) !important;
    border-radius: 6px !important;
    box-shadow: none !important;
    color: var(--sbtp-orange) !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: 0.075em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    transition: background 0.22s ease, color 0.22s ease, transform 0.22s ease !important;
}

html body .sbtp-start-copy .sbtp-button:hover,
html body .sbtp-start-copy .sbtp-button-outline:hover {
    background: var(--sbtp-orange) !important;
    color: #111111 !important;
    transform: translateY(-2px) !important;
}

/* Rechte Karten-Spalte */
html body .sbtp-start-cards {
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 26px !important;
    align-items: stretch !important;
}

html body .sbtp-focus-card {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    background: var(--sbtp-card-bg) !important;
    border: 1px solid var(--sbtp-card-border) !important;
    border-radius: 13px !important;
    box-shadow: var(--sbtp-shadow-card) !important;
    transition: transform 0.23s ease, box-shadow 0.23s ease, border-color 0.23s ease !important;
}

html body .sbtp-focus-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: var(--sbtp-shadow-card-hover) !important;
    border-color: rgba(245,166,35,0.50) !important;
}

html body .sbtp-focus-image {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    height: 190px !important;
    flex: 0 0 190px !important;
    background-color: #eeeeee !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    text-decoration: none !important;
}

html body .sbtp-focus-image .sbtp-badge {
    position: absolute !important;
    left: 16px !important;
    top: 16px !important;
    z-index: 4 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 7px 12px !important;
    border-radius: 6px !important;
    background: rgba(255,255,255,0.90) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.10) !important;
    backdrop-filter: blur(4px) !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 11px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: 0.065em !important;
    text-transform: uppercase !important;
}

html body .sbtp-focus-body {
    position: relative !important;
    flex: 1 1 auto !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 34px 22px 24px 22px !important;
}

html body .sbtp-focus-icon {
    position: absolute !important;
    left: 22px !important;
    top: -30px !important;
    width: 58px !important;
    height: 58px !important;
    display: grid !important;
    place-items: center !important;
    color: #111111 !important;
    background: #fff8ea !important;
    border: 4px solid #ffffff !important;
    border-radius: 50% !important;
    box-shadow: 0 4px 14px rgba(0,0,0,0.10) !important;
}

html body .sbtp-focus-icon svg {
    width: 25px !important;
    height: 25px !important;
}

html body .sbtp-focus-body h3 {
    min-height: 58px !important;
    margin: 0 0 12px 0 !important;
    padding-left: 72px !important;
    color: var(--sbtp-black) !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 24px !important;
    line-height: 1.14 !important;
    font-weight: 900 !important;
    letter-spacing: -0.01em !important;
    text-transform: none !important;
    text-align: left !important;
    overflow: visible !important;
}

html body .sbtp-focus-body h3 a {
    color: inherit !important;
    text-decoration: none !important;
}

html body .sbtp-focus-body h3 a:hover {
    color: var(--sbtp-orange) !important;
}

html body .sbtp-focus-body p {
    margin: 0 0 20px 0 !important;
    color: #4d4d4d !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 15px !important;
    line-height: 1.62 !important;
    font-weight: 400 !important;
    text-align: left !important;
}

html body .sbtp-focus-body .sbtp-card-meta {
    display: none !important;
}

html body .sbtp-focus-link,
html body .sbtp-start-cards .sbtp-button {
    margin-top: auto !important;
    align-self: flex-start !important;
    display: inline-flex !important;
    align-items: center !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    color: var(--sbtp-orange) !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
}

html body .sbtp-focus-link:hover,
html body .sbtp-start-cards .sbtp-button:hover {
    color: var(--sbtp-black) !important;
    transform: none !important;
}

/* Statusfarben auf dem Fokus-Badge */
html body .sbtp-focus-image .sbtp-status-progress,
html body .sbtp-focus-image .sbtp-status-application,
html body .sbtp-focus-image .sbtp-status-review,
html body .sbtp-focus-image .sbtp-status-waiting {
    background: var(--sbtp-orange) !important;
    color: #ffffff !important;
}

html body .sbtp-focus-image .sbtp-status-done,
html body .sbtp-focus-image .sbtp-status-partly {
    background: #2e9f45 !important;
    color: #ffffff !important;
}

html body .sbtp-focus-image .sbtp-status-new,
html body .sbtp-focus-image .sbtp-status-request {
    background: #fff8ea !important;
    color: #b07300 !important;
}

html body .sbtp-focus-image .sbtp-status-blocked,
html body .sbtp-focus-image .sbtp-status-noresponse {
    background: #c83b36 !important;
    color: #ffffff !important;
}

/* Großer Bildschirm: etwas luftiger */
@media (min-width: 1600px) {
    html body .sbtp-start-inner {
        width: min(100% - 160px, 1540px) !important;
        grid-template-columns: minmax(390px, 0.33fr) minmax(0, 0.67fr) !important;
        gap: 42px !important;
    }

    html body .sbtp-focus-image {
        height: 205px !important;
        flex-basis: 205px !important;
    }
}

@media (max-width: 1180px) {
    html body .sbtp-start-inner {
        width: min(100% - 56px, 1180px) !important;
        grid-template-columns: 1fr !important;
        gap: 30px !important;
    }

    html body .sbtp-start-copy {
        max-width: 720px !important;
    }

    html body .sbtp-start-stats {
        max-width: 520px !important;
    }
}

@media (max-width: 920px) {
    html body .sbtp-start-cards {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 680px) {
    html body .sbtp-start-section {
        padding: 38px 0 44px 0 !important;
    }

    html body .sbtp-start-inner {
        width: min(100% - 28px, 680px) !important;
        gap: 24px !important;
    }

    html body .sbtp-start-copy h2 {
        font-size: 30px !important;
    }

    html body .sbtp-start-stats {
        grid-template-columns: 1fr !important;
        max-width: 100% !important;
    }

    html body .sbtp-start-cards {
        grid-template-columns: 1fr !important;
        gap: 18px !important;
    }

    html body .sbtp-focus-image {
        height: 205px !important;
        flex-basis: 205px !important;
    }

    html body .sbtp-focus-body h3 {
        min-height: 0 !important;
        padding-left: 72px !important;
        font-size: 23px !important;
    }
}


/* =====================================================
   SB THEMEN & PROJEKTE – ARCHIVSEITE ENTWURF FINAL
   Version 1.1.0 – 05.06.2026

   Ziel:
   - /themen/ soll dem freigegebenen Mockup entsprechen.
   - Theme-eigene Archivüberschrift „Archive: Themen" ausblenden.
   - Hero mit Rathausbild rechts, weißem Verlauf links.
   - Statistikleiste überlappt den Hero wie im Entwurf.
   - Filter und Karten breiter, ruhiger und mit weniger Rundung.
   ===================================================== */

:root {
    --sbtp-radius: 8px;
    --sbtp-radius-soft: 10px;
    --sbtp-archive-max: 1700px;
    --sbtp-orange: var(--fg-farbe-primary, #f5a623);
    --sbtp-black: var(--fg-farbe-secondary, #111111);
    --sbtp-font-headline: var(--fg-font-headline, "Oswald", sans-serif);
    --sbtp-font-text: var(--fg-font-text, "Open Sans", sans-serif);
}

/* The7/Theme-Archivkopf ausblenden – nur fuer Themenarchiv */
html body.post-type-archive-sb_thema .page-title,
html body.post-type-archive-sb_thema #page-title,
html body.post-type-archive-sb_thema .page-title-head,
html body.post-type-archive-sb_thema .dt-page-title,
html body.post-type-archive-sb_thema .wf-page-title,
html body.post-type-archive-sb_thema .archive-title,
html body.post-type-archive-sb_thema .entry-title.page-title,
html body.post-type-archive-sb_thema .breadcrumbs-container,
html body.post-type-archive-sb_thema .page-title .breadcrumbs,
html body.post-type-archive-sb_thema .page-title-breadcrumbs {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
}

html body.post-type-archive-sb_thema #main,
html body.post-type-archive-sb_thema #content,
html body.post-type-archive-sb_thema .content,
html body.post-type-archive-sb_thema .content-area {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

html body .sbtp-archive-page {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    background: #ffffff !important;
    color: #333333 !important;
    overflow: hidden !important;
}

html body .sbtp-archive-page .sbtp-container {
    width: min(100% - 140px, var(--sbtp-archive-max)) !important;
    max-width: var(--sbtp-archive-max) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
}

html body .sbtp-archive-hero,
html body .sbtp-hero-rathaus {
    position: relative !important;
    overflow: hidden !important;
    min-height: 430px !important;
    padding: 72px 0 170px 0 !important;
    background-image:
        linear-gradient(90deg,
            rgba(255,255,255,1) 0%,
            rgba(255,255,255,0.98) 29%,
            rgba(255,255,255,0.82) 50%,
            rgba(255,255,255,0.34) 73%,
            rgba(255,255,255,0.06) 100%),
        url('sbtp-rathaus-hero.jpg') !important;
    background-size: cover !important;
    background-position: center right !important;
    background-repeat: no-repeat !important;
    border: 0 !important;
    box-shadow: none !important;
}

html body .sbtp-archive-hero::after {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    height: 145px !important;
    background: linear-gradient(180deg, rgba(255,255,255,0) 0%, #ffffff 83%) !important;
    pointer-events: none !important;
    z-index: 1 !important;
}

html body .sbtp-archive-hero .sbtp-container {
    position: relative !important;
    z-index: 2 !important;
}

html body .sbtp-archive-hero-text {
    max-width: 650px !important;
}

html body .sbtp-archive-hero h1 {
    margin: 0 0 18px 0 !important;
    max-width: 760px !important;
    font-family: var(--sbtp-font-headline) !important;
    color: var(--sbtp-black) !important;
    font-size: clamp(56px, 5.7vw, 92px) !important;
    line-height: .90 !important;
    font-weight: 900 !important;
    letter-spacing: -0.035em !important;
    text-transform: uppercase !important;
}

html body .sbtp-archive-hero h1 span {
    color: var(--sbtp-orange) !important;
}

html body .sbtp-archive-hero p {
    margin: 0 !important;
    max-width: 650px !important;
    color: #444444 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 18px !important;
    line-height: 1.72 !important;
    font-weight: 400 !important;
    text-align: left !important;
}

html body .sbtp-archive-main {
    position: relative !important;
    z-index: 4 !important;
    margin-top: -98px !important;
    padding: 0 0 82px 0 !important;
    background: transparent !important;
}

html body .sbtp-archive-main .sbtp-container {
    position: relative !important;
    z-index: 5 !important;
}

/* Statistikleiste */
html body .sbtp-archive-page .sbtp-statsbar,
html body .sbtp-archive-page .sbtp-statsbar-wide {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    width: 100% !important;
    margin: 0 0 30px 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    background: rgba(255,255,255,0.96) !important;
    border: 1px solid rgba(0,0,0,0.08) !important;
    border-radius: 8px !important;
    box-shadow: 0 10px 32px rgba(0,0,0,0.075) !important;
    backdrop-filter: blur(4px) !important;
}

html body .sbtp-archive-page .sbtp-statbox {
    min-height: 104px !important;
    padding: 26px 32px !important;
    display: grid !important;
    grid-template-columns: auto 1fr auto !important;
    gap: 16px !important;
    align-items: center !important;
    border-right: 1px solid rgba(0,0,0,0.08) !important;
    background: transparent !important;
}

html body .sbtp-archive-page .sbtp-statbox:last-child {
    border-right: 0 !important;
}

html body .sbtp-archive-page .sbtp-statbox strong {
    margin: 0 !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 44px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    color: var(--sbtp-orange) !important;
}

html body .sbtp-archive-page .sbtp-statbox span {
    margin: 0 !important;
    color: var(--sbtp-black) !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 15px !important;
    line-height: 1.18 !important;
    font-weight: 900 !important;
    text-align: left !important;
}

html body .sbtp-archive-page .sbtp-statbox i {
    margin-left: auto !important;
    color: var(--sbtp-orange) !important;
    font-size: 30px !important;
    line-height: 1 !important;
    font-style: normal !important;
    opacity: .96 !important;
}

/* Filter */
html body .sbtp-archive-page .sbtp-filter-pills {
    display: grid !important;
    grid-template-columns: minmax(280px, .32fr) minmax(0, .68fr) !important;
    gap: 28px 86px !important;
    align-items: start !important;
    margin: 0 0 36px 0 !important;
}

html body .sbtp-archive-page .sbtp-filter-group > strong {
    display: block !important;
    margin: 0 0 10px 0 !important;
    color: #222222 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 14px !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
}

html body .sbtp-archive-page .sbtp-filter-options {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}

html body .sbtp-archive-page .sbtp-filter-options a {
    min-width: 76px !important;
    padding: 12px 18px !important;
    background: #f2f2f2 !important;
    color: #333333 !important;
    border: 0 !important;
    border-radius: 7px !important;
    box-shadow: none !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 14px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    text-align: center !important;
    text-decoration: none !important;
    transition: transform .20s ease, background .20s ease, color .20s ease !important;
}

html body .sbtp-archive-page .sbtp-filter-options a:hover,
html body .sbtp-archive-page .sbtp-filter-options a.is-active {
    background: var(--sbtp-orange) !important;
    color: #111111 !important;
    transform: translateY(-1px) !important;
}

/* Archivkarten */
html body .sbtp-archive-page .sbtp-grid,
html body .sbtp-archive-page .sbtp-archive-grid {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 24px !important;
    align-items: stretch !important;
    margin: 0 !important;
    padding: 0 !important;
}

html body .sbtp-archive-page .sbtp-card {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
    overflow: hidden !important;
    background: #ffffff !important;
    border: 1px solid rgba(0,0,0,0.075) !important;
    border-radius: 8px !important;
    box-shadow: 0 7px 24px rgba(0,0,0,0.075) !important;
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease !important;
}

html body .sbtp-archive-page .sbtp-card:hover {
    transform: translateY(-4px) !important;
    border-color: rgba(245,166,35,.55) !important;
    box-shadow: 0 14px 34px rgba(0,0,0,.11) !important;
}

html body .sbtp-archive-page .sbtp-card-image {
    display: block !important;
    width: 100% !important;
    height: 150px !important;
    flex: 0 0 150px !important;
    background-color: #eeeeee !important;
    background-size: cover !important;
    background-position: center center !important;
    text-decoration: none !important;
}

html body .sbtp-archive-page .sbtp-card-body {
    position: relative !important;
    flex: 1 1 auto !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 260px !important;
    padding: 22px 22px 22px 22px !important;
}

html body .sbtp-archive-page .sbtp-card-icon {
    display: none !important;
}

html body .sbtp-archive-page .sbtp-card h3 {
    margin: 0 0 12px 0 !important;
    padding: 0 !important;
    color: var(--sbtp-black) !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 22px !important;
    line-height: 1.12 !important;
    font-weight: 900 !important;
    letter-spacing: -0.01em !important;
    text-transform: uppercase !important;
    text-align: left !important;
}

html body .sbtp-archive-page .sbtp-card h3 a {
    color: inherit !important;
    text-decoration: none !important;
}

html body .sbtp-archive-page .sbtp-card h3 a:hover {
    color: var(--sbtp-orange) !important;
}

html body .sbtp-archive-page .sbtp-card .sbtp-badge {
    align-self: flex-start !important;
    margin: 0 0 14px 0 !important;
    padding: 7px 12px !important;
    border-radius: 6px !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 11px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
}

html body .sbtp-archive-page .sbtp-card p {
    margin: 0 0 16px 0 !important;
    color: #444444 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 15px !important;
    line-height: 1.52 !important;
    font-weight: 400 !important;
    text-align: left !important;
}

html body .sbtp-archive-page .sbtp-card-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 14px !important;
    margin: auto 0 16px 0 !important;
    color: #777777 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
}

html body .sbtp-archive-page .sbtp-card-meta span {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
}

html body .sbtp-archive-page .sbtp-card-meta i {
    color: #777777 !important;
    font-style: normal !important;
}

html body .sbtp-archive-page .sbtp-card .sbtp-button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-height: 40px !important;
    padding: 11px 16px !important;
    margin-top: 0 !important;
    background: var(--sbtp-orange) !important;
    border: 1px solid var(--sbtp-orange) !important;
    border-radius: 6px !important;
    color: #111111 !important;
    box-shadow: none !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .07em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    transition: background .2s ease, color .2s ease, transform .2s ease !important;
}

html body .sbtp-archive-page .sbtp-card .sbtp-button:hover {
    background: #111111 !important;
    border-color: #111111 !important;
    color: #ffffff !important;
    transform: translateY(-1px) !important;
}

html body .sbtp-archive-page .sbtp-more-wrap {
    text-align: center !important;
    margin-top: 30px !important;
}

html body .sbtp-archive-page .sbtp-more-button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 360px !important;
    padding: 15px 24px !important;
    background: #ffffff !important;
    border: 1px solid rgba(0,0,0,0.10) !important;
    border-radius: 6px !important;
    color: #222222 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .10em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    box-shadow: none !important;
}

html body .sbtp-archive-page .sbtp-more-button:hover {
    border-color: var(--sbtp-orange) !important;
    color: var(--sbtp-orange) !important;
}

/* Rundungen im Startseitenblock leicht reduzieren */
html body .sbtp-start-stats div,
html body .sbtp-focus-card,
html body .sbtp-focus-image,
html body .sbtp-button,
html body .sbtp-button-outline {
    border-radius: 8px !important;
}

/* Responsive Archiv */
@media (max-width: 1450px) {
    html body .sbtp-archive-page .sbtp-grid,
    html body .sbtp-archive-page .sbtp-archive-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 1180px) {
    html body .sbtp-archive-page .sbtp-container {
        width: min(100% - 56px, var(--sbtp-archive-max)) !important;
    }
    html body .sbtp-archive-page .sbtp-statsbar,
    html body .sbtp-archive-page .sbtp-statsbar-wide {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
    html body .sbtp-archive-page .sbtp-statbox:nth-child(2) {
        border-right: 0 !important;
    }
    html body .sbtp-archive-page .sbtp-filter-pills {
        grid-template-columns: 1fr !important;
        gap: 22px !important;
    }
    html body .sbtp-archive-page .sbtp-grid,
    html body .sbtp-archive-page .sbtp-archive-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 820px) {
    html body .sbtp-archive-hero,
    html body .sbtp-hero-rathaus {
        min-height: 0 !important;
        padding: 46px 0 110px 0 !important;
        background-position: center right !important;
    }
    html body .sbtp-archive-main {
        margin-top: -68px !important;
        padding-bottom: 56px !important;
    }
    html body .sbtp-archive-page .sbtp-container {
        width: min(100% - 28px, var(--sbtp-archive-max)) !important;
    }
    html body .sbtp-archive-hero h1 {
        font-size: 48px !important;
    }
    html body .sbtp-archive-hero p {
        font-size: 15px !important;
        line-height: 1.62 !important;
    }
    html body .sbtp-archive-page .sbtp-statsbar,
    html body .sbtp-archive-page .sbtp-statsbar-wide {
        grid-template-columns: 1fr !important;
    }
    html body .sbtp-archive-page .sbtp-statbox,
    html body .sbtp-archive-page .sbtp-statbox:nth-child(2) {
        border-right: 0 !important;
        border-bottom: 1px solid rgba(0,0,0,0.08) !important;
    }
    html body .sbtp-archive-page .sbtp-statbox:last-child {
        border-bottom: 0 !important;
    }
    html body .sbtp-archive-page .sbtp-grid,
    html body .sbtp-archive-page .sbtp-archive-grid {
        grid-template-columns: 1fr !important;
    }
    html body .sbtp-archive-page .sbtp-card-image {
        height: 205px !important;
        flex-basis: 205px !important;
    }
    html body .sbtp-archive-page .sbtp-more-button {
        min-width: 0 !important;
        width: 100% !important;
    }
}

/* =====================================================
   SB THEMEN & PROJEKTE – DETAILSEITE FINAL 1.1.1
   Version 1.1.1 – 05.06.2026
   Ziel:
   - Einzelne Themenseiten näher am freigegebenen Entwurf
   - The7-Titelleiste ausblenden
   - rechte Spalte sauber: Auf einen Blick einzeilig, Antrag/Updates/Verlauf
   - weniger Rundungen, ruhigere Typografie, bessere Spaltenaufteilung
   ===================================================== */

:root {
    --sbtp-orange: var(--fg-farbe-primary, #f5a623);
    --sbtp-black: var(--fg-farbe-secondary, #111111);
    --sbtp-text: #444444;
    --sbtp-muted: #777777;
    --sbtp-border: #e7e7e7;
    --sbtp-font-headline: var(--fg-font-headline, "Oswald", sans-serif);
    --sbtp-font-text: var(--fg-font-text, "Open Sans", sans-serif);
    --sbtp-shadow-detail: 0 8px 26px rgba(0,0,0,0.065);
    --sbtp-radius-detail: 8px;
}

/* The7/Theme-Titelleiste auf einzelnen Themen ausblenden */
body.single-sb_thema .page-title,
body.single-sb_thema .page-title.solid-bg,
body.single-sb_thema .fancy-header,
body.single-sb_thema .page-title-head,
body.single-sb_thema .page-title .wf-wrap,
body.single-sb_thema .title-left,
body.single-sb_thema .breadcrumbs.bg-dark,
body.single-sb_thema .breadcrumbs.bg-light {
    display: none !important;
}

body.single-sb_thema #main,
body.single-sb_thema #content,
body.single-sb_thema .content-area {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

html body .sbtp-single-page {
    background: #ffffff !important;
    color: var(--sbtp-text) !important;
    padding: 0 0 78px 0 !important;
    font-family: var(--sbtp-font-text) !important;
}

html body .sbtp-single-page .sbtp-container {
    width: min(100% - 64px, 1260px) !important;
    margin: 0 auto !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

html body .sbtp-single-page .sbtp-breadcrumb {
    padding: 30px 0 26px 0 !important;
    margin: 0 !important;
    color: #777777 !important;
    font-size: 13px !important;
    line-height: 1.3 !important;
    font-weight: 500 !important;
}

html body .sbtp-single-page .sbtp-breadcrumb a {
    color: #555555 !important;
    text-decoration: none !important;
}

html body .sbtp-single-page .sbtp-breadcrumb a:hover {
    color: var(--sbtp-orange) !important;
}

/* Obere Grundaufteilung */
html body .sbtp-single-page .sbtp-single-layout-top {
    display: grid !important;
    grid-template-columns: minmax(0, 810px) minmax(340px, 380px) !important;
    gap: 46px !important;
    align-items: start !important;
    justify-content: center !important;
    margin: 0 !important;
}

html body .sbtp-single-page .sbtp-single-main-head {
    min-width: 0 !important;
}

html body .sbtp-single-page .sbtp-single-main-head h1 {
    max-width: 810px !important;
    margin: 0 0 10px 0 !important;
    padding: 0 !important;
    color: var(--sbtp-black) !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: clamp(46px, 4.25vw, 66px) !important;
    line-height: .94 !important;
    font-weight: 900 !important;
    letter-spacing: -.025em !important;
    text-transform: uppercase !important;
    text-align: left !important;
}

html body .sbtp-single-page .sbtp-single-main-head > .sbtp-badge {
    display: inline-flex !important;
    margin: 0 0 14px 0 !important;
    padding: 8px 13px !important;
    border-radius: 7px !important;
    font-size: 11px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
}

html body .sbtp-single-page .sbtp-lead {
    max-width: 760px !important;
    margin: 0 0 22px 0 !important;
    color: #444444 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 16px !important;
    line-height: 1.62 !important;
    font-weight: 400 !important;
    text-align: left !important;
}

html body .sbtp-single-page .sbtp-single-image {
    width: 100% !important;
    height: 330px !important;
    margin: 0 !important;
    background-color: #eeeeee !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    border: 0 !important;
    border-radius: var(--sbtp-radius-detail) !important;
    box-shadow: none !important;
    overflow: hidden !important;
}

/* Rechte Spalte */
html body .sbtp-single-page .sbtp-side-stack {
    display: grid !important;
    gap: 18px !important;
    align-content: start !important;
    min-width: 0 !important;
}

html body .sbtp-single-page .sbtp-side-card,
html body .sbtp-single-page .sbtp-timeline-card,
html body .sbtp-single-page .sbtp-linked-card,
html body .sbtp-single-page .sbtp-related-topics {
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: var(--sbtp-radius-detail) !important;
    box-shadow: var(--sbtp-shadow-detail) !important;
    padding: 24px !important;
}

html body .sbtp-single-page .sbtp-side-card h2,
html body .sbtp-single-page .sbtp-timeline-card h2,
html body .sbtp-single-page .sbtp-linked-card h2,
html body .sbtp-single-page .sbtp-related-topics h2 {
    margin: 0 0 19px 0 !important;
    padding: 0 !important;
    color: var(--sbtp-black) !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 20px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .01em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
}

/* Auf einen Blick – erzwingt saubere Zeilen */
html body .sbtp-single-page .sbtp-glance-card {
    min-width: 0 !important;
}

html body .sbtp-single-page .sbtp-glance-card dl {
    display: grid !important;
    gap: 17px !important;
    margin: 0 !important;
    padding: 0 !important;
}

html body .sbtp-single-page .sbtp-glance-card dl div {
    display: grid !important;
    grid-template-columns: minmax(145px, 1fr) minmax(120px, auto) !important;
    gap: 18px !important;
    align-items: center !important;
    min-width: 0 !important;
}

html body .sbtp-single-page .sbtp-glance-card dt {
    display: flex !important;
    align-items: center !important;
    gap: 9px !important;
    min-width: 0 !important;
    margin: 0 !important;
    color: #555555 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 15px !important;
    line-height: 1.25 !important;
    font-weight: 800 !important;
    white-space: nowrap !important;
}

html body .sbtp-single-page .sbtp-glance-card dt span {
    flex: 0 0 18px !important;
    width: 18px !important;
    margin: 0 !important;
    color: var(--sbtp-orange) !important;
    font-size: 15px !important;
    line-height: 1 !important;
    text-align: center !important;
}

html body .sbtp-single-page .sbtp-glance-card dd {
    min-width: 0 !important;
    margin: 0 !important;
    color: var(--sbtp-black) !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 15px !important;
    line-height: 1.35 !important;
    font-weight: 900 !important;
    text-align: right !important;
}

html body .sbtp-single-page .sbtp-glance-card dd .sbtp-badge {
    display: inline-flex !important;
    justify-content: center !important;
    white-space: nowrap !important;
    padding: 7px 12px !important;
    border-radius: 7px !important;
    font-size: 10px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
}

html body .sbtp-single-page .sbtp-related-application-card {
    border-color: rgba(245,166,35,.52) !important;
    background: linear-gradient(180deg, #ffffff 0%, #fffaf0 100%) !important;
}

html body .sbtp-single-page .sbtp-related-application {
    display: grid !important;
    grid-template-columns: 48px 1fr !important;
    gap: 14px !important;
    align-items: center !important;
    margin: 0 0 18px 0 !important;
}

html body .sbtp-single-page .sbtp-doc-symbol,
html body .sbtp-single-page .sbtp-pdf-icon {
    display: grid !important;
    place-items: center !important;
    width: 46px !important;
    height: 46px !important;
    border: 2px solid var(--sbtp-orange) !important;
    border-radius: 7px !important;
    color: var(--sbtp-orange) !important;
    font-size: 18px !important;
    font-weight: 900 !important;
}

html body .sbtp-single-page .sbtp-related-application strong {
    display: block !important;
    color: #111111 !important;
    font-size: 15px !important;
    line-height: 1.3 !important;
    font-weight: 900 !important;
}

html body .sbtp-single-page .sbtp-related-application span {
    display: block !important;
    margin-top: 4px !important;
    color: #777777 !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
}

html body .sbtp-single-page .sbtp-button-full {
    width: 100% !important;
}

html body .sbtp-single-page .sbtp-text-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-top: 14px !important;
    color: #111111 !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
}

html body .sbtp-single-page .sbtp-text-link:hover {
    color: var(--sbtp-orange) !important;
}

html body .sbtp-single-page .sbtp-mini-update {
    display: grid !important;
    grid-template-columns: 72px 1fr !important;
    gap: 13px !important;
    align-items: center !important;
    padding: 0 0 14px 0 !important;
    margin: 0 0 14px 0 !important;
    border-bottom: 1px solid var(--sbtp-border) !important;
    text-decoration: none !important;
}

html body .sbtp-single-page .sbtp-mini-update img {
    width: 72px !important;
    height: 54px !important;
    object-fit: cover !important;
    border-radius: 6px !important;
}

/* Die Zwischen-Statistikchips stören den Entwurf – ausblenden */
html body .sbtp-single-page .sbtp-single-chips {
    display: none !important;
}

/* Unterer Bereich mit Timeline rechts */
html body .sbtp-single-page .sbtp-single-bottom-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 810px) minmax(340px, 380px) !important;
    gap: 46px !important;
    align-items: start !important;
    justify-content: center !important;
    margin: 34px 0 0 0 !important;
}

html body .sbtp-single-page .sbtp-single-main-content {
    display: block !important;
    min-width: 0 !important;
}

html body .sbtp-single-page .sbtp-section-row {
    display: grid !important;
    grid-template-columns: 42px 1fr !important;
    gap: 20px !important;
    padding: 26px 0 !important;
    border-bottom: 1px solid var(--sbtp-border) !important;
}

html body .sbtp-single-page .sbtp-section-row:first-child {
    padding-top: 0 !important;
}

html body .sbtp-single-page .sbtp-section-icon {
    display: grid !important;
    place-items: start center !important;
    width: 36px !important;
    height: auto !important;
    color: var(--sbtp-orange) !important;
    font-size: 26px !important;
    line-height: 1 !important;
    padding-top: 3px !important;
}

html body .sbtp-single-page .sbtp-section-row h2 {
    margin: 0 0 10px 0 !important;
    padding: 0 !important;
    color: #111111 !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 20px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
    letter-spacing: .01em !important;
    text-transform: uppercase !important;
}

html body .sbtp-single-page .sbtp-section-row p,
html body .sbtp-single-page .sbtp-the-content,
html body .sbtp-single-page .sbtp-the-content p {
    margin: 0 !important;
    color: #444444 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 16px !important;
    line-height: 1.72 !important;
    font-weight: 400 !important;
    text-align: left !important;
}

html body .sbtp-single-page .sbtp-quote {
    margin: 28px 0 26px 0 !important;
    padding: 18px 22px !important;
    background: #fff7eb !important;
    border-left: 5px solid var(--sbtp-orange) !important;
    border-radius: 7px !important;
    color: #222222 !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 17px !important;
    line-height: 1.5 !important;
    font-weight: 800 !important;
}

/* Verlauf rechts */
html body .sbtp-single-page .sbtp-timeline-card {
    position: sticky !important;
    top: 112px !important;
    align-self: start !important;
}

html body .sbtp-single-page .sbtp-timeline {
    position: relative !important;
    display: grid !important;
    gap: 22px !important;
    padding-left: 18px !important;
}

html body .sbtp-single-page .sbtp-timeline::before {
    content: "" !important;
    position: absolute !important;
    left: 6px !important;
    top: 6px !important;
    bottom: 8px !important;
    width: 2px !important;
    background: #dddddd !important;
}

html body .sbtp-single-page .sbtp-timeline-item {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 98px 1fr !important;
    gap: 14px !important;
    min-width: 0 !important;
}

html body .sbtp-single-page .sbtp-timeline-item::before {
    content: "" !important;
    position: absolute !important;
    left: -17px !important;
    top: 4px !important;
    width: 13px !important;
    height: 13px !important;
    border-radius: 50% !important;
    background: var(--sbtp-orange) !important;
    box-shadow: 0 0 0 4px #ffffff !important;
}

html body .sbtp-single-page .sbtp-timeline-item span {
    color: #777777 !important;
    font-size: 13px !important;
    line-height: 1.25 !important;
}

html body .sbtp-single-page .sbtp-timeline-item strong {
    color: #111111 !important;
    font-size: 15px !important;
    line-height: 1.25 !important;
    font-weight: 900 !important;
}

html body .sbtp-single-page .sbtp-timeline-item p {
    grid-column: 2 !important;
    margin: -8px 0 0 0 !important;
    color: #555555 !important;
    font-size: 15px !important;
    line-height: 1.45 !important;
}

/* Ähnliche Themen ruhiger */
html body .sbtp-single-page .sbtp-related-topics {
    margin-top: 26px !important;
}

html body .sbtp-single-page .sbtp-related-topic-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

html body .sbtp-single-page .sbtp-related-topic-grid a {
    display: block !important;
    min-height: 92px !important;
    padding: 15px !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 7px !important;
    background: #ffffff !important;
    color: #111111 !important;
    text-decoration: none !important;
}

html body .sbtp-single-page .sbtp-related-topic-grid a:hover {
    border-color: rgba(245,166,35,.55) !important;
    box-shadow: 0 8px 22px rgba(0,0,0,.065) !important;
}

html body .sbtp-single-page .sbtp-related-topic-grid strong {
    display: block !important;
    color: #111111 !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 16px !important;
    line-height: 1.08 !important;
    font-weight: 900 !important;
}

html body .sbtp-single-page .sbtp-related-topic-grid span {
    display: block !important;
    margin-top: 7px !important;
    color: #777777 !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
}

html body .sbtp-single-page .sbtp-related-all {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 16px !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
}

@media (max-width: 1100px) {
    html body .sbtp-single-page .sbtp-single-layout-top,
    html body .sbtp-single-page .sbtp-single-bottom-grid {
        grid-template-columns: 1fr !important;
        gap: 26px !important;
        justify-content: stretch !important;
    }

    html body .sbtp-single-page .sbtp-side-stack,
    html body .sbtp-single-page .sbtp-timeline-card {
        position: static !important;
    }
}

@media (max-width: 760px) {
    html body .sbtp-single-page .sbtp-container {
        width: min(100% - 28px, 1260px) !important;
    }

    html body .sbtp-single-page .sbtp-breadcrumb {
        padding: 22px 0 18px 0 !important;
    }

    html body .sbtp-single-page .sbtp-single-main-head h1 {
        font-size: 40px !important;
        line-height: .98 !important;
    }

    html body .sbtp-single-page .sbtp-single-image {
        height: 230px !important;
    }

    html body .sbtp-single-page .sbtp-glance-card dl div {
        grid-template-columns: 1fr !important;
        gap: 4px !important;
    }

    html body .sbtp-single-page .sbtp-glance-card dd {
        text-align: left !important;
    }

    html body .sbtp-single-page .sbtp-section-row {
        grid-template-columns: 34px 1fr !important;
        gap: 14px !important;
    }

    html body .sbtp-single-page .sbtp-timeline-item {
        grid-template-columns: 1fr !important;
        gap: 4px !important;
    }

    html body .sbtp-single-page .sbtp-timeline-item p {
        grid-column: 1 !important;
        margin: 0 !important;
    }

    html body .sbtp-single-page .sbtp-related-topic-grid {
        grid-template-columns: 1fr !important;
    }
}

/* =========================================================
   SB THEMEN & PROJEKTE – DETAILSEITE FINAL 1.1.2
   Ziel: sauberer Entwurf, kompaktere Typografie, rechte Spalte geordnet.
   Änderung: Verlauf bleibt rechts, Auf-einen-Blick bleibt einzeilig.
   ========================================================= */

body.single-sb_thema .page-title,
body.single-sb_thema .page-title.solid-bg,
body.single-sb_thema .fancy-header,
body.single-sb_thema .page-title-head,
body.single-sb_thema .page-title .wf-wrap,
body.single-sb_thema .title-left,
body.single-sb_thema .breadcrumbs.bg-dark,
body.single-sb_thema .breadcrumbs.bg-light,
body.single-sb_thema .dt-title,
body.single-sb_thema .wf-title,
body.single-sb_thema .page-title-breadcrumbs {
    display: none !important;
}

html body .sbtp-single-page {
    background: #ffffff !important;
    padding: 0 0 72px 0 !important;
}

html body .sbtp-single-page .sbtp-container {
    width: min(100% - 64px, 1260px) !important;
    margin: 0 auto !important;
}

html body .sbtp-single-page .sbtp-breadcrumb {
    padding: 24px 0 22px 0 !important;
    font-size: 13px !important;
    line-height: 1.3 !important;
    color: #777777 !important;
}

/* Obere Detailseite: links Inhalt, rechts feste Infospalte */
html body .sbtp-single-page .sbtp-single-layout-top {
    display: grid !important;
    grid-template-columns: minmax(0, 760px) 450px !important;
    gap: 44px !important;
    align-items: start !important;
    justify-content: center !important;
    margin: 0 !important;
}

html body .sbtp-single-page .sbtp-single-main-head h1 {
    max-width: 760px !important;
    margin: 0 0 12px 0 !important;
    padding: 0 !important;
    color: #111111 !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: clamp(42px, 3.35vw, 56px) !important;
    line-height: 1.02 !important;
    font-weight: 900 !important;
    letter-spacing: -0.018em !important;
    text-transform: uppercase !important;
    text-align: left !important;
}

html body .sbtp-single-page .sbtp-single-main-head > .sbtp-badge {
    margin: 0 0 15px 0 !important;
    padding: 7px 12px !important;
    border-radius: 6px !important;
    font-size: 10px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
}

html body .sbtp-single-page .sbtp-lead {
    max-width: 760px !important;
    margin: 0 0 21px 0 !important;
    color: #444444 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 15.5px !important;
    line-height: 1.62 !important;
    font-weight: 400 !important;
}

html body .sbtp-single-page .sbtp-single-image {
    width: 100% !important;
    height: 300px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    background-size: cover !important;
    background-position: center center !important;
    box-shadow: none !important;
}

/* Rechte Spalte */
html body .sbtp-single-page .sbtp-side-stack {
    display: grid !important;
    gap: 16px !important;
    align-content: start !important;
    width: 100% !important;
    min-width: 0 !important;
}

html body .sbtp-single-page .sbtp-side-card,
html body .sbtp-single-page .sbtp-timeline-card,
html body .sbtp-single-page .sbtp-linked-card,
html body .sbtp-single-page .sbtp-related-topics {
    border-radius: 8px !important;
    border: 1px solid #e7e7e7 !important;
    box-shadow: 0 10px 26px rgba(0,0,0,.055) !important;
    padding: 22px 24px !important;
}

html body .sbtp-single-page .sbtp-side-card h2,
html body .sbtp-single-page .sbtp-timeline-card h2,
html body .sbtp-single-page .sbtp-linked-card h2,
html body .sbtp-single-page .sbtp-related-topics h2 {
    margin: 0 0 18px 0 !important;
    color: #111111 !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 18px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: .015em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
}

/* Auf einen Blick: feste, einzeilige Zeilen */
html body .sbtp-single-page .sbtp-glance-card dl {
    display: grid !important;
    gap: 14px !important;
    margin: 0 !important;
    padding: 0 !important;
}

html body .sbtp-single-page .sbtp-glance-card dl div {
    display: grid !important;
    grid-template-columns: 136px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: center !important;
    min-width: 0 !important;
}

html body .sbtp-single-page .sbtp-glance-card dt {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-width: 0 !important;
    margin: 0 !important;
    color: #555555 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 13.5px !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
    white-space: nowrap !important;
}

html body .sbtp-single-page .sbtp-glance-card dt span {
    flex: 0 0 16px !important;
    width: 16px !important;
    margin: 0 !important;
    color: var(--sbtp-orange) !important;
    font-size: 13px !important;
    line-height: 1 !important;
    text-align: center !important;
}

html body .sbtp-single-page .sbtp-glance-card dd {
    min-width: 0 !important;
    margin: 0 !important;
    color: #111111 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 13.2px !important;
    line-height: 1.18 !important;
    font-weight: 900 !important;
    text-align: right !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

html body .sbtp-single-page .sbtp-glance-card dd .sbtp-badge {
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    white-space: nowrap !important;
    padding: 6px 10px !important;
    border-radius: 6px !important;
    font-size: 10px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
}

/* Content darunter bleibt links sauber ausgerichtet; rechts liegt der Verlauf */
html body .sbtp-single-page .sbtp-single-chips {
    display: none !important;
}

html body .sbtp-single-page .sbtp-single-bottom-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 760px) 450px !important;
    gap: 44px !important;
    justify-content: center !important;
    align-items: start !important;
    margin: 30px 0 0 0 !important;
}

html body .sbtp-single-page .sbtp-single-main-content {
    grid-column: 1 !important;
    max-width: 760px !important;
    min-width: 0 !important;
}

html body .sbtp-single-page .sbtp-section-row {
    display: grid !important;
    grid-template-columns: 36px 1fr !important;
    gap: 18px !important;
    padding: 22px 0 !important;
    border-bottom: 1px solid #e7e7e7 !important;
}

html body .sbtp-single-page .sbtp-section-row:first-child {
    padding-top: 0 !important;
}

html body .sbtp-single-page .sbtp-section-icon {
    width: 32px !important;
    color: var(--sbtp-orange) !important;
    font-size: 23px !important;
    line-height: 1 !important;
    padding-top: 2px !important;
}

html body .sbtp-single-page .sbtp-section-row h2 {
    margin: 0 0 9px 0 !important;
    color: #111111 !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 18px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
}

html body .sbtp-single-page .sbtp-section-row p,
html body .sbtp-single-page .sbtp-the-content,
html body .sbtp-single-page .sbtp-the-content p {
    margin: 0 !important;
    color: #444444 !important;
    font-family: var(--sbtp-font-text) !important;
    font-size: 15.3px !important;
    line-height: 1.68 !important;
    font-weight: 400 !important;
}

html body .sbtp-single-page .sbtp-quote {
    margin: 26px 0 24px 0 !important;
    padding: 17px 20px !important;
    background: #fff7eb !important;
    border-left: 5px solid var(--sbtp-orange) !important;
    border-radius: 6px !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 16px !important;
    line-height: 1.45 !important;
    font-weight: 800 !important;
}

/* Verlauf in der rechten Spalte */
html body .sbtp-single-page .sbtp-side-timeline-card,
html body .sbtp-single-page .sbtp-timeline-card {
    position: static !important;
    top: auto !important;
    align-self: start !important;
}

html body .sbtp-single-page .sbtp-timeline {
    display: grid !important;
    gap: 17px !important;
    padding-left: 18px !important;
}

html body .sbtp-single-page .sbtp-timeline-item {
    display: grid !important;
    grid-template-columns: 82px 1fr !important;
    gap: 12px !important;
}

html body .sbtp-single-page .sbtp-timeline-item span {
    font-size: 12.5px !important;
    color: #777777 !important;
}

html body .sbtp-single-page .sbtp-timeline-item strong {
    font-size: 14.5px !important;
    line-height: 1.25 !important;
    color: #111111 !important;
    font-weight: 900 !important;
}

html body .sbtp-single-page .sbtp-timeline-item p {
    grid-column: 2 !important;
    margin: -6px 0 0 0 !important;
    font-size: 14px !important;
    line-height: 1.45 !important;
    color: #555555 !important;
}

html body .sbtp-single-page .sbtp-related-topics {
    margin-top: 26px !important;
    padding: 22px 24px !important;
}

html body .sbtp-single-page .sbtp-related-topic-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

html body .sbtp-single-page .sbtp-related-topic-grid a {
    border-radius: 6px !important;
    min-height: 88px !important;
}

@media (max-width: 1160px) {
    html body .sbtp-single-page .sbtp-single-layout-top,
    html body .sbtp-single-page .sbtp-single-bottom-grid {
        grid-template-columns: 1fr !important;
        gap: 26px !important;
        justify-content: stretch !important;
    }

    html body .sbtp-single-page .sbtp-single-main-content,
    html body .sbtp-single-page .sbtp-single-main-head h1,
    html body .sbtp-single-page .sbtp-lead {
        max-width: none !important;
    }

    html body .sbtp-single-page .sbtp-glance-card dd {
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: clip !important;
    }
}

@media (max-width: 760px) {
    html body .sbtp-single-page .sbtp-container {
        width: min(100% - 28px, 1260px) !important;
    }

    html body .sbtp-single-page .sbtp-single-main-head h1 {
        font-size: 38px !important;
        line-height: 1.02 !important;
    }

    html body .sbtp-single-page .sbtp-single-image {
        height: 230px !important;
    }

    html body .sbtp-single-page .sbtp-glance-card dl div {
        grid-template-columns: 1fr !important;
        gap: 5px !important;
    }

    html body .sbtp-single-page .sbtp-glance-card dd {
        text-align: left !important;
    }

    html body .sbtp-single-page .sbtp-section-row {
        grid-template-columns: 32px 1fr !important;
        gap: 14px !important;
    }

    html body .sbtp-single-page .sbtp-timeline-item {
        grid-template-columns: 1fr !important;
        gap: 4px !important;
    }

    html body .sbtp-single-page .sbtp-timeline-item p {
        grid-column: 1 !important;
        margin: 0 !important;
    }

    html body .sbtp-single-page .sbtp-related-topic-grid {
        grid-template-columns: 1fr !important;
    }
}


/* =========================================================
   SB THEMEN & PROJEKTE – Detailseite v1.1.3
   Größere Icons, Bürger-Mitmachen-Box und Share-Buttons
   ========================================================= */

/* Grundlayout bleibt kompakt, aber Icons werden deutlich sichtbarer */
html body .sbtp-single-page .sbtp-glance-card dt span {
    flex: 0 0 28px !important;
    width: 28px !important;
    height: 28px !important;
    display: inline-grid !important;
    place-items: center !important;
    color: var(--sbtp-orange) !important;
    background: #fff8ea !important;
    border-radius: 999px !important;
    font-size: 18px !important;
    line-height: 1 !important;
    text-align: center !important;
}

html body .sbtp-single-page .sbtp-glance-card dt {
    gap: 12px !important;
}

/* Haupt-Icons links bei Worum/Ziel/Aktueller Stand wie im Entwurf größer und präsenter */
html body .sbtp-single-page .sbtp-section-row {
    grid-template-columns: 66px 1fr !important;
    gap: 22px !important;
}

html body .sbtp-single-page .sbtp-section-icon {
    width: 48px !important;
    height: 48px !important;
    display: inline-grid !important;
    place-items: center !important;
    color: var(--sbtp-orange) !important;
    background: #fff8ea !important;
    border: 1px solid rgba(245,166,35,.28) !important;
    border-radius: 999px !important;
    font-size: 31px !important;
    line-height: 1 !important;
    padding-top: 0 !important;
    box-shadow: 0 5px 14px rgba(0,0,0,.045) !important;
}

/* Dokument-/PDF-Symbole in Seitenboxen größer */
html body .sbtp-single-page .sbtp-doc-symbol,
html body .sbtp-single-page .sbtp-pdf-icon {
    width: 58px !important;
    height: 58px !important;
    font-size: 23px !important;
    border-radius: 9px !important;
}

html body .sbtp-single-page .sbtp-related-application {
    grid-template-columns: 60px 1fr !important;
    gap: 16px !important;
}

/* Timeline rechts: Punkte etwas größer und hochwertiger */
html body .sbtp-single-page .sbtp-timeline::before {
    left: 8px !important;
    width: 2px !important;
}

html body .sbtp-single-page .sbtp-timeline-item::before {
    left: -18px !important;
    top: 2px !important;
    width: 17px !important;
    height: 17px !important;
    box-shadow: 0 0 0 5px #ffffff, 0 2px 8px rgba(245,166,35,.28) !important;
}

/* Bürger-Mitmach-Box */
html body .sbtp-single-page .sbtp-citizen-card {
    border-color: rgba(245,166,35,.42) !important;
    background: linear-gradient(180deg, #ffffff 0%, #fff8ea 100%) !important;
}

html body .sbtp-single-page .sbtp-citizen-card p {
    margin: 0 0 18px 0 !important;
    color: #444444 !important;
    font-size: 15px !important;
    line-height: 1.58 !important;
}

html body .sbtp-single-page .sbtp-citizen-card .sbtp-button-full {
    background: var(--sbtp-orange) !important;
    border-color: var(--sbtp-orange) !important;
    color: #111111 !important;
}

html body .sbtp-single-page .sbtp-citizen-card .sbtp-button-full:hover {
    background: #111111 !important;
    border-color: #111111 !important;
    color: #ffffff !important;
}

/* Share-Buttons im Stil der vorhandenen Website-Buttons, aber ohne externe Scripts */
html body .sbtp-single-page .sbtp-share-card {
    padding-bottom: 22px !important;
}

html body .sbtp-single-page .sbtp-share-buttons {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}

html body .sbtp-single-page .sbtp-share-buttons a {
    width: 42px !important;
    height: 42px !important;
    display: inline-grid !important;
    place-items: center !important;
    background: #ffffff !important;
    border: 1px solid var(--sbtp-border) !important;
    border-radius: 8px !important;
    color: var(--sbtp-orange) !important;
    font-family: var(--sbtp-font-headline) !important;
    font-size: 18px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    text-decoration: none !important;
    box-shadow: 0 4px 12px rgba(0,0,0,.045) !important;
    transition: transform .22s ease, background .22s ease, color .22s ease, border-color .22s ease !important;
}

html body .sbtp-single-page .sbtp-share-buttons a:hover {
    transform: translateY(-2px) !important;
    background: var(--sbtp-orange) !important;
    border-color: var(--sbtp-orange) !important;
    color: #ffffff !important;
}

/* Ecken noch einen Tick ruhiger, weil die starken Rundungen etwas verspielt wirken */
html body .sbtp-single-page .sbtp-side-card,
html body .sbtp-single-page .sbtp-timeline-card,
html body .sbtp-single-page .sbtp-linked-card,
html body .sbtp-single-page .sbtp-related-topics,
html body .sbtp-single-page .sbtp-single-image {
    border-radius: 8px !important;
}

@media (max-width: 760px) {
    html body .sbtp-single-page .sbtp-section-row {
        grid-template-columns: 52px 1fr !important;
        gap: 16px !important;
    }

    html body .sbtp-single-page .sbtp-section-icon {
        width: 42px !important;
        height: 42px !important;
        font-size: 27px !important;
    }
}


/* =========================================================
   SB THEMEN & PROJEKTE – Detailseite v1.1.4
   Korrektur: keine große Lücke unter dem Bild, Timeline-Datum sichtbar,
   ruhigere Rundungen und größere Symbolwirkung.
   ========================================================= */
html body .sbtp-single-page .sbtp-single-layout-top {
    display: grid !important;
    grid-template-columns: minmax(0, 760px) 450px !important;
    gap: 44px !important;
    align-items: start !important;
    justify-content: center !important;
}

html body .sbtp-single-page .sbtp-single-main-head {
    min-width: 0 !important;
}

html body .sbtp-single-page .sbtp-single-main-head .sbtp-single-main-content {
    margin-top: 28px !important;
    max-width: 760px !important;
}

html body .sbtp-single-page .sbtp-single-bottom-grid {
    display: none !important;
}

html body .sbtp-single-page .sbtp-single-image,
html body .sbtp-single-page .sbtp-side-card,
html body .sbtp-single-page .sbtp-timeline-card,
html body .sbtp-single-page .sbtp-linked-card,
html body .sbtp-single-page .sbtp-related-topics,
html body .sbtp-single-page .sbtp-related-topic-grid a,
html body .sbtp-single-page .sbtp-share-buttons a,
html body .sbtp-single-page .sbtp-quote {
    border-radius: 6px !important;
}

html body .sbtp-single-page .sbtp-glance-card dt span {
    flex: 0 0 30px !important;
    width: 30px !important;
    height: 30px !important;
    display: inline-grid !important;
    place-items: center !important;
    margin: 0 !important;
    color: var(--sbtp-orange) !important;
    background: #fff8ea !important;
    border: 1px solid rgba(245,166,35,.24) !important;
    border-radius: 999px !important;
    font-size: 18px !important;
    line-height: 1 !important;
}

html body .sbtp-single-page .sbtp-glance-card dt {
    gap: 12px !important;
}

html body .sbtp-single-page .sbtp-section-row {
    grid-template-columns: 64px 1fr !important;
    gap: 20px !important;
    padding: 24px 0 !important;
}

html body .sbtp-single-page .sbtp-section-row:first-child {
    padding-top: 0 !important;
}

html body .sbtp-single-page .sbtp-section-icon {
    width: 48px !important;
    height: 48px !important;
    display: inline-grid !important;
    place-items: center !important;
    color: var(--sbtp-orange) !important;
    background: #fff8ea !important;
    border: 1px solid rgba(245,166,35,.26) !important;
    border-radius: 999px !important;
    font-size: 30px !important;
    line-height: 1 !important;
    box-shadow: 0 4px 12px rgba(0,0,0,.045) !important;
}

html body .sbtp-single-page .sbtp-side-timeline-card,
html body .sbtp-single-page .sbtp-timeline-card,
html body .sbtp-single-page .sbtp-timeline {
    overflow: visible !important;
}

html body .sbtp-single-page .sbtp-timeline {
    position: relative !important;
    display: grid !important;
    gap: 18px !important;
    padding-left: 30px !important;
}

html body .sbtp-single-page .sbtp-timeline::before {
    left: 8px !important;
    width: 2px !important;
}

html body .sbtp-single-page .sbtp-timeline-item {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 98px minmax(0, 1fr) !important;
    column-gap: 14px !important;
    row-gap: 3px !important;
    overflow: visible !important;
}

html body .sbtp-single-page .sbtp-timeline-item::before {
    left: -30px !important;
    top: 1px !important;
    width: 17px !important;
    height: 17px !important;
    box-shadow: 0 0 0 5px #ffffff, 0 2px 8px rgba(245,166,35,.28) !important;
}

html body .sbtp-single-page .sbtp-timeline-item span {
    display: block !important;
    min-width: 88px !important;
    white-space: nowrap !important;
    overflow: visible !important;
    color: #777777 !important;
    font-size: 12.5px !important;
    line-height: 1.35 !important;
}

html body .sbtp-single-page .sbtp-timeline-item strong {
    display: block !important;
    min-width: 0 !important;
    font-size: 14.5px !important;
    line-height: 1.25 !important;
}

html body .sbtp-single-page .sbtp-timeline-item p {
    grid-column: 2 !important;
    margin: -4px 0 0 0 !important;
}

html body .sbtp-single-page .sbtp-side-stack {
    align-self: start !important;
}

@media (max-width: 1160px) {
    html body .sbtp-single-page .sbtp-single-layout-top {
        grid-template-columns: 1fr !important;
        gap: 28px !important;
    }
    html body .sbtp-single-page .sbtp-single-main-head .sbtp-single-main-content {
        max-width: none !important;
    }
}

@media (max-width: 760px) {
    html body .sbtp-single-page .sbtp-section-row {
        grid-template-columns: 52px 1fr !important;
        gap: 15px !important;
    }
    html body .sbtp-single-page .sbtp-section-icon {
        width: 42px !important;
        height: 42px !important;
        font-size: 26px !important;
    }
    html body .sbtp-single-page .sbtp-timeline {
        padding-left: 24px !important;
    }
    html body .sbtp-single-page .sbtp-timeline-item {
        grid-template-columns: 1fr !important;
        gap: 4px !important;
    }
    html body .sbtp-single-page .sbtp-timeline-item::before {
        left: -24px !important;
    }
    html body .sbtp-single-page .sbtp-timeline-item p {
        grid-column: 1 !important;
        margin: 0 !important;
    }
}
