/* Grundlayout-Formatierung */

/* Layout-Container Allgmein */

.Layout__oneColumn, .Layout__twoColumn, .Layout__twoColumnReverse, .Layout__narrow, .Layout__twoColumn2 {
    max-width: 90.8rem;
}

.Layout__twoColumn .Layout__layout1 {
    width: 72%;
}

.Layout__twoColumn .Layout__layout2 {
    width: 28%;
}

/* Layout-Container Startseite */

main[data-id="home"].Layout__twoColumn .Layout__layout1 {
    width: 100%;
}

main[data-id="home"].Layout__twoColumn .Layout__layout2 {
    display: none;
}

/* Button-Formatierung Sidebar */

.outline-button {
    display: inline-block;
    padding: 10px 20px;
    font-size: 16px;
    color: #30383A;
    border: 2px solid #30383A;
    border-radius: 5px;
    background-color: transparent;
    text-decoration: none;
    transition: background-color 0.3s, color 0.3s;
}

.outline-button:hover {
    background-color: #30383A;
    color: #fff;
}

/* Header-Formatierung */

/* Header */

.Header__header {
    height: 300px;
}

/* Breite Überschrift-Container */

.Header__brandFlexible .Header__brandName {
    max-width: 30rem;
}

/* Header-Layout und Tabs */

/* Hauptheader-Reihe und Tabs-Liste */

.Header__headerRow, .Header__tabsList {
    max-width: 90.8rem;
}

/* Haupttab-Styling */

.Header__tabsTab {
    text-align: center;
    cursor: pointer;
    font-size: 0.75em;
    font-weight: 600;
    line-height: 2.4rem;
    border-bottom: 3px solid transparent;
    padding: 0;
    transition: border 0.15s ease, color 0.15s ease;
}

/* Link-Styling innerhalb der Tabs */

.Header__tabsLink {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    padding: 0.8rem 3.2rem 0.6rem;
    color: inherit;
    text-decoration: none;
}

/* Aktiver Tab-Stil */

.Header__tabsTab.Header__tabsTabActive, .Header__tabsTab.Header__tabsTabActive .Header__tabsLink {
    background-color: #2F373B;
    color: #FFD500;
}

/* Hover- und Fokus-Effekt für Tabs */

.Header__tabsTab:hover .Header__tabsLink, .Header__tabsTab:focus .Header__tabsLink, .Header__tabsTab:active .Header__tabsLink {
    color: #FFF;
    border-bottom-color: #FFD500;
}

/* Anpassung für kompakte Tabs auf kleinen Bildschirmen */

.Header__tabsCompactTillSmall .Header__tabsTab {
    padding-right: 3.0rem;
    padding-left: 3.0rem;
    font-size: 16px;
}

/* Abstände und Positionierung der Tabs-Navigation */

/* Logo im Header */

.Header__brandLogoImg {
    max-height: 4rem;
    max-width: 15rem;
    display: block !important;
    margin-left: 0 !important;
    margin-right: auto !important;
}

/* Markenname im Header */

.Header__brandName {
    margin: 10px 0 0 0 !important;
    color: #FFF !important;
    font-family: "The Sans", Arial, sans-serif;
    font-weight: 500;
    font-size: 36px !important;
}

/* Anmelde-Button */

[data-id="signin_link"] {
    margin-top: 20px;
    font-size: 18px;
    color: white;
    display: inline-flex;
    align-items: center;
    line-height: 28px;
    padding: 4px 14px;
    background-color: transparent;
    border: 2px solid white;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.3s ease;
}

[data-id="signin_link"]::before {
    content: "";
    display: inline-block;
    width: 28px;
    height: 28px;
    margin-right: 8px;
    background-image: url("https://edupage-support.raabe.de/galleryDocuments/edbsn049b22a03be9081c06ea39f1bb72a6ed4cc5f7a962b2d941ad28b78013e3fbfa66d422642573bb0290be99112d4c98cf594da1e1f7c4932da6e90dc5916f20b3?inline=true");
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    transition: background-image 0.3s ease;
}

/* Registrierung-Button */

[data-id="signUpLink"] {
    margin-top: 20px;
    font-size: 18px;
    color: white;
    display: inline-flex;
    align-items: center;
    line-height: 28px;
    padding: 4px 14px;
    background-color: transparent;
    border: 2px solid white;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.3s ease;
}

[data-id="signUpLink"]::before {
    content: "";
    display: inline-block;
    width: 28px;
    height: 28px;
    margin-right: 8px;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("https://edupage-support.raabe.de/galleryDocuments/edbsncb8b941cbf10b2f1e23a9759aa2ba0b217def6b01c215067cbd528c0329f967c37dd13cce9e8929e793fa6d6d133727a1b399aa3931fb16fb547080048cb9763?inline=true");
    vertical-align: middle;
    transition: background-image 0.3s ease;
}

.Header__headerRow > *:last-child {
    margin-top: 5px;
}

[data-id="signin_link"]:hover {
    background-color: white;
    color: #30383a;
}

[data-id="signin_link"]:hover::before {
    background-image: url("https://edupage-support.raabe.de/galleryDocuments/edbsn049b22a03be9081c06ea39f1bb72a6edaf71aef017b097d31034d24f6086c753f8aa2ff91560428a94531bc85234bb51c218ff7a98358ad68ee36da56830930e?inline=true");
}

/* Styling der Suchleiste */

/* Suchleiste */

.searchPanelSearchBox {
    position: relative;
    width: 100%;
    height: 3.2rem;
    margin-top: 30px;
    background-color: rgba(255, 255, 255, 0.6);
    transition: background-color 0.3s ease-in-out;
    border-radius: 0.2rem;
    border: 1px solid #d2d3d2;
}

/* Aktivierter Zustand der Suchleiste */

.searchPanelActive .searchPanelSearchBox {
    background-color: #ffffff;
    border: 1px solid #FFD500;
}

.Input__searchPanelInput {
    border: 1px solid #ccc;
    padding: 10px;
    border-radius: 5px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    color: #30383a;
}

.Input__searchPanelInput::placeholder {
    color: #30383a;
    opacity: 1;
}

.Search__searchPanelIcon {
    top: 0;
    right: 0.8rem;
    z-index: 2;
    line-height: 3.2rem;
}

.Search__searchPanelIcon svg {
    fill: #30383a;
}

/* Styling für Radio-Button in der Suchleiste */

