/* Kosmas */
html,body.not(.backoffice)){
      height: auto;
    overflow: auto;
}

/* Fix for bakcoffice aanvraag form */ 
html,body.backoffice{
    height: 100%!important;
    overflow: auto;
}

.input-error input,
.specific-error input,
.input-error textarea,
.specific-error textarea,
.input-error select {
  border: 1px solid red;
}

.input-error:after {
  content: "*"
}
:required {
  background: red;
}

.input-error {
  position: relative;
}

.form-check > * {
	cursor: pointer;
}

.input-error::after {
  content: attr(data-name) " is verplicht";
  display: inline-block;
  color: #B81111;
  font-size: 14px;
  font-style: italic;
}

.specific-error::after {
  content: attr(data-name) " is niet geldig";
  display: inline-block;
  color: #B81111;
  font-size: 14px;
  font-style: italic;
}

.js-validate-error-label {
  content: 'Dit veld is verplicht';
  color: #B81111;
  font-size: 14px;
  font-style: italic;
}

.input-group .wrap{
  width:50%;
}

.input-error > .js-validate-error-label{
  display:none;
}

.input-group-prepend{
  position:relative;
}

.input-group-prepend > span{
  position:absolute;    
  width: 80px;
}

.input-group .wrap input{
  padding-left:90px;
}
.input-group-prepend {
    margin-right: 10px;
  display: block;
}
#buildings > div{
  background-color: #fff;
  padding:30px;
  margin-bottom:30px; 
}
button:disabled,
button[disabled]{
  border: 1px solid #999999;
  background-color: #cccccc;
  color: #666666;
  cursor: inherit;
}
button {
    position: relative;
    display: inline-block;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    text-decoration: none;
    vertical-align: top;
    margin: 0;
    text-align: center;
    padding: 5px 10px;
    border-radius: 3px;
    background-color: #949BFF;
    color: #ffffff;
    -webkit-transition: 300ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -o-transition: 300ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: 300ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -webkit-transition-property: color, background-color;
    -o-transition-property: color, background-color;
    transition-property: color, background-color;
    position: relative;
}

/* End Kosmas*/

select.form-control {
/*   Show select arrow */
	padding-left: 0.25rem;
  	-webkit-appearance: auto;
    -moz-appearance: auto;
    appearance: auto;
}

.alert-div, 
.text-success-alert, 
.text-danger {
    display:none;
    border-left: 4px solid #ce3232;
    padding: 15px;
    background-color: #f9f9f9;
    margin-bottom: 20px;
    margin-top: 50px;
}
.text-success-alert button{
  margin-top:10px;
}

.loader_1,
.loader_2,
.loader_btn_1, 
.loader_btn_2{
    pointer-events: none;
    -webkit-user-select: none; /* Safari 3.1+ */
    -moz-user-select: none; /* Firefox 2+ */
    -ms-user-select: none; /* IE 10+ */
    user-select: none; /* Standard syntax */
}

.loader_1::before,
.loader_btn_1::before,
.loader_2::before,
.loader_btn_2::before{
  	background: url(https://assets.bettyblocks.com/f41b0685963341b9af458ef416ff876f_assets/files/loader) center no-repeat;
  	background-size: 150%;
    border-top: 5px solid transparent;
}

.loader_1::before,
.loader_2::before{
    content: '';
    position: fixed;
    top: 50%;
    left: 0;
    right: 0;
    margin: -20px auto 0;
    border-radius: 50%;
    width: 80px;
    height: 80px;
    z-index: 99;
}

.loader_1::after, .loader_2::after, .loader_btn_1::after, .loader_btn_2::after {
    content: '';
    background-color: rgba(255,255,255,0.5);
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    position: fixed;
    display: block;
}


.header {
  margin: 0 60px 40px;
}

.logo {
  margin: 20px 0 30px;
}

#form {
  background-color: #ecebf7;
}

.form-group {
  margin-bottom: 4px;
}

.form-control {
  background-color: #ccd7ff;
}

.form-section {
  padding: 40px 60px 0;
}

.form-section:last-child {
  padding-bottom: 60px;
}
.section-title {
  color: #949bff;
}

.doc_title {
  color: #25dc71;
}

h1.big {
  font-size: 50px;
}

h1.small,
h4.small {
  font-size: 30px;
}

.relative {
  position: relative;
}

.sub-title {
  display: block;
  font-size: 14px;
  margin: 0 0 10px;
}

.form-check-label {
  margin-right: 10px;
}

.form-check-inline-flex {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
}

.form-check-inline-flex-label {
  color: #25dc71;
  font-weight: bold;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.form-check-inline-flex-input {
  margin-left: 0 !important;
}

.info-text {
/*   color: #b2b2bd; */
  display: block;
}

.add_building {
  margin-top: 40px;
}

.add_building_info {
  color: #949bff;
}

.input-group-prepend.width {
  margin-left: 5px;
  padding-left: 5px;
}

.signature-pad {
  width: 100%;
}

.hidden{
  display:none;
}

.button-upload {
  background: #949bff;
  overflow: hidden;
  border-radius: 5px;
  width: 220px;
  position: relative;
  padding: 8px 10px 8px 10px;
  text-align: center;
}

.button-upload.small {
  display: inline-block;
  margin: auto;
}

.button-upload:hover {
  background: #949bff;
}

.file-upload {
  opacity: 0;
  width: 220px;
  height: 40px;
  position: absolute;
  top: 0px;
  left: 0px;
  cursor: pointer;
}

#signature_validation {
  color: #B81111;
}

body .modal-header {
  	border-bottom: 0;
	justify-content: center; 
}

body .modal-body {
  text-align: center;
  justify-content: center;
}

body .modal-footer {
  border-top: 0;
  justify-content: center;
}

body .modal-footer button {
 	min-width: 100px;
  	margin-right: 15px;
}

body .modal-footer button:last-child {
  	margin-right: inherit;
}


/* (Extra) small devices (portrait tablets and phones, 600px and up) */
@media only screen and (max-width: 767px)  {
  .roof-type-wrapper {
    min-height: 625px;
  }
}

/* Medium devices (landscape tablets, 768px and up) */
@media only screen and (min-width: 768px) {
  .roof-type-wrapper {
    min-height: 315px;
  }
}

/* (Extra) large devices (laptops/desktops, 992px and up) */
@media only screen and (min-width: 1200px) {
  .roof-type-wrapper {
    min-height: 170px;
  }
}

.roof-types {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    position: absolute;
    background-color: #f9f9f9;
    left: 0;
    bottom: -1rem;
    padding: 15px;
    height: auto;
}

