@import url('/v4/style/fa.min.css');
@import url('/v4/style/fa.v4.font-face.min.css');
@import url('/v4/style/fa.v4.shims.min.css');
@import url('/v4/style/xview-module.css');


script {
    display: none !important;
}

::placeholder {
    color: var(--font-color-placeholder);
    font-style: italic;
}

a {
    text-decoration: none;
    color: var(--font-color-body);
}

a:hover {
    text-decoration: underline;
}

a[x-icon]:hover::before {
    text-decoration: none;
}

.tiny {
    font-size: var(--font-tiny);
}

.small {
    font-size: var(--font-small);
}

.med {
    font-size: var(--font-med);
}

.danger {
    color: var(--color-danger);
}

.warning,
.warn {
    color: var(--color-warning);
}

.info {
    color: var(--color-info);
}

.fill-body {
    height: calc(100vh - var(--fill-body-spacer));
}

.tab-container {
    position: relative;
    height: 100%;
    width: 100%;
}

.tab-container.top {
    grid-template-columns: 1fr;
    grid-template-rows: 
        auto 
        1fr;
    grid-template-areas: 
        "tabs"
        "body";
}

.tab-container.bottom {
    grid-template-columns: 1fr;
    grid-template-rows: 
        1fr 
        auto;
    grid-template-areas: 
        "body"
        "tabs";
}

.tab-container .tab-group {
    grid-area: tabs;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
}

.tab-container.top .tab-group {
    align-items: flex-end;
}

.tab-container.bottom .tab-group {
    align-items: flex-start;
}

.tab-container .tab-group .tab {
    display: block;
    padding: 0.3em 0.75em;
    background-color: #802e84;
    color: var(--font-color-light);
    cursor: pointer;
    min-width: 80px;
    text-align: center;
    user-select: none;
}

.tab-container .tab-group .tab[disabled] {
    pointer-events: none;
    cursor: not-allowed;
    color: var(--control-color-disabled);
    background-color: #958696;
}

.tab-container .tab-group .tab:hover {
    background-color: var(--if-purple-med);
}

.tab-container.top .tab-group .tab.selected {
    position: relative;
    display: block;
    top: 1px;
    padding-top: 0.5em;
    padding-bottom: 0.5em;
    border-top-left-radius: 0.5rem;
    border-top-right-radius: 0.5rem;
    color: var(--if-purple);
    background-color: var(--font-color-light);
    border-left: 1px solid var(--border-color);
    border-top: 1px solid var(--border-color);
    border-right: 1px solid var(--border-color);
    border-bottom: 0px solid #fff;
    font-weight: 600;
    border-style: outset;
}

.tab-container.top .tab-group .tab:not(.hidden):first-of-type {
    border-top-left-radius: 0.5rem;
    margin-left: 0.5em;
}

.tab-container.top .tab-group .tab:not(.hidden):last-of-type {
    border-top-right-radius: 0.5rem;
    border-right: 1px solid;
}

.tab-container.bottom .tab-group .tab.selected {
    position: relative;
    top: -1px;
    padding-top: 0.5em;
    padding-bottom: 0.5em;
    border-bottom-left-radius: 0.5rem;
    border-bottom-right-radius: 0.5rem;
    color: var(--if-purple);
    background-color: var(--font-color-light);
    border-left: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
    border-right: 1px solid var(--border-color);
    border-top: 0px solid #fff;
    font-weight: 600;
    border-style: outset;
}

.tab-container.bottom .tab-group .tab:not(.hidden):first-of-type {
    border-bottom-left-radius: 0.5rem;
    margin-left: 0.5em;
}

.tab-container.bottom .tab-group .tab:not(.hidden):last-of-type {
    border-bottom-right-radius: 0.5rem;
    border-right: 1px solid;
}

*[x-icon]:not([x-icon=''])::before {
    margin-right: 4px;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    z-index: 1;
    text-align: center;
    content: attr(x-icon);
}

*[x-icon-after]:not([x-icon-after=''])::after {
    margin-left: 4px;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    z-index: 1;
    text-align: center;
    content: attr(x-icon-after);
    color: var(--if-purple);
}

