/*
    COMMON AND MODAL STYLING
*/

BODY.common,BODY .col-colored.common {
    --dark-color: #0d3353;
    --secondary-color: #2c5c85;
    --main-color: #007aad;
    --light-color: #469ed4;
    --background-color: #b4d0eb;
    --btn-outline-primary-hover-background-color: #e1ecf7;
    --btn-outline-primary-hover-border-color: #2c5c85
}

BODY.academy,BODY .col-colored.academy {
    --dark-color: #501232;
    --secondary-color: #84355d;
    --main-color: #ad325d;
    --light-color: #e3306d;
    --background-color: #fad7e7;
    --btn-outline-primary-hover-background-color: #ffeff3;
    --btn-outline-primary-hover-border-color: #84355d
}

BODY.assistance,BODY .col-colored.assistance {
    --dark-color: #124350;
    --secondary-color: #245967;
    --main-color: #3d808c;
    --light-color: #37a5b2;
    --background-color: #b5dee3;
    --btn-outline-primary-hover-background-color: #e1f2f4;
    --btn-outline-primary-hover-border-color: #245967
}

BODY.health,BODY .col-colored.health {
    --dark-color: #efd700;
    --secondary-color: #f39200;
    --main-color: #fbbb21;
    --light-color: #ffde14;
    --background-color: #fff265;
    --btn-outline-primary-hover-background-color: #fff9c7;
    --btn-outline-primary-hover-border-color: #f39200
}

BODY.learning,BODY .col-colored.learning {
    --dark-color: #3b440d;
    --secondary-color: #61682b;
    --main-color: #889b32;
    --light-color: #bbc914;
    --background-color: #d2dd79;
    --btn-outline-primary-hover-background-color: #edf1c9;
    --btn-outline-primary-hover-border-color: #61682b
}


/*
    --dark-color:
    --secondary-color:
    --main-color:
    --light-color:
    --background-color:
    --btn-outline-primary-hover-background-color:

    This variables are defined in fsde-theme (color_schemes)
*/

.common {
    --cta-button-for-modal-base-color: #AD325D;
    --cta-button-for-modal-hover-color: #E3306D;
}

.academy {
    --cta-button-for-modal-base-color: #889B32;
    --cta-button-for-modal-hover-color: #BBC914;
}

.assistance {
    --cta-button-for-modal-base-color: #FBBB21;
    --cta-button-for-modal-hover-color: #FFDE14;
}

.health {
    --cta-button-for-modal-base-color: #3D808C;
    --cta-button-for-modal-hover-color: #469ED4;
}

.learning {
    --cta-button-for-modal-base-color: #007AAD;
    --cta-button-for-modal-hover-color: #469ED4;
}

.cta-formular {
    --cta-input-border-color: var(--light-color);
    --cta-icon-color: var(--main-color);
    --cta-button-base-color: var(--main-color);
    --cta-button-hover-color: var(--light-color);
    --cta-input-hover-color: var(--btn-outline-primary-hover-background-color)
}

BODY .cta-formular .form-wrapper .cta-form .description-border{
    color: var(--dark-color);
    background-color: var(--btn-outline-primary-hover-background-color);
    border-color: var(--btn-outline-primary-hover-border-color);
}


BODY .cta-formular .form-wrapper .cta-form .row {
    max-width: 680px;
}

BODY .cta-formular .form-wrapper .form-body {
    max-width: 750px;
}

BODY .cta-formular .form-wrapper {
    display: none;
}

BODY .cta-formular .form-dialog {
    position: relative;
    top: 0;
    bottom: 40px;
}

BODY .cta-formular .form-dialog .form-content {
    box-shadow: 0 0 30px #0000001A;
    border-radius: 8px;
}

BODY .cta-formular .form-wrapper .form-body-content {
    padding-top: 5px;
}


BODY .cta-formular .form-wrapper .form-body .cta-modal-form-title {
    display: block;
    text-align: center;
    padding-left: 20px;
    padding-right: 20px;
    line-height: 48px;
    font-size: 40px;
    font-family: GothamLight, sans-serif;
}

BODY .cta-formular .form-wrapper .form-body .cta-modal-form-title strong {
    font-family: GothamBold, sans-serif;
    line-height: normal;
}

BODY .cta-formular .form-wrapper .cta-success-title {
    padding-left: 10px;
    padding-right: 10px;
    font-size: 40px;
    font-family: GothamLight, sans-serif;
}

