@font-face {
    font-family: 'PT Sans';
    src: url('fonts/pt_sans/pts55f_w.eot');
    src: local('PT Sans'), url('fonts/pt_sans/PTS55F_W.eot?#iefix') format('embedded-opentype'), url('fonts/pt_sans/PTS55F_W.woff') format('woff'), url('fonts/pt_sans/PTS55F_W.ttf') format('truetype'), url('fonts/pt_sans/PTS55F_W.svg#PTSans-Regular') format('svg');
}

@font-face {
    font-family: 'PT Sans';
    font-style: italic;
    src: url('fonts/pt_sans/pts56f_w.eot');
    src: local('PT Sans Italic'), url('fonts/pt_sans/PTS56F_W.eot?#iefix') format('embedded-opentype'), url('fonts/pt_sans/PTS56F_W.woff') format('woff'), url('fonts/pt_sans/PTS56F_W.ttf') format('truetype'), url('fonts/pt_sans/PTS56F_W.svg#PTSans-Italic') format('svg');
}

@font-face {
    font-family: 'PT Sans';
    src: url('fonts/pt_sans/pts75f_w.eot');
    font-style: normal;
    font-weight: bold;
    src: local('PT Sans Bold'), url('fonts/pt_sans/PTS75F_W.eot?#iefix') format('embedded-opentype'), url('fonts/pt_sans/PTS75F_W.woff') format('woff'), url('fonts/pt_sans/PTS75F_W.ttf') format('truetype'), url('fonts/pt_sans/PTS75F_W.svg#PTSans-Bold') format('svg');
}

@font-face {
    font-family: 'PT Sans';
    font-style: italic;
    font-weight: bold;
    src: url('fonts/pt_sans/pts76f_w.eot');
    src: local('PT Sans Bold Italic'), url('fonts/pt_sans/PTS76F_W.eot?#iefix') format('embedded-opentype'), url('fonts/pt_sans/PTS76F_W.woff') format('woff'), url('fonts/pt_sans/PTS76F_W.ttf') format('truetype'), url('fonts/pt_sans/PTS76F_W.svg#PTSans-BoldItalic') format('svg');
}

@font-face {
    font-family: 'PT Sans Caption';
    src: url('fonts/pt_sans/ptc55f_w.eot');
    src: local('PT Sans Caption'), url('fonts/pt_sans/PTC55F_W.eot?#iefix') format('embedded-opentype'), url('fonts/pt_sans/PTC55F_W.woff') format('woff'), url('fonts/pt_sans/PTC55F_W.ttf') format('truetype'), url('fonts/pt_sans/PTC55F_W.svg#PTSans-Caption') format('svg');
}

@font-face {
    font-family: 'PT Sans Caption';
    font-weight: bold;
    src: url('fonts/pt_sans/ptc75f_w.eot');
    src: local('PT Sans Caption Bold'), url('fonts/pt_sans/PTC75F_W.eot?#iefix') format('embedded-opentype'), url('fonts/pt_sans/PTC75F_W.woff') format('woff'), url('fonts/pt_sans/PTC75F_W.ttf') format('truetype'), url('fonts/pt_sans/PTC75F_W.svg#PTSans-CaptionBold') format('svg');
}

@font-face {
    font-family: 'PT Sans Narrow';
    src: url('fonts/pt_sans/ptn57f_w.eot');
    src: local('PT Sans Narrow'), url('fonts/pt_sans/PTN57F_W.eot?#iefix') format('embedded-opentype'), url('fonts/pt_sans/PTN57F_W.woff') format('woff'), url('fonts/pt_sans/PTN57F_W.ttf') format('truetype'), url('fonts/pt_sans/PTN57F_W.svg#PTSans-Narrow') format('svg');
}

@font-face {
    font-family: 'PT Sans Narrow';
    font-weight: bold;
    src: url('fonts/pt_sans/ptn77f_w.eot');
    src: local('PT Sans Narrow Bold'), url('fonts/pt_sans/PTN77F_W.eot?#iefix') format('embedded-opentype'), url('fonts/pt_sans/PTN77F_W.woff') format('woff'), url('fonts/pt_sans/PTN77F_W.ttf') format('truetype'), url('fonts/pt_sans/PTN77F_W.svg#PTSans-NarrowBold') format('svg');
}

body {
    font-family: 'PT Sans', 'sans-serif';
}

b, strong {
    font-weight: bold;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'PT Sans Caption', 'sans-serif';
}

.topbar .top-navbar {
    min-height: 50px;
}

.topbar .top-navbar .navbar-header {
    line-height: 45px;
}

.topbar .top-navbar .navbar-header .navbar-brand b {
    line-height: 50px;
    padding-top: 1px;
}

.mini-sidebar .topbar .top-navbar .navbar-header .navbar-brand b {
    line-height: 51px;
}

.topbar .top-navbar .navbar-nav>.nav-item>.nav-link {
    line-height: 35px;
}

.notify {
    top: -20px;
}

.topbar .top-navbar .navbar-header {
    text-align: left;
    padding: 0 9px;
    background-color: #272c33;
}

.mini-sidebar .topbar .top-navbar .navbar-header .navbar-brand {
    margin-left: 0;
}

.mini-sidebar .topbar .top-navbar .navbar-header .navbar-brand .light-logo {
    width: 47px;
}

.topbar .top-navbar .navbar-header .navbar-brand .light-logo {
    height: 47px;
}

.mini-sidebar .sidebar-nav #sidebarnav > li > a {
    padding: 15px;
    min-height: 51px;
}

.mini-sidebar .sidebar-nav #sidebarnav>li>ul {
    left: 55px;
    top: 51px;
    width: 205px;
}

.sidebar-nav > li > ul {
    margin-bottom: 20px;
}

.sidebar-nav > ul > li.active > a,
.sidebar-nav > ul > li.active:hover > a {
    background: #1e88e5 !important;
}

.btn.disabled,
.btn:disabled {
    opacity: .33;
}

.btn-success,
.btn-success.disabled {
    background: #1e88e5;
    border: 1px solid #1e88e5;
    -webkit-box-shadow: 0 2px 2px 0 rgba(30, 136, 229, 0.14), 0 3px 1px -2px rgba(30, 136, 229, 0.2), 0 1px 5px 0 rgba(30, 136, 229, 0.12);
    box-shadow: 0 2px 2px 0 rgba(30, 136, 229, 0.14), 0 3px 1px -2px rgba(30, 136, 229, 0.2), 0 1px 5px 0 rgba(30, 136, 229, 0.12);
}

.btn-success.active.focus,
.btn-success.active:focus,
.btn-success.active:hover,
.btn-success.focus,
.btn-success.focus:active,
.btn-success:active:focus,
.btn-success:active:hover,
.btn-success:focus,
.open>.dropdown-toggle.btn-success.focus,
.open>.dropdown-toggle.btn-success:focus,
.open>.dropdown-toggle.btn-success:hover,
.btn-success.disabled:hover,
.btn-success:hover,
.btn-success:not(:disabled):not(.disabled).active,
.btn-success:not(:disabled):not(.disabled):active,
.show>.btn-success.dropdown-toggle {
    background: #1e88e5;
    border: 1px solid #1e88e5;
}

.btn-success:not(:disabled):not(.disabled):hover,
.btn-success:not(:disabled):not(.disabled).active:focus,
.btn-success:not(:disabled):not(.disabled):active:focus,
.show>.btn-success.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(30, 136, 229, .5);
}

.btn.btn-outline-success {
    border-color: #1e88e5;
    color: #1e88e5;
    -webkit-box-shadow: 0 2px 2px 0 rgba(30, 136, 229, 0.14), 0 3px 1px -2px rgba(30, 136, 229, 0.2), 0 1px 5px 0 rgba(30, 136, 229, 0.12);
    box-shadow: 0 2px 2px 0 rgba(30, 136, 229, 0.14), 0 3px 1px -2px rgba(30, 136, 229, 0.2), 0 1px 5px 0 rgba(30, 136, 229, 0.12);
}

.btn.btn-outline-success:not(:disabled):not(.disabled).active:focus,
.btn.btn-outline-success:not(:disabled):not(.disabled):active:focus,
.show>.btn-outline-success.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(30, 136, 229, .5);
}

.btn.btn-outline-success.focus,
.btn.btn-outline-success:focus,
.btn.btn-outline-success:hover,
.btn.btn-outline-success:not(:disabled):not(.disabled).active,
.btn.btn-outline-success:not(:disabled):not(.disabled):active,
.show>.btn.btn-outline-success.dropdown-toggle
{
    background: #1e88e5;
    border: 1px solid #1e88e5;
    color: #fff;
}

.btn-group .btn-outline-success {
    color: #1e88e5 !important;
}

.btn-group .btn.active,
.btn-group .btn:focus,
.btn-group .btn:hover {
    color: #fff !important;
}

.search-box .app-search input {
    padding: 15px 40px 15px 20px;
    height: 55px;
}

.search-box .app-search .srh-btn {
    top: 18px;
}

.container-fluid {
    padding: 0 15px 25px 15px;
}

