.elementor-37339 .elementor-element.elementor-element-2e519c9{--display:flex;}/* Start custom CSS *//* General Styles & Variables */
:root {
    --primary-color: #003C71;
    --primary-light: rgba(0, 60, 113, 0.08);
    --secondary-color: #f8f9fa;
    --text-color: #212529;
    --light-gray: #f5f7f9;
    --medium-gray: #e5e9ed;
    --dark-gray: #6c757d;
    --white: #fff;
    --info-bg: #e9f5ff;
    --info-border: #c0e0ff;
    --info-text: #0c5460;
    --warning-bg: #fff9e6;
    --warning-border: #ffe7a0;
    --warning-text: #856404;
    --alert-bg: #feebee;
    --alert-border: #f5c6cb;
    --alert-text: #721c24;
    --success-bg: #e5f9ee;
    --success-border: #c3e6cb;
    --success-text: #155724;
    --quote-bg: #f9f9fb;
    --quote-border: #e9ecef;
    --box-shadow-sm: 0 2px 12px rgba(0, 0, 0, 0.04);
    --box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);
    --box-shadow-lg: 0 15px 30px rgba(0, 0, 0, 0.08);
    --border-radius: 10px !important;
    --border-radius-sm: 6px !important;
    --border-radius-lg: 16px !important;
    --font-family-primary: 'Fira Sans Condensed', system-ui, -apple-system, sans-serif;
    --font-family-secondary: 'Georgia', serif;
    --font-family-monospace: 'Consolas', monospace;
    --max-width: 880px;
    --transition-fast: 200ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-normal: 300ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 500ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* Hauptstile, die nur im .post-content Bereich gelten */
.post-content {
    max-width: var(--max-width) !important;
    margin: 0 auto !important;
    padding: 30px 25px !important;
    font-family: var(--font-family-primary) !important;
    line-height: 1.75 !important;
    color: var(--text-color) !important;
    font-size: 17px !important;
    letter-spacing: -0.01em !important;
}

/* Grundlegende Typografie */
.post-content h1, 
.post-content h2, 
.post-content h3, 
.post-content h4, 
.post-content h5, 
.post-content h6 {
    font-family: var(--font-family-primary) !important;
    color: var(--primary-color) !important;
    margin-top: 2.5em !important;
    margin-bottom: 1em !important;
    line-height: 1.25 !important;
    font-weight: 600 !important;
    letter-spacing: -0.02em !important;
}

.post-content h1 { 
    font-size: 2.8em !important; 
    letter-spacing: -0.03em !important;
}
.post-content h2 { 
    font-size: 2em !important; 
    letter-spacing: -0.02em !important;
    font-family: var(--font-family-secondary) !important;
}
.post-content h3 { 
    font-size: 1.6em !important; 
    font-family: var(--font-family-primary) !important;
}
.post-content h4 { 
    font-size: 1.3em !important; 
    font-family: var(--font-family-primary) !important;
}
.post-content h5 { 
    font-size: 1.1em !important; 
    font-family: var(--font-family-primary) !important;
}
.post-content h6 { 
    font-size: 0.9em !important; 
    font-family: var(--font-family-primary) !important;
}

.post-content p {
    margin-bottom: 1.5em !important;
    line-height: 1.75 !important;
}

.post-content a {
    color: var(--primary-color) !important;
    text-decoration: none !important;
    transition: color var(--transition-fast), border-bottom var(--transition-fast) !important;
    border-bottom: 1px solid transparent !important;
}

.post-content a:hover {
    color: #0056b3 !important;
    border-bottom: 1px solid currentColor !important;
}

.post-content img {
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
    border-radius: var(--border-radius) !important;
    transition: transform var(--transition-normal), box-shadow var(--transition-normal) !important;
    box-shadow: var(--box-shadow-sm) !important;
}

.post-content img:hover {
    transform: scale(1.01) !important;
    box-shadow: var(--box-shadow) !important;
}

.post-content figure {
    margin: 0 0 2em 0 !important;
    position: relative !important;
}

.post-content figcaption {
    font-family: var(--font-family-primary) !important;
    font-size: 0.9em !important;
    color: var(--dark-gray) !important;
    text-align: center !important;
    margin-top: 1em !important;
    font-style: italic !important;
}

.post-content section {
    margin-bottom: 4em !important;
}

/* Breadcrumb */
.post-content .breadcrumb {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 1.5em 0 !important;
    font-size: 0.9em !important;
    display: flex !important;
    flex-wrap: wrap !important;
}

.post-content .breadcrumb-item {
    display: inline !important;
}

.post-content .breadcrumb-item + .breadcrumb-item::before {
    content: "/" !important;
    padding: 0 0.8em !important;
    color: var(--medium-gray) !important;
}

.post-content .breadcrumb-item a {
    color: var(--dark-gray) !important;
    transition: color var(--transition-fast) !important;
    border-bottom: none !important;
}

