/* min ready */
div#tarteaucitronMainLineOffset,.tarteaucitronBorder {border:0!important;}

#tarteaucitron [aria-pressed="true"] {
    font-weight:700;
}

.tac_visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap; /* added line */
    border: 0;
}

div#tarteaucitronAlertBig:focus {outline: 0;}

.tarteaucitron-modal-open{
    overflow: hidden;
    height: 100%;
}

#tarteaucitronContentWrapper {display:unset;}

/** 10082023 **/
div#tarteaucitronServices {
    border-radius: 8px;
}

button#tarteaucitronClosePanel {
    border-radius: 5px 5px 0 0;
    right: 15px!important;
}
button.tarteaucitron-toggle-group {
    background: transparent!important;
    padding: 10px 0 0;
    cursor: pointer;
}

#tarteaucitronRoot .tarteaucitronIsDenied .tarteaucitronAllow .tarteaucitronCheck::before {
    content: '\2610'!important
}

#tarteaucitronRoot .tarteaucitronIsAllowed .tarteaucitronAllow .tarteaucitronCheck::before {
    content: '\2611'!important
}

#tarteaucitronRoot .tarteaucitronIsDenied .tarteaucitronDeny .tarteaucitronCross::before {
    content: '\2611'!important
}

#tarteaucitronRoot .tarteaucitronIsAllowed .tarteaucitronDeny .tarteaucitronCross::before {
    content: '\2610'!important
}

#tarteaucitronRoot .tarteaucitronAllow .tarteaucitronCheck::before {
    content: '\2610'!important
}

#tarteaucitronRoot .tarteaucitronDeny .tarteaucitronCross::before {
    content: '\2610'!important
}

#tarteaucitronRoot #tarteaucitronServices_mandatory .tarteaucitronCheck::before {
    content: '\2611'!important
}

#tarteaucitronRoot .tarteaucitronCheck::before,
#tarteaucitronRoot .tarteaucitronCross::before {
    font-size: 20px;
}
/* hide useless mandatory button */
#tarteaucitronRoot #tarteaucitronServices #tarteaucitronServices_mandatory .tarteaucitronAsk {
    display: none!important;
}

/* remove icon from the banner */
#tarteaucitronRoot button.tarteaucitronCTAButton,
#tarteaucitronRoot button#tarteaucitronCloseAlert,
#tarteaucitronRoot button#tarteaucitronPrivacyUrl{
    border: 0;
    border-radius: 4px;
}
#tarteaucitronRoot button.tarteaucitronCTAButton .tarteaucitronCross,
#tarteaucitronRoot button.tarteaucitronCTAButton .tarteaucitronCheck {
    display:none;
}

/* dont use bold to avoid bigger button */
#tarteaucitronRoot #tarteaucitron [aria-pressed="true"] {
    font-weight: initial;
    text-shadow: 0px 0px 1px;
}

/* fix padding if no cookies */
#tarteaucitronRoot #tarteaucitronServices li#tarteaucitronNoServicesTitle {
    padding: 20px;
}

/* hide info about cookies number */
#tarteaucitronRoot .tarteaucitronStatusInfo {
    display: none;
}

#tarteaucitronRoot .tarteaucitronName {
    padding-top: 5px;
}
/***************/


/** 14042021 **/
span.tarteaucitronReadmoreSeparator {
    display: inline!important;
}
/******/

/** 09052021 **/
.tarteaucitronName .tacCurrentStatus, .tarteaucitronName .tarteaucitronReadmoreSeparator {
    color: #333!important;
    font-size: 12px!important;
    text-transform: capitalize;
}
/**************/

/** 27032021 **/
button.tarteaucitron-toggle-group {
    display: block;
}
span.tarteaucitronH3 {
    font-weight: 700!important;
}
#tarteaucitron #tarteaucitronServices_mandatory .tarteaucitronH3 {
    font-weight: 500!important;
    font-size: 14px;
    margin-top: 7px;
}
.tarteaucitronLine {
    border-left: 0px solid transparent!important;
}
/*****/

/** PARTNERS LIST **/
html body #tarteaucitronRoot #tarteaucitronAlertBig div.tarteaucitronPartnersList {
    text-align: left;
    background: #ffffff17;
    margin: 15px 0px 10px;
    padding: 15px;
    display: block;
    border-radius: 4px;
}

html body #tarteaucitronRoot #tarteaucitronAlertBig div.tarteaucitronPartnersList b {
    font-weight: 700;
    padding-bottom: 8px;
    display: block;
    font-size: 16px;
}

html body #tarteaucitronRoot #tarteaucitronAlertBig div.tarteaucitronPartnersList ul {
    margin-left: 22px;
}

html body #tarteaucitronRoot #tarteaucitronAlertBig div.tarteaucitronPartnersList ul li {
    list-style: circle;
    font-size: 14px;
}
/**********************/

/** SAVE BUTTON **/
html body #tarteaucitronRoot button#tarteaucitronSaveButton {
    font-size: 18px!important;
    padding: 7px 20px;
    border-radius: 5px;
    cursor: pointer;
}

html body #tarteaucitronRoot div#tarteaucitronSave {
    text-align: right;
    padding: 20px;
    background: #333;
}
/******************/

/** BETTER MOBILE MODE **/
@media screen and (max-width: 767px) {

    html body #tarteaucitronRoot #tarteaucitron ul#tarteaucitronServices_mandatory .tarteaucitronDeny {
        display: none!important;
    }

    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder button,
    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronAsk,
    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronName {
        width:100%!important;
        display: block!important;
        margin-left: 0!important;
        margin-right: 0!important;
        box-sizing: border-box!important;
        max-width: 100%!important;
        margin-bottom: 8px!important;
    }

    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder ul .tarteaucitronLine {
        padding: 16px!important;
    }

    html body #tarteaucitronRoot #tarteaucitron div#tarteaucitronMainLineOffset .tarteaucitronName {
        display: none!important;
    }

    #tarteaucitronServices_mandatory li.tarteaucitronLine .tarteaucitronName span {
        width: 100%!important;
        display: inline-block;
    }
    li.tarteaucitronLine .tarteaucitronName span {
        width: 80%!important;
        display: inline-block;
    }
    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder button.tarteaucitron-toggle-group {
        width: 10%!important;
        position: absolute;
        top: 20px;
        right: 20px;
        font-size: 0px;
        padding: 10px 0;
    }
    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder button.tarteaucitron-toggle-group:before {
        content: '\0025BE';
        font-weight:700;
        font-size: 14px;
    }
    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder .tarteaucitronIsExpanded button.tarteaucitron-toggle-group:before {
        content: '\0025B4';
    }
}
@media screen and (min-width: 768px) {

    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder button.tarteaucitron-toggle-group:after {
        content: '\0025BE';
        font-weight:700;
        font-size: 14px;
        margin-left: 15px;
    }
    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder .tarteaucitronIsExpanded button.tarteaucitron-toggle-group:after {
        content: '\0025B4';
        margin-left: 15px;
    }
}
/****/



/***
* Reset CSS
*/
#tarteaucitronRoot div, #tarteaucitronRoot span, #tarteaucitronRoot applet, #tarteaucitronRoot object, #tarteaucitronRoot iframe, #tarteaucitronRoot h1, #tarteaucitronRoot h2, #tarteaucitronRoot h3, #tarteaucitronRoot h4, #tarteaucitronRoot h5, #tarteaucitronRoot h6, #tarteaucitronRoot p, #tarteaucitronRoot blockquote, #tarteaucitronRoot pre, #tarteaucitronRoot a, #tarteaucitronRoot abbr, #tarteaucitronRoot acronym, #tarteaucitronRoot address, #tarteaucitronRoot big, #tarteaucitronRoot cite, #tarteaucitronRoot code, #tarteaucitronRoot del, #tarteaucitronRoot dfn, #tarteaucitronRoot em, #tarteaucitronRoot img, #tarteaucitronRoot ins, #tarteaucitronRoot kbd, #tarteaucitronRoot q, #tarteaucitronRoot s, #tarteaucitronRoot samp, #tarteaucitronRoot small, #tarteaucitronRoot strike, #tarteaucitronRoot strong, #tarteaucitronRoot sub, #tarteaucitronRoot sup, #tarteaucitronRoot tt, #tarteaucitronRoot var, #tarteaucitronRoot b, #tarteaucitronRoot u, #tarteaucitronRoot i, #tarteaucitronRoot center, #tarteaucitronRoot dl, #tarteaucitronRoot dt, #tarteaucitronRoot dd, #tarteaucitronRoot ol, #tarteaucitronRoot ul, #tarteaucitronRoot li, #tarteaucitronRoot fieldset, #tarteaucitronRoot form, #tarteaucitronRoot label, #tarteaucitronRoot legend, #tarteaucitronRoot table, #tarteaucitronRoot caption, #tarteaucitronRoot tbody, #tarteaucitronRoot tfoot, #tarteaucitronRoot thead, #tarteaucitronRoot tr, #tarteaucitronRoot th, #tarteaucitronRoot td, #tarteaucitronRoot article, #tarteaucitronRoot aside, #tarteaucitronRoot canvas, #tarteaucitronRoot details, #tarteaucitronRoot embed, #tarteaucitronRoot figure, #tarteaucitronRoot figcaption, #tarteaucitronRoot footer, #tarteaucitronRoot header, #tarteaucitronRoot hgroup, #tarteaucitronRoot menu, #tarteaucitronRoot nav, #tarteaucitronRoot output, #tarteaucitronRoot ruby, #tarteaucitronRoot section, #tarteaucitronRoot summary, #tarteaucitronRoot time, #tarteaucitronRoot mark, #tarteaucitronRoot audio, #tarteaucitronRoot video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
    /*background: initial;*/
    text-align: initial;
    text-shadow: initial;
}

/* Animation */
#tarteaucitronRoot * {transition: border 300ms, background 300ms, opacity 200ms, box-shadow 400ms}

/* HTML5 display-role reset for older browsers */
#tarteaucitronRoot article, #tarteaucitronRoot aside, #tarteaucitronRoot details, #tarteaucitronRoot figcaption, #tarteaucitronRoot figure, #tarteaucitronRoot footer, #tarteaucitronRoot header, #tarteaucitronRoot hgroup, #tarteaucitronRoot menu, #tarteaucitronRoot nav, #tarteaucitronRoot section {
    display: block;
}
#tarteaucitronRoot ol, #tarteaucitronRoot ul {
    list-style: none;
}
#tarteaucitronRoot blockquote, #tarteaucitronRoot q {
    quotes: none;
}
#tarteaucitronRoot blockquote:before, #tarteaucitronRoot blockquote:after, #tarteaucitronRoot q:before, #tarteaucitronRoot q:after {
    content: '';
    content: none;
}
#tarteaucitronRoot table {
    border-collapse: collapse;
    border-spacing: 0;
}

#tarteaucitronRoot a:focus-visible, #tarteaucitronRoot button:focus-visible {
    outline: 3px dashed #3d86d8;
}

/***
 * Better scroll management
 */
div#tarteaucitronMainLineOffset {
    margin-top: 0!important;
}

div#tarteaucitronServices {
    margin-top: 21px!important;
}

/*#tarteaucitronServices::-webkit-scrollbar {
    width: 5px;
}

#tarteaucitronServices::-webkit-scrollbar-track {
    -webkit-box-shadow: inset 0 0 0 rgba(0,0,0,0);
}

#tarteaucitronServices::-webkit-scrollbar-thumb {
    background-color: #ddd;
    outline: 0px solid slategrey;
}*/

div#tarteaucitronServices {
    box-shadow: 0 40px 60px #545454;
}

/***
 * Responsive layout for the control panel
 */
@media screen and (max-width:479px) {
    #tarteaucitron .tarteaucitronLine .tarteaucitronName {
        width: 90% !important;
    }

    #tarteaucitron .tarteaucitronLine .tarteaucitronAsk {
        float: left !important;
        margin: 10px 15px 5px;
    }
}

