/* This is the DCR default style. User variables and overrides are to be set in a separate .css flie. Defaults are in flow-variables.css */

/*Needed Vars*/
:root,
[data-theme="light"],
[data-theme="system-light"] {
    --flow-sky: #f5f7fa;
    --flow-clouds: #f5f7fa;
    --flow-footer: #0f142e;
}

[data-theme="dark"],
[data-theme="system-dark"] {
    --flow-sky: #1a1a1a;
    --flow-clouds: #1a1a1a;
    --flow-footer: #141414;
}

/*Element styles*/

body {
    background: var(--flow-sky);
    overscroll-behavior: none;
    min-width: 360px;
    width: 100vw;
    height: 100vh;
}

main {
    display: flex;
    justify-content: center;
    overscroll-behavior: contain;
    transition: width 0.25s ease-in-out;
}

@media screen and (max-width: 1366px) {
    main {
        width: 95% !important;
        margin: auto;
        align-self: center;
        max-width: 100% !important;
    }
}

main.center {
    align-items: center;
}

main.scrollable {
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding-bottom: 80px;
    padding-top: 80px;
    min-height: 80%;
    width: 75%;
    margin: auto;
    gap: 1rem;
}

* {
    accent-color: var(--accent-fill-rest);
}

    *:not([disabled]):focus-visible,
    .option:not([disabled]):focus-visible,
    *:focus-visible > .dcr-panel {
        outline: calc(var(--focus-stroke-width) * 1px) solid var(--focus-stroke-outer);
        outline-offset: calc(var(--focus-stroke-width) * -1px);
    }

    *[disabled] {
        cursor: unset !important;
        opacity: var(--disabled-opacity);
    }

input[type="radio"]:focus-visible, input[type="checkbox"]:focus-visible {
    outline-offset: calc(var(--focus-stroke-width) * 1px) !important;
}

a {
    text-decoration: auto !important;
}

label {
    cursor: pointer;
}

.unset {
    /*Fake display content because actual display content makes the element untabable*/
    all: unset;
    width: 100%;
    height: 100%;
}


/*Fluent cloned inputs*/
/*This is some css dark magic. Fluent uses a wrapper to do these. But *I* can do it native html*/

/*Radio*/
input[type="radio"] {
    --input-size: calc(((var(--base-height-multiplier) + var(--density)) * var(--design-unit) / 2) + var(--design-unit));
    position: relative;
    width: calc(var(--input-size) * 1px);
    height: calc(var(--input-size) * 1px);
    box-sizing: border-box;
    border-radius: 50%;
    border: calc(var(--stroke-width) * 1px) solid var(--neutral-stroke-strong-rest);
    background: var(--neutral-fill-input-alt-rest);
    cursor: pointer;
    appearance: none;
    margin-right: calc(var(--design-unit) * 2px + 2px);
    vertical-align: middle;
}

    input[type="radio"]:hover {
        background: var(--neutral-fill-input-alt-hover);
        border-color: var(--neutral-stroke-strong-hover);
    }

    input[type="radio"]:active {
        background: var(--neutral-fill-input-alt-active);
        border-color: var(--neutral-stroke-strong-active);
    }

        input[type="radio"]:active::after {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: var(--foreground-on-accent-rest);
            clip-path: circle(4px at center);
        }

    input[type="radio"]:checked {
        background-color: var(--accent-fill-rest);
        border-color: transparent;
    }

        input[type="radio"]:checked::after {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: var(--foreground-on-accent-rest);
            clip-path: circle(4px at center);
        }

    input[type="radio"]:not([disabled]):checked:hover {
        background: var(--accent-fill-hover);
        border-color: transparent;
    }

    input[type="radio"]:not([disabled]):checked:active {
        background: var(--accent-fill-active);
        border-color: transparent;
    }

/*Checkbox*/
input[type="checkbox"] {
    --input-size: calc(((var(--base-height-multiplier) + var(--density)) * var(--design-unit) / 2) + var(--design-unit));
    position: relative;
    width: calc(var(--input-size) * 1px);
    height: calc(var(--input-size) * 1px);
    box-sizing: border-box;
    border-radius: calc(var(--control-corner-radius) * 1px);
    border: calc(var(--stroke-width) * 1px) solid var(--neutral-stroke-strong-rest);
    background: var(--neutral-fill-input-alt-rest);
    cursor: pointer;
    appearance: none;
    margin-right: calc(var(--design-unit) * 2px + 2px);
    vertical-align: bottom;
}

    input[type="checkbox"]:hover {
        background: var(--neutral-fill-input-alt-hover);
        border-color: var(--neutral-stroke-strong-hover);
    }

    input[type="checkbox"]:active {
        background: var(--neutral-fill-input-alt-active);
        border-color: var(--neutral-stroke-strong-active);
    }

    input[type="checkbox"]:checked {
        background-color: var(--accent-fill-rest);
        border-color: transparent;
    }

        input[type="checkbox"]:checked::after {
            content: "";
            position: absolute;
            top: 1px;
            left: 1px;
            width: 100%;
            height: 100%;
            background-color: var(--foreground-on-accent-rest);
            clip-path: path("M13.86 3.66a.5.5 0 0 1-.02.7l-7.93 7.48a.6.6 0 0 1-.84-.02L2.4 9.1a.5.5 0 0 1 .72-.7l2.4 2.44 7.65-7.2a.5.5 0 0 1 .7.02z");
        }

    input[type="checkbox"]:not([disabled]):checked:hover {
        background: var(--accent-fill-hover);
        border-color: transparent;
    }

    input[type="checkbox"]:not([disabled]):checked:active {
        background: var(--accent-fill-hover);
        border-color: transparent;
    }

/*Text field*/
input:not([type="radio"]):not([type="checkbox"]), textarea {
    padding: 0 calc(var(--design-unit) * 2px + 1px);
    border-radius: calc(var(--control-corner-radius) * 1px);
    border: calc(var(--stroke-width) * 1px) solid transparent;
    background: padding-box linear-gradient(transparent calc(100% - 1px),var(--accent-fill-rest) calc(100% - 1px)),border-box linear-gradient(transparent calc(100% - 2px), var(--accent-fill-rest) calc(100% - 2px)),padding-box linear-gradient(var(--neutral-fill-input-rest),var(--neutral-fill-input-rest)),border-box var(--neutral-stroke-input-rest);
    height: calc((var(--base-height-multiplier) + var(--density)) * var(--design-unit) * 1px);
    display: inline-flex;
    align-items: center;
    position: relative;
    width: 100%;
    color: var(--neutral-foreground-rest);
    background-repeat: no-repeat !important;
    transition: background-size 300ms cubic-bezier(0.1, 0.9, 0.2, 1);
    background-size: 0% 100%,0% 100%, 100% 100%, 100% 100%;
    background-position: center;
}

    input:not([type="radio"]):not([type="checkbox"]):not([disabled]):not(:focus-within):hover, textarea:not([disabled]):not(:focus-within):hover {
        background: padding-box linear-gradient(transparent calc(100% - 1px),var(--accent-fill-rest) calc(100% - 1px)),border-box linear-gradient(transparent calc(100% - 2px), var(--accent-fill-rest) calc(100% - 2px)),padding-box linear-gradient(var(--neutral-fill-input-hover),var(--neutral-fill-input-hover)),border-box var(--neutral-stroke-input-hover);
        background-size: 0% 100%,0% 100%, 100% 100%, 100% 100%;
        background-position: center;
    }

    input:not([type="radio"]):not([type="checkbox"]):not([disabled]):focus, textarea:not([disabled]):focus {
        background: padding-box linear-gradient(transparent calc(100% - 1px),var(--accent-fill-rest) calc(100% - 1px)),border-box linear-gradient(transparent calc(100% - 2px), var(--accent-fill-rest) calc(100% - 2px)),padding-box linear-gradient(var(--neutral-fill-input-focus),var(--neutral-fill-input-focus)),border-box var(--neutral-stroke-input-hover);
        background-size: 100% 100%, 100% 100%, 100% 100%,100% 100%;
        background-position: center;
    }

    input:not([type="radio"]):not([type="checkbox"]):not([disabled]):focus-visible, textarea:not([disabled]):focus-visible {
        outline: 0;
    }

textarea {
    height: calc(((var(--base-height-multiplier) + var(--density)) * var(--design-unit) * 2) * 1px);
    padding: calc(var(--design-unit) * 1.5px) calc(var(--design-unit) * 2px + 1px);
}

