﻿/* Standard Form Elements */
#content .formTable > div:not(.buttonContainer) {
    display: block;
}
#content .formTable > div > div {
    padding: 0;
    white-space: nowrap;
    width: 100%;
}
#content .formTable > div:not(.nolable) > div:nth-child(1):not(.checkbox), 
#content .formTable > div > div.checkbox, 
#content .formTable > div.checkbox-sub-elements > div > div:nth-child(1)  {
    padding: 25px 0 10px 0;
}
#content .formTable > div > div:nth-child(3),
#content .formTable > div.checkbox-sub-elements > div > div:nth-child(3),
#content .formTable > div div.validation {
    background-color: rgba(var(--form-input-error-border-color),1);
    max-height: 3px;
    overflow: hidden;
    position: relative;
    top: -1px;
    z-index: 999;
}
#content .formTable > div.checkbox-sub-elements  {
    margin-bottom: 45px;
}
#content .formTable div.checkbox-sub-elements > div, 
#content .formTable div.checkbox-sub-elements > div > div {
    padding-top: 5px !important;
}
#content .formTable div.checkbox-sub-elements > div:not(:first-child) {
    padding-top: 10px !important;
}

#content input[type=text],
#content input[type=password],
#content textarea,
#content select {
    width: 100% !important;
    padding: 8px;
    font-family: var(--main-font-family);
    color: var(--content-text-color);
    /*
    font-size: 1.375rem;
    line-height: 1.938rem;
    */
    font-size: 1.188rem;
    line-height: 1.656rem;
    font-weight: 300;
    box-sizing: border-box;
    border: 1px solid rgba(135, 152, 158, .25);
    border-bottom: 1px solid rgba(135, 152, 158, .75);
}
#content input[type=text]:active,
#content input[type=text]:focus,
#content input[type=password]:active,
#content input[type=password]:focus,
#content textarea:active,
#content textarea:focus,
#content select:active,
#content select:focus {
    outline-style: none;
    box-shadow: none;
    border-color: transparent;
    border: 1px solid rgba(135, 152, 158, .25);
    border-bottom: 1px solid rgba(var(--main-color-accent), 1);
}
#content textarea {
    height: unset;
    min-height: 100px;
    field-sizing: content;
    line-height: 28px;
    display: block;
}
.buttonContainer {
    padding: 45px 0 0 0;
    text-align: center;
    display: flex;
}
.buttonContainer:has(input:nth-child(2)) {
    justify-content: space-between;
}
.buttonContainer:has(input:only-child),
.buttonContainer:has(input:first-child:last-child) {
    justify-content: flex-end;
}
@media screen and (max-width: 650px) {
    .buttonContainer {
        display: flex;
        flex-direction: column;
    }
}
.buttonContainer > input[type=button],
#content .formTable .buttonContainer .weiter {
    background-color: rgba(var(--main-color-accent),1);
    text-transform: uppercase;
    font-family: var(--main-font-family);
    font-size: 14px;
    letter-spacing: .88px;
    text-align: center;
    line-height: 20px;
    padding: 15px 25px;
    cursor: pointer;
    min-width: 230px;
    border: 1px solid rgba(var(--main-color-accent),1);
    color: rgba(var(--text-in-accent),1);
    text-decoration: none;
    transition-duration: .75s;
    transition-delay: .0s;
}
.buttonContainer > input[type=button]:hover,
#content .formTable .buttonContainer .weiter:hover {
    background-color: rgba(var(--main-color-accent),.9);
    transition-duration: .75s;
    transition-delay: .0s;
}

/* Placeholder */
#content input::placeholder {
    font-weight: normal;
    font-family: var(--main-font-family);
    color: rgb(0 0 0 / 15%);
}

/* Checkboxen */
.checkbox {
    position: relative;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    margin: 0;
    padding-top: 5px !important;
    white-space: unset !important;
    display: flex;
    flex-direction: row-reverse;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    align-content: flex-start;
    gap: 15px;
    padding-top: 0;
}
.checkbox > label,
.checkbox > span.checkmark {
    display: block;
    position: unset;
}
.checkbox > label {
    flex-grow: 2;
    hyphens: auto;
}
.checkbox > span.checkmark {
    width: 25px;
    height: 25px;
    background-color: #dcdcdc;
    position: relative;
    cursor: pointer;
    flex-shrink: 0;
}
.checkbox input[type=checkbox] {
    position: absolute;
    opacity: 0;
    z-index: 50;
    left: 0;
    top: 5px;
    width: 25px;
    height: 25px;
}
.checkbox:hover input ~ .checkmark {
  background-color: #c4c2c2;
}
.checkbox input:checked ~ .checkmark {
    background-color: rgba(var(--main-color-accent),1);
}
.checkbox .checkmark:after {
    content: "";
    position: absolute;
    display: none;
}
.checkbox input:checked ~ .checkmark:after {
    display: block;
}
.checkbox .checkmark:after {
    left: 9px;
    top: 5px;
    width: 5px;
    height: 10px;
    border: solid rgba(var(--text-in-accent),1);
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* Farbschemas */
.s_blue .checkbox input:checked ~ .checkmark {
    background-color: #00b7e4;
}