@media screen and (max-width:767px) {
    #tarteaucitronAlertSmall #tarteaucitronCookiesListContainer, #tarteaucitron {
        background: #fff;
        border: 0 !important;
        bottom: 0 !important;
        height: 100% !important;
        left: 0 !important;
        margin: 0 !important;
        max-height: 100% !important;
        max-width: 100% !important;
        top: 0 !important;
        width: 100% !important;
    }

    #tarteaucitron .tarteaucitronBorder {
        border: 0 !important;
    }

    #tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList {
        border: 0 !important;
    }

    #tarteaucitron #tarteaucitronServices .tarteaucitronTitle {
        text-align: left !important;
    }

    .tarteaucitronName .tarteaucitronH2 {
        max-width: 80%;
    }

    #tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk {
        text-align: center !important;
    }

    #tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk button {
        margin-bottom: 5px;
    }
}

@media screen and (min-width:768px) and (max-width:991px) {
    #tarteaucitron {
        border: 0 !important;
        left: 0 !important;
        margin: 0 5% !important;
        max-height: 80% !important;
        width: 90% !important;
    }
}

/***
 * Common value
 */
#tarteaucitronRoot div#tarteaucitron {
    left: 0;
    right: 0;
    margin: auto;
}

#tarteaucitronRoot button#tarteaucitronBack {
    background: #eee;
}

#tarteaucitron .clear {
    clear: both;
}

#tarteaucitron a {
    color: rgb(66, 66, 66);
    font-size: 11px;
    font-weight: 700;
    text-decoration: none;
}

#tarteaucitronRoot button {
    background: transparent;
    border: 0;
}

#tarteaucitronAlertBig strong, #tarteaucitronAlertSmall strong,
#tarteaucitronAlertBig a, #tarteaucitronAlertSmall a {
    color: #fff;
}

#tarteaucitron strong {
    font-size: 22px;
    font-weight: 500;
}

#tarteaucitron ul {
    padding: 0;
}

#tarteaucitron .tarteaucitronH1, #tarteaucitron .tarteaucitronH2, #tarteaucitron .tarteaucitronH3, #tarteaucitron .tarteaucitronH4, #tarteaucitron .tarteaucitronH5, #tarteaucitron .tarteaucitronH6 {
    display: block;
}

.cookie-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
/***
 * Root div added just before </body>
 */
#tarteaucitronRoot {
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    width: 100%;
}

#tarteaucitronRoot * {
    box-sizing: initial;
    color: #333;
    /*font-family: sans-serif !important;*/
    font-size: 14px;
    line-height: normal;
    vertical-align: initial;
}

#tarteaucitronRoot .tarteaucitronH1 {
    font-size: 1.5em;
    text-align: center;
    color: #fff;
    margin: 15px 0 28px;
}

#tarteaucitronRoot .tarteaucitronH2 {
    display: inline-block;
    margin: 12px 0 0 15px;
    color: #fff;
}

#tarteaucitronCookiesNumberBis.tarteaucitronH2 {
    margin-left: 0;
}

/***
 * Control panel
 */
#tarteaucitronBack {
    background: #fff;
    display: none;
    height: 100%;
    left: 0;
    opacity: 0.7;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 2147483646;
}

#tarteaucitron {
    display: none;
    max-height: 80%;
    left: 50%;
    margin: 0 auto 0 -430px;
    padding: 0;
    position: fixed;
    top: 6%;
    width: 860px;
    z-index: 2147483647;
}

#tarteaucitron .tarteaucitronBorder {
    background: #fff;
    border: 2px solid #333;
    border-top: 0;
    height: auto;
    overflow: auto;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronClosePanelCookie,
#tarteaucitron #tarteaucitronClosePanel {
    background: #333333;
    color: #fff;
    cursor: pointer;
    font-size: 12px;
    font-weight: 700;
    text-decoration: none;
    padding: 4px 0;
    position: absolute;
    right: 0;
    text-align: center;
    width: 70px;
}

#tarteaucitron #tarteaucitronDisclaimer {
    color: #555;
    font-size: 12px;
    margin: 15px auto 0;
    width: 80%;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronHidden,
#tarteaucitron #tarteaucitronServices .tarteaucitronHidden {
    background: rgba(51, 51, 51, 0.07);
}

#tarteaucitron #tarteaucitronServices .tarteaucitronHidden {
    display: none;
    position: relative;
}

#tarteaucitronCookiesList .tarteaucitronH3.tarteaucitronTitle {
    width: 100%;
    box-sizing: border-box;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronTitle,
#tarteaucitron #tarteaucitronServices .tarteaucitronTitle button,
#tarteaucitron #tarteaucitronInfo,
#tarteaucitron #tarteaucitronServices .tarteaucitronDetails,
#tarteaucitronRoot .asCatToggleBtn {
    color: #fff;
    display: inline-block;
    font-size: 14px;
    font-weight: 700;
    margin: 20px 0px 0px;
    padding: 5px 20px;
    text-align: left;
    width: auto;
    background: #333;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronMainLine .tarteaucitronName a,
#tarteaucitron #tarteaucitronServices .tarteaucitronTitle a {
    color: #fff;
    font-weight: 500;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronMainLine .tarteaucitronName a:hover,
#tarteaucitron #tarteaucitronServices .tarteaucitronTitle a:hover {
    text-decoration: none !important;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronMainLine .tarteaucitronName a {
    font-size: 22px;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronTitle a {
    font-size: 14px;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronTitle {
    padding: 5px 10px;
    margin: 0;
}

#tarteaucitron #tarteaucitronInfo,
#tarteaucitron #tarteaucitronServices .tarteaucitronDetails:not(.tarteaucitronDetailsInline) {
    color: #fff;
    display: none;
    font-size: 12px;
    font-weight: 500;
    margin-top: 0;
    max-width: 270px;
    padding: 20px;
    position: absolute;
    z-index: 2147483647;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronTitle + [id^="tarteaucitronDetails"] {
    width: calc(100% - 40px);
    font-weight:500;
    margin:0;
    padding:5px 20px 20px;
    background:rgba(51, 51, 51, 0.2);
    color:#333;
}

#tarteaucitron #tarteaucitronInfo a {
    color: #fff;
    text-decoration: underline;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine:hover {
    background: rgba(51, 51, 51, 0.2);
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine {
    background: rgba(51, 51, 51, 0.1);
    border-left: 5px solid transparent;
    margin: 0;
    overflow: hidden;
    padding: 15px 5px;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine.tarteaucitronIsAllowed {
    border-color: #1B870B;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine.tarteaucitronIsDenied {
    border-color: #9C1A1A;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronMainLine {
    background: #333;
    border: 3px solid #333;
    border-left: 9px solid #333;
    border-top: 5px solid #333;
    margin-bottom: 0;
    margin-top: 21px;
    position: relative;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronMainLine:hover {
    background: #333;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronMainLine .tarteaucitronName {
    margin-left: 15px;
    margin-top: 2px;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronMainLine .tarteaucitronName button {
    color: #fff;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronMainLine .tarteaucitronAsk {
    margin-top: 0px !important;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronName {
    display: inline-block;
    float: left;
    margin-left: 15px;
    text-align: left;
    width: 50%;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronName a:hover {
    text-decoration: underline;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk {
    display: inline-block;
    float: right;
    margin: 7px 15px 0;
    text-align: right;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronAllow,
#tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronDeny,
.tac_activate .tarteaucitronAllow {
    background: #555;
    border-radius: 4px;
    color: #fff;
    cursor: pointer;
    display: inline-block;
    padding: 6px 10px;
    text-align: center;
    text-decoration: none;
    width: auto;
    border: 0;
}

#tarteaucitron #tarteaucitronServices #tarteaucitronAllAllowed.tarteaucitronIsSelected {
    background-color: #1B870B;
    opacity: 1;
}
#tarteaucitron #tarteaucitronServices #tarteaucitronAllDenied.tarteaucitronIsSelected,
#tarteaucitron #tarteaucitronServices #tarteaucitronAllDenied2.tarteaucitronIsSelected {
    background-color: #9C1A1A;
    opacity: 1;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine.tarteaucitronIsAllowed .tarteaucitronAllow,
#tarteaucitron #tarteaucitronServices #tarteaucitronServices_mandatory .tarteaucitronLine button.tarteaucitronAllow {
    background-color: #1B870B;
}
#tarteaucitron #tarteaucitronServices .tarteaucitronLine.tarteaucitronIsDenied .tarteaucitronDeny {
    background-color: #9C1A1A;
}

#tarteaucitron #tarteaucitronServices #tarteaucitronServices_mandatory .tarteaucitronLine button.tarteaucitronAllow{
    opacity: 0.4;
}

#tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronName .tarteaucitronListCookies {
    color: #333;
    font-size: 12px;
}

#tarteaucitron .tarteaucitronH3 {
    font-size: 18px;
}

#tarteaucitron #tarteaucitronMainLineOffset .tarteaucitronName {
    width: auto!important;
    margin-left: 0!important;
    font-size: 14px;
}

.tarteaucitronAlertBigBottom span#tarteaucitronDisclaimerAlert,
.tarteaucitronAlertBigTop span#tarteaucitronDisclaimerAlert {
    display: inline-flex;
}
span#tarteaucitronDisclaimerAlert {
    padding: 0 10px;
    display: inline-block;
    overflow-y: auto;
    max-height: 50vh;
    line-height: normal;
}
@media only screen and (max-width: 768px) {
    #tarteaucitronRoot span#tarteaucitronDisclaimerAlert {
        font-size: 16px;
    }
}
#tarteaucitron .tarteaucitronBorder, #tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronCookiesListMain, #tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList, #tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronHidden, #tarteaucitron #tarteaucitronServices .tarteaucitronMainLine {
    border-color: #333!important;
}

/***
 * Big alert
 */
.tarteaucitronAlertBigTop {
    top: 0;
}

.tarteaucitronAlertBigBottom {
    bottom: 0;
}

#tarteaucitronRoot #tarteaucitronAlertBig {
    background: #000000;
    color: #fff;
    display: none;
    font-size: 15px !important;
    left: 0;
    position: fixed;
    box-sizing: content-box;
    z-index: 2147483645;
    text-align: center;
    padding: 10px 0 10px 0;
    margin: auto;
    width: 100%;
}

#tarteaucitronAlertBig #tarteaucitronPrivacyUrl,
#tarteaucitronAlertBig #tarteaucitronPrivacyUrlDialog,
#tarteaucitronAlertBig #tarteaucitronDisclaimerAlert,
#tarteaucitronAlertBig #tarteaucitronDisclaimerAlert strong {
    /*font: 15px verdana;*/
    color: #fff;
}

#tarteaucitronAlertBig #tarteaucitronDisclaimerAlert strong {
    font-weight: 700;
}

#tarteaucitronAlertBig #tarteaucitronPrivacyUrl,
#tarteaucitronAlertBig #tarteaucitronPrivacyUrlDialog {
    cursor: pointer;
}

#tarteaucitronAlertBig #tarteaucitronCloseAlert,
#tarteaucitronAlertBig #tarteaucitronPersonalize,
#tarteaucitronAlertBig #tarteaucitronPersonalize2,
.tarteaucitronCTAButton,
#tarteaucitron #tarteaucitronPrivacyUrl,
#tarteaucitron #tarteaucitronPrivacyUrlDialog,
#tarteaucitronRoot .tarteaucitronDeny,
#tarteaucitronRoot .tarteaucitronAllow {
    background: #ffffff;
    color: #000000;
    cursor: pointer;
    display: inline-block;
    font-size: 16px!important;
    line-height: 1.2;
    padding: 5px 10px;
    text-decoration: none;
    margin-left: 7px;
}

#tarteaucitronRoot .tarteaucitronDeny {
    background: #9C1A1A;
}

#tarteaucitronAlertBig #tarteaucitronCloseAlert, #tarteaucitron #tarteaucitronPrivacyUrl, #tarteaucitron #tarteaucitronPrivacyUrlDialog {
    background: #fff;
    color: #333;
    font-size: 13px;
    margin-bottom: 3px;
    margin-left: 7px;
    padding: 5px 10px;
}

