/* -------------------------------------------------------------------------------- Form -----*/


.extra-margin {
    height:20px;
}

.kontaktform {
    --hs-bg: rgb(212, 151, 122);
    --hs-ink: rgb(36, 50, 38);              /* Text */
    --hs-muted: rgb(36, 50, 38);         /* Labels */
    --hs-line: rgb(36, 50, 38);  /* Trennlinien */
    --hs-accent: #d0043a;        /* Button-Hintergrund */
    --hs-accent-ink: #e5e5e1;    /* Button-Text */
    margin:0 auto;
    position:relative;
    font-size: 0.9rem;
    font-weight: 600;
}

#mainWrapper .section.footer .formWrapper {
    position: relative;
    margin: 6vw 0;
    display: none;
    opacity: 0;
    transition: opacity 0.6s ease-in-out;
}

#mainWrapper .section.footer .formWrapper.open {
    opacity: 1;
}

/* -------------------------------------------------------------------------------- Typo -----*/

.kontaktform br {
    display: block;
}


.kontaktform h3 {
    margin: 0 0 30px 0
}

.thankyou h3 {
    font-size: 1.6rem;
}


.kontaktform h3.h4 {
}

.thankyou .small {
    font-size:0.7rem;
    line-height: 125%;
}

.kontaktform .small {
    margin: 20px 0 7px 0 !important;
    font-size:0.7rem;
    opacity:0.7
}

.kontaktform .small a {
    text-decoration:underline
}

.kontaktform .formIntro {
    margin: 0 0 50px 0;
}

.kontaktform .formIntro h3 {

}

/* -------------------------------------------------------------------------------- Layout -----*/

.no-margin {
    margin:0 !important;
}

.small-margin {
    margin:14px 0 0 0 !important;
}

.kontaktform .hs-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: start;
    margin:0 0 20px 0;
    gap:20px;
}

/* -------------------------------------------------------------------------------- Form Elements -----*/

.kontaktform .hs-col label,
.kontaktform .spamschutz label{
    display: block;
    margin: 0;
    color: var(--hs-muted);
}

.kontaktform .hs-col label .smalllbl {
    font-size:0.8rem !important;
    letter-spacing: 0 !important;
    text-transform:none !important;
    font-weight:100 !important;
}

.kontaktform input[type="text"],
.kontaktform input[type="email"],
.kontaktform input[type="tel"],
.kontaktform input[type="date"],
.kontaktform input[type="time"],
.kontaktform input[type="number"],
.kontaktform select,
.kontaktform textarea,
.kontaktform input.wpcf7-file {
    width: 100%;
    background: transparent;
    border: none;
    height: 2.507em;
    border-bottom: 1px solid var(--hs-line);
    padding: 0;
    color: var(--hs-ink);
    outline: none;
    border-radius: 0;
    box-shadow:none !important;
    margin: 0;
}

.kontaktform input[type="file"]{
    font-size: 0.8rem;
    background:transparent;
    border:none;
    padding:0 0 7px 0;
    color:rgba(0,0,0,.7);
    height:auto !important;
}

/* Der eigentliche Button */
.kontaktform input[type="file"]::file-selector-button{
    background: #d0043a;
    color: #FFF;
    border: none;
    border-radius: 9999px;
    padding: 8px 12px;
    font-weight: 700;
    letter-spacing: .02em;
    cursor: pointer;
    margin:10px 8px 0 0;
    transition: transform .08s ease, filter .2s ease;
    font-size:0.8rem;
}

.kontaktform input[type="file"]::file-selector-button:hover{ filter:brightness(1.05); }

/* Fallback für Safari/ältere WebKit */
.kontaktform input[type="file"]::-webkit-file-upload-button{
    background: #d0043a;
    color: #FFF;
    border:none; border-radius:9999px; padding: 8px 12px; font-weight:700; cursor:pointer;
}

.kontaktform .hs-select{ position:relative; }
.kontaktform .hs-select select{
    -webkit-appearance:none; appearance:none; padding-right:40px;
    background:transparent;
    cursor:pointer
}
.kontaktform .hs-select::after{
    content:"";
    position:absolute; right:3px; top:45%; transform:translateY(-50%);
    width:0; height:0;
    border-left:6px solid transparent;
    border-right:6px solid transparent;
    border-top:7px solid #222; /* Pfeilfarbe */
    pointer-events:none;
}


.kontaktform input[type="date"] {
    cursor:text
}

.kontaktform textarea {
    min-height: 80px;
    border-bottom: 1px solid var(--hs-line);
    padding: 0;
    margin: 8px 0 20px 0;
    resize: none;
    font-size:0.9rem;
    font-family:inherit;
    line-height:1.2;
    font-family:"basier_squareregular", sans-serif;
}

textarea::placeholder,
input::placeholder{
    color:var(--hs-ink);
    opacity: 0.8;
    font-size:0.8rem;
    line-height:1.2
}

.kontaktform .hs-help {
    display: block;
    font-size: 0.7rem;
    margin:0 0 0 0;

}

