* { box-sizing: border-box; }
html { height: 100%; }
body { height: 100%; margin: 0; padding: 52px 0 0 0; font-family: Regular; font-size: 13px; line-height: 22px; display: flex; flex-direction: column; }
body.nopadd { padding: 0; }
p { margin: 0; padding: 0; } 
h2 { color: #334463; font-family: semiBold; font-size: 20px; margin: 0; padding: 0; }
h3 { color: #334463; font-family: semiBold; font-size: 17px; margin: 0 0 10px 0; padding: 0; }
#popup-title {
    display: flex; 
    flex-direction: row;
    padding: 20px 45px 20px 20px;
}

#popup-title.scrolled {
    box-shadow: 0 0 5px #d4d4d4;
    z-index: 100;
}

#popup-content {
    display: flex;
    flex-direction: column;
    flex: 1;
    overflow: auto;
    padding: 0 20px;
}

#popup-footer {
    display: flex; 
    flex-direction: row;
    padding: 20px 20px 20px 20px;
    box-shadow: 0 0 5px #d4d4d4;
    z-index: 100;
    position: relative;
}

#popup-footer.right .link {
    position: absolute;
    left: 20px;
    top: 32px;
}

#popup-footer.right {
    justify-content: flex-end;
}

#popup-footer.center {
    justify-content: center;
}

.fancybox-close-small { top: 0 !important; right: 0 !important; color: #334463 !important; }
.fancybox-content { border-radius: 3px; }
.fancybox-is-open .fancybox-bg { opacity: .7; background: #435269; }
.fancy-scroll::-webkit-scrollbar { width: 10px; /*height: 5px;*/ }
.fancy-scroll::-webkit-scrollbar-thumb { background: #d4d4d4; }
.fancy-scroll::-webkit-scrollbar-track { background: transparent; }
.tippy-content { font-size: 12px; }
.text-right { text-align: right; }
.text-center { text-align: center; }
.text-uppercase { text-transform: uppercase; }
.text-bold { font-family: semiBold; }
.dflex { display: flex; }
.flexrow { flex-direction: row !important; }
.flexcol { flex-direction: column !important; }
.unset-flex { flex: unset !important; }
.flex-1 { flex: 1; }
.flex-2 { flex: 2; }
.flex-3 { flex: 3; }
.flex-4 { flex: 4; }
.flex-5 { flex: 5; }
.flex-6 { flex: 6; }
.flex-7 { flex: 7; }
.flex-8 { flex: 8; }
.flex-9 { flex: 9; }
.flex-10 { flex: 10; }
.flex-11 { flex: 11; }
.flex-12 { flex: 12; }
.flex-jcc {justify-content: center;}
.flex-jcfe {justify-content: flex-end;}
.flex-jcsb {justify-content: space-between;}
.flex-asc { align-self: center;}
.flex-align-center { align-items: center}
.flex-wrap { flex-wrap: wrap; }

a:link, a:visited { text-decoration: none; color: #0252cc; }
a:hover { text-decoration: none; }

table {
    border-collapse: collapse;
    width: 100%;
}

table.hovered tr:hover {
    background-color: #f5f5f5;
}

table.hovered tr.header:hover {
    background-color: #ffffff;
}

table th {
    padding: 10px;
    color: #6c778c;
    font-family: semiBold;
    text-align: left;
    font-size: 12px;
    text-transform: uppercase;
}

table td {
    padding: 15px 10px;
    border-top: #e6e6e6 1px solid;
    vertical-align: top;
}

table td.row-icon i {
    font-size: 24px;
    color: #334463;
}

table td label {
    display: block;
    color: #334463;
}

span.url {
    color: #009900;
}

table td.action a:link, 
    table td.action a:visited {
    color: #334463;
    text-decoration: none;
    display: inline-block;
    align-items: center;
    text-align: center;
    border-radius: 3px;
    width: 22px;
    height: 22px;
    margin: 0;
    font-size: 16px;
}

table.borderless td {
    border-top: transparent 1px solid;
}

table td.action a:hover {
    background-color: #334463;
    color: #ffffff;
}

table.vcenter td { vertical-align: middle; }

.pagination {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
    padding: 15px 0;
    border-top: #e8e8e8 1px solid;    
}

.pagination a:link,
    .pagination a:visited {
    text-decoration: none;
}

.pagination a:hover {
    color: #334463;
}

.pagination a i { 
    margin: 0 5px;
}

.pagination select {
    margin: 0 16px;
    padding: 10px;
    border: #f5f5f5 1px solid;
    border-radius: 4px;
    background-color: #f5f5f5;
    color: #334463;
}

/* topbar ============================================== */
#topbar { 
    background-color: #ffffff; 
    box-shadow: 0 0 5px #d4d4d4; 
    position: fixed;
    top: 0;
    width: 100%;
    display: flex;
    flex-direction: row;
    align-items: center;
    z-index: 1000;
}

h1.logo {
    padding: 15px;
    font-family: semiBold;
    color: #334463;
    font-size: 18px;
    margin: 0;
}

#topbar .hmenu a:link,
    #topbar .hmenu a:visited {
    color: #ffffff;
    text-decoration: none;
    padding: 10px 16px;
    border-radius: 4px;
    margin: 0 3px;
}

#topbar .hmenu .inner a:link,
    #topbar .hmenu .inner a:visited {
    color: #242424;
    text-decoration: none;
    padding: 10px 16px;
    border-radius: 4px;
    margin: 0 3px;
}

#topbar .hmenu a:hover,
    #topbar .hmenu span:hover {
    background-color: #e2edff;
    color: #054acc;
}

#topbar .hmenu span {
    cursor: pointer;
    color: #334463;
    text-decoration: none;
    padding: 10px 16px;
    border-radius: 4px;
    margin: 0 3px;
    position: relative;
}