BODY .cta-formular .form-wrapper .cta-success-title strong {
    font-family: GothamBold, sans-serif;
    line-height: normal;
}

BODY .cta-formular .form-wrapper .cta-success-info-text,BODY .cta-formular .form-wrapper .info-text  {
    font-size: 20px;
    font-family: Verdana, serif;
    color: #333333;
}

BODY .cta-formular .form-wrapper .cta-success-icon {
    color: var(--cta-icon-color);
}


BODY .cta-formular .form-wrapper .cta-error-title {
    padding-left: 10px;
    padding-right: 10px;
    font-size: 40px;
    font-family: GothamLight, sans-serif;
}

BODY .cta-formular .form-wrapper .cta-error-title strong {
    font-family: GothamBold, sans-serif;
    line-height: normal;
}

BODY .cta-formular .form-wrapper .cta-error-info-text {
    text-align: center;
    font-size: 20px;
    font-family: Verdana, serif;
    color: #333333;
}

BODY .cta-formular .form-wrapper .cta-error-icon {
    color: var(--cta-icon-color);
}

BODY .cta-inline-content .custom-alert{
    padding: 25px 0 40px 0;
    background-color: #fff;
    border-top: 8px solid;
    border-bottom: 1px solid #dee2e6;
    border-right: 1px solid #dee2e6;
    border-left: 1px solid #dee2e6;
    border-radius: 0.3rem!important;
    box-shadow: 0 .125rem .25rem rgba(0,0,0,.075)!important;
}

BODY .cta-inline-content .custom-success-alert{
    border-top-color: #198754;
}

BODY .cta-inline-content .custom-error-alert{
    border-top-color: #CF3445;
}

/*
    FORM INPUT FIELDS
 */
BODY .cta-formular .form-wrapper .cta-form .cta-select-input,
BODY .cta-formular .form-wrapper .cta-form .cta-input {
    display: flex;
    position: relative;
}

BODY .cta-formular .form-wrapper .cta-form .cta-select-input,
BODY .cta-formular .form-wrapper .cta-form .cta-text-input {
    width: 100%;
    height: 50px;
    padding-left: 10px;
    padding-right: 10px;
}

BODY .cta-formular .form-wrapper .cta-form .cta-textarea-input {
    width: 100%;
    height: 200px;
    padding-left: 10px;
    padding-right: 10px;
    padding-top: 8px;
}

BODY .cta-formular .form-wrapper .cta-form .cta-select-input,
BODY .cta-formular .form-wrapper .cta-form .cta-textarea-input,
BODY .cta-formular .form-wrapper .cta-form .cta-text-input {
    border: 2px solid var(--cta-input-border-color);
    border-radius: 10px;
    opacity: 1;
    background: white no-repeat 0 0;
    margin-bottom: 0;
    font-size: 16px;
    font-family: Verdana, sans-serif;
}

BODY .cta-formular .form-wrapper .cta-form .cta-select-input:required {
    background-color: gold;
}

BODY .cta-formular .form-wrapper .cta-form .cta-input .cta-checkbox-label a{
    color: #007aad;
}


BODY .cta-formular .form-wrapper .cta-form .cta-select-input:hover,
BODY .cta-formular .form-wrapper .cta-form .cta-select-input:focus,
BODY .cta-formular .form-wrapper .cta-form .cta-textarea-input:hover,
BODY .cta-formular .form-wrappermodal .cta-form .cta-textarea-input:focus,
BODY .cta-formular .form-wrapper .cta-form .cta-textarea-input:focus,
BODY .cta-formular .form-wrapper .cta-form .cta-text-input:hover,
BODY .cta-formular .form-wrapper .cta-form .cta-text-input:focus {
    background-color: var(--cta-input-hover-color);
    outline: none;
}

BODY .cta-formular [type="checkbox"]:checked,
BODY .cta-formular [type="checkbox"]:not(:checked) {
    position: absolute;
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    width: 1px;
    padding: 0;
    border: 0;
    overflow: hidden;
}

BODY .cta-formular [type="checkbox"]:checked + label,
BODY .cta-formular [type="checkbox"]:not(:checked) + label {
    position: relative;
    padding-left: 45px;
    cursor: pointer;
    line-height: 29px;
    display: inline-block;
    color: #666;
    margin-bottom: 0;
}

BODY .cta-formular [type="checkbox"]:checked + label:before,
BODY .cta-formular [type="checkbox"]:not(:checked) + label:before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 30px;
    height: 30px;
    border-radius: 6px;
    border: 2px solid var(--cta-input-border-color);
    background: #fff;
}