.post-content .breadcrumb-item a:hover {
    color: var(--primary-color) !important;
}

.post-content .breadcrumb-item.active {
    color: var(--text-color) !important;
    font-weight: 600 !important;
}

/* Post Meta */
.post-content .post-meta {
    font-size: 0.9em !important;
    color: var(--dark-gray) !important;
    margin-top: 1em !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.5em !important;
}

.post-content .post-meta span {
    margin-right: 0.5em !important;
}

.post-content .post-meta span:not(:last-child)::after {
    content: "|" !important;
    margin-left: 0.5em !important;
    color: var(--medium-gray) !important;
}

/* Summary Box */
.post-content .summary-box {
    background-color: var(--primary-light) !important;
    border: none !important;
    border-left: 5px solid var(--primary-color) !important;
    padding: 32px 35px !important;
    margin-bottom: 3.5em !important;
    border-radius: var(--border-radius) !important;
    box-shadow: var(--box-shadow-sm) !important;
    transition: box-shadow var(--transition-normal), transform var(--transition-normal) !important;
}

.post-content .summary-box:hover {
    box-shadow: var(--box-shadow) !important;
    transform: translateY(-3px) !important;
}

.post-content .summary-box h2 {
    margin-top: 0 !important;
    font-size: 1.7em !important;
    color: var(--primary-color) !important;
    font-family: var(--font-family-secondary) !important;
    margin-bottom: 1.2em !important;
    position: relative !important;
}

.post-content .summary-box h2::after {
    content: "" !important;
    position: absolute !important;
    bottom: -0.5em !important;
    left: 0 !important;
    width: 50px !important;
    height: 3px !important;
    background-color: var(--primary-color) !important;
    opacity: 0.3 !important;
}

/* Style list items in summary box */
.post-content .summary-box ul {
    list-style: none !important;
    padding-left: 5px !important;
    margin-bottom: 0 !important;
}

.post-content .summary-box li {
    position: relative !important;
    padding-left: 30px !important;
    margin-bottom: 1em !important;
    font-size: 1.05em !important;
}

.post-content .summary-box li::before {
    content: '✓' !important;
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    color: var(--primary-color) !important;
    font-weight: bold !important;
    font-size: 1.2em !important;
}

/* Table of Contents */
.post-content .table-of-contents {
    background-color: var(--white) !important;
    border: 1px solid var(--medium-gray) !important;
    padding: 32px 35px !important;
    margin-bottom: 3.5em !important;
    border-radius: var(--border-radius) !important;
    box-shadow: var(--box-shadow-sm) !important;
    transition: box-shadow var(--transition-normal), transform var(--transition-normal) !important;
}

.post-content .table-of-contents:hover {
    box-shadow: var(--box-shadow) !important;
    transform: translateY(-2px) !important;
}

.post-content .table-of-contents h2 {
    margin-top: 0 !important;
    font-size: 1.6em !important;
    margin-bottom: 1.2em !important;
    position: relative !important;
    font-family: var(--font-family-primary) !important;
    color: var(--primary-color) !important;
}

.post-content .table-of-contents h2::after {
    content: "" !important;
    position: absolute !important;
    bottom: -0.5em !important;
    left: 0 !important;
    width: 40px !important;
    height: 2px !important;
    background-color: var(--primary-color) !important;
    opacity: 0.3 !important;
}

.post-content .table-of-contents ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.post-content .table-of-contents li {
    margin-bottom: 0.5em !important;
    padding-left: 0 !important;
    transition: transform var(--transition-fast), padding-left var(--transition-fast) !important;
    border-left: 0px solid transparent !important;
}

.post-content .table-of-contents li:hover {
    transform: translateX(5px) !important;
    border-left-color: var(--primary-color) !important;
}

.post-content .table-of-contents a {
    text-decoration: none !important;
    color: var(--text-color) !important;
    transition: color var(--transition-fast) !important;
    display: inline-block !important;
    width: 100% !important;
    padding: 3px 0 !important;
    border-bottom: none !important;
    font-size: 0.95em !important;
}

.post-content .table-of-contents a:hover {
    color: var(--primary-color) !important;
    border-bottom: none !important;
}

/* Tables */
.post-content .table-responsive {
    width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    margin-bottom: 2em !important;
    border-radius: var(--border-radius) !important;
    box-shadow: var(--box-shadow-sm) !important;
}

.post-content table {
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    min-width: 600px !important;
    border: 1px solid var(--medium-gray) !important;
    border-radius: var(--border-radius) !important;
    overflow: hidden !important;
    margin-bottom: 0 !important;
}

.post-content th, 
.post-content td {
    padding: 15px 18px !important;
    text-align: left !important;
    border-bottom: 1px solid var(--medium-gray) !important;
    border-right: 1px solid var(--medium-gray) !important;
    transition: background-color var(--transition-fast) !important;
    vertical-align: middle !important;
}