.page-titles {
    padding: 10px 15px;
    margin: 0 -15px 15px;
}

.card {
    margin-bottom: 15px;
}

#year-selector-button {
    text-align: left;
    padding-left: 40px;
    position: relative;
}

#year-selector-button::before {
    content: "\F0ED";
    font: normal normal normal 24px/1 "Material Design Icons";
    position: absolute;
    left: 7px;
    top: 50%;
    margin-top: -11px;
}

#year-selector {
    text-align: right;
}

#loginform .text-center hr {
    margin-left: -1.25rem;
    margin-right: -1.25rem;
}

.login-register .login-overlay {
    background-color: rgba(0, 0, 0, 0.5);
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    z-index: 5;
}

.login-register .login-box {
    z-index: 10;
    position: relative;
    width: 560px;
}

.login-register .login-box > .card .card-header {
    padding: 5px;
    text-align: center;
}

.login-box-header {
    background-color: #fff;
    border-radius: calc(.25rem - 1px) calc(.25rem - 1px) 0 0;
    padding: 20px 0;
}

.login-box #collapse-client .card-body,
.login-box #collapse-admin .card-body {
    padding-top: 0;
}

.login-box #collapse-client .comment {
    line-height: 1.2;
}

.login-box .card-header .btn {
    color: inherit;
}

.login-box .card-header .btn i {
    display: none;
}

.login-box .card-header .btn.collapsed {
    color: #007bff;
}

.login-box .card-header .btn.collapsed i {
    display: inline;
}

.login-box .message-box .message-widget a .mail-contnet {
    width: 100%;
}

.login-box .message-box .message-widget {
    height: 300px;
    overflow-y: scroll;
    margin: 0 -20px;
}

.login-box .contact-box .contact-widget > a {
    padding: 10px 20px;
}

.table .action-column {
    width: 50px;
    padding: .25rem;
}

.table .checkbox-column {
    width: 42px;
    text-align: center;
}

.table .checkbox-column [type=checkbox]+label {
    padding-left: 18px;
}

.table .action-column-big {
    width: 250px;
}

.table .action-column-big .btn {

}

.table .lesson-column {
    text-align: center;
    width: 130px;
}

.table .lesson-summary-column {
    text-align: center;
    width: 130px;
    font-weight: bold;
}

.table .serial-column {
    width: 10px;
    text-align: center;
}

.table .picture-column {
    width: 50px;
    padding: .25rem;
}

.table .picture-column .round {
    width: 40px;
    height: 40px;
}

.table .flow-column {
    font-size: 150%;
    font-weight: bold;
    text-align: center;
}

.table .mark-column {
    text-align: center;
}

.table th.mark-column {
    text-align: inherit;
}

.table th.mark-column .delete-type-button {
    float: right;
}

.table tbody td.mark-column a {
    color: #99abb4;
    margin-left: 10px;
}

.table th {
    position: relative;
}

.table th a[data-sort]::after {
    content: "\f0dc";
    margin-left: 10px;
    font-family: "Font Awesome 5 Free"!important;
    font-weight: 900;
    cursor: pointer;
    color: rgba(50, 50, 50, 0.5);
    position: absolute;
    right: .15rem;
}

.table th a[data-sort].asc::after {
    content: "\f0de";
    color: rgb(50, 50, 50);
}

.table th a[data-sort].desc::after {
    content: "\f0dd";
    color: rgb(50, 50, 50);
}

.table + .row .summary {
    line-height: 38px;
}

.sidebar-footer button {
    background: none;
    border: none;
    outline: none;
    color: #455a64;
    padding: 15px;
    width: 33.333337%;
    float: left;
    text-align: center;
    font-size: 18px;
}

.sidebar-footer button:hover, .sidebar-footer button:focus {
    color: #1e88e5 !important;
}

.custom-control {
    padding-left: 0;
}

.form-group [aria-invalid="true"] ~ .invalid-feedback,
.form-group .is-invalid ~ .invalid-feedback {
    display: block;
}

.dropify-wrapper .dropify-message p {
    text-align: center;
}

.dropify-preview .dropify-filename-inner {
    content: "123";
}

.sidebar-nav {
    padding: 10px;
}

.sidebar-nav ul li a {
    white-space: normal;
    padding: 6px 35px 6px 15px;
    line-height: 1.4;
}

.sidebar-nav ul li ul li a {
    padding: 7px 35px 7px 10px;
}

.sidebar-nav > ul > li > a {
    position: relative;
}

.sidebar-nav > ul > li > a span {
    margin-left: 30px;
    display: inline-block;
}

.sidebar-nav > ul > li > a i {
    text-align: center;
    position: absolute;
    left: 10px;
    top: 50%;
    margin-top: -14px;
}

.sidebar-nav ul li.nav-small-cap {
    padding-left: 10px;
}

.page-titles .btn {
    white-space: nowrap;
}

.tab-content .tab-pane > h4:first-child {
    margin-top: 0;
}

.vtabs {
    width: 100%;
}

[type=checkbox]:not(:checked):disabled + label:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 18px;
    height: 18px;
    z-index: 0;
    border: 2px solid #5a5a5a;
    border-radius: 1px;
    margin-top: 2px;
    -webkit-transition: .2s;
    -o-transition: .2s;
    transition: .2s;
    opacity: 0.33;
}

[type=checkbox]:not(:checked):disabled + label:after {
    border: 0;
    -webkit-transform: scale(0);
    -ms-transform: scale(0);
    transform: scale(0);
}

.btn-lg.btn-circle {
    font-size: 27px;
    padding: 6px 11px;
}

.page-titles .col-xs-4 {
    text-align: right;
}

.page-titles .text-right > a + a {
    margin-left: 10px;
}

.form-group .col-9 .switch,
.form-group .col-9 [type=radio]:first-child + label {
    margin-top: calc(.375rem + 1px);
    margin-bottom: calc(.375rem + 1px);
}

[type=radio] + label.with-input {
    height: 32px;
    line-height: 32px;
}

[type=radio] + label.with-input::before {
    top: 5px;
}

.select2-container .select2-selection--single {
    height: 38px;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b {
    margin-top: 3px;
}

.select2-container--default .select2-selection--single,
.select2-dropdown {
    border: 1px solid #ced4da;
}

.select2-container .select2-selection--single .select2-selection__rendered {
    white-space: normal;
    padding-top: 5px;
    padding-bottom: 5px;
}

.select2-container .select2-selection--single {
    height: auto;
    min-height: 38px;
}

#profiling-grid {
    font-size: 85%;
}

#profiling-grid td,
#profiling-grid th {
    padding: .25rem;
}

#profiling-grid tbody td {
    word-wrap: break-word;
    word-break: break-all;
}

.dropdown-item i {
    width: 16px;
    text-align: center;
    margin-right: 4px;
}

.chat-main-box .chat-left-aside .chat-left-inner .style-none li a {
    padding: 10px 20px;
}

.chat-left-inner .form-material .spinner-border {
    position: absolute;
    right: 8px;
    top: 14px;
}

#sidebarnav a > .label {
    position: absolute;
    right: 4px;
    top: 50%;
    margin-top: -9px;
}

.chatonline li a .label {
    float: right;
    border: 1px solid #67757c;
}

.chatonline .empty {
    font-size: 85%;
    text-align: center;
    padding: 50px 20px;
}

.chat-right-aside > .spinner-border {
    position: absolute;
    left: calc(50% + 125px);
    top: 50%;
    margin-left: -1rem;
    margin-top: -1rem;
}

.chat-list li .chat-content .box {
    position: relative;
}

.chat-list li .chat-content .box .btn-delete {
    position: absolute;
    top: -9px;
    right: -5px;
}

.chatui-header {
    padding: 10px 20px;
}

.chatui-input .chatui-add-file {
    color: rgba(0, 0, 0, 0.3);
    position: absolute;
    right: 15px;
    top: 0;
    z-index: 10;
    font-size: 18px;
}

.chatui-input .chatui-add-file i {
    margin-top: -6px;
}

.chatui-file-uploader input[type="file"] {
    display: none;
}

.chatui-file-uploader .files {
    padding: 5px 10px;
    border-bottom: 1px solid #eeeeee;
}

.chatui-file-uploader .files .file {
    display: inline-block;
    max-width: 300px;
    min-width: 150px;
    position: relative;
    line-height: initial;
    padding: 0 30px 0 30px;
    overflow: hidden;
    height: 30px;
    margin-right: 20px;
    font-size: 85%;
}

.chatui-file-uploader .files .file:last-child {
    margin-right: 0;
}

.chatui-file-uploader .files .file .fi,
.chatui-file-uploader .files .file .fa.fa-file {
    position: absolute;
    left: 0;
    top: 6px;
}

.chatui-file-uploader .files .file .progress {
    margin: 0;
    height: 8px;
    margin-top: 2px;
}

.chatui-file-uploader .files .file .remove {
    position: absolute;
    right: 0;
    top: 0;
    padding: 6px 5px;
    display: block;
}

.chatui-file-uploader .files .file .name {
    max-height: 18px;
    overflow: hidden;
}

