*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
}

body {
    font-size: var(--font-size-base);
    color: var(--color-text);
    line-height: var(--line-height-base);
    font-family: var(--standard-font), sans-serif;
    overflow: hidden;
}

html, body {
    height: 100%;
    margin: 0;
    padding: 0;
}

.page {
    height: calc(100dvh - var(--navbar-height));
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

.e-control, .e-content, .e-toolbar, .e-grid, .e-richtexteditor, .e-schedule, .e-ddl, .e-list-item {
    font-family: var(--standard-font), sans-serif !important;
}

/* Überschriften */
.h1, h1 {
    font-family: var(--title-font), sans-serif;
    font-size: 4rem;
    font-weight: normal;
    outline: none;
    max-width: 100%;
    hyphens: auto;
    text-overflow: ellipsis;
    word-wrap: break-word;
}

.h2, h2 {
    font-family: var(--title-font), sans-serif;
    font-size: 2.333rem;
    font-weight: normal;
}

.h3, h3 {
    font-family: var(--title-font), sans-serif;
    font-size: 1.75rem;
    font-weight: normal;
}

.h4, h4 {
    font-size: 1.5rem;
}

.h5, h5 {
    font-size: 1.25rem;
}

.h6, h6 {
    font-size: 1rem;
    font-weight: 500;
}

a,
a:hover,
a:focus,
a:active {
    color: var(--color-primary);
}

.description {
    font-style: italic;
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
}

.background-primary {
    background-color: var(--color-primary);
}

.background-secondary {
    background-color: var(--color-secondary);
}

.color-primary {
    color: var(--color-primary);
}

.color-secondary {
    color: var(--color-secondary);
}

.small-gap {
    gap: 1rem;
}

.show-mobile {
    display: none !important;
}

.show-desktop {
    display: initial;
}

body,
footer {
    font-family: var(--standard-font);
}

.btn-primary {
    background-color: var(--color-primary);
    color: var(--color-secondary);
    outline: none;
    border: none;
}

    .btn-primary:focus {
        color: var(--color-secondary);
        background-color: var(--color-primary);
        border-color: var(--color-primary);
        box-shadow: none;
    }

    .btn-primary:hover {
        background-color: var(--color-primary-hover);
    }

    .btn-check:active+.btn-primary, .btn-check:checked+.btn-primary, .btn-primary.active, .btn-primary:active, .show>.btn-primary.dropdown-toggle {
        background-color: var(--color-primary-hover);
        border-color: var(--color-primary-hover);
        box-shadow: none !important;
    }

.btn-secondary {
    background-color: white;
    border: 1px solid var(--color-primary);
    color: var(--color-primary);
    outline: none;
}
    .btn-secondary:hover {
        background-color: var(--color-secondary-hover);
        border: 1px solid var(--color-primary-hover);
        color: var(--color-primary-hover);
    }

    .fade {
        transition: opacity .15s linear;
    }

@media(max-width: 928px){
    .show-mobile {
        display: initial !important;
    }

    .show-desktop {
        display: none !important;
    }
}

/*input heights*/
input,
input.e-input,
.e-input-group input,
.e-input-group.e-control-wrapper input,
.e-input-group input.e-input,
.e-input-group.e-control-wrapper input.e-input
{
    height: 2rem;
}

/* Form */

.form-field-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
}

    .form-field-wrapper form {
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

.form-item-container {
    margin-bottom: 10px;
    display: flex;
    flex-direction: column;
    flex: 1;
    width: 100%;
}

    .form-item-container label {
        color: var(--color-primary);
    }

    .form-item-container input:not([type="checkbox"]) {
        background-color: var(--color-secondary);
        color: var(--color-text);
        outline: none;
        padding: 4px 12px;
        border-radius: var(--border-radius);
        border: none;
        width: 100%;
    }

input[type="checkbox"] {
    accent-color: var(--color-primary);
}

.form-item-container textarea {
    background-color: var(--color-secondary);
    color: var(--color-text);
    outline: none;
    padding: 4px 12px;
    border-radius: var(--border-radius);
    border: 1px solid var(--color-component-border);
    width: 100%;
    line-height: 1.5;
    min-height: 5rem;
}

        .form-item-container textarea:focus {
            border-color: var(--color-primary) !important;
        }

        .form-item-container textarea.modified.invalid {
            border-color: var(--color-danger);
        }

.form-field-wrapper form .button-wrapper {
    margin-top: 10px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.form-row {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.form-columns {
    width: 100%;
    display: flex;
    flex-direction: column;
}

.form-column {
    flex: 1 1 auto;
    width: 100%;
    display: flex;
    flex-direction: column;
}

@media(min-width: 768px) {
    .form-row {
        flex-direction: row;
        gap: 1rem;
    }
}

@media(min-width: 1200px) {

    .form-columns {
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-start;
        gap: 1rem;
    }
}

.e-ddl {
    background-color: var(--color-secondary) !important;
}

    .e-ddl.e-input-group.e-control-wrapper.e-success {
        border-color: var(--color-component-border);
    }

    .e-ddl.e-input-group.e-control-wrapper input.e-dropdownlist.e-input {
        color: var( --color-text);
        padding: 4px 12px;
        font-size: 1rem;
    }

    .e-ddl .e-list-item {
        font-size: 1rem;
    }

.e-input-group.e-input-focus:not(.e-error):not(.e-warning).e-success, 
.e-input-group.e-control-wrapper.e-input-focus:not(.e-error):not(.e-warning).e-success, 
.e-input-group:not(.e-disabled):active:not(.e-error):not(.e-warning).e-success, 
.e-input-group.e-control-wrapper:not(.e-disabled):active:not(.e-error):not(.e-warning).e-success {
    box-shadow: none;
    -webkit-box-shadow: none;
}

.e-input-group input.e-input, 
.e-input-group.e-control-wrapper input.e-input, 
.e-float-input input, 
.e-float-input.e-control-wrapper input, 
.e-input-group textarea.e-input, 
.e-input-group.e-control-wrapper textarea.e-input, 
.e-float-input textarea,
.e-float-input.e-control-wrapper textarea, 
.e-input-group .e-input[disabled], 
.e-input-group.e-control-wrapper .e-input[disabled], 
.e-input-group.e-disabled input.e-input, 
.e-input-group.e-control-wrapper.e-disabled input.e-input, 
.e-input-group.e-disabled textarea.e-input, 
.e-input-group.e-control-wrapper.e-disabled textarea.e-input {
    background-color: var(--color-secondary);
}

.e-input-group .e-input-group-icon, 
.e-input-group.e-control-wrapper .e-input-group-icon {
    background-color: var(--color-secondary);
}

.e-float-input .e-clear-icon, 
.e-float-input.e-control-wrapper .e-clear-icon, 
.e-input-group .e-clear-icon, 
.e-input-group.e-control-wrapper .e-clear-icon {
    background-color: var(--color-secondary);
}

.custom-validator .file-upload-custom-container {
    border: none !important;
}

    .custom-validator .file-upload-custom-container.has-items {
        border-bottom: 1px solid !important;
    }

.custom-validator .file-upload-custom-item {
    border-inline: none !important;
}

    .custom-validator .file-upload-custom-item:last-of-type {
        border-bottom: none !important;
    }

.custom-validator:has(.custom-validator-error) {
    outline: 1px solid var(--color-danger) !important;
}

.custom-validator-error {
    width: 32px;
    height: 100%;
    text-align: center;
    background-color: #dc262622;
    border-left: 1px solid var(--color-danger);
    color: var(--color-danger);
    line-height: 32px;
    font-size: 1rem;
}

.custom-validator {
    display: flex;
    justify-content: space-between;
    border: 1px solid var(--color-component-border);
    border-radius: var(--border-radius);
}

    .custom-validator:focus-within {
        outline: 1px solid var(--color-primary-dark);
    }

    .custom-validator input {
        border: 0px !important;
        outline: none !important;
    }

.custom-validator-content {
    width: 100%;
}

    .custom-validator-content .e-input-group {
        border: none !important;
        outline: none !important;
    }

.error-tooltip {
    background-color: var(--color-danger) !important;
    color: white !important;
    border-color: var(--color-danger) !important;
}

    .error-tooltip .e-arrow-tip-outer.e-tip-left {
        border-bottom: 12px solid transparent;
        border-right: 12px solid var(--color-danger);
        border-top: 12px solid transparent;
        border-left: 12px solid transparent;
    }

    .error-tooltip .e-arrow-tip-inner.e-tip-left {
        color: var(--color-danger) !important;
    }


.custom-phone-container {
    background-color: var(--color-secondary);
}

    .custom-phone-container .e-input-group input.e-textbox {
        background-color: var(--color-secondary);
        color: var(--color-text);
        font-size: 1rem;
    }

    .custom-phone-container .e-ddl .e-input-value {
        color: var(--color-primary);
    }

.e-input-group:not(.e-disabled):active:not(.e-success):not(.e-warning):not(.e-error), .e-input-group.e-control-wrapper:not(.e-disabled):active:not(.e-success):not(.e-warning):not(.e-error) {
    box-shadow: none;
}

.e-input-group.e-input-focus:not(.e-success):not(.e-warning):not(.e-error), .e-input-group.e-control-wrapper.e-input-focus:not(.e-success):not(.e-warning):not(.e-error) {
    box-shadow: none;
}

.validation-message {
    color: var(--color-danger);
}

.custom-validator:has(.custom-validator-error) .file-upload-custom-actions .btn-tertiary-custom:last-of-type {
    border-top-right-radius: 0px !important;
    border-bottom-right-radius: 0px !important;
}

.mapbox-container {
    width: 100%;
    height: 40rem;
    border-radius: 0px;
    overflow: hidden;
}

section.kitas .mapbox-container {
    --map-height: calc(100dvh - var(--navbar-height) - 5rem);
    height: 50dvh;
    max-height: var(--map-height);
}

button.mapboxgl-popup-close-button {
    position: absolute;
    top: 3px;
    right: 3px;
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    outline: none;
    line-height: 1;
    width: 16px;
    height: 16px;
    overflow: hidden;
}

.mapboxgl-popup-content {
    padding-top: calc(1rem);
}

.custom-phone-container .e-ddl-icon.e-icons {
    min-width: 16px;
}

.e-multi-line-input.e-input-group.e-control-container.e-control-wrapper:focus-within,
.e-multi-line-input.e-input-group.e-control-container.e-control-wrapper:focus {
    outline: 1px solid var(--color-primary-dark);
}

.e-input-group:not(.e-success):not(.e-warning):not(.e-error), 
.e-input-group.e-control-wrapper:not(.e-success):not(.e-warning):not(.e-error) {
    border-color: var(--color-component-border);
}

textarea.e-input, 
.e-input-group textarea, 
.e-input-group textarea.e-input, 
.e-input-group.e-input-focus textarea, 
.e-input-group.e-input-focus textarea.e-input, 
.e-input-group.e-control-wrapper textarea, 
.e-input-group.e-control-wrapper.e-input-focus textarea, 
.e-input-group.e-control-wrapper textarea.e-input, 
.e-input-group.e-control-wrapper.e-input-focus textarea.e-input, 
.e-float-input textarea, 
.e-float-input.e-control-wrapper textarea {
    min-height: 10rem;
}

.form-item-container input[type='checkbox'] {
    cursor: pointer;
}

.no-import.e-richtexteditor .e-rte-upload {
    display: none;
}