*[x-browser-icon]:not([x-browser-icon=''])::before {
    margin-right: 4px;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    z-index: 1;
    text-align: center;
    color: var(--if-purple);
    content: '\f0ac';
}

*[x-browser-icon-after]:not([x-browser-icon-after=''])::after {
    margin-left: 4px;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    z-index: 1;
    text-align: center;
    color: var(--if-purple);
    content: '\f0ac';
}

/* *[x-browser-icon='chrome']::before,
*[x-browser-icon-after='chrome']::after {
    content: '\f268' !important;
}

*[x-browser-icon='ie']::before,
*[x-browser-icon-after='ie']::after {
    content: '\f26b' !important;
}

*[x-browser-icon='edge-chromium']::before,
*[x-browser-icon-after='edge-chromium']::after {
    content: '\f282' !important;
}

*[x-browser-icon='edge']::before,
*[x-browser-icon-after='edge']::after {
    content: '\e078' !important;
}

*[x-browser-icon='safari']::before,
*[x-browser-icon-after='safari']::after {
    content: '\f267' !important;
}

*[x-browser-icon='firefox']::before,
*[x-browser-icon-after='firefox']::after {
    content: '\e007' !important;
} */


.no-margin[x-icon]:not([x-icon=''])::before {
    margin: 0px !important;
}

.no-margin[x-icon-after]:not([x-icon-after=''])::after {
    margin: 0px !important;
}

.tab-container .tab-body {
    grid-area: body;
    border: 1px solid var(--border-color);
    padding: 0.5em;
    min-height: 200px;
    border-radius: 0.3em;
}

input[type='text'],
input[type='number'],
input[type='date'],
input[type='time'],
input[type='datetime'],
input[type='datetime-local'], 
/* input[type='time'], */
textarea,
select {
    display: block;
    font-size: var(--font-med-small);
    color: var(--font-color-body);
    background-color: var(--white);
    background-image: none;
    border: 1px solid var(--border-control-color);
    border-radius: 4px;
    -webkit-box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%);
    box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%);
    -webkit-transition: border-color ease-in-out .15s,-webkit-box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
    outline: none;
    padding: var(--input-padding);
}

input[type='text']:focus,
input[type='number']:focus,
textarea:focus,
select:focus {
    border-color: #66afe9;
    outline: 0;
    -webkit-box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%), 0 0 8px rgb(102 175 233 / 60%);
    box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%), 0 0 8px rgb(102 175 233 / 60%);
}

input:disabled {
    background-color: var(--input-background-disabled);
}

.button,
button {
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    -ms-touch-action: manipulation;
    touch-action: manipulation;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-image: none;
    border: 1px solid transparent;
    border-radius: 4px;
    padding: var(--button-padding);
    border-color: var(--button-border-color);
    color: var(--button-color);
    background-color: var(--button-background);
    outline: none;
    cursor: pointer;
    text-overflow: ellipsis;
    overflow: hidden;
}

.button.delete,
button.delete {
    overflow: visible;
}

.button:hover,
button:hover {
    color: #333;
    background-color: #e6e6e6;
    border-color: #adadad;
}

.button:focus,
button:focus {
    border-color: #66afe9;
    outline: 0;
    -webkit-box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%), 0 0 8px rgb(102 175 233 / 60%);
    box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%), 0 0 8px rgb(102 175 233 / 60%);
}

.button.primary,
button.primary {
    color: var(--button-color-primary);
    background-color: var(--button-background-primary);
    border-color: var(--button-color-primary-border);
}

.button.purple,
button.purple {
    color: var(--button-color-primary);
    background-color: var(--if-purple);
    border-color: var(--white);
}

.button.primary:hover,
button.primary:hover {
    background-color: var(--button-background-primary-hover);
}

.button.danger,
button.danger {
    color: var(--button-color-danger);
    background-color: var(--button-background-danger);
    border-color: var(--button-color-danger-border);
}

.button.danger:hover,
button.danger:hover {
    color: var(--button-color-danger-hover);
    background-color: var(--button-background-danger-hover);
}