.chatui-file-uploader .files .file .description {
    font-size: 10px;
}

.chat-left-inner .search .fa-plus {
    display: none;
}

.chat-left-inner .search.add .fa-plus {
    display: block;
}

#users-modal .img-circle {
    width: 40px;
    height: 40px;
    float: left;
}

#users-modal .people-group-item {
    overflow: hidden;
    display: block;
}

#users-modal .people-group-item-heading {
    margin-left: 44px;
    line-height: 32px;
    margin-top: 6px;
}

.user-profile {
    background-size: cover !important;
}

.user-profile .profile-text {
    padding: 0;
}

.user-profile .profile-text > a {
    white-space: normal;
}

.btn + .test-result {
    padding: 2px 20px;
    line-height: 34px;
    margin-left: 120px;
}

.topbar ul.dropdown-user button {
    border: none;
    outline: none;
    background: transparent;
    padding: 9px 15px;
    display: block;
    color: #67757c;
    width: 100%;
    text-align: left;
}

.topbar ul.dropdown-user button:hover,
.topbar ul.dropdown-user button:focus,
.topbar ul.dropdown-user button:active {
    background: #f2f4f8;
    color: #009efb;
    text-decoration: none;
}

#branding {
    background: rgba(0, 0, 0, 0.6);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10;
}

#branding .container {
    padding: 10px;
    color: #fff;
    text-align: center;
}

#branding .logo {
    float: left;
    width: 60px;
    height: 60px;
    margin-right: 15px;
    background: center no-repeat;
    background-size: contain;
}

#branding .name {
    float: left;
    line-height: 60px;
    font-size: 40px;
    font-weight: bold;
}

#branding .center-block {
    margin: 0 auto;
    overflow: hidden;
    display: inline-block;
}

.card-body > .row > .col-3 > .row > .col-3 > .btn-circle,
.card-body > .row > .col-9 > .row > .col-3 > .btn-group {
    margin-top: -5px;
}

.input-group-text.bg-outline-info {
    border-top: 1px solid #ced4da;
    border-bottom: 1px solid #ced4da;
}

.input-group-text.bg-outline-info i {
    color: #1e88e5;
}

.treeview span.icon {
    width: 12px !important;
    display: inline-block;
    margin-right: 2px !important;
}

.treeview span.icon.glyphicon {
    display: none;
}

.node-icon {
    margin-right: 2px;
}

.treeview span.node-icon {
    display: none;
}

.list-group-item {
    padding: .5rem;
    display: flex;
}

.list-group-block .list-group-item {
    display: block;
}

[data-pjax-container] + .text-right > .btn,
[data-pjax-container] + .text-right > .btn-group {
    /*margin-top: 20px;*/
}

.sidebar-nav ul li.active > a {
    color: #fff;
    font-weight: 500;
}

#tab-main {
    position: relative;
}

#tab-main .form-group.row {
    margin-bottom: 0;
}

.edit-field + .spinner-border {
    position: absolute;
    margin-top: -4px;
    margin-left: 8px;
}

.form-group.row > label > .edit-field + .spinner-border {
    right: auto;
}

.btn + .spinner-border,
.btn-group + .spinner-border {
    position: absolute;
    margin-top: 3px;
    margin-left: 8px;
}

.popover {
    min-width: 340px;
    max-width: none;
}

.clockpicker-popover {
    max-width: 276px;
}

.clockpicker-plate {
    margin: 0 auto;
}

.col-3 > .card > .card-body > .nav {
    margin: -10px -20px;
}

.col-3 > .card > .card-body > .nav + .nav {
    margin-top: 10px;
}

.col-3 > .card > .card-body > p:first-child {
    margin-top: 0;
}

.col-3 > .card > .card-body > p {
    margin: 10px -5px 0;
}

.col-3 > .card > .card-body > .nav a.disabled {
    opacity: 0.5;
}

.col-3 > .card > .card-body > hr {
    margin: 1rem -20px;
}

.col-3 > .card > .card-body > .nav[hidden] + hr {
    display: none;
}

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

.table-vertical-align tbody td > input[type="checkbox"] + label {
    margin-bottom: 0;
    margin-top: 6px;
}

.node-tree a {
    color: inherit;
}

.node-tree:not(.node-disabled):hover {
    background-color: rgba(0, 0, 0, 0.05);
}

.node-tree.active {
    background-color: #03a9f3;
    color: #fff;
}

body > .datepicker {
    z-index: 2000 !important;
}

.tab-pane > .card-footer,
.tab-pane > div > .card-footer {
    overflow: hidden;
}

.tab-pane > .card-footer > .status,
.tab-pane > div > .card-footer > .status,
.card-footer > .btn + .status {
    float: left;
    margin-left: 10px;
    padding-top: 7px;
}

.tab-pane > .card-footer > .status .spinner-border,
.tab-pane > div > .card-footer > .status .spinner-border,
.card-footer > .btn + .status .spinner-border {
    margin-top: -4px;
}

.nested-table .td-level-2 {
    padding-left: 25px;
}

.nested-table .td-level-3 {
    padding-left: 50px;
}

.nested-table .td-level-4 {
    padding-left: 75px;
}

.nested-table td.no-padding {
    padding-left: 5px;
}

.nested-table .td-level-expandable {
    position: relative;
    background-clip: padding-box;
}

.nested-table .td-level-expandable.td-level-1 {
    padding-left: 50px;
}

.nested-table .td-level-expandable.td-level-1 > .expand {
    position: absolute;
    left: 4px;
}

.nested-table .td-level-expandable.td-level-2 {
    padding-left: 71px;
}

.nested-table .td-level-expandable.td-level-2 > .expand {
    position: absolute;
    left: 25px;
}

.nested-table .td-level-expandable.td-level-3 {
    padding-left: 96px;
}

.nested-table .td-level-expandable.td-level-3 > .expand {
    position: absolute;
    left: 50px;
}

.nested-table .td-level-expandable.td-level-4 {
    padding-left: 121px;
}

.nested-table .td-level-expandable.td-level-4 > .expand {
    position: absolute;
    left: 75px;
}

.nested-table {
    border-color: rgba(36, 141, 193, 0.5);
}

.nested-table tr.tr-level-1 > td {
    background-color: rgba(36, 141, 193, 0.2);
}

.nested-table tr.tr-level-2 > td {
    background-color: rgba(36, 141, 193, 0.12);
}

.nested-table tr.tr-level-3 > td {
    background-color: rgba(36, 141, 193, 0.05);
}

.nested-table tr.tr-level-4 > td {
    background-color: rgba(36, 141, 193, 0);
}

.nested-table tbody {
    border: 3px solid rgba(36, 141, 193, 0.5);
}

.nested-table tbody td input[type=text],
.nested-table tbody td input[type=number],
.nested-table tbody td textarea,
.nested-table tbody td select {
    min-width: 50px;
}

.nested-table tbody tr.tr-level-1 {
    border-top: 3px solid rgba(36, 141, 193, 0.5);
}

.nested-table tbody td.td-level-3 {
    position: relative;
}

.nested-table tbody td.td-level-3 > .expand {
    position: absolute;
    left: 4px;
}

.nested-table tbody td > ul {
    padding-left: 10px;
}

.nested-table th a {
    font-size: 70%;
    font-weight: normal;
    border-bottom: 1px dashed #1BBAE1;
    cursor: pointer;
}

.nested-table th a:hover {
    text-decoration: none;
}

table thead.tableFloatingHeaderOriginal {
    z-index: 100 !important;
}

table thead.tableFloatingHeaderOriginal th {
    background-color: #fff;
}

.modal-footer .btn.float-left + .btn:not(.float-left) {
    margin-left: auto;
}

table tbody td a + .spinner-border {
    margin-left: 5px;
    position: absolute;
    margin-top: -5px;
}

.input-group-text label {
    margin: 0 !important;
    height: 23px !important;
}

.invalid-feedback.show {
    display: block;
}

.year-selector,
.params-selector {
    display: inline-block;
    margin: -0.5rem 0 -0.5rem 1rem;
}

.year-selector .name,
.params-selector .name {
    display: inline-block;
    margin-right: 20px;
}

.params-selector .form-control {
    display: inline-block;
    width: 200px;
}

.table-condensed tr th,
.table-condensed tr td {
    padding: 3px;
    font-size: 80%;
    min-width: 20px;
}

.year-grid thead tr th {
    text-align: center;
    font-size: 14px;
    padding: .25rem;
}

.year-grid thead tr:last-child th {
    padding-left: 2px;
    padding-right: 2px;
}

.year-grid > tbody > tr > td {
    height: 35px;
}

.year-grid tbody tr td,
.year-grid tfoot tr td {
    text-align: center;
}

.year-grid tbody tr td.ui-selected,
.year-grid tbody tr td.ui-selecting {
    background-color: #F5F5F5;
}

.year-grid tbody tr td.with-table {
    padding: 0;
    height: 40px;
}

.year-grid tbody tr td.with-table table {
    background: none !important;
}

.year-grid tbody tr td table {
    width: 100%;
    height: 100%;
    margin: -3px;
}

