/* ==================================================
   01. Design Tokens / Grundwerte
   ================================================== */

:root {
    --et24-teal: #0D9488;
    --et24-teal-light: #23b9ad;
    --et24-teal-hover: #18a89d;
    --et24-blue: #0b4f91;
    --et24-blue-dark: #083f78;
    --et24-slate-900: #0f172a;
    --et24-slate-800: #1f2937;
    --et24-slate-700: #334155;
    --et24-slate-600: #475569;
    --et24-slate-500: #64748b;
    --et24-slate-100: #f1f5f9;
    --et24-slate-50: #f8fafc;
    --et24-white: #ffffff;
    --et24-success: #15803d;
    --et24-danger: #dc2626;

    --et24-border: rgba(15, 23, 42, 0.08);
    --et24-border-strong: rgba(15, 23, 42, 0.10);
    --et24-card-border: rgba(224, 225, 225, 0.9);

    --et24-shadow-sm: 0 8px 22px rgba(15, 23, 42, 0.04);
    --et24-shadow-md: 0 10px 25px rgba(15, 23, 42, 0.06);
    --et24-shadow-lg: 0 14px 35px rgba(15, 23, 42, 0.07);
    --et24-shadow-xl: 0 20px 50px rgba(15, 23, 42, 0.12);
    --et24-shadow-contact: 0 24px 70px rgba(15, 23, 42, 0.11);

    --et24-radius-sm: 0.4rem;
    --et24-radius-md: 0.75rem;
    --et24-radius-lg: 1rem;
    --et24-radius-xl: 18px;
    --et24-radius-2xl: 22px;
    --et24-radius-3xl: 28px;

    --et24-fontawesome: "Font Awesome 6 Free", "Font Awesome 5 Free";
}

/* ==================================================
   02. Globale Hilfsklassen / Astroid Basis
   ================================================== */

.text-teal {
    color: var(--et24-teal) !important;
}

.text-grau-blau {
    color: var(--et24-slate-500) !important;
}

/* Allgemeiner Seitenhintergrund für Komponentenbereich */
body .astroid-component-section {
    background:
        radial-gradient(circle at top left, rgba(35, 185, 173, 0.12), transparent 32%),
        radial-gradient(circle at bottom right, rgba(11, 79, 145, 0.10), transparent 34%),
        linear-gradient(180deg, var(--et24-slate-50) 0%, var(--et24-white) 100%);
    padding: 3.25rem 0 4.75rem;
}

/* ==================================================
   Ausnahme: Verzeichnis-Layout
   Betrifft deine Verzeichnis-Seiten und Praxis-Detailseiten
   mit layout-astroidtemplatetwoergotherapeuten24verzeichnis
   ================================================== */

body.layout-astroidtemplatetwoergotherapeuten24verzeichnis .astroid-component-section {
    padding: 0 0 4.75rem;
}

/* ==================================================
   Mobile Anpassung
   ================================================== */

@media (max-width: 767.98px) {
    body .astroid-component-section {
        padding: 2.25rem 0 3.25rem;
    }

    body.layout-astroidtemplatetwoergotherapeuten24verzeichnis .astroid-component-section {
        padding: 0 0 3.25rem;
    }
}

/* Header-Navigation optisch leicht ausrichten */
@media (min-width: 992px) {
    #astroid-header .header-left-section > nav {
        transform: translateY(5px);
    }

    #astroid-sticky-header .header-center-section > nav {
        transform: translateY(3px);
    }
}

.mod-breadcrumbs {
    border: none;
    border-radius: 0;
}

/* ==================================================
   03. Icon-Felder / Custom-Field Icons
   ================================================== */

.field-phone::before,
.field-mobile::before,
.field-fax::before,
.field-website::before,
.field-kontakt::before,
.field-termin::before {
    font-family: var(--et24-fontawesome);
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    margin-right: 0.5rem;
    color: var(--et24-teal);
    border: 2px solid var(--et24-teal);
    border-radius: var(--et24-radius-sm);
    box-sizing: border-box;
}

.field-phone::before {
    content: "\f095";
}

.field-mobile::before {
    content: "\f3cd";
}

.field-fax::before {
    content: "\f1ac";
}

.field-website::before {
    content: "\f0ac";
}

.field-kontakt::before {
    content: "\f0e0";
}

.field-termin::before {
    content: "\f274";
}

.field-website a,
.field-kontakt a,
.field-termin a {
    font-size: 0;
}

.field-website a::after,
.field-kontakt a::after,
.field-termin a::after {
    font-size: 1rem;
}

.field-website a::after {
    content: "Website besuchen";
}

.field-kontakt a::after {
    content: "Kontaktformular";
}

.field-termin a::after {
    content: "Termin buchen";
}

/* ==================================================
   04. Joomla Finder Suchmodul im Hero-Stil
   Modulklassensuffix: praxis-search-box
   ================================================== */

.praxis-search-box {
    max-width: 680px;
    margin: 0 auto;
}

.praxis-search-box search,
.praxis-search-box form.mod-finder {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.praxis-search-box .mod-finder__search.input-group {
    display: flex;
    align-items: center;
    width: 100%;
    gap: 8px;
    padding: 8px;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.10);
    box-shadow: 0 12px 35px rgba(0, 0, 0, 0.22);
}

.praxis-search-box .awesomplete {
    position: relative;
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
    display: block;
}

.praxis-search-box .awesomplete::before {
    content: "\f3c5";
    font-family: var(--et24-fontawesome);
    font-weight: 900;
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--et24-teal-light);
    font-size: 1.05rem;
    z-index: 3;
    pointer-events: none;
}

.praxis-search-box .js-finder-search-query,
.praxis-search-box input[type="text"].form-control {
    width: 100%;
    height: 56px;
    min-height: 56px;
    padding: 0 1.25rem 0 3.1rem;
    border: 0;
    border-radius: 10px !important;
    background: var(--et24-white);
    color: #20313a;
    font-size: 1rem;
    font-weight: 400;
    line-height: 56px;
    box-shadow: none;
    outline: none;
}

.praxis-search-box input::placeholder {
    color: #8f98a3;
    opacity: 1;
}

.praxis-search-box .js-finder-search-query:focus,
.praxis-search-box input[type="text"].form-control:focus {
    border: 0;
    box-shadow: 0 0 0 3px rgba(35, 185, 173, 0.22);
    outline: none;
}

.praxis-search-box .btn.btn-primary {
    flex: 0 0 auto;
    width: 200px;
    height: 56px;
    min-height: 56px;
    padding: 0 1.5rem;
    border: 0;
    border-radius: 10px !important;
    background: var(--et24-teal-light);
    color: var(--et24-white);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    box-shadow: none;
    transition: background 0.2s ease, transform 0.2s ease;
}

.praxis-search-box .btn.btn-primary .icon-search {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    font-size: 1rem;
}

.praxis-search-box .btn.btn-primary::before {
    content: none !important;
}

.praxis-search-box .btn.btn-primary:hover,
.praxis-search-box .btn.btn-primary:focus {
    background: var(--et24-teal-hover);
    color: var(--et24-white);
    transform: translateY(-1px);
    box-shadow: none;
}

.praxis-search-box .awesomplete > ul {
    z-index: 9999;
    border-radius: 10px;
    margin-top: 6px;
}

@media (max-width: 575.98px) {
    .praxis-search-box {
        max-width: 100%;
    }

    .praxis-search-box .mod-finder__search.input-group {
        flex-direction: column;
        gap: 10px;
        padding: 10px;
    }

    .praxis-search-box .awesomplete,
    .praxis-search-box .btn.btn-primary {
        width: 100%;
    }

    .praxis-search-box .btn.btn-primary {
        min-width: 0;
    }
}

/* ==================================================
   05. Hero Trustline / Vorteilzeile
   ================================================== */

.hero-trustline {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 1.75rem;
    margin-top: 1.25rem;
    color: rgba(255, 255, 255, 0.66);
    font-size: 0.95rem;
    font-weight: 500;
    line-height: 1.4;
}

.hero-trustline-item {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    white-space: nowrap;
}

@media (max-width: 575.98px) {
    .hero-trustline {
        gap: 0.75rem 1rem;
        font-size: 0.9rem;
    }

    .hero-trustline-item {
        white-space: normal;
        justify-content: center;
    }
}

/* ==================================================
   06. com_finder Suchergebnisse
   ================================================== */

.com-finder.finder {
    max-width: 1040px;
    margin: 3rem auto 4rem;
}

.com-finder__form {
    margin-bottom: 2rem;
    padding: 1.25rem;
    border: 1px solid var(--et24-border);
    border-radius: var(--et24-radius-2xl);
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.14), transparent 34%),
        linear-gradient(135deg, var(--et24-white), var(--et24-slate-50));
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}

.com-finder__search.word {
    margin: 0 !important;
    padding: 0;
    border: 0;
}

.com-finder__search .form-inline > label {
    display: block;
    margin: 0 0 0.6rem;
    color: var(--et24-slate-700);
    font-size: 0.95rem;
    font-weight: 700;
}

.com-finder__search .input-group {
    display: flex;
    align-items: stretch;
    width: 100%;
    gap: 0.65rem;
}

.com-finder__search .awesomplete {
    position: relative;
    flex: 1 1 auto;
    min-width: 0;
}

.com-finder__search .awesomplete::before {
    content: "\f002";
    font-family: var(--et24-fontawesome);
    font-weight: 900;
    position: absolute;
    left: 1.05rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--et24-teal-light);
    font-size: 1rem;
    z-index: 3;
    pointer-events: none;
}

.com-finder__search .js-finder-search-query,
.com-finder__search input[type="text"].form-control {
    width: 100%;
    height: 54px;
    min-height: 54px;
    padding: 0 1.1rem 0 2.9rem;
    border: 1px solid var(--et24-border-strong);
    border-radius: 14px !important;
    background: var(--et24-white);
    color: var(--et24-slate-900);
    font-size: 1rem;
    font-weight: 500;
    box-shadow: none;
    outline: none;
}

.com-finder__search .js-finder-search-query:focus,
.com-finder__search input[type="text"].form-control:focus {
    border-color: rgba(35, 185, 173, 0.55);
    box-shadow: 0 0 0 4px rgba(35, 185, 173, 0.16);
}

.com-finder__search .btn.btn-primary {
    flex: 0 0 auto;
    min-width: 180px;
    height: 54px;
    padding: 0 1.35rem;
    border: 0;
    border-radius: 14px !important;
    background: #0f9f98;
    color: var(--et24-white);
    font-size: 0.98rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    box-shadow: none;
    transition: background 0.2s ease, transform 0.2s ease;
}