.post-content th {
    background-color: var(--primary-light) !important;
    font-weight: 600 !important;
    color: var(--primary-color) !important;
    white-space: nowrap !important;
    text-transform: uppercase !important;
    font-size: 0.9em !important;
    letter-spacing: 0.06em !important;
    position: relative !important;
}

.post-content th::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 2px !important;
    background-color: rgba(0, 60, 113, 0.2) !important;
}

.post-content tbody tr:last-child td {
    border-bottom: none !important;
}

.post-content tbody tr {
    transition: all var(--transition-fast) !important;
}

.post-content tbody tr:nth-child(odd) {
    background-color: var(--white) !important;
}

.post-content tbody tr:nth-child(even) {
    background-color: var(--light-gray) !important;
}

.post-content tbody tr:hover {
    background-color: var(--primary-light) !important;
    box-shadow: 0 0 10px rgba(0, 60, 113, 0.1) inset !important;
}

.post-content td:last-child, 
.post-content th:last-child {
    border-right: none !important;
}

/* Tabs */
.post-content .tabs {
    margin-bottom: 2em !important;
    border-radius: var(--border-radius) !important;
    overflow: hidden !important;
}

.post-content .tab-list {
    display: flex !important;
    border-bottom: 1px solid var(--medium-gray) !important;
    background-color: var(--light-gray) !important;
    border-radius: var(--border-radius) var(--border-radius) 0 0 !important;
    position: relative !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
}

.post-content .tab-button {
    border: none !important;
    background: none !important;
    padding: 12px 20px !important;
    cursor: pointer !important;
    color: var(--dark-gray) !important;
    font-weight: 600 !important;
    font-size: 1em !important;
    transition: all var(--transition-normal) !important;
    border-bottom: 3px solid transparent !important;
    white-space: nowrap !important;
    outline: none !important;
    flex: 1 !important;
    text-align: center !important;
    position: relative !important;
    z-index: 1 !important;
}

.post-content .tab-button:hover,
.post-content .tab-button:focus {
    color: var(--primary-color) !important;
    background-color: rgba(0, 60, 113, 0.05) !important;
    border-bottom-color: rgba(0, 60, 113, 0.3) !important;
}

.post-content .tab-button.active {
    color: var(--primary-color) !important;
    border-bottom-color: var(--primary-color) !important;
    background-color: var(--white) !important;
    box-shadow: 0 -3px 10px rgba(0, 0, 0, 0.05) !important;
}

.post-content .tab-panel {
    padding: 20px !important;
    background-color: var(--white) !important;
    border: 1px solid var(--medium-gray) !important;
    border-top: none !important;
    border-radius: 0 0 var(--border-radius) var(--border-radius) !important;
}

.post-content .tab-panel[hidden] {
    display: none !important;
}

/* Vertical Tabs */
.post-content .vertical-tabs {
    display: flex !important;
    flex-direction: row !important;
    border: 1px solid var(--medium-gray) !important;
}