.intl-tel-input input:not([type="radio"]):not([type="checkbox"]) {
    padding-right: 6px;
    padding-left: 52px;
}

/*Select*/
select, .select-wrap {
    background: padding-box linear-gradient(var(--neutral-fill-rest),var(--neutral-fill-rest)),border-box var(--neutral-stroke-control-rest);
    color: var(--neutral-foreground-rest);
    border: calc(var(--stroke-width) * 1px) solid transparent;
    border-radius: calc(var(--control-corner-radius) * 1px);
    height: calc((var(--base-height-multiplier) + var(--density)) * var(--design-unit) * 1px);
    align-items: center;
    box-sizing: border-box;
    cursor: pointer;
    display: inline-flex;
    font-family: var(--body-font);
    font-size: var(--type-ramp-base-font-size);
    line-height: var(--type-ramp-base-line-height);
    font-weight: initial;
    font-variation-settings: var(--type-ramp-base-font-variations);
    padding: 0 calc(var(--design-unit) * 2.25px);
    width: 100%;
}

    select:not([disabled]):not([open]):hover, .select-wrap:not([disabled]):not([open]):hover {
        background: padding-box linear-gradient(var(--neutral-fill-hover),var(--neutral-fill-hover)),border-box var(--neutral-stroke-control-hover);
    }


/*Button*/
.button-accent {
    border: calc(var(--stroke-width) * 1px) solid transparent;
    flex-grow: 1;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    padding: 0 calc((10 + (var(--design-unit) * 2 * var(--density))) * 1px);
    white-space: nowrap;
    outline: none;
    text-decoration: none;
    position: relative;
    box-sizing: border-box;
    font-family: var(--body-font);
    font-size: var(--type-ramp-base-font-size);
    line-height: var(--type-ramp-base-line-height);
    font-weight: initial;
    font-variation-settings: var(--type-ramp-base-font-variations);
    height: calc((var(--base-height-multiplier) + var(--density)) * var(--design-unit) * 1px);
    min-width: calc((var(--base-height-multiplier) + var(--density)) * var(--design-unit) * 1px);
    border-radius: calc(var(--control-corner-radius) * 1px);
    fill: currentcolor;
    background: padding-box linear-gradient(var(--accent-fill-rest),var(--accent-fill-rest)),border-box var(--accent-stroke-control-rest);
    color: var(--foreground-on-accent-rest);
}

    .button-accent:not([disabled]):hover {
        background: padding-box linear-gradient(var(--accent-fill-hover),var(--accent-fill-hover)),border-box var(--accent-stroke-control-hover);
        color: var(--foreground-on-accent-hover);
    }

    .button-accent:not([disabled]):active {
        background: padding-box linear-gradient(var(--accent-fill-active),var(--accent-fill-active)),border-box var(--accent-stroke-control-active);
        color: var(--foreground-on-accent-active);
    }

/*Option*/
.option {
    display: flex;
    position: relative;
    font-family: var(--body-font);
    font-size: var(--type-ramp-base-font-size);
    line-height: var(--type-ramp-base-line-height);
    font-weight: initial;
    font-variation-settings: var(--type-ramp-base-font-variations);
    background: var(--neutral-fill-stealth-rest);
    border-radius: calc(var(--control-corner-radius) * 1px);
    border: calc(var(--stroke-width) * 1px) solid transparent;
    box-sizing: border-box;
    color: var(--neutral-foreground-rest);
    cursor: pointer;
    fill: currentcolor;
    height: calc((var(--base-height-multiplier) + var(--density)) * var(--design-unit) * 1px);
    overflow: hidden;
    align-items: center;
    padding: 0 calc(((var(--design-unit) * 3) - var(--stroke-width) - 1) * 1px);
    user-select: none;
    white-space: nowrap;
    width: 100%;
}


    .option:not([disabled]):hover {
        background: var(--neutral-fill-stealth-hover);
    }

    .option:not([disabled]):focus-visible {
        z-index: 2;
    }

    .option::before {
        content: "";
        display: block;
        position: absolute;
        left: calc((var(--focus-stroke-width) - var(--stroke-width)) * 1px);
        top: calc(((var(--base-height-multiplier) + var(--density)) * var(--design-unit) / 4) - var(--focus-stroke-width) * 1px);
        width: 3px;
        height: calc(((var(--base-height-multiplier) + var(--density)) * var(--design-unit) / 2) * 1px);
        background: transparent;
        border-radius: calc(var(--control-corner-radius) * 1px);
    }

    .option:not([disabled]).active::before {
        background: var(--accent-fill-rest);
        height: calc((((var(--base-height-multiplier) + var(--density)) * var(--design-unit) / 2) - 6) * 1px);
    }

    .option.selected {
        background: var(--neutral-fill-secondary-rest);
    }

        .option.selected::before {
            background: var(--accent-fill-rest);
        }

    .option:not([disabled]).selected:hover {
        background: var(--neutral-fill-secondary-hover);
    }



