/* Version 12.10.24
/* Add sm Mobile and b=border,m=margin,p=padding,w=with,h=heihgt
/* standardize 2019-08-05
/* document 2019-08-14
/* 2020-04-28 add text 0-6
/* 2021-01-01 add x,y in margin-padding
/* 2021-02-24 fixed safari
/* 2022-04-10 Add sm - st - sp
/* 2022-05-12 Change p-m-r from 5 level to 12 level*/
/*sm : 0-599dp // Small screen / phone
  st: 600-904  // Medium screen / tablet
  sp: 905-1439 // Large screen / desktop - default platform
  sx: +1439    // Extra large screen / wide desktop
*/
:root {
    --bgcolor: #F5F6FA;
    --context: #fff;
    --transparent: #ffffffaa;
    --white: #fff;
    --whitelight: rgba(255, 255, 255, 0.8);
    --primary: #545aa7;
    --secondary: #686cbb;
    --dark: #434885;
    --light: #868ac2;
    --lightbg: #545aa768;
    --lighthover: rgba(84, 90, 167, 0.1);
    --verylight: #e8e9f9;
    --additon: #2ea295;
    --header: #D8DCEB /*#e7ebee*/;
    --title: #522761;
    --label: #707077;
    --link: #428bca;
    --line: #C0C6DF;
    --linelight: #dde1f3;
    --lineselect: #0176C3;
    --select: #D4D8E9;
    --selected: #879cf7;
    --success: #28a745;
    --info: rgb(144, 147, 153);
    --info-lighten: rgb(233, 233, 235);
    --warning: rgb(230, 162, 60);
    --warning-lighten: rgb(250, 236, 216);
    --error: #eb9fa6;
    --error-lighten: #fab3ba;
    --danger: rgb(245, 108, 108);
    --danger-lighten: rgb(255 149 149);
    --disble: #707077;
    --font-primary: sans-serif;
    --loading: url('/themes/base/images/loading.gif');
    --sending: url('/themes/base/images/indicator.gif');
    --bgloading: url('/themes/base/images/bgLoading.gif');
    --wloading: url('/themes/base/images/white/loading.gif');
    --radius: 4px;
    --hoverIndex: 15;
    --pickerIndex: 20;
}
/*Reset Css*/
*, ::after, ::before {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

body {
    font-family: var(--font-primary);
}

img {
    border: none;
}

a {
    text-decoration: none;
    outline: none;
}

    a[disabled] {
        pointer-events: none !important;
        cursor: default;
        color: Gray;
    }

        a[disabled] img {
            filter: grayscale(70%);
        }
/** important safari/ios */
input {
    -webkit-user-select: text;
    user-select: text;
}

textarea {
    white-space: revert;
}

table {
    width: 100%;
    border-collapse: collapse;
}
/*Font-face*/
@font-face {
    font-family: 'nasalization';
    src: url('https://www.smartportal.org/themes/default/fonts/nasalization.eot');
    src: url('https://www.smartportal.org/themes/default/fonts/nasalization.woff2') format('woff2');
    src: url('https://www.smartportal.org/themes/default/fonts/nasalization.eot?#iefix') format('embedded-opentype');
    src: url('https://www.smartportal.org/themes/default/fonts/nasalization.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "Raleway";
    src: url(/themes/default/fonts/Raleway-Regular.ttf);
}
/*modal*/
/* block scroll for mobile; */
/* causes underlying page to jump to top; */
/* prevents scrolling on all screens overflow: hidden; */
body.dialog {
    height: 100%;
    overflow: hidden !important;
}
/*color*/
.sp-color-primary, .sp-primary {
    color: var(--primary);
}

.sp-color-title {
    color: var(--title);
}

.sp-color-label {
    color: var(--label);
}

.sp-color-link {
    color: var(--link);
}

.sp-color-pink {
    color: var(--link);
}

.sp-color-purple {
    color: var(--purple);
}

.sp-color-violet {
    color: var(--violet);
}

.sp-color-portal, .sp-portal {
    color: #2cd00e !important;
}

.sp-color-white, .sp-white {
    color: var(--white) !important;
}

.sp-color-black, .sp-black {
    color: var(--dark) !important;
}

.sp-color-orange, .sp-orange {
    color: #ff5947 !important;
}

.sp-color-blue, .sp-blue {
    color: #00a1e6 !important;
}

.sp-color-green, .sp-green {
    color: #20e43a !important;
}

.sp-color-red, .sp-red {
    color: #e43d20 !important;
}

.sp-color-yellow, .sp-yellow {
    color: #ffd800 !important;
}

.sp-color-lightviolet {
    color: var(--lightviolet);
}

.sp-color-dark {
    color: var(--dark);
}

.sp-color-success {
    color: var(--success);
}

.sp-color-danger {
    color: var(--danger);
}

.sp-color-error {
    color: var(--error);
}

.sp-color-warning {
    color: var(--warning);
}

.sp-color-select {
    color: var(--select);
}

.sp-color-secondary {
    color: var(--secondary);
}

/*background color*/
.sp-bg-white {
    background-color: #fff;
    background-color: var(--white) !important;
    color: var(--dark);
}

.sp-bg-context {
    background-color: var(--context) !important;
    color: var(--dark);
}

.sp-bg-select {
    background-color: var(--select) !important;
}

.sp-bg-selected {
    background-color: var(--selected) !important;
}

.sp-bg-primary {
    background-color: var(--primary);
    color: var(--white);
}

.sp-bg-success {
    background-color: var(--success) !important;
    color: var(--white);
}

.sp-bg-info {
    background-color: var(--info) !important;
    color: var(--white);
}

.sp-bg-warning {
    background-color: var(--warning) !important;
    color: var(--white);
}

.sp-bg-danger {
    background-color: var(--danger) !important;
    color: #721c24;
    border-color: #f5c6cb;
}

.sp-bg-error {
    background-color: var(--error) !important;
    color: var(--white);
}

.sp-bg-black {
    background-color: var(--dark) !important;
}

.sp-bg-header {
    background-color: var(--header) !important;
}

.sp-bg-orange {
    background-color: #ff5947 !important;
}

.sp-bg-blue {
    background-color: #20a8d8 !important
}

.sp-bg-green {
    background-color: #4dbd74 !important;
}

.sp-bg-red {
    background-color: #f86c6b !important;
}

.sp-bg-yellow {
    background-color: #ffc107 !important;
}

.sp-bg-grey {
    color: #000 !important;
    background-color: #f1f1f1 !important;
}

.sp-bg-primary {
    background-color: var(--primary);
}

.sp-bg-title {
    background: var(--title);
}

.sp-bg-label {
    background-color: var(--label);
}

.sp-bg-bgcolor {
    background-color: var(--bgcolor);
}

.sp-bg-link {
    background-color: var(--link);
}

.sp-bg-pink {
    background-color: var(--link);
}

.sp-bg-purple {
    background-color: var(--purple);
}

.sp-bg-violet {
    background-color: var(--violet);
}

.sp-bg-lightviolet {
    background-color: var(--lightviolet);
}

.sp-bg-dark {
    background-color: var(--dark);
}

.sp-bg-success {
    background-color: var(--success);
}

.sp-bg-danger {
    background-color: var(--danger);
}

.sp-bg-error {
    background-color: var(--error);
}

.sp-bg-warning {
    background-color: var(--warning);
}

.sp-bg-select {
    background-color: var(--select);
}

.sp-bg-secondary {
    background-color: var(--secondary);
}

.sp-bg-transparent {
    background: transparent !important;
}

/* Display and Visibility */
.sp-bg-bgcolor, .sp-background {
    background-color: var(--bgcolor) !important;
}

.sp-nobackground {
    background: none !important;
    color: var(--title);
}

.sp-disabled, .sp-disabled:focus, .sp-disabled:hover {
    color: #777;
    cursor: not-allowed !important;
}

    .sp-disabled img {
        filter: grayscale(70%);
    }
/*direction & align*/
.sp-rtl {
    direction: rtl !important;
}

.sp-ltr {
    direction: ltr !important;
}

.sp-right {
    text-align: right;
    padding: 4px;
    vertical-align: middle;
}

.sp-right-imp {
    text-align: right !important;
    padding: 4px !important;
    vertical-align: middle !important;
}

.sp-left {
    text-align: left;
    vertical-align: middle;
    padding: 4px;
}

.sp-left-imp {
    text-align: left !important;
    vertical-align: middle !important;
    padding: 4px !important;
}

.sp-justify {
    text-align: justify;
    vertical-align: middle;
    padding: 4px;
}

.sp-justify-between {
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

.sp-justify-around {
    -webkit-justify-content: space-around;
    justify-content: space-around;
}

.sp-justify-evenly {
    -webkit-justify-content: space-evenly;
    justify-content: space-evenly;
}

.sp-justify-center {
    -webkit-justify-content: center;
    justify-content: center;
}

.sp-justify-right {
    -webkit-justify-content: right;
    justify-content: right;
}

.sp-center {
    text-align: center;
    vertical-align: middle;
    -webkit-justify-content: center;
    justify-content: center;
    align-items: center;
}

.sp-float-right {
    float: right;
}

.sp-float-left {
    float: left;
}

.sp-float-none {
    float: none;
}
/*flex*/
.sp-flex-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
}

.sp-flex-rcolumn {
    flex-direction: column-reverse;
}

.sp-flex-between {
    justify-content: space-between;
}

.sp-flex-around {
    justify-content: space-around;
}

.sp-flex-wrap {
    flex-wrap: wrap;
}

.sp-flex-end {
    justify-content: flex-end;
}

.sp-flex-nowrap {
    flex-wrap: nowrap;
}

.sp-flex-reverse {
    flex-direction: row-reverse;
}
/*Flex*/
.sp-flex-1 {
    flex: 1 !important;
}

.sp-flex-2 {
    flex: 2 !important;
}

.sp-flex-3 {
    flex: 3 !important;
}

.sp-flex-4 {
    flex: 4 !important;
}

.sp-flex-5 {
    flex: 5 !important;
}

.sp-flex-6 {
    flex: 6 !important;
}

.sp-flex-7 {
    flex: 7 !important;
}

.sp-flex-8 {
    flex: 8 !important;
}

.sp-flex-9 {
    flex: 9 !important;
}

.sp-flex-10 {
    flex: 10 !important;
}

.sp-flex-11 {
    flex: 11 !important;
}

.sp-flex-12 {
    flex: 12 !important;
}
/*text*/
.sp-upper {
    text-transform: uppercase;
}

.sp-lower {
    text-transform: lowercase;
}

.sp-capitalize {
    text-transform: capitalize;
}
/*position*/
.sp-relative {
    position: relative;
}

.sp-absolute {
    position: absolute;
}

.sp-fixed {
    position: fixed;
}
/*display*/
.sp-hidden {
    opacity: 0 !important;
    visibility: hidden !important;
}

.sp-visible {
    opacity: 1;
    visibility: visible !important;
}

.sp-none, .sp-d-none {
    display: none !important;
}

.sp-d-inline {
    display: inline !important;
}

.sp-d-inline-block {
    display: inline-block !important;
}

.sp-block, .sp-display-block, .sp-d-block {
    display: block !important;
}

.sp-d-table, .sp-table {
    display: table !important;
}

.sp-table-row {
    display: table-row !important;
}

.sp-table-cell {
    display: table-cell !important;
}

.sp-d-flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex !important;
}

.sp-d-inline-flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: inline-flex !important;
}

/*font*/
.sp-font-large {
    font-size: 16px !important;
}

.sp-font-normal {
    font-size: 14px !important;
}

.sp-font-small {
    font-size: 12px !important;
}

.sp-font-xxsmall {
    font-size: 10px;
}

.sp-font-xxxsmall {
    font-size: 8px;
}

.sp-font-xlarge {
    font-size: 18px !important;
}

.sp-font-xxlarge {
    font-size: 20px !important;
}

.sp-font-exlarge {
    font-size: 24px;
}

.sp-font-xxxlarge {
    font-size: 30px !important;
}

.sp-font-exxlarge {
    font-size: 28px;
}

.sp-font-xnormal {
    font-size: 11px;
}

.sp-font-primary {
    font-family: var(--font-primary);
}

.sp-font-bold {
    font-weight: bold;
}

.sp-font-italic {
    font-style: italic;
}

/*font weight*/
.sp-fw-100 {
    font-weight: 100;
}

.sp-fw-200 {
    font-weight: 200;
}

.sp-fw-300 {
    font-weight: 300;
}

.sp-fw-400 {
    font-weight: 400;
}

.sp-fw-500 {
    font-weight: 500;
}

.sp-fw-600 {
    font-weight: 600;
}

.sp-fw-700 {
    font-weight: 700;
}

.sp-fw-800 {
    font-weight: 800;
}

.sp-fw-900 {
    font-weight: 900;
}

/*Text font-size*/
.sp-text-small, .sp-t-s, .sp-t-0 {
    font-size: .25rem !important;
}

.sp-t-1 {
    font-size: 0.5rem !important;
}

.sp-t-2 {
    font-size: .75rem !important;
}

.sp-text-large, .sp-t-3 {
    font-size: 1rem !important;
}

.sp-t-4 {
    font-size: 1.25rem !important;
}

.sp-t-5 {
    font-size: 1.5rem !important;
}

.sp-t-6 {
    font-size: 1.75rem !important;
}

.sp-t-7 {
    font-size: 2rem !important;
}

.sp-t-8 {
    font-size: 2.25rem !important;
}

.sp-t-9 {
    font-size: 2.5rem !important;
}

.sp-t-10 {
    font-size: 2.75rem !important;
}

.sp-t-11 {
    font-size: 3rem !important;
}

.sp-t-12 {
    font-size: 3.25rem !important;
}

/*alignment*/
.sp-direction {
    direction: ltr
}

.sp-align {
    text-align: left;
}

.sp-align-left, .sp-a-left {
    text-align: left;
}

.sp-align-right, .sp-a-right {
    text-align: right;
}

.sp-align-top, .sp-a-top, .sp-at {
    vertical-align: top;
}

.sp-align-bottom, .sp-a-bottom, .sp-ab {
    vertical-align: bottom;
}

.sp-align-middle, .sp-a-middle, .sp-am {
    vertical-align: middle;
}

.sp-align-stretch, .sp-a-stretch, .sp-as {
    align-items: stretch;
}

/*border*/
.sp-border, .sp-b {
    border: 1px solid var(--line);
}

.sp-border-none, .sp-b-none {
    border: none;
}

.sp-b-0 {
    border: 0 !important;
}

.sp-border-dashed, .sp-b-dashed, sp-b-d {
    border-style: dashed !important;
}
/*Color*/
.sp-border-danger, .sp-b-danger {
    border-color: var(--danger) !important;
}

.sp-border-dark, .sp-b-dark {
    border-color: var(--dark) !important;
}

.sp-border-white, .sp-b-white {
    border-color: var(--white) !important;
}

.sp-border-success, .sp-b-success {
    border-color: var(--success) !important;
}

.sp-border-warning, .sp-b-warning {
    border-color: var(--warning) !important;
}

.sp-bx {
    border-left: 1px solid var(--line);
    border-right: 1px solid var(--line);
}

.sp-by {
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}
/*Border*/
.sp-b-top, .sp-bt {
    border-top: 1px solid var(--line);
}

.sp-b-right, .sp-br {
    border-right: 1px solid var(--line);
}

.sp-b-bottom, .sp-bb {
    border-bottom: 1px solid var(--line);
}

.sp-b-left, .sp-bl {
    border-left: 1px solid var(--line);
}

.sp-b-primary {
    border-color: var(--primary);
}

.sp-b-secondary {
    border-color: var(--secondary);
}

.sp-b-light {
    border-color: var(--light);
}

/*Border size*/
.sp-b-1 {
    border-width: 1px;
}

.sp-b-2 {
    border-width: 2px !important;
}

.sp-b-3 {
    border-width: 4px !important;
}

.sp-b-4 {
    border-width: 4px !important;
}

.sp-b-5 {
    border-width: 5px !important;
}

.sp-b-6 {
    border-width: 6px !important;
}
/*round*/
.sp-r-0 {
    border-radius: 0;
}

.sp-r-1 {
    border-radius: 8.33333%;
}

.sp-r-2 {
    border-radius: 16.66667%;
}

.sp-r-3 {
    border-radius: 25%
}

.sp-r-4 {
    border-radius: 33.33333%;
}

.sp-r-5 {
    border-radius: 41.66667%;
}

.sp-r-6 {
    border-radius: 50%;
}
/*Radius Pixel*/
.sp-rp-1 {
    border-radius: .25rem !important;
}

.sp-rp-2 {
    border-radius: .5rem !important;
}

.sp-rp-3 {
    border-radius: 0.75rem !important;
}

.sp-rp-4 {
    border-radius: 1rem !important;
}

.sp-rp-5 {
    border-radius: 1.25rem !important;
}

.sp-rp-6 {
    border-radius: 1.5rem !important;
}

.sp-rp-7 {
    border-radius: 1.75rem !important;
}

.sp-rp-8 {
    border-radius: 2rem !important;
}

.sp-rp-9 {
    border-radius: 2.25rem !important;
}

.sp-rp-10 {
    border-radius: 2.5rem !important;
}

.sp-rp-11 {
    border-radius: 2.75rem !important;
}

.sp-rp-12 {
    border-radius: 3rem !important;
}

/*raduis top and Right and Left*/
.sp-rt-1 {
    border-top-left-radius: 0.25rem;
    border-top-right-radius: 0.25rem;
}

.sp-rt-2 {
    border-top-left-radius: 0.5rem;
    border-top-right-radius: 0.5rem;
}

.sp-rt-3 {
    border-top-left-radius: 0.75rem;
    border-top-right-radius: 0.75rem;
}

.sp-rt-4 {
    border-top-left-radius: 0.75rem;
    border-top-right-radius: 0.75rem;
}

.sp-rt-5 {
    border-top-left-radius: 0.75rem;
    border-top-right-radius: 0.75rem;
}

.sp-rt-6 {
    border-top-left-radius: 1.5rem;
    border-top-right-radius: 1.5rem;
}
/*Right and Left*/
.sp-rl-1 {
    border-top-left-radius: 0.25rem !important;
    border-bottom-left-radius: 0.25rem !important;
}

.sp-rl-2 {
    border-top-left-radius: 0.5rem !important;
    border-bottom-left-radius: 0.5rem !important;
}

.sp-rl-3 {
    border-top-left-radius: 0.75rem !important;
    border-bottom-left-radius: 0.75rem !important;
}

.sp-rl-4 {
    border-top-left-radius: 1rem !important;
    border-bottom-left-radius: 1rem !important;
}

.sp-rl-5 {
    border-top-left-radius: 1.25rem !important;
    border-bottom-left-radius: 1.25rem !important;
}

.sp-rl-6 {
    border-top-left-radius: 2rem !important;
    border-bottom-left-radius: 2rem !important;
}


/*shadow*/
.sp-s-none {
    box-shadow: none;
}

.sp-s {
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.15) !important;
}

.sp-s-small, .sp-ss {
    box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
}

.sp-s-large, .sp-sl {
    box-shadow: 0 1rem 3rem rgba(0,0,0,.175) !important;
}

/*line-height*/
.sp-lh-1 {
    line-height: .25rem !important;
}

.sp-lh-2 {
    line-height: .5rem !important;
}

.sp-lh-3 {
    line-height: 0.75rem !important;
}

.sp-lh-4 {
    line-height: 1rem !important;
}

.sp-lh-5 {
    line-height: 1.25rem !important;
}

.sp-lh-6 {
    line-height: 1.5rem !important;
}

.sp-lh-7 {
    line-height: 1.75rem !important;
}

.sp-lh-8 {
    line-height: 2rem !important;
}

.sp-lh-9 {
    line-height: 2.25rem !important;
}

.sp-lh-10 {
    line-height: 2.5rem !important;
}

.sp-lh-11 {
    line-height: 2.75rem !important;
}

.sp-lh-12 {
    line-height: 3rem !important;
}
/*margin auto*/
.sp-m-auto {
    margin: auto !important;
}

.sp-mr-auto {
    margin-right: auto !important;
}

.sp-ml-auto {
    margin-left: auto !important;
}

.sp-mt-auto {
    margin-top: auto !important;
}

.sp-mb-auto {
    margin-bottom: auto !important;
}
/*margin*/
.sp-m-0 {
    margin: 0 !important;
}

.sp-m-1 {
    margin: .25rem !important;
}

.sp-m-2 {
    margin: .5rem !important;
}

.sp-m-3 {
    margin: .75rem !important;
}