.post-content .vertical-tabs .tab-list {
    display: flex !important;
    flex-direction: column !important;
    border-bottom: none !important;
    border-right: 1px solid var(--medium-gray) !important;
    width: 200px !important;
    min-width: 200px !important;
    background-color: var(--light-gray) !important;
    border-radius: var(--border-radius) 0 0 var(--border-radius) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

.post-content .vertical-tabs .tab-button {
    text-align: left !important;
    border-bottom: none !important;
    border-left: 3px solid transparent !important;
    border-radius: 0 !important;
    margin-bottom: 1px !important;
    transition: all var(--transition-normal) !important;
    justify-content: flex-start !important;
    flex: none !important;
}

.post-content .vertical-tabs .tab-button.active {
    color: var(--primary-color) !important;
    border-left-color: var(--primary-color) !important;
    background-color: var(--white) !important;
    box-shadow: -3px 0 10px rgba(0, 0, 0, 0.05) !important;
}

.post-content .vertical-tabs .tab-panels {
    flex: 1 !important;
    min-width: 0 !important;
}

.post-content .vertical-tabs .tab-panel {
    height: 100% !important;
    border: none !important;
    border-radius: 0 var(--border-radius) var(--border-radius) 0 !important;
}

/* FAQ Section & Accordion */
.post-content .faq-section {
    margin-bottom: 4em !important;
}

.post-content .faq-section h3 {
    margin-bottom: 1.2em !important;
}

.post-content .accordion {
    border: 1px solid var(--medium-gray) !important;
    border-radius: var(--border-radius) !important;
    overflow: hidden !important;
    box-shadow: var(--box-shadow-sm) !important;
    background-color: var(--white) !important;
}

.post-content .accordion-item {
    border-bottom: 1px solid var(--medium-gray) !important;
    transition: background-color var(--transition-fast) !important;
    margin: 0 0 10px 0 !important;
    padding: 0 !important;
    border-radius: var(--border-radius) !important;
    overflow: hidden !important;
    box-shadow: var(--box-shadow-sm) !important;
}

.post-content .accordion-item:last-child {
    margin-bottom: 0 !important;
    border-bottom: none !important;
}

.post-content .accordion-title {
    width: 100% !important;
    background: var(--light-gray) !important;
    border: none !important;
    text-align: left !important;
    padding: 18px 25px !important;
    color: var(--text-color) !important;
    font-weight: 600 !important;
    font-size: 1.05em !important;
    cursor: pointer !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    transition: all var(--transition-normal) !important;
    letter-spacing: -0.01em !important;
    font-family: var(--font-family-primary) !important;
    border-radius: var(--border-radius) !important;
}

.post-content .accordion-title:hover,
.post-content .accordion-title:focus {
    background-color: var(--primary-light) !important;
    outline: none !important;
    color: var(--primary-color) !important;
}

.post-content .accordion-title[aria-expanded="true"] {
    background-color: var(--primary-light) !important;
    color: var(--primary-color) !important;
    border-bottom: none !important;
    border-radius: var(--border-radius) var(--border-radius) 0 0 !important;
}

.post-content .accordion-title-text {
    margin-right: 20px !important;
    flex: 1 !important;
    position: relative !important;
}

.post-content .accordion-icon {
    position: relative !important;
    width: 20px !important;
    height: 20px !important;
    flex-shrink: 0 !important;
    transition: transform var(--transition-normal) !important;
}

.post-content .accordion-icon::before,
.post-content .accordion-icon::after {
    content: '' !important;
    position: absolute !important;
    background-color: currentColor !important;
    transition: transform var(--transition-normal), opacity var(--transition-normal) !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
}

.post-content .accordion-icon::before { /* Horizontal line */
    width: 20px !important;
    height: 2px !important;
}

.post-content .accordion-icon::after { /* Vertical line */
    width: 2px !important;
    height: 20px !important;
}

.post-content .accordion-title[aria-expanded="true"] .accordion-icon::after {
    transform: translate(-50%, -50%) rotate(90deg) !important;
    opacity: 0 !important;
}

.post-content .accordion-content {
    padding: 0 25px 25px !important;
    transition: max-height var(--transition-normal), padding var(--transition-normal) !important;
    background-color: var(--primary-light) !important;
    border-top: 1px solid rgba(0, 60, 113, 0.1) !important;
}

.post-content .accordion-content[hidden] {
    display: none !important;
    padding: 0 25px !important;
}

.post-content .accordion-content p:last-child {
    margin-bottom: 0 !important;
}

/* Chart Container */
.post-content .chart-container {
    margin-bottom: 3.5em !important;
    padding: 25px !important;
    background-color: var(--white) !important;
    border-radius: var(--border-radius) !important;
    box-shadow: var(--box-shadow-sm) !important;
    transition: transform var(--transition-normal), box-shadow var(--transition-normal) !important;
    overflow: hidden !important;
    border: 1px solid var(--medium-gray) !important;
}

.post-content .chart-container:hover {
    transform: translateY(-4px) !important;
    box-shadow: var(--box-shadow) !important;
}

.post-content .chart-container h3 {
    margin-top: 0 !important;
    margin-bottom: 1.5em !important;
    text-align: center !important;
    font-size: 1.4em !important;
    color: var(--primary-color) !important;
}

/* Stat Cards */
.post-content .stats-cards {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 25px !important;
    margin-bottom: 3.5em !important;
}

.post-content .stat-card {
    flex: 1 !important;
    min-width: 220px !important;
    background-color: var(--white) !important;
    border-radius: var(--border-radius) !important;
    padding: 28px 25px !important;
    text-align: center !important;
    box-shadow: var(--box-shadow-sm) !important;
    transition: transform var(--transition-normal), box-shadow var(--transition-normal) !important;
    border: 1px solid var(--medium-gray) !important;
    position: relative !important;
    overflow: hidden !important;
}

.post-content .stat-card::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 4px !important;
    background-color: var(--primary-color) !important;
    opacity: 0.7 !important;
    transform: translateY(-100%) !important;
    transition: transform var(--transition-normal) !important;
}

.post-content .stat-card:hover {
    transform: translateY(-6px) !important;
    box-shadow: var(--box-shadow) !important;
}

.post-content .stat-card:hover::before {
    transform: translateY(0) !important;
}

.post-content .stat-card h4 {
    margin-top: 0 !important;
    margin-bottom: 0.3em !important;
    font-size: 2.8em !important;
    color: var(--primary-color) !important;
    font-weight: 700 !important;
    line-height: 1.1 !important;
}