.Radio__radioButton [type=radio]:checked + .Radio__radioLabel {
    background-color: #FFD500;
    color: #30383a;
    box-shadow: 0 2px #e0b400;
    border-left-color: #e0b400;
}

.Radio__radio [type=radio]:checked + .Radio__radioLabel .Radio__radioFaux:after {
    background-color: #FFD500;
}

/* Styling des Accordions */

.accordion summary {
    cursor: pointer;
    border: 1px solid #D6D6D6;
    border-radius: 6px;
    padding: 20px;
    font-size: 14px;
    margin-bottom: 20px;
    list-style: none;
}

.accordion summary:hover {
    background-color: #FFD500;
    border: 1px solid #FFD500;
}

.accordion-content {
    padding: 10px;
}

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

.accordion summary:before {
    content: "▶";
    color: #30383a;
    display: inline-block;
    margin-right: 10px;
}

.accordion details[open] summary:before {
    content: "▼";
    color: #30383a;
}

.accordion details[open] summary {
    background-color: #FFD500;
    border: 1px solid #FFD500;
}

/* Icon-Styling */

#plusIcon {
    color: #FFF;
}

/* Anpassung Icon "To the Top" */

.AppContainer__backToTop {
    background-color: #FFD500 !important;
    border-radius: 50%;
    align-items: center;
    justify-content: center;
}

.AppContainer__backToTop svg {
    fill: #2F373B !important;
}

/* Anpassung Seitenelemente */

/* Styling Tags */

.Pill__pill, .Pill__tag {
    border: 1px solid #FFD500;
    background-color: #FFD500;
    border-radius: .2rem;
    transition: all .15s ease;
    padding: 0 .5rem 0.2rem;
}

/* Styling Info-Boxen */

.KB_New_Editor_Highlights {
    background-color: #FFF !important;
    border: 2px solid #FFD500;
    border-radius: 10px;
    width: 100%;
    box-sizing: border-box;
}

/* Button-Größe anpassen */

.Icon__icon {
    margin-left: 5px;
}

/* Erklärungstext Abbonieren-Button ausblenden */

.KBArticleRightContainer__followDescription {
    display: none;
}

/* Abstand nach unten vergrößern */

.Button__button:last-child {
    margin-bottom: 15px;
}

/* Text-Formatierung */

/* Schriftart-Definitionen */

@font-face {
    font-family: "The Sans";
    src: local("The Sans Light"),
         url("https://www.raabe.de/raabe-fonts/woff/RAABETheSans-2_ExtraLight.woff2") format("woff2");
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: "The Sans";
    src: local("The Sans Plain"),
         url("https://www.raabe.de/raabe-fonts/woff/RAABETheSans-5_Plain.woff2") format("woff2");
    font-weight: 500;
    font-style: normal;
}

/* Anwendung der Schriftarten für Fließtext und Überschriften */

body, p {
    font-family: "The Sans", Arial, sans-serif;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.02em;
}

h1, h2, h3, h4, h5, h6 {
    font-family: "The Sans", Arial, sans-serif;
    font-weight: 500;
}

.portalContainer,.html {
    font-family: "The Sans", Arial, sans-serif;
    line-height: 1.6;
    color: #000;
}

.subtitle {
    font-weight: 300 !important;
}

/* Anpassung Überschrift Seite Übersicht */

.portalContainer .Headline {
    font-weight: 500;
    font-size: 30px;
    color: #2F373B;
    background-color: #FFD500;
    padding: 5px;
    display: inline-block;
    margin-top: -50px;
    margin-bottom: -50px;
}

/* Überschrift H2 in Artikelbeschreibung */

.KBArticleDetailLeftContainer__description h2 {
    color: #30383a;
    padding: 7px;
    margin: 0px 0 0px 0;
    font-size: 16px;
    display: inline-block;
}

h3 {
    color: #30383a;
    padding: 0px;
    margin: 25px 0  20px 0px;
    font-size: 20px !important;
    display: inline-block;
}

/* Neue Formatierung für H6 */

h6 {
    color: #30383a;
    font-size: 12px;
}

/* Bestehende Definition für portal Elemente überschreiben */
.portal p {
    margin: 0 0 0.2rem;
    word-wrap: break-word;
}

/* Spezifische Regel für bestimmte H3-Klassen */
.CategoriesContainer__solutionListHeading, .ArticleWidgets__menuTitle, .CommunityCategoriesContainer__forumsTitle, .CommunityCategoryRightContainer__title {
    color: inherit;
    background-color: transparent;
    padding: 0;
    margin: 0;
    display: block;
    position: static;
    font-size: inherit;
}

/* Ausgewählter Text */

.CommonStyle__zt1LinkActive, .Menu__menuTextBlockActive {
    font-weight: bold;
    color: #30383a;
    text-decoration: underline #ffD500;
    padding: 7px;
    display: inline-block;
    position: relative;
}

/* Breadcrump Pfad Formatieren */

.BreadCrumbs__breadcrumbs {
    background-color: #FFD500;
    display: inline-block;
    margin-bottom: 10px;
    list-style: none;
    padding: 7px;
}

/* Listen in AK-Klasse */

.ak-ol li {
    margin-bottom: 0.5em;
    padding-bottom: 0;
}

.ak-ol li p {
    margin-bottom: 0.75em;
}

h2 + h3 {
    display: block;
    clear: both;
}

/* Links im Artikel: Statisch */

.Article__articleContent a {
    color: #30383a;
    text-decoration: none;
    border-bottom: 2px solid #FFD500;
    transition: background-color 0.3s ease, padding 0.3s ease;
}

/* Links im Aritikel: Hover */

.Article__articleContent a:hover {
    color: #30383a;
    background-color: #FFD500;
    padding: 2px 4px;
}

/* Links im Menü sollen nicht ausgezeichnet werden */

.Menu__menuItem a {
    color: inherit;
    text-decoration: none;
    border-bottom: none;
}

/* Tabellen */

/* Stil für die gesamte Tabelle */

table {
    width: 100%;
    table-layout: fixed;
    border-collapse: collapse;
    border: 1px solid #FFD500 !important;
}

/* Stil für Zellen */

td, th {
    border: 1px solid #FFD500 !important;
    padding: 8px;
    text-align: left;
    vertical-align: middle;
    min-width: 100px;
    max-width: 300px;
    word-wrap: break-word;
}

/* Stil für den Kopfbereich der Tabelle, falls verwendet */

th {
    text-align: center;
    font-weight: bold;
}

/* Sicherstellen, dass Bilder innerhalb der Zellen bleiben */