.year-grid tbody tr td table tr {
    height: 50%;
}

.year-grid tbody tr td table td {
    border: 1px solid #EAEDF1;
    padding: 0 3px;
    min-width: 15px;
    height: 17px;
}

.year-grid tbody tr td table tr:first-child td {
    border-top: none;
}

.year-grid tbody tr td table tr:last-child td {
    border-bottom: none;
}

.year-grid tbody tr td table tr td:first-child {
    border-left: none;
}

.year-grid tbody tr td table tr td:last-child {
    border-right: none;
}

.year-grid tbody {
    cursor: default;
}
.year-grid tbody tr td.semester-border-start {
    border-left: 2px solid #AAD178 !important;
}

.year-grid tbody tr td.semester-border-end {
    border-right: 2px solid #AAD178 !important;
}

.year-grid tbody tr td.disabled,
.year-grid tbody tr td[data-empty="1"] {
    background-color: rgba(241, 244, 248, 0.8) !important;
}

.year-grid tbody tr td[data-course="1"] {
    background-color: rgba(163, 213, 95, 0.15);
}

.year-grid tbody tr td[data-course="2"] {
    background-color: rgba(225, 231, 35, 0.15);
}

.year-grid tbody tr td[data-course="3"] {
    background-color: rgba(255, 69, 57, 0.1);
}

.year-grid tbody tr td[data-course="4"] {
    background-color: rgba(255, 191, 61, 0.15);
}

.year-grid tbody tr td[data-course="5"] {
    background-color: rgba(101, 178, 233, 0.15);
}

.year-grid tbody tr td[data-course="6"] {
    background-color: rgba(217, 60, 180, 0.15);
}

.year-grid tbody tr td[data-course="7"] {
    background-color: rgba(177, 80, 197, 0.15);
}

.semesters-grid tbody tr td[data-course="1"] {
    background-color: rgba(163, 213, 95, 0.3);
}

.semesters-grid tbody tr td[data-course="2"] {
    background-color: rgba(225, 231, 35, 0.3);
}

.semesters-grid tbody tr td[data-course="3"] {
    background-color: rgba(255, 69, 57, 0.2);
}

.semesters-grid tbody tr td[data-course="4"] {
    background-color: rgba(255, 191, 61, 0.3);
}

.semesters-grid tbody tr td[data-course="5"] {
    background-color: rgba(101, 178, 233, 0.2);
}

.semesters-grid tbody tr td[data-course="6"] {
    background-color: rgba(217, 60, 180, 0.15);
}

.semesters-grid tbody tr td[data-course="7"] {
    background-color: rgba(177, 80, 197, 0.3);
}

.table-auto-width {
    width: auto;
}

#semester-form-table th:not(:first-child),
#semester-form-table td:not(:first-child) {
    text-align: center;
}

#semester-form-table td.td-round {
    position: relative;
}

#semester-form-table td.td-round::after {
    content: 'Не требуется';
    color: #999;
    width: 100%;
    left: 0;
    top: 15px;
    position: absolute;
}

#semester-form-table td.td-round .result-label {
    background: #fff;
    position: relative;
    z-index: 10;
}

#semester-form-table td .select-select2 {
    text-align: left;
    position: relative;
    z-index: 10;
}

.select-select2 ~ input[type=checkbox] {
    margin-top: 10px;
    margin-left: 10px;
}

#semester-form-table tfoot tr td {
    background: none;
}

#semester-form-table h4,
#semester-form-table label {
    margin: 0;
    padding: 0;
    line-height: 37px;
}

#semester-form-table select {
    width: 50px;
}

#semester-form-table tr td:first-child label {
    text-align: right;
    display: block;
}

#semester-form-table tr th,
#semester-form-table tr td {
    padding: .75rem .25rem;
    font-size: 85%;
}

.color-sample[data-course="1"] {
    background-color: rgba(163, 213, 95, 0.3);
    border-color: rgba(163, 213, 95, 0.5);
}

.color-sample[data-course="2"] {
    background-color: rgba(225, 231, 35, 0.3);
    border-color: rgba(225, 231, 35, 0.5);
}

.color-sample[data-course="3"] {
    background-color: rgba(255, 69, 57, 0.2);
    border-color: rgba(255, 69, 57, 0.4);
}

.color-sample[data-course="4"] {
    background-color: rgba(255, 191, 61, 0.3);
    border-color: rgba(255, 191, 61, 0.5);
}

.color-sample[data-course="5"] {
    background-color: rgba(101, 178, 233, 0.2);
    border-color: rgba(101, 178, 233, 0.4);
}

.color-sample[data-course="6"] {
    background-color: rgba(217, 60, 180, 0.15);
    border-color: rgba(217, 60, 180, 0.3);
}

.color-sample[data-course="7"] {
    background-color: rgba(177, 80, 197, 0.3);
    border-color: rgba(177, 80, 197, 0.5);
}

.tr-color-1 {
    background-color: rgba(163, 213, 95, 0.15);
}

.tr-color-2 {
    background-color: rgba(225, 231, 35, 0.15);
}

.tr-color-3 {
    background-color: rgba(255, 69, 57, 0.1);
}

.tr-color-4 {
    background-color: rgba(255, 191, 61, 0.15);
}

.tr-color-5 {
    background-color: rgba(101, 178, 233, 0.15);
}

.tr-color-6 {
    background-color: rgba(217, 60, 180, 0.15);
}

.tr-color-7 {
    background-color: rgba(177, 80, 197, 0.15);
}

.semesters-grid tbody tr td {
    position: relative;
}

.semesters-grid thead tr:last-child th {
    border-bottom: 2px solid #AAD178;
    padding-left: 2px;
    padding-right: 2px;
}

.semesters-grid tbody tr td:not(:first-child) {
    border-top: 2px solid #AAD178;
    border-bottom: 2px solid #AAD178;
}

.semesters-grid tbody tr td:last-child,
.semesters-grid tbody tr td:first-child {
    border-right: 2px solid #AAD178;
}

.semesters-grid tbody tr td .semester-divider-end,
.semesters-grid tbody tr td .semester-divider-start {
    background: url("../images/other/table-divider.png") repeat-y center;
    position: absolute;
    left: 75%;
    top: 0;
    width: 50%;
    height: 100%;
    min-width: 2px;
    z-index: 500;
}

.semesters-grid tbody tr td .semester-divider-start {
    left: -25%;
}

.semesters-grid tbody tr td.active {
    border-top: 2px solid #AAD178;
    border-bottom: 2px solid #AAD178;
}

.semesters-grid tbody tr td.active[data-drag-year="1"] {
    background-color: rgba(170, 209, 120, 0.8);
}

.semesters-grid tbody tr td.active[data-drag-year="2"] {
    background-color: rgba(225, 231, 35, 0.7);
}

.semesters-grid tbody tr td.active[data-drag-year="3"] {
    background-color: rgba(255, 69, 57, 0.7);
}

.semesters-grid tbody tr td.active[data-drag-year="4"] {
    background-color: rgba(255, 191, 61, 0.8);
}

.semesters-grid tbody tr td.active[data-drag-year="5"] {
    background-color: rgba(101, 178, 233, 0.7);
}

.semesters-grid tbody tr td.active[data-drag-year="6"] {
    background-color: rgba(217, 60, 180, 0.7);
}

.semesters-grid tbody tr td.active[data-drag-year="7"] {
    background-color: rgba(177, 80, 197, 0.7);
}

.year-grid thead th {
    border: 1px solid #f3f1f1;
}

.btn.btn-first-bold span {
    font-size: 120%;
    height: 25px;
    width: 25px;
    margin-right: 8px;
    border: 1px solid #fff;
    border-radius: 4px;
    display: inline-block;
    text-align: center;
}

.btn.btn-first-bold span i {
    margin-top: -3px;
}

.btn.btn-first-bold.btn-sm {
    padding: 5px;
}

.btn.btn-first-bold.btn-sm span {
    font-size: 100%;
    height: 20px;
    width: 20px;
    margin-right: 0;
}

#learning-schedule-summary-grid tbody tr td:first-child {
    text-align: left;
}

#learning-schedule-summary-grid tbody tr td:first-child span {
    font-size: 120%;
    height: 25px;
    width: 25px;
    margin-right: 8px;
    border: 1px solid #394263;
    border-radius: 4px;
    display: inline-block;
    text-align: center;
}

#learning-schedule-summary-grid tfoot td:first-child {
    text-align: left;
    padding-left: 37px;
}

#sample-plan-grid thead tr th[data-course],
#hours-grid thead tr th[data-course],
.table-vcenter thead tr th {
    text-align: center;
    font-size: 14px;
    padding-top: 8px;
    padding-bottom: 8px;
}

#sample-plan-grid tbody tr td .discipline_name {
    display: block;
}

#sample-plan-grid tbody tr td .discipline_name ~ .practice_type {
    font-size: 80%;
    margin-left: 15px;
}

#sample-plan-grid tbody tr td .discipline_name ~ .planned-credits {
    display: inline;
}