.post-content .stat-card p {
    margin: 0 !important;
    color: var(--dark-gray) !important;
    font-size: 0.95em !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    font-weight: 500 !important;
}

/* Info Boxes */
.post-content .info-box {
    margin-bottom: 2.5em !important;
    padding: 25px 30px !important;
    border-radius: var(--border-radius) !important;
    position: relative !important;
    padding-left: 70px !important;
    box-shadow: var(--box-shadow-sm) !important;
    transition: transform var(--transition-normal), box-shadow var(--transition-normal) !important;
    border-left: 5px solid transparent !important;
}

.post-content .info-box:hover {
    transform: translateY(-3px) !important;
    box-shadow: var(--box-shadow) !important;
}

.post-content .info-box::before {
    font-family: var(--font-family-monospace) !important;
    position: absolute !important;
    left: 20px !important;
    top: 20px !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: bold !important;
    font-size: 16px !important;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15) !important;
}

.post-content .info-box p:last-child,
.post-content .info-box ul:last-child {
    margin-bottom: 0 !important;
}

.post-content .info-box strong {
    color: inherit !important;
    font-weight: 600 !important;
    font-size: 1.15em !important;
    display: block !important;
    margin-bottom: 0.6em !important;
    font-family: var(--font-family-primary) !important;
    letter-spacing: -0.01em !important;
}

/* Info box types */
.post-content .info-box.info {
    background-color: var(--info-bg) !important;
    border-left-color: var(--info-border) !important;
}

.post-content .info-box.info::before {
    content: "i" !important;
    background-color: var(--info-text) !important;
    color: var(--white) !important;
}

.post-content .info-box.warning {
    background-color: var(--warning-bg) !important;
    border-left-color: var(--warning-border) !important;
}

.post-content .info-box.warning::before {
    content: "!" !important;
    background-color: var(--warning-text) !important;
    color: var(--white) !important;
}

.post-content .info-box.alert {
    background-color: var(--alert-bg) !important;
    border-left-color: var(--alert-border) !important;
}

.post-content .info-box.alert::before {
    content: "×" !important;
    background-color: var(--alert-text) !important;
    color: var(--white) !important;
}

.post-content .info-box.success {
    background-color: var(--success-bg) !important;
    border-left-color: var(--success-border) !important;
}

.post-content .info-box.success::before {
    content: "✓" !important;
    background-color: var(--success-text) !important;
    color: var(--white) !important;
}

.post-content .info-box.quote {
    background-color: var(--quote-bg) !important;
    border-left-color: var(--quote-border) !important;
    font-style: italic !important;
    padding-left: 25px !important;
    font-family: var(--font-family-secondary) !important;
}

.post-content .info-box.quote::before {
    display: none !important;
}

.post-content .info-box.quote blockquote {
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    font-size: 1.1em !important;
    line-height: 1.6 !important;
}

.post-content .info-box.quote footer {
    text-align: right !important;
    margin-top: 0.8em !important;
    color: var(--dark-gray) !important;
    font-size: 0.9em !important;
    font-style: normal !important;
    font-family: var(--font-family-primary) !important;
}

/* Tooltips */
.post-content .tooltip {
    position: relative !important;
    display: inline-block !important;
    border-bottom: 1px dotted var(--medium-gray) !important;
    cursor: help !important;
}

.post-content .tooltip .tooltip-text {
    visibility: hidden !important;
    width: 220px !important;
    background-color: #2c2c2c !important;
    color: #fff !important;
    text-align: center !important;
    border-radius: var(--border-radius-sm) !important;
    padding: 12px 15px !important;
    position: absolute !important;
    z-index: 100 !important;
    bottom: 125% !important;
    left: 50% !important;
    margin-left: -110px !important;
    opacity: 0 !important;
    transition: opacity var(--transition-normal), transform var(--transition-normal) !important;
    transform: translateY(10px) !important;
    box-shadow: var(--box-shadow) !important;
    font-size: 0.9em !important;
    pointer-events: none !important;
    line-height: 1.5 !important;
    font-weight: 400 !important;
    font-family: var(--font-family-primary) !important;
    color: #ffffff !important;
}

.post-content .tooltip .tooltip-text::after {
    content: "" !important;
    position: absolute !important;
    top: 100% !important;
    left: 50% !important;
    margin-left: -6px !important;
    border-width: 6px !important;
    border-style: solid !important;
    border-color: #2c2c2c transparent transparent transparent !important;
}