.button.warn,
button.warn {
    color: var(--button-color-warn);
    background-color: var(--button-background-warn);
    border-color: var(--button-color-warn-border);
}

.button.warn:hover,
button.warn:hover {
    color: var(--button-color-warn-hover);
    background-color: var(--button-background-warn-hover);
}

.button.small,
button.small {
    font-size: var(--font-small-ex);
    min-width: 16px;
    padding: 4px;
}

.button.med,
button.med {
    font-size: var(--font-med);
    min-width: 28px;
    height: 28px;
    padding: 2px;
}

a.button:hover {
    text-decoration: none;
}

*[x-icon]:not([x-icon='']):empty:before {
    margin-right: unset;
}

x-split-button-4 > :not(button) {
    display: none;
}

x-split-button-4 > button:first-of-type {
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    -ms-touch-action: manipulation;
    touch-action: manipulation;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-image: none;
    border: 1px solid transparent;
    border-right: none;
    border-top-left-radius: 4px;
    border-bottom-left-radius: 4px;
    border-top-right-radius: 0px;
    border-bottom-right-radius: 0px;
    padding: var(--button-padding);
    border-color: var(--button-border-color);
    color: var(--button-color);
    background-color: var(--button-background);
    outline: none;
    cursor: pointer;
    padding-right: 8px !important;
}
x-split-button-4 > button:first-of-type * {
    cursor: pointer;
    padding-left: 4px;
    padding-right: 4px;
}

x-split-button-4 > button:first-of-type:hover {
    color: #333;
    background-color: #e6e6e6;
    border-color: #adadad;
}

x-split-button-4 > button:first-of-type:focus {
    border-color: #66afe9;
    outline: 0;
    -webkit-box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%), 0 0 8px rgb(102 175 233 / 60%);
    box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%), 0 0 8px rgb(102 175 233 / 60%);
}

x-split-button-4 > button:last-of-type {
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    -ms-touch-action: manipulation;
    touch-action: manipulation;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-image: none;
    border: 1px solid transparent;
    border-left: none;
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
    border-top-left-radius: 0px;
    border-bottom-left-radius: 0px;
    padding: var(--button-padding-toggle);
    border-color: var(--button-border-color);
    color: var(--button-color-toggle);
    background-color: var(--button-background-toggle);
    outline: none;
    cursor: pointer;
}

x-split-button-4 > button:last-of-type::before {
    content: '\f0d7';
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    width: 12px;
    display: block;
}

x-split-button-4 > button:last-of-type svg polygon {
    fill: var(--button-color);
    stroke: transparent;
    stroke-width: 0;
}

x-split-button-4.small {
    font-size: var(--font-small-ex);
    line-height: var(--font-small-ex);
}
x-split-button-4.small button {
    padding: 2px;
    height: 20px;
}
x-split-button-4.small button:last-of-type {
    height: 20px;
}

x-split-button-4.small button:last-of-type svg {
    position: relative;
    top: 1px;
}



x-split-button-4.primary > button:first-of-type {
    color: var(--button-color-primary);
    background-color: var(--button-background-primary);
    border-color: var(--button-color-primary-border);
}

x-split-button-4.primary > button:first-of-type:hover {
    color: var(--button-color-primary-hover);
    background-color: var(--button-background-primary-hover);
}

x-split-button-4.primary > button:last-of-type {
    color: var(--button-color-primary-toggle);
    background-color: var(--button-background-primary-toggle);
    border-color: var(--button-color-primary-border);
}

x-split-button-4.primary > button:last-of-type:hover {
    color: var(--button-color-primary-hover-toggle);
    background-color: var(--button-background-primary-hover-toggle);
}

x-split-button-4.primary > button:last-of-type svg polygon {
    fill: var(--button-color-primary-toggle);
}

x-split-button-4[disabled] > button,
x-split-button-4[disabled] > button:hover,
button:disabled,
button:disabled:hover {
    cursor: not-allowed !important;
    touch-action: none !important;
    pointer-events: none !important;
    background-color: var(--control-background-disabled) !important;
    color: var(--control-color-disabled) !important;
    border-color: var(--control-border-disabled) !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 600;
    margin-block-end: 0;
    color: var(--if-purple);
}