#tarteaucitronPercentage {
    background: #0A0!important;
    box-shadow: 0 0 2px #fff, 0 1px 2px #555;
    height: 5px;
    left: 0;
    position: fixed;
    width: 0;
    z-index: 2147483644;
}

/***
 * Icon
 */
.tarteaucitronIconBottomRight {
    bottom: 0;
    right: 0;
}
.tarteaucitronIconBottomLeft {
    bottom: 0;
    left: 0;
}
.tarteaucitronIconTopRight {
    top: 0;
    right: 0;
}
.tarteaucitronIconTopLeft {
    top: 0;
    left: 0;
}

.tarteaucitronIconTopLeft #tarteaucitronManager {
    border-radius: 2px 7px 7px 2px;
}

.tarteaucitronIconTopRight #tarteaucitronManager {
    border-radius: 7px 2px 2px 7px;
}

.tarteaucitronIconBottomLeft #tarteaucitronManager {
    border-radius: 7px 7px 2px 2px;
}

.tarteaucitronIconBottomRight #tarteaucitronManager {
    border-radius: 7px 7px 2px 2px;
}

#tarteaucitronIcon {
    background: transparent;
    position: fixed;
    /*display: none;*/
    width: auto;
    z-index: 2147483646;
}
#tarteaucitronIcon #tarteaucitronManager {
    color: transparent;
    cursor: pointer;
    display: inline-block;
    font-size: 11px !important;
    padding: 8px 10px 8px;
    border: none;
}
#tarteaucitronIcon #tarteaucitronManager img {
    width: 50px;
    height: 50px;
}

#tarteaucitronRoot .tarteaucitronCross::before {
    content: '\2717';
    display: inline-block;
    color: white;
}

#tarteaucitronRoot .tarteaucitronCheck::before {
    content: '\2713';
    display: inline-block;
    color: white;
}

#tarteaucitronRoot .tarteaucitronPlus::before {
    content: '\271b';
    display: inline-block;
    color: white;
}


/***
 * Small alert
 */

.tarteaucitronAlertSmallTop,.tarteaucitronAlertSmallBottom {
    bottom: 0;
}

#tarteaucitronAlertSmall {
    background: #333;
    display: none;
    padding: 0;
    position: fixed;
    right: 0;
    text-align: center;
    width: auto;
    z-index: 2147483646;
}

#tarteaucitronAlertSmall #tarteaucitronManager {
    color: #fff;
    cursor: pointer;
    display: inline-block;
    font-size: 11px !important;
    padding: 8px 10px 8px;
}

#tarteaucitronAlertSmall #tarteaucitronManager:hover {
    background: rgba(255, 255, 255, 0.05);
}

#tarteaucitronAlertSmall #tarteaucitronManager #tarteaucitronDot {
    background-color: gray;
    border-radius: 5px;
    display: block;
    height: 8px;
    margin-bottom: 1px;
    margin-top: 5px;
    overflow: hidden;
    width: 100%;
}

#tarteaucitronAlertSmall #tarteaucitronManager #tarteaucitronDot #tarteaucitronDotGreen,
#tarteaucitronAlertSmall #tarteaucitronManager #tarteaucitronDot #tarteaucitronDotYellow,
#tarteaucitronAlertSmall #tarteaucitronManager #tarteaucitronDot #tarteaucitronDotRed {
    display: block;
    float: left;
    height: 100%;
    width: 0%;
}

#tarteaucitronAlertSmall #tarteaucitronManager #tarteaucitronDot #tarteaucitronDotGreen {
    background-color: #1B870B;
}

#tarteaucitronAlertSmall #tarteaucitronManager #tarteaucitronDot #tarteaucitronDotYellow {
    background-color: #FBDA26;
}

#tarteaucitronAlertSmall #tarteaucitronManager #tarteaucitronDot #tarteaucitronDotRed {
    background-color: #9C1A1A;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesNumber {
    background: rgba(255, 255, 255, 0.2);
    color: #fff;
    cursor: pointer;
    display: inline-block;
    font-size: 30px;
    padding: 0px 10px;
    vertical-align: top;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesNumber:hover {
    background: rgba(255, 255, 255, 0.3);
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer {
    display: none;
    max-height: 70%;
    max-width: 500px;
    position: fixed;
    right: 0;
    width: 100%;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList {
    background: #fff;
    border: 2px solid #333;
    color: #333;
    font-size: 11px;
    height: auto;
    overflow: auto;
    text-align: left;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList strong {
    color: #333;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesTitle {
    background: #333;
    margin-top: 21px;
    padding: 13px 0 9px 13px;
    text-align: left;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesTitle strong {
    color: #fff;
    font-size: 16px;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronCookiesListMain {
    background: rgba(51, 51, 51, 0.1);
    padding: 7px 5px 10px;
    word-wrap: break-word;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronCookiesListMain:hover {
    background: rgba(51, 51, 51, 0.2);
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronCookiesListMain a {
    color: #333;
    text-decoration: none;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronCookiesListMain .tarteaucitronCookiesListLeft {
    display: inline-block;
    width: 50%;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronCookiesListMain .tarteaucitronCookiesListLeft a strong {
    color: darkred;
}

#tarteaucitronAlertSmall #tarteaucitronCookiesListContainer #tarteaucitronCookiesList .tarteaucitronCookiesListMain .tarteaucitronCookiesListRight {
    color: #333;
    display: inline-block;
    font-size: 11px;
    margin-left: 10%;
    vertical-align: top;
    width: 30%;
}

/***
 * Fallback activate link
 */
.tac_activate {
    background: #333;
    color: #fff;
    display: table;
    font-size: 12px;
    height: 100%;
    line-height: initial;
    margin: auto;
    text-align: center;
    width: 100%;
}

.tac_float {
    display: table-cell;
    text-align: center;
    vertical-align: middle;
}

.tac_activate .tac_float strong {
    color: #fff;
}

.tac_activate .tac_float .tarteaucitronAllow {
    background-color: #1B870B;
    display: inline-block;
}

/***
 * CSS for services
 */
ins.ferank-publicite, ins.adsbygoogle {
    text-decoration: none;
}

div.amazon_product {
    height:240px;
    width:120px;
}

.tarteaucitronIsAllowed .tarteaucitronDeny {
    opacity: 0.4!important;
}.tarteaucitronIsDenied .tarteaucitronAllow {
     opacity: 0.4!important;
 }.tarteaucitronIsAllowed .tarteaucitronAllow {
      opacity: 1!important;
  }.tarteaucitronIsDenied .tarteaucitronDeny {
       opacity: 1!important;
   }
.tarteaucitronLine .tarteaucitronAllow, .tarteaucitronLine .tarteaucitronDeny {
    opacity: 0.4;
}
#tarteaucitronServices_mandatory button.tarteaucitronAllow {
    opacity: 1;
}

div#tarteaucitronInfo {
    display: block!important;
    position: relative !important;
    text-align: center!important;
    max-width: 80%!important;
    padding: 15px 0!important;
    margin: -10px auto 40px!important;
    font-size: 1em!important;
    border-bottom: 1px solid;
    border-top: 1px solid;
    border-color: #555;
}

a.tarteaucitronSelfLink {
    position: absolute;
    left: 0;
    right: 0;
    bottom: -30px;
    text-align: center!important;
    display: block;
    height:30px;
}

.tarteaucitronMainLine .tarteaucitronH2 {
    font-size: 1.2em!important;
    margin-top: 4px!important;
}

span.tarteaucitronTitle.tarteaucitronH3 {
    margin-top: 12px!important;
}

#tarteaucitronCloseCross {
    position:absolute;
    color: #FFF;
    font-size:1.8rem;
    cursor: pointer;
    top: 10px;
    right: 26px
}

#tarteaucitronCloseCross span {
    color: inherit;
}

.tarteaucitron-spacer-20 {
    height: 20px;
    display: block;
}

.tarteaucitron-display-block {
    display: block;
}

.tarteaucitron-display-none {
    display: none;
}

/* ========================================================================
   ikraMed Consent UI FINAL v2
   Korrekturen:
   - Middle-Box ist immer exakt mittig, auch um 760px Breite
   - bei längeren Buttontexten wird die Box breiter/rechteckig
   - Buttontexte bleiben bei Desktop/Tablet einzeilig
   - Buttons bleiben immer nebeneinander
   - oben/unten weniger Leerraum
   - top, middle und bottom werden berücksichtigt
   ======================================================================== */

:root {
    --ikra-consent-logo-url: url('/images/favicon3.png');
    --ikra-consent-font: Georgia, 'Times New Roman', serif;
    --ikra-consent-text: #111111;
    --ikra-consent-bg: #ffffff;
    --ikra-consent-shadow: 0 22px 70px rgba(0, 0, 0, 0.22);
    --ikra-consent-button-shadow: 0 7px 18px rgba(0, 0, 0, 0.16);
    --ikra-consent-gap: 10px;
    --ikra-consent-button-min: 154px;
    --ikra-consent-button-max: 214px;
}

/* tarteaucitron Middle-Overlay neutralisieren und selbst steuern */
html body div#tarteaucitronRoot.tarteaucitronBeforeVisible::before {
    content: '' !important;
    display: none !important;
}

@supports selector(:has(*)) {
    html body div#tarteaucitronRoot.tarteaucitronBeforeVisible:has(#tarteaucitronAlertBig[role="dialog"])::before {
        content: '' !important;
        display: block !important;
        position: fixed !important;
        inset: 0 !important;
        width: 100vw !important;
        height: 100vh !important;
        background: rgba(0, 0, 0, 0.28) !important;
        opacity: 1 !important;
        z-index: 2147483644 !important;
        pointer-events: auto !important;
    }
}

/* Grundlayout */
html body #tarteaucitronRoot #tarteaucitronAlertBig {
    background: var(--ikra-consent-bg) !important;
    color: var(--ikra-consent-text) !important;
    border: 0 !important;
    box-sizing: border-box !important;
    font-family: var(--ikra-consent-font) !important;
    text-align: center !important;
    z-index: 2147483645 !important;

    display: grid !important;
    grid-template-columns: repeat(3, minmax(var(--ikra-consent-button-min), var(--ikra-consent-button-max))) !important;
    column-gap: var(--ikra-consent-gap) !important;
    row-gap: 12px !important;
    align-items: center !important;
    justify-content: center !important;
    align-content: center !important;
}

/* Logo */
html body #tarteaucitronRoot #tarteaucitronAlertBig::before {
    content: '' !important;
    display: block !important;
    grid-column: 1 / -1 !important;
    justify-self: center !important;

    width: 68px !important;
    height: 68px !important;
    margin: 0 auto 0 !important;

    background-image: var(--ikra-consent-logo-url) !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    background-size: contain !important;
}

/* Farben im Banner erzwingen */
html body #tarteaucitronRoot #tarteaucitronAlertBig,
html body #tarteaucitronRoot #tarteaucitronAlertBig strong,
html body #tarteaucitronRoot #tarteaucitronAlertBig a,
html body #tarteaucitronRoot #tarteaucitronAlertBig span {
    color: var(--ikra-consent-text) !important;
}

/*
   Text:
   Nutzt exakt die komplette Gesamtbreite der Buttonreihe.
   Damit ist der Satz oberhalb der Buttons vollständig ausgeschrieben
   und nicht künstlich schmal gesetzt.
*/
html body #tarteaucitronRoot #tarteaucitronDisclaimerAlert {
    grid-column: 1 / -1 !important;
    justify-self: stretch !important;
    align-self: center !important;

    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 auto !important;
    padding: 0 !important;

    color: var(--ikra-consent-text) !important;
    font-family: var(--ikra-consent-font) !important;
    font-size: 16px !important;
    line-height: 1.45 !important;
    font-weight: 400 !important;
    text-align: center !important;
    white-space: normal !important;
    overflow: visible !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
}