BODY .cta-formular [type="checkbox"].error-border:invalid + label:before {
    border-color: #F96C6C !important;
}

BODY .cta-formular [type="checkbox"]:valid + label:before {
    border-color: var(--cta-input-border-color);
}

BODY .cta-formular [type="checkbox"]:checked + label:after,
BODY .cta-formular [type="checkbox"]:not(:checked) + label:after {
    content: '';
    width: 8px;
    height: 8px;
    background: var(--cta-input-border-color);
    position: absolute;
    top: 6px;
    left: 6px;
}

BODY .cta-formular [type="checkbox"]:not(:checked) + label:after {
    opacity: 0;
    --webkit-transform: scale(0);
    transform: scale(0);
}

BODY .cta-formular [type="checkbox"]:checked + label:after {
    left: 3px;

    opacity: 1;
    --webkit-transform: scale(1);
    transform: scale(1);
    clip-path: polygon(22% 33%, 15% 40%, 41% 73%, 100% 20%, 93% 11%, 42% 59%);
    height: 23px;
    width: 23px;
}

BODY .cta-formular input[type="checkbox"]:focus-visible + label {
    outline: dashed 2px lightgrey;
    outline-offset: 5px;
}

/*
    radio buttons
*/

BODY .cta-formular .form-wrapper .cta-form .cta-radio-item input[type="radio"] {
    position: absolute;
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    width: 1px;
    padding: 0;
    border: 0;
    overflow: hidden;
}

BODY .cta-formular .form-wrapper .cta-form .cta-radio-item .cta-radio-label:before {
    content: " ";
    display: inline-block;
    position: relative;
    top: 9px;
    margin: 0 10px 0 0;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 2px solid var(--cta-input-border-color);
    background-color: transparent;
}

BODY .cta-formular .form-wrapper .cta-form .cta-radio-item input[type="radio"]:checked + .cta-radio-label:after {
    border-radius: 12px;
    width: 23px;
    height: 21px;
    position: absolute;
    top: 16px;
    left: 9px;
    content: " ";
    display: block;
    background: var(--cta-input-border-color);
    clip-path: polygon(22% 33%, 15% 40%, 41% 73%, 100% 20%, 93% 11%, 42% 59%);
}

BODY .cta-formular .form-wrapper .cta-form .cta-radio-grid {
    margin-bottom: 6px;
}

BODY .cta-formular .form-wrapper .cta-form .cta-radio-item {
    display: inline-block;
    position: relative;
    padding: 0 6px;
    margin: 10px 0 0;
}

BODY .cta-formular .form-wrapper .cta-form .cta-radio-item .cta-radio-label {
    margin-right: 10px;
    display: inline-block;

    color: #6b6b6b;
    font-weight: normal;
    font-size: 14px;
    font-family: Verdana, sans-serif;
}

BODY .cta-formular input[type="radio"]:focus-visible + .cta-radio-label {
    outline: dashed 2px lightgrey;
    outline-offset: 5px;
}

/*
    ERROR MESSAGES FROM VALIDATION (BACKEND)
 */

BODY .cta-formular .form-wrapper .cta-form .cta-error-div {
    padding-bottom: 0;
}

BODY .cta-formular .pme-errors {
    width: 100%;
    color: #F96C6C;
    font-family: Verdana, sans-serif;
    font-size: 0.8125rem;
    margin-top: 4px;
    text-align: left;
}

BODY .cta-formular .cta-error {
    display: block;
    margin-top: 5px;
    text-align: center;
    padding: 10px 0 10px 0;
    color: #d80000;
    font-size: 16px;
    font-family: Verdana, sans-serif;
}

.cta-error-div{
    color: #D32F2F;
    font-size: 0.8125rem;
    margin-top: 4px;
    text-align: left;
}

.error-border{
    border-color: #F96C6C !important;
    background-position: right 10px center!important;
    background-repeat: no-repeat!important;
    background-size: 16px auto!important;
    background-image: url("data:image/svg+xml;base64,PHN2ZyBpZD0iQ29tcG9uZW50XzE1Nl8xIiBkYXRhLW5hbWU9IkNvbXBvbmVudCAxNTYg4oCTIDEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2IiB2aWV3Qm94PSIwIDAgMTYgMTYiPgogIDxwYXRoIGlkPSJQYXRoXzM1IiBkYXRhLW5hbWU9IlBhdGggMzUiIGQ9Ik04LDBhOCw4LDAsMSwwLDgsOEE4LjAyNCw4LjAyNCwwLDAsMCw4LDBaTTkuMSwxMi4ySDYuOVYxMC4zSDkuMnYxLjlabS4xLTcuNEw4LjYsOS4ySDcuNEw2LjgsNC44di0xSDkuM3YxWiIgZmlsbD0iI2Y5NmM2YyIvPgo8L3N2Zz4K") !important;
}