.com-finder__search .btn.btn-primary:hover,
.com-finder__search .btn.btn-primary:focus {
    background: #0b8f88;
    color: var(--et24-white);
    transform: translateY(-1px);
}

.com-finder__explained {
    margin: 0 0 1.5rem;
    padding: 1rem 1.15rem;
    border: 1px solid rgba(35, 185, 173, 0.18);
    border-radius: 16px;
    background: rgba(35, 185, 173, 0.08);
    color: var(--et24-slate-700);
}

.com-finder__explained p {
    margin: 0;
    font-size: 0.98rem;
    line-height: 1.6;
}

.com-finder__explained .term {
    color: var(--et24-blue);
    font-weight: 800;
}

/* Suchergebnis-Karten */
.et24-search-results {
    margin-top: 2rem;
}

.et24-search-results__header {
    max-width: 760px;
    margin-bottom: 1.5rem;
}

.et24-search-results__eyebrow {
    display: inline-flex;
    margin-bottom: 0.55rem;
    color: var(--et24-teal-light);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.et24-search-results__title {
    margin: 0;
    color: var(--et24-slate-900);
    font-size: clamp(1.75rem, 2.5vw, 2.4rem);
    font-weight: 850;
    line-height: 1.1;
}

.et24-search-results__intro {
    margin: 0.75rem 0 0;
    color: var(--et24-slate-500);
    font-size: 1rem;
    line-height: 1.65;
}

.et24-search-results__grid {
    display: grid;
    gap: 1rem;
}

.et24-search-card {
    border: 1px solid var(--et24-border);
    border-radius: var(--et24-radius-2xl);
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.14), transparent 34%),
        linear-gradient(135deg, var(--et24-white), var(--et24-slate-50));
    box-shadow: var(--et24-shadow-lg);
    overflow: hidden;
    transition:
        transform 0.22s ease,
        box-shadow 0.22s ease,
        border-color 0.22s ease;
}

.et24-search-card:hover {
    transform: translateY(-3px);
    border-color: rgba(35, 185, 173, 0.42);
    box-shadow: var(--et24-shadow-xl);
}

.et24-search-card__main {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 118px;
    padding: 1.35rem 4rem 1.35rem 1.35rem;
    color: inherit;
    text-decoration: none;
}

.et24-search-card__main:hover,
.et24-search-card__main:focus {
    text-decoration: none;
}

.et24-search-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 54px;
    width: 54px;
    height: 54px;
    margin-right: 1rem;
    border-radius: 18px;
    background: rgba(35, 185, 173, 0.12);
    color: var(--et24-teal-light);
    font-size: 1.25rem;
}

.et24-search-card__body {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.et24-search-card__title {
    color: var(--et24-blue);
    font-size: 1.28rem;
    font-weight: 850;
    line-height: 1.2;
}

.et24-search-card__subtitle {
    margin-top: 0.25rem;
    color: var(--et24-slate-700);
    font-size: 0.98rem;
    font-weight: 650;
    line-height: 1.4;
}

.et24-search-card__meta {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-top: 0.45rem;
    color: var(--et24-slate-500);
    font-size: 0.95rem;
    font-weight: 600;
}

.et24-search-card__meta i {
    color: var(--et24-teal-light);
}

.et24-search-card__description {
    margin-top: 0.45rem;
    color: var(--et24-slate-500);
    font-size: 0.95rem;
    line-height: 1.55;
}

.et24-search-card__action {
    margin-top: 0.6rem;
    color: #23a9a0;
    font-size: 0.95rem;
    font-weight: 800;
}

.et24-search-card__arrow {
    position: absolute;
    right: 1.35rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--et24-teal-light);
    font-size: 1.55rem;
    font-weight: 900;
    transition: transform 0.22s ease;
}

.et24-search-card__main:hover .et24-search-card__arrow,
.et24-search-card__main:focus .et24-search-card__arrow {
    transform: translate(4px, -50%);
}

.et24-search-card__quicklinks {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    padding: 0 1.35rem 1.35rem 6.7rem;
}

.et24-search-card__quicklink {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 38px;
    padding: 0.55rem 0.85rem;
    border-radius: 999px;
    background: rgba(11, 79, 145, 0.08);
    color: var(--et24-blue);
    font-size: 0.9rem;
    font-weight: 750;
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease;
}

.et24-search-card__quicklink:hover,
.et24-search-card__quicklink:focus {
    background: var(--et24-blue);
    color: var(--et24-white);
    text-decoration: none;
}

.et24-search-empty {
    padding: 2rem;
    border: 1px solid var(--et24-border);
    border-radius: var(--et24-radius-2xl);
    background: var(--et24-white);
    box-shadow: var(--et24-shadow-lg);
    text-align: center;
}

.et24-search-empty__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 58px;
    margin-bottom: 1rem;
    border-radius: 18px;
    background: rgba(35, 185, 173, 0.12);
    color: var(--et24-teal-light);
    font-size: 1.35rem;
}

.et24-search-empty__title {
    margin: 0;
    color: var(--et24-slate-900);
    font-size: 1.6rem;
    font-weight: 850;
}

.et24-search-empty__text {
    max-width: 560px;
    margin: 0.75rem auto 0;
    color: var(--et24-slate-500);
    font-size: 1rem;
    line-height: 1.65;
}

.com-finder__navigation.search-pagination {
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--et24-border);
}

.com-finder__counter.search-pages-counter {
    color: var(--et24-slate-500);
    font-size: 0.95rem;
    font-weight: 600;
}

.com-finder__counter.search-pages-counter strong {
    color: var(--et24-slate-900);
}

@media (max-width: 575.98px) {
    .com-finder.finder {
        margin: 2rem auto 3rem;
    }

    .com-finder__form {
        padding: 1rem;
        border-radius: 18px;
    }

    .com-finder__search .input-group {
        flex-direction: column;
        gap: 0.75rem;
    }

    .com-finder__search .awesomplete,
    .com-finder__search .btn.btn-primary {
        width: 100%;
    }

    .com-finder__search .btn.btn-primary {
        min-width: 0;
    }

    .et24-search-card__main {
        align-items: flex-start;
        min-height: 104px;
        padding: 1.15rem 3.2rem 1.15rem 1.15rem;
    }

    .et24-search-card__icon {
        flex-basis: 46px;
        width: 46px;
        height: 46px;
        margin-right: 0.85rem;
        border-radius: 15px;
        font-size: 1.05rem;
    }

    .et24-search-card__title {
        font-size: 1.12rem;
    }

    .et24-search-card__quicklinks {
        padding: 0 1.15rem 1.15rem;
    }

    .et24-search-card__quicklink {
        flex: 1 1 auto;
        justify-content: center;
    }
}

/* ==================================================
   07. Ratgeber Kategorie-Blog
   Gilt nur für body.ratgeber-alias
   ================================================== */

body.ratgeber-alias .astroid-component-area > .blog {
    margin: 2.5rem 0 4rem;
}

body.ratgeber-alias .blog > .page-header {
    max-width: 860px;
    margin: 0 0 1rem;
}

body.ratgeber-alias .blog > .page-header h1 {
    margin: 0;
    color: var(--et24-slate-900);
    font-size: clamp(2rem, 3vw, 3rem);
    font-weight: 850;
    line-height: 1.1;
}

body.ratgeber-alias .blog > .category-desc {
    max-width: 760px;
    margin: 0 0 2.25rem;
    color: var(--et24-slate-500);
    font-size: 1.05rem;
    line-height: 1.7;
}

body.ratgeber-alias .blog > .category-desc p {
    margin: 0;
}

body.ratgeber-alias .com-content-category-blog__items.blog-items {
    display: block;
    margin: 0;
}

body.ratgeber-alias .com-content-category-blog__items > .row {
    align-items: stretch;
}

body.ratgeber-alias .com-content-category-blog__item.blog-item {
    display: flex;
    min-width: 0;
}

body.ratgeber-alias .com-content-category-blog__item .item-content {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: 100%;
    padding: 0;
    border: 1px solid var(--et24-border);
    border-radius: var(--et24-radius-2xl);
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.13), transparent 34%),
        linear-gradient(135deg, var(--et24-white), var(--et24-slate-50));
    box-shadow: var(--et24-shadow-lg);
    overflow: hidden;
    transition:
        transform 0.22s ease,
        box-shadow 0.22s ease,
        border-color 0.22s ease;
}

body.ratgeber-alias .com-content-category-blog__item .item-content:hover {
    transform: translateY(-4px);
    border-color: rgba(35, 185, 173, 0.42);
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.13);
}

body.ratgeber-alias .com-content-category-blog__item .item-image {
    display: block;
    width: 100%;
    margin: 0;
    overflow: hidden;
    background: #e2e8f0;
}

body.ratgeber-alias .com-content-category-blog__item .item-image img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
    object-fit: cover;
    transition: transform 0.35s ease;
}

body.ratgeber-alias .com-content-category-blog__item .item-content:hover .item-image img {
    transform: scale(1.045);
}

body.ratgeber-alias .com-content-category-blog__item .has-image,
body.ratgeber-alias .com-content-category-blog__item .item-content > .d-flex {
    display: flex !important;
    flex-direction: column;
    flex: 1 1 auto;
    padding: 1.35rem;
}

body.ratgeber-alias .article-title.item-title,
body.ratgeber-alias .article-title.item-title .page-header {
    margin: 0;
    padding: 0;
}

body.ratgeber-alias .article-title.item-title h2 {
    margin: 0;
    color: var(--et24-blue);
    font-size: 1.32rem;
    font-weight: 850;
    line-height: 1.23;
}

body.ratgeber-alias .article-title.item-title h2 a {
    color: var(--et24-blue);
    text-decoration: none;
}

body.ratgeber-alias .article-title.item-title h2 a:hover,
body.ratgeber-alias .article-title.item-title h2 a:focus {
    color: #23a9a0;
    text-decoration: none;
}

body.ratgeber-alias .article-intro-text {
    margin-top: 0.85rem;
    color: var(--et24-slate-500);
    font-size: 0.98rem;
    line-height: 1.65;
}

body.ratgeber-alias .article-intro-text p {
    margin: 0 0 0.75rem;
}

body.ratgeber-alias .article-intro-text p:last-child {
    margin-bottom: 0;
}

body.ratgeber-alias .article-intro-text strong {
    color: var(--et24-slate-700);
    font-weight: 800;
}

