@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;600&display=swap');

* {
  box-sizing: border-box;
}

:root {
  --colorPrimario:  #194481;          //#20254a;  //#303E49;
  --colorSecundario:#186d63;  //#186d63;
  --colorGris: #bdbfbf;
  --colorBlanco: #FFF;
  --Light: 300;
  --Regular: 400;
  --Semi-bold: 600;
  --heightUnderline: 2px;
}

body{
  font-family: 'Open Sans', sans-serif;
  background-image: url('../img/background.jpg');
  background-repeat: no-repeat;
  overflow: hidden;
}

.container {
  display: -webkit-box;
  display: flex;
  overflow: hidden;
  width: 100vw;
  height: 100vh;
  -webkit-box-align: center;
          align-items: center;
  -webkit-box-pack: center;
          justify-content: center;
}

.adorno {
  position: absolute;
  transform: scale(8);
  transform-origin: center;
  left: -5em;
  top: -5em;
  opacity: 0;
  animation: showDonut 1.2s 3s forwards cubic-bezier(0.075, 0.82, 0.165, 1);
}

@keyframes showDonut {
  to{
    opacity: 0.2;
    left: -2em;
    top: -2em;
  }
}

.adorno::after{
  position: absolute;
  content: '';
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: var(--colorPrimario);
  z-index: 2;
  transform: scale(0.85);
  transform-origin: center;
}

.adorno::before{
  position: absolute;
  content: '';
  width: 20px;
  height: 20px;
  background-color: var(--colorGris);
  z-index: 1;
  border-radius: 50%;
  transform: scale(1.2);
  transform-origin: center;
}

.form-container {
  -webkit-transform: translateY(5em);
          transform: translateY(5em);
  opacity: 0;
  width: 22em;
  border: 2px solid var(--colorSecundario);
  border-radius: 50px 0 0 0;
  padding: 1.1rem 2rem;
  padding: 1.1rem 2.5rem 3em;
  box-shadow: 0 0 10px 0px rgba(150, 150, 150, 0.5);
  background-color: var(--colorPrimario);
  position: relative;
  overflow: hidden;
}

.form-container::before{
  position: absolute;
  content: '';
  right: 0px;
  bottom: 0px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 35px 35px;
  border-color: transparent transparent var(--colorSecundario) transparent;
}

.logo-container {
  width: 100%;
  height: auto;
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
  justify-content: center;
  margin-top: 2.5em;
  height: 5em;
  position: relative;
  transform: translateX(1.5em) scale(1.1);
  transform-origin: center center;
}

.logo-container .logo-part-one {
  position: absolute;
  filter: blur(60px);
  opacity: 0;
  transform: scale(1.2);
  animation: blurLogo 1.5s 1s forwards ease-in-out;
}

@keyframes blurLogo {
  40% {
    filter: blur(0);
  }
  100% {
    filter: blur(0);
    opacity: 1;
    transform: translateX(-5.1em) scale(1.2);
  }
}

.logo-container .logo-part-one svg {
  width: 100px;
  height: auto;
}

.logo-container .logo-part-two {
  position: absolute;
  z-index: -1;
  transform: translate(3em, 2em);
  opacity: 0;
  animation: leftShow 1s 2s forwards ease-in-out;
}

@keyframes leftShow {
  to {
    opacity: 1;
    transform: translateX(3em);
  }
}

.logo-container .logo-part-two svg{
  width: 100px;
  height: auto;
  position: relative;
  top: -6px;
}

.inputs-container {
  margin-top: 2rem;
  margin-bottom: 4rem;
}

.inputs-container,
.actions-container {
  opacity: 0;
  transform: translateY(-2em);
  animation: downInfo 1s 2.5s forwards ease-in-out;
}

@keyframes downInfo {
  to {
    opacity: 1;
    transform: translateY(0em);
  }
}

.inputs-container .input-container {
  margin-bottom: 1rem;
  position: relative;
}