h1 {
    font-size: var(--font-lg);
}

h2 {
    font-size: var(--font-med-lg);
}

h3 {
    font-size: var(--font-med);
}

h4 {
    font-size: var(--font-med-small);
}

h5 {
    font-size: var(--font-small);
}

h6 {
    font-size: var(--font-small-ex);
}

.labeled-radio,
.labeled-radio *,
.labeled-check,
.labeled-check * {
    display: inline;
}

.labeled-check > label,
.labeled-radio > label {
    position: relative;
    bottom: 2px;
}

.labeled-check[disabled] {
    color: var(--control-color-disabled);
    cursor: not-allowed;
}

x-search-box-4 {
    border: 1px solid var(--border-control-color);
    border-radius: 4px;
    position: relative;
}

x-search-box-4 input {
    border: 0px solid transparent !important;
    outline: none;
}

x-search-box-4 .search input[type='text'] {
    padding: var(--input-padding);
}


.search,
.edit {
    position: relative;
    /* text-align: right; */
    display: inline-block;
    width: 100%;
}

.search > input,
.edit > input {
    width: calc(100% - 34px);
    padding-right: 16px;
}

.search > input::placeholder,
.edit > input::placeholder {
    font-size: var(--font-small);
}

.edit::after {
    position: absolute;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    background-color: #f0f0f8;
    border-left: 1px solid #e0e0e8;
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
    z-index: 1;
    height: calc(100% - 2px);
    width: 24px;
    right: 1px;
    top: 50%;
    transform: translateY(-50%);
    line-height: calc(1em * 2);
    text-align: center;
    cursor: pointer;
}

.edit::after {
    content: '\f303';
    cursor: pointer;
}

.item-container {
    border-radius: 4px;
    border: 1px solid var(--border-color);
    padding: 4px;
    box-shadow: 1px 2px 3px rgb(0 0 0 / 18%);
    font-size: var(--font-small);
    position: relative;
}

.item-container * {
    font-size: var(--font-small);
}

.items-table {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    overflow-y: auto;
    justify-content: center;
    align-content: flex-start;
}

.items-table > * {
    margin: 2px;
}


/* width */
.pretty-scroll::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

/* Track */
.pretty-scroll::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 4px;
}

/* Handle */
.pretty-scroll::-webkit-scrollbar-thumb {
    background: var(--if-purple-light);
    border-radius: 4px;
    cursor: pointer;
}

/* Handle on hover */
.pretty-scroll::-webkit-scrollbar-thumb:hover {
    background: var(--if-purple-light);
}

x-callout-4 {
    user-select: none;
}

x-callout-4[disabled] {
    pointer-events: none;
    color: #c8c7c9;
    cursor: not-allowed;
}

x-callout-4 > div {
    display: grid;
    grid-template-rows: 100%;
    grid-template-columns: 24px auto 24px;
    grid-template-areas:
        "icon title callout";
    height: 24px;
    position: relative;
    cursor: pointer;
    border-radius: 4px;
}

x-callout-4.bordered > div {
    border: 1px solid var(--if-purple-med-light);
}


x-callout-4[toggled='true'] > div,
x-callout-4[toggled='true'] > div > svg,
x-callout-4 > div:hover,
x-callout-4 > div:hover > svg,
x-callout-4[toggled='true'] > div:hover > svg {
    background-color: var(--if-purple-med);
    color: var(--white);
    fill: var(--white);
}


x-callout-4[toggled='true'] > div > div:first-of-type {
    color: var(--white);
}

x-callout-4 > div::after {
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 4px;
}

x-callout-4[direction='down'] > div::after {
    content: '\f0d7';
}

x-callout-4[direction='right'] > div::after {
    content: '\f0da';
}

x-callout-4 > div > div:first-of-type {
    height: 24px;
    width: 24px;
    grid-area: icon;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    color: var(--if-purple);
}

x-callout-4[disabled] > div > div:first-of-type {
    color: #c8c7c9;
}