body.ratgeber-alias .article-intro-text a {
    color: var(--et24-blue);
    font-weight: 700;
    text-decoration: none;
}

body.ratgeber-alias .article-intro-text a:hover,
body.ratgeber-alias .article-intro-text a:focus {
    color: #23a9a0;
    text-decoration: underline;
}

body.ratgeber-alias .readmore {
    margin: auto 0 0;
    padding-top: 1.1rem;
}

body.ratgeber-alias .readmore .as-readmore {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 42px;
    padding: 0.65rem 1rem;
    border: 2px solid var(--et24-teal-light);
    border-radius: 999px;
    background: var(--et24-teal-light);
    color: var(--et24-white);
    font-size: 0.92rem;
    font-weight: 800;
    line-height: 1.2;
    text-decoration: none;
    transition:
        background 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
}

body.ratgeber-alias .readmore .as-readmore:hover,
body.ratgeber-alias .readmore .as-readmore:focus {
    background: var(--et24-white);
    color: var(--et24-teal-light);
    border-color: var(--et24-teal-light);
    text-decoration: none;
    transform: translateY(-1px);
}

body.ratgeber-alias .article-info,
body.ratgeber-alias .icons {
    margin-top: 0.75rem;
}

body.ratgeber-alias .com-content-category-blog__navigation,
body.ratgeber-alias .pagination__wrapper {
    margin-top: 2rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--et24-border);
}

@media (max-width: 767.98px) {
    body.ratgeber-alias .astroid-component-area > .blog {
        margin: 2rem 0 3rem;
    }

    body.ratgeber-alias .blog > .page-header h1 {
        font-size: 2rem;
    }

    body.ratgeber-alias .blog > .category-desc {
        margin-bottom: 1.75rem;
        font-size: 1rem;
    }

    body.ratgeber-alias .com-content-category-blog__item .has-image,
    body.ratgeber-alias .com-content-category-blog__item .item-content > .d-flex {
        padding: 1.15rem;
    }

    body.ratgeber-alias .article-title.item-title h2 {
        font-size: 1.16rem;
    }

    body.ratgeber-alias .article-intro-text {
        font-size: 0.95rem;
    }

    body.ratgeber-alias .readmore .as-readmore {
        width: 100%;
    }
}

/* ==================================================
   08. Ratgeber Einzelartikel
   ================================================== */

body.ratgeber-alias.view-article .astroid-component-area {
    max-width: 1300px;
    margin: 0 auto;
}

body.ratgeber-alias.view-article .com-content-article.item-page {
    margin: 2.5rem 0 4rem;
}

body.ratgeber-alias.view-article .com-content-article.item-page > .astroid-section {
    border: 1px solid var(--et24-border);
    border-radius: var(--et24-radius-3xl);
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.13), transparent 32%),
        linear-gradient(135deg, var(--et24-white), var(--et24-slate-50));
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
    overflow: hidden;
}

body.ratgeber-alias.view-article .com-content-article.item-page .astroid-row {
    margin: 0;
}

body.ratgeber-alias.view-article .com-content-article.item-page .astroid-column {
    padding: 2.25rem;
}

body.ratgeber-alias.view-article .astroid-article-pageheading {
    margin-bottom: 0.75rem;
}

body.ratgeber-alias.view-article .astroid-article-pageheading h1 {
    display: inline-flex;
    align-items: center;
    margin: 0;
    color: var(--et24-teal-light);
    font-size: 0.86rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    line-height: 1.2;
    text-transform: uppercase;
}

body.ratgeber-alias.view-article .astroid-article-title {
    max-width: 1300px;
    margin-bottom: 1.5rem;
}

body.ratgeber-alias.view-article .astroid-article-title h2 {
    margin: 0;
    color: var(--et24-slate-900);
    font-size: clamp(2rem, 3vw, 3.15rem);
    font-weight: 850;
    line-height: 1.08;
}

body.ratgeber-alias.view-article .astroid-article-text {
    color: var(--et24-slate-700);
    font-size: 1.05rem;
    line-height: 1.78;
}

body.ratgeber-alias.view-article .astroid-article-text p {
    margin: 0 0 1.15rem;
}

body.ratgeber-alias.view-article .astroid-article-text p:last-child {
    margin-bottom: 0;
}

body.ratgeber-alias.view-article .astroid-article-text strong {
    color: var(--et24-slate-900);
    font-weight: 850;
}

body.ratgeber-alias.view-article .astroid-article-text a {
    color: var(--et24-blue);
    font-weight: 750;
    text-decoration: none;
    border-bottom: 1px solid rgba(35, 185, 173, 0.35);
}

body.ratgeber-alias.view-article .astroid-article-text a:hover,
body.ratgeber-alias.view-article .astroid-article-text a:focus {
    color: #23a9a0;
    border-bottom-color: #23a9a0;
    text-decoration: none;
}

body.ratgeber-alias.view-article .astroid-article-text h2 {
    position: relative;
    margin: 2.6rem 0 1rem;
    padding-top: 1.25rem;
    color: var(--et24-slate-900);
    font-size: clamp(1.55rem, 2vw, 2.15rem);
    font-weight: 850;
    line-height: 1.18;
    border-top: 1px solid var(--et24-border);
}

body.ratgeber-alias.view-article .astroid-article-text h2::before {
    content: "";
    position: absolute;
    top: -1px;
    left: 0;
    width: 72px;
    height: 3px;
    border-radius: 999px;
    background: var(--et24-teal-light);
}

body.ratgeber-alias.view-article .astroid-article-text h3 {
    margin: 2rem 0 0.85rem;
    color: var(--et24-blue);
    font-size: clamp(1.2rem, 1.6vw, 1.45rem);
    font-weight: 850;
    line-height: 1.25;
}

body.ratgeber-alias.view-article .astroid-article-text ul {
    display: grid;
    gap: 0.65rem;
    margin: 1rem 0 1.5rem;
    padding: 0;
    list-style: none;
}

body.ratgeber-alias.view-article .astroid-article-text li {
    position: relative;
    padding: 0.8rem 1rem 0.8rem 3rem;
    border: 1px solid var(--et24-border);
    border-radius: 16px;
    background: var(--et24-white);
    color: var(--et24-slate-700);
    box-shadow: var(--et24-shadow-sm);
}

body.ratgeber-alias.view-article .astroid-article-text li::before {
    content: "\f00c";
    font-family: var(--et24-fontawesome);
    font-weight: 900;
    position: absolute;
    left: 1rem;
    top: 0.82rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 0.45rem;
    background: rgba(35, 185, 173, 0.12);
    color: var(--et24-teal-light);
    font-size: 0.75rem;
}

body.ratgeber-alias.view-article .astroid-article-text figure.image {
    margin: 2rem 0;
    border: 1px solid var(--et24-border);
    border-radius: 24px;
    background: var(--et24-white);
    box-shadow: var(--et24-shadow-lg);
    overflow: hidden;
}

body.ratgeber-alias.view-article .astroid-article-text figure.image img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
    object-fit: cover;
}

body.ratgeber-alias.view-article .astroid-article-text figure.image figcaption {
    padding: 0.9rem 1.15rem;
    color: var(--et24-slate-500);
    font-size: 0.92rem;
    font-weight: 650;
    line-height: 1.45;
    background: var(--et24-white);
    border-top: 1px solid rgba(15, 23, 42, 0.06);
}

/* FAQ Accordion */
body.ratgeber-alias.view-article .astroid-article-text .accordion {
    margin: 1.5rem 0 2rem;
    display: grid;
    gap: 0.75rem;
}

body.ratgeber-alias.view-article .astroid-article-text .accordion-item {
    border: 1px solid var(--et24-border);
    border-radius: 18px;
    background: var(--et24-white);
    box-shadow: 0 10px 25px rgba(15, 23, 42, 0.05);
    overflow: hidden;
}

body.ratgeber-alias.view-article .astroid-article-text .accordion-header {
    margin: 0;
}

body.ratgeber-alias.view-article .astroid-article-text .accordion-button {
    padding: 1rem 1.15rem;
    background: var(--et24-white);
    color: var(--et24-slate-900);
    font-size: 1rem;
    font-weight: 850;
    line-height: 1.35;
    box-shadow: none;
}

body.ratgeber-alias.view-article .astroid-article-text .accordion-button:not(.collapsed) {
    background: rgba(35, 185, 173, 0.10);
    color: var(--et24-blue);
    box-shadow: none;
}

body.ratgeber-alias.view-article .astroid-article-text .accordion-button:focus {
    border-color: transparent;
    box-shadow: 0 0 0 4px rgba(35, 185, 173, 0.16);
}

body.ratgeber-alias.view-article .astroid-article-text .accordion-body {
    padding: 1rem 1.15rem 1.15rem;
    color: var(--et24-slate-600);
    font-size: 0.98rem;
    line-height: 1.7;
}

body.ratgeber-alias.view-article .astroid-article-text .accordion-button::after {
    opacity: 0.75;
}

body.ratgeber-alias.view-article .astroid-article-text > p:first-child {
    padding: 1.25rem 1.35rem;
    border: 1px solid rgba(35, 185, 173, 0.20);
    border-radius: 20px;
    background: rgba(35, 185, 173, 0.08);
    color: var(--et24-slate-700);
    font-size: 1.08rem;
    line-height: 1.75;
}

/* Tabellen */
body.ratgeber-alias.view-article .astroid-article-text table {
    width: 100%;
    margin: 1.75rem 0 2rem;
    border-collapse: separate;
    border-spacing: 0;
    border: 1px solid var(--et24-border);
    border-radius: var(--et24-radius-2xl);
    background: var(--et24-white);
    box-shadow: var(--et24-shadow-lg);
    overflow: hidden;
}

body.ratgeber-alias.view-article .astroid-article-text table thead {
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.22), transparent 40%),
        linear-gradient(135deg, var(--et24-blue), #0f9f98);
}

body.ratgeber-alias.view-article .astroid-article-text table thead th,
body.ratgeber-alias.view-article .astroid-article-text table tbody td {
    padding: 1rem 1.15rem;
    line-height: 1.55;
    text-align: left;
    vertical-align: top;
    border: 0;
}

body.ratgeber-alias.view-article .astroid-article-text table thead th {
    color: var(--et24-white);
    font-size: 0.95rem;
    font-weight: 850;
    line-height: 1.35;
}

body.ratgeber-alias.view-article .astroid-article-text table tbody td {
    color: var(--et24-slate-700);
    font-size: 0.98rem;
    font-weight: 500;
    border-top: 1px solid rgba(15, 23, 42, 0.07);
}

