* {
  padding: 0;
  margin: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
body {
  font: 16px Helvetica, Tahoma, sans-serif;
  color: #231f20;
}
img {
  max-width: 100%;
  vertical-align: bottom;
  border: 0;
}
a {
  color: #006699;
}
a:hover {
  text-decoration: none;
}
p {
  margin-bottom: 16px;
}
ul {
  list-style: none;
}
h1 {
  font-size: 36px;
  line-height: 46px;
  text-align: center;
  text-transform: uppercase;
  color: #1c439c;
  margin-bottom: 36px;
}
h2 {
  font-size: 45px;
}
label {
  display: block;
  font-size: 25px;
  cursor: pointer;
}
input[type="text"] {
  font: 25px Helvetica, Tahoma, sans-serif;
  outline: none;
  border: none;
  color: #231f20;
}
input[type="radio"] {
  display: none;
}
#logo {
  max-width: 285px;
  margin: 0 auto 75px;
}
#ov_club {
  max-width: 130px;
  margin: 0 auto 40px;
}
#debug {
  position: absolute;
  top: 10px;
  font-size: 16px;
}
.container {
  margin: 0 auto;
  max-width: 1280px;
  padding: 45px;
  position: relative;
  /*-webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    -o-box-sizing: content-box;  
    box-sizing: content-box; */

}
.row {
  display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  justify-content: space-between;
  margin: 0 -25px;
}
.step.step4 .row{
  justify-content: space-around;
}

.row.center {
  justify-content: center;
}
.row.left {
  justify-content: flex-start;
}
.row.right {
  justify-content: flex-end;
}
.row.wrap {
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
}
.row > .col {
  margin: 0 25px;
}
.btn {
  font-size: 28px;
  text-align: center;
  background: white;
  outline: none;
  cursor: pointer;
  margin: 0 25px 40px;
  display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  align-content: center;
  justify-content: center;
}
.btn.small {
  border: 1px solid #1c439c;
  padding: 18px 50px;
  min-width: 470px;
  margin-bottom: 10px;
}
.btn > span {
  flex-basis: 100%;
  -webkit-flex-basis: 100%;
  -ms-flex-preferred-size: 100%;
}
.btn input {
  display: none;
}
.field {
  border: 1px solid #1c439c;
  background: white;
  display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  padding: 18px 50px;
  font-size: 28px;
  margin-bottom: 10px;
}
.field span {
  flex-shrink: 0;
}
.field input[type="text"] {
  flex-basis: 100%;
  -webkit-flex-basis: 100%;
  -ms-flex-preferred-size: 100%;
  margin-left: 10px;
}
.line {
  display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
}
.line span {
  flex-shrink: 0;
}
.line input[type="text"] {
  border-bottom: 1px solid #231f20;
  flex-basis: 100%;
  -webkit-flex-basis: 100%;
  -ms-flex-preferred-size: 100%;
  margin-left: 10px;
}
.checkbox {
  display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
}
.checkbox input[type="checkbox"] {
  outline: none;
  width: 30px;
  height: 30px;
  flex-shrink: 0;
  margin-right: 20px;
}
.checkbox span {
  font-size: 13px;
  line-height: 15px;
}
.map {
  text-align: center;
}
.step.step1 h1 {
  margin-bottom: 10px;
}
.step.step1 .btn {
  margin-bottom: 0;
}
.step.step1 .btn img {
  width: 170px;
  height: 96px;
}
.step.step2 h1 {
  margin-bottom: 100px;
}
.step.step3 h1 {
  margin-bottom: 90px;
}
.step.step3 .btn {
  padding: 75px 130px;
  border: 1px solid #1c439c;
}
.step.step4,
.step.step7,
.step.step10 {
  padding: 0 70px;
}
.step.step4 h1,
.step.step7 h1{
  margin-top: -20px;
}
.step.step4 .btn,
.step.step7 .btn {
  width: 230px;
}
.step.step10 .btn {
  width: 300px;
}
/*.step.step4 .btn:nth-child(n+4),*/
.step.step7 .btn:nth-child(n+4),
.step.step10 .btn:nth-child(n+4) {
  margin-bottom: 0;
}
.step.step4 .btn span,
.step.step7 .btn span,
.step.step10 .btn span {
  display: block;
  margin-bottom: 20px;
}
.step.step5 {
  padding: 0 70px;
}
.step.step5 h1 {
  margin-top: -46px;
  margin-bottom: 26px;
}
.step.step6 {
  padding: 0 45px;
  margin-top: -40px;
}
.step.step8 h1 {
  margin-top: 180px;
}
.step.step10 .row {
  justify-content: center;
}
.button-lived {
  margin-top: 15px;
}
.errorMessages {
  color: red !important;
  margin: 10px 0 10px 50px;
}
.fieldError {
  border-color: red !important;
}