.error-border-top{
    background-position: right 10px top 15px!important;
}

/*
    BUTTONS COMMON
 */

BODY .cta-formular .btn {
    line-height: 17px;
    font-weight: bold;
    font-variant: normal;
    font-style: normal;
    font-size: 14px;
    font-family: Verdana, serif;
}


BODY .cta-formular .btn:hover,
BODY .cta-formular .btn:focus {
    color: white;
    box-shadow: none;
}


/*
    FORM CLOSE BUTTON
 */
BODY .cta-formular .form-wrapper .cta-modal-close-button {
    background-color: transparent;
    margin-right: 2px;
}

BODY .cta-formular .form-wrapper .cta-modal-close-button-text {
    color: var(--cta-button-base-color);

    font-size: 33px;
    font-weight: 200;
}

BODY .cta-formular .form-wrapper .cta-modal-close-button-text:hover,
BODY .cta-formular .form-wrapper .cta-modal-close-button-text:focus {
    filter: brightness(1.2);
}

/*
    FORM SUBMIT BUTTON
 */
BODY .cta-formular .form-wrapper button.cta-form-button {
    width: 50%;
    height: 50px;
    padding: 10px 16px;

    border-radius: 5px;
    color: white;
    background-color: var(--cta-button-base-color);
    -webkit-transition: 200ms; /* For Safari 3.1 to 6.0 */
    transition: 200ms;
}

BODY .cta-formular .form-wrapper button.cta-form-button:hover,
BODY .cta-formular .form-wrapper button.cta-form-button:focus {
    background-color: var(--cta-button-hover-color);
}

/*
    BUTTON FOR OPENING OF THE MODAL WINDOW
 */
BODY .cta-formular .cta-button-for-modal {
    width: 300px;
    height: 50px;

    padding-top: 8px;

    border-radius: 7px;
    background-color: var(--cta-button-for-modal-base-color);
}

BODY .cta-formular .cta-button-for-modal:hover,
BODY .cta-formular .cta-button-for-modal:focus {
    background-color: var(--cta-button-for-modal-hover-color);
}

BODY .cta-formular .cta-button-for-modal-div {
    text-align: center;
}

/*
    REDIRECT-BUTTON IN CONFIRMATION-MODAL
*/
BODY .cta-formular .form-wrapper .cta-form-redirect-button {

}

BODY .cta-formular .form-wrapper INPUT:required::placeholder,
BODY .cta-formular .form-wrapper SELECT:required::placeholder {
    color: #A9A9A9;
    text-transform: capitalize;
}

BODY .cta-formular .form-wrapper .cta-input:has(> .cta-text-input:required) .floating-label::after,
BODY .cta-formular .form-wrapper .cta-input:has(SELECT:required)::after {
    color: inherit;
    content: "*";
}

BODY .cta-formular .form-wrapper .cta-input[required]::placeholder {
    content: "*";
    color: #A9A9A9;
    position: absolute;
    right: 0;
}


BODY .cta-formular .form-wrapper .cta-input .cta-radio-grid:has(.cta-radio-input:required)::after {
    color: #A9A9A9;
    content: "*";
    top: -10px;
    position: relative;
}



/*
    STYLING FOR SMALLER SCREENS
 */
@media (max-width: 768px) and (min-width: 576px) {
    BODY .cta-formular .form-dialog .form-body .form-body-content {
        padding-left: 10px;
        padding-right: 10px;
    }

    BODY .cta-formular .form-dialog {
        width: 90% !important;
        margin: 0 auto;
    }

    BODY .cta-formular .form-wrapper .cta-form .cta-modal-form-title {
        padding-left: 0;
        padding-right: 0;
        line-height: inherit;

        font-size: 34px;
    }
}

@media (min-width: 768px) {
    BODY .cta-formular .form-dialog {
        max-width: 97%;
        margin: 0 auto;
        position: absolute;
        left: calc(50% - 375px);
        right: calc(50% - 375px);
    }
}