.inputs-container .input-container label {
  margin-bottom: 0.25rem;
  display: block;
  font-weight: var(--Regular);
  font-size: 1.2em;
  color: var(--colorGris);
  position: absolute;
  top: 0.65em;
  z-index: -1;
  transition: top 0.2s ease-in-out, transform 0.2s ease-in-out, color 0.2s ease-in-out;
}

.inputs-container .input-container .underline {
  width: 0%;
  height: var(--heightUnderline);
  background-color: var(--colorSecundario);
  display: block;
  position: absolute;
  bottom: 0;
  -webkit-transition: width 0.4s cubic-bezier(1, 0, 0, 1);
  transition: width 0.4s cubic-bezier(1, 0, 0, 1);
}

.inputs-container .input-container input {
  width: 100%;
  outline: none;
  border: none;
  padding: 0.45rem;
  padding-left: 0.2em;
  padding-right: 1.5em;
  background-color: transparent;
  border-bottom: var(--heightUnderline) solid var(--colorGris);
  font-weight: var(--Regular);
  color: var(--colorBlanco);
  font-size: 1.15em;
  line-height: 0em;
}

.inputs-container .input-container input:valid + .underline + label {
  top: -0.9em;
  transform: scale(0.85);
  transform-origin: left center;
  color: var(--colorSecundario);
  font-weight: 600;
}

.inputs-container .input-container input:focus + .underline {
  width: 100%;
}

.inputs-container .input-container input:focus + .underline + label {
  top: -0.9em;
  transform: scale(0.85);
  transform-origin: left center;
}

.inputs-container .input-container .icon {
  width: 18px;
  display: block;
  position: absolute;
  right: 0;
  top: 0.65em;
}

.inputs-container .input-container .icon svg {
  width: 100%;
}

.inputs-container .input-container .icon path {
  transition: fill 0.5s ease-in-out;
}

.inputs-container .input-container svg path{
  fill: var(--colorBlanco);
}

.inputs-container .input-container input:focus + .underline + label + .icon svg path{
  fill: var(--colorSecundario);
}

.inputs-container .input-container:first-child {
  margin-bottom: 3em;
}

.actions-container {
  width: 80%;
  display: block;
  margin: 0 auto;
}

.actions-container .action-container:nth-child(1) {
  margin-bottom: 1rem;
}

.actions-container .action-container .btn{
  width: 100%;
  border: none;
  padding: 0.8rem 0.65rem;
  font-weight: var(--Semi-bold);
  border-radius: 2rem;
  text-align: center;
  background-color: var(--colorGris);
  color: var(--colorBlanco);
  cursor: pointer;
}

.actions-container .action-container .btn-link{
  width: 100%;
  text-align: center;
  background-color: transparent;
  padding: .5em;
  color: var(--colorBlanco);
  cursor: pointer;
  display: block;
  text-decoration: none;
  font-size: 0.95em;
  font-weight: var(--Light);
}

#loginbtn {
  background-color: var(--colorSecundario);
  border: 2px solid var(--colorSecundario);
  transition: background-color 0.3s linear;
  font-size: 1.1em;
  outline: none;
}

#loginbtn:hover {
  background-color: transparent;
}

#recuperarbtn:hover {
  text-decoration: underline;
}

.anim-form {
  -webkit-animation: upForm forwards 1s ease;
          animation: upForm forwards 1s ease;
}

@-webkit-keyframes upForm {
  to {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
}

@keyframes upForm {
  to {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
}

@media (min-width: 300px) {

  body {
    background-size: cover;
    background-position: right top;
  }

  .form-container {
    top: -1em;
    width: 22em;
  }

}

@media (min-width: 700px) {
  
  body {
    background-size: cover;
  }
  
  .form-container {
    width: 24em;
  }
  
  .logo-container {
    transform: translateX(1.5em) scale(1.1);
  }
  
}

@media (min-width: 1280px) {

  body {
    background-size: 110% 165%;
    background-position: right top;
  }

}