.post-content .tooltip:hover .tooltip-text {
    visibility: visible !important;
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* Buttons */
.post-content .button {
    display: inline-block !important;
    padding: 14px 28px !important;
    background-color: var(--white) !important;
    color: var(--text-color) !important;
    border: 2px solid var(--medium-gray) !important;
    border-radius: var(--border-radius) !important;
    font-weight: 600 !important;
    font-size: 1em !important;
    text-align: center !important;
    cursor: pointer !important;
    transition: all var(--transition-normal) !important;
    text-decoration: none !important;
    margin: 0.6em 1.2em 0.6em 0 !important;
    box-shadow: var(--box-shadow-sm) !important;
    font-family: var(--font-family-primary) !important;
    letter-spacing: -0.01em !important;
}

.post-content .button:hover,
.post-content .button:focus {
    background-color: var(--light-gray) !important;
    color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    text-decoration: none !important;
    box-shadow: var(--box-shadow) !important;
    transform: translateY(-3px) !important;
    border-bottom: 2px solid var(--primary-color) !important;
}

.post-content .button.primary {
    background-color: var(--primary-color) !important;
    color: var(--white) !important;
    border-color: var(--primary-color) !important;
}

.post-content .button.primary:hover,
.post-content .button.primary:focus {
    background-color: #00305a !important;
    border-color: #00305a !important;
    color: var(--white) !important;
    box-shadow: 0 5px 15px rgba(0, 48, 90, 0.3) !important;
}

.post-content .button.secondary {
    background-color: var(--secondary-color) !important;
    color: var(--text-color) !important;
    border-color: var(--secondary-color) !important;
}

.post-content .button.secondary:hover,
.post-content .button.secondary:focus {
    background-color: #e9ecef !important;
    border-color: #e9ecef !important;
    color: var(--text-color) !important;
}

/* Dezente Buttons für externe und interne Links */
.post-content .button.external,
.post-content .button.internal {
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    color: var(--primary-color) !important;
    box-shadow: none !important;
    margin: 0 !important;
    display: inline !important;
    font-weight: 600 !important;
    border-bottom: 1px solid transparent !important;
}

.post-content .button.external:hover,
.post-content .button.internal:hover {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    transform: none !important;
    border-bottom: 1px solid var(--primary-color) !important;
}

.post-content .button.external::after {
    content: " ↗" !important;
    font-size: 0.9em !important;
    vertical-align: super !important;
    display: inline-block !important;
    transition: transform var(--transition-fast) !important;
    margin-left: 2px !important;
}

.post-content .button.external:hover::after {
    transform: translateX(2px) translateY(-2px) !important;
}

.post-content .button.internal::after {
    content: " →" !important;
    display: inline-block !important;
    transition: transform var(--transition-fast) !important;
    margin-left: 2px !important;
}

.post-content .button.internal:hover::after {
    transform: translateX(3px) !important;
}

.post-content .inline-button {
    display: inline-flex !important;
    align-items: center !important;
    color: var(--primary-color) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border-bottom: 2px solid transparent !important;
    transition: border-color var(--transition-fast) !important;
}

.post-content .inline-button:hover,
.post-content .inline-button:focus {
    border-bottom-color: var(--primary-color) !important;
    text-decoration: none !important;
}

/* Layouts */
.post-content .layout-text-image,
.post-content .layout-image-text {
    display: flex !important;
    gap: 40px !important;
    margin-bottom: 3.5em !important;
    align-items: center !important;
}

.post-content .layout-text {
    flex: 1 !important;
    min-width: 45% !important;
}

.post-content .layout-image figure {
    margin: 0 !important;
    flex: 0 0 45% !important;
    max-width: 45% !important;
    box-shadow: var(--box-shadow) !important;
    border-radius: var(--border-radius) !important;
    overflow: hidden !important;
    transition: transform var(--transition-normal) !important;
}

.post-content .layout-image figure:hover {
    transform: scale(1.02) !important;
}

.post-content .layout-full-width-image {
    margin: 4em -20px !important;
    position: relative !important;
}

.post-content .layout-full-width-image img {
    width: 100% !important;
    border-radius: 0 !important;
}

.post-content .layout-full-width-image figcaption {
    padding: 0 20px !important;
    margin-top: 1em !important;
}

.post-content .layout-two-columns,
.post-content .layout-three-columns {
    display: flex !important;
    gap: 40px !important;
    margin-bottom: 3em !important;
}

.post-content .layout-two-columns .column {
    flex: 1 !important;
}

.post-content .layout-three-columns .column {
    flex: 1 !important;
}

.post-content .column h4 {
    margin-top: 0 !important;
    font-size: 1.4em !important;
    position: relative !important;
    padding-bottom: 0.8em !important;
    margin-bottom: 1em !important;
}

.post-content .column h4::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 40px !important;
    height: 3px !important;
    background-color: var(--primary-color) !important;
    opacity: 0.3 !important;
}

/* Divider */
hr.layout-divider {
    border: 0 !important;
    height: 1px !important;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0)) !important;
    margin: 4em 0 !important;
}

