
@keyframes loading {
    0% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0 50%;
    }
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

:root {
    --hover-opacity: 0.8;
    --hover-cursor: pointer;
    --font-family: Poppins, 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    --font-size: 12pt;
    --image-preview-content: "IMAGE";
    --border-radius: 0.25rem;
    --backcolor-danger: #b00c3b;
    --bordercolor-danger: #b00c3b;
    --forecolor-danger: #f5f5f5;
    --forecolor-default-reverse: #f5f5f5;
    /*--backcolor-default: #292a2d;*/
    --backcolor-default: #f5f5f5;
    --bordercolor-default: #292a2d;
    --forecolor-default: #000;
    --forecolor-default-reverse: #f5f5f5;
    --backcolor-success: #28a745;
    --bordercolor-success: #28a745;
    --forecolor-success: #1f1f1f;
    --backcolor-warning: #ffd100;
    --bordercolor-warning: #ffd100;
    --forecolor-warning: #1f1f1f;
    --danger-color: red;
    --success-color: green;
    --warning-color: orange;
    --info-color: blue;
}

@media (prefers-color-scheme: dark) {
    :root {
        --background-color: #3c4043;
        --background-color-highlight: #3c3c3c;
        --fore-color: #f5f5f5;
        --forecolor-default: #f5f5f5;
        --backcolor-default: #292a2d;
        --text-color: #f5f5f5;
        --text-color-highlight: #000;
        --link-color: #543fd7;
        --input-background-color: #292a2d;
        --input-border: 1px solid #666;
        --input-text-color: #f5f5f5;
        --input-text-color-highlight: #333333;
        --error-text-color: #ff0000;
        --border-color: #f5f5f5;
        --danger-color: #b00c3b;
        --success-color: #78be20;
        --info-color: #fff;
        --warning-color: #ffe366;
        --danger-filter: invert(16%) sepia(21%) saturate(4326%) hue-rotate(323deg) brightness(104%) contrast(101%);
        --info-filter: invert(100%); /*invert(11%) sepia(88%) saturate(4093%) hue-rotate(245deg) brightness(82%) contrast(127%);*/
        --warning-filter: invert(76%) sepia(83%) saturate(290%) hue-rotate(355deg) brightness(101%) contrast(104%);
        /* ReSharper disable once InvalidValue */
        --loading-background: linear-gradient(100deg, var(--input-background-color) 30%, var(--text-color) 50%, var(--input-background-color) 70%);
        --loading-animation: loading 1.2s ease-in-out infinite;
        --spinner-animation: spin 1.2s infinite;
    }
}