.sp-m-4 {
    margin: 1rem !important;
}

.sp-m-5 {
    margin: 1.25rem !important;
}

.sp-m-6 {
    margin: 1.5rem !important;
}

.sp-m-7 {
    margin: 1.75rem !important;
}

.sp-m-8 {
    margin: 2rem !important;
}

.sp-m-9 {
    margin: 2.25rem !important;
}

.sp-m-10 {
    margin: 2.5rem !important;
}

.sp-m-11 {
    margin: 2.75rem !important;
}

.sp-m-12 {
    margin: 3rem !important;
}

/*margin left and Right = x*/
.sp-mx-0 {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.sp-mx-1 {
    margin-left: .25rem !important;
    margin-right: .25rem !important;
}

.sp-mx-2 {
    margin-left: .5rem !important;
    margin-right: .5rem !important;
}

.sp-mx-3 {
    margin-left: .75rem !important;
    margin-right: .75rem !important;
}

.sp-mx-4 {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
}

.sp-mx-5 {
    margin-left: 1.25rem !important;
    margin-right: 1.25rem !important;
}

.sp-mx-6 {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
}

.sp-mx-7 {
    margin-left: 1.75rem !important;
    margin-right: 1.75rem !important;
}

.sp-mx-8 {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
}

.sp-mx-9 {
    margin-left: 2.25rem !important;
    margin-right: 2.25rem !important;
}

.sp-mx-10 {
    margin-left: 2.5rem !important;
    margin-right: 2.5rem !important;
}

.sp-mx-11 {
    margin-left: 2.75rem !important;
    margin-right: 2.75rem !important;
}

.sp-mx-12 {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
}
/*margin top and bottom = y*/
.sp-my-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.sp-my-1 {
    margin-top: .25rem !important;
    margin-bottom: .25rem !important;
}

.sp-my-2 {
    margin-top: .75rem !important;
    margin-bottom: .75rem !important;
}

.sp-my-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
}

.sp-my-4 {
    margin-top: 1.25rem !important;
    margin-bottom: 1.25rem !important;
}

.sp-my-5 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
}

.sp-my-6 {
    margin-top: 1.75rem !important;
    margin-bottom: 1.75rem !important;
}

.sp-my-7 {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
}

.sp-my-8 {
    margin-top: 2.25rem !important;
    margin-bottom: 2.25rem !important;
}

.sp-my-9 {
    margin-top: 2.5rem !important;
    margin-bottom: 2.5rem !important;
}

.sp-my-10 {
    margin-top: 2.75rem !important;
    margin-bottom: 2.75rem !important;
}

.sp-my-11 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
}

.sp-my-12 {
    margin-top: 3.25rem !important;
    margin-bottom: 3.25rem !important;
}
/*Margin bottom*/
.sp-mb-0 {
    margin-bottom: 0 !important;
}

.sp-mb-1 {
    margin-bottom: .25rem !important;
}

.sp-mb-2 {
    margin-bottom: .5rem !important;
}

.sp-mb-3 {
    margin-bottom: 0.75rem !important;
}

.sp-mb-4 {
    margin-bottom: 1rem !important;
}

.sp-mb-5 {
    margin-bottom: 1.25rem !important;
}

.sp-mb-6 {
    margin-bottom: 1.5rem !important;
}

.sp-mb-7 {
    margin-bottom: 1.75rem !important;
}

.sp-mb-8 {
    margin-bottom: 2rem !important;
}

.sp-mb-9 {
    margin-bottom: 2.25rem !important;
}

.sp-mb-10 {
    margin-bottom: 2.5rem !important;
}

.sp-mb-11 {
    margin-bottom: 2.75rem !important;
}

.sp-mb-12 {
    margin-bottom: 3rem !important;
}
/*margin top*/
.sp-mt-0 {
    margin-top: 0 !important;
}

.sp-mt-1 {
    margin-top: .25rem !important;
}

.sp-mt-2 {
    margin-top: .5rem !important;
}

.sp-mt-3 {
    margin-top: .75rem !important;
}

.sp-mt-4 {
    margin-top: 1rem !important;
}

.sp-mt-5 {
    margin-top: 1.25rem !important;
}

.sp-mt-6 {
    margin-top: 1.5rem !important;
}

.sp-mt-7 {
    margin-top: 1.75rem !important;
}

.sp-mt-8 {
    margin-top: 2rem !important;
}

.sp-mt-9 {
    margin-top: 2.25rem !important;
}

.sp-mt-10 {
    margin-top: 2.5rem !important;
}

.sp-mt-11 {
    margin-top: 2.75rem !important;
}

.sp-mt-12 {
    margin-top: 3rem !important;
}
/*margin left*/
.sp-ml-0 {
    margin-left: 0 !important;
}

.sp-ml-1 {
    margin-left: .25rem !important;
}

.sp-ml-2 {
    margin-left: .5rem !important;
}

.sp-ml-3 {
    margin-left: 0.75rem !important;
}

.sp-ml-4 {
    margin-left: 1rem !important;
}

.sp-ml-5 {
    margin-left: 1.25rem !important;
}

.sp-ml-6 {
    margin-left: 1.5rem !important;
}

.sp-ml-7 {
    margin-left: 1.75rem !important;
}

.sp-ml-8 {
    margin-left: 2rem !important;
}

.sp-ml-9 {
    margin-left: 2.25rem !important;
}

.sp-ml-10 {
    margin-left: 2.5rem !important;
}

.sp-ml-11 {
    margin-left: 2.75rem !important;
}

.sp-ml-12 {
    margin-left: 3rem !important;
}
/*margin right*/
.sp-mr-0 {
    margin-right: 0 !important;
}

.sp-mr-1 {
    margin-right: .25rem !important;
}

.sp-mr-2 {
    margin-right: .5rem !important;
}

.sp-mr-3 {
    margin-right: .75rem !important;
}

.sp-mr-4 {
    margin-right: 1rem !important;
}

.sp-mr-5 {
    margin-right: 1.25rem !important;
}

.sp-mr-6 {
    margin-right: 1.5rem !important;
}

.sp-mr-7 {
    margin-right: 1.75rem !important;
}

.sp-mr-8 {
    margin-right: 2rem !important;
}

.sp-mr-9 {
    margin-right: 2.25rem !important;
}

.sp-mr-10 {
    margin-right: 2.5rem !important;
}

.sp-mr-11 {
    margin-right: 2.75rem !important;
}

.sp-mr-12 {
    margin-right: 3rem !important;
}
/*padding*/
.sp-p-0 {
    padding: 0 !important;
}

.sp-p-1 {
    padding: .25rem !important;
}

.sp-p-2 {
    padding: .5rem !important;
}

.sp-p-3 {
    padding: .75rem !important;
}

.sp-p-4 {
    padding: 1rem !important;
}

.sp-p-5 {
    padding: 1.25rem !important;
}

.sp-p-6 {
    padding: 1.5rem !important;
}

.sp-p-7 {
    padding: 1.75rem !important;
}

.sp-p-8 {
    padding: 2rem !important;
}

.sp-p-9 {
    padding: 2.25rem !important;
}

.sp-p-10 {
    padding: 2.5rem !important;
}

.sp-p-11 {
    padding: 2.75rem !important;
}

.sp-p-12 {
    padding: 3rem !important;
}


/*padding*/
.sp-px-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.sp-px-1 {
    padding-left: .25rem !important;
    padding-right: .25rem !important;
}

.sp-px-2 {
    padding-left: .5rem !important;
    padding-right: .5rem !important;
}

.sp-px-3 {
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
}

.sp-px-4 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
}

.sp-px-5 {
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
}

.sp-px-6 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
}

.sp-px-7 {
    padding-left: 1.75rem !important;
    padding-right: 1.75rem !important;
}

.sp-px-8 {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
}

.sp-px-9 {
    padding-left: 2.25rem !important;
    padding-right: 2.25rem !important;
}

.sp-px-10 {
    padding-left: 2.5rem !important;
    padding-right: 2.5rem !important;
}

.sp-px-11 {
    padding-left: 2.75rem !important;
    padding-right: 2.75rem !important;
}

.sp-px-12 {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
}
/*padding top and bottom*/
.sp-py-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.sp-py-1 {
    padding-top: .25rem !important;
    padding-bottom: .25rem !important;
}

.sp-py-2 {
    padding-top: .5rem !important;
    padding-bottom: .5rem !important;
}

.sp-py-3 {
    padding-top: 0.75rem !important;
    padding-bottom: 0.75rem !important;
}

.sp-py-4 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
}

.sp-py-5 {
    padding-top: 1.25rem !important;
    padding-bottom: 1.25rem !important;
}

.sp-py-6 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
}

.sp-py-7 {
    padding-top: 1.75rem !important;
    padding-bottom: 1.75rem !important;
}

.sp-py-8 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
}

.sp-py-9 {
    padding-top: 2.25rem !important;
    padding-bottom: 2.25rem !important;
}

.sp-py-10 {
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
}

.sp-py-11 {
    padding-top: 2.75rem !important;
    padding-bottom: 2.75rem !important;
}

.sp-py-12 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
}

/*padding bottom*/
.sp-pb-0 {
    padding-bottom: 0 !important;
}

.sp-pb-1 {
    padding-bottom: .25rem !important;
}

.sp-pb-2 {
    padding-bottom: .5rem !important;
}

.sp-pb-3 {
    padding-bottom: 0.75rem !important;
}

.sp-pb-4 {
    padding-bottom: 1rem !important;
}

.sp-pb-5 {
    padding-bottom: 1.25rem !important;
}

.sp-pb-6 {
    padding-bottom: 1.5rem !important;
}

.sp-pb-7 {
    padding-bottom: 1.75rem !important;
}

.sp-pb-8 {
    padding-bottom: 2rem !important;
}

.sp-pb-9 {
    padding-bottom: 2.25rem !important;
}

.sp-pb-10 {
    padding-bottom: 2.5rem !important;
}

.sp-pb-11 {
    padding-bottom: 2.75rem !important;
}

.sp-pb-12 {
    padding-bottom: 3rem !important;
}

/*padding top*/
.sp-pt-0 {
    padding-top: 0 !important;
}

.sp-pt-1 {
    padding-top: .25rem !important;
}

.sp-pt-2 {
    padding-top: .5rem !important;
}

.sp-pt-3 {
    padding-top: .75rem !important;
}

.sp-pt-4 {
    padding-top: 1rem !important;
}

.sp-pt-5 {
    padding-top: 1.25rem !important;
}

.sp-pt-6 {
    padding-top: 1.5rem !important;
}

.sp-pt-7 {
    padding-top: 1.75rem !important;
}

.sp-pt-8 {
    padding-top: 2rem !important;
}

.sp-pt-9 {
    padding-top: 2.25rem !important;
}

.sp-pt-10 {
    padding-top: 2.5rem !important;
}

.sp-pt-11 {
    padding-top: 2.75rem !important;
}

.sp-pt-12 {
    padding-top: 3rem !important;
}
/*padding left*/
.sp-pl-0 {
    padding-left: 0 !important;
}

.sp-pl-1 {
    padding-left: .25rem !important;
}

.sp-pl-2 {
    padding-left: .5rem !important;
}

.sp-pl-3 {
    padding-left: 0.75rem !important;
}

.sp-pl-4 {
    padding-left: 1rem !important;
}

.sp-pl-5 {
    padding-left: 1.25rem !important;
}

.sp-pl-6 {
    padding-left: 1.5rem !important;
}

.sp-pl-7 {
    padding-left: 1.75rem !important;
}

.sp-pl-8 {
    padding-left: 2rem !important;
}

.sp-pl-9 {
    padding-left: 2.25rem !important;
}

.sp-pl-10 {
    padding-left: 2.5rem !important;
}

.sp-pl-11 {
    padding-left: 2.75rem !important;
}

.sp-pl-12 {
    padding-left: 3rem !important;
}
/*padding-right*/
.sp-pr-0 {
    padding-right: 0 !important;
}

.sp-pr-1 {
    padding-right: .25rem !important;
}

.sp-pr-2 {
    padding-right: .5rem !important;
}

.sp-pr-3 {
    padding-right: 0.75rem !important;
}

.sp-pr-4 {
    padding-right: 1rem !important;
}

.sp-pr-5 {
    padding-right: 1.25rem !important;
}

.sp-pr-6 {
    padding-right: 1.5rem !important;
}

.sp-pr-7 {
    padding-right: 1.75rem !important;
}

.sp-pr-8 {
    padding-right: 2rem !important;
}

.sp-pr-9 {
    padding-right: 2.25rem !important;
}

.sp-pr-10 {
    padding-right: 2.5rem !important;
}

.sp-pr-11 {
    padding-right: 2.75rem !important;
}

.sp-pr-12 {
    padding-right: 3rem !important;
}

/*width*/
.sp-w-auto {
    width: auto;
    min-width: auto;
    max-width: fit-content;
    max-width: -moz-fit-content;
}

.sp-w {
    width: 100% !important;
}

.sp-w-1 {
    width: 8.33333% !important;
    max-width: 8.33333%;
}

.sp-w-2 {
    width: 16.66667% !important;
    max-width: 16.66667%;
}

.sp-w-3 {
    width: 25% !important;
    max-width: 25%
}

.sp-w-4 {
    width: 33.33333% !important;
    max-width: 33.33333%;
}

.sp-w-5 {
    width: 41.66667% !important;
    max-width: 41.66667%;
}

.sp-w-6 {
    width: 50% !important;
    max-width: 50%;
}

.sp-w-7 {
    width: 58.33333% !important;
    max-width: 58.33333%
}

.sp-w-8 {
    width: 66.66667% !important;
    max-width: 66.66667%
}

.sp-w-9 {
    width: 75% !important;
    max-width: 75%
}

.sp-w-10 {
    width: 83.33333% !important;
    max-width: 83.33333%
}

.sp-w-11 {
    width: 91.66667% !important;
    max-width: 91.66667%
}

.sp-w-12 {
    width: 100% !important;
    max-width: 100%
}

/*Max Width*/
.sp-wp-1 {
    width: 80px !important;
    max-width: 80px;
}

.sp-wp-2 {
    width: 160px !important;
    max-width: 160px;
}

.sp-wp-3 {
    width: 240px !important;
    max-width: 240px;
}

.sp-wp-4 {
    width: 320px !important;
    max-width: 320px;
}

.sp-wp-5 {
    width: 400px !important;
    max-width: 400px;
}

.sp-wp-6 {
    width: 480px !important;
    max-width: 480px;
}

.sp-wp-7 {
    width: 560px !important;
    max-width: 560px;
}

.sp-wp-8 {
    width: 640px !important;
    max-width: 640px;
}

.sp-wp-9 {
    width: 720px !important;
    max-width: 720px;
}

.sp-wp-10 {
    width: 800px !important;
    max-width: 800px;
}

.sp-wp-11 {
    width: 900px !important;
    max-width: 900px;
}

.sp-wp-12 {
    width: 1000px !important;
    max-width: 1000px;
}

.sp-wm-1 {
    max-width: 80px !important;
}

.sp-wm-2 {
    max-width: 160px !important;
}

.sp-wm-3 {
    max-width: 240px !important;
}

.sp-wm-4 {
    max-width: 320px !important;
}

.sp-wm-5 {
    max-width: 400px !important;
}

.sp-wm-6 {
    max-width: 480px !important;
}

.sp-wm-7 {
    max-width: 560px !important;
}

.sp-wm-8 {
    max-width: 640px !important;
}

.sp-wm-9 {
    max-width: 720px !important;
}

.sp-wm-10 {
    max-width: 800px !important;
}

.sp-wm-11 {
    max-width: 900px !important;
}

.sp-wm-12 {
    max-width: 1000px !important;
}

.sp-wn-1 {
    min-width: 80px !important;
}

.sp-wn-2 {
    min-width: 160px !important;
}

.sp-wn-3 {
    min-width: 240px !important;
}

.sp-wn-4 {
    min-width: 320px !important;
}

.sp-wn-5 {
    min-width: 400px !important;
}

.sp-wn-6 {
    min-width: 480px !important;
}

.sp-wn-7 {
    min-width: 560px !important;
}

.sp-wn-8 {
    min-width: 640px !important;
}

.sp-wn-9 {
    min-width: 720px !important;
}

.sp-wn-10 {
    min-width: 800px !important;
}

.sp-wn-11 {
    min-width: 900px !important;
}

.sp-wn-12 {
    min-width: 1000px !important;
}

/*height*/
.sp-h-auto {
    height: fit-content;
}

.sp-h {
    height: 100% !important;
}

.sp-h-1 {
    height: 8.33333% !important;
}

.sp-h-2 {
    height: 16.66667% !important;
}

.sp-h-3 {
    height: 25% !important;
}

.sp-h-4 {
    height: 33.33333% !important;
}

.sp-h-5 {
    height: 41.66667% !important;
}

.sp-h-6 {
    height: 50% !important;
}

.sp-h-7 {
    height: 58.33333% !important;
}

.sp-h-8 {
    height: 66.66667% !important;
}

.sp-h-9 {
    height: 75% !important;
}

.sp-h-10 {
    height: 83.33333% !important;
}

.sp-h-11 {
    height: 91.66667% !important;
}

.sp-h-12 {
    height: 100% !important;
    max-height: 100%
}

.sp-hp-1 {
    height: 40px !important;
    max-height: 40px !important;
}

.sp-hp-2 {
    height: 80px !important;
    max-height: 80px !important;
}

.sp-hp-3 {
    height: 120px !important;
    max-height: 120px !important;
}

.sp-hp-4 {
    height: 160px !important;
    max-height: 160px !important;
}

.sp-hp-5 {
    height: 200px !important;
    max-height: 200px !important;
}

.sp-hp-6 {
    height: 240px !important;
    max-height: 240px !important;
}

.sp-hp-7 {
    height: 260px !important;
    max-height: 260px !important;
}

.sp-hp-8 {
    height: 320px !important;
    max-height: 320px !important;
}

.sp-hp-9 {
    height: 350px !important;
    max-height: 350px !important;
}

.sp-hp-10 {
    height: 400px !important;
    max-height: 400px !important;
}

.sp-hp-11 {
    height: 500px !important;
    max-height: 500px !important;
}

.sp-hp-12 {
    height: 600px !important;
    max-height: 600px !important;
}
/*Max Height*/
.sp-hm-1 {
    max-height: 40px !important;
}

.sp-hm-2 {
    max-height: 80px !important;
}

.sp-hm-3 {
    max-height: 120px !important;
}

.sp-hm-4 {
    max-height: 160px !important;
}

.sp-hm-5 {
    max-height: 200px !important;
}

.sp-hm-6 {
    max-height: 240px !important;
}

.sp-hm-7 {
    max-height: 260px !important;
}

.sp-hm-8 {
    max-height: 320px !important;
}

.sp-hm-9 {
    max-height: 350px !important;
}

.sp-hm-10 {
    max-height: 400px !important;
}

.sp-hm-11 {
    max-height: 500px !important;
}

.sp-hm-12 {
    max-height: 600px !important;
}
/*Min Height*/
.sp-hn-1 {
    min-height: 40px !important;
}

.sp-hn-2 {
    min-height: 80px !important;
}

.sp-hn-3 {
    min-height: 120px !important;
}

.sp-hn-4 {
    min-height: 160px !important;
}

.sp-hn-5 {
    min-height: 200px !important;
}

.sp-hn-6 {
    min-height: 240px !important;
}

.sp-hn-7 {
    min-height: 260px !important;
}

.sp-hn-8 {
    min-height: 320px !important;
}

.sp-hn-9 {
    min-height: 350px !important;
}

.sp-hn-10 {
    min-height: 400px !important;
}

.sp-hn-11 {
    min-height: 500px !important;
}

.sp-hn-12 {
    min-height: 600px !important;
}