img {
    max-width: 100%;
    height: auto;
}

/* Tabellen innerhalb von Widgets ohne Rahmen darstellen */
.CustomWidgets__customDescription table {
    border: none !important;
    border-collapse: collapse !important;
}

.CustomWidgets__customDescription table th, .CustomWidgets__customDescription table td {
    border: none !important;
    vertical-align: top;
}

/* Medien-Formatierung */

/* Formatierung für Bilder in Artikeldetails */

/* Formatierung für Logo-Bilder im Header */

.Header__brandLogo img {
    border: 0;
    box-shadow: none;
    margin: 0;
}

/* Bilder im Artikel immer im Center */

.articleDetail img {
    border: 1px solid rgba(0, 0, 0, 0.05);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    box-sizing: border-box;
    margin: 10px 0;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

/* Formatierung für iFrames */

iframe {
    width: 100%;
    height: 550px;
    aspect-ratio: 16 / 9;
    border-top-style: none !important;
    border-left: 1px solid rgba(0, 0, 0, 0.05);
    border-right: 1px solid rgba(0, 0, 0, 0.05);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    box-sizing: border-box;
    margin: 10px 0;
    display: block;
}

/* Icons in Infoboxen nicht formatieren */

.KB_New_Editor_Highlights img {
    box-shadow: none;
    border: none;
    outline: none;
    margin: 0;
    padding: 0;
}

/* Styling für geordnete Listen (Kreise) */

ol {
    counter-reset: item;
    list-style-type: none;
    padding-left: 10px;
}

ol > li {
    counter-increment: item;
    margin-bottom: 10px;
    position: relative;
    padding-left: 40px;
}

ol > li::before {
    content: counter(item);
    background-color: #FFD500;
    color: #30383a;
    border-radius: 50%;
    display: inline-block;
    width: 24px;
    height: 24px;
    text-align: center;
    line-height: 24px;
    position: absolute;
    left: -0.5px;
    top: 0;
    transform: translateY(0);
    z-index: 1;
}

/* Unterpunkte mit Kreisen ohne gelben Hintergrund */

ol ol {
    counter-reset: subitem;
    list-style-type: none;
    padding-left: 40px;
}

ol ol > li {
    counter-increment: subitem;
    position: relative;
    padding-left: 30px !important;
}

ol ol > li::before {
    content: "●";
    color: #30383a !important;
    background-color: #FFF;
    font-size: 10px !important;
    display: inline-block !important;
    width: 24px !important;
    height: 24px !important;
    text-align: center !important;
    line-height: 24px !important;
    position: absolute !important;
    left: -4px !important;
    top: 0 !important;
    transform: translateY(0) !important;
    z-index: 1 !important;
}

/* Entfernt die Standard-Markierungen */
::marker {
    content: "";
}

/* Spezifische Anpassungen für Safari */
@supports (-webkit-touch-callout: none) {
    ol ol > li::before {
        content: "●";
    }
}

/* Listen in der Klasse KB_New_Editor_Highlights mit schwarzen Punkten */
.KB_New_Editor_Highlights ol, .KB_New_Editor_Highlights ul {
    list-style: none;
    padding-left: 20px;
}

.KB_New_Editor_Highlights ol > li::before, .KB_New_Editor_Highlights ul > li::before {
    content: "●";
    color: #FFD300;
    background-color: #FFF;
    font-size: 16px;
    display: inline-block;
    width: 24px;
    height: 24px;
    text-align: center;
    line-height: 24px;
    position: absolute;
    left: -30px;
    top: 0;
    transform: translateY(0);
    z-index: 1;
}

/* Als Fallback in Safari: Marker explizit verstecken */
.Article__articleContent li::marker, .KB_New_Editor_Highlights li::marker {
    content: none !important;
    color: transparent !important;
    display: none !important;
}

/* Grundlegendes Footer-Layout */
.footer {
    width: 100%;
    background-color: #2F373B;
    color: #FFF;
    padding: 20px;
    box-sizing: border-box;
    border-top: 1px solid #d2d3d2;
}

/* Maximalbreite und Anordnung des Footer-Inhalts */
.footer__content {
    max-width: 90.8rem;
    display: flex;
    justify-content: space-between;
    width: 100%;
    gap: 20px;
    margin: auto;
}

/* Footer-Spalten */
.footer__column {
    flex: 1;
    padding: 10px;
    text-align: center;
}

/* Vergrößertes Logo in der ersten Spalte */
.footer__logo {
    max-height: 120px;
    width: auto;
    display: block;
    margin: 0 auto;
}

/* App-Links unter dem Hauptlogo */
.footer__app-links {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 10px;
}

/* Überschriften im Footer */

.footer__column h3 {
    font-size: 18px;
    margin-bottom: 10px;
    margin-left: 10px;
    margin-top: 0;
    color: #FFF;
    text-align: left;
}

/* Kontaktinformationen-Tabelle */

.footer__contact-table {
    width: 100%;
    font-size: 16px;
    color: #FFF;
    border: 2px solid #2F373B !important;
}

.footer__contact-table th, .footer__contact-table td {
    border: 1px solid #2F373B !important;
}

.footer__contact-table td {
    padding: 4px 8px;
    vertical-align: top;
    text-align: left;
}

/* Menü-Spalte */

.footer__menu-column {
    flex: 0.5;
    padding: 0 15px 0 0px;
}

/* Links in der Menü-Spalte */
.footer__menu a {
    display: block;
    color: #ffffff;
    padding: 6px 10px;
    margin: 10px 0;
    text-decoration: none;
    font-size: 16px;
    text-align: center;
    width: calc(100% - 30px);
    box-sizing: border-box;
    border: 2px solid #ffffff;
    border-radius: 5px;
}

.footer__menu a:hover, .footer__menu a:active {
    background-color: #ffffff;
    color: #2f373b;
}

/* Mobile Ansicht für Footer */
@media (max-width: 768px) {
    .footer__content {
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }

    .footer__column {
        text-align: center;
        padding: 10px 0;
    }

    .footer__menu a {
        width: auto;
    }
}

/* Anpassung Community */

/* Ausgabe Datum Ankündigung über h5 */
.TopicDetailLeftContainer__postContent.TopicCommon__postContent {
    position: relative;
}

.TopicDetailLeftContainer__topicDetail h5 {
    background-color: #FFD500;
    color: #30383a;
    text-align: right;
    position: absolute;
    bottom: calc(100% - 2px);
    right: 0;
    z-index: 10;
    padding: 2px 5px;
    font-size: 1em;
    font-weight: normal;
}

.TopicDetailLeftContainer__topicDetail h5 .bold-text {
    font-weight: bold;
}

/* Anpassung Startseite */

/* Grid auf volle Seitenbreite ausdehnen */

/* Hintergrund für den gesamten Bereich */
.Start-Usergrid-container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(2, auto);
    gap: 2rem;
    width: 100%;
    max-width: 100vw;
    padding: 2rem;
    margin: 0 auto;
    background-color: var(--color-white);
    box-shadow: 0 2px 2px rgba(32, 35, 32, 0.15);
    border-radius: 10px;
    border: 1px solid #d2d3d2;
}