/* Buttonpositionen */
html body #tarteaucitronRoot #tarteaucitronPersonalize2 {
    grid-column: 1 !important;
}

html body #tarteaucitronRoot #tarteaucitronAllDenied2 {
    grid-column: 2 !important;
}

html body #tarteaucitronRoot #tarteaucitronCloseAlert {
    grid-column: 3 !important;
}

/*
   Buttons:
   Bei Desktop/Tablet einzeilig.
   Auf sehr kleinen Geräten bleiben sie nebeneinander,
   dürfen aber notfalls kleiner werden.
*/
html body #tarteaucitronRoot #tarteaucitronPersonalize2,
html body #tarteaucitronRoot #tarteaucitronAllDenied2,
html body #tarteaucitronRoot #tarteaucitronCloseAlert {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 42px !important;
    margin: 0 !important;
    padding: 10px 12px !important;

    background: #ffffff !important;
    color: var(--ikra-consent-text) !important;
    border: 1px solid rgba(0, 0, 0, 0.12) !important;
    border-radius: 999px !important;
    box-shadow: var(--ikra-consent-button-shadow) !important;

    box-sizing: border-box !important;
    font-family: var(--ikra-consent-font) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.15 !important;
    text-align: center !important;

    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
    hyphens: none !important;

    cursor: pointer !important;
}

html body #tarteaucitronRoot #tarteaucitronPersonalize2:hover,
html body #tarteaucitronRoot #tarteaucitronAllDenied2:hover,
html body #tarteaucitronRoot #tarteaucitronCloseAlert:hover {
    box-shadow: 0 9px 22px rgba(0, 0, 0, 0.20) !important;
    transform: translateY(-1px) !important;
}

/* Icons im Button ausblenden */
html body #tarteaucitronRoot .tarteaucitronCheck,
html body #tarteaucitronRoot .tarteaucitronCross {
    display: none !important;
}

/* Datenschutzlink */
html body #tarteaucitronRoot #tarteaucitronPrivacyUrl {
    grid-column: 1 / -1 !important;
    justify-self: center !important;

    display: block !important;
    width: auto !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;

    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;

    color: var(--ikra-consent-text) !important;
    font-family: var(--ikra-consent-font) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
    text-align: center !important;
    text-decoration: underline !important;
    cursor: pointer !important;
}

/* Fokus */
html body #tarteaucitronRoot #tarteaucitronAlertBig button:focus-visible {
    outline: 3px solid rgba(0, 0, 0, 0.28) !important;
    outline-offset: 3px !important;
}

html body #tarteaucitronRoot #tarteaucitronPercentage {
    grid-column: 1 / -1 !important;
    top: auto !important;
    bottom: auto !important;
}

/* ========================================================================
   MIDDLE
   tarteaucitron setzt bei middle role="dialog".
   Wichtig: feste, zentrierte Breite statt auto, damit die Box nicht rechts klebt.
   ======================================================================== */
html body #tarteaucitronRoot #tarteaucitronAlertBig[role="dialog"] {
    position: fixed !important;
    top: 50vh !important;
    left: 50vw !important;
    right: auto !important;
    bottom: auto !important;
    transform: translate(-50%, -50%) !important;

    width: min(690px, calc(100vw - 28px)) !important;
    min-width: 0 !important;
    max-width: calc(100vw - 28px) !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: calc(100vh - 28px) !important;
    overflow-y: auto !important;

    padding: 24px 26px 22px !important;
    margin: 0 !important;

    border-radius: 24px !important;
    box-shadow: var(--ikra-consent-shadow) !important;

    grid-template-columns: repeat(3, minmax(154px, 214px)) !important;
    justify-content: center !important;
    align-content: center !important;
}

/* ========================================================================
   TOP
   ======================================================================== */
html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigTop:not([role="dialog"]) {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: auto !important;
    transform: none !important;

    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: 72vh !important;
    overflow-y: auto !important;

    padding: 12px 18px 14px !important;
    margin: 0 !important;

    border-radius: 0 0 22px 22px !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08) !important;
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.16) !important;

    grid-template-columns: repeat(3, minmax(154px, 214px)) !important;
    justify-content: center !important;
}

html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigTop:not([role="dialog"])::before {
    width: 48px !important;
    height: 48px !important;
}

/* ========================================================================
   BOTTOM
   ======================================================================== */
html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigBottom {
    position: fixed !important;
    top: auto !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    transform: none !important;

    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: 72vh !important;
    overflow-y: auto !important;

    padding: 12px 18px 14px !important;
    margin: 0 !important;

    border-radius: 22px 22px 0 0 !important;
    border-top: 1px solid rgba(0, 0, 0, 0.08) !important;
    box-shadow: 0 -10px 32px rgba(0, 0, 0, 0.16) !important;

    grid-template-columns: repeat(3, minmax(154px, 214px)) !important;
    justify-content: center !important;
}

html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigBottom::before {
    width: 48px !important;
    height: 48px !important;
}

/* ========================================================================
   1188px / Tablet / kleinere Laptops
   Buttontexte bleiben einzeilig.
   Box bleibt mittig.
   ======================================================================== */
@media screen and (max-width: 1188px) {
    html body #tarteaucitronRoot #tarteaucitronAlertBig[role="dialog"] {
        width: min(650px, calc(100vw - 28px)) !important;
        grid-template-columns: repeat(3, minmax(150px, 200px)) !important;
        padding-top: 22px !important;
        padding-bottom: 20px !important;
    }

    html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigTop:not([role="dialog"]),
    html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigBottom {
        grid-template-columns: repeat(3, minmax(150px, 200px)) !important;
    }

    html body #tarteaucitronRoot #tarteaucitronPersonalize2,
    html body #tarteaucitronRoot #tarteaucitronAllDenied2,
    html body #tarteaucitronRoot #tarteaucitronCloseAlert {
        font-size: 13.5px !important;
        padding-left: 10px !important;
        padding-right: 10px !important;
    }
}

/* ========================================================================
   Um ca. 760px:
   Nicht mehr an den rechten Rand kleben.
   Breite bewusst kleiner als Viewport, dadurch sichtbar mittig.
   ======================================================================== */
@media screen and (max-width: 820px) {
    html body #tarteaucitronRoot #tarteaucitronAlertBig[role="dialog"] {
        width: min(640px, calc(100vw - 48px)) !important;
        max-width: calc(100vw - 48px) !important;
        left: 50vw !important;
        right: auto !important;
        transform: translate(-50%, -50%) !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        column-gap: 6px !important;
        row-gap: 11px !important;
        padding: 20px 20px 18px !important;
    }

    html body #tarteaucitronRoot #tarteaucitronAlertBig::before {
        width: 56px !important;
        height: 56px !important;
    }

    html body #tarteaucitronRoot #tarteaucitronDisclaimerAlert {
        font-size: 15px !important;
        line-height: 1.38 !important;
    }

    html body #tarteaucitronRoot #tarteaucitronPersonalize2,
    html body #tarteaucitronRoot #tarteaucitronAllDenied2,
    html body #tarteaucitronRoot #tarteaucitronCloseAlert {
        min-height: 40px !important;
        padding: 8px 6px !important;
        font-size: clamp(11px, 1.65vw, 13px) !important;
        white-space: nowrap !important;
    }
}

/* ========================================================================
   Mobile:
   Buttons bleiben nebeneinander, Text wird kleiner.
   ======================================================================== */
@media screen and (max-width: 560px) {
    html body #tarteaucitronRoot #tarteaucitronAlertBig[role="dialog"] {
        width: calc(100vw - 24px) !important;
        max-width: calc(100vw - 24px) !important;
        max-height: calc(100vh - 24px) !important;
        padding: 18px 14px 16px !important;
        border-radius: 20px !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        column-gap: 5px !important;
        row-gap: 10px !important;
    }

    html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigTop:not([role="dialog"]),
    html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigBottom {
        padding: 12px 10px 12px !important;
        max-height: 78vh !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        column-gap: 5px !important;
    }

    html body #tarteaucitronRoot #tarteaucitronAlertBig::before {
        width: 50px !important;
        height: 50px !important;
    }

    html body #tarteaucitronRoot #tarteaucitronDisclaimerAlert {
        font-size: 14px !important;
        line-height: 1.34 !important;
    }

    html body #tarteaucitronRoot #tarteaucitronPersonalize2,
    html body #tarteaucitronRoot #tarteaucitronAllDenied2,
    html body #tarteaucitronRoot #tarteaucitronCloseAlert {
        min-height: 38px !important;
        padding: 7px 4px !important;
        font-size: clamp(9.5px, 2.45vw, 12px) !important;
        line-height: 1.05 !important;
        white-space: nowrap !important;
    }

    html body #tarteaucitronRoot #tarteaucitronPrivacyUrl {
        font-size: 13.5px !important;
    }
}

/* Sehr kleine Displays: weiterhin nebeneinander, aber sehr kompakt */
@media screen and (max-width: 390px) {
    html body #tarteaucitronRoot #tarteaucitronAlertBig[role="dialog"] {
        padding-left: 10px !important;
        padding-right: 10px !important;
        column-gap: 4px !important;
    }

    html body #tarteaucitronRoot #tarteaucitronPersonalize2,
    html body #tarteaucitronRoot #tarteaucitronAllDenied2,
    html body #tarteaucitronRoot #tarteaucitronCloseAlert {
        min-height: 36px !important;
        padding: 6px 3px !important;
        font-size: clamp(8.8px, 2.35vw, 11px) !important;
        letter-spacing: -0.15px !important;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    html body #tarteaucitronRoot #tarteaucitronAlertBig,
    html body #tarteaucitronRoot #tarteaucitronAlertBig *,
    html body #tarteaucitronRoot #tarteaucitronAlertBig button {
        transition: none !important;
    }

    html body #tarteaucitronRoot #tarteaucitronPersonalize2:hover,
    html body #tarteaucitronRoot #tarteaucitronAllDenied2:hover,
    html body #tarteaucitronRoot #tarteaucitronCloseAlert:hover {
        transform: none !important;
    }
}



/* ========================================================================
   ikraMed Consent FINAL v3 - Panel-Fixes
   - Service-Auswahl im Detail-Panel bleibt sichtbar
   - YouTube-Auswahl zeigt pending Zustand bis Speichern
   - reCAPTCHA wird als technisch notwendig nicht auswählbar angezeigt
   - ausgeblendeter Consent-Hinweis fängt keine Klicks mehr ab
   ======================================================================== */

/* Wenn der große Consent-Hinweis ausgeblendet ist, darf er keine Klicks abfangen. */
html body #tarteaucitronRoot:not(.tarteaucitronBeforeVisible) #tarteaucitronAlertBig,
html body #tarteaucitronRoot:not(.tarteaucitronBeforeVisible) #tarteaucitronBack,
html body #tarteaucitronRoot:not(.tarteaucitronBeforeVisible) #tarteaucitronPercentage {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* Das kleine Consent-Icon bleibt klickbar. */
html body #tarteaucitronRoot #tarteaucitronIcon,
html body #tarteaucitronRoot #tarteaucitronIcon button,
html body #tarteaucitronRoot #tarteaucitronManager {
    pointer-events: auto !important;
}

/* Button-Icons nur im großen Banner ausblenden, NICHT im Einstellungs-Panel. */
html body #tarteaucitronRoot #tarteaucitronAlertBig .tarteaucitronCheck,
html body #tarteaucitronRoot #tarteaucitronAlertBig .tarteaucitronCross {
    display: none !important;
}

/* Im Detail-Panel müssen die Häkchen/Kreuze sichtbar bleiben. */
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices .tarteaucitronCheck,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices .tarteaucitronCross {
    display: inline-block !important;
    min-width: 18px !important;
    margin-right: 4px !important;
}

/* reCAPTCHA darf nicht als optionaler Dienst auswählbar sein. */
html body #tarteaucitronRoot #recaptchaLine,
html body #tarteaucitronRoot #tarteaucitronServicesTitle_recaptcha,
html body #tarteaucitronRoot li[id*="recaptcha" i] {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