body.ratgeber-alias.view-article .astroid-article-text table tbody tr:nth-child(even) td {
    background: rgba(248, 250, 252, 0.95);
}

body.ratgeber-alias.view-article .astroid-article-text table tbody tr:hover td {
    background: rgba(35, 185, 173, 0.07);
}

body.ratgeber-alias.view-article .astroid-article-text table tbody td:first-child {
    color: var(--et24-blue);
    font-weight: 800;
}

body.ratgeber-alias.view-article .astroid-article-text table caption {
    caption-side: bottom;
    padding: 0.85rem 1rem 0;
    color: var(--et24-slate-500);
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1.45;
    text-align: left;
}

body.ratgeber-alias.view-article .astroid-article-text table a {
    color: var(--et24-blue);
    font-weight: 800;
    text-decoration: none;
    border-bottom: 1px solid rgba(35, 185, 173, 0.35);
}

body.ratgeber-alias.view-article .astroid-article-text table a:hover,
body.ratgeber-alias.view-article .astroid-article-text table a:focus {
    color: #23a9a0;
    border-bottom-color: #23a9a0;
}

@media (max-width: 767.98px) {
    body.ratgeber-alias.view-article .com-content-article.item-page {
        margin: 2rem 0 3rem;
    }

    body.ratgeber-alias.view-article .com-content-article.item-page > .astroid-section {
        border-radius: var(--et24-radius-2xl);
    }

    body.ratgeber-alias.view-article .com-content-article.item-page .astroid-column {
        padding: 1.25rem;
    }

    body.ratgeber-alias.view-article .astroid-article-title h2 {
        font-size: 1.85rem;
    }

    body.ratgeber-alias.view-article .astroid-article-text {
        font-size: 1rem;
        line-height: 1.72;
    }

    body.ratgeber-alias.view-article .astroid-article-text h2 {
        margin-top: 2.25rem;
        font-size: 1.45rem;
    }

    body.ratgeber-alias.view-article .astroid-article-text h3 {
        font-size: 1.18rem;
    }

    body.ratgeber-alias.view-article .astroid-article-text li {
        padding: 0.75rem 0.9rem 0.75rem 2.75rem;
    }

    body.ratgeber-alias.view-article .astroid-article-text li::before {
        left: 0.9rem;
    }

    body.ratgeber-alias.view-article .astroid-article-text > p:first-child {
        padding: 1rem;
        font-size: 1rem;
    }

    body.ratgeber-alias.view-article .astroid-article-text table {
        display: block;
        width: 100%;
        overflow-x: auto;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch;
        border-radius: 18px;
    }

    body.ratgeber-alias.view-article .astroid-article-text table thead,
    body.ratgeber-alias.view-article .astroid-article-text table tbody,
    body.ratgeber-alias.view-article .astroid-article-text table tr {
        width: 100%;
    }

    body.ratgeber-alias.view-article .astroid-article-text table thead th,
    body.ratgeber-alias.view-article .astroid-article-text table tbody td {
        padding: 0.85rem 1rem;
        font-size: 0.92rem;
    }
}

/* ==================================================
   09. Kontaktseite / com_contact Override
   ================================================== */

body.kontakt-alias.com-contact.view-contact .astroid-component-area {
    max-width: 1300px;
    margin: 0 auto;
}

.et24-contact-page {
    color: var(--et24-slate-700);
}

.et24-contact-hero {
    max-width: 1300px;
    margin: 0 0 2rem;
}

.et24-contact-hero__eyebrow {
    display: inline-flex;
    margin-bottom: 0.7rem;
    color: var(--et24-teal-light);
    font-size: 0.82rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.et24-contact-hero__title {
    margin: 0;
    color: var(--et24-slate-900);
    font-size: clamp(2.1rem, 3.4vw, 3.4rem);
    font-weight: 850;
    line-height: 1.08;
}

.et24-contact-hero__text {
    max-width: 1300px;
    margin: 1rem 0 0;
    color: var(--et24-slate-500);
    font-size: 1.08rem;
    line-height: 1.7;
}

.et24-contact-layout {
    display: grid;
    grid-template-columns: minmax(300px, 0.82fr) minmax(0, 1.45fr);
    gap: 1.25rem;
    padding: 1.25rem;
    border: 1px solid var(--et24-border);
    border-radius: 34px;
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.13), transparent 36%),
        linear-gradient(135deg, var(--et24-white), var(--et24-slate-50));
    box-shadow: var(--et24-shadow-contact);
}

.et24-contact-info-card {
    min-height: 100%;
}

.et24-contact-info-card__inner {
    position: relative;
    height: 100%;
    min-height: 440px;
    padding: 2rem;
    border-radius: var(--et24-radius-3xl);
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.30), transparent 35%),
        linear-gradient(145deg, var(--et24-slate-900), var(--et24-blue));
    color: var(--et24-white);
    overflow: hidden;
}

.et24-contact-info-card__inner::after {
    content: "";
    position: absolute;
    right: -78px;
    bottom: -78px;
    width: 210px;
    height: 210px;
    border-radius: 50%;
    background: rgba(35, 185, 173, 0.18);
    pointer-events: none;
}

.et24-contact-info-card__icon {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 62px;
    height: 62px;
    margin-bottom: 1.35rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.12);
    color: #5eead4;
    font-size: 1.55rem;
}

.et24-contact-info-card__eyebrow {
    position: relative;
    z-index: 1;
    display: inline-flex;
    margin-bottom: 0.7rem;
    color: rgba(255, 255, 255, 0.76);
    font-size: 0.78rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.et24-contact-info-card__title {
    position: relative;
    z-index: 1;
    margin: 0;
    color: var(--et24-white);
    font-size: clamp(1.75rem, 2.4vw, 2.35rem);
    font-weight: 850;
    line-height: 1.12;
}

.et24-contact-info-card__text {
    position: relative;
    z-index: 1;
    margin: 1rem 0 0;
    color: rgba(255, 255, 255, 0.76);
    font-size: 1rem;
    line-height: 1.7;
}

.et24-contact-info-list {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 0.85rem;
    margin-top: 2rem;
}

.et24-contact-info-list__item {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    padding: 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.84);
    font-size: 0.96rem;
    line-height: 1.55;
}

.et24-contact-info-list__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 36px;
    width: 36px;
    height: 36px;
    border-radius: 12px;
    background: rgba(94, 234, 212, 0.13);
    color: #5eead4;
    align-self: center;
}

.et24-contact-info-list__item--email,
.et24-contact-info-list__item--phone,
.et24-contact-info-list__item--mobile,
.et24-contact-info-list__item--fax,
.et24-contact-info-list__item--website {
    align-items: center;
    min-height: 64px;
}

.et24-contact-info-list__content {
    min-width: 0;
}

.et24-contact-info-list__item--email .et24-contact-info-list__content,
.et24-contact-info-list__item--phone .et24-contact-info-list__content,
.et24-contact-info-list__item--mobile .et24-contact-info-list__content,
.et24-contact-info-list__item--fax .et24-contact-info-list__content,
.et24-contact-info-list__item--website .et24-contact-info-list__content {
    display: flex;
    align-items: center;
    min-height: 36px;
}

.et24-contact-info-list__item a {
    color: var(--et24-white);
    font-weight: 750;
    text-decoration: none;
}

.et24-contact-info-list__item--email a,
.et24-contact-info-list__item--phone a,
.et24-contact-info-list__item--mobile a,
.et24-contact-info-list__item--website a {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    margin: 0;
    line-height: 1.2;
}

.et24-contact-info-list__item a:hover,
.et24-contact-info-list__item a:focus {
    color: #5eead4;
    text-decoration: none;
}

.et24-contact-info-card__notice {
    display: none !important;
}

.et24-contact-form-card {
    padding: 2rem;
}

.et24-contact-form-card__eyebrow {
    display: inline-flex;
    margin-bottom: 0.6rem;
    color: var(--et24-teal-light);
    font-size: 0.8rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.et24-contact-form-card__title {
    margin: 0;
    color: var(--et24-slate-900);
    font-size: clamp(1.9rem, 2.6vw, 2.65rem);
    font-weight: 850;
    line-height: 1.1;
}

.et24-contact-form-card__text {
    max-width: 680px;
    margin: 0.8rem 0 0;
    color: var(--et24-slate-500);
    font-size: 1rem;
    line-height: 1.7;
}

.et24-contact-form {
    margin-top: 1.65rem;
}

.et24-contact-form__required {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-bottom: 1rem;
    padding: 0.85rem 1rem;
    border: 1px solid rgba(35, 185, 173, 0.18);
    border-radius: 16px;
    background: rgba(35, 185, 173, 0.07);
    color: var(--et24-slate-600);
    font-size: 0.92rem;
    font-weight: 700;
}

.et24-contact-form__required i,
.et24-contact-form__required strong {
    color: var(--et24-teal-light);
}

.et24-contact-form__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.et24-contact-form__field--full {
    grid-column: 1 / -1;
}

.et24-contact-form__label {
    margin-bottom: 0.45rem;
}

.et24-contact-form__label label {
    margin: 0;
    color: var(--et24-slate-700);
    font-size: 0.95rem;
    font-weight: 850;
}

.et24-contact-form__label .star {
    color: var(--et24-teal-light);
    font-weight: 900;
}

.et24-contact-form__control {
    position: relative;
}

.et24-contact-form__field-icon {
    position: absolute;
    left: 1rem;
    top: 27px;
    transform: translateY(-50%);
    z-index: 2;
    color: var(--et24-teal-light);
    font-size: 1rem;
    pointer-events: none;
}

.et24-contact-form__field--message .et24-contact-form__field-icon {
    top: 1.3rem;
    transform: none;
}

.et24-contact-form input[type="text"],
.et24-contact-form input[type="email"],
.et24-contact-form textarea,
.et24-contact-form .form-control {
    width: 100%;
    border: 1px solid var(--et24-border-strong);
    border-radius: 16px !important;
    background: var(--et24-white);
    color: var(--et24-slate-900);
    font-size: 1rem;
    font-weight: 500;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.04);
    outline: none;
    transition:
        border-color 0.2s ease,
        box-shadow 0.2s ease,
        transform 0.2s ease;
}

.et24-contact-form input[type="text"],
.et24-contact-form input[type="email"] {
    min-height: 54px;
    padding: 0 1rem 0 2.9rem;
}

.et24-contact-form textarea {
    min-height: 180px;
    padding: 1rem 1rem 1rem 2.9rem;
    resize: vertical;
    line-height: 1.65;
}