/* Einzelne Boxen */
.Start-Usergrid-item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    padding: 1.5rem;
    background-color: #fff;
    border: 1px solid #d2d3d2;
    border-radius: 10px;
    box-shadow: 0 2px 4px rgba(32, 35, 32, 0.15);
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: background 0.3s ease-in-out;
}

/* Hintergrund-Hover-Effekt (füllt sich von unten nach oben) */

.Start-Usergrid-item::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: -100%;
    width: 100%;
    height: 100%;
    background-color: #FFD500;
    z-index: 0;
    transition: bottom 0.3s ease-in-out;
}

/* Hover: Hintergrund füllt sich von unten nach oben */

.Start-Usergrid-item:hover::before {
    bottom: 0;
}

/* Container für Icon und Überschrift */

/* Icon über der Überschrift */

.Start-Usergrid-icon {
    width: 60px;
    height: 60px;
    display: block;
    margin-bottom: 0.5rem;
}

/* Überschrift in einer eigenen Grid-Zeile */

.Start-Usergrid-header {
    justify-content: space-between;
    margin-bottom: 0.5rem;
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    position: relative;
    z-index: 1;
    grid-column: span 3;
    padding: 0;
    text-align: left;
    margin: 0;
}

/* H2 optimieren, um Abstand oben und unten zu entfernen */

.Start-Usergrid-title {
    font-size: 1.5rem;
    font-weight: bold;
    color: #000;
    margin: 0;
    padding: 0;
}

/* Grauer Trennstrich unter der Überschrift */

.Start-Usergrid-divider {
    grid-column: span 3;
    height: 1px;
    background-color: #d2d3d2;
    margin-bottom: 0rem;
}

/* Überschriften bleiben innerhalb der Box */

.Start-Usergrid-item h3 {
    font-size: 1rem;
    font-weight: bold;
    color: #000;
    margin: 0;
}

/* Beschreibungstext */

.Start-Usergrid-item p {
    color: #555;
    font-size: 0.9rem;
    position: relative;
    z-index: 1;
    margin-bottom: 0.5rem;
}

/* Call-to-Action ("Jetzt starten") rechtsbündig */

.Start-Usergrid-cta {
    font-size: 14px;
    font-weight: bold;
    text-align: right;
    width: 100%;
    display: flex;
    justify-content: flex-end;
    margin-top: auto;
    position: relative;
    z-index: 1;
}

/* Rundung Hauptcontainer */

.Feed__feed {
    background-color: #fff;
    border: 1px solid #d2d3d2;
    border-radius: 10px;
    box-shadow: 0 2px 4px rgba(32, 35, 32, 0.15);
    box-sizing: border-box;
    padding: 10px;
}

/* Ersetzt den Text "Ankündigungen" durch "Aktuelle Updates für EduPage" */

/* Versteckt den ursprünglichen Text "Ankündigungen" */

h2[data-id="announcement"] {
    visibility: hidden;
    position: relative;
}

/* Positioniert den neuen Text exakt an der Stelle des Originals */

h2[data-id="announcement"]::after {
    content: "Aktuelle Updates für EduPage";
    visibility: visible;
    white-space: nowrap;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    text-align: left;
    display: block;
}

/* Grid Startseite Funktionsbereiche */

/* Weißer, gerundeter Hintergrund für den gesamten Bereich */

.box-container {
    background-color: var(--color-white);
    box-shadow: 0 2px 2px rgba(32, 35, 32, 0.15);
    border-radius: 10px;
    padding: 2rem;
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: space-between;
}

/* Einzelne Boxen mit Hover-Effekt */

/* Hintergrund-Hover-Effekt */

.box::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 0;
    background-color: #FFD500;
    z-index: 0;
    transition: height 0.3s ease-in-out;
}

/* Hover: Gelber Hintergrund füllt sich von unten nach oben */

.box:hover::before {
    height: 100%;
}

/* Überschriften in der Box */

.box h3 {
    font-size: 18px;
    margin: 0 0 5px 0;
    position: relative;
    z-index: 1;
    font-weight: bold;
    color: #000;
}

/* Beschreibungstext */

.box p {
    font-size: 14px;
    margin: 0;
    position: relative;
    z-index: 1;
    color: #555;
}

/* Call-to-Action (unten rechts) */

/* Button Anpassen */

.Button__hoverdanger:hover {
    background-color: #FFD500;
    box-shadow: 2px #30383a;
}

.Button__primary:hover {
    background-color: #3A4246;
}

.Layout__twoColumn {
    display: flex;
    flex-direction: row-reverse;
}

/* Info-Text Übersicht Wissensdatenbank */

.container {
    display: flex;
    justify-content: space-between;
    gap: 20px;
}

.column {
    flex: 1;
    min-width: 300px;
    padding: 15px;
    border: 1px solid #ddd;
    background-color: #f9f9f9;
    border-radius: 5px;
}

/* @media (max-width: 768px) */

@media (max-width: 768px) {
    .container {
        flex-direction: column;
    }
}

/* Titel und Trennlinie innerhalb des weißen Bereichs */

.box-title {
    color: #333;
    margin: 0;
    padding-bottom: 5px;
    text-align: left;
}

/* Grauer Strich unter der Überschrift */

.separator {
    width: 100%;
    height: 1px;
    background-color: #ccc;
}

/* Bilder in Boxen Startseite */

.box-container-inner {
    width: 100%;
}

/* Akademie Grid */

.box-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 0.8rem;
}

.box-icon {
    height: 45px;
    width: auto;
    object-fit: contain;
    margin-left: 1rem;
}

.box-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: space-between;
}

.box.box-webinar {
    margin-top: 1.8rem;
}