@media (prefers-color-scheme: light) {
    :root {
        --background-color: #fff;
        --background-color-highlight: #f5f5f5;
        --fore-color: #1f1f1f;
        --text-color: #1f1f1f;
        --link-color: #543fd7;
        --input-background-color: #f5f5f5;
        --input-border: 1px solid #000;
        --input-text-color: #1f1f1f;
        --error-text-color: #ff0000;
        --border-color: #f5f5f5;
        --danger-color: #b00c3b;
        --success-color: #007a53;
        --info-color: #10069F;
        --warning-color: #ffe366;
        --danger-filter: invert(16%) sepia(21%) saturate(4326%) hue-rotate(323deg) brightness(104%) contrast(101%);
        --info-filter: invert(11%) sepia(88%) saturate(4093%) hue-rotate(245deg) brightness(82%) contrast(127%);
        --warning-filter: invert(76%) sepia(83%) saturate(290%) hue-rotate(355deg) brightness(101%) contrast(104%);
        --loading-background: linear-gradient(100deg, #dfe1e4 30%, #f6f7f8 50%, #dfe1e4 70%);
        --loading-animation: loading 1.2s ease-in-out infinite;
    }
}

/* form */

.dynamicform-container {
    display: flex;
    height: 100%;
    flex-direction: column;
    overflow-x: hidden;
    overflow-y: auto;
}

    .dynamicform-container * {
        font-family: var(--font-family);
    }

/* controls */

.dynamicform-button {
    background-color: var(--input-background-color);
    border: var(--input-border);
    border-radius: var(--border-radius);
    box-sizing: border-box;
    color: var(--fore-color);
    font-family: var(--font-family);
    font-size: var(--font-size);
    font-weight: bold;
    min-width: 6rem;
    padding: 0.5rem;
}

    .dynamicform-button:disabled {
        opacity: 0.6;
    }

        .dynamicform-button:disabled:hover {
            cursor: not-allowed;
        }

    .dynamicform-button:not(:disabled):hover {
        cursor: var(--hover-cursor);
        opacity: var(--hover-opacity);
    }


.dynamicform-link {
    background: none;
    border: none;
    border-radius: var(--border-radius);
    box-sizing: border-box;
    color: var(--fore-color);
    font-family: var(--font-family);
    font-size: var(--font-size);
    font-weight: normal;
    min-width: 6rem;
    padding: 0.5rem;
    text-decoration: underline;
}

    .dynamicform-link:disabled {
        opacity: 0.6;
    }

        .dynamicform-link:disabled:hover {
            cursor: not-allowed;
        }

    .dynamicform-link:not(:disabled):hover {
        cursor: var(--hover-cursor);
        opacity: var(--hover-opacity);
    }


/* step */
.dynamicform-steps {
    display: flex;
    flex: 1 0 auto;
    flex-direction: column;
}

.dynamicform-step {
    display: none !important;
}

    .dynamicform-step.dynamicform-active {
        display: flex !important;
    }

/* error */

.dynamicform-error-message {
    align-items: center;
    background-color: #f5f5f5;
    border-radius: var(--border-radius);
    color: var(--danger-color);
    display: inline-flex;
    font-weight: bold;
    height: 2rem;
    padding: 0 0.5rem;
    width: fit-content;
}

.dynamicform-row {
    display: flex;
    flex-direction: row;
}

.dynamicform-column {
    display: flex;
    flex-direction: column;
}

/* group */
.dynamicform-group {
    display: flex;
    flex: 1 1 auto;
    /*flex-wrap: wrap;*/
    min-width: 0;
}

    .dynamicform-group.dynamicform-row {
        flex-direction: row;
    }

    .dynamicform-group.dynamicform-column {
        flex-direction: column;
    }

.dynamicform-group-title {
    border-bottom: 1px solid var(--input-text-color);
    color: var(--input-text-color);
    font-family: var(--font-family);
    font-weight: normal;
    margin: 0.75rem 0 0.5rem 0;
    white-space: normal;
}

.dynamicform-group-description {
    font-size: 1rem;
    margin: 0 0 0.5rem 0;
    white-space: normal;
}

    .dynamicform-group-description > ul > li {
        margin-bottom: 0.5rem;
    }

.dynamicform-group-heading,
.dynamicform-group-label {
    color: var(--text-color);
    display: block;
    margin: 0 0 0.25rem 0;
    padding: 0;
    white-space: pre-wrap;
}

.dynamicform-group-heading {
    font-size: 1.5rem;
}

.dynamicform-group-textbox {
    background-color: var(--input-background-color);
    border: var(--input-border);
    box-sizing: border-box;
    color: var(--input-text-color);
    font-family: var(--font-family);
    font-size: var(--font-size);
    padding: 0.5rem;
}

.dynamicform-group-dropdown {
    background-color: var(--input-background-color);
    border: none;
    box-sizing: border-box;
    color: var(--input-text-color);
    padding: 0.5rem;
}

.dynamicform-group-textbox,
.dynamicform-group-dropdown {
    border: var(--input-border);
    border-radius: var(--border-radius);
    margin-bottom: 1rem;
    resize: vertical;
    width: 100%;
}

    .dynamicform-group-textbox:read-only,
    .dynamicform-group-dropdown:read-only {
        cursor: default;
    }

    .dynamicform-group-textbox:disabled,
    .dynamicform-group-dropdown:disabled,
    label:has(+ .dynamicform-group-textbox:disabled),
    label:has(+ .dynamicform-group-dropdown:disabled) {
        opacity: 0.2;
    }

textarea.dynamicform-group-textbox {
    min-height: 10rem;
}
/*
.dynamicform-group-description {
    font-size: 0.8rem;
    margin: 0 0 0.5rem 0;
}
*/
.dynamicform-group-ticks {
    display: flex;
    flex-wrap: wrap;
}

.dynamicform-group-tick {
    display: inline-block;
}

.dynamicform-group-tick-input {
    display: none;
}

    .dynamicform-group-tick-input:checked + .dynamicform-group-tick-label {
        background-color: var(--fore-color);
        color: var(--background-color);
    }

    .dynamicform-group-tick-input:disabled + .dynamicform-group-tick-label {
        pointer-events: none;
    }

        .dynamicform-group-tick-input:disabled + .dynamicform-group-tick-label:hover {
            cursor: default;
        }

.dynamicform-group-tick-label {
    border: var(--input-border);
    background-color: var(--input-background-color);
    border-radius: var(--border-radius);
    color: var(--fore-color);
    box-sizing: border-box;
    display: inline-block;
    font-weight: normal;
    margin: 0 1rem 1rem 0;
    min-width: 6rem;
    padding: 0.5rem;
    text-align: center;
}

    .dynamicform-group-tick-label:hover {
        cursor: var(--hover-cursor);
        opacity: var(--hover-opacity);
    }

.dynamicform-field {
    display: flex;
    /*margin: 0.5rem 0.5rem 3rem 0.5rem;*/
    margin: 0.5rem 0 3rem 0;
}

    .dynamicform-field.dynamicform-fit {
        flex: 1 0 auto;
    }

    .dynamicform-field.dynamicform-auto {
        width: auto;
    }

    .dynamicform-field.dynamicform-small {
        width: 6rem;
    }

    .dynamicform-field.dynamicform-medium {
        width: 15rem;
    }

    .dynamicform-field.dynamicform-large {
        width: 30rem;
    }

    .dynamicform-field.dynamicform-half {
        width: 50%;
    }

    .dynamicform-field.dynamicform-full {
        width: 100%;
    }

.dynamicform-control-title {
    margin: 0 0 0.5rem 0;
    border-bottom-style: solid;
    border-bottom-width: 1px;
    border-bottom-color: var(--border-color);
}

.dynamicform-control-description {
    margin: 0;
}

/* control */
.dynamicform-control {
    display: flex;
    flex: 1 0 auto;
    flex-direction: column;
    position: relative;
}

    .dynamicform-control:after {
    }

    .dynamicform-control.dynamicform-column {
        flex-direction: column;
    }

    .dynamicform-control.dynamicform-row {
        flex-direction: row;
    }

.dynamicform-image-trigger {
    margin-bottom: 1rem;
}

.dynamicform-image-previews {
    display: flex;
    flex: 1 0 auto;
    flex-direction: row;
    flex-wrap: wrap;
}

.dynamicform-image-preview {
    position: relative;
    margin: 0 1rem 1rem 0;
}

.dynamicform-image-preview-label {
    background-color: rgba(0, 0, 0, 0.2);
    left: 0;
    padding: 0.5rem 1rem;
    position: absolute;
    top: 0;
}

.dynamicform-image-preview-control {
    background-color: rgb(97, 38, 38);
    right: 0;
    padding: 0.5rem 1rem;
    position: absolute;
    top: 0;
}

    .dynamicform-image-preview-control:hover {
        cursor: var(--hover-cursor);
        opacity: 1 !important;
    }

.dynamicform-label {
    color: var(--fore-color);
    padding: 0.5rem 1rem;
}

/* nav */

.dynamicform-nav {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
}
    /*
.dynamicform-button {
    background-color: var(--input-background-color);
    border: var(--input-border);
    border-radius: var(--border-radius);
    color: var(--fore-color);
    font-weight: bold;
}
*/
    .dynamicform-nav > .dynamicform-button {
        margin: 0.5rem;
        position: relative;
    }



.dynamicform-button.dynamicform-theme-danger {
    background-color: var(--backcolor-danger);
    color: var(--text-color);
}

.dynamicform-button.dynamicform-theme-success {
    background-color: var(--backcolor-success);
    color: var(--text-color);
}




/* finder */

.dynamicform-finder {
    position: relative;
}

.dynamicform-finder-control {
    background-color: var(--input-background-color);
    border: var(--input-border);
    border-radius: var(--border-radius);
    box-sizing: border-box;
    color: var(--input-text-color);
    font-family: var(--font-family);
    font-size: var(--font-size);
    padding: 0.5rem;
    width: 100%;
}

.dynamicform-finder-results {
    background-color: var(--input-background-color);
    border-radius: var(--border-radius);
    color: var(--input-text-color);
    display: flex;
    flex-direction: column;
    font-family: var(--font-family);
    font-size: var(--font-size);
    left: 0;
    max-height: 17.5rem;
    overflow-y: scroll;
    padding: 0.5rem 1rem;
    position: absolute;
    right: 0;
    top: 3.5rem;
    z-index: 1050;
}

.dynamicform-finder-result {
    background-color: transparent;
    border: none;
    color: var(--text-color);
    font-size: 1rem;
    margin: 0.25rem 0;
    padding: 0;
    text-align: left;
}

    .dynamicform-finder-result:hover {
        cursor: var(--hover-cursor);
        opacity: var(--hover-opacity);
    }

.dynamicform-group-find {
    display: flex;
    flex-direction: row;
}

    .dynamicform-group-find > .dynamicform-group-textbox {
        margin-right: 1rem;
    }

    .dynamicform-group-find > .dynamicform-button {
        width: 10rem;
    }

.dynamicform-group-find-results {
    margin-top: 1rem;
}

    .dynamicform-group-find-results > table {
        width: 100%;
    }

    .dynamicform-group-find-results th {
        text-align: left;
    }

.dynamicform-group-find-display {
    border-radius: var(--border-radius);
    background-color: #333333;
    color: var(--text-color);
    margin: 0 1rem 1rem 0;
    padding: 1rem;
    width: 20rem;
}

.dynamicform-group-find-display-title {
    font-weight: normal;
    margin: 0 0 1rem 0;
}

.dynamicform-group-find-display-value {
    background-color: var(--fore-color);
    border-radius: var(--border-radius);
    color: var(--text-color-highlight);
    margin: 0 0 0.5rem 0;
    padding: 0.5rem 1rem;
}

.dynamicform-group-find-selected {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    margin-top: 1rem;
}


.dynamicform-table {
    border: none;
    border-spacing: 0;
}

    .dynamicform-table th {
        padding: 0.5rem 1rem;
    }

.dynamicform-table-head {
}

    .dynamicform-table-head > th {
        background-color: var(--input-background-color);
        border: none;
        color: var(--input-text-color);
        padding: 0.5rem 1rem !important;
    }

        .dynamicform-table-head > th.dynamicform-hover:hover {
            background-color: var(--fore-color);
            color: var(--input-text-color-highlight);
        }

        .dynamicform-table-row > td:first-child,
        .dynamicform-table-head > th:first-child {
            border-top-left-radius: var(--border-radius);
            border-bottom-left-radius: var(--border-radius);
        }

        .dynamicform-table-row > td:last-child,
        .dynamicform-table-head > th:last-child {
            border-top-right-radius: var(--border-radius);
            border-bottom-right-radius: var(--border-radius);
        }

.dynamicform-table-row {
}

    .dynamicform-table-row > th,
    .dynamicform-table-row > td {
        border: none;
        padding: 0.5rem 1rem !important;
    }

    .dynamicform-table-row:nth-child(even) > td {
        background-color: var(--background-color-highlight);
    }

.dynamicform-pagination {
    align-items: center;
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    margin-top: 0.5rem;
}

.dynamicform-pagination-previous {
}

.dynamicform-pagination-next {
}

.dynamicform-pagination-page {
    background-color: var(--input-background-color);
    border: var(--input-border);
    box-sizing: border-box;
    color: var(--input-text-color);
    font-family: var(--font-family);
    font-size: var(--font-size);
    padding: 0.5rem;
    text-align: center;
    width: 2rem;
}

.dynamicform-pagination-display {
}

.dynamicform-pagination-controls {
    margin-left: 1rem;
}


.dynamicform-modal {
    align-items: center;
    background-color: rgba(0, 0, 0, 0.5);
    bottom: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    left: 0;
    padding: 2rem;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 100;
}

.dynamicform-modal-content {
    background-color: var(--background-color);
    border-radius: var(--border-radius);
    color: var(--text-color);
    padding: 1rem;
}

.dynamicform-modal-controls {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    margin-top: 1rem;
}

.dynamicform-modal-header {
    font-size: 1.25rem;
    margin-bottom: 1rem;
}

.dynamicform-modal-body {
}

.dynamicform-message {
    background-color: transparent;
    border-color: transparent;
    border-radius: var(--border-radius);
    border-style: solid;
    border-width: 1px;
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 3rem;
    padding: 1rem;
}

.dynamicform-message-inline {
    background-color: transparent;
    border-color: transparent;
    border-radius: var(--border-radius);
    border-style: solid;
    border-width: 1px;
    display: inline-flex;
    flex-wrap: wrap;
    margin-bottom: 3rem;
    padding: 1rem;
}

    .dynamicform-message-inline > *:not(:last-child),
    .dynamicform-message > *:not(:last-child) {
        margin-bottom: 0.5rem;
    }

    .dynamicform-message-inline.dynamicform-theme-danger,
    .dynamicform-message.dynamicform-theme-danger {
        border-color: transparent;
        color: var(--forecolor-danger);
        background-color: var(--backcolor-danger);
    }

    .dynamicform-message-inline.dynamicform-theme-default,
    .dynamicform-message.dynamicform-theme-default {
        border-color: transparent;
        color: var(--forecolor-default);
        background-color: var(--backcolor-default);
    }

    .dynamicform-message-inline.dynamicform-theme-success,
    .dynamicform-message.dynamicform-theme-success {
        border-color: transparent;
        color: var(--forecolor-success);
        background-color: var(--backcolor-success);
    }

    .dynamicform-message-inline.dynamicform-theme-warning,
    .dynamicform-message.dynamicform-theme-warning {
        border-color: transparent;
        color: var(--forecolor-warning);
        background-color: var(--backcolor-warning);
    }

.dynamicform-message-title,
.dynamicform-message-description {
    white-space: pre-wrap;
    margin: 0;
}

.dynamicform-popup-table {
    border: none;
    border-collapse: collapse;
}

    .dynamicform-popup-table th {
        background-color: transparent;
        border: none;
        color: #000;
        font-size: 0.75rem;
    }

    .dynamicform-popup-table td {
        border: none;
        font-size: 0.75rem;
    }


.a {
}


/* helpers */
.dynamicform-hidden {
    display: none !important;
}

.dynamicform-vertical {
    display: flex;
    flex-direction: column;
}

.dynamicform-hover:hover {
    cursor: var(--hover-cursor);
    opacity: var(--hover-opacity);
}

.dynamicform-lock {
}

input.dynamicform-lock + label,
input.dynamicform-lock,
textarea.dynamicform-lock,
select.dynamicform-lock,
div.dynamicform-lock {
    pointer-events: none;
}




.dynamicform-theme-danger {
    border-color: transparent;
    color: var(--forecolor-danger);
    background-color: var(--backcolor-danger);
}



.a {
}


/* 

    IP SPECIFIC

*/

.ip-appointment {
    display: flex;
    flex-direction: column;
}

.ip-appointment-nav {
    display: flex;
    flex-direction: row;
    margin-bottom: 1rem;
}

.ip-appointment-days,
.ip-appointment-slots {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-top: 1rem;
}

.ip-appointment-day,
.ip-appointment-slot {
    background-color: var(--input-background-color);
    border: var(--input-border);
    border-radius: var(--border-radius);
    color: var(--input-text-color);
    display: flex;
    flex-direction: column;
    margin: 0 1rem 1rem 0;
    width: 20rem;
    padding: 1rem;
    flex: 0 0 auto;
}

    .ip-appointment-day.ip-disabled,
    .ip-appointment-slot.ip-disabled {
        opacity: 0.5;
    }

    .ip-appointment-slot:not(.ip-disabled):hover,
    .ip-appointment-day:not(.ip-disabled):hover {
        cursor: var(--hover-cursor);
        opacity: var(--hover-opacity);
    }

    .ip-appointment-day > h,
    .ip-appointment-slot > h5 {
        display: flex;
        flex-direction: row;
        font-size: 1.5rem;
        font-weight: bold;
        justify-content: space-between;
        margin: 0.5rem 0 1rem 0;
    }

    .ip-appointment-day > p,
    .ip-appointment-slot > p {
        margin: 0.5rem 0 0 0;
        align-items: center;
        border-radius: var(--border-radius);
        background-color: #f5f5f5;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        color: #000;
        padding: 0 0.5rem;
    }

        .ip-appointment-day > p > span,
        .ip-appointment-slot > p > span {
            font-size: 1.5rem;
            font-weight: bold;
        }

.ip-jumbo {
    background-color: var(--background-color);
    border-radius: var(--border-radius);
    color: var(--input-text-color);
    max-width: 33rem;
    padding: 1rem;
}

    .ip-jumbo > h4 {
        margin: 0;
    }

        .ip-jumbo > h4 > small {
            font-size: 80%;
        }

.ip-hidden {
    display: none !important;
}

.ip-loading {
    animation: var(--loading-animation);
    background: var(--loading-background);
    background-size: 400%;
    border-radius: 5px;
    color: transparent;
    /*margin-top: 1rem;*/
    min-height: 2.75rem;
    width: 100%;
}

    .ip-loading > * {
        display: none !important;
    }


.dynamicform-loading {
    animation: var(--spinner-animation);
    height: 2rem;
    width: 2rem;
}

/*
.dynamicform-map-popup {
    width: 10rem;
    height: 4rem;
}*/

.dynamicform-group-textbox::-webkit-outer-spin-button,
.dynamicform-group-textbox::-webkit-inner-spin-button {
    /* display: none; <- Crashes Chrome on hover */
    -webkit-appearance: none;
    margin: 0; /* <-- Apparently some margin are still there even though it's hidden */
}

.dynamicform-group-textbox[type=number] {
    -moz-appearance: textfield; /* Firefox */
}

.dynamicform-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dynamicform-list-item {
    margin: 0;
    padding: 0;
}


.dynamicform-addresses {
    position: relative;
}

.dynamicform-address-display {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    margin-right: -1rem;
    position: relative;
}

    .dynamicform-address-display > div {
        align-items: flex-start;
        flex: 1 0 0;
        /*flex-direction: row;*/
        min-width: 10rem;
        margin-right: 1rem;
    }

        .dynamicform-address-display > div:first-child,
        .dynamicform-address-display > div:nth-of-type(2) {
            flex-basis: calc(50% - 1rem);
        }

div.choices {
    border: var(--input-border);
}


.dynamicform-map-message {
    background-color: rgba(0, 0, 0, 0.5);
    bottom: 0;
    color: #000;
    font-size: 1.25rem;
    font-weight: bold;
    left: 0;
    padding-top: 2rem;
    position: absolute;
    right: 0;
    text-align: center;
    top: 0;
    z-index: 10;
}