#sample-plan-grid tbody tr td .discipline_name ~ .planned-credits .auto {
    margin-top: -4px;
    margin-left: 5px;
}

#sample-plan-grid tbody tr td .discipline_name ~ .hours,
#sample-plan-grid tbody tr td .discipline_name ~ .credit,
#sample-plan-grid tbody tr td .discipline_name ~ .planned-credits,
#sample-plan-grid tbody tr td .discipline_name ~ .hours-detailed {
    color: #999;
    font-size: 80%;
    margin-left: 15px;
}

#sample-plan-grid tbody tr td .discipline_name ~ .planned-credits {
    margin-left: 0;
    margin-bottom: 5px;
}

#sample-plan-grid tbody tr td .discipline_name ~ .hours-detailed {
    margin-top: 5px;
    min-width: 200px;
}

#sample-plan-grid tbody tr td .discipline_name ~ .hours,
#sample-plan-grid tbody tr td .discipline_name ~ .credit {
    margin-bottom: 5px;
    display: inline;
}

#sample-plan-grid tbody tr td .discipline_name ~ .credit {
    margin-left: 5px;
}

#sample-plan-grid tbody tr td .discipline_name ~ .credit .form {
    border-bottom: 1px dashed #337ab7;
}

#sample-plan-grid tbody tr td .discipline_name ~ .credit .form:hover,
#sample-plan-grid tbody tr td .discipline_name ~ .credit .form:focus {
    text-decoration: none;
    border-bottom: 1px dashed #1bbae1;
}

#sample-plan-grid tbody tr td .discipline_name ~ .credit i {
    margin-left: 4px;
    margin-top: -3px;
}

#sample-plan-grid thead tr th .hours,
#sample-plan-grid thead tr th .credit,
#sample-plan-grid thead tr th .hours-detailed,
#sample-plan-grid thead tr th .year-hours-detailed,
#hours-grid thead tr th .hours,
#hours-grid thead tr th .credit,
#hours-grid thead tr th .hours-detailed,
#hours-grid thead tr th .year-hours-detailed,
#disciplines-grid thead tr th .summary,
#disciplines-grid thead tr th .start-date {
    color: #999;
    font-size: 80%;
    font-weight: normal;
}

#disciplines-grid thead tr th .start-date {
    font-size: 90%;
    margin-bottom: 5px;
}

#sample-plan-grid thead tr th .hours,
#hours-grid thead tr th .hours {
    margin-bottom: 5px;
}

#sample-plan-grid thead tr th .credit {
    margin-left: 5px;
    margin-bottom: 5px;
}

#sample-plan-grid tbody tr td:nth-child(3) .help-block {
    margin-top: 0;
    margin-left: 7px;
}

#sample-plan-grid tbody tr.discipline-group {
    border-top: 2px solid rgba(170, 209, 120, 0.3);
}

#sample-plan-grid tbody tr.discipline-group > td {
    background-color: rgba(223, 240, 216, 0.5);
}

#sample-plan-grid tbody tr.discipline-group .discipline_name ~ .hours,
#sample-plan-grid tbody tr.discipline-group .discipline_name ~ .credit,
#sample-plan-grid tbody tr.discipline-group .discipline_name ~ .hours-detailed {
    display: none;
}

.workload-column {
    min-width: 100px;
    vertical-align: top !important;
    font-size: 85%;
}

tr.practice .workload-column {
    vertical-align: middle !important;
}

.workload-column .item-container {
    overflow: hidden;
    max-width: 100px;
    margin: 0 auto;
}

#sample-plan-grid thead tr th[data-course].workload-column {
    padding-left: 4px;
    padding-right: 4px;
}

#sample-plan-grid thead tr th[data-course].workload-column .hours {
    display: none;
}

.workload-column .item {
    float: left;
    width: 50%;
    line-height: 1;
    text-align: center;
    margin-bottom: 4px;
}

.workload-column .item.transparent .name,
.workload-column .item.transparent .count,
.workload-column .self-training.transparent,
.workload-column .summary.transparent,
.workload-column .all-summary.transparent,
.workload-column .item-container.transparent .control-hint,
.workload-column .item-container.transparent .control-form {
    opacity: 0.2;
}

.workload-column .item.practice-item {
    width: 100%;
    float: none;
    text-align: left;
    margin-bottom: 0;
}

.editable-table .workload-column .item .count,
.editable-table .workload-column .self-training,
.editable-table .workload-column .control-form {
    display: inline-block;
    cursor: pointer;
    border-bottom: dashed 1px #0088cc;
}

.workload-column .item.practice-item .name {
    float: left;
    width: 70%;
}

.workload-column .item.practice-item .count {
    float: right;
    text-align: center;
    width: 30%;
    margin-top: -1px;
}

.workload-column .summary,
.workload-column .all-summary {
    float: left;
    width: 33%;
    text-align: center;
    font-size: 80%;
    font-weight: bold;
    padding-top: 3px;
}

.workload-column .self-training {
    float: left;
    text-align: center;
    width: 34%;
}

.workload-column .item .name {
    font-size: 80%;
}

.workload-column .item .count {
    font-weight: bold;
}

.workload-column .control-hint {
    float: left;
    width: 33%;
    margin-top: 4px;
}

.workload-column .control-form {
    float: left;
    width: 67%;
    margin-top: 4px;
    font-size: 80%;
    padding-top: 2px;
}

.workload-column .control-form ul {
    padding-left: 4px;
    margin: 0;
    list-style-type: none;
}

.workload-column .control-form div[data-class-type] {
    display: inline;
}

.workload-column .popover-content {
    padding: 0 9px;
}

.workload-column .form-group {
    border-bottom: none;
    padding-top: 5px;
}

.workload-column .credit-summary {
    margin: -13px -13px 7px;
    padding: 5px;
    text-align: center;
}

.workload-column .credit-summary.ok {
    background-color: rgba(0, 175, 67, 0.33);
    color: #fff;
}

.workload-column .credit-summary.error {
    background-color: #e74c3c;
    color: #fff;
}

#hours-panel .workload-column .credit-summary {
    display: none;
}

.planned-credits-mode .workload-column {
    padding-top: 33px;
}

.code-column {
    width: 150px;
}

.competencies-column {
    width: 150px;
}

.department-column {
    width: 150px;
}

.credit-unit-column {
    width: 120px;
}

.summary-column {
    width: 300px;
    vertical-align: top !important;
}

.btn-group label.btn-secondary.active,
.btn-group label.btn-secondary.disabled.active,
.btn-group label.btn-secondary.disabled:focus,
.btn-group label.btn-secondary:hover,
.btn-group label.btn-secondary:focus {
    color: #fff !important;
}

#sample-plan-grid .mode-disciplines .summary-column,
#sample-plan-grid .mode-disciplines .planned-credits-column,
#sample-plan-grid .mode-disciplines .workload-column {
    display: none;
}

#sample-plan-grid .mode-credits .action-column,
#sample-plan-grid .mode-credits .code-column,
#sample-plan-grid .mode-credits .discipline-column,
#sample-plan-grid .mode-credits .competencies-column,
#sample-plan-grid .mode-credits .department-column,
#sample-plan-grid .mode-credits .credit-unit-column,
#sample-plan-grid .mode-credits .workload-column {
    display: none;
}

#sample-plan-grid .mode-hours .action-column,
#sample-plan-grid .mode-hours .code-column,
#sample-plan-grid .mode-hours .discipline-column,
#sample-plan-grid .mode-hours .competencies-column,
#sample-plan-grid .mode-hours .department-column,
#sample-plan-grid .mode-hours .credit-unit-column,
#sample-plan-grid .mode-hours .planned-credits-column {
    display: none;
}

.planned-credits-column input[type="text"] {
    text-align: center;
}

.not-set {
    color: #99abb4 !important;
}

.file-item-short {
    display: inline-block;
    overflow: hidden;
    text-align: left;
    color: #394263;
    margin: 10px;
}

table td .file-item-short {
    float: left;
    width: 48%;
    display: block;
}

table.detail-view td .file-item-short {
    float: none;
    width: auto;
    display: block;
}

.file-item-short:hover,
.file-item-short:focus,
.file-item-short:active {
    text-decoration: none;
    color: inherit;
}

.file-item-short .file-item-image {
    float: left;
}

.file-item-short .file-item-image .fa,
.file-item-short .file-item-image .fi {
    line-height: 1;
}

.file-item-short .file-item-image .fa-image {
    font-size: 2.7rem;
    margin-top: 5px;
}

.file-item-short .file-item-info {
    margin-left: 50px;
    color: #777;
    font-size: 12px;
    padding: 5px 0;
}

.file-item-short .file-item-name {
    color: #394263;
    font-weight: bold;
    font-size: 16px;
}

.file-item-short .file-item-size {
    display: inline-block;
}

.file-item-short .file-item-status {
    display: inline-block;
}

.file-item-short .file-item-size + .file-item-status::before {
    content: "|";
    display: inline-block;
    margin: 0 3px;
}

#topics-summary-grid thead th,
#topics-summary-grid tbody tr td,
#topics-summary-grid tfoot tr td {
    text-align: center;
}