.sp-select-none {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.sp-pointer {
    cursor: pointer !important;
}

/*Ultra*/
*[ultra-action] {
    color: var(--linelight);
}

    *[ultra-action] img {
        filter: opacity(20%) grayscale(70%);
    }

.sp-ultra-active {
    cursor: pointer !important;
    color: inherit;
}

    .sp-ultra-active img {
        filter: inherit;
    }

input[type=button] .sp-ultra-active, input[type=submit] .sp-ultra-active, button .sp-ultra-active {
    background-color: var(--dark);
}

.sp-ultra-active .sp-ultra-wait img {
    content: var(--bgloading) !important;
}

.sp-ultra-help {
    cursor: help !important;
}

.sp-ultra-deactive {
    cursor: no-drop !important;
}

.sp-ultra-wait {
    cursor: wait !important;
}

.sp-ultra-waiting {
    position: absolute;
    cursor: wait !important;
    height: 100%;
    width: 100%;
    background-color: black;
    opacity: 0.5;
    top: 0;
    left: 0;
    z-index: 100;
    border-radius: 4px;
    border-radius: var(--radius);
}

input[type=button] .sp-ultra-wait, input[type=submit] .sp-ultra-wait, button .sp-ultra-wait {
    background-image: var(--wloading) !important;
}

.sp-ultra-wait .sp-select-input, .sp-ultra-wait .sp-drop-button {
    background-image: url(/themes/base/images/bgLoading.gif) !important;
    background-size: 24px;
    background-repeat: no-repeat;
    background-position: left;
    background-position-x: 4px;
    cursor: wait !important;
}

.sp-ultra-wait .sp-f-select::after, .sp-ultra-wait .sp-select:after, .sp-ultra-wait .sp-drop:after {
    border: none !important;
}

.sp-f-select .sp-toggle-active.sp-select-collapse {
    transform: rotate(90deg);
}
/*Toggle*/
.sp-toggle {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    -webkit-flex: 0 0 100%;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
}

.sp-toggle-nav, .sp-toggle-left {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 20%;
    -webkit-flex: 0 0 20%;
    -ms-flex: 0 0 20%;
    flex: 0 0 20%;
    border-radius: 4px;
    background-color: var(--verylight);
    padding: 4px;
}

.sp-toggle-resize {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-flex: 0 0 4px;
    -ms-flex: 0 0 4px;
    flex: 0 0 4px;
    background-color: var(--select);
    width: 4px;
    cursor: e-resize;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    margin: 0 4px;
    border-radius: 4px;
}

.sp-toggle-body {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: calc(80% - 10px);
    -webkit-flex: 0 0 calc(80% - 10px);
    -ms-flex: 0 0 calc(80% - 10px);
    flex: 0 0 calc(80% - 10px);
    border-radius: 4px;
    padding: 0 4px 0 4px;
}

.sp-toggle-small .sp-toggle-nav {
    width: 10%;
    -webkit-flex: 0 0 10%;
    -ms-flex: 0 0 10%;
    flex: 0 0 10%;
}

.sp-toggle-small .sp-toggle-body {
    width: calc(90% - 8px);
    -webkit-flex: 0 0 calc(90% - 8px);
    -ms-flex: 0 0 calc(90% - 8px);
    flex: 0 0 calc(90% - 8px);
}
/*Panel*/
.sp-panel {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-basis: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    background-color: var(--context);
    border: 1px solid var(--line);
    border-radius: 4px;
    border-radius: var(--radius);
    margin-bottom: 0.5rem;
}

.sp-panel-header {
    font-size: 14px;
    border-bottom: 1px solid var(--line);
    background-color: var(--lighthover);
    background-image: -webkit-linear-gradient(top,#dfe1e5 0,#b9bbbf 100%);
    background-image: -o-linear-gradient(top,#dfe1e5 0,#b9bbbf 100%);
    background-image: linear-gradient(to bottom,#dfe1e5 0,#b9bbbf 100%);
    background-repeat: repeat-x;
    border-radius: 4px 4px 0 0;
    font-weight: 700;
    padding: 4px;
    padding-left: 10px;
}

.sp-panel-body {
    background-color: white;
}

.sp-panel-row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    border-bottom: 1px solid rgb(184, 186, 187);
}

.sp-panel-title {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 200px;
    padding: 5px 6px;
    padding-left: 16px;
    background: var(--header);
    min-width: 220px;
    font-size: 12px;
}

.sp-panel-value {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: calc(100% - 200px);
    padding: 2px 4px;
    padding-left: 8px;
    line-height: 1.4em;
}

/*sp-skeleton*/
.sp-skeleton {
    position: relative;
    min-height: 50px;
    overflow: hidden;
    background-color: var(--lightbg);
    border-radius: 4px;
    border-radius: var(--radius);
    margin: 4px 4px 8px 4px;
}

    .sp-skeleton:after {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        transform: translateX(-100%);
        background-color: var(--lighthover);
        animation: shimmer 2s infinite;
        content: '';
    }

@keyframes shimmer {
    100% {
        transform: translateX(100%);
    }
}

.sp-container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-basis: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
}

    .sp-container:hover .sp-hover {
        display: block;
    }

.sp-header {
    background-color: var(--header);
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    flex-basis: 100%;
    padding: 4px;
    border-radius: 4px;
    border-radius: var(--radius);
    text-align: center;
}

.sp-line {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-flex-basis: 100px;
    flex-basis: 100%;
    margin-right: -5px;
    margin-left: -5px;
    margin-bottom: 10px;
}

.sp-link {
    color: var(--link);
}

    .sp-link .sp-ultra-active {
        color: var(--link);
    }

.sp-title {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    vertical-align: top;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    min-width: 20%;
    font-weight: bold;
    text-align: left;
    padding: 4px
}

.sp-value {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    vertical-align: top;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    max-width: 80%;
    text-align: left;
    padding: 4px
}
/*Hover*/
.sp-hover-view, .sp-hover {
    display: none;
}

    .sp-hover-view:hover, .sp-hover:hover {
        display: none;
        transform: scale(1.1);
    }

.sp-hover-scale:hover {
    transition: 0.5s;
    transform: scale(1.1);
}

.sp-hover-gray {
    transition: 0.5s;
    filter: grayscale(0.6);
}

    .sp-hover-gray:hover {
        filter: grayscale(0);
    }

.sp-hover-dashed {
    border-style: none;
}

    .sp-hover-dashed:hover {
        border-style: dashed;
    }
/*Row-col*/
.sp-row, .sp-r {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-flex-basis: 100px;
    flex-basis: 100%;
    margin-right: -5px;
    margin-left: -5px;
}
/*column 12*/
.sp-col, .sp-col-1, .sp-col-2, .sp-col-3, .sp-col-4, .sp-col-5, .sp-col-6,
.sp-col-7, .sp-col-8, .sp-col-9, .sp-col-10, .sp-col-11, .sp-col-12,
.sp-c, .sp-c-1, .sp-c-2, .sp-c-3, .sp-c-4, .sp-c-5, .sp-c-6,
.sp-c-7, .sp-c-8, .sp-c-9, .sp-c-10, .sp-c-11, .sp-c-12 {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    vertical-align: top;
    width: 100%;
    padding-right: 5px;
    padding-left: 5px;
}

.sp-col, .sp-col-1, .sp-c, .sp-c-1 {
    -webkit-flex: 0 0 8.33333%;
    -ms-flex: 0 0 8.33333%;
    flex: 0 0 8.33333%;
    max-width: 8.33333%;
}

.sp-col-2, .sp-c-2 {
    -webkit-flex: 0 0 16.66667%;
    -ms-flex: 0 0 16.66667%;
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
}

.sp-col-3, .sp-c-3 {
    -webkit-flex: 0 0 25%;
    -ms-flex: 0 0 25%;
    flex: 0 0 25%;
    max-width: 25%
}

.sp-col-4, .sp-c-4 {
    -webkit-flex: 0 0 33.33333%;
    -ms-flex: 0 0 33.33333%;
    flex: 0 0 33.33333%;
    max-width: 33.33333%;
}

.sp-col-5, .sp-c-5 {
    -webkit-flex: 0 0 41.66667%;
    -ms-flex: 0 0 41.66667%;
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
}

.sp-col-6, .sp-c-6 {
    -webkit-flex: 0 0 50%;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
}

.sp-col-7, .sp-c-7 {
    -webkit-flex: 0 0 58.33333%;
    -ms-flex: 0 0 58.33333%;
    flex: 0 0 58.33333%;
    max-width: 58.33333%
}

.sp-col-8, .sp-c-8 {
    -webkit-flex: 0 0 66.66667%;
    -ms-flex: 0 0 66.66667%;
    flex: 0 0 66.66667%;
    max-width: 66.66667%
}

.sp-col-9, .sp-c-9 {
    -webkit-flex: 0 0 75%;
    -ms-flex: 0 0 75%;
    flex: 0 0 75%;
    max-width: 75%
}

.sp-col-10, .sp-c-10 {
    -webkit-flex: 0 0 83.33333%;
    -ms-flex: 0 0 83.33333%;
    flex: 0 0 83.33333%;
    max-width: 83.33333%
}

.sp-col-11, .sp-c-11 {
    -webkit-flex: 0 0 91.66667%;
    -ms-flex: 0 0 91.66667%;
    flex: 0 0 91.66667%;
    max-width: 91.66667%
}

.sp-col-12, .sp-c-12 {
    -webkit-flex: 0 0 100%;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%
}

/*Column Ten*/
.sp-ct, .sp-ct-1, .sp-ct-2, .sp-ct-3, .sp-ct-4, .sp-ct-5, .sp-ct-6, .sp-ct-7, .sp-ct-8, .sp-ct-9, .sp-ct-10 {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    vertical-align: top;
    width: 100%;
    padding-right: 5px;
    padding-left: 5px;
}

sp-ct, .sp-ct-1 {
    -webkit-flex: 0 0 10%;
    -ms-flex: 0 0 10%;
    flex: 0 0 10%;
    max-width: 10%;
}

.sp-ct-2 {
    -webkit-flex: 0 0 20%;
    -ms-flex: 0 0 20%;
    flex: 0 0 20%;
    max-width: 0 0 20%;
}

.sp-ct-3 {
    -webkit-flex: 0 0 30%;
    -ms-flex: 0 0 30%;
    flex: 0 0 30%;
    max-width: 30%;
}

.sp-ct-4 {
    -webkit-flex: 0 0 40%;
    -ms-flex: 0 0 40%;
    flex: 0 0 40%;
    max-width: 40%;
}

.sp-ct-5 {
    -webkit-flex: 0 0 50%;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
}

.sp-ct-6 {
    -webkit-flex: 0 0 60%;
    -ms-flex: 0 0 60%;
    flex: 0 0 60%;
    max-width: 60%;
}

.sp-ct-7 {
    -webkit-flex: 0 0 70%;
    -ms-flex: 0 0 70%;
    flex: 0 0 70%;
    max-width: 70%;
}

.sp-ct-8 {
    -webkit-flex: 0 0 80%;
    -ms-flex: 0 0 80%;
    flex: 0 0 80%;
    max-width: 80%;
}

.sp-ct-9 {
    -webkit-flex: 0 0 90%;
    -ms-flex: 0 0 90%;
    flex: 0 0 90%;
    max-width: 90%;
}

.sp-ct-10 {
    -webkit-flex: 0 0 100%;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
}

/*Column Seven*/
.sp-cs, .sp-cs-1, .sp-cs-2, .sp-cs-3, .sp-cs-4, .sp-cs-5, .sp-cs-6, .sp-cs-7 {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    vertical-align: top;
    width: 100%;
    padding-right: 5px;
    padding-left: 5px;
}

.sp-cs, .sp-cs-1 {
    -webkit-flex: 0 0 14.28%;
    -ms-flex: 0 0 14.28%;
    flex: 0 0 14.28%;
    max-width: 14.28%;
}

.sp-cs-2 {
    -webkit-flex: 0 0 28.57%;
    -ms-flex: 0 0 28.57%;
    flex: 0 0 28.57%;
    max-width: 0 0 28.57%;
}

.sp-cs-3 {
    -webkit-flex: 0 0 42.84%;
    -ms-flex: 0 0 42.84%;
    flex: 0 0 42.84%;
    max-width: 42.84%;
}

.sp-cs-4 {
    -webkit-flex: 0 0 57.12%;
    -ms-flex: 0 0 57.12%;
    flex: 0 0 57.12%;
    max-width: 57.12%;
}

.sp-cs-5 {
    -webkit-flex: 0 0 71.4%;
    -ms-flex: 0 0 71.4%;
    flex: 0 0 71.4%;
    max-width: 71.4%;
}

.sp-cs-6 {
    -webkit-flex: 0 0 85.68%;
    -ms-flex: 0 0 85.68%;
    flex: 0 0 85.68%;
    max-width: 85.68%;
}

.sp-cs-7 {
    -webkit-flex: 0 0 100%;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
}
/*Html Left to right*/
.sp-html {
    text-align: left !important;
    font-family: inherit;
    font-size: 14px;
    direction: ltr !important;
}

/*Table*/
.sp-table {
    width: auto;
    border-spacing: 5px;
    border-width: 0;
    direction: ltr;
    border-radius: 6px;
    border: 1px solid var(--line);
    box-sizing: border-box;
    overflow: hidden;
    background-color: var(--bgcolor);
    display: block;
}

.sp-table-row {
    width: 100%;
    display: block;
}

.sp-table-cell {
    display: inline-block;
}

.sp-wait-page {
    position: fixed;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    background-color: black;
    text-align: center;
    height: 100%;
    z-index: 90000;
    opacity: 0.6;
    filter: alpha(opacity=60);
    color: var(--white);
}

.sp-overflow-auto {
    overflow: auto;
}

.sp-overflowx-auto {
    overflow-x: auto;
}

.sp-overflowy-auto {
    overflow-x: auto;
}

.sp-overflow-hidden {
    overflow: hidden;
}
/*barcode*/
.sp-barcode {
    max-height: 150px;
    max-width: 150px;
}
/*tab*/
.sp-tab {
    position: relative;
    width: 100%;
    overflow: hidden;
    transition: border 250ms ease;
}

.sp-tab-header {
    position: relative;
    border-bottom: 1px solid var(--line);
    padding-top: 4px;
    border-radius: 4px 4px 0 0;
    background-color: var(--verylight);
}

    .sp-tab-header:after {
        position: absolute;
        content: " ";
        right: 0;
        left: 0;
        bottom: -1px;
        border-bottom: 4px solid var(--light);
        border-radius: 4px 4px 0 0;
        z-index: 4;
    }

.sp-tab-body {
    background-color: var(--header);
    padding: 4px;
}

.sp-tab-item {
    position: relative;
    display: inline-block;
    padding: 10px 24px 8px;
    background-color: #FFF;
    z-index: 2;
    cursor: pointer;
    color: #777;
    text-transform: uppercase;
    transition: all 250ms ease;
    background-color: var(--bgcolor);
    margin-left: 46px;
    color: var(--line);
}

    .sp-tab-item a {
        color: #777;
    }

    .sp-tab-item:before, .sp-tab-item:after {
        position: absolute;
        display: block;
        content: " ";
        top: 0;
        height: 100%;
        width: 44px;
        background-color: var(--bgcolor);
        transition: all 250ms ease;
        z-index: 2;
    }

    .sp-tab-item:before {
        right: -24px;
        transform: skew(30deg, 0deg);
        box-shadow: rgba(0,0,0,.1) 4px 2px 5px, inset rgba(255,255,255,.09) -1px 0;
        border-radius: 0 8px 0 0;
    }

    .sp-tab-item:after {
        left: -24px;
        transform: skew(-30deg, 0deg);
        box-shadow: rgba(0,0,0,.1) -3px 2px 5px, inset rgba(255,255,255,.09) 1px 0;
        border-radius: 8px 8px 0 0;
    }

    .sp-tab-item:hover, .sp-tab-item:hover::after, .sp-tab-item:hover::before {
        background-color: var(--verylight);
        color: var(--primary);
    }

.sp-tab-small {
    margin-right: 4px;
    margin-left: 15px;
    padding: 10px 12px 8px;
}

    .sp-tab-small:before, .sp-tab-small:after {
        width: 22px;
    }

    .sp-tab-small:before {
        right: -12px;
        transform: skew(14deg, 0deg);
    }

    .sp-tab-small:after {
        left: -12px;
        transform: skew(-14deg, 0deg);
    }

.sp-tab-thin, .sp-tab-thin .sp-tab-item {
    margin-right: 4px;
    margin-left: 15px;
    padding: 4px 12px 2px;
}

    .sp-tab-thin:before, .sp-tab-thin:after, .sp-tab-thin .sp-tab-item:before, .sp-tab-thin .sp-tab-item:after {
        width: 22px;
    }

    .sp-tab-thin:before, .sp-tab-thin .sp-tab-item:before {
        right: -12px;
        transform: skew(14deg, 0deg);
    }

    .sp-tab-thin:after, .sp-tab-thin .sp-tab-item:after {
        left: -12px;
        transform: skew(-14deg, 0deg);
    }

.sp-tab-active, .sp-tab-active a {
    background-color: var(--light);
    color: var(--dark) !important;
    z-index: 3;
}

    .sp-tab-active:after, .sp-tab-active:before {
        background-color: var(--light);
        z-index: 3;
    }

    .sp-tab-active:hover, .sp-tab-active:hover::after, .sp-tab-active:hover::before {
        background-color: var(--light);
    }

.sp-tab-image {
    display: inline-block;
}

.sp-tab-content {
    margin: 4px;
}

.sp-tab-text {
    display: inline-block;
}

.sp-tab-item img {
    width: 20px;
}
/*type of tab*/
.sp-tab-left {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    border-bottom: 0;
    padding-top: 0px;
}

    .sp-tab-left .sp-tab-header {
        height: unset;
        border-right: 4px solid var(--primary);
        border-bottom: none;
        width: 50px;
        min-height: 300px;
        direction: ltr;
    }

    .sp-tab-left .sp-tab-rotate {
        position: relative;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        transform: rotate(-90deg);
        flex-direction: row-reverse;
        padding-left: 46px;
        height: unset;
        min-width: 50px;
        width: unset
    }

    .sp-tab-left .sp-tab-item {
        margin-left: 0;
        margin-right: 46px;
    }


    .sp-tab-left .sp-tab-body {
        padding: 4px;
        width: calc(100% - 50px);
    }

    .sp-tab-left .sp-tab-small {
        padding-left: 13px
    }


.sp-tab-right {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    border-bottom: 0;
    padding-top: 0px;
}

    .sp-tab-right .sp-tab-header {
        height: unset;
        border-right: 4px solid var(--primary);
        border-bottom: none;
        width: 50px;
        min-height: 300px;
        direction: ltr;
    }

    .sp-tab-right .sp-tab-rotate {
        position: relative;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        transform: rotate(-90deg);
        flex-direction: row-reverse;
        padding-left: 46px;
        height: unset;
        min-width: 50px;
        width: unset
    }

    .sp-tab-right .sp-tab-item {
        margin-left: 0;
        margin-right: 46px;
    }


    .sp-tab-right .sp-tab-body {
        padding: 4px;
        width: calc(100% - 50px);
    }

    .sp-tab-right .sp-tab-small {
        padding-left: 13px
    }

.sp-tab-simple {
}

    .sp-tab-simple .sp-tab-header {
        background-color: var(--bgcolor);
    }

    .sp-tab-simple .sp-tab-item {
        margin-right: 2px;
        margin-left: 2px;
        border-radius: 8px 8px 0 0;
        padding: 8px 10px 8px;
        background-color: var(--linelight);
    }

    .sp-tab-simple .sp-tab-active {
        background-color: var(--light);
    }

    .sp-tab-simple .sp-tab-item:first-child {
        margin-left: 10px;
    }

    .sp-tab-simple .sp-tab-item:before {
        content: none;
    }

    .sp-tab-simple .sp-tab-item:after {
        content: none;
    }


/*image*/
.sp-image-large {
    position: fixed;
    text-align: center;
    z-index: 1000;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(100,100,100, 0.5);
}

.sp-image-preview, sp-icon-preview, sp-picture-preview, sp-figure-preview {
    cursor: pointer;
}
/*Tab*/
.sp-tab-normal .sp-tab-item {
    margin-left: 0;
    margin-right: 0px;
    padding: 8px;
    border-radius: 4px 4px 0 0;
}

    .sp-tab-normal .sp-tab-item:first-child {
        margin-right: 4px;
    }

    .sp-tab-normal .sp-tab-item:before {
        content: none;
    }

    .sp-tab-normal .sp-tab-item:after {
        content: none;
    }


/*Chart*/
.sp-chart {
    background-color: var(--context);
}
/*Grid*/
.sp-grid, .sp-g {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    clear: both;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    background-color: var(--context);
    border: 1px solid var(--line);
    white-space: normal;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-grid-header, .sp-g-header {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    flex: 0 1 auto;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-basis: 100%;
    border-bottom: 1px solid var(--line);
    cursor: default;
    color: var(--white);
    text-align: center;
    min-height: 46px;
    background-color: var(--primary);
    border-radius: 4px 4px 0 0;
    -webkit-justify-content: center;
    justify-content: center;
}

    .sp-grid-header .sp-grid-cell, .sp-g-header .sp-g-cell {
        border-right: 1px solid var(--line);
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        text-align: center;
        vertical-align: top;
        box-sizing: border-box;
        padding: .75rem .15rem;
        background-repeat: no-repeat;
        background-position: center right;
        overflow: hidden;
    }

    .sp-grid-header .sp-grid-sorting, .sp-g-header .sp-g-sorting {
        background-image: url(/themes/base/images/sort_both.png);
    }

    .sp-grid-header .sp-grid-sorting-asc, .sp-g-header .sp-g-sorting-asc {
        background-image: url(/themes/base/images/sort_asc.png)
    }

    .sp-grid-header .sp-grid-sorting-desc, .sp-g-header .sp-g-sorting-desc {
        background-image: url(/themes/base/images/sort_desc.png)
    }

    .sp-grid-header .sp-grid-cell:[dir*="ltr"]:last-child, .sp-g-header .sp-g-cell:[dir*="ltr"]:last-child {
        border-right: none;
    }

    .sp-grid-header .sp-grid-cell:[dir*="rtl"]:first-child, .sp-g-header .sp-g-cell:[dir*="rtl"]:first-child {
        border-right: none;
    }

.sp-grid-footer, .sp-g-footer {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    flex: 0 1 auto;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-basis: 100%;
    cursor: default;
    background-color: var(--header);
    color: var(--label);
    font-weight: bold;
    min-height: 40px;
    border-top: 1px solid var(--line);
    border-radius: 0 0 4px 4px;
    -webkit-justify-content: center;
    justify-content: center;
}

    .sp-grid-footer .sp-grid-cell, .sp-g-footer .sp-g-cell {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        margin-top: 4px;
        margin-bottom: 4px;
        height: 35px;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        text-align: center;
        padding: 4px;
        vertical-align: top;
    }

        .sp-grid-footer .sp-grid-cell span, .sp-g-footer .sp-g-cell span {
            border: 1px solid var(--line);
            padding: 2px 10px;
            border-radius: 4px;
            border-radius: var(--radius);
        }

.sp-grid .sp-paging, .sp-g .sp-paging {
    border: none;
}

.sp-grid-row, .sp-g-row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    flex: 0 1 auto;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-basis: 100%;
    background-color: var(--context);
    border-top: none;
    color: var(--label);
    text-align: center;
    -webkit-justify-content: center;
    justify-content: center;
    min-height: 35px;
}

    .sp-grid-row:hover, .sp-g-row:hover {
        background-color: var(--select);
        border-top: none;
        color: black;
        text-align: center;
        transition: all 0.5s ease-in-out;
    }

        .sp-grid-row:hover .sp-g-cell img, .sp-g-row:hover .sp-g-cell img,
        .sp-g-row:hover .sp-g-cell i, .sp-grid-row:hover .sp-grid-cell i {
            filter: none;
            transition: all 0.5s ease-in-out;
        }

    .sp-grid-row:nth-child(even), .sp-g-row:nth-child(even) {
        background-color: var(--lighthover);
        border-top: none;
    }

    .sp-grid-row .sp-grid-cell, .sp-g-row .sp-g-cell {
        margin-top: 0;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        border-right: 1px solid var(--line);
        vertical-align: top;
        box-sizing: border-box;
        padding: .5rem .15rem;
    }

        .sp-grid-row .sp-grid-cell:[dir*="ltr"]:last-child, .sp-g-row .sp-g-cell:[dir*="ltr"]:last-child {
            border-right: none;
        }

        .sp-grid-row .sp-grid-cell:[dir*="rtl"]:first-child, .sp-g-row .sp-g-cell:[dir*="rtl"]:first-child {
            border-right: none;
        }

.sp-grid-nested, .sp-g-nested {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}

.sp-grid-cell img, .sp-g-cell img {
    width: 24px;
    height: 24px;
    filter: opacity(20%) grayscale(70%);
    margin: auto;
}

.sp-grid-cell i, .sp-g-cell i {
    filter: opacity(20%) grayscale(70%)
}


.sp-grid-cell a, .sp-g-cell a {
    display: block;
}

.sp-grid-row .sp-grid-cell, .sp-g-row .sp-g-cell {
    white-space: nowrap;
    overflow: hidden; /* "overflow" value must be different from "visible" */
    text-overflow: ellipsis;
}

.sp-grid-filter, .sp-g-filter {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    flex: 0 1 auto;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-basis: 100%;
    background-color: var(--select);
    border-top: none;
    color: var(--label);
    text-align: center;
    -webkit-justify-content: center;
    justify-content: center;
    min-height: 35px;
}

.sp-grid-multi .sp-grid-cell, .sp-g-multi .sp-g-cell {
    white-space: normal !important;
    text-overflow: ellipsis !important;
    overflow: hidden; /* "overflow" value must be different from "visible" */
}

.sp-grid-buttons, .sp-g-buttons {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex: 0 0 auto;
    flex-direction: row;
    flex-wrap: wrap;
}

.sp-grid-button, .sp-g-button {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex: 0 0 auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 0px 4px;
}

.sp-grid-select, .sp-g-select {
    background-color: var(--select) !important;
}
/*Grid Right to left */
.sp-grid-rtl, .sp-g-rtl {
    direction: rtl;
}

    .sp-grid-rtl .sp-grid-cell, .sp-g-rtl .sp-g-cell {
        border: none !important
    }

    .sp-grid-rtl sp-grid-header .sp-grid-cell:not(:first-child), .sp-g-rtl .sp-g-header .sp-g-cell:not(:first-child) {
        border-right: 1px solid var(--line) !important
    }

    .sp-grid-rtl sp-grid-row .sp-grid-cell:not(:first-child), .sp-g-rtl .sp-g-row .sp-g-cell:not(:first-child) {
        border-right: 1px solid var(--line) !important
    }

    .sp-grid-rtl .sp-grid-footer .sp-grid-cell, .sp-g-rtl .sp-g-footer .sp-g-cell {
        border: none !important
    }
/*Grid Group*/
.sp-g-group {
}

    .sp-g-group .sp-g-cell {
        border-bottom: 1px solid var(--line) !important;
        border-right: none;
    }

        .sp-g-group .sp-g-cell:last-child {
            border-bottom: none;
        }

/*Scroll grid*/
.sp-g-scroll {
    overflow-x: auto;
}

    .sp-g-scroll .sp-g {
        width: fit-content;
        width: -moz-fit-content;
        margin: 0.25% auto;
    }

    .sp-g-scroll .sp-grid-cell a, .sp-g-scroll .sp-g-cell a {
        display: block;
        text-align: center;
    }

    /*.sp-g-scroll .sp-g-row .sp-g-cell {
        min-width: 100px !important;
        max-width: fit-content !important;
        width: 100px !important;
    }*/

    /* .sp-g-scroll .sp-g-header .sp-g-cell {
        min-width: 100px !important;
        max-width: max-content !important;
        width: 100px !important;
    }*/

    .sp-g-scroll .sp-g-row .sp-g-cell {
        white-space: normal;
    }

    .sp-g-scroll .sp-grid-row, .sp-g-scroll .sp-g-row,
    .sp-g-scroll .sp-grid-header, .sp-g-scroll .sp-g-header,
    .sp-g-scroll .sp-grid-footer, .sp-g-scroll .sp-g-footer {
        flex-wrap: nowrap;
        width: fit-content;
        width: -moz-fit-content;
    }

/*Mobile framework*/
/*sm : 0-599dp // Small screen / phone
  st: 600-904  // Medium screen / tablet
  sp: 905-1439 // Large screen / desktop - default platform
  sx: +1439    // Extra large screen / wide desktop
*/
.sm-c-1 {
}
/*Responsive Grid*/
/*scroll-collapse-tcollapse-crop-toggle-step*/
@media screen and (max-width: 40em) {

    /*collapse*/
    .sp-g-tcollapse .sp-g-header .sp-g-cell {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        width: 100% !important;
        min-width: 98vw !important;
        max-width: 99vw !important;
        text-align: center;
    }

    .sp-g-tcollapse .sp-g-cell a {
        text-align: center;
    }

    .sp-g-tcollapse .sp-grid-row .sp-grid-cell,
    .sp-g-tcollapse .sp-g-row .sp-g-cell {
        width: 100% !important;
        max-width: 100% !important;
        min-width: auto !important;
    }

    .sp-g-tcollapse .sp-g-row .sp-g-cell {
        margin-top: 0;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        border: 1px solid var(--line);
    }

    .sp-g-tcollapse .sp-grid-header .sp-grid-cell,
    .sp-g-tcollapse .sp-g-header .sp-g-cell {
        border: 1px solid var(--line);
    }

    .sp-g-tcollapse .sp-grid-row,
    .sp-g-tcollapse .sp-g-row {
        margin: 3rem 0 0;
    }
    /*collapse*/
    .sp-g-collapse .sp-grid,
    .sp-g-collapse .sp-g {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
    }

    .sp-g-collapse .sp-grid-row .sp-grid-cell,
    .sp-g-collapse .sp-g-row .sp-g-cell {
        white-space: normal;
    }

    .sp-g-collapse .sp-grid-row .sp-grid-cell,
    .sp-g-collapse .sp-g-row .sp-g-cell {
        border-right: 0;
    }

    .sp-g-collapse .sp-grid-header .sp-grid-cell,
    .sp-g-collapse .sp-g-header .sp-g-cell {
        border-right: 0;
    }

    .sp-g-collapse .sp-grid-cell a,
    .sp-g-collapse .sp-g-cell a {
        text-align: center;
    }
    /*grid crop*/
    .sp-g-crop .sp-g-header .sp-g-cell:nth-child(1),
    .sp-g-crop .sp-g-header .sp-g-cell:nth-child(2),
    .sp-g-crop .sp-g-header .sp-g-cell:nth-child(3),
    .sp-g-crop .sp-g-header .sp-g-cell:last-child {
        display: block !important;
    }

    .sp-g-crop .sp-g-header .sp-g-cell {
        display: none;
    }

    .sp-g-crop .sp-g-row .sp-g-cell:nth-child(1),
    .sp-g-crop .sp-g-row .sp-g-cell:nth-child(2),
    .sp-g-crop .sp-g-row .sp-g-cell:nth-child(3),
    .sp-g-crop .sp-g-row .sp-g-cell:last-child {
        display: block !important;
    }

    .sp-g-crop .sp-grid-row .sp-grid-cell,
    .sp-g-crop .sp-g-row .sp-g-cell {
        display: none;
    }

    .sp-g-crop .sp-grid-header,
    .sp-g-crop .sp-g-header {
        flex-wrap: nowrap;
    }

    .sp-g-crop .sp-grid-row,
    .sp-g-crop .sp-g-row {
        flex-wrap: nowrap;
    }

    .sp-g-crop .sp-grid-cell a,
    .sp-g-crop .sp-g-cell a {
        text-align: center;
    }
    /*expend*/
    .sp-g-expend .sp-g-header .sp-g-cell:nth-child(1),
    .sp-g-expend .sp-g-header .sp-g-cell:nth-child(2),
    .sp-g-expend .sp-g-header .sp-g-cell:last-child {
        display: block !important;
    }

    .sp-g-expend .sp-g-header .sp-g-cell {
        display: none;
    }

    .sp-g-expend .sp-g-row .sp-g-cell:nth-child(1),
    .sp-g-expend .sp-g-row .sp-g-cell:nth-child(2),
    .sp-g-expend .sp-g-row .sp-g-cell:last-child {
        display: block !important;
    }

    .sp-g-expend .sp-grid-row .sp-grid-cell,
    .sp-g-expend .sp-g-row .sp-g-cell {
        display: none;
    }

    .sp-g-expend .sp-grid-header,
    .sp-g-expend .sp-g-header {
        flex-wrap: nowrap;
    }

    .sp-g-expend .sp-grid-row,
    .sp-g-expend .sp-g-row {
        flex-wrap: nowrap;
    }

    .toggleshow .sp-p-3 {
        display: block;
    }
    /*grid toogle*/
    .sp-g-toggle .sp-g-header .sp-g-cell:nth-child(1),
    .sp-g-toggle .sp-g-header .sp-g-cell:nth-child(2),
    .sp-g-toggle .sp-g-header .sp-g-cell:nth-child(3) {
        display: block !important;
    }

    .sp-g-toggle .sp-g-row .sp-g-cell:not(:nth-child(1)):not(:nth-child(2)):not(:nth-child(3)) {
        background: red;
        opacity: 1;
    }

    .sp-g-toggle .sp-grid-row,
    .sp-g-toggle .sp-g-row {
        flex-wrap: nowrap;
    }

    .sp-g-toggle .sp-grid-header,
    .sp-g-toggle .sp-g-header {
        flex-wrap: nowrap;
    }

        .sp-g-toggle .sp-g-header .sp-g-cell {
            display: none;
        }

    .sp-g-toggle .sp-g-row .sp-g-cell:nth-child(1),
    .sp-g-toggle .sp-g-row .sp-g-cell:nth-child(2),
    .sp-g-toggle .sp-g-row .sp-g-cell:nth-child(3) {
        display: block !important;
    }

    .sp-g-toggle .sp-grid-row .sp-grid-cell,
    .sp-g-toggle .sp-g-row .sp-g-cell {
        display: none;
    }

    .sp-g-toggle .sp-grid-cell a,
    .sp-g-toggle .sp-g-cell a {
        text-align: center;
    }

    /*step grid*/
    .sp-g-step .sp-g-header .sp-g-cell:nth-child(1),
    .sp-g-step .sp-g-header .sp-g-cell:nth-child(2) {
        display: block !important;
    }


    .sp-g-step .sp-grid-row,
    .sp-g-step .sp-g-row {
        flex-wrap: nowrap;
    }

    .sp-g-step .sp-grid-header,
    .sp-g-step .sp-g-header {
        flex-wrap: nowrap;
    }

        .sp-g-step .sp-g-header .sp-g-cell {
            display: none;
        }

    .sp-g-step .sp-g-row .sp-g-cell:nth-child(1),
    .sp-g-step .sp-g-row .sp-g-cell:nth-child(2) {
        display: block !important;
    }

    .sp-g-step .sp-grid-row .sp-grid-cell,
    .sp-g-step .sp-g-row .sp-g-cell {
        display: none;
    }

    .sp-g-step .sp-grid-cell a,
    .sp-g-step .sp-g-cell a {
        text-align: center;
    }
}
/*paging*/
.sp-paging {
    clear: both;
    border: 1px solid var(--line);
    white-space: normal;
    border-radius: 4px;
    border-radius: var(--radius);
    /*margin: 0.25%;*/
}

.sp-paging-row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    flex: 0 1 auto;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-basis: 100%;
    border-top: none;
    color: var(--label);
    text-align: center;
    -webkit-justify-content: center;
    justify-content: center;
    min-height: 35px;
}

.sp-paging-item {
    margin-top: 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    border-right: 1px solid var(--line);
    vertical-align: top;
    box-sizing: border-box;
    padding: .5rem .5rem;
}

    .sp-paging-item:first-child {
        border-right: none;
    }

.sp-paging-select {
    background-color: var(--select);
}

/*dialog*/
.sp-dialog-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.75);
    z-index: 69999;
    display: none;
}