/* Call to Action Box */
.post-content .cta-box {
    background-color: var(--primary-light) !important;
    border-radius: var(--border-radius) !important;
    padding: 50px 40px !important;
    text-align: center !important;
    margin: 4em 0 !important;
    box-shadow: var(--box-shadow) !important;
    transition: transform var(--transition-normal), box-shadow var(--transition-normal) !important;
    border: 1px solid rgba(0, 60, 113, 0.1) !important;
}

.post-content .cta-box:hover {
    transform: translateY(-5px) !important;
    box-shadow: var(--box-shadow-lg) !important;
}

.post-content .cta-box h2 {
    margin-top: 0 !important;
    color: var(--primary-color) !important;
    font-size: 2.2em !important;
    margin-bottom: 0.6em !important;
}

.post-content .cta-box p {
    max-width: 620px !important;
    margin: 1em auto 2em !important;
    font-size: 1.15em !important;
    line-height: 1.6 !important;
}

.post-content .cta-box .button.primary {
    background-color: var(--primary-color) !important;
    color: var(--white) !important;
    border-color: var(--primary-color) !important;
    padding: 16px 35px !important;
    font-size: 1.1em !important;
    box-shadow: 0 5px 15px rgba(0, 60, 113, 0.3) !important;
    letter-spacing: 0.02em !important;
}

.post-content .cta-box .button.primary:hover,
.post-content .cta-box .button.primary:focus {
    background-color: #00305a !important;
    border-color: #00305a !important;
    transform: translateY(-4px) !important;
    box-shadow: 0 10px 20px rgba(0, 48, 90, 0.4) !important;
}

/* Media Queries */
@media (max-width: 992px) {
    :root {
        --max-width: calc(100% - 50px) !important;
    }
    h1 { font-size: 2.4em !important; }
    h2 { font-size: 1.8em !important; }
    h3 { font-size: 1.5em !important; }
    h4 { font-size: 1.2em !important; }
    body { line-height: 1.65 !important; }
    
    .post-header, 
    .post-content, 
    .post-footer {
        padding: 25px 25px !important;
    }
    
    .summary-box,
    .table-of-contents,
    .info-box {
        padding: 25px !important;
    }
}

@media (max-width: 768px) {
    :root {
        --border-radius: 8px !important;
    }
    h1 { font-size: 2em !important; }
    h2 { font-size: 1.6em !important; }
    h3 { font-size: 1.4em !important; }
    h4 { font-size: 1.15em !important; }
    p { font-size: 0.95rem !important; }
    
    body {
        font-size: 16px !important;
    }
    
    .post-header,
    .post-content,
    .post-footer {
        padding: 20px !important;
    }
    
    .stats-cards {
        gap: 20px !important;
    }
    
    .vertical-tabs {
        flex-direction: column !important;
    }
    
    .vertical-tabs .tab-list {
        flex-direction: row !important;
        width: 100% !important;
        min-width: 100% !important;
        overflow-x: auto !important;
        border-right: none !important;
        border-bottom: 1px solid var(--medium-gray) !important;
    }
    
    .vertical-tabs .tab-button {
        flex: 1 0 auto !important;
        border-left: none !important;
        border-bottom: 3px solid transparent !important;
        white-space: nowrap !important;
        padding: 10px 15px !important;
    }
    
    .vertical-tabs .tab-button.active {
        border-left-color: transparent !important;
        border-bottom-color: var(--primary-color) !important;
    }
    
    .vertical-tabs .tab-panels {
        width: 100% !important;
    }
    
    .vertical-tabs .tab-panel {
        border-radius: 0 0 var(--border-radius) var(--border-radius) !important;
    }
    
    .layout-text-image,
    .layout-image-text,
    .layout-two-columns,
    .layout-three-columns {
        flex-direction: column !important;
        gap: 30px !important;
    }
    
    .layout-image figure {
        flex-basis: 100% !important;
    }
    
    .summary-box h2::after,
    .table-of-contents h2::after,
    .column h4::after {
        width: 35px !important;
        height: 2px !important;
    }
    
    .cta-box {
        padding: 40px 25px !important;
    }
    
    .cta-box h2 {
        font-size: 1.8em !important;
    }
}

@media (max-width: 480px) {
    :root {
        --border-radius: 6px !important;
        --max-width: calc(100% - 30px) !important;
    }
    h1 { font-size: 1.7em !important; }
    h2 { font-size: 1.45em !important; }
    h3 { font-size: 1.25em !important; }
    h4 { font-size: 1.1em !important; }
    p { font-size: 0.9rem !important; }
    body { line-height: 1.6 !important; }
    
    .post-meta {
        flex-direction: column !important;
        gap: 0.4em !important;
    }
    
    .post-meta span:not(:last-child)::after {
        display: none !important;
    }
    
    .stats-cards {
        flex-direction: column !important;
    }
    
    .button {
        display: block !important;
        width: 100% !important;
        margin: 0.8em 0 !important;
        padding: 12px 24px !important;
    }
    
    .button:last-child {
        margin-bottom: 0 !important;
    }
    
    .table-of-contents {
        padding: 20px !important;
    }
    
    .summary-box {
        padding: 20px !important;
    }
    
    .info-box {
        padding: 20px !important;
        padding-left: 50px !important;
    }
    
    .info-box::before {
        width: 24px !important;
        height: 24px !important;
        font-size: 12px !important;
        left: 15px !important;
    }
    
    .cta-box {
        padding: 30px 20px !important;
    }
    
    .cta-box h2 {
        font-size: 1.6em !important;
    }
    
    .cta-box p {
        font-size: 1em !important;
    }
}