.et24-contact-form input[type="text"]:focus,
.et24-contact-form input[type="email"]:focus,
.et24-contact-form textarea:focus,
.et24-contact-form .form-control:focus {
    border-color: rgba(35, 185, 173, 0.65);
    box-shadow:
        0 0 0 4px rgba(35, 185, 173, 0.15),
        0 12px 30px rgba(15, 23, 42, 0.07);
    transform: translateY(-1px);
}

.et24-contact-form__copy {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-top: 1rem;
    color: var(--et24-slate-600);
    font-size: 0.95rem;
    font-weight: 650;
}

.et24-contact-form__copy input,
.et24-contact-form__plugin-input input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--et24-teal-light);
}

.et24-contact-form__copy label {
    margin: 0;
}

/* Datenschutz-/Pluginfelder */
.et24-contact-form__plugin-fields {
    display: grid;
    gap: 1rem;
    margin-top: 1.25rem;
}

.et24-contact-form__plugin-field {
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
    padding: 1rem;
    border: 1px solid rgba(35, 185, 173, 0.20);
    border-radius: 20px;
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.11), transparent 34%),
        linear-gradient(135deg, var(--et24-white), var(--et24-slate-50));
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.05);
}

.et24-contact-form__plugin-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 42px;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: rgba(35, 185, 173, 0.12);
    color: var(--et24-teal-light);
    font-size: 1.05rem;
}

.et24-contact-form__plugin-content,
.et24-contact-form__plugin-label label {
    min-width: 0;
    color: var(--et24-slate-600);
    font-size: 0.94rem;
    line-height: 1.65;
}

.et24-contact-form__plugin-label label {
    display: block;
    margin: 0;
    font-weight: 500;
}

.et24-contact-form__plugin-label label > a {
    display: inline-flex;
    align-items: center;
    margin-bottom: 0.35rem;
    color: var(--et24-blue);
    font-size: 0.98rem;
    font-weight: 850;
    text-decoration: none;
    border-bottom: 1px solid rgba(35, 185, 173, 0.35);
}

.et24-contact-form__plugin-label label > a::before {
    content: "\f05a";
    font-family: var(--et24-fontawesome);
    font-weight: 900;
    margin-right: 0.45rem;
    color: var(--et24-teal-light);
}

.et24-contact-form__plugin-label label > a:hover,
.et24-contact-form__plugin-label label > a:focus {
    color: #23a9a0;
    border-bottom-color: #23a9a0;
    text-decoration: none;
}

.et24-contact-form__plugin-label label div {
    margin-top: 0.25rem;
    color: var(--et24-slate-500);
    font-size: 0.93rem;
    line-height: 1.65;
}

.et24-contact-form__plugin-input {
    margin-top: 0.7rem;
}

.et24-contact-form__plugin-field--consentbox {
    margin-top: 0.25rem;
}

/* Captcha */
.et24-contact-form__captcha {
    margin-top: 1.25rem;
    padding: 1rem;
    border: 1px solid var(--et24-border);
    border-radius: 20px;
    background: var(--et24-white);
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.05);
}

.et24-contact-form__captcha-label label {
    margin: 0 0 0.65rem;
    color: var(--et24-slate-700);
    font-size: 0.95rem;
    font-weight: 850;
}

.et24-contact-form__captcha-label .star {
    color: var(--et24-teal-light);
}

.et24-contact-form altcha-widget {
    display: block;
    max-width: 100%;
    --altcha-color-base: #ffffff;
    --altcha-color-border: rgba(15, 23, 42, 0.12);
    --altcha-color-text: #334155;
    --altcha-color-border-focus: #23b9ad;
    --altcha-color-accent: #23b9ad;
}

.et24-contact-form__actions {
    margin-top: 1.5rem;
}

.et24-contact-form__submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    min-height: 56px;
    min-width: 230px;
    padding: 0.85rem 1.7rem;
    border: 0;
    border-radius: 999px !important;
    background: linear-gradient(135deg, var(--et24-teal-light), var(--et24-blue));
    color: var(--et24-white);
    font-size: 1rem;
    font-weight: 850;
    line-height: 1.2;
    box-shadow: 0 16px 34px rgba(35, 185, 173, 0.25);
    transition:
        transform 0.22s ease,
        box-shadow 0.22s ease,
        background 0.22s ease;
}

.et24-contact-form__submit::before {
    content: "\f1d8";
    font-family: var(--et24-fontawesome);
    font-weight: 900;
}

.et24-contact-form__submit:hover,
.et24-contact-form__submit:focus {
    background: linear-gradient(135deg, var(--et24-teal-hover), var(--et24-blue-dark));
    color: var(--et24-white);
    transform: translateY(-2px);
    box-shadow: 0 20px 42px rgba(35, 185, 173, 0.32);
}

.et24-contact-form .invalid,
.et24-contact-form .form-control.invalid {
    border-color: rgba(220, 38, 38, 0.58) !important;
}

.et24-contact-form .form-control.invalid:focus {
    box-shadow: 0 0 0 4px rgba(220, 38, 38, 0.12);
}

.et24-contact-form-card__disabled {
    margin-top: 1.5rem;
    padding: 1.25rem;
    border: 1px solid rgba(220, 38, 38, 0.16);
    border-radius: 18px;
    background: rgba(220, 38, 38, 0.06);
    color: #7f1d1d;
}

.et24-contact-form-card__disabled strong,
.et24-contact-form-card__disabled span {
    display: block;
}

@media (max-width: 991.98px) {
    .et24-contact-layout {
        grid-template-columns: 1fr;
    }

    .et24-contact-info-card__inner {
        min-height: auto;
    }
}

@media (max-width: 767.98px) {
    .et24-contact-layout {
        padding: 0.85rem;
        border-radius: 26px;
    }

    .et24-contact-info-card__inner {
        padding: 1.5rem;
        border-radius: var(--et24-radius-2xl);
    }

    .et24-contact-form-card {
        padding: 1.35rem 0.5rem 0.5rem;
    }

    .et24-contact-form__grid {
        grid-template-columns: 1fr;
    }

    .et24-contact-form__submit {
        width: 100%;
        min-width: 0;
    }

    .et24-contact-form textarea {
        min-height: 150px;
    }

    .et24-contact-form__plugin-field {
        gap: 0.75rem;
        padding: 0.9rem;
        border-radius: 18px;
    }

    .et24-contact-form__plugin-icon {
        flex-basis: 38px;
        width: 38px;
        height: 38px;
        border-radius: 13px;
        font-size: 0.95rem;
    }

    .et24-contact-form__plugin-content,
    .et24-contact-form__plugin-label label,
    .et24-contact-form__plugin-label label div {
        font-size: 0.9rem;
    }
}

/* ==================================================
   10. Praxis Detailseite / Vollbreite Hero & Ankernavigation
   ================================================== */

#vo-65056e43b0f5f854156558,
#as-65056b04bfbf0472904891 {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

#vo-65056e43b0f5f854156558 .astroid-row,
#as-65056b04bfbf0472904891 .astroid-row {
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
}

#vo-65056e43b0f5f854156558 h1 {
    color: var(--et24-white);
    margin: 0;
}

#as-65056b04bfbf0472904891 .as-nav-bar .nav-link {
    color: var(--et24-teal);
    font-weight: 600;
    padding: 0.65rem 1rem;
    border: 1px solid transparent;
    border-radius: var(--et24-radius-md);
    background: transparent;
    transition: all 0.2s ease-in-out;
}

#as-65056b04bfbf0472904891 .as-nav-bar .nav-link:hover,
#as-65056b04bfbf0472904891 .as-nav-bar .nav-link:focus,
#as-65056b04bfbf0472904891 .as-nav-bar .nav-link.active,
#as-65056b04bfbf0472904891 .as-nav-bar .nav-item.active .nav-link {
    color: var(--et24-teal);
    background: var(--et24-slate-50);
    border-color: var(--et24-teal);
    text-decoration: none;
}

#praxis,
#sprechzeiten,
#behandlungsschwerpunkte,
#leistungen {
    scroll-margin-top: 175px;
}

@media (min-width: 992px) {
    #ac-6505e0702f4c1010404137 {
        position: sticky;
        top: 175px;
        align-self: flex-start;
        z-index: 10;
    }

    #ar-65056aea6a8c2836621923 {
        align-items: stretch;
    }

    #ac-65056aea6a8c2858311689,
    #ac-6505e0702f4c1010404137 {
        display: flex;
        flex-direction: column;
    }

    #ac-65056aea6a8c2858311689 > .astroid-article-custom-fields,
    #ac-65056aea6a8c2858311689 > .astroid-article-custom-fields > .astroid-article-custom-fields,
    #ac-65056aea6a8c2858311689 .astroid-article-custom-fields__group,
    #ac-65056aea6a8c2858311689 .astroid-article-custom-fields__item,
    #ac-65056aea6a8c2858311689 .astroid-article-custom-fields__value {
        height: 100%;
    }

    #ac-65056aea6a8c2858311689 [id^="map_jform_com_fields_ergo_karte"] {
        height: 100% !important;
        min-height: 400px;
    }
}

/* Name / Adresse kombinierte Felder */
#a-6505cc48e371c491624980 .astroid-article-custom-fields__item.is-combined {
    display: flex;
    align-items: center;
    line-height: 1.4;
}

#a-6505cc48e371c491624980 .astroid-article-custom-fields__combined-field {
    font-weight: 700;
}

#a-6505cc48e371c491624980 .astroid-article-custom-fields__item.is-combined::before {
    content: "\f3c5";
    font-family: var(--et24-fontawesome);
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    min-width: 2rem;
    height: 2rem;
    margin-right: 0.5rem;
    color: var(--et24-teal);
    border: 2px solid var(--et24-teal);
    border-radius: var(--et24-radius-sm);
    box-sizing: border-box;
    flex-shrink: 0;
}

#pa-6505c1f27cd88813102582 .astroid-article-custom-fields__item.is-combined {
    display: block;
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1.25;
    color: var(--et24-slate-800);
    margin-top: 0;
    margin-bottom: 0.75rem;
}

@media (max-width: 575.98px) {
    #pa-6505c1f27cd88813102582 .astroid-article-custom-fields__item.is-combined {
        font-size: 1.4rem;
    }
}

/* ==================================================
   11. Wiederverwendbare Kartenraster für Custom-Fields
   ================================================== */

/* Kosten & Abrechnung */
#acf-6505ec160e84b868828114 .astroid-article-custom-fields__group {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem !important;
    align-items: stretch !important;
}

