@font-face {
  font-family: 'Karla';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../webfonts/Karla-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Karla';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../webfonts/Karla-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

*, *:before, *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body, html {
  margin: 0;
  padding: 0;
  height: 100%;
}

body {
  position: relative;
  background-color: transparent;
  font-family: Karla, sans-serif;
  font-weight: 400;
  font-size: 0;
  color: #121212;
}

.main {
  position: relative;
  opacity: 1;
}

.container {
  max-width: 1072px;
  padding: 40px 20px;
  margin: 0 auto;
}

.container form {
  position: relative;
}

.container form input[type="text"], .container form input[type="email"] {
  background: transparent;
  border: none;
  border-bottom: 2px solid #121212;
  color: #121212;
  font-size: 21px;
  font-family: Karla, sans-serif;
  font-weight: 400;
  outline: none;
  box-shadow: none;
  width: 100%;
  border-radius: 0;
  padding: 12px 0 12px 5px;
  margin: 0 0 20px 0;
  display: block;
  line-height: normal;
  box-sizing: border-box;
}
.container form input[type="text"]:-moz-placeholder, .container form input[type="email"]:-moz-placeholder {
  color: #6a6a6a;
  font-size: 21px;
  font-weight: 400;
  opacity: 1;
}
.container form input[type="text"]::-moz-placeholder, .container form input[type="email"]::-moz-placeholder {
  color: #6a6a6a;
  font-size: 21px;
  font-weight: 400;
  opacity: 1;
}
.container form input[type="text"]:-ms-input-placeholder, .container form input[type="email"]:-ms-input-placeholder {
  color: #6a6a6a;
  font-size: 21px;
  font-weight: 400;
}
.container form input[type="text"]::-webkit-input-placeholder, .container form input[type="email"]::-webkit-input-placeholder {
  color: #6a6a6a;
  font-size: 21px;
  font-weight: 400;
}
.container form input[type="text"]::placeholder, .container form input[type="email"]::placeholder {
  color: #6a6a6a;
  font-size: 21px;
  font-weight: 400;
  opacity: 1;
}
@media (max-width: 1023px) {
  .container form input[type="text"], .container form input[type="email"] {
    margin: 10px 0;
  }
}

.container form .checkbox {
  position: relative;
  font-size: 20px;
  line-height: 29px;
  text-align: left;
  padding-left: 41px;
  -moz-user-select: -moz-none;
  -ms-user-select: none;
  -webkit-user-select: none;
  user-select: none;
  color: #121212;
  margin-top: auto;
  display: block;
  text-transform: uppercase;
}
@media (max-width: 1279px) {
  .container form .checkbox {
    font-size: 18px;
  }
}
.container form .checkbox .checkbox-label {
  display: inline-block;
  vertical-align: middle;
  width: calc(100% - 41px);
}
.container form .checkbox a {
  color: inherit;
}
.container form .checkbox input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}
.container form .checkbox input:checked ~ .checkmark:after {
  display: block;
}
.container form .checkbox .checkmark {
  position: absolute;
  top: 0px;
  left: 0;
  height: 33px;
  width: 33px;
  border: 2px solid #121212;
}
.container form .checkbox .checkmark:after {
  content: "";
  position: absolute;
  display: none;
  left: 2px;
  top: 2px;
  right: 2px;
  bottom: 2px;
  background-color: #121212;
}
.container form .checkbox.privacy {
  margin: 20px 0 0 0px;
  text-transform: none;
  font-size: 14px;
  line-height: 18px;
}
.container form .checkbox.privacy .checkbox-label {
  width: auto;
}
@media (max-width: 720px) {
  .container form .checkbox.privacy {
    margin: 20px 0 0 0;
    font-size: 12px;
  }
}
.container form .checkbox.privacy .checkmark {
  border: 2px solid #121212;
}
.container form .checkbox .checkmark.error,
.container form .checkbox.privacy .checkmark.error {
  border-color: #ff0000;
}

.container form input.error {
  background-color: transparent;
  border-bottom-color: #ff0000;
}
.container form input.error:-moz-placeholder { color: #ff0000; opacity: 1; }
.container form input.error::-moz-placeholder { color: #ff0000; opacity: 1; }
.container form input.error:-ms-input-placeholder { color: #ff0000; }
.container form input.error::-webkit-input-placeholder { color: #ff0000; }
.container form input.error::placeholder { color: #ff0000; opacity: 1; }
.container form label.error {
  position: absolute;
  left: 6px;
  top: 50px;
  font-size: 42px;
  color: #ff0000;
}

.container .formular-success {
  font-size: 22px;
  line-height: 29px;
  display: none;
  margin: 60px 0;
}

.container .button {
  position: relative;
  display: inline-block;
  color: #f3f3f3;
  text-decoration: none;
  font-family: Karla, sans-serif;
  font-size: 1.2rem;
  letter-spacing: 1px;
  font-weight: 400;
  cursor: pointer;
  background-color: rgb(18, 18, 18);
  border: 0;
  border-radius: 30px;
  text-align: center;
  padding: 8px 20px 8px 20px;
  margin-top: 30px;
  transition: transform 0.25s ease;
}
.container .button:hover {
  transform: scale(1.02);
}
@media (max-width: 720px) {
  .container .button {
    display: block;
    width: 100%;
    text-align: center;
  }
}