/* YouTube im Detail-Panel klar sichtbar. */
html body #tarteaucitronRoot #youtubeLine {
    border-left: 4px solid rgba(0, 0, 0, 0.10) !important;
}

html body #tarteaucitronRoot #youtubeAllowed,
html body #tarteaucitronRoot #youtubeDenied {
    opacity: 1 !important;
    cursor: pointer !important;
    transition: background 160ms ease, color 160ms ease, box-shadow 160ms ease !important;
}

/* gespeicherter Zustand */
html body #tarteaucitronRoot #youtubeLine.tarteaucitronIsAllowed #youtubeAllowed,
html body #tarteaucitronRoot #youtubeAllowed[aria-pressed="true"] {
    background: #1B870B !important;
    color: #ffffff !important;
    box-shadow: 0 3px 10px rgba(27, 135, 11, 0.25) !important;
}

html body #tarteaucitronRoot #youtubeLine.tarteaucitronIsDenied #youtubeDenied,
html body #tarteaucitronRoot #youtubeDenied[aria-pressed="true"] {
    background: #9C1A1A !important;
    color: #ffffff !important;
    box-shadow: 0 3px 10px rgba(156, 26, 26, 0.25) !important;
}

/* vorgemerkter Zustand bis Speichern */
html body #tarteaucitronRoot #youtubeAllowed.ikra-consent-pending {
    background: #1B870B !important;
    color: #ffffff !important;
    outline: 2px solid rgba(27, 135, 11, 0.35) !important;
    outline-offset: 2px !important;
}

html body #tarteaucitronRoot #youtubeDenied.ikra-consent-pending {
    background: #9C1A1A !important;
    color: #ffffff !important;
    outline: 2px solid rgba(156, 26, 26, 0.35) !important;
    outline-offset: 2px !important;
}

/* Die Symbole im aktiven YouTube-Button weiß darstellen. */
html body #tarteaucitronRoot #youtubeAllowed[aria-pressed="true"] .tarteaucitronCheck::before,
html body #tarteaucitronRoot #youtubeDenied[aria-pressed="true"] .tarteaucitronCross::before,
html body #tarteaucitronRoot #youtubeAllowed.ikra-consent-pending .tarteaucitronCheck::before,
html body #tarteaucitronRoot #youtubeDenied.ikra-consent-pending .tarteaucitronCross::before {
    color: #ffffff !important;
}

/* Save-Button im Panel deutlich machen. */
html body #tarteaucitronRoot #tarteaucitronSave {
    text-align: center !important;
    padding: 18px 20px !important;
    background: #ffffff !important;
    border-top: 1px solid rgba(0, 0, 0, 0.08) !important;
}

html body #tarteaucitronRoot #tarteaucitronSaveButton {
    min-width: 180px !important;
    min-height: 42px !important;
    border-radius: 999px !important;
    background: #ffffff !important;
    color: #111111 !important;
    border: 1px solid rgba(0, 0, 0, 0.14) !important;
    box-shadow: 0 7px 18px rgba(0, 0, 0, 0.16) !important;
    font-family: Georgia, 'Times New Roman', serif !important;
    font-weight: 700 !important;
    cursor: pointer !important;
}

/* ========================================================================
   ikraMed Consent FINAL v4 - Detailmodus: erst Speichern, dann umsetzen
   - Klick auf „Auswahl anpassen“ öffnet das Einstellungsfenster animiert
   - Die Hauptbuttons werden durch „Abbrechen“ und „Speichern“ ersetzt
   - „Abbrechen“ stellt den ursprünglichen Zustand wieder her
   - Dienst-Auswahl im Panel wird erst nach „Speichern“ übernommen
   ======================================================================== */

body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronAlertBig {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronBack {
    display: block !important;
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    background: rgba(0, 0, 0, 0.28) !important;
    opacity: 1 !important;
    z-index: 2147483644 !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitron {
    display: block !important;
    position: fixed !important;
    top: 50vh !important;
    left: 50vw !important;
    right: auto !important;
    bottom: auto !important;
    transform: translate(-50%, -50%) !important;

    width: min(900px, calc(100vw - 28px)) !important;
    max-width: calc(100vw - 28px) !important;
    height: auto !important;
    max-height: calc(100vh - 28px) !important;
    margin: 0 !important;
    padding: 0 !important;

    background: #ffffff !important;
    border: 0 !important;
    border-radius: 24px !important;
    box-shadow: 0 22px 70px rgba(0, 0, 0, 0.24) !important;
    overflow: hidden !important;
    z-index: 2147483646 !important;
    animation: ikraConsentDetailDrop 260ms ease-out both !important;
}

@keyframes ikraConsentDetailDrop {
    from {
        opacity: 0;
        transform: translate(-50%, -58%) scale(0.985);
    }
    to {
        opacity: 1;
        transform: translate(-50%, -50%) scale(1);
    }
}

body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronClosePanel {
    display: none !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronServices {
    display: flex !important;
    flex-direction: column !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-height: calc(100vh - 28px) !important;
    background: #ffffff !important;
    border-radius: 24px !important;
    box-shadow: none !important;
    overflow: hidden !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronServices > .tarteaucitronLine,
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronMainLineOffset {
    flex: 0 0 auto !important;
    background: #ffffff !important;
    padding: 22px 24px 16px !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08) !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronServices .tarteaucitronBorder {
    flex: 1 1 auto !important;
    min-height: 180px !important;
    max-height: calc(100vh - 220px) !important;
    overflow-y: auto !important;
    background: #ffffff !important;
    border: 0 !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronServices .tarteaucitronTitle,
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronServices .tarteaucitronLine {
    background: #ffffff !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronInfo,
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronInfo * {
    color: #111111 !important;
    font-family: Georgia, 'Times New Roman', serif !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitron .tarteaucitronH1,
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitron .tarteaucitronH2,
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitron .tarteaucitronH3 {
    color: #111111 !important;
    font-family: Georgia, 'Times New Roman', serif !important;
}

/* Abbrechen/Speichern ersetzen die drei Hauptbuttons */
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronSave,
body.ikra-consent-detail-mode #tarteaucitronRoot .ikra-consent-savebar {
    flex: 0 0 auto !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 16px 20px 18px !important;
    background: #ffffff !important;
    border-top: 1px solid rgba(0, 0, 0, 0.08) !important;
    text-align: center !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #ikraConsentCancel,
body.ikra-consent-detail-mode #tarteaucitronRoot #ikraConsentSave,
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronSaveButton {
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-width: 170px !important;
    min-height: 44px !important;
    padding: 10px 22px !important;
    margin: 0 !important;

    border-radius: 999px !important;
    background: #ffffff !important;
    color: #111111 !important;
    border: 1px solid rgba(0, 0, 0, 0.14) !important;
    box-shadow: 0 7px 18px rgba(0, 0, 0, 0.16) !important;

    font-family: Georgia, 'Times New Roman', serif !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.15 !important;
    text-align: center !important;
    cursor: pointer !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #ikraConsentSave,
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronSaveButton {
    border-color: rgba(27, 135, 11, 0.28) !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot #ikraConsentCancel:hover,
body.ikra-consent-detail-mode #tarteaucitronRoot #ikraConsentSave:hover,
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronSaveButton:hover {
    box-shadow: 0 9px 22px rgba(0, 0, 0, 0.20) !important;
    transform: translateY(-1px) !important;
}

/* Auswahlbuttons im Panel: sichtbar und klickbar */
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronServices button[id$="Allowed"],
body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronServices button[id$="Denied"] {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    cursor: pointer !important;
}

/* Vorgemerkte Änderungen allgemein sichtbar machen */
body.ikra-consent-detail-mode #tarteaucitronRoot .ikra-consent-pending-allow {
    border-left: 4px solid rgba(27, 135, 11, 0.50) !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot .ikra-consent-pending-deny {
    border-left: 4px solid rgba(156, 26, 26, 0.50) !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot button[id$="Allowed"].ikra-consent-pending,
body.ikra-consent-detail-mode #tarteaucitronRoot #youtubeAllowed.ikra-consent-pending {
    background: #1B870B !important;
    color: #ffffff !important;
    box-shadow: 0 3px 10px rgba(27, 135, 11, 0.25) !important;
    outline: 2px solid rgba(27, 135, 11, 0.35) !important;
    outline-offset: 2px !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot button[id$="Denied"].ikra-consent-pending,
body.ikra-consent-detail-mode #tarteaucitronRoot #youtubeDenied.ikra-consent-pending {
    background: #9C1A1A !important;
    color: #ffffff !important;
    box-shadow: 0 3px 10px rgba(156, 26, 26, 0.25) !important;
    outline: 2px solid rgba(156, 26, 26, 0.35) !important;
    outline-offset: 2px !important;
}

body.ikra-consent-detail-mode #tarteaucitronRoot button.ikra-consent-pending .tarteaucitronCheck::before,
body.ikra-consent-detail-mode #tarteaucitronRoot button.ikra-consent-pending .tarteaucitronCross::before {
    color: #ffffff !important;
}

/* Original-Save-Leiste aus v3 zurücksetzen, damit Abbrechen/Speichern nebeneinander bleiben. */
html body #tarteaucitronRoot #tarteaucitronSave.ikra-consent-savebar {
    text-align: center !important;
}

@media screen and (max-width: 767px) {
    body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitron {
        width: calc(100vw - 22px) !important;
        max-height: calc(100vh - 22px) !important;
        border-radius: 20px !important;
    }

    body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronServices {
        border-radius: 20px !important;
    }

    body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronServices .tarteaucitronBorder {
        max-height: calc(100vh - 240px) !important;
    }

    body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronSave,
    body.ikra-consent-detail-mode #tarteaucitronRoot .ikra-consent-savebar {
        gap: 8px !important;
        padding: 14px 12px 15px !important;
    }

    body.ikra-consent-detail-mode #tarteaucitronRoot #ikraConsentCancel,
    body.ikra-consent-detail-mode #tarteaucitronRoot #ikraConsentSave,
    body.ikra-consent-detail-mode #tarteaucitronRoot #tarteaucitronSaveButton {
        min-width: 0 !important;
        width: 50% !important;
        padding: 9px 8px !important;
        font-size: 14px !important;
    }
}


/* ========================================================================
   ikraMed Consent Button Slim + Active State
   Muss ganz unten in tarteaucitron.css stehen.
   Ziel:
   - Buttons schlanker und weniger breit
   - sichtbarer Aktivzustand für "Alle akzeptieren" und "Ablehnen"
   - Detail-Panel-Buttons bleiben klickbar und erkennbar
   ======================================================================== */

/* Hauptbanner: schlankere Buttons */
html body #tarteaucitronRoot #tarteaucitronPersonalize2,
html body #tarteaucitronRoot #tarteaucitronAllDenied2,
html body #tarteaucitronRoot #tarteaucitronCloseAlert {
    min-height: 34px !important;
    height: 34px !important;
    padding: 6px 12px !important;
    border-radius: 999px !important;
    font-size: 13px !important;
    line-height: 1.1 !important;
    font-weight: 600 !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.13) !important;
}

/* Middle-Card: Buttons nicht unnötig breit ziehen */
html body #tarteaucitronRoot #tarteaucitronAlertBig[role="dialog"] {
    grid-template-columns: repeat(3, minmax(118px, 170px)) !important;
    column-gap: 8px !important;
}

/* Top/Bottom: Buttons kompakter */
html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigTop:not([role="dialog"]),
html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigBottom {
    grid-template-columns: repeat(3, minmax(118px, 170px)) !important;
    column-gap: 8px !important;
}

/* Sichtbarer Zustand: Alle akzeptieren */
html body #tarteaucitronRoot #tarteaucitronPersonalize2.ikra-consent-active,
html body #tarteaucitronRoot #tarteaucitronPersonalize2[aria-pressed="true"],
html body #tarteaucitronRoot #tarteaucitronPersonalize2:active {
    background: #eef8f0 !important;
    border-color: #2e7d32 !important;
    color: #1b5e20 !important;
    box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.16), 0 4px 12px rgba(0, 0, 0, 0.12) !important;
}