#acf-6505ec160e84b868828114 .astroid-article-custom-fields__item {
    background: var(--et24-white);
    border: 1px solid var(--et24-card-border);
    border-radius: var(--et24-radius-lg);
    padding: 1rem;
    box-shadow: var(--et24-shadow-md);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 78px;
}

#acf-6505ec160e84b868828114 .astroid-article-custom-fields__label {
    font-weight: 700;
    color: var(--et24-slate-800);
    line-height: 1.3;
    margin: 0;
}

#acf-6505ec160e84b868828114 .astroid-article-custom-fields__value {
    margin: 0;
    flex-shrink: 0;
}

/* Öffnungszeiten & Erreichbarkeit */
#acf-6505f556143ca896234329 .astroid-article-custom-fields__group {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem !important;
    align-items: stretch !important;
}

#acf-6505f556143ca896234329 .astroid-article-custom-fields__item {
    background: var(--et24-white);
    border: 1px solid var(--et24-card-border);
    border-radius: var(--et24-radius-lg);
    padding: 1rem;
    box-shadow: var(--et24-shadow-md);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 0.75rem;
    min-height: 115px;
    align-items: center;
    text-align: center;
}

#acf-6505f556143ca896234329 .astroid-article-custom-fields__label {
    font-weight: 700;
    color: var(--et24-slate-800);
    line-height: 1.3;
    margin: 0;
    text-align: center;
}

#acf-6505f556143ca896234329 .astroid-article-custom-fields__value {
    display: flex;
    justify-content: center;
    width: 100%;
    margin: 0;
}

/* Ja/Nein Icons */
#acf-6505ec160e84b868828114 .yesno-icon,
#acf-6505f556143ca896234329 .yesno-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 0.6rem;
    font-family: var(--et24-fontawesome);
    font-weight: 900;
    font-size: 1rem;
    line-height: 1;
}

#acf-6505ec160e84b868828114 .yesno-icon.is-yes,
#acf-6505f556143ca896234329 .yesno-icon.is-yes {
    color: var(--et24-success);
    background: rgba(22, 163, 74, 0.12);
    border: 1px solid rgba(22, 163, 74, 0.35);
}

#acf-6505ec160e84b868828114 .yesno-icon.is-no,
#acf-6505f556143ca896234329 .yesno-icon.is-no {
    color: var(--et24-danger);
    background: rgba(220, 38, 38, 0.12);
    border: 1px solid rgba(220, 38, 38, 0.35);
}

/* Terminbuchung als Button */
#acf-6505f556143ca896234329 .field-ergo-terminbuchung-url .astroid-article-custom-fields__label {
    display: none;
}

#acf-6505f556143ca896234329 .field-ergo-terminbuchung-url {
    justify-content: center;
}

#acf-6505f556143ca896234329 .oj-appointment-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    min-height: 2.75rem;
    padding: 0.75rem 1rem;
    color: var(--et24-white);
    background: var(--et24-teal);
    border: 2px solid var(--et24-teal);
    border-radius: var(--et24-radius-md);
    font-weight: 700;
    text-decoration: none;
    line-height: 1.2;
    transition: all 0.2s ease-in-out;
}

#acf-6505f556143ca896234329 .oj-appointment-button::before {
    content: "\f274";
    font-family: var(--et24-fontawesome);
    font-weight: 900;
}

#acf-6505f556143ca896234329 .oj-appointment-button:hover,
#acf-6505f556143ca896234329 .oj-appointment-button:focus {
    color: var(--et24-teal);
    background: var(--et24-white);
    border-color: var(--et24-teal);
    text-decoration: none;
}

@media (max-width: 991.98px) {
    #acf-6505ec160e84b868828114 .astroid-article-custom-fields__group,
    #acf-6505f556143ca896234329 .astroid-article-custom-fields__group {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    #acf-6505ec160e84b868828114 .astroid-article-custom-fields__group,
    #acf-6505f556143ca896234329 .astroid-article-custom-fields__group {
        grid-template-columns: 1fr;
    }
}

/* ==================================================
   12. Gruppen-Karten: Zielgruppen, Fachbereiche usw.
   ================================================== */

#z-650470046f881025630423 .oj-target-groups,
#f-65047025ad449c58959069 .oj-specialty-groups,
#s-650470554a0a4497524285 .oj-specialization-groups,
#l-650470f874e4c834499722 .oj-service-groups,
#ba-6504728a62ee0411390099 .oj-accessibility-groups,
#z-650475d0ca692452975550 .oj-qualification-groups,
#f-650475fa413cdc94533925 .oj-training-groups,
#z-6504763e1f19e482548679 .oj-certificate-groups {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem !important;
    align-items: stretch !important;
}

#z-650470046f881025630423 .oj-target-group-card,
#f-65047025ad449c58959069 .oj-specialty-card,
#s-650470554a0a4497524285 .oj-specialization-card,
#l-650470f874e4c834499722 .oj-service-card,
#ba-6504728a62ee0411390099 .oj-accessibility-card,
#z-650475d0ca692452975550 .oj-qualification-card,
#f-650475fa413cdc94533925 .oj-training-card,
#z-6504763e1f19e482548679 .oj-certificate-card {
    background: var(--et24-white);
    border: 1px solid var(--et24-card-border);
    border-radius: var(--et24-radius-lg);
    padding: 1rem;
    box-shadow: var(--et24-shadow-md);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 78px;
}

#z-650470046f881025630423 .oj-target-group-label,
#f-65047025ad449c58959069 .oj-specialty-label,
#s-650470554a0a4497524285 .oj-specialization-label,
#l-650470f874e4c834499722 .oj-service-label,
#ba-6504728a62ee0411390099 .oj-accessibility-label,
#z-650475d0ca692452975550 .oj-qualification-label,
#f-650475fa413cdc94533925 .oj-training-label,
#z-6504763e1f19e482548679 .oj-certificate-label {
    font-weight: 700;
    color: var(--et24-slate-800);
    line-height: 1.3;
    margin: 0;
}

#z-650470046f881025630423 .oj-target-group-icon,
#f-65047025ad449c58959069 .oj-specialty-icon,
#s-650470554a0a4497524285 .oj-specialization-icon,
#l-650470f874e4c834499722 .oj-service-icon,
#ba-6504728a62ee0411390099 .oj-accessibility-icon,
#z-650475d0ca692452975550 .oj-qualification-icon,
#f-650475fa413cdc94533925 .oj-training-icon,
#z-6504763e1f19e482548679 .oj-certificate-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 0.6rem;
    font-family: var(--et24-fontawesome);
    font-weight: 900;
    font-size: 1rem;
    line-height: 1;
    flex-shrink: 0;
    color: var(--et24-success);
    background: rgba(22, 163, 74, 0.12);
    border: 1px solid rgba(22, 163, 74, 0.35);
}

@media (max-width: 991.98px) {
    #z-650470046f881025630423 .oj-target-groups,
    #f-65047025ad449c58959069 .oj-specialty-groups,
    #s-650470554a0a4497524285 .oj-specialization-groups,
    #l-650470f874e4c834499722 .oj-service-groups,
    #ba-6504728a62ee0411390099 .oj-accessibility-groups,
    #z-650475d0ca692452975550 .oj-qualification-groups,
    #f-650475fa413cdc94533925 .oj-training-groups,
    #z-6504763e1f19e482548679 .oj-certificate-groups {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    #z-650470046f881025630423 .oj-target-groups,
    #f-65047025ad449c58959069 .oj-specialty-groups,
    #s-650470554a0a4497524285 .oj-specialization-groups,
    #l-650470f874e4c834499722 .oj-service-groups,
    #ba-6504728a62ee0411390099 .oj-accessibility-groups,
    #z-650475d0ca692452975550 .oj-qualification-groups,
    #f-650475fa413cdc94533925 .oj-training-groups,
    #z-6504763e1f19e482548679 .oj-certificate-groups {
        grid-template-columns: 1fr;
    }
}

/* ==================================================
   13. Social Media Custom Fields als SVG-Masken
   ================================================== */

.astroid-article-custom-fields__combined-field.field-ergo-facebook-url a,
.astroid-article-custom-fields__combined-field.field-ergo-instagram a,
.astroid-article-custom-fields__combined-field.field-ergo-linkedin a,
.astroid-article-custom-fields__combined-field.field-ergo-youtube a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: #f1f1f1;
    color: #222;
    text-decoration: none;
    font-size: 0;
    line-height: 1;
    transition: all 0.2s ease-in-out;
}

.astroid-article-custom-fields__combined-field.field-ergo-facebook-url a::before,
.astroid-article-custom-fields__combined-field.field-ergo-instagram a::before,
.astroid-article-custom-fields__combined-field.field-ergo-linkedin a::before,
.astroid-article-custom-fields__combined-field.field-ergo-youtube a::before {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    background-color: currentColor;
    mask-position: center;
    mask-repeat: no-repeat;
    mask-size: contain;
    -webkit-mask-position: center;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-size: contain;
}

.astroid-article-custom-fields__combined-field.field-ergo-facebook-url a::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 512'%3E%3Cpath d='M279.14 288l14.22-92.66h-88.91v-60.13c0-25.35 12.42-50.06 52.24-50.06H297V6.26S260.43 0 225.36 0C152.14 0 104.28 44.38 104.28 124.72v70.62H22.89V288h81.39v224h100.17V288z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 512'%3E%3Cpath d='M279.14 288l14.22-92.66h-88.91v-60.13c0-25.35 12.42-50.06 52.24-50.06H297V6.26S260.43 0 225.36 0C152.14 0 104.28 44.38 104.28 124.72v70.62H22.89V288h81.39v224h100.17V288z'/%3E%3C/svg%3E");
}