.box {
    flex: 1;
    min-width: 220px;
    padding: 15px;
    border: 1px solid #ccc;
    text-align: left;
    border-radius: 10px;
    overflow: hidden;
    transition: background 0.3s ease-in-out;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 150px;
    background-color: transparent;
    position: relative;
    padding-bottom: 3rem;
}

.cta-text {
    align-self: flex-end;
    margin-top: auto;
    font-size: 14px;
    font-weight: bold;
    position: absolute;
    z-index: 2;
    bottom: 12px;
    right: 15px;
}

/* @media (max-width: 768px) */

@media (max-width: 768px) {
    .box-grid {
        flex-direction: column;
    }

    .box {
        width: 100%;
        flex: unset;
        height: auto;
    }

    .cta-text {
        position: static;
        margin-top: 1rem;
        align-self: flex-start;
    }

    .box-header {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }

    .box-title {
        flex: 1;
    }

    .box-icon {
        margin-top: 0.5rem;
        height: 35px;
    }
}

/* Anpassung Ticketformular */

/* Austausch Feldbenennung Layout */

label[for="layoutId"]::after {
    content: "Ihr Thema*" !important;
    visibility: visible !important;
    position: absolute;
    color: #2F373B;
    font-size: 1rem;
    top: -7px;
    left: 0;
    white-space: nowrap;
}

/* Weißraum über Kontakt */

.TicketFmLtCnter__sectionName.Ihre_Kontaktdaten_ {
    margin-top: 40px !important;
    position: relative;
}

label[for="layoutId"] {
    font-size: 0 !important;
    position: relative;
}

/* Austausch Feldname Name */

label[for="contactId"]::after {
    content: "Ihr Name*" !important;
    visibility: visible !important;
    position: absolute;
    color: #2F373B;
    font-size: 1rem;
    top: -7px;
    left: 0;
    white-space: nowrap;
}

label[for="contactId"] {
    font-size: 0 !important;
    position: relative;
}

/* Austausch Feldname E-Mail */

label[for="email"]::after {
    content: "Ihre E-Mail*" !important;
    visibility: visible !important;
    position: absolute;
    color: #2F373B;
    font-size: 1rem;
    top: -7px;
    left: 0;
    white-space: nowrap;
}

label[for="email"] {
    font-size: 0 !important;
    position: relative;
}

/* Austausch Feldname Kategorie */

label[for="category"]::after {
    content: "Funktionsbereich EduPage*" !important;
    visibility: visible !important;
    position: absolute;
    color: #2F373B;
    font-size: 1rem;
    top: -7px;
    left: 0;
    white-space: nowrap;
}

/* Austausch Feldname Nutzungsart */

label[for="cf_status_lizenz"] {
    font-size: 0 !important;
    display: block;
    margin-bottom: 8px;
    position: relative;
}

label[for="cf_status_lizenz"]::after {
    content: "Art der Nutzung* (Setzen Sie EduPage produktiv ein oder testen Sie die Software aktuell?)";
    color: #2F373B;
    font-size: 1rem;
    display: block;
    white-space: normal;
    line-height: 1.4;
    margin-left: 0;
    position: relative;
}

label[for="category"] {
    font-size: 0 !important;
    position: relative;
}

/* Austausch Feldname Kategorie */

label[for="cf_edu_page_url"]::after {
    content: "EduPage URL der Schule*" !important;
    visibility: visible !important;
    position: absolute;
    color: #2F373B;
    font-size: 1rem;
    top: -7px;
    left: 0;
    white-space: nowrap;
}

label[for="cf_edu_page_url"] {
    font-size: 0 !important;
    position: relative;
}

/* Weißraum über Anliegen schaffen */

.TicketFmLtCnter__sectionName.Ihr_Anliegen_ {
    margin-top: 40px !important;
    position: relative;
}

/* Austausch Feldname Betreff */

label[for="subject"]::after {
    content: "Zusammenfassung*" !important;
    visibility: visible !important;
    position: absolute;
    color: #2F373B;
    font-size: 1rem;
    top: -7px;
    left: 0;
    white-space: nowrap;
}

label[for="subject"] {
    font-size: 0 !important;
    position: relative;
}

/* Austausch Feldname Beschreibung */

label[for="description"]::after {
    content: "Beschreibung Ihrer Frage*" !important;
    visibility: visible !important;
    position: absolute;
    color: #2F373B;
    font-size: 1rem;
    top: -7px;
    left: 0;
    white-space: nowrap;
}

label[for="description"] {
    font-size: 0 !important;
    position: relative;
}

label[for="cf_thema"]::after {
    content: "Thema*" !important;
    visibility: visible !important;
    position: absolute;
    color: #2F373B;
    font-size: 1rem;
    top: -7px;
    left: 0;
    white-space: nowrap;
}

label[for="cf_thema"] {
    font-size: 0 !important;
    position: relative;
}

/* Austausch Feldname Name der Schule */

label[for="cf_name_der_schule"]::after {
    content: "Name der Schule*" !important;
    visibility: visible !important;
    position: absolute;
    color: #2F373B;
    font-size: 1rem;
    top: -7px;
    left: 0;
    white-space: nowrap;
}

label[for="cf_name_der_schule"] {
    font-size: 0 !important;
    position: relative;
}

/* Anpassung Datei anhängen Button */

/* Stil für das Label */

.FileUpload__labelAllow {
    display: inline-block;
    background-color: #2F373B;
    color: white;
    padding: 10px 20px;
    border-radius: 5px;
    cursor: pointer;
    font-size: 16px;
    text-align: center;
    transition: background-color 0.3s ease;
    white-space: nowrap;
}

/* Hover-Effekt für das Label */

.FileUpload__labelAllow:hover {
    background-color: #FFD500;
    color: #2F373B;
}

/* Austasuch Datei-Upload-Button */

/* Verstecke das tatsächliche input[type="file"] */

.FileUpload__labelAllow input[type="file"] {
    display: none;
}

#cf_ich_akzeptiere + label::after {
    content: " Ich habe die unten verlinkten Datenschutzbestimmungen zur Kenntnis genommen.";
    display: inline;
    color: #2F373B;
    font-size: 1rem;
}

label[for="cf_ich_akzeptiere"] {
    font-size: 0 !important;
    position: relative;
}

/* Weißraum über Datenschutz und Anliegen schaffen */

.TicketFmLtCnter__sectionName.Datenschutz_und_Anhänge_ {
    margin-top: 40px !important;
    position: relative;
}

/* Austausch Feldname Sicherheitsfrage */