/* Sichtbarer Zustand: Ablehnen */
html body #tarteaucitronRoot #tarteaucitronAllDenied2.ikra-consent-active,
html body #tarteaucitronRoot #tarteaucitronAllDenied2[aria-pressed="true"],
html body #tarteaucitronRoot #tarteaucitronAllDenied2:active {
    background: #fff1f1 !important;
    border-color: #b71c1c !important;
    color: #8b0000 !important;
    box-shadow: 0 0 0 3px rgba(183, 28, 28, 0.14), 0 4px 12px rgba(0, 0, 0, 0.12) !important;
}

/* Sichtbarer Zustand: Auswahl anpassen */
html body #tarteaucitronRoot #tarteaucitronCloseAlert.ikra-consent-active,
html body #tarteaucitronRoot #tarteaucitronCloseAlert[aria-pressed="true"],
html body #tarteaucitronRoot #tarteaucitronCloseAlert:active {
    background: #f3f3f3 !important;
    border-color: #333333 !important;
    color: #111111 !important;
    box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.13), 0 4px 12px rgba(0, 0, 0, 0.12) !important;
}

/* Detail-Panel: erlauben/ablehnen sichtbar darstellen */
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied {
    min-height: 32px !important;
    padding: 6px 12px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(0, 0, 0, 0.14) !important;
    background: #ffffff !important;
    color: #111111 !important;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.10) !important;
    font-family: Georgia, 'Times New Roman', serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
}

/* Detail-Panel: erlaubter Dienst sichtbar */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronIsAllowed button.tarteaucitronAllow,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow[aria-pressed="true"] {
    background: #eef8f0 !important;
    border-color: #2e7d32 !important;
    color: #1b5e20 !important;
    box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.14), 0 3px 10px rgba(0, 0, 0, 0.10) !important;
}

/* Detail-Panel: abgelehnter Dienst sichtbar */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronIsDenied button.tarteaucitronDeny,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny[aria-pressed="true"] {
    background: #fff1f1 !important;
    border-color: #b71c1c !important;
    color: #8b0000 !important;
    box-shadow: 0 0 0 3px rgba(183, 28, 28, 0.13), 0 3px 10px rgba(0, 0, 0, 0.10) !important;
}

/* Detail-Panel: nicht aktiver Gegenbutton neutral */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronIsAllowed button.tarteaucitronDeny,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronIsDenied button.tarteaucitronAllow {
    background: #ffffff !important;
    border-color: rgba(0, 0, 0, 0.14) !important;
    color: #111111 !important;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08) !important;
}

/* Mobile: weiterhin nebeneinander, aber sehr kompakt */
@media screen and (max-width: 820px) {
    html body #tarteaucitronRoot #tarteaucitronAlertBig[role="dialog"],
    html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigTop:not([role="dialog"]),
    html body #tarteaucitronRoot #tarteaucitronAlertBig.tarteaucitronAlertBigBottom {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        column-gap: 6px !important;
    }

    html body #tarteaucitronRoot #tarteaucitronPersonalize2,
    html body #tarteaucitronRoot #tarteaucitronAllDenied2,
    html body #tarteaucitronRoot #tarteaucitronCloseAlert {
        min-height: 32px !important;
        height: auto !important;
        padding: 6px 5px !important;
        font-size: clamp(10px, 1.75vw, 12.5px) !important;
        white-space: nowrap !important;
    }
}

@media screen and (max-width: 420px) {
    html body #tarteaucitronRoot #tarteaucitronPersonalize2,
    html body #tarteaucitronRoot #tarteaucitronAllDenied2,
    html body #tarteaucitronRoot #tarteaucitronCloseAlert {
        min-height: 30px !important;
        padding: 5px 3px !important;
        font-size: clamp(8.8px, 2.35vw, 10.8px) !important;
        letter-spacing: -0.15px !important;
    }
}


/* ========================================================================
   ikraMed Modern Unified Manager UI
   Ziel:
   - einheitlich
   - modern
   - deutlich ruhiger / cleaner
   - keine dunklen unförmigen Blöcke
   - konsistente Buttons und Karten
   ======================================================================== */

:root {
    --ikra-ui-bg: #ffffff;
    --ikra-ui-surface: #fbfbfc;
    --ikra-ui-surface-2: #f5f6f8;
    --ikra-ui-border: #e5e7eb;
    --ikra-ui-border-soft: #eef0f3;
    --ikra-ui-text: #171717;
    --ikra-ui-text-soft: #4b5563;
    --ikra-ui-title: #111827;
    --ikra-ui-green: #2e7d32;
    --ikra-ui-green-bg: #eef8f0;
    --ikra-ui-red: #b71c1c;
    --ikra-ui-red-bg: #fff2f2;
    --ikra-ui-accent: #111111;
    --ikra-ui-shadow: 0 14px 40px rgba(17, 24, 39, 0.08);
    --ikra-ui-shadow-soft: 0 8px 24px rgba(17, 24, 39, 0.06);
    --ikra-ui-radius-lg: 22px;
    --ikra-ui-radius-md: 16px;
    --ikra-ui-radius-sm: 12px;
}

/* Manager-Fläche allgemein */
html body #tarteaucitronRoot #tarteaucitron {
    background: var(--ikra-ui-bg) !important;
    color: var(--ikra-ui-text) !important;
    font-family: Georgia, "Times New Roman", serif !important;
    border: 0 !important;
}

html body #tarteaucitronRoot #tarteaucitron * {
    box-sizing: border-box !important;
}

/* Überschrift */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronTitle,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfoTop {
    color: var(--ikra-ui-title) !important;
    text-align: center !important;
    font-family: Georgia, "Times New Roman", serif !important;
}

html body #tarteaucitronRoot #tarteaucitron .tarteaucitronTitle {
    font-size: 26px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    margin: 8px 0 14px !important;
}

/* Oberer Infoblock – statt dunklem Kasten helle moderne Karte */
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfoTop,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfo {
    background: linear-gradient(180deg, #ffffff 0%, #f8f9fb 100%) !important;
    border: 1px solid var(--ikra-ui-border) !important;
    border-radius: var(--ikra-ui-radius-lg) !important;
    color: var(--ikra-ui-text) !important;
    box-shadow: var(--ikra-ui-shadow-soft) !important;
    padding: 18px 20px !important;
    max-width: 860px !important;
    margin: 0 auto 18px !important;
    text-align: center !important;
}

html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfoTop p,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfo p,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfoTop span,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfo span {
    color: var(--ikra-ui-text) !important;
    font-size: 16px !important;
    line-height: 1.6 !important;
    font-weight: 400 !important;
}

/* Datenschutzerklärung im Info-Bereich */
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfoTop a,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfo a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 40px !important;
    padding: 0 18px !important;
    background: #ffffff !important;
    color: var(--ikra-ui-title) !important;
    border: 1px solid var(--ikra-ui-border) !important;
    border-radius: 999px !important;
    box-shadow: var(--ikra-ui-shadow-soft) !important;
    text-decoration: none !important;
    font-weight: 700 !important;
    font-size: 15px !important;
}

/* Bereich "Einstellungen für alle Dienste" */
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServicesTitle_mandatory,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServicesTitle {
    color: var(--ikra-ui-title) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
}

/* Top-Leiste / alle Dienste Buttons */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronLine.tarteaucitronMainLine {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    flex-wrap: wrap !important;
    padding: 18px 8px 18px !important;
    border-top: 1px solid var(--ikra-ui-border) !important;
    border-bottom: 1px solid var(--ikra-ui-border) !important;
    background: transparent !important;
}

/* Allgemeine Consent-Buttons im Manager */
html body #tarteaucitronRoot #tarteaucitron button,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronAllow,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronDeny,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronSaveButton {
    font-family: Georgia, "Times New Roman", serif !important;
}

/* Moderne Buttons */
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied,
html body #tarteaucitronRoot #tarteaucitron button#ikraConsentCancel,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronSaveButton,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny {
    min-height: 38px !important;
    padding: 8px 18px !important;
    border-radius: 999px !important;
    border: 1px solid var(--ikra-ui-border) !important;
    background: #ffffff !important;
    color: var(--ikra-ui-title) !important;
    box-shadow: var(--ikra-ui-shadow-soft) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.1 !important;
    transition: all 0.18s ease !important;
    cursor: pointer !important;
    text-decoration: none !important;
}

/* Hover */
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed:hover,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied:hover,
html body #tarteaucitronRoot #tarteaucitron button#ikraConsentCancel:hover,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronSaveButton:hover,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow:hover,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 10px 22px rgba(17, 24, 39, 0.10) !important;
}

/* Primärer positiver Button */
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronSaveButton,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronIsAllowed button.tarteaucitronAllow {
    background: var(--ikra-ui-green-bg) !important;
    color: var(--ikra-ui-green) !important;
    border-color: rgba(46, 125, 50, 0.35) !important;
    box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.09), var(--ikra-ui-shadow-soft) !important;
}

/* Negativer Button */
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronIsDenied button.tarteaucitronDeny {
    background: var(--ikra-ui-red-bg) !important;
    color: var(--ikra-ui-red) !important;
    border-color: rgba(183, 28, 28, 0.28) !important;
    box-shadow: 0 0 0 3px rgba(183, 28, 28, 0.08), var(--ikra-ui-shadow-soft) !important;
}

/* Neutraler Cancel */
html body #tarteaucitronRoot #tarteaucitron button#ikraConsentCancel {
    background: #ffffff !important;
    color: var(--ikra-ui-title) !important;
    border-color: var(--ikra-ui-border) !important;
}

/* Dienstekarten */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder {
    border: 1px solid var(--ikra-ui-border-soft) !important;
    border-radius: 18px !important;
    background: var(--ikra-ui-surface) !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 0 14px !important;
    overflow: hidden !important;
}

/* Gruppenheader wie "Notwendige Cookies" / "Videos" */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronTitleGroup,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronH2 {
    background: #f7f8fa !important;
    color: var(--ikra-ui-title) !important;
    border-bottom: 1px solid var(--ikra-ui-border) !important;
    padding: 16px 18px !important;
    margin: 0 !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
}

/* Zeilen pro Dienst */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronLine {
    background: transparent !important;
    border-bottom: 1px solid var(--ikra-ui-border-soft) !important;
    padding: 18px 18px !important;
    margin: 0 !important;
}

html body #tarteaucitronRoot #tarteaucitron .tarteaucitronLine:last-child {
    border-bottom: 0 !important;
}

/* Diensttitel */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronName,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronName strong,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronName b {
    color: var(--ikra-ui-title) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
}

/* Beschreibung */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronAsk,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronDetails,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronDescription,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronText {
    color: var(--ikra-ui-text-soft) !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
}

/* Links "Weiter lesen" */
html body #tarteaucitronRoot #tarteaucitron a {
    color: var(--ikra-ui-title) !important;
    text-decoration: none !important;
}

html body #tarteaucitronRoot #tarteaucitron .tarteaucitronReadmore {
    display: inline-block !important;
    margin-top: 6px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--ikra-ui-text-soft) !important;
}

/* Layout der Dienstzeile */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronLine .tarteaucitronName {
    margin-bottom: 4px !important;
}

/* rechte Buttongruppe */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronLine .tarteaucitronButtons {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
}

/* Unterer Footer mit Abbrechen / Speichern */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBottom {
    position: sticky !important;
    bottom: 0 !important;
    background: rgba(255, 255, 255, 0.96) !important;
    backdrop-filter: blur(10px) !important;
    border-top: 1px solid var(--ikra-ui-border) !important;
    padding: 16px 18px !important;
    margin-top: 14px !important;
}

/* Fokus sichtbar */
html body #tarteaucitronRoot #tarteaucitron button:focus-visible,
html body #tarteaucitronRoot #tarteaucitron a:focus-visible {
    outline: 3px solid rgba(17, 24, 39, 0.18) !important;
    outline-offset: 2px !important;
}