/* Behebe border-radius Probleme - stelle sicher, dass sie immer angezeigt werden */
.post-content img,
.post-content .button,
.post-content .accordion,
.post-content .tabs,
.post-content .tab-panel,
.post-content .info-box,
.post-content .summary-box,
.post-content .chart-container,
.post-content .stat-card,
.post-content .cta-box,
.post-content .table-of-contents,
.post-content table,
.post-content .tooltip .tooltip-text {
    border-radius: var(--border-radius) !important;
    overflow: hidden !important;
}

/* Dynamisches Inhaltsverzeichnis - kann auch außerhalb des .post-content Container platziert werden */
.table-of-contents {
    background-color: var(--white) !important;
    border: 1px solid var(--medium-gray) !important;
    padding: 32px 35px !important;
    margin-bottom: 3.5em !important;
    border-radius: var(--border-radius) !important;
    box-shadow: var(--box-shadow-sm) !important;
    transition: box-shadow var(--transition-normal), transform var(--transition-normal) !important;
}

.table-of-contents:hover {
    box-shadow: var(--box-shadow) !important;
    transform: translateY(-2px) !important;
}

.table-of-contents h2 {
    margin-top: 0 !important;
    font-size: 1.6em !important;
    margin-bottom: 1.2em !important;
    position: relative !important;
    font-family: var(--font-family-primary) !important;
    color: var(--primary-color) !important;
}

.table-of-contents h2::after {
    content: "" !important;
    position: absolute !important;
    bottom: -0.5em !important;
    left: 0 !important;
    width: 40px !important;
    height: 2px !important;
    background-color: var(--primary-color) !important;
    opacity: 0.3 !important;
}

.table-of-contents ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.table-of-contents li {
    margin-bottom: 0.5em !important;
    padding-left: 0 !important;
    transition: transform var(--transition-fast), padding-left var(--transition-fast) !important;
    border-left: 0px solid transparent !important;
}

.table-of-contents li:hover {
    transform: translateX(5px) !important;
    border-left-color: var(--primary-color) !important;
}

.table-of-contents a {
    text-decoration: none !important;
    color: var(--text-color) !important;
    transition: color var(--transition-fast) !important;
    display: inline-block !important;
    width: 100% !important;
    padding: 3px 0 !important;
    border-bottom: none !important;
    font-size: 0.95em !important;
}

.table-of-contents a:hover {
    color: var(--primary-color) !important;
    border-bottom: none !important;
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: 150px; /* Offset für die Navigation */
}

/* Starke Regeln für Border-Radius, die nicht überschrieben werden können */
.post-content img[src],
.post-content button.button,
.post-content a.button,
.post-content div.accordion,
.post-content div.tabs,
.post-content div.tab-panel,
.post-content div.info-box,
.post-content div.summary-box,
.post-content div.chart-container,
.post-content div.stat-card,
.post-content div.cta-box,
.post-content nav.table-of-contents,
.post-content div.table-of-contents,
.post-content table.table,
.post-content table,
.post-content span.tooltip-text,
.post-content .tooltip .tooltip-text {
    border-radius: var(--border-radius) !important;
    -webkit-border-radius: var(--border-radius) !important;
    -moz-border-radius: var(--border-radius) !important;
    overflow: hidden !important;
}

/* Elementor überschreibt möglicherweise Stile, daher noch spezifischer sein */
body .post-content img[src],
body .post-content button.button,
body .post-content a.button,
body .post-content div.accordion,
body .post-content div.tabs,
body .post-content div.tab-panel,
body .post-content div.info-box,
body .post-content div.summary-box,
body .post-content div.chart-container,
body .post-content div.stat-card,
body .post-content div.cta-box,
body .post-content nav.table-of-contents,
body .post-content div.table-of-contents,
body .post-content table.table,
body .post-content table,
body .post-content span.tooltip-text,
body .post-content .tooltip .tooltip-text {
    border-radius: var(--border-radius) !important;
    -webkit-border-radius: var(--border-radius) !important;
    -moz-border-radius: var(--border-radius) !important;
    overflow: hidden !important;
}/* End custom CSS */