#topics-summary-grid tbody tr .code-column {
    text-align: left;
}

#topics-summary-grid tfoot tr .code-column {
    text-align: right;
    font-weight: bolder;
}

#topics-summary-grid tbody td span.current,
#topics-summary-grid tfoot td span.current {
    font-weight: bold;
}

#topics-grid .code-column {
    width: 150px;
    max-width: 150px;
}

#topics-grid .hours-column {
    width: 100px;
    max-width: 100px;
}

.sequence-table .link-row {
    border-top: 2px solid #e67e22;
    border-left: 2px solid #e67e22;
    border-right: 2px solid #e67e22;
}

.sequence-table .link-row + .link-row {
    border-top: 1px solid #ddd;
}

.sequence-table .link-end {
    border-bottom: 2px solid #e67e22;
    border-left: 2px solid #e67e22;
    border-right: 2px solid #e67e22;
}

.sequence-table .link-row td,
.sequence-table .link-end td {
    background-color: rgba(230, 126, 34, 0.05);
}

.sequence-table td.code-column,
.sequence-table td.hours-column,
.sequence-table td.join-column {
    text-align: center;
}

.sequence-table .code-column {
    width: 50px;
}

.sequence-table .hours-column,
.sequence-table .join-column {
    width: 70px;
}

.sequence-table .class-type-column,
.sequence-table .comments-column {
    width: 200px;
}

.nav .nav-item .nav-link .spinner-border {
    position: absolute;
    margin-left: 8px;
    width: 1.5rem;
    height: 1.5rem;
}

.wp-count + .spinner-border {
    margin-top: -5px;
    position: absolute;
    margin-left: 5px;
}

.input-group-append .spinner-border {
    position: absolute;
    margin-left: -37px;
    margin-top: 2px;
}

.form-group.row > label {
    position: relative;
}

.form-group.row > label > .spinner-border {
    position: absolute;
    right: 0;
    top: 2px;
}

#load-calc-params-main-year-grid .boolean-column,
#load-calc-params-study-summary-grid .boolean-column,
#load-calc-params-study-groups-grid .boolean-column,
#load-calc-params-study-norms-grid .boolean-column {
    width: 150px;
    text-align: center;
}

#load-calc-params-study-norms-grid .type-column {
    width: 440px;
}

.card-footer {
    overflow: hidden;
}

.btn-group + .status {
    position: absolute;
    margin-top: 4px;
    margin-left: 10px;
}

#load-calc-params-main-year-grid tr.disabled,
#load-calc-params-study-summary-grid tr.disabled,
#load-calc-params-study-groups-grid tr.disabled,
#load-calc-params-study-norms-grid tr.disabled {
    opacity: 0.33;
}

.wizard-content .wizard>.actions>ul {
    float: none;
    display: flex;
    justify-content: flex-end;
}

.nav-photos {
    padding: 0;
    margin: -20px;
}

.nav-photos li {
    display: block;
}

.nav-photos li.active a {
    background-color: #d4e5e9;
}

.nav-photos li a {
    padding: 15px 20px;
    overflow: hidden;
    display: block;
}

.nav-photos li a img {
    width: 40px;
    height: 40px;
    border-radius: 4px;
    border: 2px solid #c0c0c0;
    margin-right: 10px;
    float: left;
}

.nav-photos li.active a img {
    border-color: #fff;
}

.nav-photos li a .name {
    font-weight: bold;
    font-size: 16px;
    line-height: 1.3;
}

.nav-photos li a .hours {
    font-size: 12px;
}

#documents-data-form table .value-column {
    width: 110px;
}

#documents-data-form table .mark-column {
    width: 150px;
}

.form-group.row > .col-9 > [type="checkbox"] + label {
    margin-top: 7px;
    margin-bottom: 0;
}

#document-preview {
    background: no-repeat left top;
    position: relative;
    border: 1px solid #000000;
    overflow: hidden;
}

.document-field {
    position: absolute;
    border: 1px solid rgba(255, 255, 255, 0.5);
    margin: -1px 0 1px 0;
    background: rgba(255, 255, 255, 0.5);
    font-family: "Times New Roman", serif;
    overflow: hidden;
    cursor: pointer;
}

.document-field:hover,
.document-field.active {
    border-color: rgb(0, 61, 115);
    background: rgba(0, 61, 115, 0.33);
}

.card .flex-column .nav-link > .spinner-border {
    position: absolute;
    right: 10px;
    margin-top: -4px;
}

#rights .tab-content ul {
    list-style: none;
    padding: 0;
    columns: 2;
}

.lesson-mark {
    color: #ccc;
}

.lesson-mark + .lesson-mark:before {
    content: "/";
    color: #ccc;
    margin-right: 3px;
}

.lesson-mark + .lesson-mark {
    margin-left: 3px;
}

.lesson-mark:last-child {
    color: #333;
}

.lesson-mark.debt,
.lesson-mark.skip {
    color: #a94442;
}

.marks + .add-mark,
.marks + .add-mark + .add-document,
.marks + a,
.marks + a ~ a {
    margin-left: 10px;
}

.form-check {
    padding-left: 0;
}

a.edit-field {
    cursor: pointer;
    border-bottom: dashed 1px #1bbae1;
}

a.edit-field:hover,
a.edit-field:focus {
    text-decoration: none;
}

.table-block tbody tr {
    border-left: 3px solid #ced1d5;
    border-right: 3px solid #ced1d5;
}

.table-block tbody tr.start-row,
.table-block tbody tr:first-child {
    border-top: 3px solid #ced1d5;
}

.table-block tbody tr:last-child {
    border-bottom: 3px solid #ced1d5;
}

.table tr.transparent td {
    color: rgba(57, 66, 99, 0.4);
}

.table tr.transparent td .btn {
    opacity: 0.25;
}

.table .lesson-info {
    font-size: 80%;
}

.table .lesson-info + .lesson-info {
    margin-top: 5px;
    padding-top: 5px;
    border-top: 1px solid #eaedf1;
}

.table .lesson-info .row {
    margin-left: -5px;
    margin-right: -5px;
}

.table .lesson-info .row + .row {
    margin-top: 5px;
}

.table .lesson-info .col-xs-6 {
    padding-left: 5px;
    padding-right: 5px;
    word-break: break-word;
}

.table .lesson-info .col-xs-6:last-child {
    text-align: right;
}

.table tr.transparent .busy-column {
    color: rgba(57, 66, 99, 1);
}

.table .busy-column {
    border-left: 3px solid #ccc;
}

.table th.date-column {
    width: 45px;
}

.table td.date-column,
.table tr.transparent td.date-column {
    color: rgba(57, 66, 99, 1);
    font-weight: bold;
    font-size: 125%;
    position: relative;
}

.table .date-column .vertical {
    -webkit-transform: rotate(-90deg);
    -moz-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    -o-transform: rotate(-90deg);
    transform: rotate(-90deg);
    position: absolute;
    top: 50%;
    left: -78px;
    margin-top: -25%;
    white-space: nowrap;
    text-align: center;
    width: 200px;
}

.schedule-table .day-start td {
    border-top: 3px solid #2cc76c;
}

.schedule-table .day-start:first-child td {
    border-top: inherit;
}

.schedule-table .day-start td:first-child {
    background-color: transparent;
}

.schedule-table .btn {
    padding: 2px 8px;
}

.schedule-table .time-column {
    text-align: center;
    white-space: nowrap;
}

.schedule-table td {
    height: 12px;
}

.schedule-table .action-column .btn-group {
    width: 100%;
}

.card .card-header .card-actions .spinner-border {
    position: absolute;
    margin-top: -5px;
    margin-left: -30px;
}

.col-form-label > .spinner-border {
    position: absolute;
    margin-top: -4px;
    margin-left: 10px;
}

.table td > input + label {
    margin: 0;
}

#load-groups-grid .year-column {
    width: 150px;
}

.chart {
    width: 150px;
    height: 150px;
}

.sl-item .comments .sl-item {
    margin-left: 60px;
}

.sl-item .sl-right img {
    max-width: 100%;
}

.datepicker {
    padding: 10px 20px;
}

.new-year-background .left-sidebar .user-profile {
    background-image: url('../images/background/new-year.jpg') !important;
    background-position: center;
    background-size: cover;
}

.new-year-background .navbar-header {
    background-image: url('../images/background/new-year-logo.png');
    background-position: center right;
    background-size: contain;
    background-repeat: no-repeat;
}

.left-sidebar {
    padding-top: 50px;
}

.number-column {
    width: 80px;
}

.note-toolbar {
    z-index: 33;
}

.staff-item {
    display: flex;
    flex-direction: row;
}

.staff-item .user-img img {
    width: 45px;
}

.staff-item + .staff-item {
    margin-top: 10px;
}

.staff-item .mail-desc {
    font-size: 12px;
    color: #67757c;
}

.table.detail-view tbody tr th:first-child {
    vertical-align: middle;
}

.grid-status-headers {
    overflow: hidden;
    margin: 0 0 20px;
}

