*{
  box-sizing:border-box;
}
body, input, textarea, button{
  font-family: "Quicksand", "sans-serif";
  font-size:18px;
}
.clearfix{
  display: table;
  content: " ";
  clear:both;
}
header{
  position:relative;
  display:block;
  width:100%;
}
header .inner{
  background: #007EFE;
  padding: 30px;
  box-shadow: 0 1px 3px #aaa;
}
h1 {
  color:#fff;
  font-size:40px;
  font-weight:100;
  text-transform:uppercase;
  letter-spacing: 10px;
  text-align: center;
}
h1 sub{
  display: block;
  font-size: 40%;
}
a{
  color:#f60;
}
a:visited{
  color:#f60;
}
#main_icon{
  display:block;
  width:100px;
  margin:auto;
}

img{
  max-width:100%;
}

img.radius{
  border-radius:5px;
}

main{
  min-height:300px;
  background:#f0f0f0;
  text-align:justify;
}

.central_container{
  max-width:1000px;
}

.central_container p{
  line-height: 1.7;
}

#big_input{
  padding: 5px 10px;
  border: 1px #aaa solid;
  border-radius: 3px;
  font-size: 20px;
  font-family: "Quicksand";
}

#big_submit{
  padding:5px 3px;
  font-size:20px;
  font-family: "Quicksand";
  background:#eee;
  border:1px #ddd solid;
}


#main_jsbbbb_footer{
  padding:10px;
  background:#f8f8f8;
  box-shadow:0 0 3px #aaa;
}

#main_jsbbbb_footer a{
  color:#007EFE !important;
}
#main_jsbbbb_footer a:hover{
  color:#0af !important;
}

.table_wrapper {
  display: block;
  overflow: auto;
  box-shadow: 0 0 3px #40505a;
}

.table_wrapper table{
  min-width:100%;
}

table.options{
  border-collapse: collapse;
}

table.options tr th{
  background:#000;
  color:#fff;
  padding:15px;
  text-align:left;
}

table.options tr td{
  background:#eee;
  vertical-align: middle;
  padding:15px;
}

table.options tr:nth-child(odd) td{
  background:#ddd;
}


@media only screen and (min-width: 700px){
  header.has_subtitle #main_icon{
    margin-top:20px;
  }
  h1{
    margin:auto;
  }

  #main_icon{
    float:left;
  }
}

@media only screen and (min-width: 921.1px){
  .balfbar .menu .item_holder{
    margin:auto;
    width:565px;
  }
  .balfbar .menu .items > li > a {
    text-transform:uppercase;
    letter-spacing: 4px;
    font-size:15px;
    padding-top:17px !important;
  }
}


@supports ((-webkit-text-fill-color: transparent) or (text-fill-color: transparent)) and ((background-clip: text) or (-webkit-background-clip:text)){

  .fancy{
    background: linear-gradient(to right,#f60,#f06);
    background: linear-gradient(45deg,#ef00ff,#f06,#f60,#ff59f8, #0af, #a0f);
    background-size: 400% 400% !important;
  }
  .fancy{
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    position: relative;
  }


}

input{
  padding:3px 5px;
}

label.big{
  display:block;
  box-shadow: 0 1px 3px #aaa;
  border-radius:5px;
  margin:10px auto;
  padding:2px;
  background:#fff;
}

label.big.unselected span, label.big.unselected input{
  opacity:0.3;
}

label.big:focus-within{
  border-color:#f60;
}

label.big span{
  display:block;
  font-size:80%;
  text-transform:uppercase;
  font-weight:bold;
  padding-left:10px;
  margin-top:10px;
}

label.big input{
  font-size:20px;
  padding:10px;
  border:0;
  display:block;
  width:100%;
  background:transparent;
}

label.big input:focus, label.big input:focus-visible{
  outline:0;
}

button, a.button{
  padding:10px;
  background:#ddd;
  border:0;
  border-radius:5px;
  cursor:pointer;
  text-decoration: none;
  color:#000;
  margin:10px;
}

button:hover, a.button:hover{
  background:#ddd;
}

blockquote{
  border:1px #ddd solid;
  background:#f8f8f8;
  padding:30px;
  font-style:italic;
  font-family:serif;
  quotes: "\201C""\201D""\201C""\201D";
}

blockquote:before{
  content: open-quote;
}

blockquote:after{
  content: close-quote;
}

.data_well, .information_well{
  background:#f0f0f0;
  border-radius:30px;
  padding:20px;
  display:block;
  box-shadow: 0 1px 3px #aaa;
  position:relative;
  z-index:2;
}

.data_well{
  background:#fff;
  border-radius:5px;
}

.big_background{
  padding:50px;
  position:relative;
  border-radius:5px;
}
.big_background .background_image{
  position:absolute;
  top:0;
  right:0;
  left:0;
  bottom:0;
  background-size:cover;
  background-repeat:no-repeat;
  opacity:0.4;
  border-radius:5px;
}

label.checkbox{
  margin:10px;
  vertical-align:middle;
}

label.checkbox span{
  border:1px #aaa solid;
  background:#fff;
  width:20px;
  height:20px;
  display:inline-block;
  position:relative;
}

label.checkbox input[type="checkbox"]{
  display:none;
}

label.checkbox input:checked+span:after{
  content: " ";
  position:absolute;
  background:#f60;
  top:3px;
  left:3px;
  right:3px;
  bottom:3px;

}
