*, *::after, *::before {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Roboto', sans-serif;
  background: url(/Assets/Background.png) no-repeat center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.container {
  max-width: 800px;
  width: 100%;
}

.container .col1 {
  text-align: center;
  background-color: #4b044b;
  padding: 0rem 1rem;
}

.container .col1 .col1_intro {
  padding-top: 4rem;
}

.container .col1 .col1_intro .col1_intro_title {
  color: #eeeeee;
}

.container .col1 .col1_intro .col1_intro__para {
  padding-top: .5rem;
  color: #29bbff;
}

.container .col1 .mockup {
  width: 100%;
  height: auto;
}

.container .col2 {
  background: #fff;
  padding: 2.5rem;
}

.container .col2 .col2_title {
  font-weight: bold;
  font-size: 2rem;
  margin-bottom: 1rem;
}

.container .col2 form .input {
  margin-bottom: 1rem;
}

.container .col2 form .input label {
  font-family: 'Roboto', sans-serif;
  margin-bottom: 2rem;
  font-weight: 500;
  position: relative;
}

.container .col2 form .input label input[type=email], .container .col2 form .input label input[type=password], .container .col2 form .input label input[type=text] {
  font-size: 1rem;
  border: 1px solid gray;
  width: 100%;
  padding: .8rem;
  display: block;
  margin-top: .2rem;
}

.container .col2 form .input label input[type=email]:invalid, .container .col2 form .input label input[type=password]:invalid, .container .col2 form .input label input[type=text]:invalid {
  color: red;
}

.container .col2 form .input label #toggleEye {
  position: absolute;
  top: 200%;
  left: 440%;
}

.container .col2 form .input label .agreement {
  font-weight: 500;
}

.container .col2 form button {
  font-family: 'Roboto', sans-serif;
  width: 100%;
  text-align: center;
  background: #4b044b;
  color: #fff;
  font-weight: 500;
  padding: 1rem 0rem;
  border: none;
  border-radius: 5px;
}

@media (min-width: 768px) {
  .container {
    margin: auto;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    max-height: 500px;
    box-shadow: 0 1.3px 3.5px -4px rgba(0, 0, 0, 0.023), 0 3px 8.2px -4px rgba(0, 0, 0, 0.034), 0 5.3px 14.8px -4px rgba(0, 0, 0, 0.041), 0 8.8px 24.6px -4px rgba(0, 0, 0, 0.049), 0 14.5px 40.5px -4px rgba(0, 0, 0, 0.056), 0 25.4px 70.7px -4px rgba(0, 0, 0, 0.067), 0 55px 153px -4px rgba(0, 0, 0, 0.09);
  }
  .container .col1 .col1_intro {
    padding-top: 1rem;
  }
  .container .col1 .mockup {
    width: 100%;
  }
}