.grid-status-headers .header-item {
    width: 20%;
    float: left;
    text-align: center;
    position: relative;
    padding-top: 54px;
}

.grid-status-headers .header-item .step {
    width: 50px;
    height: 50px;
    line-height: 45px;
    border: 3px solid #009efb;
    font-size: 1.3rem;
    border-radius: 50%;
    display: inline-block;
    position: absolute;
    top: 0;
    left: 50%;
    margin-left: -24px;
    z-index: 10;
    text-align: center;
    background-color: #fff;
    color: #009efb;
}

.grid-stack-item .ribbon-corner.ribbon-right {
    right: 10px;
    z-index: 1;
    padding: 1px 5px 0 0;
}

.grid-stack-item .ribbon-corner.ribbon-right::before {
    border-top-right-radius: 10px;
    border-width: 25px;
}

.grid-stack-container {
    background: rgba(206, 217, 231, 0.5);
    padding: 10px;
    margin: 0 -20px;
    position: relative;
}

.grid-stack-container-header {
    background: rgb(206, 217, 231);
    font-size: 1.25rem;
    font-weight: bold;
    padding: 0 22px 5px;
    margin: 0 -20px;
    color: #333;
    position: relative;
}

.grid-stack-container-header.danger {
    background-color: rgba(220, 0, 50, 0.35);
    color: #a32136;
    padding-bottom: 0;
}

.grid-stack-container-header.danger + .grid-stack-container {
    background-color: rgba(220, 0, 50, 0.17);
}

.grid-stack-container-header.warning {
    background-color: rgba(222, 139, 5, 0.35);
    color: #a32136;
    padding-bottom: 0;
}

.grid-stack-container-header.warning + .grid-stack-container {
    background-color: rgba(222, 139, 5, 0.17);
}

.grid-stack-container-header a {
    color: inherit;
    border-bottom: 2px dashed #333;
}

.grid-stack-container-header .btn-collapse {
    border-bottom: none;
    font-weight: bold;
}

.grid-stack-container-header .items {
    font-size: 1rem;
    list-style: none;
    display: inline;
    margin: 0 0 0 20px;
    padding: 0;
    position: relative;
    z-index: 10;
    background: rgb(206, 217, 231);
}

.grid-stack-container-header .items::before {
    content: "\f054";
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    margin-right: 20px;
    color: #999;
}

.grid-stack-container-header .items li {
    display: inline-block;
    font-weight: normal;
    margin-right: 10px;
}

.grid-stack-container-header .items li a {
    border-bottom: 1px dashed #333;
}

.grid-stack-container ~ .footer-block {
    margin-top: 0;
}

.grid-stack > .grid-stack-item > .grid-stack-item-content {
    overflow-y: hidden;
}

.grid-stack-item-content {
    background-color: rgb(246, 249, 249);
    border-radius: 10px;
    font-size: 0.85rem;
    text-align: left;
    position: relative;
}

.grid-stack > .grid-stack-item > .grid-stack-item-content {
    border: 2px solid rgba(125, 155, 192, 0.5);
}

.grid-stack > .grid-stack-item > .grid-stack-item-content[data-performer^="support"] {
    border-color: #6dcb99;
}

.grid-stack > .grid-stack-item > .grid-stack-item-content[data-performer^="director"] {
    border-color: #ea002a;
}

.grid-stack > .grid-stack-item > .grid-stack-item-content[data-performer^="sales"] {
    border-color: #3db5e6;
}

.grid-stack-item-header {
    height: 25px;
    padding: 2px 5px;
    border-bottom: 1px solid rgba(125, 155, 192, 0.5);
    color: #003a70;
}

.grid-stack-item-header a {
    color: inherit;
    font-weight: bold;
}

.grid-stack-item-header .time {
    font-size: 85%;
    margin-left: 5px;
}

.grid-stack-item-header .time.warning {
    color: #ffb22b;
}

.grid-stack-item-header .time.danger {
    color: #a32136;
}

.grid-stack-item-header .module {
    font-size: 75%;
    margin-left: 5px;
    background: rgba(0, 58, 112, 0.2);
    padding: 1px 4px;
    border-radius: 4px;
    float: right;
    position: relative;
    top: 2px;
    z-index: 10;
}

.grid-stack-item-body {
    height: 80px;
    padding: 2px 5px;
    line-height: 1.2;
}

.grid-stack-item-body small {
    color: rgb(125, 155, 192);
}

.grid-stack-item-footer {
    height: 25px;
    padding: 2px 5px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: inherit;
    border-top: 1px solid rgba(125, 155, 192, 0.5);
    display: flex;
    flex-direction: row;
}

.grid-stack-item-footer .item {
    margin: 0 5px;
    color: rgb(125, 155, 192);
}

.grid-stack-item-footer .item:first-child {
    margin-left: 0;
    margin-right: auto;
}

.grid-stack-item-footer .item:last-child {
    margin-right: 0;
}

.grid-stack-separator {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 1px;
    background-color: rgba(125, 155, 192, 0.5);
}

.grid-stack-separator.item-1 {
    left: 20%;
    left: calc(20% + 6px);
}

.grid-stack-separator.item-2 {
    left: 40%;
    left: calc(40% + 2px);
}

.grid-stack-separator.item-3 {
    left: 60%;
    left: calc(60% - 2px);
}

.grid-stack-separator.item-4 {
    left: 80%;
    left: calc(80% - 6px);
}

.grid-stack-container-status {
    position: absolute;
    bottom: 5px;
    font-weight: normal;
    font-size: 0.8rem;
    padding: 0 5px;
    border-radius: 4px;
    border: 2px solid rgba(125, 155, 192, 0.5);
    background-color: #fff;
    z-index: 2;
}

.grid-stack-container-status tr td:first-child {
    padding-right: 10px;
}

.grid-stack-container-status tr td:last-child {
    text-align: right;
}

.grid-stack-container-status.item-1 {
    right: 80%;
    right: calc(80% - 6px + 4px);
}

.grid-stack-container-status.item-2 {
    right: 60%;
    right: calc(60% - 2px + 4px);
}

.grid-stack-container-status.item-3 {
    right: 40%;
    right: calc(40% + 2px + 4px);
}

.grid-stack-container-status.item-4 {
    right: 20%;
    right: calc(20% + 6px + 4px);
}

.grid-stack-container-status.item-5 {
    right: 0%;
    right: calc(4px);
}

.grid-stack-container-date {
    position: absolute;
    top: 8px;
    font-weight: normal;
    font-size: 0.8rem;
    padding: 0 5px;
    z-index: 1;
    left: 80%;
    left: calc(80% - 6px);
    color: #999;
}

.grid-stack-container-date span {
    font-weight: bold;
}

.grid-stack-placeholder .placeholder-content {
    background: #fff;
}

.grid-stack {
    min-height: 25px;
}

.grid-stack > .empty {
    padding: 0 10px;
}

.grid-stack-item.transparent {
    opacity: 0.5;
    transition: opacity 0.3s;
}

.grid-item-selector {
    position: absolute;
    background-color: rgb(234, 237, 237);
    z-index: 2;
    top: 123px;
    right: 20px;
    border-radius: 0 0 10px 10px;
    border: 2px solid rgba(125, 155, 192, 0.5);
}

.grid-item-selector ul {
    margin: 0;
    padding: 0;
    list-style: none;
    min-width: 70px;
    font-size: 0.85rem;
}

.grid-item-selector a {
    display: block;
    padding: 2px 5px;
    border-bottom: 1px solid rgba(125, 155, 192, 0.5);
    color: rgb(66, 92, 128);
}

.grid-item-selector a:hover {
    background-color: rgb(221, 224, 224);
}

.grid-item-selector:last-child a {
    border-bottom: none;
}

.grid-item-selector[data-name="performer"] {
    right: auto;
    left: 15px;
}

.grid-item-selector[data-name="performer"] a {
    padding-right: 20px;
    white-space: nowrap;
}

.grid-item-selector[data-name="performer"] a + ul {
    display: none;
}

.grid-item-selector[data-name="performer"] > ul > li {
    position: relative;
}

.grid-item-selector[data-name="performer"] a.parent::after {
    content: "\f061";
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    position: absolute;
    right: 4px;
    top: 2px;
    opacity: 0.33;
}

.grid-item-selector[data-name="performer"]  > ul > li:hover > ul {
    display: block;
    position: absolute;
    left: 100%;
    top: -2px;
    background-color: rgb(234, 237, 237);
    z-index: 2;
    border-radius: 0 10px 10px 0;
    border: 2px solid rgba(125, 155, 192, 0.5);
}

.color-point {
    display: inline-block;
    width: 24px;
    height: 24px;
    background-color: #CED9E7;
    margin: 0 15px;
    position: relative;
    top: 6px;
    opacity: 0.5;
}

.pantone-selector {
    margin-top: 20px;
    border: 1px solid #CED9E7;
    background-color: rgba(206, 217, 231, 0.25);
    padding: 15px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

.pantone-selector .item {
    margin: 0 15px 15px 0;
    border-radius: 4px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05);
    background-color: #fff;
    width: 60px;
    cursor: pointer;
}