.sp-dialog {
    position: absolute;
    background-color: var(--bgcolor);
    width: 450px;
    top: 2%;
    left: 1%;
    display: none;
    z-index: 70000;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
    box-shadow: 0 0 16px 0 black;
    max-width: 95%;
}

    .sp-dialog .sp-main-loading {
        padding-top: 2rem;
        text-align: center;
        font-size: 24px;
        font-weight: 500;
    }

.sp-dialog-base {
    height: 100%;
    max-width: 100%;
    overflow: auto;
    vertical-align: top;
}

.sp-dialog-main {
    padding-top: 15px;
    background-color: var(--bgcolor);
    color: #343434;
    font-weight: normal;
    border-radius: 10px 10px 0 0;
    margin: 4px;
    padding: 4px;
    vertical-align: top;
    overflow: auto;
    height: 98%;
    height: calc(100% - 8px);
}


.sp-dialog-button {
    position: absolute;
    right: -15px;
    top: -15px;
}

    .sp-dialog-button img {
        width: 30px;
        height: 30px;
    }

.sp-auto {
    max-width: none;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    flex: auto;
}

.sp-content {
    max-width: none;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    flex-basis: 0;
    padding-right: 5px;
    padding-left: 5px;
}


.sp-bar {
    width: 100%;
    overflow: hidden;
}

    .sp-bar .sp-bar-item {
        padding: 8px 16px;
        float: left;
        width: auto;
        border: none;
        display: block;
        outline: 0;
    }

.sp-bar-panel {
    display: none;
}