.astroid-article-custom-fields__combined-field.field-ergo-instagram a::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M224.1 141c-63.6 0-114.9 51.3-114.9 114.9s51.3 114.9 114.9 114.9S339 319.5 339 255.9 287.7 141 224.1 141zm0 189.6c-41.1 0-74.7-33.5-74.7-74.7s33.5-74.7 74.7-74.7 74.7 33.5 74.7 74.7-33.6 74.7-74.7 74.7zm146.4-194.3c0 14.9-12 26.8-26.8 26.8-14.9 0-26.8-12-26.8-26.8s12-26.8 26.8-26.8 26.8 12 26.8 26.8zm76.1 27.2c-1.7-35.9-9.9-67.7-36.2-93.9S352.4 35.1 316.5 33.4c-37-2.1-147.9-2.1-184.9 0-35.8 1.7-67.6 9.9-93.9 36.1S3.2 127.5 1.5 163.4c-2.1 37-2.1 147.9 0 184.9 1.7 35.9 9.9 67.7 36.2 93.9s58 34.5 93.9 36.2c37 2.1 147.9 2.1 184.9 0 35.9-1.7 67.7-9.9 93.9-36.2s34.5-58 36.2-93.9c2.1-37 2.1-147.8 0-184.8zM398.8 388c-7.8 19.6-22.9 34.7-42.6 42.6-29.5 11.7-99.5 9-132.1 9s-102.7 2.6-132.1-9c-19.6-7.8-34.7-22.9-42.6-42.6-11.7-29.5-9-99.5-9-132.1s-2.6-102.7 9-132.1c7.8-19.6 22.9-34.7 42.6-42.6 29.5-11.7 99.5-9 132.1-9s102.7-2.6 132.1 9c19.6 7.8 34.7 22.9 42.6 42.6 11.7 29.5 9 99.5 9 132.1s2.7 102.7-9 132.1z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M224.1 141c-63.6 0-114.9 51.3-114.9 114.9s51.3 114.9 114.9 114.9S339 319.5 339 255.9 287.7 141 224.1 141zm0 189.6c-41.1 0-74.7-33.5-74.7-74.7s33.5-74.7 74.7-74.7 74.7 33.5 74.7 74.7-33.6 74.7-74.7 74.7zm146.4-194.3c0 14.9-12 26.8-26.8 26.8-14.9 0-26.8-12-26.8-26.8s12-26.8 26.8-26.8 26.8 12 26.8 26.8zm76.1 27.2c-1.7-35.9-9.9-67.7-36.2-93.9S352.4 35.1 316.5 33.4c-37-2.1-147.9-2.1-184.9 0-35.8 1.7-67.6 9.9-93.9 36.1S3.2 127.5 1.5 163.4c-2.1 37-2.1 147.9 0 184.9 1.7 35.9 9.9 67.7 36.2 93.9s58 34.5 93.9 36.2c37 2.1 147.9 2.1 184.9 0 35.9-1.7 67.7-9.9 93.9-36.2s34.5-58 36.2-93.9c2.1-37 2.1-147.8 0-184.8zM398.8 388c-7.8 19.6-22.9 34.7-42.6 42.6-29.5 11.7-99.5 9-132.1 9s-102.7 2.6-132.1-9c-19.6-7.8-34.7-22.9-42.6-42.6-11.7-29.5-9-99.5-9-132.1s-2.6-102.7 9-132.1c7.8-19.6 22.9-34.7 42.6-42.6 29.5-11.7 99.5-9 132.1-9s102.7-2.6 132.1 9c19.6 7.8 34.7 22.9 42.6 42.6 11.7 29.5 9 99.5 9 132.1s2.7 102.7-9 132.1z'/%3E%3C/svg%3E");
}

.astroid-article-custom-fields__combined-field.field-ergo-linkedin a::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M100.28 448H7.4V148.9h92.88zm-46.44-340C24.1 108 0 83.5 0 53.8A53.8 53.8 0 0 1 53.8 0c29.7 0 53.8 24.1 53.8 53.8 0 29.7-24.1 54.2-53.8 54.2zM447.9 448h-92.7V302.4c0-34.7-.7-79.2-48.29-79.2-48.29 0-55.69 37.7-55.69 76.7V448h-92.78V148.9h89.08v40.8h1.3c12.4-23.5 42.69-48.3 87.88-48.3 94 0 111.29 61.9 111.29 142.3V448z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath d='M100.28 448H7.4V148.9h92.88zm-46.44-340C24.1 108 0 83.5 0 53.8A53.8 53.8 0 0 1 53.8 0c29.7 0 53.8 24.1 53.8 53.8 0 29.7-24.1 54.2-53.8 54.2zM447.9 448h-92.7V302.4c0-34.7-.7-79.2-48.29-79.2-48.29 0-55.69 37.7-55.69 76.7V448h-92.78V148.9h89.08v40.8h1.3c12.4-23.5 42.69-48.3 87.88-48.3 94 0 111.29 61.9 111.29 142.3V448z'/%3E%3C/svg%3E");
}

.astroid-article-custom-fields__combined-field.field-ergo-youtube a::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 576 512'%3E%3Cpath d='M549.7 124.1c-6.3-23.7-24.8-42.3-48.3-48.6C458.8 64 288 64 288 64S117.2 64 74.6 75.5c-23.5 6.3-42 24.9-48.3 48.6C15 167 15 256.4 15 256.4s0 89.4 11.3 132.3c6.3 23.7 24.8 41.5 48.3 47.8C117.2 448 288 448 288 448s170.8 0 213.4-11.5c23.5-6.3 42-24.1 48.3-47.8C561 345.8 561 256.4 561 256.4s0-89.4-11.3-132.3zM232 337.6V175.2l142.7 81.2L232 337.6z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 576 512'%3E%3Cpath d='M549.7 124.1c-6.3-23.7-24.8-42.3-48.3-48.6C458.8 64 288 64 288 64S117.2 64 74.6 75.5c-23.5 6.3-42 24.9-48.3 48.6C15 167 15 256.4 15 256.4s0 89.4 11.3 132.3c6.3 23.7 24.8 41.5 48.3 47.8C117.2 448 288 448 288 448s170.8 0 213.4-11.5c23.5-6.3 42-24.1 48.3-47.8C561 345.8 561 256.4 561 256.4s0-89.4-11.3-132.3zM232 337.6V175.2l142.7 81.2L232 337.6z'/%3E%3C/svg%3E");
}

.astroid-article-custom-fields__item.is-combined {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.astroid-article-custom-fields__item.is-combined > span {
    display: inline-flex;
}

.astroid-article-custom-fields__combined-field.field-ergo-facebook-url a:hover,
.astroid-article-custom-fields__combined-field.field-ergo-facebook-url a:focus {
    background: #1877f2;
    color: #fff;
}

.astroid-article-custom-fields__combined-field.field-ergo-instagram a:hover,
.astroid-article-custom-fields__combined-field.field-ergo-instagram a:focus {
    background: #e4405f;
    color: #fff;
}

.astroid-article-custom-fields__combined-field.field-ergo-linkedin a:hover,
.astroid-article-custom-fields__combined-field.field-ergo-linkedin a:focus {
    background: #0a66c2;
    color: #fff;
}

.astroid-article-custom-fields__combined-field.field-ergo-youtube a:hover,
.astroid-article-custom-fields__combined-field.field-ergo-youtube a:focus {
    background: #ff0000;
    color: #fff;
}

.astroid-article-custom-fields__combined-field.field-ergo-facebook-url a:focus,
.astroid-article-custom-fields__combined-field.field-ergo-instagram a:focus,
.astroid-article-custom-fields__combined-field.field-ergo-linkedin a:focus,
.astroid-article-custom-fields__combined-field.field-ergo-youtube a:focus {
    outline: 2px solid currentColor;
    outline-offset: 3px;
}

/* Social-Media-Block rechtsbündig */
#ac-650bab8fbbbc1c4138777 {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

#sm-650ba5c733c1e871484834 {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

#sm-650ba5c733c1e871484834 .astroid-article-custom-fields,
#sm-650ba5c733c1e871484834 .astroid-article-custom-fields__group {
    width: 100%;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
}

#sm-650ba5c733c1e871484834 .astroid-article-custom-fields__item.is-combined {
    display: flex !important;
    flex-wrap: wrap;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 0.5rem;
    width: 100%;
    text-align: right;
}

#sm-650ba5c733c1e871484834 .astroid-article-custom-fields__combined-field,
#sm-650ba5c733c1e871484834 .astroid-article-custom-fields__value {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#sm-650ba5c733c1e871484834 .astroid-article-custom-fields__combined-field {
    margin: 0;
}

@media (max-width: 991.98px) {
    #ac-650bab8fbbbc1c4138777,
    #sm-650ba5c733c1e871484834,
    #sm-650ba5c733c1e871484834 .astroid-article-custom-fields,
    #sm-650ba5c733c1e871484834 .astroid-article-custom-fields__group,
    #sm-650ba5c733c1e871484834 .astroid-article-custom-fields__item.is-combined {
        justify-content: flex-start !important;
        text-align: left;
    }

    #sm-650ba5c733c1e871484834 {
        margin-top: 1rem;
    }
}

/* ==================================================
   14. Kategorie-Blog Unterkategorien als Städte-Karten
   ================================================== */

.et24-category-children {
    margin: 2.5rem 0 3.5rem;
}

.et24-category-children__header,
.et24-premium-category-view__header {
    max-width: 760px;
    margin-bottom: 1.75rem;
}

.et24-category-children__eyebrow,
.et24-premium-category-view__eyebrow {
    display: inline-flex;
    align-items: center;
    margin-bottom: 0.65rem;
    color: var(--et24-teal-light);
    font-size: 0.85rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.et24-category-children__title,
.et24-premium-category-view__title {
    margin: 0;
    color: var(--et24-slate-900);
    font-size: clamp(2rem, 3vw, 3rem);
    font-weight: 850;
    line-height: 1.1;
}

.et24-category-children__intro,
.et24-premium-category-view__intro {
    margin: 0.85rem 0 0;
    color: var(--et24-slate-500);
    font-size: 1.05rem;
    line-height: 1.7;
}

.et24-city-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.et24-city-card {
    min-width: 0;
}

.et24-city-card__link {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 118px;
    padding: 1.25rem;
    border: 1px solid var(--et24-border);
    border-radius: 20px;
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.16), transparent 38%),
        linear-gradient(135deg, var(--et24-white), var(--et24-slate-50));
    box-shadow: var(--et24-shadow-lg);
    color: inherit;
    text-decoration: none;
    overflow: hidden;
    transition:
        transform 0.22s ease,
        box-shadow 0.22s ease,
        border-color 0.22s ease,
        background 0.22s ease;
}

.et24-city-card__link:hover,
.et24-city-card__link:focus {
    transform: translateY(-4px);
    border-color: rgba(35, 185, 173, 0.42);
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.13);
    text-decoration: none;
}

.et24-city-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 48px;
    width: 48px;
    height: 48px;
    margin-right: 1rem;
    border-radius: 16px;
    background: rgba(35, 185, 173, 0.12);
    color: var(--et24-teal-light);
    font-size: 1.15rem;
}