label[for="captchaText"]::after {
    content: "Bitte geben Sie die Zeichenfolge in das Textfeld ein.*" !important;
    visibility: visible !important;
    position: absolute;
    color: #2F373B;
    font-size: 1rem;
    top: -7px;
    left: 0;
    white-space: nowrap;
}

label[for="captchaText"] {
    font-size: 0 !important;
    position: relative;
}

/* Einfügen Trenner */

.TicketFmLtCnter__sectionName.Datenschutz_und_Anhänge_::before, .TicketFmLtCnter__sectionName.Ihre_Kontaktdaten_::before, .TicketFmLtCnter__sectionName.Ihr_Anliegen_::before {
    content: "";
    display: block;
    width: 100%;
    height: 2px;
    background-color: #FFD500;
    position: absolute;
    top: -10px;
    left: 0;
}

/* Korrigiert die Position der Labels für Firefox */

label[for="layoutId"]::after, label[for="contactId"]::after, label[for="cf_user_1"]::after, label[for="email"]::after, label[for="category"]::after, label[for="cf_edu_page_url"]::after, label[for="subject"]::after, label[for="description"]::after, label[for="cf_thema"]::after, label[for="cf_name_der_schule"]::after, label[for="captchaText"]::after {
    top: -12px !important;
}

/* Stellt sicher, dass die Eingabefelder in Firefox nicht nach unten rutschen */

input, select, textarea {
    padding-top: 8px !important;
    padding-bottom: 8px !important;
    line-height: 1.5 !important;
}

/* Stellt sicher, dass das Dropdown korrekt unter dem Eingabefeld bleibt */

.DropDown__listview {
    overflow: visible !important;
    max-height: none !important;
    z-index: 9999 !important;
    position: absolute !important;
    top: 100% !important;
}

/* Sorgt dafür, dass das Suchfeld oben im Dropdown sichtbar bleibt */

.DropDown__searchInputBtm {
    position: relative !important;
    z-index: 10000 !important;
    background-color: white !important;
    padding-top: 2px !important;
}

/* Anpassung Datenschutzhinweis Formulare */

.TicketFmLtCnter__formFooter::before {
    content: "Informationen zur Datenverarbeitung finden Sie in unseren Datenschutzhinweisen unter https://www.edupage-raabe.de/datenschutz oder unter dem Link unten auf dieser Seite.";
    display: block;
    margin-bottom: 16px;
    margin-top: -28px;
    font-size: 1rem;
    color: #2F373B;
    line-height: 1.4;
}

/* Anpassung Formular Registrierung */

/* Nur im REGISTRIERUNGSFORMULAR – Captcha-Label umbenennen & korrekt darstellen */

/* Originaltext verstecken */

label[for="fullName"] {
    font-size: 0 !important;
    position: relative;
}

/* Neues Label einfügen */

label[for="fullName"]::after {
    content: "Name*" !important;
    visibility: visible !important;
    position: absolute;
    top: -7px;
    left: 0;
    font-size: 1rem;
    color: #2F373B;
    white-space: nowrap;
}

/* Sternchen entfernen */

label[for="fullName"] abbr {
    display: none !important;
}

/* Text ersetzen */

label[for="captchaText"]:not([style*="font-size: 0"])::before {
    content: "Bitte lösen sie die folgende Aufgabe:*" !important;
    display: inline-block;
    font-size: 1rem;
    color: #2F373B;
    white-space: normal;
}

/* Originaltext unterdrücken */

label[for="captchaText"]:not([style*="font-size: 0"]) > abbr, label[for="captchaText"]:not([style*="font-size: 0"])::after {
    display: none !important;
}

label[for="captchaText"]:not([style*="font-size: 0"]) {
    position: static !important;
    color: #2F373B !important;
    line-height: 1.4 !important;
    margin-right: 12px !important;
    max-width: 240px;
    display: inline-block !important;
    vertical-align: top;
    text-align: left !important;
    font-size: 0 !important;
}

/* Einfügen Text unter Überschrift */

.UserSignup__title::after {
    content: "Registrieren Sie sich, um einfacher Tickets zu erstellen und eine Übersicht all Ihrer Tickets abzurufen.";
    display: block;
    margin-top: 8px;
    font-size: 1rem;
    color: #2F373B;
    line-height: 1.4;
    text-align: left;
}

.Button__primary {
    background-color: #2F373B;
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    margin-bottom: 1rem;
}

/* Ausblenden von Elmeenten */

/* Ausblenden der gesamten Social-Media-Liste */

.SocialShare__socialShareList {
    display: none !important;
}

/* Alternativ, um jedes einzelne Social-Media-Element auszublenden */

.SocialShare__socialItem {
    display: none !important;
}

/* Verstecke den ursprünglichen Text */

.Survey__surveyQuestion {
    visibility: hidden;
}

/* Ersetzt den Text mit dem neuen Inhalt */

.Survey__surveyQuestion::before {
    content: "War der Artikel für Sie hilfreich?";
    visibility: visible;
    display: inline;
    position: static;
}

/* Ersetze Aehnliche Artikel durch Verwandte */

.de.articleDetail .WidgetsContainer__fadeInWidgetShow .WidgetsContainer__rightWd .ArticleWidgets__menuTitle[data-id="relatedArticle"] {
    font-size: 0 !important;
}

.de.articleDetail .WidgetsContainer__fadeInWidgetShow .WidgetsContainer__rightWd .ArticleWidgets__menuTitle[data-id="relatedArticle"]::before {
    font-size: 20px;
    content: "Verwandte ";
}

.de.articleDetail .WidgetsContainer__fadeInWidgetShow .WidgetsContainer__rightWd .ArticleWidgets__menuTitle[data-id="relatedArticle"] .modulesname {
    font-size: 20px;
}

/* Anpassung Mobil / Tablet */

/* Sidebar komplett ausblenden */

/* @media (max-width: 768px) */

@media (max-width: 768px) {
    /* Sidebar komplett ausblenden */

    .Layout__twoColumn .Layout__layout2 {
        display: none !important;
    }

    /* Hauptinhalt nimmt die gesamte Breite ein */

    .Layout__twoColumn .Layout__layout1 {
        width: 100% !important;
    }
}

/* Anpassung Grid 2 Startseite */

/* @media (max-width: 768px) */