#topbar .hmenu span .dropdown-menu {
    display: none;
    position: absolute;
}

#topbar .hmenu span .dropdown-menu.right {
    position: absolute;
    right: 0;
    left: unset !important;
}

#topbar .hmenu span .dropdown-menu.auto, 
    #topbar .hmenu span .dropdown-menu.auto .inner {
    min-width: unset !important;
}

#topbar .hmenu span .dropdown-menu .inner {
    background-color: #ffffff;
    box-shadow: 0 0 5px #d4d4d4;
    margin-top: 5px;
    min-width: 250px;
    display: flex;
    flex-direction: column;
}

#topbar .hmenu span .dropdown-menu .inner label {
    color: #6c778c;
    padding: 0px 20px;
    margin: 14px 0 5px 0;
    font-family: semiBold;
    font-size: 12px;
    text-transform: uppercase;
    display: block;
}

#topbar .hmenu span .dropdown-menu .inner a:link,
    #topbar .hmenu span .dropdown-menu .inner a:visited {
    display: flex;
    flex-direction: row;
    padding: 15px 20px;
    margin: 0;
    border-radius: 0;
    white-space: nowrap;
}

#topbar .hmenu span .dropdown-menu .inner a i {
    font-size: 24px;
    margin-right: 10px;
}

#topbar .hmenu span .dropdown-menu .inner em {
    display: block;
    height: 1px;
    background-color: #e8e8e8;
    margin: 8px 0;
}

#topbar .hmenu span .dropdown-menu .inner a:hover {
    background-color: #f4f5f7;
    color: #182a4e;
}

#topbar .hmenu span:hover .dropdown-menu {
    display: flex;
    flex-direction: column;
    left: 0;
    top: 100%;
    padding: 2px 0 0;
}

#topbar .toolbar {
    display: flex; 
    flex-direction: row;
    padding: 0 15px;
}

#topbar .toolbar a i {
    font-size: 20px;
    color: #334463;
}

i {
    position: relative;
}

i em {
    width: 14px;
    height: 14px;
    font-size: 10px;
    background-color: #cc0001;
    color: #ffffff;
    font-style: normal;
    display: flex;
    font-family: semiBold;
    position: absolute;
    right: -6px;
    top: -2px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
}

#topbar .toolbar a:link,
    #topbar .toolbar a:visited {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    margin: 0 2px;
    text-decoration: none;
    border-radius: 50%;
}

#topbar .toolbar a:hover {
    background-color: #e2edff;
}

/* end of topbar */

/* search box ================================================ */
.searchbox {
    position: relative;
}

.searchbox i {
    cursor: pointer;
    position: absolute;
    left: 10px; 
    top: 10px;
}

.searchbox input {
    border: #e8e8e8 2px solid;
    border-radius: 4px;
    padding: 8px 6px 8px 30px;
}
/* end of search box */

/* workspace ================================================== */
#workspace {
    display: flex; 
    flex-direction: row;
    flex: 1;
}

#workspace.center-content {
    justify-content: center;
    flex: unset;
}
/* menubar ==================================================== */
#menubar {
    width: 250px;
    padding: 30px 10px 10px 10px;
    background-color: #fafbfc;
    display: flex;
    flex-direction: row;
    position: relative;
    transition: all .75s;
    overflow: auto;
    z-index: 900;
}

#menubar.close {
    width: 20px;
}

#menubar.close .links {
    display: none;
}

#menubar .links {
    flex: 1;
}

#seperator {
    position: relative;
    width: 1.75px;
    background-color: #e6e6e6;
    z-index: 950;
}

#seperator i {
    position: absolute;
    width: 20px;
    height: 20px;
    border-radius: 10px;
    background-color: #ffffff;
    left: -8px;
    top: 30px;
    border: #e6e6e6 2px solid;
    font-size: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #999999;
    cursor: pointer;
}

#seperator:hover {
    background-color: #0252cc;
}

#seperator:hover i {
    background-color: #0252cc;
    border: #0252cc 2px solid;
    color: #ffffff;
}

#menubar a:link,
    #menubar a:visited {
    color: #334463;
    padding: 8px 15px;
    display: flex;
    flex-direction: row;
    align-items: center;
    text-decoration: none;
    border-radius: 4px;
    margin: 4px 0;
}

#menubar a:hover {
    background-color: #ebecf0;
}

#menubar a.active {
    font-family: semiBold;
}

#menubar a i {
    font-size: 24px;
    margin-right: 20px;
} 

#menubar em {
    display: block;
    height: 1px;
    background-color: #e8e8e8;
    margin: 8px 0;
}

em.seperator {
    display: block;
    height: 1px;
    background-color: #e8e8e8;
    margin: 8px 0;
}

#playground {
    flex: 1;
    padding: 40px 50px;
    z-index: 800;
}

.breadcrumb a:link, 
    .breadcrumb a:visited {
    font-size: 12px;
    text-decoration: none;
    color: #334463;
}

.breadcrumb a:hover {
    text-decoration: underline;
}

.breadcrumb span { 
    margin: 0 5px;
    color: #334463;
    font-size: 12px;
}

#playground .page-header {
    display: flex;
    flex-direction: row;
    margin: 10px 0;
}

#playground .page-header h1 {
    display: flex;
    align-items: center;
    margin: 0;
    padding: 0;
    font-size: 24px;
    color: #334463;
}

.section-title {
    border-bottom: #e8e8e8 1px solid;
    margin-bottom: 30px;
    height: 28px;
    width: 100%;
}

.section-title label {
    display: inline-block;
    padding: 15px 10px;
    background-color: #ffffff;
    font-family: 'SemiBold';
    font-size: 15px;
    color: #0052cc;
}