x-callout-4 > div > div:first-of-type[icon]::before {
    display: block;
    content: attr(icon);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    text-align: center;
    font-size: var(--font-small-ex);
}

x-callout-4 > div:hover > div:first-of-type {
    color: var(--white);
}

x-callout-4 > div > div:last-of-type {
    grid-area: title;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    white-space: nowrap;
    overflow: hidden;
    max-width: 110%;
    text-overflow: ellipsis;
    width: 100%;
}

x-callout-4.button {
    display: inline-block;
}

x-callout-4.button.small {
    padding: 1px 1px;
}

x-callout-4.button.small > div {
    grid-template-columns: 16px 0px 0px;
    height: 16px;
}

x-callout-4.button.small > div > div:first-of-type {
    height: 16px;
    width: 16px;

}

x-callout-4.button[toggled='true'] > div,
x-callout-4.button[toggled='true'] > div > svg,
x-callout-4.button > div:hover,
x-callout-4.button > div:hover > svg,
x-callout-4.button[toggled='true'] > div:hover > svg {
    fill: #333;
    color: #333;
    background-color: #e6e6e6;
}

x-callout-4.button > div > div:first-of-type,
x-callout-4.button > div:hover > div:first-of-type,
x-callout-4.button[toggled='true'] > div > div:first-of-type {
    color: var(--button-color);
}


.callout {
    border: 1px solid var(--border-color);
    -webkit-box-shadow: 0 8px 16px rgb(0 0 0 / 55%);
    box-shadow: 0 8px 16px rgb(0 0 0 / 55%);
    border-radius: 8px;
    display: grid;
    grid-template-rows: auto auto;
    grid-auto-columns: auto 32px;
    grid-template-areas:
        "header controls"
        "body controls";
    background-color: var(--white);
    padding: 8px;
    z-index: 100000;
    font-size: var(--font-small-ex);
    min-height: 56px;
}

.callout[x-no-chrome='true'] {
    padding: 0px;
    grid-template-rows: auto auto;
    grid-auto-columns: auto 0px;
    grid-template-areas:
        "header controls"
        "body controls";
    border-radius: 0px;
}

.callout[x-no-chrome='true'] .callout-controls {
    display: none;
}

.separator {
    width: 100%;
    height: 1px;
    margin-top: 6px;
    margin-bottom: 6px;
    background: linear-gradient( to right, var(--if-purple-light) 0%, var(--if-purple-light) 50%, rgba(0,0,0,0) 100% ) left bottom rgba(0,0,0,0) no-repeat;
}

.callout *,
.callout input[type='text'],
.callout input[type='number'],
.callout input[type='tel'],
.callout input[type='email'],
.callout select,
.callout textarea {
    font-size: var(--font-small-ex) !important;
}

.callout-header {
    grid-area: header;
    text-align: left;
    position: relative;
    font-size: var(--font-med-small) !important;
    max-height: 250px;
    overflow-y: auto;
}

.callout-header:not(:empty) {
    margin-bottom: 8px;
}

.callout-header::before {
    display: block;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    margin-right: 8px;
    position: absolute;
}
.callout-header::after {
    display: block;
    content: attr(message);
    margin-right: 8px;
    position: relative;
    margin-left: 1.5em;
}

.callout-header[type='error'] {
    color: var(--font-color-error);
}

.callout-header[type='error']::before {
    content: '\f06a';
}

.callout-header[type='warning'],
.callout-header[type='warn'] {
    color: var(--font-color-warn);
}

.callout-header[type='warning']::before,
.callout-header[type='warn']::before {
    content: '\f071';
}

.callout-header[type='info'] {
    color: var(--font-color-info);
}

.callout-header[type='info']::before {
    content: '\f05a';
}

.callout-header[type='question'] {
    color: var(--font-color-info);
}

.callout-header[type='question']::before {
    content: '\f059';
}

.callout-controls {
    grid-area: controls;
    text-align: center;
    position: relative;
}

.callout-body {
    grid-area: body;
    position: relative;
    overflow: inherit;
    max-height: 75vh;
}

.callout-body > x-view-4 {
    height: 100%;
}