.et24-city-card__content {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.et24-city-card__name {
    color: var(--et24-blue);
    font-size: 1.25rem;
    font-weight: 850;
    line-height: 1.2;
}

.et24-city-card__meta {
    margin-top: 0.4rem;
    color: var(--et24-slate-500);
    font-size: 0.94rem;
    font-weight: 600;
    line-height: 1.35;
}

.et24-city-card__arrow {
    margin-left: auto;
    color: var(--et24-teal-light);
    font-size: 1.35rem;
    font-weight: 800;
    line-height: 1;
    transform: translateX(0);
    transition: transform 0.22s ease;
}

.et24-city-card__link:hover .et24-city-card__arrow,
.et24-city-card__link:focus .et24-city-card__arrow {
    transform: translateX(4px);
}

.blog .alert.alert-info {
    display: none;
}

@media (max-width: 991.98px) {
    .et24-city-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .et24-category-children {
        margin: 2rem 0 2.75rem;
    }

    .et24-city-grid {
        grid-template-columns: 1fr;
    }

    .et24-city-card__link {
        min-height: 104px;
        padding: 1.1rem;
        border-radius: 18px;
    }

    .et24-city-card__icon {
        flex-basis: 44px;
        width: 44px;
        height: 44px;
        margin-right: 0.85rem;
        border-radius: 14px;
    }

    .et24-city-card__name {
        font-size: 1.15rem;
    }
}

/* ==================================================
   15. Städte-Filter nach Anfangsbuchstaben
   ================================================== */

.et24-city-filter {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0 1.5rem;
    padding: 0.75rem;
    border: 1px solid var(--et24-border);
    border-radius: 18px;
    background: var(--et24-white);
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
}

.et24-city-filter__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 40px;
    padding: 0 0.9rem;
    border: 1px solid var(--et24-border-strong);
    border-radius: 999px;
    background: var(--et24-slate-50);
    color: var(--et24-slate-700);
    font-size: 0.95rem;
    font-weight: 750;
    line-height: 1;
    cursor: pointer;
    transition:
        background 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
}

.et24-city-filter__button:hover,
.et24-city-filter__button:focus {
    border-color: rgba(35, 185, 173, 0.45);
    background: rgba(35, 185, 173, 0.10);
    color: var(--et24-blue);
    outline: none;
    transform: translateY(-1px);
}

.et24-city-filter__button.is-active {
    border-color: var(--et24-teal-light);
    background: var(--et24-teal-light);
    color: var(--et24-white);
}

.et24-city-card[hidden] {
    display: none !important;
}

@media (max-width: 575.98px) {
    .et24-city-filter {
        gap: 0.4rem;
        padding: 0.65rem;
        border-radius: 16px;
    }

    .et24-city-filter__button {
        min-width: 38px;
        height: 38px;
        padding: 0 0.75rem;
        font-size: 0.9rem;
    }
}

/* ==================================================
   16. Kategorie-Blog Praxis-Karten
   ================================================== */

.com-content-category-blog.blog {
    margin: 2.5rem 0 4rem;
}

.com-content-category-blog__items.blog-items {
    display: grid;
    gap: 1rem;
    margin: 0;
}

.com-content-category-blog__item.blog-item,
.com-content-category-blog__item.blog-item .item-content,
.com-content-category-blog__item.blog-item .d-flex {
    display: block;
    margin-bottom: 0;
    padding: 0;
}

.et24-praxis-card {
    border: 1px solid var(--et24-border);
    border-radius: var(--et24-radius-2xl);
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.14), transparent 34%),
        linear-gradient(135deg, var(--et24-white), var(--et24-slate-50));
    box-shadow: var(--et24-shadow-lg);
    overflow: hidden;
    transition:
        transform 0.22s ease,
        box-shadow 0.22s ease,
        border-color 0.22s ease;
}

.et24-praxis-card:hover {
    transform: translateY(-3px);
    border-color: rgba(35, 185, 173, 0.42);
    box-shadow: var(--et24-shadow-xl);
}

.et24-praxis-card.is-premium {
    border-color: rgba(35, 185, 173, 0.38);
    background:
        radial-gradient(circle at top right, rgba(35, 185, 173, 0.22), transparent 36%),
        linear-gradient(135deg, var(--et24-white), #f5fffd);
}

.et24-praxis-card__main {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 132px;
    padding: 1.35rem 4rem 1.35rem 1.35rem;
    color: inherit;
    text-decoration: none;
}

.et24-praxis-card__main:hover,
.et24-praxis-card__main:focus {
    text-decoration: none;
}

.et24-praxis-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 56px;
    width: 56px;
    height: 56px;
    margin-right: 1rem;
    border-radius: 18px;
    background: rgba(35, 185, 173, 0.12);
    color: var(--et24-teal-light);
    font-size: 1.25rem;
}

.et24-praxis-card.is-premium .et24-praxis-card__icon {
    background: var(--et24-teal-light);
    color: var(--et24-white);
}

.et24-praxis-card__body {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.et24-praxis-card__topline {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
    margin-bottom: 0.35rem;
}

.et24-praxis-card__badge {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    background: var(--et24-teal-light);
    color: var(--et24-white);
    font-size: 0.75rem;
    font-weight: 850;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.et24-praxis-card__city {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    background: rgba(11, 79, 145, 0.08);
    color: var(--et24-blue);
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1;
}

.et24-praxis-card__title {
    color: var(--et24-blue);
    font-size: 1.32rem;
    font-weight: 850;
    line-height: 1.22;
}

.et24-praxis-card__subtitle {
    margin-top: 0.25rem;
    color: var(--et24-slate-700);
    font-size: 0.98rem;
    font-weight: 650;
    line-height: 1.4;
}

.et24-praxis-card__address {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-top: 0.5rem;
    color: var(--et24-slate-500);
    font-size: 0.95rem;
    font-weight: 600;
    line-height: 1.45;
}

.et24-praxis-card__address i {
    color: var(--et24-teal-light);
}

.et24-praxis-card__action {
    margin-top: 0.65rem;
    color: #23a9a0;
    font-size: 0.95rem;
    font-weight: 850;
}

.et24-praxis-card__arrow {
    position: absolute;
    right: 1.35rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--et24-teal-light);
    font-size: 1.55rem;
    font-weight: 900;
    transition: transform 0.22s ease;
}

.et24-praxis-card__main:hover .et24-praxis-card__arrow,
.et24-praxis-card__main:focus .et24-praxis-card__arrow {
    transform: translate(4px, -50%);
}

.et24-praxis-card__quicklinks {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    padding: 0 1.35rem 1.35rem 6.9rem;
}

.et24-praxis-card__quicklink {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 38px;
    padding: 0.55rem 0.85rem;
    border-radius: 999px;
    background: rgba(11, 79, 145, 0.08);
    color: var(--et24-blue);
    font-size: 0.9rem;
    font-weight: 750;
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease;
}

.et24-praxis-card__quicklink:hover,
.et24-praxis-card__quicklink:focus {
    background: var(--et24-blue);
    color: var(--et24-white);
    text-decoration: none;
}

/* Pagination */
.com-content-category-blog__navigation {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 2rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--et24-border);
}

.com-content-category-blog__counter.counter {
    margin: 0;
    padding: 0 !important;
    color: var(--et24-slate-500);
    font-size: 0.95rem;
    font-weight: 650;
}

.com-content-category-blog__pagination .pagination {
    gap: 0.35rem;
    margin: 0 !important;
}

.com-content-category-blog__pagination .page-link {
    min-width: 40px;
    height: 40px;
    border: 1px solid var(--et24-border-strong);
    border-radius: 12px !important;
    color: var(--et24-blue);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 750;
}

.com-content-category-blog__pagination .page-item.active .page-link {
    border-color: var(--et24-teal-light);
    background: var(--et24-teal-light);
    color: var(--et24-white);
}

.com-content-category-blog__pagination .page-item.disabled .page-link {
    opacity: 0.45;
}

@media (max-width: 575.98px) {
    .com-content-category-blog.blog {
        margin: 2rem 0 3rem;
    }

    .et24-praxis-card__main {
        align-items: flex-start;
        min-height: 112px;
        padding: 1.15rem 3.2rem 1.15rem 1.15rem;
    }

    .et24-praxis-card__icon {
        flex-basis: 46px;
        width: 46px;
        height: 46px;
        margin-right: 0.85rem;
        border-radius: 15px;
        font-size: 1.05rem;
    }

    .et24-praxis-card__title {
        font-size: 1.12rem;
    }

    .et24-praxis-card__address {
        align-items: flex-start;
        font-size: 0.9rem;
    }

    .et24-praxis-card__quicklinks {
        padding: 0 1.15rem 1.15rem;
    }

    .et24-praxis-card__quicklink {
        flex: 1 1 auto;
        justify-content: center;
    }

    .com-content-category-blog__navigation {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .com-content-category-blog__pagination .pagination {
        justify-content: center;
    }

    .com-content-category-blog__counter.counter {
        text-align: center;
    }
}

/* ==================================================
   17. OJ Conditional Astroid Output
   ================================================== */

.ojcao-cta-button {
    display: flex;
    width: 100%;
    justify-content: center;
    align-items: center;
    text-align: center;
}

/* ==================================================
   18. Cards Frontpage
   ================================================== */

#g-651742b1eb5bf034079658 .row {
  align-items: stretch;
}

#g-651742b1eb5bf034079658 .as-grid {
  display: flex;
}

#g-651742b1eb5bf034079658 .card {
  width: 100%;
  height: 100%;
  min-height: 190px;
  display: flex;
  flex-direction: column;
}

#g-651742b1eb5bf034079658 .card-body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
}

#g-651742b1eb5bf034079658 .astroid-heading {
  margin-bottom: 0.75rem;
}

#g-651742b1eb5bf034079658 .astroid-text {
  flex: 1 1 auto;
}

/* ==================================================
   19. Buttons Staedte Frontpage
   ================================================== */

/* Stadt-Buttons: 3 pro Reihe, alle gleich groß */
.ergo24-city-buttons .as-gutter-lg {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 1rem !important;
  align-items: stretch !important;
}

.ergo24-city-buttons .as-gutter-lg > a.btn {
  display: flex !important;
  width: 100% !important;
  min-height: 64px !important;
  margin: 0 !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  white-space: normal !important;
  line-height: 1.25 !important;
  box-sizing: border-box !important;
}

/* Tablet */
@media (max-width: 991.98px) {
  .ergo24-city-buttons .as-gutter-lg {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* Smartphone */
@media (max-width: 575.98px) {
  .ergo24-city-buttons .as-gutter-lg {
    grid-template-columns: 1fr !important;
  }
}