/* Responsive */
@media screen and (max-width: 900px) {
    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronLine.tarteaucitronMainLine {
        align-items: flex-start !important;
    }

    html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfoTop,
    html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfo {
        margin-left: 12px !important;
        margin-right: 12px !important;
        padding: 16px 14px !important;
    }

    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronTitle {
        font-size: 22px !important;
    }
}

@media screen and (max-width: 640px) {
    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronLine {
        padding: 14px 14px !important;
    }

    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronButtons {
        width: 100% !important;
        justify-content: flex-start !important;
        margin-top: 10px !important;
    }

    html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed,
    html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied,
    html body #tarteaucitronRoot #tarteaucitron button#ikraConsentCancel,
    html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronSaveButton,
    html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow,
    html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny {
        min-height: 36px !important;
        padding: 8px 14px !important;
        font-size: 14px !important;
    }

    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronName,
    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronName strong,
    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronName b {
        font-size: 17px !important;
    }
}


/* ========================================================================
   ikraMed Design Variante A
   Clean Medical / ruhig / passend für Praxis- und Login-Seiten
   ======================================================================== */

:root {
    --ikra-a-bg: #ffffff;
    --ikra-a-surface: #ffffff;
    --ikra-a-surface-soft: #f7f8fa;
    --ikra-a-border: rgba(0, 0, 0, 0.10);
    --ikra-a-border-soft: rgba(0, 0, 0, 0.06);
    --ikra-a-text: #111111;
    --ikra-a-text-soft: #4b5563;
    --ikra-a-shadow: 0 18px 50px rgba(0, 0, 0, 0.14);
    --ikra-a-shadow-soft: 0 8px 24px rgba(0, 0, 0, 0.08);
}

/* Consent-Hauptkarte */
html body #tarteaucitronRoot #tarteaucitronAlertBig,
html body #tarteaucitronRoot #tarteaucitronAlertBig[role="dialog"] {
    background: linear-gradient(180deg, #ffffff 0%, #fbfbfc 100%) !important;
    border: 1px solid var(--ikra-a-border) !important;
    box-shadow: var(--ikra-a-shadow) !important;
    border-radius: 26px !important;
}

/* Haupttext */
html body #tarteaucitronRoot #tarteaucitronDisclaimerAlert {
    color: var(--ikra-a-text) !important;
    font-size: 15.5px !important;
    line-height: 1.5 !important;
}

/* Banner Buttons */
html body #tarteaucitronRoot #tarteaucitronPersonalize2,
html body #tarteaucitronRoot #tarteaucitronAllDenied2,
html body #tarteaucitronRoot #tarteaucitronCloseAlert {
    background: #ffffff !important;
    color: #111111 !important;
    border: 1px solid var(--ikra-a-border) !important;
    border-radius: 999px !important;
    box-shadow: var(--ikra-a-shadow-soft) !important;
    min-height: 36px !important;
    height: auto !important;
    padding: 7px 14px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
}

/* Akzeptieren optisch positiv, aber nicht grell */
html body #tarteaucitronRoot #tarteaucitronPersonalize2:hover,
html body #tarteaucitronRoot #tarteaucitronPersonalize2.ikra-consent-active,
html body #tarteaucitronRoot #tarteaucitronPersonalize2[aria-pressed="true"] {
    background: #edf8f0 !important;
    color: #1f6b2a !important;
    border-color: rgba(46, 125, 50, 0.35) !important;
}

/* Ablehnen ruhig rot */
html body #tarteaucitronRoot #tarteaucitronAllDenied2:hover,
html body #tarteaucitronRoot #tarteaucitronAllDenied2.ikra-consent-active,
html body #tarteaucitronRoot #tarteaucitronAllDenied2[aria-pressed="true"] {
    background: #fff3f3 !important;
    color: #8b1111 !important;
    border-color: rgba(183, 28, 28, 0.30) !important;
}

/* Auswahl neutral */
html body #tarteaucitronRoot #tarteaucitronCloseAlert:hover,
html body #tarteaucitronRoot #tarteaucitronCloseAlert.ikra-consent-active,
html body #tarteaucitronRoot #tarteaucitronCloseAlert[aria-pressed="true"] {
    background: #f5f5f5 !important;
    border-color: rgba(0, 0, 0, 0.18) !important;
}

/* Consent Manager */
html body #tarteaucitronRoot #tarteaucitron {
    background: #ffffff !important;
    border-radius: 24px !important;
    box-shadow: 0 22px 80px rgba(0, 0, 0, 0.18) !important;
    overflow: hidden !important;
}

/* Manager Überschrift */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronH1,
html body #tarteaucitronRoot #tarteaucitron #dialogTitle {
    color: #111111 !important;
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    margin: 22px 0 16px !important;
    text-align: center !important;
}

/* Manager Infobox */
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfo,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronInfoTop {
    background: #f8f9fb !important;
    border: 1px solid var(--ikra-a-border-soft) !important;
    color: #111111 !important;
    border-radius: 18px !important;
    box-shadow: none !important;
}

/* Gruppenheader */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronTitle,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronH2 {
    background: #f6f7f9 !important;
    color: #111111 !important;
    border: 0 !important;
    border-bottom: 1px solid var(--ikra-a-border-soft) !important;
    font-weight: 700 !important;
}

/* Dienstzeilen */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronLine {
    background: #ffffff !important;
    border-bottom: 1px solid var(--ikra-a-border-soft) !important;
}

/* Manager Buttons */
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied,
html body #tarteaucitronRoot #tarteaucitron button#ikraConsentCancel,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronSaveButton {
    border-radius: 999px !important;
    min-height: 36px !important;
    padding: 7px 16px !important;
    font-size: 14px !important;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08) !important;
}

/* Untere Speichern-Zeile */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBottom,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronSave {
    background: rgba(255, 255, 255, 0.96) !important;
    border-top: 1px solid var(--ikra-a-border-soft) !important;
    box-shadow: 0 -10px 24px rgba(0, 0, 0, 0.04) !important;
}

/* Responsive */
@media screen and (max-width: 640px) {
    html body #tarteaucitronRoot #tarteaucitronAlertBig[role="dialog"] {
        border-radius: 22px !important;
    }

    html body #tarteaucitronRoot #tarteaucitronPersonalize2,
    html body #tarteaucitronRoot #tarteaucitronAllDenied2,
    html body #tarteaucitronRoot #tarteaucitronCloseAlert {
        font-size: clamp(9px, 2.4vw, 12px) !important;
        padding: 6px 4px !important;
    }
}


/* ========================================================================
   ikraMed Checkboxless Buttons + Correct Active State
   Muss ganz unten in tarteaucitron.css stehen.
   Ziel:
   - keine Kästchen/Checkbox-Symbole in den Buttons
   - "Erlaube alle Cookies" und "Ablehnen" nicht dauerhaft aktiv
   - aktive Darstellung nur bei tatsächlicher Auswahl
   - YouTube Dienstbuttons ebenfalls ohne Kästchen
   ======================================================================== */

/* 1) Checkbox-/Icon-Symbole vollständig aus allen Consent-Buttons entfernen */
html body #tarteaucitronRoot .tarteaucitronCheck,
html body #tarteaucitronRoot .tarteaucitronCross,
html body #tarteaucitronRoot .tarteaucitronCheck::before,
html body #tarteaucitronRoot .tarteaucitronCross::before,
html body #tarteaucitronRoot button .tarteaucitronCheck,
html body #tarteaucitronRoot button .tarteaucitronCross,
html body #tarteaucitronRoot button .tarteaucitronCheck::before,
html body #tarteaucitronRoot button .tarteaucitronCross::before {
    content: none !important;
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
}

/* 2) Alle Manager-Buttons im Standardzustand neutral */
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny {
    background: #ffffff !important;
    color: #111111 !important;
    border: 1px solid rgba(0, 0, 0, 0.13) !important;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08) !important;
}

/* 3) "Alle Cookies erlauben" nur aktiv, wenn wirklich gewählt */
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed.ikra-consent-active,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed[aria-pressed="true"] {
    background: #eef8f0 !important;
    color: #1f6b2a !important;
    border-color: rgba(46, 125, 50, 0.42) !important;
    box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.12), 0 6px 18px rgba(0, 0, 0, 0.08) !important;
}

/* 4) "Alle ablehnen" nur aktiv, wenn wirklich gewählt */
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied.ikra-consent-active,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied[aria-pressed="true"] {
    background: #fff2f2 !important;
    color: #8b1111 !important;
    border-color: rgba(183, 28, 28, 0.38) !important;
    box-shadow: 0 0 0 3px rgba(183, 28, 28, 0.10), 0 6px 18px rgba(0, 0, 0, 0.08) !important;
}

/* 5) Einzelner Dienst erlaubt */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronIsAllowed button.tarteaucitronAllow,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow.ikra-consent-active,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow[aria-pressed="true"] {
    background: #eef8f0 !important;
    color: #1f6b2a !important;
    border-color: rgba(46, 125, 50, 0.42) !important;
    box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.12), 0 6px 18px rgba(0, 0, 0, 0.08) !important;
}

/* 6) Einzelner Dienst abgelehnt */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronIsDenied button.tarteaucitronDeny,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny.ikra-consent-active,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny[aria-pressed="true"] {
    background: #fff2f2 !important;
    color: #8b1111 !important;
    border-color: rgba(183, 28, 28, 0.38) !important;
    box-shadow: 0 0 0 3px rgba(183, 28, 28, 0.10), 0 6px 18px rgba(0, 0, 0, 0.08) !important;
}

/* 7) Gegenbutton immer neutral halten */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronIsAllowed button.tarteaucitronDeny,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronIsDenied button.tarteaucitronAllow {
    background: #ffffff !important;
    color: #111111 !important;
    border-color: rgba(0, 0, 0, 0.13) !important;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08) !important;
}

/* 8) Buttons kompakter und einheitlicher */
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow,
html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny,
html body #tarteaucitronRoot #tarteaucitron button#ikraConsentCancel,
html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronSaveButton {
    min-height: 34px !important;
    padding: 7px 16px !important;
    border-radius: 999px !important;
    font-size: 14px !important;
    line-height: 1.1 !important;
    font-weight: 700 !important;
    text-align: center !important;
}

/* 9) Hauptbanner-Buttons ebenfalls ohne Icons/Kästchen */
html body #tarteaucitronRoot #tarteaucitronAlertBig button .tarteaucitronCheck,
html body #tarteaucitronRoot #tarteaucitronAlertBig button .tarteaucitronCross {
    display: none !important;
}

/* 10) Überschriften nicht wie aktive Buttons aussehen lassen */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronTitle,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronH2 {
    box-shadow: none !important;
}

/* 11) Mobile sauber kompakt */
@media screen and (max-width: 640px) {
    html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllAllowed,
    html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronAllDenied,
    html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronAllow,
    html body #tarteaucitronRoot #tarteaucitron button.tarteaucitronDeny,
    html body #tarteaucitronRoot #tarteaucitron button#ikraConsentCancel,
    html body #tarteaucitronRoot #tarteaucitron button#tarteaucitronSaveButton {
        min-height: 32px !important;
        padding: 6px 12px !important;
        font-size: 13px !important;
    }
}


/* ========================================================================
   ikraMed Consent FINAL Button-Center + All-Choice Interaction
   Muss ganz unten stehen.
   Behebt:
   - Button-Texte wirklich zentriert
   - Häkchen/Kreuz verschieben den Text nicht mehr
   - "Erlaube alle Cookies" und "Ablehnen" reagieren sichtbar
   - vorgemerkte Auswahl bleibt bis Speichern sichtbar
   ======================================================================== */