.pantone-selector .item .color {
    height: 60px;
}

.pantone-selector .item .name {
    font-size: 70%;
    padding: 5px;
}

#history-table .type-column,
#history-table .datetime-column,
#history-table .user-column {
    max-width: 120px;
}

#history-table .file-item-short {
    margin: 0 20px 0 0;
    width: auto;
}

#history-table .file-item-short .file-item-info {
    margin-left: 20px;
    padding: 0;
}

.card .card-subtitle {
    margin-bottom: 0;
}

small.documents a {
    margin-right: 8px;
}

.grid-stack-item-headers {
    display: flex;
    justify-content: center;
}

.grid-stack-item-content .grid-stack-item-headers {
    display: none;
    float: right;
}

.grid-stack-item-headers .header-item {
    display: block;
    float: left;
    margin-top: 1px;
}

.grid-stack-item-headers .header-item .step {
    width: 16px;
    height: 16px;
    line-height: 14px;
    border: 2px solid #009efb;
    font-size: 0.7rem;
    border-radius: 50%;
    display: inline-block;
    z-index: 10;
    text-align: center;
    background-color: #fff;
    color: #009efb;
    opacity: 0.3;
}

.grid-stack-item-headers .header-item .step.active {
    opacity: 1;
}

.grid-stack-item-headers .header-item .step.success {
    border: 2px solid #26c6da;
    color: #26c6da;
    transform: scale(1.5);
}

.col-md-3 > .card > .card-body > .nav,
.col-md-3 > div > .card > .card-body > .nav {
    margin: -10px -20px;
}

.col-md-3 > .card > .card-body > .nav + .nav,
.col-md-3 > div > .card > .card-body > .nav + .nav {
    margin-top: 10px;
}

.col-md-3 > .card > .card-body > p:first-child,
.col-md-3 > div > .card > .card-body > p:first-child {
    margin-top: 0;
}

.col-md-3 > .card > .card-body > p,
.col-md-3 > div > .card > .card-body > p {
    margin: 10px -5px 0;
}

.col-md-3 > .card > .card-body > .nav a.disabled,
.col-md-3 > div > .card > .card-body > .nav a.disabled {
    opacity: 0.5;
}

.col-md-3 > .card > .card-body > hr,
.col-md-3 > div > .card > .card-body > hr {
    margin: 1rem -20px;
}

.col-md-3 > .card > .card-body > .nav[hidden] + hr,
.col-md-3 > div > .card > .card-body > .nav[hidden] + hr {
    display: none;
}

.nav-pills .collapse.show > .nav-link {
    color: #1e88e5;
    background-color: inherit;
    padding-left: 2rem;
}

#swal2-content > .text-left {
    font-size: 1rem;
}

.btn-group > .dropdown:first-child .btn {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.btn-group > .dropdown:last-child .btn {
    border-top-right-radius: .25rem;
    border-bottom-right-radius: .25rem;
}

.ribbon + .ribbon {
    top: 45px;
}

small.ribbon {
    height: 24px;
    line-height: 24px;
}

.dropdown-item.disabled,
.dropdown-item:disabled {
    color: #adb5bd;
}

.footer-block {
    margin: 1.25rem -1.25rem -1.25rem;
    padding: .75rem 1.25rem;
    background-color: rgba(0,0,0,.03);
    border-top: 1px solid rgba(0,0,0,.125);
    border-radius: 0 0 calc(.25rem - 1px) calc(.25rem - 1px);
}

.wizard-content .wizard {
    overflow: inherit;
}

#source-files .collapse {
    font-size: 14px;
}

.card-actions form {
    display: inline-block;
}

.card-actions button[type="submit"] {
    cursor: pointer;
    color: #67757c;
    opacity: 0.7;
    padding-left: 7px;
    font-size: 13px;
    outline: none;
    border: none;
    background: none;
}

.card-actions button[type="submit"]:hover {
    opacity: 1;
}

.profiling-wrapper {
    position: relative;
}

.profiling-wrapper .profiling-data {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 10;
    font-size: 70%;
    display: flex;
    background: rgba(0, 0, 0, 0.05);
    border-bottom-left-radius: 4px;
    border-top-right-radius: 4px;
    border: 1px solid #d7dfe3;
}

.profiling-wrapper .profiling-data .item {
    padding: 1px 3px;
}

.nav-item.profiling-wrapper .profiling-data {
    border-radius: 0 0 4px 4px;
    font-size: 60%;
    top: -1px;
}

.line-height-12 {
    line-height: 1.2;
}

.form-group.form-submit-block {
    margin: 1.25rem -1.25rem -1.25rem;
    padding: .75rem 1.25rem;
    background-color: rgba(0,0,0,.03);
    border-top: 1px solid rgba(0,0,0,.125);
    border-radius: 0 0 calc(.25rem - 1px) calc(.25rem - 1px);
}

.widgets-grid .grid-stack-item {
    cursor: move;
}

.widgets-grid .grid-stack-item .grid-stack-item-content {
    border-color: #d7dfe3;
    border-radius: 4px;
    -webkit-box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05);
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05);
    height: 60px;
    display: flex;
    justify-content: center;
    text-align: center;
    flex-direction: column;
    font-size: 16px;
}

.widgets-grid .grid-stack-container {
    margin: 10px 0 20px;
    padding: 10px 0;
    background-color: rgba(206, 217, 231, 0.25);
    position: relative;
}

.widgets-grid .grid-stack-headers {
    display: flex;
    flex-direction: row;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
}

.widgets-grid .grid-stack-headers [class^="col-"] {
    padding: 0;
}

.widgets-grid .widgets-row {
    position: relative;
}

.widgets-grid .grid-stack-headers .item {
    border-right: 1px solid rgba(206, 217, 231, 0.5);
    height: 100%;
}

.widgets-grid .grid-stack-headers [class^="col-"]:last-child {
    display: none;
}

.widgets-grid .widgets-row[data-id="-1"] .grid-stack > .grid-stack-item[data-gs-x="0"] {
    left: 0;
    width: 100%;
}

.w-64px {
    width: 64px;
}

.message-box .message-widget a.active {
    background: #eceef0;
}

.rounded-end{
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

hr {
    border-color: rgba(0, 0, 0, .5);
}

.overflow-x-scroll {
    overflow-x: scroll;
}

.topbar ul.dropdown-user li .dw-user-box {
    display: flex;
    gap: 15px;
}

.topbar ul.dropdown-user li .dw-user-box .u-text {
    padding-left: 0;
    padding-top: 0;
}

.mini-sidebar .sidebar-nav #sidebarnav > li:hover > a {
    width: 310px;
    border-bottom-right-radius: 0;
    background: #1e88e5 !important;
}

.mini-sidebar .sidebar-nav #sidebarnav > li > ul {
    width: 255px;
}

.mini-sidebar .sidebar-nav #sidebarnav > li > a {
    max-height: 51px;
    transition: none;
}

.mini-sidebar .sidebar-nav #sidebarnav > li:hover > a .hide-menu {
    display: inline-block;
}

.gap-20 {
    gap: 20px;
}

.card-image {
    width: 100px;
    height: 100px;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.card-image-contain {
    background-size: contain;
}

@media (max-width: 1024px) {
    .table textarea.form-control,
    .table input.form-control,
    .table select.form-control {
        padding: .175rem .375rem;
    }

    .table th,
    .table td {
        padding: .375rem;
    }
}

@media (max-width: 768px) {
    .grid-stack-separator {
        display: none;
    }

    .grid-status-headers {
        display: none;
    }

    .tasks-index {
        margin-top: -20px;
    }

    .grid-stack-item-headers {
        display: inline-block;
    }

    .wizard-content .wizard>.steps>ul>li {
        display: table-cell;
        width: auto;
        float: none;
    }

    .wizard-content .wizard>.steps>ul>li a {
        font-size: 0;
        padding-top: 30px;
        margin-top: 5px;
    }

    .wizard-content .wizard.wizard-circle>.steps .step {
        width: 32px;
        height: 32px;
        line-height: 30px;
        font-size: 1rem;
    }

    .wizard-content .wizard.wizard-circle>.steps>ul>li:after,
    .wizard-content .wizard.wizard-circle>.steps>ul>li:before {
        top: 20px;
    }

    .wizard-content .wizard>.steps .step {
        margin-left: -16px;
    }

    .card-actions {
        float: none;
    }

    .card-actions button[type="submit"],
    .card-actions a {
        padding-left: 0;
        padding-right: 7px;
    }

    .grid-stack.grid-stack-5 > .grid-stack-item[data-gs-width="1"] {
        width: 100%;
    }

    .grid-stack-item-content .grid-stack-item-headers {
        display: block;
    }

    .grid-stack-container-status,
    .grid-stack-container-date {
        display: none;
    }

    .page-titles .col-xs-4 {
        text-align: left;
    }
}



@media (max-width: 560px) {
    .login-register .login-box {
        width: 100%;
    }

    .login-register .login-box .card,
    .login-register .login-box .card .card-header {
        border-radius: 0;
    }
}