.kontaktform .hs-actions .wpcf7-spinner {
    display:none;
}

.kontaktform .hs-submit,
.kontaktform input[type="submit"].hs-submit {
    background: var(--hs-accent);
    color: var(--hs-accent-ink);
    font-weight: 800;
    border: none;
    border-radius: 20px;
    padding: 5px 25px;
    font-size: 1rem;
    cursor: pointer;
    margin:0 !important;
    opacity:1;
    box-shadow:none;
    transition: all 0.6s ease-in-out;
}
.kontaktform .hs-submit:hover {
    opacity:0.7 !important
}

.kontaktform .hs-submit:active {
    transform: translateY(0);
}

.kontaktform .hs-submit:disabled {
    opacity: 0.3 !important;
    cursor: default !important;
}

.kontaktform .wpcf7-acceptance .wpcf7-list-item {
    margin: 0;
}
.kontaktform .wpcf7-acceptance input[type="checkbox"] {
    width: 22px; height: 22px;
    margin-right: 10px; vertical-align: middle;
}


.kontaktform .datenschutz,
.kontaktform .datenschutzct,
.kontaktform .datenschutzjob {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: 20px 1fr;
    grid-column-gap: 8px;
    margin: 8px 0 20px 0
}

.jobForm {
    padding: 5vw 0 0 0;
    max-width: calc(100% - 16vw);
}

.jobformWrapper {
    padding: 0 0 100px 0;
}

.jobformWrapper .kontaktform .datenschutz-col.extra-padding {
    padding:25px 0 20px 0;
}

.jobformWrapper .kontaktform h3 {
    font-size: 2.5rem;
    text-transform: uppercase;
}

.kontaktform .datenschutz-col.extra-padding {
    padding:0 0 20px 0;
}

.kontaktform .datenschutz label,
.kontaktform .datenschutzct label,
.kontaktform .datenschutzjob label{
    margin:0
}
.kontaktform .datenschutz a,
.kontaktform .datenschutzct a,
.kontaktform .datenschutzjob a{
    text-decoration:underline;
    color:var(--hs-ink) !important;
}

.kontaktform .datenschutz .privacyhint,
.kontaktform .datenschutzct .privacyhint,
.kontaktform .datenschutzjob .privacyhint{
    font-size: 0.8rem;
    font-weight: 400 !important;
    font-family:"basier_squareregular", sans-serif;
    color:var(--hs-line);
    line-height: 130%;
    display: inline-block;
    padding: 0 5vw 0 0;

}

.kontaktform .datenschutz .wpcf7-list-item,
.kontaktform .datenschutzct .wpcf7-list-item,
.kontaktform .datenschutzjob .wpcf7-list-item{
    position: relative;
    display: block
}

.kontaktform .datenschutz .wpcf7-list-item label,
.kontaktform .datenschutzct .wpcf7-list-item label,
.kontaktform .datenschutzjob .wpcf7-list-item label{
    background-color: var(--hs-line);
    border: 1px solid rgba(0, 0, 0, 0);
    border-radius: 50%;
    cursor: pointer;
    height: 20px;
    width: 20px;
    display: block;
    -webkit-transition: 0.3s ease;
    -moz-transition: 0.3s ease;
    -ms-transition: 0.3s ease;
    -o-transition: 0.3s ease;
    transition: 0.3s ease;
}

.kontaktform .datenschutz .wpcf7-list-item label:after,
.kontaktform .datenschutzct .wpcf7-list-item label:after,
.kontaktform .datenschutzjob .wpcf7-list-item label:after{
    border: 2px solid var(--hs-accent-ink);
    border-top: none;
    border-right: none;
    content: "";
    height: 6px;
    left: 5px;
    opacity: 0;
    position: absolute;
    top: 6px;
    transform: rotate(-45deg);
    width: 9px;
}

.kontaktform .datenschutz .wpcf7-list-item input[type="checkbox"],
.kontaktform .datenschutzct .wpcf7-list-item input[type="checkbox"],
.kontaktform .datenschutzjob .wpcf7-list-item input[type="checkbox"]{
    visibility: hidden;
    display: none;
    opacity: 0;
}

.kontaktform .datenschutz .wpcf7-list-item input[type="checkbox"]:checked + label,
.kontaktform .datenschutzct .wpcf7-list-item input[type="checkbox"]:checked + label,
.kontaktform .datenschutzjob .wpcf7-list-item input[type="checkbox"]:checked + label{
    background-color: var(--hs-line);
    border-color: var(--hs-line);
}

.kontaktform .datenschutz .wpcf7-list-item input[type="checkbox"]:checked + label:after,
.kontaktform .datenschutzct .wpcf7-list-item input[type="checkbox"]:checked + label:after,
.kontaktform .datenschutzjob .wpcf7-list-item input[type="checkbox"]:checked + label:after{
    opacity: 1;
}

.kontaktform .spamschutz {
}


.kontaktform .spamschutz input {
    text-align:center;
    width:70px;
    font-weight:100;
    font-size:1.2rem
}

.kontaktform .spamschutz .wpcf7-quiz-label {
    display:block;
    font-size:0.9rem
}

