@charset "utf-8";
/*********************************
reset
*********************************/
* {
	box-sizing: border-box;
}
html {
	overflow-y: scroll;
}
/* http://meyerweb.com/eric/tools/css/reset/ v2.0 | 20110126 License: none (public domain) */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1.15;
}
/*ol, ul {
	list-style: none;
}*/
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-spacing: 0;
	width: 100%;
}
img {
	max-width: 100%;
	height: auto;
}
hr {
	margin: 18px 0;
}
/*********************************
loader
*********************************/
.loader {
	align-items: center;
	background-color: #fff;
	display: flex;
	height: 100%;
	justify-content: center;
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
}
.loader,
.loader * {
	will-change: auto;
}
.dot-loader {
    -webkit-animation: 1.2s scaleDown ease-in-out infinite ;
    animation: 1.2s scaleDown ease-in-out infinite ;
	background-color: #000f9f;
	border-radius: 50%;
	height: 15px;
	position: relative;
	width: 15px;
}
.page-admin .dot-loader {
    background-color: #000;
}
.dot-loader:nth-child(2) {
    margin: 0 12px;
    -webkit-animation: 1.2s scaleDown ease-in-out infinite .15555s;
    animation: 1.2s scaleDown ease-in-out infinite .15555s;
}
.dot-loader:nth-child(3) {
    -webkit-animation: 1.2s scaleDown ease-in-out infinite .300000s;
    animation: 1.2s scaleDown ease-in-out infinite .300000s;
}
@-webkit-keyframes scaleDown {
    0%, 80%, 100%{
      -webkit-transform: scale(0);
              transform: scale(0);
    }
    40%{
      -webkit-transform: scale(1);
              transform: scale(1);
    }
}
@keyframes scaleDown {
    0%, 80%, 100%{
      -webkit-transform: scale(0);
              transform: scale(0);
    }
    40%{
      -webkit-transform: scale(1);
              transform: scale(1);
    }
}
/*********************************
font
*********************************/
.page-admin input,
.page-certificates textarea,
.page-admin textarea {
	font: inherit;
}
/* font-family */
body {
	font-family: sans-serif;
}
/* color */
body,
.button:not(.submit-container) a,
.button.submit-container input {
	color: #000f9f;
}
.save-button span.saved {
	color: #008000;
}
body.page-certificates,
body.page-admin,
.breadcrumb,
.breadcrumb .delimiter,
.breadcrumb a:hover,
.save-button span.save:hover,
.sesame-item:hover,
body.page-certificates .criterias textarea.active,
.page-certificates .criterias textarea[readonly]:hover,
.checkbox-wrap:hover,
.checkbox-wrap input:checked ~ .check,
.page-admin .add span:hover,
.page-admin .add-form input {
	color: #333;
}
footer .inside {
	color: #747474;
}
.breadcrumb a,
.save-button span,
.sesame-item,
.checkbox-wrap,
.page-admin .eye input + .visible + .invisible,
.page-admin .add span {
	color: #aaa;
}
aside,
.button:not(.submit-container) a:hover,
.button.submit-container input:hover,
.success-message,
.error-message,
.loggedin-header h1,
#toTop a {
	color: #fff;
}
.page-certificates .criterias textarea[readonly] {
	color: #7f7f7f;
}
a,
input,
hr {
	color: inherit;
}
.color-red {
	color: red;
}
/* font-size */
footer .credits,
footer .right span {
	font-size: 10px;
}
.count,
.page-certificates .no-show-custom-text,
.page-certificates .custom-text,
#admin-nav .subnav a,
.page-admin .add-form input {
	font-size: 11px;
}
.button:not(.submit-container) a,
.button.submit-container input,
.success-message,
.error-message,
.main-header,
.sesame,
.page-certificates th,
.page-certificates .no-show-wrap h3,
#admin-nav ul li.level_1 > a,
.page-admin .section-header .visible-switch,
.page-admin th,
.page-admin .add span,
aside nav ul li a,
footer .inside {
	font-size: 12px;
}
.page-certificates td,
.page-certificates .no-show-wrap,
.page-admin td {
	font-size: 14px;
}
.checkbox-wrap .la {
	font-size: 16px;
}
.loggedin-header .right .la,
.page-admin .section-header .visible-switch .la,
.page-admin .add span i,
.save-button .la,
footer .la-keyboard-o {
	font-size: 18px;
}
h1 {
	font-size: 21px;
}
aside nav ul li a .la {
	font-size: 24px;
}
.page-certificates .student > p:before,
.page-certificates .subject > p:before {
	font-size: 30px;
}
/* font-weight */
.button:not(.submit-container) a,
.button.submit-container input,
.page-certificates th,
.count,
.page-admin .section-header .visible-switch,
.page-admin th,
.page-admin .add span,
#admin-nav ul li.level_1 > a,
.page-certificates .no-show-wrap h3,
.page-certificates .student > p:before,
.page-certificates .subject > p:before  {
	font-weight: bold;
}
/* line-height */
.page-admin .add-form input {
	line-height: 1;
}
.page-certificates td,
.page-admin td {
	line-height: 1.15;
}
.success-message,
.error-message,
#top textarea {
	line-height: 1.2;
}
.page-certificates .student > p:before,
.page-certificates .subject > p:before {
	line-height: 16px;
}
#toTop a {
	line-height: 35px;
}
/* text-align */
body.page-certificates,
body.page-admin,
.align-left {
	text-align: left;
}
body,
.loggedin-header .center,
#admin-nav ul li.level_1 > a,
#toTop a,
footer .center {
	text-align: center;
}
.loggedin-header .right,
.submit-container,
.page-certificates .no-show-custom-text,
.page-certificates .custom-text,
footer .right {
	text-align: right;
}
/* text-decoration */
a {
	text-decoration: none;
}
.forgot,
.underline {
	text-decoration: underline;
}
/* text-transform */
.button:not(.submit-container) a,
.button.submit-container input,
#admin-nav ul li.level_1 > a {
	text-transform: uppercase;
}
/*********************************
z-index & sticky top
*********************************/
.page-certificates .student > p.open + .criterias th,
.page-certificates td.criteria {
	z-index: 100;
}
.page-certificates .student > p.open {
	z-index: 101;
}
.page-admin section .section-header,
.page-admin section th {
	z-index: 9999;
}
.main-header,
.page-admin table.text-blocks td {
	z-index: 10000;
}
.page-admin aside,
.page-admin .loggedin-header {
	z-index: 10001;
}
#toTop {
	z-index: 100000;
}
.loader {
	z-index: 100001;
}
/* sticky top */
.main-header {
	top: -1px;
}
.page-admin .main-header {
	top: 63px;
}
.page-certificates .student > p.open + .criterias th {
	top: 78px;
}
.page-certificates td.criteria {
	top: 102px;
}
.page-admin section .section-header {
	top: 115px;
}
.page-admin section th {
	top: 137px;
}
.page-admin table.text-blocks td {
	top: 153px;
}
/*********************************
global settings
*********************************/
progress {
	width: 100%;
}
.relative {
	position: relative;
}
.jconfirm-hidden .jconfirm,
.jconfirm-hidden .jconfirm * {
	height: 0 !important;
	left: -10000px;
	max-height: 0 !important;
	max-width: 0 !important;
	overflow: hidden !important;
	position: absolute !important;
	transition: none !important;
	visibility: hidden !important;
	width: 0 !important;
	z-index: -100 !important;
}
.jconfirm .jconfirm-box div.jconfirm-content-pane .jconfirm-content {
	overflow: hidden;
}
.hidden{
	display: none!important;
}
ul {
	will-change: auto;
}
main,
footer {
	background-color: #fff;
	visibility: hidden;
	opacity: 0;
}
/*p {
	margin-bottom: 5px;
}*/
.flex {
	display: flex;
}
.flex-wrap {
	flex-wrap: wrap;
}
.flex-wrap > * {
	width: 100%;
}
.grid {
	display: grid;
}
.grid-3-1 {
	grid-template-columns: 1fr 1fr 1fr;
	grid-template-rows: 1fr;
}
.align-center {
	align-items: center;
}
.justify-center {
	justify-content: center;
}
.justify-right {
	justify-content: flex-end;
}
.space-between {
	justify-content: space-between;
}
.sticky {
	background-color: #fff;
	position: sticky;
}
#wrapper {
	min-height: 100vh;
}
.page-admin #wrapper {
	padding-top: 63px;
	padding-left: 120px;
}
main > .inside,
.page-member header > .inside,
.page-logout header > .inside,
footer .inside {
	max-width: 1280px;
	margin: 0 auto;
	padding: 10px;
}
.success-message,
.error-message {
	background-color: #c1392b;
	padding: 5px;
	margin: 0 auto 10px;
	max-width: 310px;
}
.success-message {
	background-color: #0d8842;
}
#toTop {
	bottom: 48px;
	position: fixed;
	right: 8px;
}
#toTop a {
	background-color: #474747;
	border-radius: 100%;
	border: 2px solid #aaa;
	display: block;
	height: 35px;
	width: 35px;
}
#toTop a:hover {
	background-color: #1e1e1e;
}
/*********************************
buttons
*********************************/
.save-button .la {
	margin-right: 5px;
	position: relative;
	top: 2px;
}
.save-button span {
	display: inline-block;
	padding: 10px 0;
}
.save-button span.saved {
	display: none;
}
.save-button span.save:hover {
	cursor: pointer;
	opacity: .8;
}
.saved .save-button span.saved {
	display: inline-block;
}
.saved .save-button span.save {
	display: none;
}
.button:not(.submit-container) a,
.button.submit-container input {
	background-color: #fff;
	border: 2px solid #000f9f;
	border-radius: 3px;
	display: inline-block;
	padding: 10px 15px;
}
.button:not(.submit-container) a:hover,
.button.submit-container input:hover {
	background-color: #000f9f;
	cursor: pointer;
}
.button.button-2 a {
	background-color: transparent;
	border-color: transparent;
	color: #fff;
}
.button.button-2 a:hover {
	background-color: transparent;
	opacity: .8;
}
/*********************************
forms
*********************************/
::placeholder {
	opacity: 1;
}
.login-form,
.forgot-form,
.reset-form {
	background-color: #fff;
	margin: 0 auto;
	max-width: 350px;
	padding: 0 20px;
}
.form-widget input {
	border-radius: 3px;
	border: 2px solid #000f9f;
	display: block;
	margin-bottom: 15px;
	padding: 10px;
	width: 100%;
}
.page-admin .add-form input {
	border-radius: 0;
	border: 1px solid #333;
}
.page-admin .add-form .submit-container input:hover {
	background-color: #333;
}
.forgot-form {
	margin-top: 15px;
}
.switch {
	display: inline-block;
	height: 17px;
	position: relative;
	vertical-align: top;
	width: 30px;
}
.visible-switch input,
.switch input {
	height: 0;
	opacity: 0;
	width: 0;
}
.slider {
	border-radius: 17px;
	position: absolute;
	cursor: pointer;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #ccc;
	transition: .3s;
}
.slider:before {
	border-radius: 50%;
	position: absolute;
	content: "";
	height: 11px;
	width: 11px;
	left: 3px;
	bottom: 3px;
	background-color: white;
	transition: .3s;
}
input:checked + .slider {
	/*background-color: #2196F3;*/
	background-color: #1e1e1e;
}
input:focus + .slider {
	/*box-shadow: 0 0 1px #2196F3;*/
	box-shadow: 0 0 1px #1e1e1e;
}
input:checked + .slider:before {
	transform: translateX(13px);
}
.page-admin input:disabled {
	border-color: transparent;
	background-color: transparent;
}
.checkbox-wrap {
	cursor: pointer;
	display: inline-block;
	position: relative;
}
.checkbox-wrap input {
	height: 0;
	opacity: 0;
	position: absolute;
	width: 0;
}
.checkbox-wrap .la {
	margin-right: 2px;
	position: relative;
	top: 1px;
}
.checkbox-wrap input ~ .check,
.checkbox-wrap input:checked + .edit {
	display: none;
}
.checkbox-wrap input:checked ~ .check {
	display: inline-block;
}
/*********************************
header, main-header
*********************************/
.logo {
	max-height: 100px;
}
.loggedin-header {
	background-color: #000f9f;
	padding: 10px;
}
.page-admin .loggedin-header {
	background-color: #1e1e1e;
	left: 0;
	height: 63px;
	position: fixed;
	top: 0;
	width: 100%;
}
.loggedin-header h1 {
	padding-right: 30px;
}
.loggedin-header .button {
	margin-bottom: 0;
}
.loggedin-header .logo {
	margin-left: 15px;
	max-height: 35px;
}
.loggedin-header .right .la {
	margin-right: 5px;
	position: relative;
	top: 2px;
}
.main-header {
	background: #fff;
	border-bottom: 1px solid #ccc;
	height: 53px;
	margin-bottom: 20px;
}
.sesame {
	align-items: end;
	padding-bottom: 10px;
}
.sesame-item:hover {
	cursor: pointer;
}
.sesame .delimiter {
	display: inline-block;
	margin: 0 5px;
}
/*********************************
aside
*********************************/
.page-admin aside {
	background-color: #1e1e1e;
	height: calc(100% - 63px);
	left: 0;
	position: fixed;
	top: 63px;
	width: 120px;
}
#admin-nav a {
	display: block;
}
#admin-nav a:hover {
	background-color: #606060;
}
#admin-nav ul {
	list-style: none;
}
#admin-nav ul li.level_1 > a {
	padding: 15px 10px;
}
#admin-nav ul li.level_1 > a .la {
	display: block;
	margin-bottom: 5px;
}
#admin-nav ul li.has-subnav > a {
	padding-bottom: 7px;
}
#admin-nav .subnav a {
	padding: 3px 10px 3px 25px;
	position: relative;
}
#admin-nav .subnav a::before {
	content: "- ";
	left: 15px;
	position: absolute;
}
#admin-nav .create {
	border-top: 1px solid #fff;
}
#admin-nav .create span {
	display: block;
}
#admin-nav .create .la-plus-circle {
	background-color: #1e1e1e;
	border-radius: 100%;
	font-size: 17px;
	left: 50%;
	position: absolute;
	top: -4px;
}
#admin-nav .create a:hover .la-plus-circle {
	background-color: #606060;
}