@media (max-width: 768px) {
    .Start-Usergrid-container {
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

    /* Optional: Passe die Boxen an, wenn die Grid-Items untereinander stehen */

    .Start-Usergrid-item {
        width: 100%;
    }

    /* Optional: Verhindere, dass Bilder zu groß werden */

    .Start-Usergrid-item img {
        width: 100%;
        height: auto;
    }
}

/* Anpassung Menü */

/* Standardansicht für Desktop - Anmelden, Registrieren und Menü sichtbar */

.Header__signInOut {
    display: block;
}

.Header__headerNav {
    margin-top: 130px;
    display: block;
}

.Header__tabs {
    display: block;
}

/* Burger-Menü nur für mobile Geräte (max-width: 768px) */

.Header__burgerMenu {
    display: none;
}

/* Media Query für mobile Geräte (max-width: 768px) - Burger-Menü und ausgeblendetes normales Menü */

/* @media (max-width: 768px) */

@media (max-width: 768px) {
    /* Anmelden und Registrieren Buttons auf mobilen Geräten ausblenden */

    .Header__signInOut {
        display: none;
    }

    /* Navigation auf mobilen Geräten ausblenden */

    .Header__headerNav {
        display: none;
    }

    /* Menü Tabs auf mobilen Geräten ausblenden (Hauptmenü) */

    .Header__tabs {
        display: none;
    }

    /* Burger-Menü auf mobilen Geräten anzeigen */

    .Header__burgerMenu {
        display: block;
    }

    /* Burger-Menü Navigation anzeigen */

    #burgerMenu {
        display: block;
    }
}

/* Media Query für mobile Geräte (max-width: 768px) - Anpassungen für Logo und Header */

/* @media (max-width: 768px) */

@media (max-width: 768px) {
    /* Abstand nach oben für das Brand-Logo */

    .Header__brandLogo {
        margin-top: 20px;
        height: 80%;
    }

    /* Header Höhe anpassen */

    .Header__header {
        height: auto;
        padding-top: 10px;
        padding-bottom: 10px;
    }
}

/* Anpassen Schriftgroessen Header */

/* @media (max-width: 768px) */

@media (max-width: 768px) {
    /* Für den Text in der .Headline */

    .CustomWidgets__customDescription .Headline {
        font-size: 1.2rem !important;
    }

    /* Für den Text in der .Header__brandName */

    .Header__brandName {
        font-size: 1.9rem !important;
    }

    /* Für den Text in .subtitle (Support Center) */

    .Header__brandName .subtitle {
        font-size: 1.9rem !important;
    }
}

/* Media Query für mobile Geräte (max-width: 768px) - Verhindert vertikales Scrollen */

/* @media (max-width: 768px) */

@media (max-width: 768px) {
    /* Setze das Overflow auf "hidden", um das vertikale Scrollen zu verhindern */
}

#portal_tabSolutions > a.Header__tabsLink {
    color: inherit;
    text-decoration: none;
}

/* Wissensdatenbank-Sidebar */

/* Hauptkategorien: nur gelbe Linie, kein Kasten */

.widgetItem.treeView > .Menu__menu > .Menu__menuItem {
    margin-bottom: 1rem;
}

.widgetItem.treeView > .Menu__menu > .Menu__menuItem > .Menu__menuLink {
    display: block;
    padding: 0.1rem 0;
    border: none !important;
    background: transparent !important;
    text-decoration: none;
}

.widgetItem.treeView > .Menu__menu > .Menu__menuItem > .Menu__menuLink .Menu__menuTextBlock {
    display: inline-block;
    font-size: 1.15rem;
    font-weight: 700;
    color: #30383a;
    padding-bottom: 1px;
    border-bottom: 2px solid #FFD500;
}

/* Unterlisten eingerückt, aber ohne Linien */

.widgetItem.treeView .Menu__menuItem > .Menu__menu {
    margin-top: 0.55rem;
    margin-left: 1rem !important;
    padding-left: 0.75rem !important;
    border-left: none !important;
}

/* 2. Ebene: etwas größer */

.widgetItem.treeView > .Menu__menu > .Menu__menuItem > .Menu__menu > .Menu__menuItem > .Menu__menuLink {
    display: block;
    padding: 0.2rem 0;
    text-decoration: none;
}

.widgetItem.treeView > .Menu__menu > .Menu__menuItem > .Menu__menu > .Menu__menuItem > .Menu__menuLink .Menu__menuTextBlock {
    font-size: 1.02rem;
    font-weight: 500;
    color: #30383a;
}

/* 3. Ebene: kleiner */

.widgetItem.treeView > .Menu__menu > .Menu__menuItem > .Menu__menu > .Menu__menuItem > .Menu__menu {
    margin-left: 0.85rem !important;
    padding-left: 0.6rem !important;
    border-left: none !important;
}

.widgetItem.treeView > .Menu__menu > .Menu__menuItem > .Menu__menu > .Menu__menuItem > .Menu__menu > .Menu__menuItem > .Menu__menuLink {
    display: block;
    padding: 0.16rem 0;
    text-decoration: none;
}

.widgetItem.treeView > .Menu__menu > .Menu__menuItem > .Menu__menu > .Menu__menuItem > .Menu__menu > .Menu__menuItem > .Menu__menuLink .Menu__menuTextBlock {
    font-size: 0.92rem;
    font-weight: 400;
    color: #30383a;
}

/* Aktiver Punkt: keine Verschiebung mehr, nur gelbe Unterstreichung */

.widgetItem.treeView .Menu__menuTextBlockActive, .widgetItem.treeView .CommonStyle__zt1LinkActive {
    padding: 0 !important;
    margin: 0 !important;
    display: inline !important;
    position: static !important;
    background: transparent !important;
    color: #30383a !important;
    font-weight: 600 !important;
    text-decoration: underline !important;
    text-decoration-color: #FFD500 !important;
    text-decoration-thickness: 2px;
    text-underline-offset: 2px;
}

.widgetItem.treeView > .Menu__menu > .Menu__menuItem:first-child {
    margin-top: 0.5rem;
}

/* @media print */

