html, body {
  height: 100%;
  width: 100%;
  margin: 0;
  font-family: Arial, Helvetica, sans-serif; }

.page {
  display: flex;
  flex-direction: column;
  height: 100%; }

.main {
  background-color: #50d0fb;
  width: 100%;
  box-sizing: border-box;
  flex: 1;
  position: relative;
  padding: 15px; }
  .main .container {
    width: 350px;
    display: inline-block;
    position: relative;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%); }
    .main .container .company-name {
      color: #21698c;
      font-style: italic;
      text-align: center;
      font-weight: bold;
      margin: 10px 0; }
      .main .container .company-name span {
        color: #b9eefd; }
    .main .container .login-box {
      width: 100%;
      background: #fff;
      border-radius: 2px;
      padding: 10px;
      box-sizing: border-box; }
      .main .container .login-box h3 {
        color: #21698c;
        text-align: center;
        margin: 7px 0; }
      .main .container .login-box .error_message {
        color: #fff;
        background: #EC644B;
        font-weight: bold;
        font-size: 11px;
        padding: 5px;
        border-radius: 2px;
        text-align: center;
        margin: 10px 0 0; }
      .main .container .login-box .float-label {
        position: relative;
        margin: 30px 0; }
        .main .container .login-box .float-label input[type="text"],
        .main .container .login-box .float-label input[type="email"],
        .main .container .login-box .float-label input[type="password"] {
          width: 100%;
          border: none;
          color: #3f8ea8;
          font-size: 16px;
          border-bottom: 2px solid #50d0fb;
          padding: 4px 0;
          box-sizing: border-box;
          outline: none; }
          .main .container .login-box .float-label input[type="text"].invalid,
          .main .container .login-box .float-label input[type="email"].invalid,
          .main .container .login-box .float-label input[type="password"].invalid {
            border-bottom: 2px solid #EC644B;
            color: #EC644B; }
        .main .container .login-box .float-label label {
          color: #3f8ea8;
          position: absolute;
          top: 0;
          left: 0;
          font-size: 16px;
          padding: 4px 0;
          cursor: text;
          -webkit-transition: all 0.25s ease;
          transition: all 0.25s ease; }
          .main .container .login-box .float-label label.top {
            font-size: 10px;
            transform: translateY(-100%); }
      .main .container .login-box .checkbox {
        margin: 0 0 20px;
        display: inline-block;
        cursor: pointer;
        padding-left: 25px;
        position: relative;
        line-height: 20px;
        color: #50d0fb; }
        .main .container .login-box .checkbox input[type="checkbox"] {
          display: none; }
          .main .container .login-box .checkbox input[type="checkbox"] + span {
            height: 19px;
            width: 19px;
            background: #50d0fb;
            border-radius: 2px;
            display: inline-block;
            position: absolute;
            left: 0; }
          .main .container .login-box .checkbox input[type="checkbox"]:checked + span:before {
            content: '\2714';
            color: #fff;
            position: absolute;
            top: 0px;
            left: 1px;
            font-size: 20px; }
      .main .container .login-box input[type="button"] {
        color: #fff;
        background: #50d0fb;
        border: none;
        border-radius: 2px;
        width: 100%;
        padding: 10px;
        cursor: pointer;
        outline: none; }
      .main .container .login-box .loading {
        text-align: center; }
        .main .container .login-box .loading span {
          display: block;
          width: 25px;
          height: 25px;
          margin: 0 auto;
          border-radius: 50%;
          border: 6px solid #50d0fb;
          border-right-color: transparent;
          animation: loader 1s infinite linear; }
        .main .container .login-box .loading label {
          margin-top: 5px;
          display: inline-block;
          color: #50d0fb; }

.footer {
  background: #3da6cc;
  width: 100%; }
  .footer .container {
    width: 1200px;
    height: 100%;
    margin: 0 auto;
    display: flex; }
    .footer .container .col-25 {
      width: 25%;
      float: left;
      box-sizing: border-box;
      padding: 0 30px 50px; }
      .footer .container .col-25.present {
        padding-bottom: 0; }
        .footer .container .col-25.present .text-centered-y {
          position: absolute;
          top: 50%;
          transform: translateY(-50%); }
          .footer .container .col-25.present .text-centered-y h1 {
            font-style: italic; }
            .footer .container .col-25.present .text-centered-y h1 span {
              color: #29738e; }
          .footer .container .col-25.present .text-centered-y h3 {
            font-weight: lighter; }
      .footer .container .col-25 .footer-col {
        color: #fff;
        height: 100%;
        display: inline-block;
        position: relative; }
        .footer .container .col-25 .footer-col h2 {
          font-size: 18px; }
        .footer .container .col-25 .footer-col input[type="button"] {
          font-size: 16px;
          color: #3da6cc;
          background: #fff;
          padding: 10px;
          width: 100%;
          border: none;
          border-radius: 3px;
          position: absolute;
          top: 100%; }

@keyframes loader {
  0% {
    transform: rotate(0deg); }
  100% {
    transform: rotate(360deg); } }

@media only screen and (max-width: 1200px) {
  .footer .container {
    width: 100%; } }

@media only screen and (max-width: 960px) {
  .footer .container .col-25 {
    padding: 0 8px 50px; } }

@media only screen and (max-width: 768px) {
  .main {
    height: auto; }
    .main .container {
      width: 100%;
      left: 0;
      top: 0;
      transform: none; }
  .footer {
    height: auto;
    padding: 10px 0;
    position: relative; }
    .footer .container {
      display: block; }
      .footer .container .col-25 {
        width: 100%;
        float: none; }
        .footer .container .col-25.present .text-centered-y {
          position: relative;
          top: 0;
          transform: translateY(0); }
        .footer .container .col-25 .footer-col {
          width: 100%; }
          .footer .container .col-25 .footer-col input[type="button"] {
            position: relative;
            bottom: 0; } }