/* Alle Consent-Buttons als echte Center-Buttons */
html body #tarteaucitronRoot #tarteaucitron button,
html body #tarteaucitronRoot #tarteaucitronAlertBig button,
html body #tarteaucitronRoot #tarteaucitronSaveButton,
html body #tarteaucitronRoot #ikraConsentCancel,
html body #tarteaucitronRoot #tarteaucitronAllAllowed,
html body #tarteaucitronRoot #tarteaucitronAllDenied,
html body #tarteaucitronRoot #youtubeAllowed,
html body #tarteaucitronRoot #youtubeDenied {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    vertical-align: middle !important;
    box-sizing: border-box !important;
    line-height: 1.15 !important;
    white-space: nowrap !important;
    opacity: 1 !important;
    pointer-events: auto !important;
}

/* Icons im Detail-Panel entfernen, damit Text exakt mittig bleibt */
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices .tarteaucitronCheck,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices .tarteaucitronCross,
html body #tarteaucitronRoot #tarteaucitronAllAllowed .tarteaucitronCheck,
html body #tarteaucitronRoot #tarteaucitronAllDenied .tarteaucitronCross,
html body #tarteaucitronRoot #youtubeAllowed .tarteaucitronCheck,
html body #tarteaucitronRoot #youtubeDenied .tarteaucitronCross {
    display: none !important;
    width: 0 !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Oberer Bereich "Einstellungen für alle Dienste" sauber ausrichten */
html body #tarteaucitronRoot #tarteaucitronMainLineOffset {
    display: grid !important;
    grid-template-columns: minmax(220px, 1fr) auto !important;
    align-items: center !important;
    gap: 18px !important;
    width: 100% !important;
    padding: 18px 22px !important;
    margin: 0 !important;
    background: #ffffff !important;
    border-bottom: 1px solid #eceef2 !important;
}

html body #tarteaucitronRoot #tarteaucitronMainLineOffset .tarteaucitronName {
    width: auto !important;
    margin: 0 !important;
    float: none !important;
    text-align: left !important;
}

html body #tarteaucitronRoot #tarteaucitronMainLineOffset .tarteaucitronName .tarteaucitronH2 {
    margin: 0 !important;
    padding: 0 !important;
    color: #111827 !important;
    font-size: 19px !important;
    font-weight: 700 !important;
}

html body #tarteaucitronRoot #tarteaucitronMainLineOffset .tarteaucitronAsk {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    float: none !important;
    width: auto !important;
    margin: 0 !important;
    text-align: right !important;
}

/* Einheitliche kompakte Top-Buttons */
html body #tarteaucitronRoot #tarteaucitronAllAllowed,
html body #tarteaucitronRoot #tarteaucitronAllDenied {
    min-width: 170px !important;
    min-height: 40px !important;
    padding: 9px 18px !important;
    border-radius: 999px !important;
    border: 1px solid #dfe3e8 !important;
    background: #ffffff !important;
    color: #111827 !important;
    box-shadow: 0 7px 18px rgba(17, 24, 39, 0.08) !important;
    font-family: Georgia, 'Times New Roman', serif !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
}

/* Sichtbarer Hover */
html body #tarteaucitronRoot #tarteaucitronAllAllowed:hover,
html body #tarteaucitronRoot #tarteaucitronAllDenied:hover,
html body #tarteaucitronRoot #youtubeAllowed:hover,
html body #tarteaucitronRoot #youtubeDenied:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 10px 24px rgba(17, 24, 39, 0.12) !important;
}

/* Vorgemerkt: alle erlauben */
html body #tarteaucitronRoot #tarteaucitronAllAllowed.ikra-consent-pending,
html body #tarteaucitronRoot #tarteaucitronAllAllowed.ikra-consent-pending-all-allow,
html body #tarteaucitronRoot #tarteaucitronAllAllowed[aria-pressed="true"] {
    background: #eef8f0 !important;
    color: #2e7d32 !important;
    border-color: rgba(46, 125, 50, 0.45) !important;
    box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.14), 0 7px 18px rgba(17, 24, 39, 0.08) !important;
}

/* Vorgemerkt: alle ablehnen */
html body #tarteaucitronRoot #tarteaucitronAllDenied.ikra-consent-pending,
html body #tarteaucitronRoot #tarteaucitronAllDenied.ikra-consent-pending-all-deny,
html body #tarteaucitronRoot #tarteaucitronAllDenied[aria-pressed="true"] {
    background: #fff2f2 !important;
    color: #a31616 !important;
    border-color: rgba(163, 22, 22, 0.42) !important;
    box-shadow: 0 0 0 3px rgba(163, 22, 22, 0.13), 0 7px 18px rgba(17, 24, 39, 0.08) !important;
}

/* YouTube-Buttons ebenfalls exakt zentriert */
html body #tarteaucitronRoot #youtubeAllowed,
html body #tarteaucitronRoot #youtubeDenied {
    min-width: 132px !important;
    min-height: 40px !important;
    padding: 9px 18px !important;
    border-radius: 999px !important;
    border: 1px solid #dfe3e8 !important;
    background: #ffffff !important;
    color: #111827 !important;
    box-shadow: 0 7px 18px rgba(17, 24, 39, 0.08) !important;
    font-family: Georgia, 'Times New Roman', serif !important;
    font-size: 15px !important;
    font-weight: 700 !important;
}

/* Vorgemerkt/gespeichert: YouTube erlauben */
html body #tarteaucitronRoot #youtubeAllowed.ikra-consent-pending,
html body #tarteaucitronRoot #youtubeAllowed[aria-pressed="true"],
html body #tarteaucitronRoot #youtubeLine.tarteaucitronIsAllowed #youtubeAllowed {
    background: #eef8f0 !important;
    color: #2e7d32 !important;
    border-color: rgba(46, 125, 50, 0.45) !important;
    box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.14), 0 7px 18px rgba(17, 24, 39, 0.08) !important;
}

/* Vorgemerkt/gespeichert: YouTube ablehnen */
html body #tarteaucitronRoot #youtubeDenied.ikra-consent-pending,
html body #tarteaucitronRoot #youtubeDenied[aria-pressed="true"],
html body #tarteaucitronRoot #youtubeLine.tarteaucitronIsDenied #youtubeDenied {
    background: #fff2f2 !important;
    color: #a31616 !important;
    border-color: rgba(163, 22, 22, 0.42) !important;
    box-shadow: 0 0 0 3px rgba(163, 22, 22, 0.13), 0 7px 18px rgba(17, 24, 39, 0.08) !important;
}

/* Nicht aktiver Gegenbutton bleibt neutral und nicht ausgegraut */
html body #tarteaucitronRoot #youtubeLine.tarteaucitronIsAllowed #youtubeDenied,
html body #tarteaucitronRoot #youtubeLine.tarteaucitronIsDenied #youtubeAllowed {
    background: #ffffff !important;
    color: #111827 !important;
    border-color: #dfe3e8 !important;
    opacity: 1 !important;
    box-shadow: 0 7px 18px rgba(17, 24, 39, 0.08) !important;
}

/* Abbrechen / Speichern mittig und einheitlich */
html body #tarteaucitronRoot #ikraConsentCancel,
html body #tarteaucitronRoot #tarteaucitronSaveButton {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    min-width: 180px !important;
    min-height: 40px !important;
    padding: 9px 18px !important;
    border-radius: 999px !important;
    font-size: 15px !important;
    line-height: 1.15 !important;
    font-weight: 700 !important;
}

/* Responsive */
@media screen and (max-width: 760px) {
    html body #tarteaucitronRoot #tarteaucitronMainLineOffset {
        grid-template-columns: 1fr !important;
        justify-items: stretch !important;
        gap: 12px !important;
    }

    html body #tarteaucitronRoot #tarteaucitronMainLineOffset .tarteaucitronName {
        text-align: center !important;
    }

    html body #tarteaucitronRoot #tarteaucitronMainLineOffset .tarteaucitronAsk {
        justify-content: center !important;
        width: 100% !important;
    }

    html body #tarteaucitronRoot #tarteaucitronAllAllowed,
    html body #tarteaucitronRoot #tarteaucitronAllDenied {
        min-width: 0 !important;
        flex: 1 1 0 !important;
        font-size: 13px !important;
        padding-left: 10px !important;
        padding-right: 10px !important;
    }
}


/* ========================================================================
   ikraMed Consent FINAL polish
   Wünsche:
   - Hauptfenster: Alle akzeptieren / Ablehnen ändern bei Hover keine Farbe
   - Auswahlfenster: Schließen-Tab entfernen
   - Auswahlfenster: nur Dienst-/Cookie-Liste scrollt, nicht das komplette Fenster
   ======================================================================== */

/* 1) Hauptfenster: keine Farbänderung bei Hover für Alle akzeptieren / Ablehnen */
html body #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronPersonalize2:hover,
html body #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronAllDenied2:hover {
    background: #ffffff !important;
    color: #111111 !important;
    border-color: rgba(0, 0, 0, 0.12) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.13) !important;
    transform: none !important;
}

/* Hauptfenster: auch bei Focus/Active neutral halten, solange nicht bewusst geklickt/aktiv */
html body #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronPersonalize2:focus,
html body #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronAllDenied2:focus {
    background: #ffffff !important;
    color: #111111 !important;
}

/* 2) Auswahlfenster: Schließen-Tab oben rechts entfernen */
html body #tarteaucitronRoot #tarteaucitronClosePanel,
html body #tarteaucitronRoot #tarteaucitronCloseCross,
html body #tarteaucitronRoot button#tarteaucitronClosePanel {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* 3) Auswahlfenster: Modal selbst nicht komplett scrollen */
html body #tarteaucitronRoot #tarteaucitron {
    overflow: hidden !important;
    max-height: min(88vh, 760px) !important;
    height: auto !important;
    display: none;
    flex-direction: column !important;
    background: #ffffff !important;
    border-radius: 22px !important;
}

/* Wenn tarteaucitron das Panel öffnet, bleibt es flexfähig */
html body #tarteaucitronRoot #tarteaucitron[style*="display: block"] {
    display: flex !important;
}

/* Services-Bereich als Spalte aufbauen */
html body #tarteaucitronRoot #tarteaucitronServices {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    max-height: min(88vh, 760px) !important;
    overflow: hidden !important;
    background: #ffffff !important;
}

/* Oberer Infotext und Hauptzeile bleiben oben sichtbar */
html body #tarteaucitronRoot #tarteaucitronInfo,
html body #tarteaucitronRoot #tarteaucitronInfoTop,
html body #tarteaucitronRoot #tarteaucitronMainLineOffset {
    flex: 0 0 auto !important;
}

/* Nur die eigentliche Dienst-/Cookie-Liste scrollt */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder {
    flex: 1 1 auto !important;
    min-height: 180px !important;
    max-height: none !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    border-radius: 0 !important;
}

/* Falls tarteaucitron intern UL/Listen schachtelt, Scroll nur auf Border belassen */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder > ul {
    overflow: visible !important;
}

/* Unterer Speichern-/Abbrechen-Bereich bleibt unten sichtbar */
html body #tarteaucitronRoot #tarteaucitronSave,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBottom,
html body #tarteaucitronRoot #tarteaucitron .ikra-consent-detail-actions {
    flex: 0 0 auto !important;
    position: sticky !important;
    bottom: 0 !important;
    z-index: 3 !important;
    background: rgba(255, 255, 255, 0.96) !important;
    backdrop-filter: blur(10px) !important;
    border-top: 1px solid #eceef2 !important;
}

/* Scrollbar etwas dezenter */
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder::-webkit-scrollbar {
    width: 9px;
}

html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder::-webkit-scrollbar-track {
    background: #f3f4f6;
    border-radius: 999px;
}

html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder::-webkit-scrollbar-thumb {
    background: #c9cdd3;
    border-radius: 999px;
    border: 2px solid #f3f4f6;
}

/* Mobile: Auswahlfenster fast volle Höhe, aber weiterhin nur Liste scrollen */
@media screen and (max-width: 767px) {
    html body #tarteaucitronRoot #tarteaucitron,
    html body #tarteaucitronRoot #tarteaucitronServices {
        max-height: 92vh !important;
        height: auto !important;
    }

    html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder {
        min-height: 160px !important;
    }
}