.option-content {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

/*Helper classes*/
.truncate {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.text-primary {
    color: var(--accent-fill-rest);
}

.text-success {
    color: var(--success);
}

.text-warning {
    color: var(--warning);
}

.text-error {
    color: var(--error);
}

.text-muted {
    color: var(--input-placeholder-rest)
}

.bg-primary {
    background: var(--accent-fill-rest);
}

.bg-secondary {
    background: var(--secondary);
}

.bg-success {
    background: var(--success);
}

.bg-warning {
    background: var(--warning);
}

.bg-error {
    background: var(--error);
}

.cursor-pointer {
    cursor: pointer;
}

.overflow-auto {
    overflow: auto;
}

.d-grid {
    display: grid;
}

/* Column span classes */
.span-1 {
    grid-column: span 1 / span 1;
}

.span-2 {
    grid-column: span 2 / span 2;
}

.span-3 {
    grid-column: span 3 / span 3;
}

.span-4 {
    grid-column: span 4 / span 4;
}

.span-5 {
    grid-column: span 5 / span 5;
}

.span-6 {
    grid-column: span 6 / span 6;
}

.span-7 {
    grid-column: span 7 / span 7;
}

.span-8 {
    grid-column: span 8 / span 8;
}

.span-9 {
    grid-column: span 9 / span 9;
}

.span-10 {
    grid-column: span 10 / span 10;
}

.span-11 {
    grid-column: span 11 / span 11;
}

.span-12 {
    grid-column: span 12 / span 12;
}

/* Start column at a specific line */
.col-1 {
    grid-column-start: 1;
}

.col-2 {
    grid-column-start: 2;
}

.col-3 {
    grid-column-start: 3;
}

.col-4 {
    grid-column-start: 4;
}

.col-5 {
    grid-column-start: 5;
}

.col-6 {
    grid-column-start: 6;
}

.col-7 {
    grid-column-start: 7;
}

.col-8 {
    grid-column-start: 8;
}

.col-9 {
    grid-column-start: 9;
}

.col-10 {
    grid-column-start: 10;
}

.col-11 {
    grid-column-start: 11;
}

.col-12 {
    grid-column-start: 12;
}

.d-flex {
    display: flex;
}

.d-inline-flex {
    display: inline-flex;
}

.flex-grow-0 {
    flex-grow: 0;
}

.flex-grow-1 {
    flex-grow: 1;
}

.flex-shrink-0 {
    flex-shrink: 0;
}

.flex-shrink-1 {
    flex-shrink: 1;
}

.flex-row {
    flex-direction: row;
}

.flex-row-reverse {
    flex-direction: row-reverse;
}

.flex-column {
    flex-direction: column;
}

.flex-column-reverse {
    flex-direction: column-reverse;
}

.flex-wrap {
    flex-wrap: wrap;
}

.align-self-start {
    align-self: start;
}

.align-self-center {
    align-self: center;
}

.align-self-end {
    align-self: end;
}

.align-self-baseline {
    align-self: baseline;
}

.align-self-stretch {
    align-self: stretch;
}

.align-items-start {
    align-items: flex-start;
}

.align-items-center {
    align-items: center;
}

.align-items-end {
    align-items: flex-end;
}

.align-items-baseline {
    align-items: baseline;
}

.align-items-stretch {
    align-items: stretch;
}

.justify-content-start {
    justify-content: flex-start;
}

.justify-content-center {
    justify-content: center;
}

.justify-content-end {
    justify-content: flex-end;
}

.justify-content-between {
    justify-content: space-between;
}

.justify-content-around {
    justify-content: space-around;
}

.justify-content-evenly {
    justify-content: space-evenly;
}

.gap-0 {
    gap: 0;
}

.gap-1 {
    gap: 0.25rem;
}

.gap-2 {
    gap: 0.5rem;
}

.gap-3 {
    gap: 1rem;
}

.gap-4 {
    gap: 1.5rem;
}

.gap-5 {
    gap: 3rem;
}

.w-25 {
    width: 25%;
}

.w-50 {
    width: 50%;
}

.w-75 {
    width: 75%;
}

.w-100 {
    width: 100%;
}

.w-auto {
    width: auto;
}

.h-25 {
    height: 25%;
}

.h-50 {
    height: 50%;
}

.h-75 {
    height: 75%;
}

.h-100 {
    height: 100%;
}

.p-0 {
    padding: 0;
}

.p-1 {
    padding: 0.25rem;
}

.p-2 {
    padding: 0.5rem;
}

.p-3 {
    padding: 1rem;
}

.p-4 {
    padding: 1.5rem;
}

.p-5 {
    padding: 3rem;
}

.pt-0 {
    padding-top: 0;
}

.pt-1 {
    padding-top: 0.25rem;
}

.pt-2 {
    padding-top: 0.5rem;
}

.pt-3 {
    padding-top: 1rem;
}

.pt-4 {
    padding-top: 1.5rem;
}

.pt-5 {
    padding-top: 3rem;
}

.pb-0 {
    padding-bottom: 0;
}

.pb-1 {
    padding-bottom: 0.25rem;
}

.pb-2 {
    padding-bottom: 0.5rem;
}

.pb-3 {
    padding-bottom: 1rem;
}

.pb-4 {
    padding-bottom: 1.5rem;
}

.pb-5 {
    padding-bottom: 3rem;
}

.ps-0 {
    padding-left: 0;
}

.ps-1 {
    padding-left: 0.25rem;
}

.ps-2 {
    padding-left: 0.5rem;
}

.ps-3 {
    padding-left: 1rem;
}

.ps-4 {
    padding-left: 1.5rem;
}

.ps-5 {
    padding-left: 3rem;
}

.pe-0 {
    padding-right: 0;
}

.pe-1 {
    padding-right: 0.25rem;
}

.pe-2 {
    padding-right: 0.5rem;
}

.pe-3 {
    padding-right: 1rem;
}

.pe-4 {
    padding-right: 1.5rem;
}

.pe-5 {
    padding-right: 3rem;
}

.px-0 {
    padding-left: 0;
    padding-right: 0;
}

.px-1 {
    padding-left: 0.25rem;
    padding-right: 0.25rem;
}

.px-2 {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.px-3 {
    padding-left: 1rem;
    padding-right: 1rem;
}

.px-4 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.px-5 {
    padding-left: 3rem;
    padding-right: 3rem;
}

.py-0 {
    padding-top: 0;
    padding-bottom: 0;
}

.py-1 {
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}

.py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.py-3 {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.py-4 {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}

.py-5 {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.m-auto {
    margin: auto;
}

.m-0 {
    margin: 0;
}

.rounded-1 {
    border-radius: calc(var(--control-corner-radius) * 1px);
}

.rounded-2 {
    border-radius: calc(var(--layer-corner-radius) * 1px);
}

.flat-left {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.flat-right {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.flat-top {
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
}

.flat-bottom {
    border-bottom-right-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.table-striped tbody tr:nth-child(odd) {
    background-color: rgba(0, 0, 0, 0.03);
}

.table-hover tbody tr:hover {
    background-color: rgba(0, 0, 0, 0.07);
}

.table > * > * > * {
    padding: .5rem .5rem;
}

/* Components with colors outside palette */
.dcr-text-clouds {
    color: var(--flow-clouds) !important;
}

.dcr-text-bg-monochrome-light {
    color: #6c757d;
    background-color: #dee2e6;
    font-weight: 600;
}

.dcr-text-bg-monochrome-lighter {
    color: #495057;
    background-color: #dee2e6;
    font-weight: 600;
}

.btn.dcr-text-bg-monochrome-medium,
.dcr-text-bg-monochrome-medium {
    color: #495057;
    background-color: #adb5bd;
    font-weight: 600;
}

/* Bootstrap color customization */

.dcr-text-bg-primary, tr.dcr-select-row.active, tr.dcr-select-row.active:hover {
    color: var(--foreground-on-accent-rest);
    background-color: var(--accent-fill-rest);
}

.dcr-text-bg-secondary, tr.dcr-select-row:hover {
    color: var(--foreground-on-accent-rest);
    background-color: var(--secondary);
}

.dcr-text-bg-success {
    color: var(--foreground-on-accent-rest);
    background-color: var(--success);
}

.dcr-text-bg-warning {
    color: var(--foreground-on-accent-rest);
    background-color: var(--warning);
}

.dcr-text-bg-error {
    color: var(--foreground-on-accent-rest);
    background-color: var(--error);
}

.w-xxl {
    width: 60rem !important;
}

.w-xl {
    width: 57.5rem !important;
}

.w-lg {
    width: 48rem !important;
}

.w-md {
    width: 38.5rem !important;
}

.w-sm {
    width: 29rem !important;
}

.w-xs {
    width: 19rem !important;
}

/* Responsive layout */
.dcr-urgency-borders {
    border-width: thin;
    border-style: solid;
}

    .dcr-urgency-borders.dcr-urgency-late {
        border-color: var(--error);
    }

    .dcr-urgency-borders.dcr-urgency-close {
        border-color: var(--accent-fill-rest);
    }

    .dcr-urgency-borders.dcr-urgency-deadline {
        border-color: var(--accent-fill-rest);
    }

    .dcr-urgency-borders.dcr-urgency-pending {
        border-color: var(--accent-fill-rest);
    }

    .dcr-urgency-borders.dcr-urgency-nonpending {
        border-color: var(--success);
    }

.dcr-urgency-text.dcr-urgency-late {
    color: var(--error);
}

.dcr-urgency-text.dcr-urgency-close {
    font-weight: 600;
    color: var(--warning);
}

.dcr-urgency-text.dcr-urgency-deadline {
    font-weight: 600;
    color: var(--accent-fill-rest);
}

.dcr-urgency-text.dcr-urgency-pending {
    font-weight: 600;
    color: var(--accent-fill-rest);
}

.dcr-urgency-text.dcr-urgency-nonpending {
    font-weight: 600;
    color: var(--success);
}

.dcr-urgency-background {
    background-color: #dee2e6;
}

    .dcr-urgency-background.dcr-urgency-late {
        background-color: var(--error);
        font-weight: 600;
        color: var(--foreground-on-accent-rest);
    }

    .dcr-urgency-background.dcr-urgency-close {
        background-color: var(--warning);
        font-weight: 600;
        color: var(--foreground-on-accent-rest);
    }

    .dcr-urgency-background.dcr-urgency-deadline {
        background-color: var(--accent-fill-rest);
        font-weight: 600;
        color: var(--foreground-on-accent-rest);
    }

    .dcr-urgency-background.dcr-urgency-pending {
        background-color: var(--accent-fill-rest);
        font-weight: 600;
        color: var(--foreground-on-accent-rest);
    }

    .dcr-urgency-background.dcr-urgency-nonpending {
        background-color: var(--success);
        font-weight: 600;
        color: var(--foreground-on-accent-rest);
    }

/* Standard panel: Slightly floating white-background rectangular container, row
 * layout, 80.0% width. */
.dcr-panel-header {
    padding: calc(var(--design-unit) * 5px);
    padding-bottom: 0;
    border-top-left-radius: calc(var(--layer-corner-radius) * 1px - 1px);
    border-top-right-radius: calc(var(--layer-corner-radius) * 1px - 1px);
}

    .dcr-panel-header:only-child, .dcr-panel-header.collapsed {
        border-radius: calc(var(--layer-corner-radius) * 1px);
        padding-bottom: calc(var(--design-unit) * 5px);
    }

.dcr-panel, .dcr-role-delegation-input .dcr-user-input-edit, .dcr-log {
    box-shadow: var(--elevation-shadow-card-rest);
    transition: box-shadow 0.2s ease-in-out;
    background-color: var(--fill-color);
    color: var(--neutral-foreground-rest);
    border-radius: calc(var(--layer-corner-radius) * 1px + 1px);
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    width: 100%;
    min-height: fit-content;
    border-width: calc(var(--stroke-width) * 1px);
}

.hoverable {
    transition: transform 0.1s ease-in-out,box-shadow 0.1s ease-in-out;
    transform: scale(1);
    transform-origin: center;
}

    .hoverable:hover {
        box-shadow: var(--elevation-shadow-flyout);
        transform: scale(1.002);
        z-index: 4;
    }

.dcr-panel .dcr-panel-body, .dcr-role-delegation-input .dcr-user-input-edit .dcr-panel-body, .dcr-log .dcr-panel-body {
    padding: calc(var(--design-unit) * 5px);
}

    .dcr-panel .dcr-panel-body.collapsed, .dcr-role-delegation-input .dcr-user-input-edit .dcr-panel-body.collapsed, .dcr-log .dcr-panel-body.collapsed {
        visibility: hidden;
    }

.dcr-panel.dcr-interactive, .dcr-role-delegation-input .dcr-interactive.dcr-user-input-edit, .dcr-interactive.dcr-log {
    color: var(--accent-fill-rest);
}

.dcr-panel.dcr-panel-primary, .dcr-role-delegation-input .dcr-panel-primary.dcr-user-input-edit, .dcr-panel-primary.dcr-log {
    border-color: var(--accent-fill-rest);
    border-style: solid;
}

    .dcr-panel.dcr-panel-primary > .dcr-panel-header, .dcr-role-delegation-input .dcr-panel-primary.dcr-user-input-edit > .dcr-panel-header, .dcr-panel-primary.dcr-log > .dcr-panel-header {
        box-shadow: inset 0px 0px 0px 2px var(--accent-fill-rest);
        background-color: var(--accent-fill-rest);
        color: var(--foreground-on-accent-rest);
        padding-bottom: calc(var(--design-unit) * 5px);
    }

.dcr-panel.dcr-panel-secondary, .dcr-role-delegation-input .dcr-panel-secondary.dcr-user-input-edit, .dcr-panel-secondary.dcr-log {
    border-color: var(--secondary);
    border-style: solid;
}

    .dcr-panel.dcr-panel-secondary > .dcr-panel-header, .dcr-role-delegation-input .dcr-panel-secondary.dcr-user-input-edit > .dcr-panel-header, .dcr-panel-secondary.dcr-log > .dcr-panel-header {
        box-shadow: inset 0px 0px 0px 2px var(--secondary);
        background-color: var(--secondary);
        color: var(--foreground-on-accent-rest);
        padding-bottom: calc(var(--design-unit) * 5px);
    }

.dcr-panel.dcr-panel-success, .dcr-role-delegation-input .dcr-panel-success.dcr-user-input-edit, .dcr-panel-success.dcr-log {
    border-color: var(--success);
    border-style: solid;
}

    .dcr-panel.dcr-panel-success > .dcr-panel-header, .dcr-role-delegation-input .dcr-panel-success.dcr-user-input-edit > .dcr-panel-header, .dcr-panel-success.dcr-log > .dcr-panel-header {
        box-shadow: inset 0px 0px 0px 2px var(--success);
        background-color: var(--success);
        color: var(--foreground-on-accent-rest);
        padding-bottom: calc(var(--design-unit) * 5px);
    }

.dcr-panel.dcr-panel-info, .dcr-role-delegation-input .dcr-panel-info.dcr-user-input-edit, .dcr-panel-info.dcr-log {
    border-color: var(--info);
    border-style: solid;
}

    .dcr-panel.dcr-panel-info > .dcr-panel-header, .dcr-role-delegation-input .dcr-panel-info.dcr-user-input-edit > .dcr-panel-header, .dcr-panel-info.dcr-log > .dcr-panel-header {
        box-shadow: inset 0px 0px 0px 2px var(--info);
        background-color: var(--info);
        color: var(--foreground-on-accent-rest);
        padding-bottom: calc(var(--design-unit) * 5px);
    }

.dcr-panel.dcr-panel-warning, .dcr-role-delegation-input .dcr-panel-warning.dcr-user-input-edit, .dcr-panel-warning.dcr-log {
    border-color: var(--warning);
    border-style: solid;
}

    .dcr-panel.dcr-panel-warning > .dcr-panel-header, .dcr-role-delegation-input .dcr-panel-warning.dcr-user-input-edit > .dcr-panel-header, .dcr-panel-warning.dcr-log > .dcr-panel-header {
        box-shadow: inset 0px 0px 0px 2px var(--warning);
        background-color: var(--warning);
        color: var(--foreground-on-accent-rest);
        padding-bottom: calc(var(--design-unit) * 5px);
    }

.dcr-panel.dcr-panel-danger, .dcr-role-delegation-input .dcr-panel-danger.dcr-user-input-edit, .dcr-panel-danger.dcr-log {
    border-color: var(--error);
    border-style: solid;
}

    .dcr-panel.dcr-panel-danger > .dcr-panel-header, .dcr-role-delegation-input .dcr-panel-danger.dcr-user-input-edit > .dcr-panel-header, .dcr-panel-danger.dcr-log > .dcr-panel-header {
        box-shadow: inset 0px 0px 0px 2px var(--error);
        background-color: var(--error);
        color: var(--foreground-on-accent-rest);
        padding-bottom: calc(var(--design-unit) * 5px);
    }

.dcr-panel .dcr-panel-header:only-child, .dcr-role-delegation-input .dcr-user-input-edit .dcr-panel-header:only-child, .dcr-log .dcr-panel-header:only-child {
    border-radius: calc(var(--layer-corner-radius) * 1px - 1px);
}

.dcr-panel-body:empty {
    padding: 1.5rem 0 0 0;
}

a.dcr-panel, .dcr-role-delegation-input a.dcr-user-input-edit, a.dcr-log {
    text-decoration: none;
}

    a.dcr-panel :hover, .dcr-role-delegation-input a.dcr-user-input-edit :hover, a.dcr-log :hover {
        color: #212529;
    }

/* Layout */
/* Standard component customization / bootstrap overrides */

.alert {
    border-radius: calc(var(--layer-corner-radius) * 1px);
    max-width: 25rem;
}

.list-group,
.list-group.list-group-flush {
    border-radius: calc(var(--control-corner-radius) * 1px);
}

.main > .alert {
    align-self: center;
    justify-self: center;
}

.input-group-text:first-child {
    border-radius: calc(var(--control-corner-radius) * 1px);
}

/* Blazored modal overrides */
.blazored-modal {
    position: absolute;
    top: 44px;
    max-height: 85%;
    max-width: 80%;
    width: 80%;
    box-sizing: border-box;
    overflow-x: hidden;
    box-shadow: var(--elevation-shadow-card-rest);
    transition: box-shadow 0.2s ease-in-out;
    background-color: var(--fill-color);
    color: var(--neutral-foreground-rest);
    border-radius: calc(var(--layer-corner-radius) * 1px + 1px);
    display: flex;
    border: calc(var(--stroke-width) * 1px) solid var(--neutral-stroke-layer-rest);
}

.blazored-modal-header {
    align-items: baseline;
}

.blazored-modal-content {
    display: flex;
    flex-direction: column;
    height: 100%;
    max-height: 80vh;
    overflow-y: auto;
    box-sizing: border-box;
    margin: 0;
    padding: 0.0rem 0.8rem;
}

/* Bootstrap override*/

#dcr-circle-right {
    fill: var(--flow-clouds);
}

.dcr-circle-right {
    overflow: visible;
    margin: auto;
    height: 100%;
    /* left: 1265.3px */
    transform: matrix(1, 0, 0, 1, 0, 0);
}

.circle-container {
    height: 50%;
}

.background {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    z-index: -2;
}

/* Header
 */
.navbar {
    top: 0;
    left: 0;
    pointer-events: none;
    position: absolute;
    z-index: 99;
}

@media (max-width: 1366px) {
    .navbar {
        position: fixed;
    }
}

.dcr-nav-item {
    height: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: calc(var(--layer-corner-radius) * 1px);
    border-width: 1px;
    border-style: solid;
    background-color: var(--fill-color);
    border-color: var(--accent-fill-rest);
    pointer-events: auto;
    text-decoration: none !important;
}

.dcr-nav-icon {
    width: 2.5rem;
    color: var(--accent-fill-rest);
}

    .dcr-nav-icon i {
        border: none;
    }

a.dcr-nav-icon {
    text-decoration-line: none;
}

.dcr-nav-box {
    min-width: 2.5rem;
    color: var(--accent-fill-rest);
    padding-right: 1rem;
    padding-left: 1rem;
}

    .dcr-nav-box:hover {
        color: var(--accent-foreground-hover);
    }

    .dcr-nav-box img {
        height: 100%;
        width: auto;
    }

.dcr-tenant-logo {
    height: 100%;
}

.dcr-tenant-logo-image {
    height: 100%;
    width: auto;
    object-fit: cover;
}

/* Footer
 */
.footer {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 40px;
    background-color: var(--flow-footer);
    display: flex;
    justify-content: center;
    z-index: 50;
}

.rump {
    width: 184px;
    height: 100%;
    position: absolute;
    bottom: 0;
    left: calc(50% - 92px);
    transform: skew(-22.5deg);
    background-color: rgba(220, 233, 252, 0.059);
}

.dcr-logo {
    width: 184px;
    height: 100%;
    margin: auto;
    overflow: visible;
    fill: white;
    display: flex;
    justify-content: center;
    align-items: center;
}

.dcr-letter {
    height: 25px;
    width: 12px;
}

    .dcr-letter:nth-child(1) {
        margin-right: 2px;
    }

    .dcr-letter:nth-child(2) {
        margin-right: 3px;
    }

/* Vertical forms */
form {
    display: flex;
    flex-direction: column;
}

.field:not(:first-child) {
    margin-top: 1.6rem;
}

.field {
    display: flex;
    flex-direction: column;
}

    .field input[type=text],
    .field input[type=password],
    .field input[type=email] {
        height: 2.4rem;
        border-width: 1pt;
        border-color: #ced4da;
        border-radius: calc(var(--control-corner-radius) * 1px);
        padding: 0.2rem 0.8rem 0.2rem 0.8rem;
    }

    .field *:not(:last-child) {
        margin-bottom: 0.26rem;
    }

/* Phase styling */
.dcr-card-phase {
    min-width: 8rem;
    padding: 0.2rem 0.8rem;
    border-style: none;
    border-radius: 18pt;
}

.list-group-item {
    border-radius: calc(var(--control-corner-radius) * 1px);
}

    .list-group-item.dcr-panel:first-child, .dcr-role-delegation-input .list-group-item.dcr-user-input-edit:first-child, .list-group-item.dcr-log:first-child, .list-group-item.dcr-panel:last-child, .dcr-role-delegation-input .list-group-item.dcr-user-input-edit:last-child, .list-group-item.dcr-log:last-child {
        border-radius: calc(var(--control-corner-radius) * 1px);
    }

.infobox {
    display: flex;
    flex-direction: row;
    justify-content: space-around;
    border-radius: calc(var(--control-corner-radius) * 1px);
    background-color: #ced4da;
}

/* "Advanced" section animation */
.advanced a {
    color: #212529;
}

    .advanced a:hover {
        color: var(--accent-fill-rest);
    }

.advanced .bi {
    transition: 0.3s transform ease-in-out;
    position: relative;
    top: 0.8px;
    color: gray;
    transform: scale(0.66) rotate(-90deg);
}

.advanced .bi {
    color: var(--accent-fill-rest);
}

.advanced .collapsed .bi {
    transform: scale(0.66) rotate(0deg);
}

/* SOP specific layout */
.field.advanced {
    min-height: 5rem;
}

.dcr-register-link {
    color: black;
    text-decoration: underline;
}

.dcr-line {
    align-items: center;
    border-bottom: 0.8px solid #dadde1;
    display: flex;
    margin: 16px 12px;
    text-align: center;
}

.dcr-login-btn {
    width: 100%;
    color: var(--foreground-on-accent-rest);
    font-weight: 600;
}

    .dcr-login-btn:hover {
        color: var(--foreground-on-accent-rest);
    }

/* Law text specific layout */
.dcr-law-to-text {
    width: 51rem;
}

/* login specific layout */
#login-submit {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

#login-spinner {
    margin-top: 3.2px;
}

#login-notice {
    height: 2rem;
}

/* HOME */
.dcr-nav-card {
    width: 12rem;
    height: 7rem;
    border-radius: calc(var(--layer-corner-radius) * 1px);
    border-width: 1pt;
    border-color: var(--accent-fill-rest);
    background-color: var(--accent-fill-rest);
    color: var(--foreground-on-accent-rest);
    margin: 3rem;
    transition: background-color 0.25s ease;
}

    .dcr-nav-card > a {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-start;
        color: var(--foreground-on-accent-rest);
        text-decoration: none;
        height: 6rem;
    }

        .dcr-nav-card > a > span {
            height: 4rem;
            padding-top: 1.6rem;
            padding-bottom: 1.6rem;
            font-size: 20pt;
        }

        .dcr-nav-card > a > h4, .dcr-nav-card > a > .h4 {
            height: 1.6rem;
        }

    .dcr-nav-card:hover {
        background-color: var(--warning);
    }

.dcr-tasklist {
    border-bottom-left-radius: calc(var(--layer-corner-radius) * 1px);
    border-bottom-right-radius: calc(var(--layer-corner-radius) * 1px);
}

    .dcr-tasklist > *:last-child {
        border-bottom-left-radius: calc(var(--layer-corner-radius) * 1px);
        border-bottom-right-radius: calc(var(--layer-corner-radius) * 1px);
    }

    .dcr-tasklist .container-fluid, .dcr-tasklist .container-sm, .dcr-tasklist .container-md, .dcr-tasklist .container-lg, .dcr-tasklist .container-xl, .dcr-tasklist .container-xxl {
        padding: 0;
        margin: 0;
    }

    .dcr-tasklist .status .success {
        color: var(--success);
    }

    .dcr-tasklist .status .deadline.missed {
        color: var(--error);
    }

    .dcr-tasklist .status .deadline {
        color: var(--accent-fill-rest);
    }

    .dcr-tasklist .status .info {
        color: gray;
    }

    .dcr-tasklist .deadline {
        color: var(--accent-fill-rest);
    }

    .dcr-tasklist .dcr-action {
        display: flex;
        flex-direction: row;
        justify-content: flex-end;
        padding-right: 2rem;
    }

        .dcr-tasklist .dcr-action button {
            display: flex;
            flex-direction: row;
            justify-content: center;
            align-items: center;
        }

        .dcr-tasklist .dcr-action .dcr-control-container {
            width: auto !important;
        }

        .dcr-tasklist .dcr-action button {
            min-width: 5rem;
            height: 2rem;
            border-radius: calc(var(--control-corner-radius) * 1px);
            font-size: small;
        }

    .dcr-tasklist > .container-fluid > .row, .dcr-tasklist > .container-sm > .row, .dcr-tasklist > .container-md > .row, .dcr-tasklist > .container-lg > .row, .dcr-tasklist > .container-xl > .row, .dcr-tasklist > .container-xxl > .row {
        padding: 1.2rem 0rem;
    }

    .dcr-tasklist.inactive .row:nth-child(even) {
        background-color: #ced4da;
    }

    .dcr-tasklist.inactive .row:nth-child(odd) {
        background-color: #dee2e6;
    }

    .dcr-tasklist.inactive button {
        background-color: #adb5bd;
        border: none;
    }

.row {
    min-height: 5rem;
    padding-right: 0;
    padding-left: 0;
}

.dcr-tasklist {
    min-height: 5rem;
}

    .dcr-tasklist .dcr-row-style-a {
        min-height: 5rem;
        background-color: var(--fill-color);
    }

    .dcr-tasklist .dcr-row-style-b {
        min-height: 5rem;
        background-color: var(--neutral-fill-layer-alt-rest);
    }

.dcr-tasklist-sub-contents {
    border: calc(var(--stroke-width)* 1px) solid var(--neutral-stroke-layer-rest);
    overflow: clip;
    box-shadow: var(--elevation-shadow-card-rest);
    border-radius: calc(var(--control-corner-radius) * 1px);
}

.row.dcr-tasklist-sub-row {
    padding-top: 0 !important;
}

    .row.dcr-tasklist-sub-row .row {
        padding: 0.4rem 0rem;
    }

.dcr-annotation-container {
    position: relative;
    display: flex;
    flex-direction: column;
}

    .dcr-annotation-container .invalid-feedback,
    .dcr-annotation-container .valid-feedback,
    .dcr-annotation-container .feedback,
    .dcr-annotation-container .annotation {
        position: absolute;
        bottom: -1.2rem;
    }

.dcr-form {
    flex-grow: 1;
    transition: max-height 0.3s ease-in-out;
    /* Override fixed-size annotation for file control in form context */
}

    .dcr-form button {
        border-radius: calc(var(--control-corner-radius) * 1px);
    }

    .dcr-form .dcr-file-control .dcr-annotation-container div {
        position: static;
    }

    .dcr-form fieldset {
        border-style: none none none solid;
        border-width: thin;
        margin-bottom: 0.0rem;
        padding-right: 0;
        padding: 0 0 0 1.2rem;
    }

        .dcr-form fieldset > div > div:last-child {
            margin-bottom: 0;
        }

.dcr-form-submission .dcr-form-submit,
.dcr-form-submission .dcr-form-draft-btn,
.dcr-form-submission .dcr-form-submit,
.dcr-form-submission .dcr-form-submit-btn,
.dcr-form-submission .dcr-form-cancel-btn {
    min-width: 6rem;
    height: 2.4rem;
    max-height: 2.4rem;
}

.dcr-form-control {
    margin-bottom: 1.04rem;
}

.dcr-file-control {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    width: 100%;
}

    .dcr-file-control .dcr-file-list > a {
        padding-top: 0.53rem;
        display: flex;
        text-decoration-line: none;
        justify-content: flex-start;
        align-items: center;
    }

        .dcr-file-control .dcr-file-list > a:last-child {
            margin-bottom: 0.53em;
        }

        .dcr-file-control .dcr-file-list > a .dcr-delete-badge {
            position: relative;
            right: -0.5rem;
            top: -0.5rem;
        }

.dcr-delete-badge {
    width: 1rem;
    height: 1rem;
    border-radius: 50.0%;
    background-color: var(--foreground-on-accent-rest);
    color: #6c757d;
    cursor: pointer;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: color 100ms ease-in-out;
}

    .dcr-delete-badge:hover {
        color: #ff403d;
    }

.dcr-image-control {
    display: flex;
    flex-flow: row wrap;
    gap: 0.66rem;
    justify-content: start;
    width: 100%;
}

    .dcr-image-control .dcr-image-control-container {
        display: flex;
        align-items: flex-start;
    }

        .dcr-image-control .dcr-image-control-container img {
            cursor: pointer;
            border: calc(var(--stroke-width) * 1px) solid var(--neutral-stroke-rest);
            border-radius: calc(var(--control-corner-radius) * 1px);
            width: 45%;
            aspect-ratio: auto;
        }

        .dcr-image-control .dcr-image-control-container .dcr-delete-badge {
            position: relative;
            right: 0.75rem;
            top: -0.25rem;
        }

        .dcr-image-control .dcr-image-control-container .dcr-annotation-container {
            width: 16.0%;
        }

.dcr-delegation-control {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
}

    .dcr-delegation-control input {
        margin-right: 2.4rem;
    }

.dcr-delegation-page {
    overflow: auto;
}

.dcr-share-row.row {
    margin-top: -2.4rem;
}

.dcr-share-row-container {
    border-radius: calc(var(--layer-corner-radius) * 1px);
    border-style: solid;
    border-color: var(--secondary);
    border-width: 0.8px;
    background-color: var(--foreground-on-accent-rest);
    padding: 0.53rem 1.2rem;
    margin-top: 0.53rem;
}

.dcr-share.dcr-share-share-new {
    color: var(--secondary);
}

.dcr-share.dcr-share-accessed {
    color: var(--accent-fill-rest);
}

.dcr-share.dcr-share-completed {
    color: var(--success);
}

.dcr-share.dcr-share-mail-sent {
    color: var(--warning);
}

.dcr-share.dcr-share-mail-failed {
    color: var(--error);
}

.dcr-share.dcr-share-unknown {
    color: #495057;
}

.dcr-share .row {
    padding-top: 0.53rem;
    padding-bottom: 0.53rem;
}

.dcr-share input {
    filter: none;
}

/* DCR Case */
.dcr-log {
    height: 100%;
}

/* DCR Cases */
.dcr-case {
    padding-left: 4.0rem;
    padding-right: 4.0rem;
}

button.dcr-fab {
    height: 1.2rem;
    width: 1.2rem;
    padding: 1.2rem;
    border-radius: 50.0%;
    display: flex;
    justify-content: center;
    align-items: center;
    border: none;
    transform: scale(0.9);
}

    button.dcr-fab:active {
        transform: scale(0.85);
    }

.dcr-fab {
    background-color: var(--success);
    color: var(--foreground-on-accent-rest);
}

button.dcr-add {
    padding: 0;
    height: 1.2rem;
    width: 1.2rem;
    border-radius: 40.0%;
    display: flex;
    justify-content: center;
    align-items: center;
    border: none;
}

    button.dcr-add:active {
        transform: scale(0.9);
    }

.dcr-add {
    background-color: var(--success);
    color: var(--foreground-on-accent-rest);
}

.dcr-remove {
    height: 1.2rem;
    width: 1.2rem;
    border-radius: 40.0%;
    justify-content: center;
    align-items: center;
    display: flex;
    border: none;
}

    .dcr-remove:active {
        transform: scale(0.9);
    }

.small-clickable, button.btn.small, .btn.dcr-help-text, .dcr-case-admin .btn.dcr-role-delegation-state, .btn.dcr-byline {
    border: none;
    color: inherit;
    background-color: #dee2e6;
}

    .small-clickable:active, button.btn.small:active, .btn.dcr-help-text:active, .dcr-case-admin .btn.dcr-role-delegation-state:active, .btn.dcr-byline:active {
        transform: scale(0.9);
    }

    .small-clickable:hover, button.btn.small:hover, .btn.dcr-help-text:hover, .dcr-case-admin .btn.dcr-role-delegation-state:hover, .btn.dcr-byline:hover {
        background-color: #ced4da;
    }

button.btn.small, .btn.dcr-help-text, .dcr-case-admin .btn.dcr-role-delegation-state, .btn.dcr-byline {
    height: 1.2rem;
    padding: 0 0.4rem;
    font-size: 8pt;
}

i.background-interactive {
    color: #6c757d;
}

    i.background-interactive:active {
        transform: scale(0.9);
    }

    i.background-interactive:hover {
        color: #343a40;
    }

.link {
    color: var(--accent-fill-rest);
}

.dcr-role-delegation-pane {
    min-width: 40rem;
    padding: 5px;
}

    .dcr-role-delegation-pane .row {
        padding-bottom: 0.8rem;
    }

        .dcr-role-delegation-pane .row:first-child {
            padding-bottom: 1.2rem;
        }

        .dcr-role-delegation-pane .row .col-5 input,
        .dcr-role-delegation-pane .row .col-4 input {
            margin-left: -0.6rem;
        }

/* https://www.w3schools.com/css/css_tooltip.asp */
button[disabled].dcr-tooltip {
    pointer-events: auto;
}

.dcr-tooltip {
    position: relative;
    display: inline-block;
    /* Animation */
    /* Positioning */
}

    .dcr-tooltip .dcr-tooltip-text {
        width: 20rem;
        color: var(--foreground-on-accent-rest);
        background-color: #212529;
        text-align: center;
        padding: 0.4rem 0.24rem;
        border-radius: calc(var(--control-corner-radius) * 1px);
        position: absolute;
        z-index: 1;
        transition: opacity 0.3s;
    }

    .dcr-tooltip .dcr-tooltip-text {
        opacity: 0;
        visibility: hidden;
    }

    .dcr-tooltip:hover .dcr-tooltip-text {
        visibility: visible;
        opacity: 1;
    }

    .dcr-tooltip .dcr-tooltip-text.dcr-tooltip-top {
        bottom: 0%;
        left: 50%;
        transform: translate(-50%, -100%);
    }

        .dcr-tooltip .dcr-tooltip-text.dcr-tooltip-top::after {
            content: " ";
            position: absolute;
            top: 80.0%;
            left: 40.0%;
            margin-left: -4.0px;
            border-width: 0.8px;
            border-style: solid;
            border-color: #212529 transparent transparent transparent;
        }

    .dcr-tooltip .dcr-tooltip-text.dcr-tooltip-left {
        top: 50%;
        right: 110%;
        transform: translate(0, -50%);
    }

        .dcr-tooltip .dcr-tooltip-text.dcr-tooltip-left::after {
            content: " ";
            position: absolute;
            top: 40.0%;
            left: 80.0%;
            margin-top: -4.0px;
            border-width: 0.8px;
            border-style: solid;
            border-color: transparent transparent transparent #212529;
        }

    .dcr-tooltip .dcr-tooltip-text.dcr-tooltip-bottom {
        top: 0%;
        left: 50%;
        transform: translate(-50%, 100%);
    }

        .dcr-tooltip .dcr-tooltip-text.dcr-tooltip-bottom::after {
            content: " ";
            position: absolute;
            bottom: 80.0%;
            left: 40.0%;
            margin-left: -4.0px;
            border-width: 0.8px;
            border-style: solid;
            border-color: transparent transparent #212529 transparent;
        }

    .dcr-tooltip .dcr-tooltip-text.dcr-tooltip-right {
        top: 50%;
        left: 110%;
        transform: translate(0, -50%);
    }

        .dcr-tooltip .dcr-tooltip-text.dcr-tooltip-right::after {
            content: " ";
            position: absolute;
            top: 40.0%;
            right: 80.0%;
            margin-top: -4.0px;
            border-width: 0.8px;
            border-style: solid;
            border-color: transparent #212529 transparent transparent;
        }

.dcr-reason {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

ul.dcr-reason-list {
    margin-bottom: 0;
    padding-left: 0rem;
}

    ul.dcr-reason-list li {
        text-align: left;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: flex-start;
    }

        ul.dcr-reason-list li:not(:last-child) {
            margin-bottom: 0.4rem;
        }

        ul.dcr-reason-list li i {
            width: 2.5rem;
            display: inline-block;
            text-align: center;
            padding: 0.8rem;
        }

        ul.dcr-reason-list li p {
            display: inline-block;
            margin-bottom: 0;
        }

    ul.dcr-reason-list .dcr-reason-cond i {
        color: var(--warning);
    }

    ul.dcr-reason-list .dcr-reason-mile i {
        color: var(--warning);
    }

    ul.dcr-reason-list .dcr-reason-excluded i {
        color: var(--error);
    }

.dcr-case-delegate {
    max-width: 60rem;
}

.dcr-form-delegation-pane {
    min-width: 33rem;
    margin-top: 0.4rem;
    margin-left: 0.4rem;
}

    .dcr-form-delegation-pane .dcr-user-input {
        width: 100%;
        margin-right: 0.8rem;
    }

    .dcr-form-delegation-pane .dcr-user-input-edit + button {
        display: none;
    }

.dcr-guest-search-input {
    margin-bottom: 1.04rem;
}

.dcr-case-admin .dcr-check {
    width: 1.6rem;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-left: 0.8rem;
    height: 2.4rem;
}

.dcr-case-admin .dcr-search-input {
    flex-grow: 1;
}

.dcr-case-admin .dcr-role-delegation-state {
    height: 1.6rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dcr-case-admin .dcr-role-delegation-title {
    width: 21%;
    height: 3rem;
    line-height: 3rem;
}

.dcr-case-admin .dcr-role-delegation-input {
    flex-grow: 1;
}

    .dcr-case-admin .dcr-role-delegation-input .dcr-user-input {
        height: auto;
        display: flex;
        align-items: center;
    }

.dcr-case-admin .dcr-role-delegation-row .dcr-check {
    height: 3rem;
}

.dcr-role-delegation .col-4,
.dcr-role-delegation .col-8 {
    display: flex;
    padding: 0;
    align-items: center;
}

.dcr-role-delegation .dcr-user-input {
    width: 100%;
}

.dcr-role-delegation-input .dcr-user-input-edit {
    padding: 0.16rem;
    border-style: solid;
    border-color: #adb5bd;
}

.dcr-delegation-row div i {
    width: 1.6rem;
}

.dcr-last-update .dcr-tooltip-text {
    width: 12rem;
}

.dcr-delegate a {
    text-decoration: none;
}

.dcr-cases-search i {
    color: #adb5bd;
}

.dcr-cases-search form {
    min-width: 10rem;
}

.collapsible-container {
    max-height: 4096px;
    overflow: hidden;
    transition: max-height 0.2s ease-in-out;
}

    .collapsible-container.collapsed {
        max-height: 0;
    }

.dcr-gear-button {
    transition: 0.2s transform ease-in-out;
    position: relative;
    transform: rotate(0deg);
    cursor: pointer;
}

    .dcr-gear-button:hover {
    }

    .dcr-gear-button.collapsed {
        transform: rotate(90deg);
    }

.dcr-form-control-with-pending-flag {
    position: relative;
    width: 100%;
    display: flex;
    flex-direction: row;
    align-items: center;
}

    .dcr-form-control-with-pending-flag .dcr-annotation-container {
        width: 100%;
    }

    .dcr-form-control-with-pending-flag .dcr-form-pending-flag {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        position: relative;
    }

        .dcr-form-control-with-pending-flag .dcr-form-pending-flag .dcr-form-pending-circle {
            height: 6px;
            width: 6px;
            background-color: var(--accent-fill-rest);
            border-radius: 50.0%;
            position: absolute;
            left: -1rem;
            top: -3px;
        }

    .dcr-form-control-with-pending-flag.hide-hint-text .hint-text {
        display: none;
    }

main > .dcr-search.dcr-panel, main > .dcr-search.dcr-log, .dcr-role-delegation-input main > .dcr-search.dcr-user-input-edit {
    min-width: 72rem;
}

.dcr-table th:first-child,
.dcr-table td:first-child {
    padding-left: 1.2rem;
}

.dcr-table th:last-child,
.dcr-table td:last-child {
    padding-right: 1.2rem;
}

.criipto-eid-btn {
    padding: .25rem .75rem .25rem 1rem;
    height: 42px;
    box-sizing: border-box;
    text-decoration: none;
    border: 0;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 12.8px;
    font-family: "IBM Plex Sans", sans-serif;
    font-weight: 600;
    font-size: 12px;
    color: #FFF;
    justify-content: flex-start;
    width: 100%;
    background: #0060E6;
    margin-top: 0.4rem;
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

    .criipto-eid-btn:hover {
        background-color: #1a7aff;
    }

    .criipto-eid-btn .criipto-eid-logo {
        width: 88px;
        height: 18px;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: flex-end;
        flex-shrink: 0;
    }

        .criipto-eid-btn .criipto-eid-logo img {
            max-width: 16.0%;
            max-height: 16.0%;
        }

.dcr-help-text {
    opacity: 0;
    position: absolute;
    color: var(--accent-fill-rest);
    margin-top: 0.08rem;
    margin-left: 0.08rem;
    transition: opacity 0.33s ease-in-out;
}

.dcr-help-container:hover .dcr-help-text {
    opacity: 1;
}

.archived-color {
    background-color: var(--neutral-layer-2);
}

.dcr-form-conflict-header {
}

.dcr-form-conflict-form {
    background-color: var(--neutral-layer-2);
    opacity: .66;
}

.dcr-form-container {
    display: flex;
    flex-direction: column;
    height: 100%;
    margin-left: 0pt;
    margin-right: 0pt;
}

.dcr-feel-parameter.dcr-feel-active {
    text-decoration: underline;
}

tr.dcr-select-row {
    padding-left: .24rem;
    padding-right: .24rem;
    /*
    & button.dcr-select-action {
        display: none;

    }

    &:hover button.dcr-select-action {
        display: inline-block !important;
    }
    */
}

.shake {
    animation: shake 0.82s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
    transform: translate3d(0, 0, 0);
    backface-visibility: hidden;
    perspective: 1000px;
    border: red 2px solid;
}

@keyframes shake {
    8.0%, 72.0% {
        transform: translate3d(-0.8px, 0, 0);
    }

    20%, 80% {
        transform: translate3d(2px, 0, 0);
    }

    24.0%, 40.0%, 56.0% {
        transform: translate3d(-3.2px, 0, 0);
    }

    40%, 60% {
        transform: translate3d(4px, 0, 0);
    }
}

.grid-container {
    display: flex;
    flex-direction: row-reverse;
    height: 100vh;
    transition: all 0.3s ease-in-out;
    overflow: hidden;
}

@media (max-width: 768px) {
    .grid-container {
        flex-direction: column;
        overflow-y: auto;
    }
}

.main-content {
    flex-grow: 1;
    padding: 16px;
    overflow-y: auto;
    overflow-x: hidden;
    transition: width 0.3s ease-in-out;
    margin: 0 1rem 0 1rem;
}

@media (max-width: 768px) {
    .main-content {
        width: 100%;
        height: 100%;
        overflow-y: unset;
        overflow-x: unset;
    }
}

.drawer {
    flex-basis: 0;
    min-width: 0;
    max-width: 0;
    max-height: 0;
    overflow-y: auto;
    background-color: #f8f9fa;
    padding: 0;
    transition: max-width 0.3s ease-in-out;
}

    .drawer.open {
        flex-basis: auto;
        max-width: 50%;
        padding: 16px;
        max-height: 100%;
    }

@media (max-width: 768px) {
    .drawer.open {
        height: 100%;
        overflow-y: unset;
        flex-basis: auto;
        max-width: none;
        width: 100%;
        padding: 8px;
    }
}

.drawer.open + .main-content {
    width: 40rem;
}

@media (max-width: 768px) {
    .drawer.open + .main-content {
        width: 100%;
        margin: 0;
    }
}

.dcr-form-small {
    max-width: 72ch;
}

.drawer-toggle {
    position: absolute;
    top: 0;
    right: 0;
    padding: 2rem;
    color: var(--accent-fill-rest);
}

@media (max-width: 768px) {
    .drawer-toggle {
        transform: rotate(90deg);
    }
}

.drawer-toggle:focus-visible {
    border-color: transparent;
    box-shadow: none;
    outline: none;
}

.fluent-stack {
    position: sticky;
    bottom: 0;
    width: unset !important;
    padding: 16px;
    background-color: var(--fill-color);
    margin: 0 0.2rem 0 1rem;
}

@media (max-width: 768px) {
    .fluent-stack {
        margin: 0;
        padding-left: 16px;
        padding-right: 6px;
    }
}

.dcr-form-buttons {
    max-width: 0;
    max-height: 0;
    padding: 0;
    transition: max-width 0.3s ease-in-out;
}

    .dcr-form-buttons.open {
        display: flex;
        max-width: 100%;
        width: 100%;
        padding: unset;
        max-height: 100%;
    }

@media (max-width: 768px) {
    .dcr-form-buttons.open {
        max-width: 0;
        max-height: 0;
        padding: 0;
    }
}

.dcr-form-buttons-stack {
    padding-right: 16px;
    margin: 0 1rem 0 0;
}

@media (max-width: 768px) {
    .dcr-form-buttons-stack {
        margin: 0;
        padding: 0;
        padding-right: 0px;
    }
}

#blazor-error-ui {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1000;
}

    #blazor-error-ui > .alert {
        border-radius: calc(var(--layer-corner-radius) * 1px);
        max-width: 25rem;
        padding: 1rem;
        background: white;
        box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
    }

.validation-message {
    color: var(--error);
    font-size: var(--type-ramp-minus-1-font-size);
    display: flex;
    align-items: center;
    column-gap: 4px;
}
/*Icon Sizes*/
.icon-xs {
    font-size: var(--type-ramp-minus-2-font-size);
}

.icon-s {
    font-size: var(--type-ramp-minus-1-font-size);
}

.icon-m {
    font-size: var(--type-ramp-base-font-size);
}

.icon-l {
    font-size: var(--type-ramp-plus-1-font-size);
}

.icon-xl {
    font-size: var(--type-ramp-plus-2-font-size);
}

.icon-xxl {
    font-size: var(--type-ramp-plus-4-font-size);
}

.dcr-button {
    display: contents;
}

.round-btn::part(control) {
    padding: unset !important;
}

/*Paginator*/
.fluent-paginator {
    display: flex;
    justify-content: center;
}

    .fluent-paginator > .dcr-button:not(:first-child):not(:last-child) > fluent-button {
        border-radius: 0;
    }

    .fluent-paginator > .dcr-button:first-child > fluent-button {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    .fluent-paginator > .dcr-button:last-child > fluent-button {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

/*Fluent Overrides*/
fluent-select[aria-multiselectable="true"]::part(listbox) {
    position: relative;
    padding: 0;
    box-shadow: none;
}

.fluent-inputfile-container .inputfile-content {
    z-index: unset !important;
    width: 100%;
}
/*
    css trickery to avoid using media query
    https://www.freecodecamp.org/news/the-fab-four-technique-to-create-responsive-emails-without-media-queries-baf11fdfa848#.qn28y65bx
    in short use 80.0% width when the screen is less than 400.0px
*/
fluent-dialog::part(control) {
    min-width: var(--dialog-width);
    max-width: 100%;
    width: calc((500px - 100%) * 500) !important;
}

fluent-dialog .fluent-dialog-footer:empty {
    display: none !important;
}

fluent-option::before {
    --accent-fill-rest: hsl(var(--accent-hue), var(--accent-saturation), var(--accent-lightness-clamped)) !important;
}
/*Popover menu*/
.relative-menu {
    pointer-events: initial;
    background-color: var(--neutral-layer-floating);
    color: var(--neutral-foreground-rest);
    min-width: max-content;
    border: calc(var(--stroke-width) * 1px) solid transparent;
    border-radius: calc(var(--layer-corner-radius) * 1px);
    box-shadow: var(--elevation-shadow-flyout);
    padding: calc((var(--design-unit) - var(--stroke-width)) * 1px);
}

    .relative-menu:focus-visible {
        outline: 0;
    }
/*phone list menu*/
.iti--inline-dropdown .iti__dropdown-content {
    background-color: var(--neutral-layer-floating);
    border: calc(var(--stroke-width) * 1px) solid transparent;
    border-radius: calc(var(--layer-corner-radius) * 1px);
    box-shadow: var(--elevation-shadow-flyout);
    padding: calc((var(--design-unit) - var(--stroke-width)) * 1px);
}
/*Required for sticky popovers*/
[popover] {
    position: absolute;
    top: 0;
    left: 0;
    margin: 0;
}

[menu-option] {
    cursor: pointer;
}
/*Overview */
.overview-hud-square {
    border-radius: 1rem;
    color: var(--foreground-on-accent-rest);
    display: flex;
    padding: 1rem;
}

    .overview-hud-square.primary {
        background: var(--accent-fill-rest);
    }

    .overview-hud-square.success {
        background: var(--success);
    }

    .overview-hud-square.warning {
        background: var(--warning);
    }

    .overview-hud-square.error {
        background: var(--error);
    }

/*Progress bars*/
.progress,
.progress-stacked {
    display: flex;
    height: 1rem;
    overflow: hidden;
    background-color: var(--neutral-layer-2);
    border-radius: calc(var(--control-corner-radius) * 1px);
}

.progress-bar {
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
    text-align: center;
    white-space: nowrap;
    transition: width 0.6s ease;
}

@media (prefers-reduced-motion: reduce) {
    .progress-bar {
        transition: none;
    }
}

.progress-stacked > .progress {
    overflow: visible;
}

    .progress-stacked > .progress > .progress-bar {
        width: 100%;
    }

/*Badge*/
.badge {
    border-radius: calc(var(--control-corner-radius) * 1px);
    padding: calc(((var(--design-unit) * 0.5) - var(--stroke-width)) * 1px) calc((var(--design-unit) - var(--stroke-width)) * 1px);
    border: calc(var(--stroke-width) * 1px) solid transparent;
}

    .badge.accent {
        background: var(--accent-fill-rest);
        color: var(--foreground-on-accent-rest);
    }

    .badge.secondary {
        background: var(--secondary);
        color: var(--foreground-on-accent-rest);
    }

    .badge.success {
        background: var(--success);
        color: var(--foreground-on-accent-rest);
    }

    .badge.error {
        background: var(--error);
        color: var(--foreground-on-accent-rest);
    }
    .badge.info {
        background: #0dcaf0!important;
        color: #212529!important;
    }
/*Tabs*/
.nav {
    display: flex;
    flex-wrap: wrap;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
    position: relative;
    --n-tabs: 1;
    --tab-width: calc(100% / var(--n-tabs));
    --tab-index: 1;
}

.nav-link {
    width: 100%;
    display: block;
    padding: .5rem 1rem;
    color: var(--neutral-foreground-rest);
    text-decoration: none;
}

    .nav-link.active {
        color: var(--accent-fill-rest);
    }

.nav > .nav-link,
.nav .nav-item {
    flex: 1 1 auto;
    text-align: center;
}

/*Simple Modal*/
.modal {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1060;
    display: none;
    width: 100%;
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    outline: 0;
    background: rgba(0, 0, 0, 0.3);
    align-items: center;
    justify-content: center;
    opacity: 0;
}

    .modal.open {
        display: flex;
        opacity: 1;
    }

    .modal > * {
        width: 50%;
        max-height: 80%;
        box-shadow: var(--elevation-shadow-dialog);
    }

.fade {
    transition: opacity .15s linear;
}