/*********************************
main
*********************************/
main {
	width: 100%;
}
main > .inside h1,
.page-home h1,
.page-member h1 {
	margin-bottom: 20px;
}
main > .inside h2 {
	margin-bottom: 15px;
}
.page-home .inner,
.page-logout .inner,
.page-member .inner  {
	height: 100%;
	width: 50%;
}
.page-home .inner.left,
.page-logout .inner.left,
.page-member .inner.left {
	background-color: #000f9f;
}
.page-member .inner.right > div {
	max-width: 340px;
	padding: 10px;
	width: 100%;
}
.page-forgotpassword .button {
	margin-top: 20px;
}
.icon-wrap {
	border-radius: 5px;
	border: 2px solid #000f9f;
	display: inline-block;
	margin-bottom: 5px;
	overflow: hidden;
	width: 35px;
}
.loggedin-header .icon-wrap {
	margin: 0 5px 0 0;
	width: 25px;
}
.page-admin .loggedin-header .icon-wrap {
	border-color: #1e1e1e;
	filter: grayscale(100);
}
.page-home form {
	padding-bottom: 28px;
}
.page-home .icon-wrap img {
	display: block;
}
.location {
	margin-right: 10px;
}
.page-certificates #wrapper,
.page-admin main {
	flex-direction: column;
}
.page-certificates main,
.page-admin main .inside {
	flex: 1;
}
.page-certificates main ul {
	list-style: none;
}
.page-certificates main ul ul {
	padding-left: 20px;
	margin-bottom: 20px;
}
.page-certificates .student > p {
	margin-bottom: 0;
	padding: 5px 10px 5px 0;
}
.page-certificates .student > p.open {
	background-color: #efefef;
	position: sticky;
	top: 52px;
}
.page-certificates .student > p:before,
.page-certificates .subject > p:before  {
	color: red;
	content: "\2022";
	display: inline-block;
	margin-left: -8px;
	width: 15px;
}
.page-certificates .student > p:before {
	margin-left: -12px;
}
.page-certificates .student.in-progress > p:before,
.page-certificates .subject.in-progress > p:before  {
	color: orange;
}
.page-certificates .student.completed > p:before,
.page-certificates .subject.completed > p:before  {
	color: green;
}
.page-certificates main li.subject ul {
	display: none;
}
.page-certificates .subjects p:hover {
	background-color: #efefef;
	cursor: pointer;
}
.page-certificates .subject,
.page-certificates .criterias td {
	border-top: 1px solid #ccc;
}
.page-certificates .subject:last-child,
.page-certificates tr:nth-last-child(3) td.criteria,
.page-certificates tr:last-child td,
.page-certificates .criterias th {
	border-bottom: 1px solid #ccc;
}
.page-certificates .subject > p {
	margin-bottom: 0;
	padding: 10px;
}
.page-certificates .subject .la-minus {
	margin-left: auto;
	display: none;
}
.page-certificates .subject  p.open .la-minus {
	display: block;
}
.page-certificates .no-show-wrap {
	display: inline-block;
	margin: 10px 0 5px;
}
.page-certificates .no-show-wrap h3 {
	margin-bottom: 5px;
}
.page-certificates .no-show-switch,
.page-certificates .no-show-wrap textarea {
	height: 20px;
	vertical-align: top;
}
.page-certificates .no-show-switch,
.page-certificates .criterias .no-show-wrap textarea {
	display: inline-block;
}
.page-certificates th,
.page-certificates td {
	background-color: #fff;
	padding: 5px;
	vertical-align: top;
}
.page-certificates .criterias textarea {
	border: 1px solid #333;
	display: block;
	flex-grow: 1;
	margin-bottom: 1px;
	padding: 0 3px;
}
.page-certificates .criterias textarea[readonly] {
	background-color: #dadada;
	border-color: transparent;
}
.page-certificates .criterias textarea[readonly]:hover {
	cursor: pointer;
}
.page-certificates #wrapper .criterias textarea.active {
	background-color: #fff;
	cursor: initial;
}
.page-certificates .criterias .switch {
	margin: 0 5px 0 3px;
}
.page-certificates td.criteria {
	width: 20%;
}
.page-certificates td.content {
	width: 30%;
}
.page-certificates td.grade-text {
	padding-bottom: 3px;
	width: 50%;
}
/* page-admin */
.page-admin main .inside {
	margin: 0;
	padding: 10px 25px;
}
.page-admin main .inside {
	max-width: none;
}
.page-admin .main-header p {
	margin-bottom: 0;
}
.page-admin section {
	margin-bottom: 100px;
}
.page-admin .section-header .visible-switch {
	padding: 2px;
}
.page-admin .eye input + .visible,
.page-admin .eye input:checked ~ .invisible,
.page-admin .eye:hover input ~ .invisible,
.page-admin .eye:hover input:checked + .visible {
	display: none;
}
.page-admin .eye input:checked + .visible,
.page-admin .eye:hover input + .visible,
.page-admin .eye:hover input:checked ~ .invisible {
	display: block;
}
.page-admin .eye span:hover {
	cursor: pointer;
}
.page-admin .section-header .visible-switch .la {
	margin-left: 3px;
	position: relative;
	top: 2px;
}
.page-admin table:not(.text-blocks) tr:hover td {
	background-color: #efefef;
}
.page-admin table.period td {
	vertical-align: top;
}
.page-admin table.period input:checked {
	pointer-events: none;
}
.page-admin .add {
	display: inline-block;
	padding: 5px;
}
.page-admin .add span:hover {
	cursor: pointer;
}
.page-admin .add span i {
	margin-left: 3px;
	position: relative;
	top: 2px;
}
.page-admin table.users th:nth-last-child(-n+2),
.page-admin table.users td:nth-last-child(-n+2),
.page-admin table.students th:last-child,
.page-admin table.students td:last-child {
	background-color: #efefef;
}
.page-admin th,
.page-admin td {
	background-color: #fff;
	padding: 2px 5px;
}
.page-admin table,
.page-admin th {
	border-bottom: 1px solid #ccc;
}
.page-admin td {
	border-top: 1px solid #ccc;
}
.page-admin table.text-blocks td {
	vertical-align: top;
}
.page-admin table.subjects th {
	vertical-align: bottom;
}
.page-admin table.text-blocks textarea {
	width: 100%;
}
.page-admin .text-blocks span.count {
	display: inline-block;
	margin-right: 5px;
}
/*********************************
footer
*********************************/
footer .inside {
	border-top: 1px solid #ccc;
	margin-top: 100px;
	padding: 15px 10px 15px;
}
footer .la-keyboard-o {
	margin-left: 5px;
	position: relative;
	top: 1px;
	vertical-align: sub;
}

/* dev */