.callout-cancel {
    cursor: pointer;
    border: 1px solid var(--button-border-color-solid);
    border-radius: 4px;
    background-color: var(--button-background);
    height: 22px;
    width: 22px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}

.callout-cancel:hover {
    background-color: var(--button-background-hover);
    color: var(--button-color-hover);
}

.callout-cancel::after {
    display: block;
    content: '\f00d';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    height: 100%;
    width: 100%;
    text-align: center;
    font-size: var(--font-med);
}

.callout-commit {
    cursor: pointer;
    border: 1px solid var(--button-color-primary-border);
    border-radius: 4px;
    background-color: var(--button-background-primary);
    height: 22px;
    width: 22px;
    position: absolute;
    left: 50%;
    top: 56px;
    transform: translateX(-50%);
}

.callout-commit:hover {
    background-color: var(--button-background-primary-hover);
}

.callout-commit[disabled],
.callout-commit[disabled]:hover {
    background-color: var(--control-background-disabled);
    border-color: var(--control-border-disabled);
    cursor: not-allowed;
}

.callout-commit::after {
    display: block;
    content: '\f00c';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    height: 100%;
    width: 100%;
    text-align: center;
    font-size: var(--font-med);
    color: var(--button-color-primary);
}

.callout-commit-close {
    cursor: pointer;
    border: 1px solid var(--button-color-primary-border);
    border-radius: 4px;
    background-color: var(--button-background-primary);
    height: 22px;
    width: 22px;
    position: absolute;
    left: 50%;
    top: 28px;
    transform: translateX(-50%);
}

.callout-commit-close:hover {
    background-color: var(--button-background-primary-hover);
}

.callout-commit-close[disabled],
.callout-commit-close[disabled]:hover {
    background-color: var(--control-background-disabled);
    border-color: var(--control-border-disabled);
    cursor: not-allowed;
}

.callout-commit-close::after {
    display: block;
    content: '\f560';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    height: 100%;
    width: 100%;
    text-align: center;
    font-size: var(--font-med);
    color: var(--button-color-primary);
}

.callout-spacer {
    position: absolute;
    bottom: -50px;
    height: 1px;
    width: 100%;
    left:  0px;
}

.flex-row {
    display: flex;
    flex-direction: row;
}

.flex-column {
    display: inline-flex;
    flex-direction: column;
}

.flex-row.center {
    justify-content: center;
    align-items: center;
}

.flex-row.even {
    justify-content: space-evenly;
}

.flex-row.between {
    justify-content: space-between;
}

.flex-row.around {
    justify-content: space-around;
}

.flex-row.start {
    justify-content: flex-start;
}

.flex-row.end {
    justify-content: flex-end;
}

.flex-row.fit > * {
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: auto;
}

.flex-row.nofit > * {
    flex-grow: 0;
    flex-shrink: 0;
}

.flex-column.wrap,
.flex-row.wrap {
    flex-wrap: wrap;
}

.flex-column.nowrap,
.flex-row.nowrap {
    flex-wrap: nowrap;
}


.callout-item {
    width: 100%;
    margin: 2px 0px;
    /* display: block; */
}

label.callout-item {
    font-weight: 600;
}

.hidden {
    display: none !important;
    visibility: collapse;
}

table {
    border-spacing: 0;
    margin-top: 2px;
    margin-bottom: 2px;
    display: block;
}

th {
    font-weight: 600;
    padding: 2px 6px;
}

td {
    padding: 2px 2px;
    vertical-align: top;
}

/*td:first-of-type {
    border-left: 1px solid var(--if-purple); */


/*td:last-of-type {
     border-right: 1px solid var(--if-purple); */


/*tbody tr:last-of-type td {
     border-bottom: 1px solid var(--if-purple); */


thead tr:last-of-type th:first-of-type {
    border-top-left-radius: 4px;
 }
 
thead tr:last-of-type th:last-of-type {
    border-top-right-radius: 4px;
}

tfoot tr:last-of-type td:first-of-type {
   border-bottom-left-radius: 4px;
}

tfoot tr:last-of-type td:last-of-type {
    border-bottom-right-radius: 4px;
}