/* Vor dem ersten Submit keine roten Tipps/Umrandungen zeigen */
.wpcf7 form .wpcf7-not-valid-tip { display:none; }
.wpcf7 form .wpcf7-not-valid { border-color: var(--hs-line);}

/* Nach einem fehlgeschlagenen Submit normal anzeigen */
.wpcf7 form.invalid .wpcf7-not-valid { border-color: var(--hs-line) !important; background: rgba(255,255,255,0.5) }

/* -------------------------------------------------------------------------------- Validation Output -----*/

.kontaktform .processing:before {
    display:none !important
}

.kontaktform .wpcf7-response-output {
    border:none !important;
    margin: 0 !important;
    padding: 20px 0 0 0 !important;
    height: auto;
    color: var(--hs-accent) !important;
    font-weight: 600;
    font-size: 0.9rem;
}

/* -------------------------------------------------------------------------------- Sending Animation -----*/

.wpcf7-form.submitting .kontaktform {
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -ms-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
    opacity: 0.4;
    pointer-events: none
}

.kontaktform .response {
    position:relative
}

.wpcf7-form.submitting .spinner {
    display: block;
    z-index:10
}

.wpcf7-form .spinner {
    display: none;
    border: 3px solid var(--hs-accent);
    border-radius: 50%;
    border-top: 3px solid transparent;
    width: 24px;
    height: 24px;
    position: absolute;
    bottom: 140px;
    left: 50%;
    margin:-12px 0 0 -12px;
    -webkit-animation: spin 1s linear infinite;
    animation: spin 1s linear infinite;
}

@-webkit-keyframes spin {
    0% { -webkit-transform: rotate(0deg); }
    100% { -webkit-transform: rotate(360deg); }
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* -------------------------------------------------------------------------------- Thank you -----*/

.kontaktform .thankyou {
    padding: 2vw 0 0 0;
}

.kontaktform .thankyou {
display: none;
}

.kontaktform .thankyou a {
    color:var(--hs-ink) !important;
}

.kontaktform .thankyou p {
    margin: 0 0 20px 0
}

.nlWrapper {
    margin: 3vw 0;
}

.kontaktform p {
    font-weight: 400;
    margin: 1.5vw 0 2vw 0 !important;
    line-height: 130%;
    font-family:"basier_squareregular", sans-serif;
    font-size: 1rem;
}

.nlWrapper .datenschutz-col {
    margin: 20px 0 0 0;
}

.ty-modal{
    position: fixed;
    inset: 0;
    z-index: 9999;

    display: flex;
    align-items: center;
    justify-content: center;

    opacity: 0;
    visibility: hidden;
    pointer-events: none;

    transition: opacity .3s ease, visibility 0s linear .3s;
}

.ty-modal.is-open{
    opacity: 1;
    visibility: visible;
    pointer-events: auto;

    transition: opacity .3s ease, visibility 0s;
}

.ty-backdrop{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.6);
    opacity:0;
    transition:opacity .3s ease;
}

.ty-modal.is-open .ty-backdrop{
    opacity:1;
}

.ty-dialog{
    position:relative;
    max-width:500px;
    width:90%;
    background:#EFEEE8;
    padding:40px;
    text-align: center;
    transform:translateY(20px) scale(.96);
    opacity:0;
    transition:all .35s ease;
    line-height: 125%;
}

.ty-modal.is-open .ty-dialog{
    transform:translateY(0) scale(1);
    opacity:1;
}

.ty-dialog button {
    position: absolute;
    right: 13px;
    top: 6px;
    font-size: 1.8rem;
    cursor: pointer;
}

.ty-dialog p {
    margin: 20px 0 0 0;
}

.ty-dialog a {
   color: var(--hs-accent) !important;
    text-decoration: underline;
}

@media (max-width: 860px) {

    #mainWrapper .section.footer .formWrapper {
        position: relative;
        font-size: 1.1rem;
        font-weight:600;
        margin: 8vw 0;
        display: none;
    }

    .kontaktform .hs-row {
        grid-template-columns: 1fr;
        margin:0;
        gap:0;
    }

    .kontaktform .hs-row > .hs-col + .hs-col, .kontaktform .hs-row > .hs-col:first-child {
        border: 0; padding: 0;
    }

    .kontaktform .datenschutz-col {
        margin:20px 0 0 0
    }

    .kontaktform .spamschutz {
        margin:20px auto 0
    }

    .kontaktform .datenschutz,
    .kontaktform .datenschutzct,
    .kontaktform textarea,
    .small-margin {
        margin:0 !important;
    }

    .kontaktform .hs-col {
        margin:0 0 15px 0
    }

    .kontaktform .hs-sub-row {
        margin:10px 0 0 0 !important
    }

    .kontaktform .small-margin {
        margin:5px 0 0 0 !important
    }

    .kontaktform .datenschutz,
    .kontaktform .datenschutzct {
        margin:10px 0 0 0 !important;
    }

    .extra-margin {
        display:none
    }

}


@media (max-width: 620px) {



}