body, html {
  height: 100%;
  padding: 0px;
  margin: 0px;
  overflow: hidden;
  font-family: 'Montserrat'; }
  body *, html * {
    box-sizing: border-box; }

.logo {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: 200px;
  height: 130px;
  background: url('img/logo.svg') no-repeat center;
  background-size: contain; }
@media (max-width: 860px) {
  .logo {
    width: 100px;
    height: 50px; } }
.logo:before, .logo:after {
  height: 2px;
  width: 2000px;
  background: #FFC880;
  top: 50%;
  transform: translateY(-50%);
  position: absolute;
  content: ''; }
.logo:before {
  left: -2020px; }
.logo:after {
  right: -2020px; }

.bg {
  background: url('img/bg.svg') no-repeat bottom center;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: contain; }

.form {
  position: fixed;
  top: 180px;
  left: 50%;
  transform: translateX(-50%);
  text-align: center; }
@media (max-width: 860px) {
  .form {
    top: 50%;
    transform: translate(-50%, -50%); } }
.form .title {
  font-size: 32px;
  font-weight: 500;
  color: #294A8A;
  letter-spacing: 3px;
  display: inline-block;
  width: 100%;
  text-align: center;
  margin-bottom: 20px; }
@media (max-width: 860px) {
  .form .title {
    font-size: 18px;
    margin-bottom: 5px; } }
.form .desc {
  font-size: 15px;
  color: #294A8A;
  display: inline-block;
  width: 100%;
  text-align: center;
  margin-bottom: 50px;
  opacity: 0.8; }
@media (max-width: 860px) {
  .form .desc {
    margin-bottom: 30px;
    font-size: 13px; } }
.form input {
  border: 1px solid #FFEDAF;
  border-radius: 5px;
  padding: 13px 15px;
  font-family: 'Montserrat';
  text-align: center;
  display: inline-block;
  margin-bottom: 20px;
  width: 300px;
  appearance: none;
  -webkit-appearance: none;
  color: #294A8A;
  font-size: 16px; }
@media (max-width: 860px) {
  .form input {
    max-width: 85%; } }
.form input:focus {
  outline: none; }
.form input::placeholder {
  color: #5E7BB2; }
.form .actions {
  width: 100%;
  display: inline-block;
  margin-top: 20px; }
@media (max-width: 860px) {
  .form .actions {
    margin-top: 10px; } }
.form .actions a {
  display: inline-block;
  text-decoration: none; }
.form .actions .login {
  border-radius: 5px;
  background: #294A8A;
  color: #fff;
  width: 200px;
  padding: 15px 0px;
  letter-spacing: 1px;
  font-size: 16px;
  font-weight: 500; }
.form .actions .register {
  margin-top: 15px;
  border-radius: 5px;
  background: #E2FFBC;
  color: #127D00;
  padding: 10px 20px;
  font-size: 15px; }
.form .actions .forgot {
  margin-top: 25px;
  color: #DE8816;
  font-size: 14px; }

.loading {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 200;
  background: rgba(255, 255, 255, 0.922);
  font-size: 30px;
  color: #111;
  display: none; }
@media (max-width: 860px) {
  .loading {
    font-size: 20px; } }
.loading span {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: #294a8a;
  color: #fff;
  padding: 20px 50px;
  border-radius: 10px; }
@media (max-width: 860px) {
  .loading span {
    padding: 15px 30px; } }

.error {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 100;
  background: rgba(255, 255, 255, 0.922);
  font-size: 30px;
  color: #111;
  cursor: pointer; }
@media (max-width: 860px) {
  .error {
    font-size: 20px; } }
.error span {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: #d11f1f;
  color: #fff;
  padding: 20px 50px;
  border-radius: 10px; }
@media (max-width: 860px) {
  .error span {
    width: 70%;
    text-align: center;
    padding: 15px 30px; } }

#modal {
  position: fixed;
  width: 80%;
  height: 80%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  border-radius: 10px;
  z-index: 2000;
  background: #fff;
  display: none; }
@media (max-width: 860px) {
  #modal {
    width: 100%;
    height: 100%;
    border-radius: 0px;
    padding-top: 55px; } }
#modal.small {
  width: 40%;
  height: 40%; }
@media (max-width: 860px) {
  #modal.small {
    width: 100%;
    height: 100%;
    border-radius: 0px;
    padding-top: 55px; } }
#modal .close {
  position: absolute;
  top: 25px;
  right: 25px;
  width: 20px;
  height: 20px;
  background: url('img/cross-out.svg') no-repeat center;
  background-size: 100%;
  cursor: pointer;
  z-index: 3000; }
#modal:after {
  position: absolute;
  left: -250%;
  width: 600%;
  top: -250%;
  background: #333;
  z-index: -1;
  content: '';
  height: 600%;
  opacity: 0.7; }
@media (max-width: 860px) {
  #modal:after {
    background: #fff;
    opacity: 1; } }
#modal iframe {
  border: 0px;
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 10px;
  z-index: 2005; }
@media (max-width: 860px) {
  #modal iframe {
    height: 90%;
    border-radius: 0px; } }