thead {
    position: sticky;
    top: -7px;
    background-color: var(--if-purple-med);
    color: var(--white);
    z-index: 10;
    display: block;
    width: 100%;
    border-top-left-radius: 4px;
    border-top-right-radius: 4px;
}

tfoot {
    position: sticky;
    bottom: 0px;
    background: var(--if-purple-med);
    z-index: 100;
    color: var(--white);
    width: 100%;
}

tbody tr:not(.hidden):nth-of-type(odd) {
    background-color: var(--if-purple-light-alt);
}

tr.group-header {
    display: block;
    position:sticky;
    top:0px;
    background: linear-gradient(
            to right, 
            var(--if-purple-med) 0%, 
            var(--if-purple-med) 20%, 
            var(--white) 100%
        );
    color: var(--white);
    z-index: 10;
    border-top: 1px solid var(--white);
}

table.scrollable,
table.scrollable thead,
table.scrollable tbody {
    display: block;
}

table.scrollable.scroll-y tbody {
    overflow-y: scroll;
    overflow-x: hidden;
}

table.scrollable.scroll-x tbody {
    overflow-x: scroll;
    overflow-y: hidden;
}

table.scrollable thead,
table.scrollable tbody {
    width: 100%;
}

table.scrollable tbody {
    overflow: auto;
    border: 1px solid var(--if-purple-light-alt);
}

table.scrollable th,
table.scrollable td,
table.scrollable tr {
    display: inline-block;
}

table.scrollable th,
table.scrollable td {
    padding: 2px 2px;
}

.no-scroll {
    overflow-x: unset;
    overflow-y: unset;
}

.no-scroll-important {
    overflow-x: unset !important;
    overflow-y: unset !important;
}

.mono,
x-callout-4.mono > div > div:last-of-type {
    font-family: monospace;
}

.search > .search-icon {
    background-color: #f0f0f8;
    border-left: 1px solid #e0e0e8;
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
    cursor: pointer;
    position: absolute;
    height: calc(100% - 0px);
    width: 24px;
    right: 0px;
    top: 50%;
    transform: translateY(-50%);
    line-height: calc(1em * 2);
    z-index: 1;
    text-align: center;
    color: var(--button-color);
}

.search > .search-icon::after {
    position: absolute;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    content: '\f002';
    z-index: 2;
    width:  100%;
    text-align: center;
    left: 0px;
    top: 1px;
}

.search > .search-icon[icon]::after {
    content: attr(icon);
}

.callout[executing] > .callout-controls > .callout-commit-close::after,
.callout[executing] > .callout-controls > .callout-commit::after,
.search > .search-icon.searching::after {
    content: '\f110';
    animation-name: spin;
    animation-duration: 1s;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
}

.callout[executing] > .callout-controls > .callout-commit-close::after,
.callout[executing] > .callout-controls > .callout-commit::after {
    cursor: not-allowed;
    touch-action: none;
    left:  0px;
    top: 0px;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

@keyframes spin-half {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(180deg);
    }
}

@keyframes spin-half-back {
    from {
        transform: rotate(180deg);
    }
    to {
        transform: rotate(360deg);
    }
}

.split-button-menu,
.search-box-menu {
    position: absolute;
    z-index: 10000;
    background-color: var(--white);
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    border: 1px solid rgba(0,0,0,.15);
    border-radius: 4px;
    -webkit-box-shadow: 0 6px 12px rgb(0 0 0 / 18%);
    box-shadow: 0 6px 12px rgb(0 0 0 / 18%);
    padding: 8px;
    max-height: 250px;
    overflow-y: auto;
    overflow-x: hidden;
    z-index: 200000;
    text-align: left;
}

.search-box-menu::after {
    content: '';
    display: table;
    clear: both;
}

.split-button-menu {
    display: none;
    color: var(--font-color-body);
}

.split-button-menu > .split-button-menu-item,
.search-box-menu .search-box-menu-item {
    cursor: pointer;
    padding: 4px 8px;
    white-space: nowrap;
    font-size: var(--font-small-ex);
}

.split-button-menu > .split-button-menu-item.separator, 
.search-box-menu .search-box-menu-item.separator {
    padding: 0px;
}