@media print {
    .accordion details, .accordion details[open] {
        display: block !important;
    }

    .accordion details > summary {
        list-style: none;
    }

    .accordion details > * {
        display: block !important;
    }

    /* Gesamtes Layout darf beim Drucken nicht abschneiden */

    html, body, .portalContainer, .Layout__oneColumn, .Layout__twoColumn, .Layout__twoColumnReverse, .Layout__narrow, .Layout__twoColumn2, .Layout__layout1, .Layout__layout2, .articleDetail, .KBArticleDetailLeftContainer, .KBArticleDetailLeftContainer__description, .CustomWidgets__customDescription, .Feed__feed {
        height: auto !important;
        max-height: none !important;
        overflow: visible !important;
    }

    /* Header/Footer und störende Elemente beim Drucken ausblenden */

    .Header__header, .Header__headerNav, .footer, .AppContainer__backToTop, .KBArticleDetailLeftContainer__pdfView, .KBArticleDetailLeftContainer__printView, .SocialShare__socialShareList {
        display: none !important;
    }

    /* Accordions/Inhalte im Druck immer vollständig zeigen */

    .accordion, .accordion details, .accordion-content {
        display: block !important;
        height: auto !important;
        max-height: none !important;
        overflow: visible !important;
    }

    .accordion details:not([open]) > :not(summary) {
        display: block !important;
    }

    .accordion summary {
        list-style: none !important;
        cursor: default !important;
    }

    .accordion summary::-webkit-details-marker {
        display: none !important;
    }

    .accordion summary:before {
        content: "" !important;
    }

    /* Bessere Seitenumbrüche */

    h1, h2, h3, h4, h5, h6, p, ul, ol, li, table, tr, td, th, .KB_New_Editor_Highlights, .accordion details, .accordion-content {
        break-inside: auto !important;
        page-break-inside: auto !important;
    }

    img, table, .KB_New_Editor_Highlights {
        break-inside: avoid !important;
        page-break-inside: avoid !important;
    }

    /* Falls Zoho irgendwo Breiten begrenzt */

    .Layout__oneColumn, .Layout__twoColumn, .Layout__twoColumnReverse, .Layout__narrow, .Layout__twoColumn2 {
        max-width: 100% !important;
        width: 100% !important;
    }
}

/* @media print */

@media print {
    * {
        overflow: visible !important;
        max-height: none !important;
    }

    .Feed__footerCol {
        display: none !important;
    }
}

/* Ausblenden des PDF-Download-Symbols */

.KBArticleDetailLeftContainer__pdfView {
    display: none !important;
}

/* Wissensdatenbank-Tab: normal, aktiv und hover sauber steuern */

#portal_tabSolutions > a, #portal_tabSolutions > .Header__tabsLink {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    text-decoration: none !important;
    color: #30383a !important;
    -webkit-text-fill-color: #30383a !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Aktiver Zustand: gelbe Schrift auf dunklem Balken */

#portal_tabSolutions.Header__tabsTabActive > a, #portal_tabSolutions.Header__tabsTabActive > .Header__tabsLink {
    color: #FFD500 !important;
    -webkit-text-fill-color: #FFD500 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

#portal_tabSolutions:hover > a, #portal_tabSolutions:hover > .Header__tabsLink, #portal_tabSolutions:focus-within > a, #portal_tabSolutions:focus-within > .Header__tabsLink {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

/* Aktiv + Hover: bleibt weiß beim Darüberfahren */

#portal_tabSolutions.Header__tabsTabActive:hover > a, #portal_tabSolutions.Header__tabsTabActive:hover > .Header__tabsLink, #portal_tabSolutions.Header__tabsTabActive:focus-within > a, #portal_tabSolutions.Header__tabsTabActive:focus-within > .Header__tabsLink {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

/* Mittlere Footer-Spalte neu gestalten */

.footer__left {
    text-align: left;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    margin-top: 0;
    margin-left: 0;
}

.footer__left h3 {
    margin-left: 0;
    margin-bottom: 18px;
}

.footer__service-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin: 0;
    padding: 0;
}

.footer__service-item {
    display: flex;
    align-items: center;
    gap: 14px;
    color: #FFF;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.4;
    text-align: left;
}

.footer__service-icon {
    width: 24px;
    height: 24px;
    min-width: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.footer__service-icon img {
    display: block;
    width: 24px;
    height: 24px;
    object-fit: contain;
}

/* Links in der Service-Spalte */

.footer__left .footer__service-link, .footer__left .footer__service-link:link, .footer__left .footer__service-link:visited {
    color: #FFFFFF !important;
    text-decoration: underline !important;
    text-decoration-color: #FFFFFF !important;
    text-underline-offset: 2px;
    text-decoration-thickness: 0.2px;
}

.footer__left .footer__service-link:hover, .footer__left .footer__service-link:focus, .footer__left .footer__service-link:active {
    color: #FFD500 !important;
    text-decoration: underline !important;
    text-decoration-color: #FFFFFF !important;
}

/* Mobile Ansicht */

@media (max-width: 768px) {
    .footer__left {
        margin-left: 0;
        align-items: flex-start;
    }

    .footer__left h3 {
        text-align: left;
        margin-left: 0;
    }

    .footer__service-item {
        font-size: 16px;
    }

    .footer__service-icon, .footer__service-icon img {
        width: 22px;
        height: 22px;
    }
}

/* Name: Globale Accessibility-Basis Bereich: Fokus, Tastatur, Kontrast Zweck: Macht den Tastaturfokus sichtbar und behebt erste Kontrastprobleme in Header, Suche ... */

/* Sichtbarer Fokus für alle interaktiven Elemente */

a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible, summary:focus-visible, [role="button"]:focus-visible, [tabindex]:not([tabindex="-1"]):focus-visible {
    outline: 3px solid #000000 !important;
    outline-offset: 3px !important;
    box-shadow: none !important;
}

/* Suchfilter-Kontrast korrigieren */

.Search__serchFilter {
    font-size: 1.0rem;
    font-weight: bold;
    color: #30383a !important;
}

/* Fokus für Formularfelder sichtbarer */
input:focus, select:focus, textarea:focus {
    border-color: #000000 !important;
    outline: 2px solid #000000 !important;
    outline-offset: 1px !important;
}

/* Upload-Button auch per Fokus sichtbar */
.FileUpload__labelAllow:focus-within, .FileUpload__labelAllow:focus {
    outline: 3px solid #000000 !important;
    outline-offset: 3px !important;
}

/* Mobile: Scrollen nicht komplett sperren, sonst problematisch für Accessibility */
@media (max-width: 768px) {
    body, html {
        overflow-y: auto !important;
        height: auto !important;
    }
}

/* Problematischen Zoho-Richtext-Umschalter im Kommentarformular deaktivieren */

.CommentForm__threadComment .CommentForm__richtext, .CommentForm__threadComment [data-id^="comment_toggle_"], .CommentForm__threadComment [data-id*="comment_toggle"], .CommentForm__threadComment [aria-label="plaintext"] {
    pointer-events: none !important;
}