/*divitions*/
.sp-d-form, .sp-d-section, .sp-d-division, .sp-d-frame, .sp-d-grid, .sp-d-card,
.sp-d-buttons, .sp-d-set, .sp-d-group, .sp-d-list, .sp-d-menu, .sp-d-portlet,
.sp-d-tab, .sp-d-table, .sp-d-accordion, .sp-d-banner, .sp-d-clock, .sp-d-gauge,
.sp-d-chart, .sp-d-tree, .sp-d-board {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex: 1 1 auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-section {
}

.sp-section-body {
    width: 100%;
}

.sp-section-paging {
    width: 100%;
}

.sp-frame {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
}

.sp-iframe {
    padding: 0;
    margin: 0;
    border: 1px solid var(--line);
    border-radius: 4px;
}
/*form - page*/
.sp-form, .sp-f, .sp-p {
    clear: both;
    display: block;
    background-color: var(--context);
    border-spacing: 0;
    margin: 0.25%;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-form-row::before, .sp-f-row::before, .sp-p-row::before {
    margin: 0;
    padding: 0;
    display: none;
}

.sp-form-row, .sp-f-row, .sp-p-row {
    margin: 0;
    padding: 0;
    border-bottom: 1px solid var(--lighthover);
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    direction: ltr;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
}

    .sp-form-row::after, .sp-f-row::after, .sp-p-row::after {
        margin: 0;
        padding: 0;
        display: none;
    }

    .sp-form-row:last-child, .sp-f-row:last-child, .sp-p-row:last-child {
        border: none;
    }

.sp-form-title, .sp-f-title, .sp-p-title {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    text-align: right;
    width: 150px;
    padding: 0;
    padding-bottom: 2px;
    padding-top: 10px;
    margin-top: 0;
    padding-right: 5px;
    padding-left: 5px;
    font-size: 0.9em;
    border: none;
    color: var(--label);
    vertical-align: top;
    box-sizing: border-box;
    font-weight: 400;
}

.sp-form-editor, .sp-f-editor, .sp-p-editor {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
    width: calc(100% - 150px);
    padding-top: 5px;
    padding-bottom: 5px;
    text-align: left;
    color: var(--label);
    box-sizing: border-box;
    vertical-align: top;
}

.sp-form-detail, .sp-f-detail {
    float: left;
}

.sp-form-row2, .sp-f-row2 {
    width: 50%;
    white-space: normal;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    min-width: 250px;
    min-height: 45px;
    box-sizing: border-box;
    vertical-align: top;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    border-bottom: 1px solid var(--lighthover);
}

    .sp-form-row2 .sp-form-title, .sp-f-row2 .sp-f-title, .sp-p-row2 .sp-f-title {
        width: 150px;
        padding-left: 5px;
    }

    .sp-form-row2 .sp-form-editor, .sp-f-row2 .sp-f-editor, .sp-p-row2 .sp-f-editor {
        width: 100%;
        width: calc(100% - 150px);
    }

.sp-form-row3, .sp-f-row3, .sp-p-row3 {
    width: 33.333%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    border-bottom: 1px solid var(--lighthover);
}

    .sp-form-row3 .sp-form-title, .sp-f-row3 .sp-f-title {
        width: 150px;
    }

    .sp-form-row3 .sp-form-editor, .sp-f-row3 .sp-f-editor {
        width: 100%;
        width: calc(100% - 150px);
    }

.sp-form-row4, .sp-f-row4, .sp-p-row4 {
    width: 25%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    border-bottom: 1px solid var(--lighthover);
}

    .sp-form-row4 .sp-form-title, .sp-f-row4 .sp-f-title, .sp-p-row4 .sp-f-title {
        width: 150px;
    }

    .sp-form-row4 .sp-form-editor, .sp-f-row4 .sp-f-editor, .sp-p-row4 .sp-f-editor {
        width: 100%;
        width: calc(100% - 150px);
    }

.sp-form-editor label, .sp-f-editor label {
    color: var(--label);
    display: block;
    padding: 0;
    font-size: 11px;
    margin-top: 5px;
}


.sp-f-input, .sp-f-text, .sp-f-select, .sp-f-textarea {
    font: normal 13px;
    font-family: var(--font-primary);
    resize: none;
    direction: ltr;
    vertical-align: top;
    border-radius: 4px;
    border-radius: var(--radius);
    border: 1px solid silver;
    padding: 4px;
    margin: 4px;
}

/* Chrome/Opera/Safari */
.sp-form input::placeholder, .sp-form input::-webkit-input-placeholder, .sp-form input::-moz-placeholder,
.sp-form input:-ms-input-placeholder, .sp-form input:-moz-placeholder {
    font-family: var(--font-primary);
    color: #999;
    opacity: 0.8;
}

.sp-f input::placeholder, .sp-f input::-webkit-input-placeholder, .sp-f input::-moz-placeholder,
.sp-f input:-ms-input-placeholder, .sp-f input:-moz-placeholder {
    font-family: var(--font-primary);
    color: #999;
    opacity: 0.8;
}


.sp-form textarea, .sp-f textarea {
    resize: both;
    vertical-align: top;
}

    .sp-form input:disabled, .sp-form select:disabled, .sp-form textarea:disabled, .sp-form button:disabled,
    .sp-f input:disabled, sp-f select:disabled, .sp-f textarea:disabled, .sp-f button:disabled,
    .sp-f .sp-select:disabled, .sp-form .sp-select:disabled, .sp-f .sp-drop:disabled, .sp-form .sp-drop:disabled,
    .sp-form-input:disabled, .sp-form-select:disabled, .sp-form-textarea:disabled, .sp-form-button:disabled,
    .sp-f-input:disabled, sp-f-select:disabled, .sp-f-textarea:disabled, .sp-f-button:disabled {
        background-color: var(--line);
    }

    .sp-form input:read-only, .sp-form select:read-only, .sp-form textarea:read-only,
    .sp-f input:read-only, sp-f select:read-only, .sp-f textarea:read-only,
    .sp-form-input:read-only, .sp-form-select:read-only, .sp-form-textarea:read-only,
    .sp-f-input:read-only, sp-f-select:read-only, .sp-f-textarea:read-only {
        background-color: #faeea7;
    }

.sp-f .sp-select:read-only .sp-select-input, .sp-form .sp-select:read-only .sp-select-input {
    background-color: #faeea7;
}

.sp-f .sp-drop:read-only .sp-drop-show, .sp-form .sp-drop:read-only .sp-drop-show {
    background-color: #faeea7;
}

.sp-form input:focus, .sp-f input:focus, .sp-form select:focus, .sp-f select:focus,
.sp-form textarea:focus, .sp-f textarea:focus, .sp-form .sp-drop:focus, .sp-f .sp-drop:focus,
.sp-form .sp-select:focus, .sp-f .sp-select:focus {
    border: 1px solid var(--lineselect);
}

.sp-form input[type=button], .sp-form input[type=submit], .sp-form button,
.sp-f input[type=button], .sp-f input[type=submit], .sp-f button,
.sp-f-button, .sp-f-submit {
    height: 30px;
    min-height: 30px;
    display: inline-block;
    font-weight: bold;
    outline: none;
    cursor: pointer;
    margin: 2px;
    background-color: var(--secondary);
    border-radius: 4px;
    border-radius: var(--radius);
    color: var(--white);
    text-align: center;
    border: 1px solid var(--primary);
    width: fit-content;
}

    .sp-form input[type=button]:hover, .sp-form input[type=submit]:hover, .sp-form button:hover,
    .sp-f input[type=button]:hover, .sp-f input[type=submit]:hover, .sp-f button:hover,
    .sp-f-button:hover, .sp-f-submit:hover {
        background-color: var(--dark);
        -webkit-transition-duration: 0.4s;
        transition-duration: 0.4s;
    }

.sp-form input[type=text]:hover, .sp-form input[type=password]:hover,
.sp-form input[type=number]:hover, .sp-form textarea:hover,
.sp-f input[type=text]:hover, .sp-f input[type=password]:hover,
.sp-f input[type=number]:hover, .sp-f textarea:hover,
.sp-form-text:hover, .sp-f-text:hover {
    -webkit-transition: background .3s ease;
    transition: background .3s ease;
    box-shadow: 1px 1px 1px var(--line);
}

.sp-form input[type=text]:focus, .sp-form input[type=password]:focus,
.sp-form input[type=number]:focus, .sp-form textarea:focus {
    background-color: #ccecf3;
    border: 1px solid #0176C3;
    box-shadow: 1px 1px 1px var(--line);
    color: black;
}

.sp-form input[type=text], .sp-form input[type=password], .sp-form input[type=number], .sp-form textarea,
.sp-f input[type=text], .sp-f input[type=password], .sp-f input[type=number], .sp-f textarea,
.sp-f-input, .sp-f-password, .sp-f-number, .sp-f-textarea {
    position: relative;
    width: 97%;
    width: calc(100% - 10px);
    min-height: 30px;
    margin: 2px;
    padding: 2px 4px;
    line-height: 1.2;
    color: #6f849a;
    background-color: var(--white);
    background-image: none;
    border: 1px solid var(--line);
    border-radius: 4px;
    -webkit-transition: border-color ease-in-out 0.15s, -webkit-box-shadow ease-in-out 0.15s;
    transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
    -webkit-user-select: text;
    user-select: text;
}


.sp-form input[data-type="date"] :before,
.sp-f input[data-type="date"] :before {
    position: absolute;
    background: none;
    display: block;
    font-family: 'fontAwesome';
    content: '\f073';
    /* This is the calendar icon in FontAwesome */
    width: 15px;
    height: 20px;
    top: 12px;
    right: 6px;
    color: #999;
}

.sp-form select, .sp-f select,
.sp-form-select, .sp-f-select {
    width: 97%;
    width: calc(100% - 10px);
    height: 30px;
    padding: 2px 4px;
    line-height: 1.2;
    color: #6f849a;
    background-color: var(--context);
    border: 1px solid var(--line);
    border-radius: 4px;
    border-radius: var(--radius);
    -webkit-transition: border-color ease-in-out 0.15s, -webkit-box-shadow ease-in-out 0.15s;
    transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
}

    .sp-form select:hover, .sp-f select:focus {
        box-shadow: 1px 1px 1px var(--line);
        background-color: #ccecf3;
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
    }

.sp-form .sp-validated, .sp-form .sp-valid,
.sp-f .sp-validated, .sp-f .sp-valid {
    border-color: #34a853 !important;
    padding-right: 1rem !important;
    background-repeat: no-repeat;
    background-position: center right calc(1.966971rem / 4) !important;
    background-size: calc(1.966971rem / 2) calc(1.966971rem / 2) !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%2334a853' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e") !important;
}

    .sp-form .sp-validated:focus, .sp-form .sp-valid:focus,
    .sp-f .sp-validated:focus, .sp-f .sp-valid:focus {
        background-image: inherit !important;
    }

.sp-form .sp-invalidated, .sp-form .sp-invalid,
.sp-f .sp-invalidated, .sp-f .sp-invalid {
    /*border-color: #ea4335 !important;*/
    padding-right: 1rem !important;
    background-repeat: no-repeat;
    background-position: center right calc(1.966971rem / 4) !important;
    background-size: calc(1.966971rem / 2) calc(1.966971rem / 2) !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23ea4335' viewBox='-2 -2 7 7'%3e%3cpath stroke='%23d9534f' d='M0 0l3 3m0-3L0 3'/%3e%3ccircle r='.5'/%3e%3ccircle cx='3' r='.5'/%3e%3ccircle cy='3' r='.5'/%3e%3ccircle cx='3' cy='3' r='.5'/%3e%3c/svg%3E") !important;
}

    .sp-form .sp-invalidated:focus, .sp-form .sp-invalid:focus,
    .sp-f .sp-invalidated:focus, .sp-f .sp-invalid:focus {
        background-image: inherit !important;
    }

.sp-form .sp-form-message, .sp-f .sp-f-message {
    color: var(--danger);
    display: none;
    margin-left: 150px;
}

.sp-form .sp-invalidated .sp-form-message, .sp-f .sp-invalidated .sp-f-message {
    display: block;
}

.sp-form .sp-form-important, .sp-f .sp-f-important,
.sp-form .sp-important, .sp-f .sp-important {
    position: absolute;
    color: #fc5f5f;
    padding-right: 2px;
    padding-left: 2px;
    top: 0;
    left: 0;
}

.sp-f-number {
    direction: ltr !important;
}

.sp-f-buttons {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    align-items: flex-start;
    flex: 0 0 auto;
    flex-direction: row;
    flex-wrap: wrap;
}

.sp-f-group {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
    width: 100%;
}

    .sp-f-group > .sp-f-file, .sp-f-group > .sp-f-select,
    .sp-f-group > .sp-f-input, .sp-f-group > .sp-f-widget {
        position: relative;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
        flex: 1 1 auto;
        width: 1% !important;
        margin-bottom: 0;
    }

.sp-f-append, .sp-f-prepend {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.sp-form-result, .sp-f-result {
    border: none;
    background: none;
    box-shadow: none;
    outline: none;
}

/*radio and checkbox*/
.sp-form-check, .sp-f-check,
.sp-form-radio, .sp-f-radio {
    position: relative;
    display: inline-block;
    margin: 4px 10px !important;
    cursor: pointer;
    webkit-transition: all .3s;
    -moz-transition: all .3s;
    -ms-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
    -ms-transform: scale(1) !important;
    -moz-transform: scale(1) !important;
    -webkit-transform: scale(1) !important;
    -o-transform: scale(1) !important;
    max-width: 1rem;
    max-height: 1rem;
}

    .sp-form-check:before, .sp-f-check:before, .sp-form-radio:before, .sp-f-radio:before,
    .sp-form-check:after, .sp-f-check:after, .sp-form-radio:after, .sp-f-radio:after {
        position: absolute;
        content: '';
        display: block;
        z-index: 1;
        border-radius: 4px;
    }

    .sp-form-check:before, .sp-f-check:before,
    .sp-form-radio:before, .sp-f-radio:before {
        top: -3px;
        left: calc(50% - 0.5rem);
        height: 1rem;
        width: 1rem;
        border: 1px solid var(--line);
        background-color: #fff;
    }

    .sp-form-check:indeterminate:before, .sp-f-check:indeterminate:before {
        border: 1px solid var(--line);
    }

    .sp-form-check:indeterminate:after, .sp-f-check:indeterminate:after {
        left: 0.5px;
        top: -2px;
        display: inline-block;
        height: 1rem;
        border-bottom: 2px solid var(--line);
        border-radius: 1px;
    }

    .sp-form-radio:before, .sp-f-radio:before {
        -ms-border-radius: 50% !important;
        -o-border-radius: 50% !important;
        border-radius: 50% !important;
    }

    .sp-form-radio:checked:after, .sp-f-radio:checked:after {
        left: 4px;
        top: 4px;
        height: 6px;
        width: 6px;
        border-radius: 100% !important;
        background: #888
    }

    .sp-form-check:checked:after, .sp-f-check:checked:after {
        left: 4px;
        top: 0px;
        width: 5px;
        height: 10px;
        border: 2px solid #888;
        border-width: 0 2px 2px 0;
        transform: rotate(45deg);
    }

    .sp-form-check:indeterminate:after, .sp-f-check:indeterminate:after {
        left: 1px;
        top: 4px;
        width: 10px;
        height: 2px;
        border: 2px solid #aaa;
    }

    .sp-form-check[disabled]:before, .sp-f-check[disabled]:before,
    .sp-form-radio[disabled]:before, .sp-f-radio[disabled]:before {
        background-color: silver;
        cursor: not-allowed
    }

/*switch*/
.sp-form-switch, .sp-f-switch {
    position: relative;
    display: inline-block;
    width: 60px;
    height: 28px;
}

    .sp-form-switch:before, .sp-f-switch:before {
        position: absolute;
        content: "";
        cursor: pointer;
        top: 0;
        left: 0;
        width: 60px;
        height: 28px;
        background-color: var(--line);
        -webkit-transition: .4s;
        transition: .4s;
        border-radius: 34px;
        border: 1px solid var(--verylight);
    }

    .sp-form-switch:after, .sp-f-switch:after {
        position: absolute;
        content: "";
        top: 4px;
        height: 20px;
        width: 20px;
        left: 4px;
        bottom: 4px;
        background-color: var(--white);
        -webkit-transition: .4s;
        transition: .4s;
        border-radius: 50%;
    }

    .sp-form-switch:checked:before, .sp-f-switch:checked:before {
        background-color: var(--light);
    }

    .sp-form-switch:checked:after, .sp-f-switch:checked:after {
        background-color: var(--white);
        left: 35px;
    }

    .sp-form-switch:focus, .sp-f-switch input:focus {
        box-shadow: 0 0 1px var(--light);
    }

.sp-f-note {
    margin-left: 150px;
    color: var(--line);
}

.sp-f-flat .sp-f-note {
    margin: 0px;
    color: var(--line);
}

/*Triple*/
.sp-f-triple {
    position: relative;
    display: inline-block;
    background: var(--bgcolor);
    border-radius: 34px;
    border: 1px solid var(--verylight);
    width: 75px;
    height: 28px;
    padding-top: 4px;
}

    .sp-f-triple .sp-f-item {
        display: inline-block;
        background-image: url(/themes/base/Images/AllowDeny.png);
        background-repeat: no-repeat;
        background-size: 60px;
    }

    .sp-f-triple .sp-f-true {
        width: 20px;
        height: 20px;
        background-position: 0px;
    }

    .sp-f-triple .sp-f-null {
        width: 20px;
        height: 20px;
        background-position: -20px;
    }

    .sp-f-triple .sp-f-false {
        width: 20px;
        height: 20px;
        background-position: -40px;
    }

    .sp-f-triple .sp-f-active {
        background-color: var(--light);
        border-radius: 50%;
    }

/*Fixed*/
.sp-form-fixed, .sp-f-fixed {
    position: fixed;
    bottom: 70px;
    left: -27px;
    min-width: 20px !important;
    border: 1px solid var(--dark);
    box-shadow: 0 1px 2px #6e7a84;
    border-left: none;
    box-sizing: border-box;
    background-color: var(--primary);
    z-index: 10000;
    padding-right: 10px;
    border-radius: 0;
    border-radius: 0 10px 10px 0;
    padding-top: 5px;
    padding-bottom: 5px;
    -webkit-transition: .4s;
    transition: .4s;
}

    .sp-form-fixed:hover, .sp-f-fixed:hover {
        left: 0;
    }

    .sp-form-fixed img, .sp-f-fixed img {
        width: 30px;
        padding: 2px;
        display: block;
    }

.sp-ltr .sp-form-row, .sp-ltr .sp-f-row, .sp-ltr .sp-p-row {
    direction: ltr !important;
}

.sp-ltr .sp-form-row2, .sp-ltr .sp-f-row2, .sp-ltr .sp-p-row2 {
    direction: ltr !important;
}

.sp-ltr .sp-form-row3, .sp-ltr .sp-f-row3, .sp-ltr .sp-p-row3 {
    direction: ltr !important;
}

.sp-ltr .sp-form-title, .sp-ltr .sp-f-title {
    text-align: right;
    padding-right: 5px;
    padding-left: 5px;
}

.sp-ltr .sp-form-editor, .sp-ltr .sp-f-editor {
    text-align: left;
}

.sp-f-warning {
    background-image: url(/themes/base/Images/warning.png);
    background-repeat: no-repeat;
    background-size: 20px;
}
/*Flat Form*/
.sp-form-flat, .sp-f-flat {
    padding: 0 3%;
}

    .sp-form-flat .sp-form-row, .sp-f-flat .sp-f-row,
    .sp-f-flat .sp-form-row, .sp-f-flat .sp-f-row {
        border: none;
    }

    .sp-form-flat .sp-form-title, .sp-f-flat .sp-f-title,
    .sp-f-flat .sp-form-title, .sp-f-flat .sp-f-title {
        text-align: left;
        padding: 0;
        width: 100%;
    }

    .sp-form-flat .sp-form-editor, .sp-f-flat .sp-f-editor,
    .sp-f-flat .sp-form-editor, .sp-f-flat .sp-f-editor {
        width: 97%;
        width: calc(100% - 10px);
        padding-top: 0;
        padding-bottom: 10px;
    }

    .sp-form-flat .sp-form-row2 .sp-form-editor, .sp-f-flat .sp-f-row2 .sp-f-editor,
    .sp-f-flat .sp-form-row2 .sp-form-editor, .sp-f-flat .sp-f-row2 .sp-f-editor {
        width: 95%;
    }

/*Matrial Form*/
.sp-form-material, .sp-f-material {
    padding: 0 3%;
}

    .sp-form-material .sp-form-row, .sp-f-mateial .sp-f-row,
    .sp-f-material .sp-form-row, .sp-f-material .sp-f-row {
        border: none;
    }

    .sp-form-material .sp-form-title, .sp-f-mateial .sp-f-title,
    .sp-f-material .sp-form-title, .sp-f-material .sp-f-title {
        padding: 0;
        width: 100%;
    }

    .sp-form-material .sp-form-editor, .sp-f-mateial .sp-f-editor,
    .sp-f-material .sp-form-editor, .sp-f-material .sp-f-editor {
        border: none;
        width: 97%;
        width: calc(100% - 10px);
        padding-top: 0;
        padding-bottom: 10px;
    }

    .sp-f-material input, .sp-f-material select, .sp-f-material textarea {
        border: none !important;
        border-bottom: 1px solid var(--verylight) !important;
        border-radius: 0 !important;
        box-shadow: none;
    }

        .sp-form-material input:hover, .sp-form-material select:hover, .sp-form-material textarea:hover,
        .sp-f-material input:focus, .sp-f-material select:focus, .sp-f-material textarea:focus {
            border-bottom: 1px solid var(--primary) !important;
            box-shadow: none;
        }

    .sp-form-material .sp-form-row2 .sp-form-editor, .sp-f-mateial .sp-f-row2 .sp-f-editor,
    .sp-f-material .sp-form-row2 .sp-form-editor, .sp-f-material .sp-f-row2 .sp-f-editor {
        width: 95%;
    }
/*page*/
.sp-p-title {
    font-weight: 600;
}

.sp-p-label {
    border: 1px solid var(--linelight);
    padding: 1px 5px;
    border-radius: 4px;
    min-height: 22px;
}

/*Flat pgae*/
.sp-p-flat {
    padding: 0 3%;
    margin-top: 10px;
}

    .sp-p-flat .sp-p-row {
        border: none;
        margin-bottom: 10px;
    }

    .sp-p-flat .sp-p-title {
        text-align: left;
        padding: 0;
        width: 100%;
    }

    .sp-p-flat .sp-p-editor {
        width: 97%;
        width: calc(100% - 10px);
        padding-top: 0;
        padding-bottom: 10px;
    }

    .sp-p-flat .sp-p-row2 .sp-p-editor, .sp-p-flat .sp-p-row2 .sp-p-editor {
        width: 95%;
    }


/*Buttons*/
.sp-btn {
    display: inline-block;
    padding: 8px 4px;
    vertical-align: middle;
    overflow: hidden;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    white-space: nowrap;
    color: var(--white);
    background-color: var(--light);
    border: 1px solid var(--secondary);
    margin: 0 2px;
    font-family: var(--font-primary);
    padding-right: 34px;
    background: url(/themes/base/images/white/Action.png) no-repeat var(--light) 90%;
    background-size: 20px 20px;
    width: fit-content;
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-btn span, .sp-btn span {
        color: var(--white);
        float: left;
        margin: 4px;
        padding-right: 10px;
    }

.sp-btn-clean {
    display: inline-block;
    padding: 8px 4px;
    vertical-align: middle;
    overflow: hidden;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    white-space: nowrap;
    color: var(--white);
    background-color: var(--light);
    border: 1px solid var(--secondary);
    margin: 0 2px;
    font-family: var(--font-primary);
    width: fit-content;
    border-radius: 4px;
    border-radius: var(--radius);
    min-height: 35px;
}

.sp-btn-small {
    font-size: 0;
    min-width: 33px !important;
    background-position-x: 50% !important
}

.sp-btn-save {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/save.png) no-repeat var(--light) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-btn-save:hover {
        border-color: #168a73;
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
    }

    .sp-btn-save:focus {
        background-color: var(--selected);
    }

.sp-btn-delete {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: red;
    background: url(/themes/base/images/white/delete.png) no-repeat var(--dark) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-btn-delete:hover {
        border-color: #168a73;
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
    }

.sp-btn-clean {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    background: url(/themes/base/images/white/clean.png) no-repeat var(--dark) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-btn-clean:hover {
        border-color: #168a73;
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
    }

.sp-btn-new {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    background: url(/themes/base/images/white/new.png) no-repeat var(--dark) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-btn-new:hover {
        border-color: #168a73;
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
    }

.sp-btn-edit {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/edit.png) no-repeat var(--dark) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-btn-edit:hover {
        border-color: #168a73;
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
    }

.sp-btn-cancel {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    background: url(/themes/base/images/white/cancel.png) no-repeat #D8DCEB 90%;
    background-size: 20px 20px;
    color: #707077;
    border: 1px solid var(--line);
    font-weight: 100;
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-btn-cancel .sp-ultra-active {
        color: white !important;
    }

.sp-btn-sort {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    background: url(/themes/base/images/white/sort.png) no-repeat var(--light) 90%;
    background-size: 20px 20px;
    color: #707077;
    border: 1px solid var(--line);
    font-weight: 100;
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-btn-sort .sp-ultra-active {
        color: white !important;
    }

.sp-btn-setting {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    background: url(/themes/base/images/white/setting.png) no-repeat #D8DCEB 90%;
    background-size: 20px 20px;
    color: #707077;
    border: 1px solid var(--line);
    font-weight: 100;
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-btn-setting .sp-ultra-active {
        color: white !important;
    }

.sp-btn-refresh {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    background: url(/themes/base/images/white/refresh.png) no-repeat var(--light) 90%;
    background-size: 20px 20px;
    color: #707077;
    border: 1px solid var(--line);
    font-weight: 100;
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-btn-refresh .sp-ultra-active {
        color: white !important;
    }

.sp-btn-print {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    background: url(/themes/base/images/white/print.png) no-repeat var(--dark) 90%;
    background-size: 20px 20px;
    font-weight: 100;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-search {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    background: url(/themes/base/images/white/search.png) no-repeat var(--dark) 90%;
    background-size: 20px 20px;
    font-weight: 100;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-export {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/export.png) no-repeat var(--dark) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-preview {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/preview.png) no-repeat var(--dark) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-filter {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/Filter.png) no-repeat var(--light) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-star {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/favorite.png) no-repeat var(--light) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-class {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/class.png) no-repeat var(--light) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-chart {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/chart.png) no-repeat var(--light) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-visible {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/visible.png) no-repeat var(--light) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-hidden {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/hidden.png) no-repeat var(--light) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-undo {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/undo.png) no-repeat var(--verylight) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-redo {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    border-color: green;
    background: url(/themes/base/images/white/redo.png) no-repeat var(--verylight) 90%;
    background-size: 20px 20px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-zoomin {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    background: url(/themes/base/images/white/print.png) no-repeat var(--dark) 90%;
    background-size: 20px 20px;
    font-weight: 100;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-btn-zoomout {
    min-height: 35px;
    min-width: 100px;
    padding-right: 34px;
    background: url(/themes/base/images/white/print.png) no-repeat var(--dark) 90%;
    background-size: 20px 20px;
    font-weight: 100;
    border-radius: 4px;
    border-radius: var(--radius);
}

/*upload*/
.sp-upload {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    min-height: 100px;
}

.sp-upload-header {
    position: absolute;
    height: 30px;
    width: 100%;
    background-color: rgb(112 112 119 / 0.24);
    text-align: center;
}

.sp-upload-body {
    max-height: 150px;
    width: 100%;
    background-color: rgb(112 112 119 / 0.24);
    text-align: center;
}

.sp-upload-image {
    max-width: 100%;
    max-height: 150px;
}

.sp-upload-hover {
    position: absolute;
    display: none;
    height: 30px;
    width: 100%;
    background-color: rgb(112 112 119 / 0.24);
    bottom: 0;
}

.sp-upload:hover .sp-upload-hover {
    display: block;
}

.sp-upload-button {
    display: inline-block;
    width: 25%;
    text-align: center;
}

.sp-upload-icon {
    width: 24px;
}
/*widget-picker*/
.sp-widget {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}

.sp-widget-picker {
    position: fixed;
    display: none;
    background: var(--white);
    z-index: 20;
    z-index: var(--pickerIndex);
    border: 1px solid var(--line);
    border-radius: 4px;
    width: 17em;
    padding: 0.2em 0 0.2em 0;
    display: none;
}

.sp-widget-show .sp-widget-picker {
    display: block;
}

.sp-widget-left .sp-widget-picker {
    left: 0 !important;
    right: auto;
}

.sp-widget-right .sp-widget-picker {
    right: 0 !important;
    left: auto;
}

.sp-widget-top .sp-widget-picker {
    bottom: 0;
    top: auto;
}

.sp-widget-bottom .sp-widget-picker {
    top: 32px;
    bottom: auto;
}

.sp-widget-item {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding: 4px 1em 4px .4em;
    cursor: pointer;
    min-height: 20px;
    -webkit-transition: background .3s ease;
    transition: background .3s ease;
}

    .sp-widget-item:hover, .sp-widget-active {
        background-color: var(--select);
    }
/*dropdown*/
.sp-drop {
    position: relative;
    width: 100% !important;
    text-align: right;
    white-space: nowrap;
    display: -webkit-inline-box;
    display: -webkit-inline-flex;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.sp-drop-button {
    position: relative;
    display: block;
    height: 30px;
    width: 100%;
    background-color: white;
    color: black;
    font: normal 13px;
    font-family: var(--font-primary);
    resize: none;
    direction: ltr;
    vertical-align: top;
    border-radius: 4px;
    border-radius: var(--radius);
    border: 1px solid var(--line);
    padding: 4px;
    margin: 4px;
}

    .sp-drop-button:focus {
        box-shadow: 1px 1px 1px var(--line) !important;
        background-color: #ccecf3 !important;
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
    }

    .sp-drop-button img {
        width: 24px;
        float: right;
    }

    .sp-drop-button:after {
        position: absolute;
        display: block;
        width: 0;
        height: 0;
        margin-left: 0.255em;
        vertical-align: 0.255em;
        content: "";
        border-left: 4px solid transparent;
        border-right: 4px solid transparent;
        border-top: 7px solid var(--line);
        right: 4px;
        top: 12px;
    }

.sp-drop-items {
    position: fixed;
    border: 1px solid var(--line) !important;
    width: 100%;
    background: white;
    display: none;
    z-index: 20;
    z-index: var(--pickerIndex);
    padding: 4px;
    border-radius: 0 0 4px 4px;
    overflow: scroll;
    max-height: 250px;
}

    .sp-drop-items li {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        cursor: pointer;
        min-height: 20px;
    }

.sp-drop-item {
    -webkit-transition: background .3s ease;
    transition: background .3s ease;
}

    .sp-drop-item:hover {
        background-color: var(--select);
    }

    .sp-drop-item img {
        width: 24px;
    }

.sp-drop-show .sp-drop-items {
    display: block;
}

.sp-drop-show .sp-drop-button {
    border-radius: 4px 4px 0 0;
}

    .sp-drop-show .sp-drop-button:after {
        border-top: 0;
        transform: rotate(180deg);
        border-left: 4px solid transparent;
        border-right: 4px solid transparent;
        border-top: 7px solid var(--line);
    }

.sp-drop-active {
    background: var(--select);
}

.sp-drop-collapse {
}

    .sp-drop-collapse ul {
        display: none;
    }

.sp-drop-expand {
}

    .sp-drop-expand ul {
        display: block;
    }

.sp-drop-disable {
    cursor: not-allowed !important;
    background-color: var(--disble);
}
/*Select*/
.sp-select {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
}

.sp-select-icon {
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    margin-left: 0.255em;
    vertical-align: 0.255em;
    top: 0.75rem;
    content: "";
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 7px solid var(--dark);
    left: 0.5rem;
    cursor: pointer;
}

.sp-f-select.sp-select-show .sp-select-icon {
    transform: rotate(180deg);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 7px solid var(--dark);
    border-bottom: 0;
}

.sp-select-input {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
}

.sp-select-items {
    position: fixed;
    border: 1px solid var(--line) !important;
    width: 100%;
    background: white;
    display: none;
    z-index: 20;
    z-index: var(--pickerIndex);
    padding: 4px;
    border-radius: 0 0 4px 4px;
    overflow: scroll;
    max-height: 250px;
    box-shadow: 0px 8px 16px 0px rgb(0 0 0 / 20%);
}

    .sp-select-items li {
        cursor: pointer;
        min-height: 20px;
    }

.sp-select-disable {
    cursor: not-allowed !important;
    background-color: var(--disble);
}


.sp-select-show .sp-select-items {
    display: block;
}

.sp-select-show .sp-select:after {
    border-top: 0;
    transform: rotate(180deg);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 7px solid var(--line);
}


/*.sp-select-active {
    background: var(--select);
}*/

.sp-select-active > label, .sp-drop-active > label {
    background: var(--select);
}

.sp-select-nested {
}

    .sp-select-nested i {
        position: absolute;
        width: 10px;
        height: 10px;
        background: var(--white);
        display: inline-block;
        top: 8px;
        z-index: 20;
        z-index: var(--pickerIndex);
        right: 4px;
        border-left: 4px solid transparent;
        border-right: 4px solid transparent;
        border-top: 7px solid var(--dark);
    }

.sp-select-collapse {
}

    .sp-select-collapse ul {
        display: none;
    }

.sp-select-expand {
}

    .sp-select-expand ul {
        display: block;
    }
/* Color */
.sp-color-items {
    padding-top: 4px;
}

.sp-color-item {
    display: inline-block;
    margin: 0 4px 4px 0;
}

.sp-color {
    padding-left: 0;
    width: 24px;
    height: 24px;
    border-radius: 2px;
}

.sp-color-active {
    border: 1px solid;
    border-color: #FFFFFF;
    border-radius: 2px;
    box-shadow: rgba(28, 161, 193, 0.6) 0 0 0 2px;
}
/*Board*/
.sp-board {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    flex-basis: 100%;
    margin-right: -5px;
    margin-left: -5px;
    border-radius: 4px;
}

/*portlet*/
.sp-portlet {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex: auto;
    flex-direction: column;
    margin: .5rem;
    padding: 0;
    border-radius: 4px;
}

.sp-portlet-title, .sp-portlet-header {
    border-bottom: 1px solid #eee;
    padding: 0;
    margin-bottom: 10px;
    min-height: 41px;
    -webkit-border-radius: 4px 4px 0 0;
    -moz-border-radius: 4px 4px 0 0;
    -ms-border-radius: 4px 4px 0 0;
    -o-border-radius: 4px 4px 0 0;
    border-radius: 4px 4px 0 0;
    color: var(--label);
}

.sp-portlet-footer {
    border-top: 1px solid #eee;
    padding: 0;
    padding-top: 10px;
    margin-top: 10px;
    min-height: 41px;
    -webkit-border-radius: 4px 4px 0 0;
    -moz-border-radius: 4px 4px 0 0;
    -ms-border-radius: 4px 4px 0 0;
    -o-border-radius: 4px 4px 0 0;
    border-radius: 4px 4px 0 0;
    color: var(--label);
}

.sp-portlet-body {
    clear: both;
    -webkit-border-radius: 0 0 4px 4px;
    -moz-border-radius: 0 0 4px 4px;
    -ms-border-radius: 0 0 4px 4px;
    -o-border-radius: 0 0 4px 4px;
    border-radius: 0 0 4px 4px;
}

.sp-portlet-option {
    float: right;
}

.sp-portlet-light {
    border: 1px solid var(--linelight) !important;
    padding: 12px 20px 15px;
    background-color: var(--context);
}

    .sp-portlet-light .sp-portlet-title, .sp-portlet-light .sp-portlet-header {
        padding: 0;
        min-height: 48px;
        border-bottom: 1px solid var(--linelight);
        padding-top: 5px;
    }

/*chart*/
.sp-chart-data {
    display: none;
}
/*Card*/
.sp-d-card {
    margin-bottom: 8px;
}

.sp-card {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    border: 1px solid var(--linelight);
    border-radius: .286rem;
    vertical-align: top;
    -webkit-box-shadow: 0 1px 15px 1px rgba(69,65,78,.08);
    -moz-box-shadow: 0 1px 15px 1px rgba(69,65,78,.08);
    box-shadow: 0 1px 15px 1px rgba(69,65,78,.08);
    min-width: 0;
    word-wrap: break-word;
    margin: 0.5% 0.5% 10px 0.5%;
    margin: 4px 4px 8px 4px;
    height: 100%;
    align-items: stretch;
    background-color: var(--context);
}

    .sp-card li {
        display: block;
        text-align: left;
        padding-left: 15px;
        margin-top: 7px;
    }

.sp-card-disabled label {
    color: silver;
}

.sp-card-disabled img {
    filter: alpha(opacity=50);
}

.sp-card-selected {
    background-color: var(--select);
    /*border: 2px solid #c1c1f3;*/
}

.sp-card-finished {
    background-color: var(--success);
}

.sp-card-header {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    font-size: 14px;
    font-weight: 400;
    padding: .75rem 1.25rem;
    text-align: left;
    border-radius: 4px 4px 0 0;
    margin-bottom: 0;
    background-color: var(--lighthover);
    border-bottom: 1px solid var(--linelight);
}

.sp-card-body {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex: 1 1 auto;
    -webkit-flex: 1 1 auto;
    flex: 1 1 auto;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 1rem;
    min-height: 30px;
    display: block;
}

.sp-card-image {
    text-align: center;
    padding: 1rem;
    align-items: stretch;
    height: 100%;
}

    .sp-card-image img {
        width: 100%;
        max-width: 64px;
        max-height: 64px;
    }

.sp-card-footer {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    font-size: 17px;
    text-align: center;
    font-weight: 600;
    padding: .75rem 1.25rem;
    background-color: var(--lighthover);
    border-radius: 0 0 4px 4px;
    border-top: 1px solid var(--linelight);
}

.sp-card-hover img {
    max-width: 35px;
    max-height: 35px;
}

.sp-card-hover {
    position: absolute;
    opacity: 0;
    visibility: hidden;
    top: 0;
    left: 0;
    background-color: rgba(0,0,0,0.2);
    width: 100%;
    padding: 0.2em;
    text-align: center;
    transition: visibility 0s, opacity 0.5s linear;
    z-index: 15;
    z-index: var(--hoverIndex);
}

.sp-card:hover .sp-card-hover {
    opacity: 1;
    visibility: visible;
}

.sp-card-hover-left {
    bottom: 0;
    width: 42px;
}

.sp-card-hover-right {
    right: 0;
    left: auto;
    bottom: 0;
    width: 42px;
}

.sp-card-hover-bottom {
    bottom: 0;
    top: auto;
}

.sp-card-option {
    float: right;
}

.sp-card-item {
    text-align: left;
}

.sp-card-item-title {
    text-align: left;
}

.sp-card-summary {
    text-align: left;
    box-sizing: border-box;
}

.sp-card-summary2 {
    float: right;
    width: 50%;
    box-sizing: border-box;
}

.sp-card-summary-label {
    font-size: 41px;
    text-align: center
}

.sp-card-status {
    background: var(--bg-white);
    border-radius: 2px;
    padding: 25px 18px 18px;
    text-align: center;
    width: 100%;
}

.sp-card-title {
    width: 100%;
}

/*Design*/
.sp-design {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    border-radius: .286rem;
    vertical-align: top;
    overflow: hidden;
    -webkit-box-shadow: 0 1px 15px 1px rgba(69,65,78,.08);
    -moz-box-shadow: 0 1px 15px 1px rgba(69,65,78,.08);
    box-shadow: 0 1px 15px 1px rgba(69,65,78,.08);
    min-width: 0;
    word-wrap: break-word;
    height: 100%;
    align-items: stretch;
    background-color: var(--context);
    width: 100%;
    display: block;
    margin: 0;
    padding: 0;
}

.sp-design-body {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex: 1 1 auto;
    -webkit-flex: 1 1 auto;
    flex: 1 1 auto;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    min-height: 30px;
    border: 1px solid silver;
    border-style: dashed;
    display: block;
}

.sp-design-header,
.sp-design-footer {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex: 1 1 auto;
    -webkit-flex: 1 1 auto;
    flex: 1 1 auto;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    min-height: 30px;
    border: 1px solid silver;
    border-style: dashed;
}

.sp-design-hover {
    position: absolute;
    opacity: 0;
    visibility: hidden;
    left: 0;
    background-color: rgba(255,0,0,0.2);
    width: 100%;
    padding: 0.2em;
    text-align: center;
    transition: visibility 0s, opacity 0.5s linear;
    z-index: 15;
    z-index: var(--hoverIndex);
}

.sp-design-top {
    top: 0;
}

.sp-design-bottom {
    bottom: 0;
}

.sp-design:hover > .sp-design-hover {
    opacity: 1;
    visibility: visible;
}

.sp-design-space {
    width: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    border: 2px solid #5e3d3d;
    border-style: dashed;
}

.sp-design-active {
    border: 1px dashed var(--line);
}
/*accordion*/
.sp-accordion-header {
    background-color: var(--header);
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    flex-basis: 100%;
    padding: 4px;
    border-radius: 4px;
    border-radius: var(--radius);
    text-align: center;
}

.sp-accordion-body {
    padding: 4px;
    border: 1px solid var(--line);
    border-radius: 4px;
    border-radius: var(--radius);
}
/*carousel*/
.sp-carousel {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    overflow: hidden;
    width: 100%;
}

.sp-carousel-slide {
    position: absolute;
    height: calc(100vh - 2rem);
    width: 100%;
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    scroll-behavior: smooth;
}

.sp-carousel-item {
    width: 100%;
    height: 100%;
    flex: 1 0 100%;
}

.sp-carousel-body {
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* Internet Explorer 10+ */
}

    /* WebKit */
    .sp-carousel-body::-webkit-scrollbar {
        width: 0;
        height: 0;
    }

.sp-carousel img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sp-carousel-next, .sp-carousel-prev {
    position: absolute;
    color: var(--dark);
    display: block;
    background-color: var(--lighthover);
    padding: 1rem;
    font-size: 3rem;
    height: 10rem;
    vertical-align: middle;
    line-height: 10rem;
    top: 50%;
    transform: translate3d(0, -50%, 0);
    cursor: pointer;
    z-index: 10;
}

.sp-carousel:hover .sp-carousel-next {
    background-color: var(--lightbg);
}

.sp-carousel:hover .sp-carousel-prev {
    background-color: var(--lightbg);
}

.sp-carousel-next {
    content: "\276D";
    right: 10px;
    border-top-left-radius: 50%;
    border-bottom-left-radius: 50%;
}

.sp-carousel-prev {
    content: "\276C";
    left: 10px;
    border-top-right-radius: 50%;
    border-bottom-right-radius: 50%;
}
/* dropdown-menu*/
.sp-drop-show {
    position: absolute;
    display: none;
}

.sp-drop-show {
    display: block;
}
/*Error Page*/
.sp-error {
    margin: 8px;
    border: 1px dashed var(--light);
    border-radius: 16px;
    background-color: var(--bgcolor);
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
    padding: 32px 8px 32px 8px;
}

.sp-error-row {
    display: block;
    min-height: 24px;
    width: 100%;
}

.sp-error-cell {
    position: relative;
    text-align: center;
    width: 99%;
    margin: auto;
    color: silver;
    font-weight: bold;
    background-color: var(--bgcolor);
    z-index: 2;
}

.sp-error-title {
    color: var(--light);
    font-weight: bold;
    text-transform: uppercase;
    font-size: 2.5em;
    line-height: 120%;
    margin-bottom: 8px;
}

.sp-error-offer {
    padding: 8px;
}

    .sp-error-offer a {
        border: 1px solid var(--light);
        border-radius: 50px;
        display: inline-block;
        width: 150px;
        color: var(--primary);
        padding: 4px;
    }

.sp-error-detail {
    position: relative;
}

    .sp-error-detail img {
        width: 27px;
    }

    .sp-error-detail:before {
        content: '';
        border-bottom: 2px solid var(--light);
        display: inline-block;
        position: absolute;
        top: 12px;
        left: 5px;
        right: 5px;
    }

.sp-error-image {
    width: 100%;
    max-width: 350px;
    max-height: 200px;
}

.sp-logo {
    max-width: 100px;
    max-height: 100px;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-logo-small {
    max-width: 50px;
    max-height: 50px;
    border-radius: 2px;
}


.sp-logo-large {
    max-width: 150px;
    max-height: 150px;
    border-radius: 7px;
}

.sp-icon-small, .sp-i-small, .sp-is {
    max-width: 16px !important;
    max-height: 16px;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.sp-icon-medium, .sp-i-medium, .sp-im {
    max-width: 20px !important;
    max-height: 20px;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.sp-icon {
    max-width: 24px !important;
    max-height: 24px;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.sp-icon-large, .sp-i-large, .sp-il {
    max-width: 32px !important;
    max-height: 32px;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.sp-icon-xlarge, .sp-i-xlarge {
    max-width: 48px !important;
    max-height: 48px;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    .sp-icon:hover,
    .sp-icon-small:hover, .sp-i-small:hover, .sp-is:hover,
    .sp-icon-medium:hover, .sp-i-medium:hover, .sp-im:hover,
    .sp-icon-large:hover, .sp-i-large:hover, .sp-il:hover,
    .sp-icon-xlarge:hover, .sp-i-xlarge:hover {
        -webkit-transform: scale(1.1,1.1);
        -ms-transform: scale(1.1,1.1);
        -o-transform: scale(1.1,1.1);
        transform: scale(1.1,1.1);
    }

    .sp-icon .sp-ultra-wait img,
    .sp-icon-small .sp-ultra-wait img,
    .sp-icon-medium .sp-ultra-wait img,
    .sp-icon-large .sp-ultra-wait img,
    .sp-icon-xlarge .sp-ultra-wait img {
        content: url(/themes/base/images/bgLoading.gif) !important;
    }

.sp-icon-calendar {
    width: 24px !important;
    height: 24px;
}

.sp-icon-clear {
    width: 24px !important;
    height: 24px;
}

.sp-icon-search {
    width: 24px !important;
    height: 24px;
}

.sp-notice {
    position: fixed;
    min-width: 300px;
    z-index: 80000;
}

.sp-notice-item {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-direction: row;
    flex-direction: row;
    font-family: var(--font-primary);
    font-size: 14px;
    background-color: #fff;
    color: #333;
    box-shadow: 0 1px 4px rgba(0,0,0,.2);
    -webkit-box-shadow: 0 1px 4px rgba(0,0,0,.2);
    border-radius: 4px;
    -webkit-border-radius: 4px;
    margin: 0 0 6px;
    padding: 15px;
    width: 300px;
    opacity: 0.9;
}

    .sp-notice-item:hover {
        opacity: 1;
    }

.sp-notice-title {
    font-size: 120%;
    font-weight: bold;
}

.sp-notice-text {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    vertical-align: top;
    min-height: 70px;
    -webkit-flex: 0 0 80%;
    -ms-flex: 0 0 80%;
    flex: 0 0 80%;
    max-width: 80%;
}

.sp-notice-image {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    vertical-align: top;
    -webkit-flex: 0 0 20%;
    -ms-flex: 0 0 20%;
    flex: 0 0 20%;
    max-width: 20%;
}

    .sp-notice-image img {
        max-width: 48px;
        max-height: 48px;
    }

.sp-notice-close {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 16px;
    height: 16px;
}

    .sp-notice-close:hover, .sp-notice-close:focus {
        color: #000;
        text-decoration: none;
        cursor: pointer;
        opacity: .4;
        -ms-filter: alpha(opacity=40);
        filter: alpha(opacity=40);
    }

.sp-notice-info {
    color: #fff;
    background-color: rgba(47, 150, 180, 0.95);
}

.sp-notice-toast {
    color: #fff;
    background-color: rgba(0,0,0,0.75);
}

.sp-notice-error {
    color: #fff;
    background-color: rgba(189, 54, 47, 0.95);
}

.sp-notice-warning {
    color: #fff;
    background-color: rgba(248, 148, 6, 0.95);
}

.sp-notice-success {
    color: #fff;
    background-color: rgba(81, 163, 81, 0.95);
}

/** position **/
.sp-notice-top {
    top: 45px;
}

.sp-notice-middle {
    top: 50%;
}

.sp-notice-bottom {
    bottom: 40px;
}

.sp-notice-left {
    left: 20px;
}

.sp-notice-center {
    left: 50%;
    margin-left: -200px;
}

.sp-notice-right {
    right: 20px;
}
/*Media*/
.sp-directory {
    width: 100%;
    background-color: var(--context);
}

.sp-directory-header {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex: 0 0 auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    background: linear-gradient(127deg, var(--primary),var(--secondary) 70% );
    padding: 4px;
    border-radius: 4px 4px 0 0;
    min-height: 48px;
}

.sp-directory-button {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    box-sizing: border-box;
    flex: 0.5 1 auto;
    flex-direction: row;
    text-align: center;
}

.sp-directory-search {
    box-sizing: border-box;
    margin: 0;
    text-align: left;
    direction: ltr;
}

.sp-directory-button-item {
    min-width: 70px;
    width: 70px;
    text-align: center;
    display: inline-block;
    vertical-align: top;
    box-sizing: border-box;
}

    .sp-directory-button-item img {
        width: 24px;
        height: 24px;
    }

    .sp-directory-button-item label {
        display: block;
    }


    .sp-directory-button-item:hover label {
        font-weight: bold;
    }

.sp-directory-main {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex: 0 0 auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
}

.sp-directory-detail {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    vertical-align: top;
    border: 1px solid var(--header);
    border-radius: 0 0 4px 4px;
    border-radius: 0 0 var(--radius) var(--radius);
    height: 100%;
}

.sp-directory-url {
    width: 100%;
    margin-top: 10px;
    margin-left: 10px;
    color: white;
    color: var(--white);
    font-size: 18px;
}

.sp-directory-files {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    direction: ltr;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    vertical-align: top;
    background-color: var(--context);
    min-height: 300px;
    text-align: left;
    border: 1px solid var(--header);
    border-radius: 0 0 4px 4px;
    border-radius: 0 0 var(--radius) var(--radius);
    height: 100%;
}

    .sp-directory-files label {
        display: block;
        font-size: 12px;
    }

    .sp-directory-files img {
        width: 60px;
        height: 60px;
        border-radius: 50%;
    }

.sp-directory-box {
    height: 60px;
}

.sp-directory-image {
    padding: 5px 2px 5px 2px !important;
}

    .sp-directory-image img {
        box-shadow: none;
        width: auto;
        max-width: 94%;
        height: auto;
        max-height: 60%;
        border-radius: 4px;
    }

.sp-directory-files ul:focus {
    outline: none;
}

.sp-directory-item {
    position: relative;
    cursor: context-menu;
    -ms-word-break: break-all;
    word-break: break-all;
    word-break: break-word;
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto;
    width: 120px;
    padding: 8px;
    border-radius: 4px;
    text-align: center;
    vertical-align: top;
    box-sizing: border-box;
    display: inline-block;
    margin: 5px;
    margin-top: 9px;
    border: 1px solid rgba(168, 171, 211, 0.31);
    overflow: hidden;
}

    .sp-directory-item:hover {
        background-color: rgba(202, 213, 221, 0.14);
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
    }

    .sp-directory-item img {
        width: 100%;
    }

    .sp-directory-item label {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        max-width: 94%;
        margin-top: 4px;
        height: 30px;
        overflow-wrap: break-word;
        line-height: 15px;
        vertical-align: middle;
        align-items: center;
    }

    .sp-directory-item:hover label {
        font-weight: bold;
    }

    .sp-directory-item :hover img {
        transform: scale(1.1,1.1);
    }

.sp-directory-menu {
    display: none;
}

.sp-directory-select {
    border-color: var(--primary);
    background-color: rgba(202, 213, 221, 0.14);
    -webkit-transition: background .3s ease;
    transition: background .3s ease;
}

.sp-directory-load {
    width: 150px;
    height: 50px;
    position: absolute;
    right: 10px;
    top: -61px;
    border: 1px solid var(--primary);
    padding: 4px;
    background-color: var(--line);
    box-shadow: 1px 2px 4px var(--secondary);
    color: white;
}

.sp-directory-menu {
    display: none;
    position: absolute;
    top: 76px;
    left: 77px;
    width: 150px;
    border: 1px solid silver;
    background-color: silver;
}


.sp-directory-imagefile img {
    border-radius: 50%;
    border: 1px solid var(--line);
}

.sp-directory-popup {
    z-index: 60;
    position: absolute;
    padding: 4px;
    display: block;
    margin: 0;
    list-style-type: none;
    list-style: none;
    background-color: #fff !important;
    border: 1px solid #b5b5b5 !important;
    box-shadow: 0 0 5px #cdcdcd !important;
    z-index: 2;
}

    .sp-directory-popup li {
        position: relative;
        display: block;
        padding: 4px 30px;
        text-decoration: none;
        white-space: nowrap;
        cursor: default;
        margin: 0 0 4px 0;
        -webkit-touch-callout: none;
        -webkit-user-select: none;
        -khtml-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
    }

        .sp-directory-popup li:hover {
            background-color: var(--select);
        }

    .sp-directory-popup a {
        color: #000;
    }

.sp-directory-popup-split {
    border-top: 1px solid var(--line);
}

.sp-directory-select {
    background-color: #cad5dd;
}
/*Alert*/
.sp-alert {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex: 1 1 auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: .75rem 1.25rem;
    margin: 0.5rem;
    border: 1px solid rgba(10, 10, 10, 0.25);
    background-color: white;
    color: #0a0a0a;
    border-radius: .25rem;
}

.sp-alert-primary {
    color: #004085;
    background-color: #cce5ff;
    border-color: #b8daff;
}

.sp-alert-secondary {
    color: #464a4e;
    background-color: #e7e8ea;
    border-color: #dddfe2;
}

.sp-alert-success {
    color: #155724;
    background-color: #d4edda;
    border-color: #c3e6cb;
}

.sp-alert-danger {
    color: #721c24;
    background-color: #f8d7da;
    border-color: #f5c6cb;
}

.sp-alert-warning {
    color: #856404;
    background-color: #fff3cd;
    border-color: #ffeeba;
}

.sp-alert-info {
    color: #0c5460;
    background-color: #d1ecf1;
    border-color: #bee5eb;
}

.sp-alert-light {
    color: #818182;
    background-color: #fefefe;
    border-color: #fdfdfe;
}

.sp-alert-dark {
    color: #1b1e21;
    background-color: #d6d8d9;
    border-color: #c6c8ca;
}

.sp-animate-drop {
    -webkit-transform: translateY(-120%);
    -moz-transform: translateY(-120%);
    -o-transform: translateY(-120%);
    transform: translateY(-120%);
    opacity: 0;
}

.sp-group-board {
    width: 98%;
    display: block;
    background-color: var(--bgcoolor);
    border-spacing: 0;
    margin: 1%;
}

.sp-group-item {
    display: inline-block;
    position: relative;
}

/*Menu*/
.sp-menu {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}

.sp-menu-items {
    display: none;
    z-index: 4;
    width: 100%;
    position: fixed;
    left: 0px;
    top: 38px;
    background: var(--line);
    min-width: 200px;
    min-height: 200px;
    box-shadow: 1px 2px 2px var(--primary);
}

.sp-menu-item {
}

/*Menu-side*/
.sp-menu-side {
    display: none;
}

.sp-menu-show .sp-menu-items {
    display: block !important;
}
/* Menu Popup */
.sp-menu-popup {
    position: fixed;
    min-height: 100px;
    min-width: 150px;
    background-color: var(--context);
    border: 1px solid var(--line);
    box-shadow: 1px 1px 2px silver;
    display: none;
}

    .sp-menu-popup .sp-menu-item {
        position: relative;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        width: auto;
        padding: 6px 0px;
        margin: 0;
    }


.sp-menu-show {
    display: block !important;
}
/*Hover*/
.sp-menu-hover {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}


/*popup*/
.sp-menu-popup {
    position: absolute !important;
    left: 0;
    top: 0;
    min-height: 100px;
    min-width: 150px;
    display: none;
    background-color: var(--context);
    border: 1px solid var(--line);
    box-shadow: 1px 1px 2px silver;
    z-index: 10;
    padding: 4px;
    margin: 0;
}

    .sp-menu-popup:before {
        content: '';
        position: absolute !important;
        left: 0;
        top: 0;
        width: 24px;
        height: 100%;
        background: var(--verylight);
    }

    .sp-menu-popup li {
        padding: 2px 0 !important;
        margin: 0 !important;
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
        padding-left: 30px !important;
    }

        .sp-menu-popup li:before, .sp-menu-popup li:after {
            content: none !important;
        }

        .sp-menu-popup li:hover {
            background-color: var(--select) !important;
        }

.sp-popup-hidden {
    display: none !important;
}

.sp-popup-show {
    display: block !important;
}

/*toolbar*/
.sp-toolbar {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding: 6px 12px 6px 12px;
    vertical-align: middle;
    margin: 0.25%;
    background-color: var(--context);
    border-radius: 4px;
    border-radius: var(--radius);
    /*border: 1px solid var(--line);*/
}

.sp-toolbar-vertical {
    margin: 0;
    padding: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
}

.sp-toolbar-item {
    position: relative;
    display: inline-block;
    width: auto;
    padding: 12px 5px;
    margin: 0;
    min-width: 55px;
    text-align: center;
    /*border: 1px solid var(--line);*/
    padding: 7px 16px;
    margin: 2px 2px 2px 2px;
    display: inline-block;
    border-radius: 4px;
    border-radius: var(--radius);
}

.sp-toolbar-small {
    min-height: 0;
    min-width: 0;
    padding: 0;
    margin: 0;
}
/*banner*/
.sp-banner {
    max-width: 1024px;
    margin: 0 auto;
    width: 100%;
}
/*digital*/
.sp-digital {
    text-align: center;
    /* display: inline-block;*/
    width: 49%;
    vertical-align: top;
    min-width: 300px;
    direction: ltr;
}

.sp-digital-part {
    display: inline-block;
    width: 65px;
    /*border: 1px solid silver;*/
    height: 140px;
    margin: 5px;
    vertical-align: top;
    padding: 10px;
    background-color: var(--white);
}

.sp-digital label {
    font-size: 40px;
    height: 78px;
    display: block;
    margin-top: 14px;
    color: var(--primary);
    border-bottom: 1px solid var(--primary);
}

.sp-digital span {
    display: block;
    /*color: white;*/
    padding-top: 5px;
}
/*Progress*/
.sp-progress {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
    height: 20px;
    margin-bottom: 20px;
    overflow: hidden;
    background-color: var(--bgcolor);
    border-radius: 4px;
    -webkit-box-shadow: inset 0 1px 2px rgb(0 0 0 / 10%);
    box-shadow: inset 0 1px 2px rgb(0 0 0 / 10%);
}

.sp-progress-bar {
    float: left;
    width: 0%;
    height: 100%;
    font-size: 12px;
    line-height: 20px;
    color: #fff;
    text-align: center;
    background-color: var(--primary);
    -webkit-box-shadow: inset 0 -1px 0 rgb(0 0 0 / 15%);
    box-shadow: inset 0 -1px 0 rgb(0 0 0 / 15%);
    -webkit-transition: width .6s ease;
    -o-transition: width .6s ease;
    transition: width .6s ease;
}
/*logotype*/
.sp-logotype {
    display: inline-block;
    justify-content: center;
}

.sp-smart {
    font-family: nasalization,sans-serif;
    font-size: 50px;
    color: #0e7cd0;
    letter-spacing: -5px;
}

.sp-portal {
    font-family: nasalization,sans-serif;
    font-size: 50px;
    color: #2cd00e;
    letter-spacing: -5px;
}

.sp-slogon {
    display: block;
    font-size: 23px;
    font-family: Raleway;
    color: #0e7cd0;
    font-weight: 600;
    text-align: center;
}
/*Smart menu*/
.sp-smart-menu {
    list-style: none;
    margin-top: 50px;
    text-align: center;
}

.sp-smart-menu-item {
    position: relative;
    width: 140px;
    height: 140px;
    display: inline-block;
    text-align: center;
    list-style: none;
    padding-top: 20px;
    vertical-align: top;
}

    .sp-smart-menu-item img {
        width: 50px;
        height: 50px;
        z-index: 1;
    }

    .sp-smart-menu-item:after {
        content: '';
        width: 130px;
        height: 130px;
        padding: 4px;
        left: 0;
        top: 0;
        border-radius: 0 20% 0 20%;
        position: absolute;
        /*border: 2px solid var(--light);*/
        background-color: var(--context);
        box-shadow: 1px 1px 4px var(--secondary);
    }

    .sp-smart-menu-item:hover:after {
        /*border: 4px  solid var(--secondary);*/
        background-color: rgba(11,105,227,.09);
        -webkit-transition: background .3s ease;
        transition: background .3s ease;
    }

.sp-smart-menu-detail {
    position: relative;
    z-index: 2;
}

.sp-business-logo {
    border-radius: 50%;
}
/*Preview*/
.sp-preview {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin: auto;
    max-width: 90%;
    max-height: 90%;
    width: 90%;
    height: 90%;
}

.sp-preview-image {
    max-height: 100%;
    max-width: 100%;
    margin: 0 auto;
    padding: 0;
    object-fit: scale-down;
}

.sp-preview-button {
    position: absolute;
    right: -15px;
    top: -15px;
}

    .sp-preview-button img {
        width: 30px;
        height: 30px;
    }
/**LOGIN ***/
.sp-login {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    min-height: 250px;
    max-height: 470px;
    max-width: 800px;
    min-width: 800px;
    margin: 30px auto;
    margin-top: 100px;
    background-color: rgba(255,255,255,0.75);
    color: var(--title);
    border-spacing: 5px;
    border-radius: 4px 20px 4px 20px;
    -webkit-border-radius: 4px 20px 4px 20px;
    -moz-border-radius: 4px 20px 4px 20px;
    box-shadow: 0 0 30px rgba(34,80,127,0.4);
    -moz-box-shadow: 0 0 30px rgba(34,80,127,0.4);
}

.sp-login-container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-basis: 100%;
    flex-direction: row;
}

.sp-login-header {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-basis: 40%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    background: var(--primary) url(/themes/base/Images/loginbg.png) no-repeat;
    background-size: cover;
    background-position: center;
    padding-top: 14%;
    max-height: 470px;
    border-radius: 4px 0 0 20px;
    -webkit-border-radius: 4px 0 0 20px;
    -moz-border-radius: 4px 0 0 20px;
}

.sp-login-logo {
    position: absolute;
    right: -37px;
    border: 4px solid white;
    border-radius: 50%;
    overflow: hidden;
    width: 75px;
    height: 75px;
    background: white;
    box-shadow: 0px 0px 8px var(--primary);
    top: 50%;
    top: calc(50% - 37px);
    text-align: center;
}

    .sp-login-logo img {
        max-height: 75px;
        max-width: 75px;
        width: 100%;
        height: 100%;
        position: relative;
    }

.sp-login-body {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-basis: 60%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 10%;
    -webkit-border-radius: 4px 20px 4px 5px;
    border-radius: 4px 20px 4px 5px;
    -moz-border-radius: 4px 20px 4px 5px;
}

.sp-login-row {
    width: auto;
    padding: 1px 2px;
    margin-top: 15px;
}

.sp-login label {
    color: var(--link);
    font-size: 14px;
    padding: 4px 2px;
}

.sp-login a {
    color: var(--link);
    font-size: 14px;
}

.sp-login .sp-form, .sp-login .sp-f {
    background-color: inherit;
}

.sp-login input[type=text], .sp-login input[type=password], .sp-login select {
    color: #002541;
    border: none;
    box-shadow: none;
    background-color: rgb(232,240,254);
    width: 97%;
    width: calc(100% - 10px);
    height: 30px;
    text-align: left;
    direction: ltr;
    padding-left: 3%;
    outline: none;
}

    .sp-login input[type=text]:focus, .sp-login input[type=password]:focus, .sp-login select:focus {
        background-color: #fafafa;
    }

.sp-login .sp-input {
    position: relative;
    padding: 0;
    padding-left: 30px;
    border-bottom: 1px solid var(--primary);
    outline: none;
    box-sizing: border-box;
    background-color: rgb(232,240,254);
    border-radius: 4px;
    border-radius: var(--radius);
}

    .sp-login .sp-input:focus {
        background-color: #fafafa;
    }

    .sp-login .sp-input i {
        position: absolute;
        left: 0;
        top: -1px;
        bottom: 0;
        color: white;
        background-color: var(--secondary);
        width: 30px;
        text-align: center;
        padding-top: 10px;
        border-radius: 4px 0 0 4px;
    }

.sp-login button {
    width: 100%;
    background-color: var(--secondary);
}

.sp-login h1, .sp-login h2 {
    margin: 0;
    color: var(--white);
    text-shadow: 0px 0px 4px black;
}

/*list*/
.sp-list, .sp-l {
    padding-left: 0;
    padding: 10px 0;
}

.sp-list-item, .sp-l-item {
    position: relative;
    display: block;
    padding: 10px 15px;
    margin-bottom: -1px;
    background-color: #fff;
    border: 1px solid #ddd;
}

    .sp-list-item:first-child, .sp-l-item:first-child {
        border-top-left-radius: 4px;
        border-top-right-radius: 4px;
    }

    .sp-list-item:last-child, .sp-l-item:last-child {
        margin-bottom: 0;
        border-bottom-right-radius: 4px;
        border-bottom-left-radius: 4px;
    }

    .sp-list-item:focus, .sp-list-item:hover, .sp-l-item:focus, .sp-l-item:hover {
        color: #555;
        text-decoration: none;
        background-color: var(--select);
    }

.sp-list-select {
    background-color: var(--selected);
}

.sp-list-bar, sp-l-bar {
}

    .sp-list-bar .sp-list-item, .sp-list-bar .sp-l-item,
    .sp-l-bar .sp-list-item, .sp-l-bar .sp-l-item {
        border: none;
    }

/*tree*/
.sp-tree {
}

    .sp-tree ul, .sp-tree li {
        position: relative;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
    }

    .sp-tree ul {
        list-style: none;
        margin-left: 20px;
    }

    .sp-tree li {
        width: 100%;
        list-style-type: none;
        margin: 0 10px;
        display: inline-block;
    }

        .sp-tree li::before, .sp-tree li::after {
            content: "";
            position: absolute;
            left: -20px;
        }

        .sp-tree li::before {
            top: 8px;
            border-left: 1px solid var(--line);
            border-top: 1px solid var(--line);
            border-radius: 0px 0 0 0;
            width: 20px;
            height: 100%;
        }

        .sp-tree li::after {
            top: -10px;
            border-left: 1px solid var(--line);
            border-bottom: 1px solid var(--line);
            border-radius: 0 0 0 0px;
            width: 20px;
            height: 100%;
        }

        .sp-tree li:last-child::before {
            display: none;
        }

        .sp-tree li:last-child::after {
            border-radius: 0 0 0 5px;
        }

    .sp-tree ul::before {
        content: "";
        position: absolute;
        left: -20px;
        border-left: 1px solid var(--line);
    }

    .sp-tree ul > li:first-child::after {
        border-radius: 4px 0 0 0;
    }

.sp-tree-nested {
    display: none;
}

.sp-tree-icon {
    margin-top: -8px;
    background-repeat: no-repeat;
    max-width: 20px;
    max-height: 20px;
}

.sp-tree-small {
    margin-top: -8px;
    background-repeat: no-repeat;
    max-width: 15px;
    max-height: 15px;
}

.sp-tree-collection {
    font-size: 20px;
    display: inline-block;
}

.sp-tree-collection {
    font-size: 20px;
    display: inline-block;
}

.sp-tree-level {
    padding: 7px;
    padding-left: 42.5px;
    display: inline-block;
    border-radius: 5px;
    font-weight: 700;
    position: relative;
    z-index: 1;
}

.sp-tree-icon img {
    width: 20px;
}

.sp-tree .sp-menu-side {
    display: inline;
}
/*Tree Right*/
.sp-tree-right {
    direction: rtl;
}

    .sp-tree-right ul {
        margin-left: 0;
        margin-right: 20px;
    }

    .sp-tree-right li::before, .sp-tree-right li::after {
        right: -20px;
        left: 0;
    }

    .sp-tree-right li::after {
        border-left: none;
        border-right: 1px solid var(--line);
    }

    .sp-tree-right li::before {
        border-left: 0;
        border-right: 1px solid var(--line);
    }

.sp-tree-tiny .sp-tree-icon {
    max-width: 16px;
    max-height: 16px;
}

    .sp-tree-tiny .sp-tree-icon img {
        width: 16px;
    }

/*tree tiny*/
.sp-tree-tiny ul {
    margin-left: 12px;
}

.sp-tree-tiny li {
    margin: 8px;
}

    .sp-tree-tiny li::after {
        width: 16px;
    }

    .sp-tree-tiny li::before {
        width: 16px;
    }
/*Hierarchy*/
/* It's supposed to look like a tree diagram */
.sp-tree-hierarchy, .sp-tree-hierarchy ul, .sp-tree-hierarchy li {
    list-style: none;
    margin: 0;
    padding: 0;
    position: relative;
}

.sp-tree-hierarchy {
    margin: 0 0 1em;
    text-align: center;
}

    .sp-tree-hierarchy, .sp-tree-hierarchy ul {
        display: table;
    }

        .sp-tree-hierarchy ul {
            width: 100%;
        }

        .sp-tree-hierarchy li {
            display: table-cell;
            padding: .5em 0;
            vertical-align: top;
        }
            /* _________ */
            .sp-tree-hierarchy li:before {
                outline: solid 1px #666;
                content: "";
                left: 0;
                position: absolute;
                right: 0;
                top: 0;
            }

            .sp-tree-hierarchy li:first-child:before {
                left: 50%;
            }

            .sp-tree-hierarchy li:last-child:before {
                right: 50%;
            }

        .sp-tree-hierarchy code, .sp-tree-hierarchy span {
            border: solid .1em #666;
            border-radius: .2em;
            display: inline-block;
            margin: 0 .2em .5em;
            padding: .2em .5em;
            position: relative;
        }
        /* If the tree represents DOM structure */
        .sp-tree-hierarchy code {
            font-family: monaco, Consolas, 'Lucida Console', monospace;
        }

            /* | */
            .sp-tree-hierarchy ul:before,
            .sp-tree-hierarchy code:before,
            .sp-tree-hierarchy span:before {
                outline: solid 1px #666;
                content: "";
                height: .5em;
                left: 50%;
                position: absolute;
            }

        .sp-tree-hierarchy ul:before {
            top: -.5em;
        }

        .sp-tree-hierarchy code:before,
        .sp-tree-hierarchy span:before {
            top: -.55em;
        }

        /* The root node doesn't connect upwards */
        .sp-tree-hierarchy > li {
            margin-top: 0;
        }

            .sp-tree-hierarchy > li:before,
            .sp-tree-hierarchy > li:after,
            .sp-tree-hierarchy > li > code:before,
            .sp-tree-hierarchy > li > span:before {
                outline: none;
            }

/*Spinner*/
.sp-spinner {
    display: inline-block;
    margin: var(--universal-margin);
    border: .25rem solid var(--spinner-back-color);
    border-left: .25rem solid var(--spinner-fore-color);
    border-radius: 50%;
    width: 1.25rem;
    height: 1.25rem;
    animation: spinner-donut-anim 1.2s linear infinite
}
/*Animaion*/
.sp-flash {
    -webkit-animation-name: flash;
    animation-name: flash;
}
/*Loading*/
.sp-sending {
    text-align: center;
    margin: 0 auto;
}

    .sp-sending img {
        content: var(--sending);
    }

.sp-loading {
    vertical-align: middle;
    text-align: center;
    margin: 0 auto
}

    .sp-loading img {
        content: var(--loading);
    }

.sp-main-loading {
}

    .sp-main-loading:before {
        content: "";
        position: absolute;
        z-index: 9;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        background: radial-gradient(rgba(255, 255, 255, 0.82), rgba(104, 108, 187, 0.28));
        transition: all .2s ease-in-out;
    }

    .sp-main-loading:after {
        content: "";
        position: absolute;
        z-index: 10;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        background: var(--loading) 50% 50% no-repeat
    }

.sp-loading-page {
    width: 500px;
    margin: 0 auto;
    z-index: 10;
}

    .sp-loading-page:before {
        content: "";
        position: absolute;
        z-index: 9;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        background: radial-gradient(rgba(255, 255, 255, 0.82), rgba(104, 108, 187, 0.28));
        transition: all .2s ease-in-out;
    }

.sp-loading-header {
    text-align: center;
}

.sp-loading-image {
    max-width: 250px;
    max-height: 250px;
}

.sp-loading-label {
    text-align: center;
}
/*quick*/
.sp-quick {
    position: fixed;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    left: 0;
    top: 0;
    bottom: 0;
    min-width: 250px;
    max-width: 30%;
    z-index: 2000;
    background-color: var(--context);
    -webkit-transform: translate(-100%, 0);
    -ms-transform: translate(-100%, 0);
    -o-transform: translate(-100%, 0);
    transform: translate(-100%,0);
    transition: top 1s,height 1s,-webkit-transform 1s;
    transition: transform 1s,top 1s,height 1s;
    transition: transform 1s,top 1s,height 1s,-webkit-transform 1s;
}

.sp-quick-main {
    z-index: 2000;
    position: relative;
    padding: 4px;
    background-color: var(--context);
    height: 100%;
    overflow-y: auto;
}

.sp-quick-flow {
    content: '';
    width: 50px;
    height: 50px;
    position: absolute;
    background-color: var(--context);
    top: 39px;
    right: -44px;
    border-radius: 50%;
    z-index: 1999;
    display: none;
    padding: 7px;
    box-shadow: 2px 4px 13px grey;
}

.sp-quick-button {
    border-radius: 50%;
    height: 35px;
    width: 35px;
    margin: 0;
    border: none;
    padding: 0;
}

    .sp-quick-button:focus {
        border: none;
        border-radius: 50%;
        outline: none;
    }

    .sp-quick-button img {
        width: 35px;
        height: 35px;
    }

.sp-quick-active {
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    transform: translate(0,0);
    box-shadow: 2px 4px 13px grey;
}

    .sp-quick-active .sp-quick-flow {
        display: block;
    }
/*scroll*/
.sp-scroll {
    overflow-y: scroll;
    flex-wrap: nowrap;
}

.sp-scroll-y {
    overflow-y: scroll;
    flex-wrap: nowrap;
    overflow-x: hidden;
}

.sp-scroll-x {
    overflow-y: scroll;
    flex-wrap: nowrap;
    overflow-y: hidden;
}
/*split*/
.sp-split {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    padding: 29px;
    border: 1px solid var(--line);
    margin: 4px 8px 8px 8px;
    border-radius: 8px;
}

.sp-split-left {
    width: 40%;
}

.sp-split-body {
    width: 60%;
}

.sp-split-title {
    text-align: left;
    color: var(--primary);
    margin-top: 8px;
}

.sp-split-note {
    text-align: left;
    margin-top: 12px;
}

.sp-split-body {
}
/*gauge*/
.sp-gauge {
    width: 400px;
    height: 200px;
    overflow: hidden;
    text-align: center;
    position: absolute;
}

.sp-gauge-circle {
    z-index: 1;
    position: absolute;
    background-color: var(--line);
    width: 400px;
    height: 200px;
    border-radius: 250px 250px 0px 0px;
}

.sp-gauge-center {
    z-index: 3;
    position: absolute;
    background-color: var(--bgcolor);
    width: 250px;
    height: 125px;
    bottom: 0;
    margin-left: 75px;
    margin-right: auto;
    border-radius: 250px 250px 0px 0px;
}

.sp-gauge-data {
    z-index: 2;
    position: absolute;
    background-color: #5664F9;
    width: 400px;
    height: 200px;
    top: 200px;
    margin-left: auto;
    margin-right: auto;
    border-radius: 0px 0px 200px 200px;
    transform-origin: center top;
    transition: all 1.3s ease-in-out;
}

.sp-gauge-title {
    z-index: 4;
    font-size: 1.5em;
    line-height: 25px;
    position: absolute;
    width: 100%;
    height: 200px;
    margin: 90px;
    margin-left: auto;
    margin-right: auto;
    transition: all 1s ease-out;
}
/* Popover */
.sp-popover {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1060;
    display: block;
    max-width: 276px;
    font-style: normal;
    font-weight: 400;
    line-height: 1.5;
    text-align: left;
    text-align: start;
    text-decoration: none;
    text-shadow: none;
    text-transform: none;
    letter-spacing: normal;
    word-break: normal;
    word-spacing: normal;
    white-space: normal;
    line-break: auto;
    font-size: .875rem;
    word-wrap: break-word;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid rgba(0,0,0,.2);
    border-radius: .3rem;
}

.sp-popover-title {
    padding: .5rem .75rem;
    margin-bottom: 0;
    font-size: 1rem;
    color: inherit;
    background-color: #f7f7f7;
    border-bottom: 1px solid #ebebeb;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
}

.sp-popover-content {
    padding: .5rem .75rem;
    color: #212529;
}

.sp-arrow {
    position: absolute;
    left: calc((.5rem + 1px) * -1);
    width: .5rem;
    height: 1rem;
    margin: .3rem 0;
}

    .sp-arrow::before, .sp-arrow::after {
        position: absolute;
        display: block;
        content: "";
        border-color: transparent;
        border-style: solid;
        border-width: .5rem .5rem .5rem 0;
    }

    .sp-arrow::before, .sp-arrow::after {
        left: 0;
        border-right-color: #f7f7f7;
    }

/*note*/
.sp-note {
    width: 100%;
}

.sp-note-image {
    text-align: center;
}

    .sp-note-image img {
        max-width: 150px;
        max-height: 150px;
    }

.sp-note-content {
    max-width: 500px;
    margin: auto;
    text-align: center;
    background-repeat: no-repeat;
    min-height: 500px;
    padding-top: 200px;
}

.sp-note-title {
    font-size: 1.2rem;
    font-weight: bold;
    color: var(--primary);
}

.sp-note-text {
    font-size: 1rem;
    font-weight: bold;
    color: var(--secondary);
}

.sp-note-button {
    text-align: center;
}


/*Calendar*/
.sp-calendar {
    border-radius: 4px;
    padding: 4px;
    width: 99%;
    display: block;
}

.sp-calendar-selector {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}

.sp-calendar-up {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 15%;
    text-align: center;
}

.sp-calendar-month, .sp-calendar-year {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 70%;
    text-align: center;
    cursor: pointer;
}

.sp-calendar-months {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    text-align: center;
    flex-direction: row;
}

.sp-calendar-month4 {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 25%;
    text-align: center;
    margin: 0.5rem 0;
    cursor: pointer;
}

    .sp-calendar-month4 a {
        font-size: 0.6rem;
    }

.sp-calendar-years {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    text-align: center;
    flex-direction: row;
}

.sp-calendar-year4 {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 25%;
    text-align: center;
    margin: 0.5rem 0;
    cursor: pointer;
}

    .sp-calendar-year4 a {
        font-size: 0.6rem;
    }

.sp-calendar-down {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 15%;
    text-align: center;
}

.sp-calendar-title {
    text-align: center;
}

.sp-calendar-indicator {
    color: var(--blue-grey-700);
    text-align: center;
    font-weight: 500;
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: var(--secondary);
    border-radius: 2px;
}

    .sp-calendar-indicator .sp-calendar-day {
        color: white
    }

.sp-calendar-week {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.sp-calendar-day {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    font-size: 0.7em;
    color: var(--blue-grey-400);
    font-weight: 500;
    letter-spacing: 0.1em;
    font-variant: small-caps;
    text-align: center;
    cursor: pointer;
    margin: 2px;
    padding: 2px;
    border-radius: 2px;
    -webkit-transition: background .3s ease;
    transition: background .3s ease;
}

    .sp-calendar-day:hover {
        background: var(--select);
        border-radius: 16px;
    }

.sp-calendar-holiday {
    color: red;
}

.sp-calendar-inactive {
    color: silver;
}

.sp-calendar-holiday .sp-calendar-inactive {
    color: #e7c3c3;
}

.sp-calendar-selected {
    background-color: var(--selected);
    border-radius: 16px;
}

.sp-calendar-today {
    background-color: var(--secondary);
    border-radius: 16px;
    color: white;
}

.sp-time {
    width: 100%;
}

.sp-time-title {
    text-align: center;
}

.sp-time-left, .sp-time-right {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.sp-time-hour, .sp-time-minute, .sp-time-secound {
    font-size: 0.7em;
    color: var(--blue-grey-400);
    font-weight: 500;
    letter-spacing: 0.1em;
    font-variant: small-caps;
    text-align: center;
    margin: 2px;
    padding: 2px;
    border-radius: 2px;
    -webkit-transition: background .3s ease;
    transition: background .3s ease;
    cursor: pointer;
}

    .sp-time-hour:hover, .sp-time-mintue:hover, .sp-time-secound:hover {
        background: var(--select);
        border-radius: 16px;
    }

.sp-time-selected {
    background-color: var(--selected);
    border-radius: 16px;
}
/*Rpoert*/
.sp-preview-page {
    margin: auto;
    padding: 1%;
    width: 100%;
    height: 750px;
}
/*Responsive*/
/*medium*/
@media screen and (max-width: 64em) {
    .sp-col, .sp-col-1, .sp-col-2, .sp-col-3, .sp-col-4, .sp-col-5,
    .sp-col-6, .sp-c, .sp-c-2, .sp-c-3, .sp-c-4, .sp-c-5, .sp-c-6 {
        flex: 0 0 50%;
        max-width: 50%
    }

    .sp-col-7, .sp-col-8, .sp-col-9, .sp-col-10, .sp-col-11, .sp-col-12,
    .sp-c-7, .sp-c-8, .sp-c-9, .sp-c-10, .sp-c-11, .sp-c-12 {
        flex: 0 0 100%;
        max-width: 100%
    }

    .sp-ct, .sp-ct-1, .sp-ct-2, .sp-ct-3, .sp-ct-4, .sp-ct-5 {
        flex: 0 0 50%;
        max-width: 50%
    }

    .sp-ct-6, .sp-ct-7, .sp-ct-8, .sp-ct-9, .sp-ct-10 {
        flex: 0 0 100%;
        max-width: 100%
    }

    .sp-cm-1, .sp-cm {
        flex: 0 0 8.33333%;
        max-width: 8.33333%;
    }

    .sp-cm-2 {
        flex: 0 0 16.66667%;
        max-width: 16.66667%;
    }

    .sp-cm-3 {
        flex: 0 0 25%;
        max-width: 25%
    }

    .sp-cm-4 {
        -ms-flex: 0 0 33.33333%;
        flex: 0 0 33.33333%;
        max-width: 33.33333%;
    }

    .sp-cm-5 {
        -ms-flex: 0 0 41.66667%;
        flex: 0 0 41.66667%;
        max-width: 41.66667%;
    }

    .sp-cm-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .sp-cm-7 {
        flex: 0 0 58.33333%;
        max-width: 58.33333%
    }

    .sp-cm-8 {
        flex: 0 0 66.66667%;
        max-width: 66.66667%
    }

    .sp-cm-9 {
        flex: 0 0 75%;
        max-width: 75%
    }

    .sp-cm-10 {
        flex: 0 0 83.33333%;
        max-width: 83.33333%
    }

    .sp-cm-11 {
        flex: 0 0 91.66667%;
        max-width: 91.66667%
    }

    .sp-cm-12 {
        flex: 0 0 100%;
        max-width: 100%
    }
}
/*small*/
@media screen and (max-width: 40em) {
    /*column*/
    .sp-col, .sp-col-1, .sp-col-2, .sp-col-3, .sp-col-4, .sp-col-5, .sp-col-6,
    .sp-col-7, .sp-col-8, .sp-col-9, .sp-col-10, .sp-col-11, .sp-col-12,
    .sp-c, .sp-c-2, .sp-c-3, .sp-c-4, .sp-c-5, .sp-c-6,
    .sp-c-7, .sp-c-8, .sp-c-9, .sp-c-10, .sp-c-11, .sp-c-12 {
        flex: 0 0 100%;
        max-width: 100%
    }

    .sp-ct, .sp-ct-1, .sp-ct-2, .sp-ct-3, .sp-ct-4, .sp-ct-5,
    .sp-ct-6, .sp-ct-7, .sp-ct-8, .sp-ct-9, .sp-ct-10 {
        flex: 0 0 100%;
        max-width: 100%
    }

    .sp-cs-1, .sp-cs, .sp-cs-2, .sp-cs-3, .sp-cs-4,
    .sp-cs-5, .sp-cs-6, .sp-cs-7 {
        flex: 0 0 100%;
        max-width: 100%
    }

    .sp-login {
        width: 100%;
        min-width: 350px;
    }

    .sp-login-header {
        display: none;
    }

    .sp-login-body {
        flex-basis: 100%;
        padding: 5%;
    }
}
/*print*/
@media print {
    .sp-d-print, .sp-d-print-block {
        display: block !important;
    }

    .sp-d-print-none, .sp-print-none {
        display: none !important;
    }
}