.split-button-menu > .split-button-menu-item.focus,
.split-button-menu > .split-button-menu-item:focus,
.split-button-menu > .split-button-menu-item:hover,
.search-box-menu .search-box-menu-item.focus,
.search-box-menu .search-box-menu-item:focus,
.search-box-menu .search-box-menu-item:hover,
.search-box-menu .search-box-menu-item:hover *[x-icon]::before,
.search-box-menu .search-box-menu-item:focus *[x-icon]::before
{
    background-color: var(--if-purple);
    color: var(--white);
    border-radius: 4px;
}

.split-button-menu > .split-button-menu-item *[x-icon]::before,
.search-box-menu .search-box-menu-item *[x-icon]::before {
    margin-right: 8px;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    z-index: 1;
    height: calc(100% - 2px);
    width: 24px;
    line-height: calc(1em * 2);
    text-align: center;
    content: attr(x-icon);
    color: var(--if-purple);
}

.search-box-menu .search-box-menu-item.focus *[x-icon]::before {
    color: var(--white) !important;
}

.split-button-menu > .split-button-menu-item *[x-icon]::before {
    line-height: unset !important;
}


.split-button-menu > .split-button-menu-item[disabled],
.search-box-menu .search-box-menu-item[disabled],
.split-button-menu > .split-button-menu-item[disabled] *[x-icon]::before,
.search-box-menu .search-box-menu-item[disabled] *[x-icon]::before
{
    cursor: not-allowed;
    background-color: transparent;
    color: var(--control-color-disabled);
}

.split-button-menu > .split-button-menu-item.focus[disabled]
.search-box-menu .search-box-menu-item.focus[disabled] {
    background-color: var(--control-background-disabled-light);
}

.search-box-menu .search-box-menu-header {
    text-align: left;
    width: 100%;
    min-width: 100%;
    margin-bottom: 4px;
    touch-action: none;
}

.sticky {
    position: sticky;
    top: 0px;
    z-index: 1;
}

.bg {
    background-color: var(--background-color);
}

.disablable-container {
    position: relative;
    width: max-content;
    min-width: 100%;
}

.disablable-container.disabled::after {
    content: '';
    height: 100%;
    width: 100%;
    top: 0px;
    left: 0px;
    position: absolute;
    z-index: 12;
    cursor: not-allowed;
    opacity: 0.1;
    background-color: var(--control-background-disabled);
}

[x-invalid]:not([x-invalid=""]) { 
    border-color: var(--border-control-invalid) !important;
}

div[x-invalid]:not([x-invalid=""]) {
    border-width: 1px;
    border-style: solid;
    border-radius: 4px;
}


.shake {
    /* Start the shake animation and make the animation last for 0.5 seconds */
  animation: shake 0.75s cubic-bezier(.36,.07,.19,.97) both;

  /* When the animation is finished, start again */
  animation-iteration-count: infinite;
}

x-repeat {
    display: none;
}



@keyframes shake {
    /* 0% { transform: translate(1px, 1px) rotate(0deg); }
    10% { transform: translate(-1px, -2px) rotate(-1deg); }
    20% { transform: translate(-3px, 0px) rotate(1deg); }
    30% { transform: translate(3px, 2px) rotate(0deg); }
    40% { transform: translate(1px, -1px) rotate(1deg); }
    50% { transform: translate(-1px, 2px) rotate(-1deg); }
    60% { transform: translate(-3px, 1px) rotate(0deg); }
    70% { transform: translate(3px, 1px) rotate(-1deg); }
    80% { transform: translate(-1px, -1px) rotate(1deg); }
    90% { transform: translate(1px, 2px) rotate(0deg); }
    100% { transform: translate(1px, -2px) rotate(-1deg); } */
    10%, 90% {
        transform: translate3d(-1px, 0, 0);
    }

    20%, 80% {
        transform: translate3d(2px, 0, 0);
    }

    30%, 50%, 70% {
        transform: translate3d(-4px, 0, 0);
    }

    40%, 60% {
        transform: translate3d(4px, 0, 0);
    }
  }