@media (min-width: 768px) {

    BODY .cta-formular .form-dialog .form-body .form-body-content {
        padding-left: 30px;
        padding-right: 30px;
    }
}

@media (max-width: 576px) {
    BODY .cta-formular .form-dialog .form-body .form-body-content {
        padding-left: 0;
        padding-right: 0;
    }

    BODY .cta-formular .form-dialog {
        width: 94% !important;
        left: 1%;
        margin: 0 auto;
    }

    BODY .cta-formular .form-wrapper button.cta-form-button {
        width: 90%;
    }

    BODY .cta-formular .form-wrapper .cta-form .cta-radio-label {
        margin-right: 10px !important;
    }

    BODY .cta-formular .form-wrapper .cta-form .cta-modal-form-title {
        padding-left: 10px;
        padding-right: 10px;
        line-height: inherit;
        font-size: 28px;
    }

    BODY .cta-formular .form-wrapper .cta-success-title {
        padding-left: 10px;
        padding-right: 10px;
        line-height: inherit;
        font-size: 28px;
    }

    BODY .cta-formular .form-wrapper .cta-success-title {
        padding-left: 10px;
        padding-right: 10px;
        line-height: inherit;
        font-size: 28px;
    }

    BODY .cta-formular [type="checkbox"]:checked + label,
    BODY .cta-formular [type="checkbox"]:not(:checked) + label {
        position: relative;
        padding-left: 35px;
        cursor: pointer;
        line-height: 29px;
        display: inline-block;
        color: #666;
        margin-bottom: 0;
        font-size: 12px;
    }
}


@media (min-height: 850px) {
    .cta-formular .cta-error-modal-title {
        margin-bottom: 80px
    }

    .cta-formular .cta-error-modal-info {
        margin-bottom: 100px;
    }

    .cta-formular .cta-error-icon-container {
        margin-bottom: 160px;
    }

    .cta-formular .cta-success-title {
        margin-bottom: 70px;
    }
    .cta-formular .cta-success-info-text {
        margin-bottom: 120px;
    }

    .cta-formular .cta-success-icon-container {
        margin-bottom: 170px;
    }
}


@media (max-height: 850px) {
    .cta-formular .cta-error-modal-title {
        margin-bottom: 30px;
    }

    .cta-formular .cta-error-modal-info {
        margin-bottom: 30px;
    }

    .cta-formular .cta-error-icon-container {
        margin-bottom: 30px;
    }
    .cta-formular .cta-error-icon {
        width: 130px;
    }
    .cta-formular .cta-success-title {
        margin-bottom: 30px;
    }

    .cta-formular .cta-success-info-text {
        margin-bottom: 30px;
    }

    .cta-formular .cta-success-icon-container {
        margin-bottom: 30px;
    }
    .cta-formular .cta-success-icon {
        width: 130px;
    }
}
.portlet .portlet-boundary_kontaktformular_WAR_kontaktformular_ {
}


/*
    RECAPTCHA
 */

#captcha-element {
    margin-top: 13px;
}

#captcha-element div {
    height: 100% !important;
    margin-left: 2px;
}


::-webkit-input-placeholder {
    color: #aaa;
}

::-moz-placeholder {
    color: #aaa;
}

:-ms-input-placeholder {
    color: #aaa;
}

:-moz-placeholder {
    color: #aaa;
}


BODY .cta-formular .form-wrapper .cta-form .cta-input .floating-label {
    position: absolute;
    top: 18px;
    left: 10px;
    pointer-events: none;
    transition: 0.2s all ease-out;
    font-size: 0.875rem;
    line-height: 1em;
    color: #6c757d;
    border-top: 1px solid transparent;
    margin-bottom: 0;
}

BODY .cta-formular .form-wrapper .cta-form .cta-input .floating-label.active{
    top: -9px;
    font-size: 12px;
    z-index: 1;
    padding: 2px 4px;
    transform: translateY(0);
    display: block;
    color: var(--main-color);
    background: #ffffff;
    line-height: 12px;
}

.has-error .floating-label.active {
    color: #D32F2F !important;
}

.ui-timepicker-wrapper {
    width: 9.7em;!important;
}

li.ui-timepicker-selected,
.ui-timepicker-list li:hover,
.ui-timepicker-list .ui-timepicker-selected:hover {
    background: var(--main-color) !important;
}

/*Chrome auto fill background color*/
input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px white inset !important;
}