/*@import url('https://fonts.googleapis.com/css?family=Roboto:400,400i,700&display=swap');*/

html {
    background: #ffffff;
    color: #000000;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    overflow: auto;
    text-shadow: none;
    -webkit-filter: none;
    filter: none;
}

body {
    margin: 0;
    padding: 0;
    font-family: 'Arial', sans-serif;
    /*font-size: 1em;*/
    color: #222222;
    overflow-x: hidden !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: #222222;
}

h1{
    font-weight: 700;
    padding: 2.5rem 0;
    line-height: 1.5;
    font-size: 1.75rem;
    text-align: center;
    text-transform: uppercase;
}

h1:first-child {
    margin-top: 0;
}

h1:last-child {
    margin-bottom: 0;
}

.formHeader {
    text-align: center;
}

h2:first-child {
    margin-top: 0;
}

h2:last-child {
    margin-bottom: 0;
}

h3 {
    text-align: left;
    font-weight: 700;
    margin: 1.25rem 0 .625rem;
    line-height: 1.5;
    font-size: 1.25rem;
}

h3:first-child {
    margin-top: 0;
}

h3:last-child {
    margin-bottom: 0;
}

h4 {
    text-align: left;
    font-weight: 700;
    margin: 1.25rem 0 .625rem;
    line-height: 1.5;
    font-size: 1.125rem;
}

h4:first-child {
    margin-top: 0;
}

h4:last-child {
    margin-bottom: 0;
}

h5 {
    text-align: left;
    font-weight: 700;
    margin: 1.25rem 0 .625rem;
    line-height: 1.5;
    font-size: 1rem;
}

h5:first-child {
    margin-top: 0;
}

h5:last-child {
    margin-bottom: 0;
}

h6 {
    text-align: left;
    font-weight: 700;
    margin: 1.25rem 0 .625rem;
    line-height: 1.5;
    font-size: .875rem;
}

h6:first-child {
    margin-top: 0;
}

h6:last-child {
    margin-bottom: 0;
}

a {
    color: #222222;
    line-height: 1.5;
    text-decoration: underline;
    font-weight: 700;
    color: inherit;
}

a:focus {
    z-index: 99;
    position: relative;
}

a:focus,
a:hover {
    transition: color .3s;
    color:  #003C88 ;
    text-decoration: underline;
    border: dotted;
}

a:not(.btn):focus{
    outline: thin dotted;
}

a[target=_blank]::after{
    content: " \e62f";
    font-family: shell;
    color: inherit;
    display: inline;
}

legend {
    font-size: inherit;
    font-weight: 700;
}

b,
strong {
    font-weight: 700;
}

.lower {
	text-transform: lowercase;
}

.tm {
    vertical-align: top; 
    position: relative; 
    top: 0.5em;
    font-size: medium;
}

.btn:hover,
.btn:focus{
    box-shadow: none;
}

.btn-primary:hover,
.btn-primary:focus{
    background-color: #222222;
    color: #FACD30;
    border-color: #222222;
}

.btn-secondary{
    color: #222222;
    background: #FACD30;
    border-color: #222222;
}

.btn-secondary:hover,
.btn-secondary:focus{
    background: #222222;
    color: #FACD30;
    border-color: #FACD30;
}

.btn-collapse:after{
    content: "\e90f";
    font-family: shell;
    font-size: 0.65em;
    text-decoration: none;
    display: inline-block;
    position: relative;
    left: 0.5rem;
}

.btn-collapse.collapsed:after{
    transform: rotate(180deg);
}

.form-control,
.form-control-file{
    border: 1px solid #d9d9d9;
    border-radius: 0;
}

.form-control:focus{
    border-color: #222222;
    box-shadow: none;
}

.custom-select.is-valid, 
.form-control.is-valid, 
.was-validated .custom-select:valid,
.was-validated .form-control:valid{
   border-color: #d9d9d9;
}

.custom-select.is-valid:focus, 
.form-control.is-valid:focus, 
.was-validated .custom-select:valid:focus, 
.was-validated .form-control:valid:focus{
    border-color: #222222;
    box-shadow: none;
}

.form-check-input.is-valid~.form-check-label, 
.was-validated .form-check-input:valid~.form-check-label{
    color: #222222;
}

.nav-pills .nav-link{
    border-radius: 0;
    background: #f3f3f3;
    font-weight: bold;
    padding-top: 12px;
    padding-bottom: 12px;
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link{
    color: #222222;
    background-color: #fbd336;
}

#map_canvas{ 
    width: 100%;
    max-width: 100%; 
    height: 450px; 
}

.locations{
    height: 450px;
    overflow: auto; 
}

.delete{
    cursor: pointer;
    margin-left: 25px;
}

.products .form-check{
    margin-bottom: 7px;
}

.products .form-check .display-on-check{
    display: none;
}

.products .form-check.checked{
    display: flex;
    align-items: center;
}

.products .form-check.checked .display-on-check{
    display: initial;
}

.products .form-check.checked .form-check-label{
  position: absolute;
  left: 94px;
  line-height: 1;
}

.products .form-check.checked .form-check-input{
  margin-top: 0;
}

.products .form-check.checked .form-control.qty{
  width: 65px;
  margin-right: 5px;
  display: inline-block;
}

.grecaptcha-badge { visibility: hidden; }

.landing-buttons {
  white-space: normal; 
  color: #404040; 
  background-color: #FBCE07; 
  border-color: #FBCE07;
}

.flex-centered {
  width: 100%;
  align-items: center;
  margin: auto; 
  text-align: center; 
  vertical-align: middle; 
  height: 25%;
}

.flex-left {
  width: 100%;
  align-items: center;
  margin: auto; 
  text-align: left; 
  vertical-align: middle;
}

a.info {
  position:relative;
  z-index:24;
}

a.info:hover, a.info:focus, a.info:active {
  z-index:25;
}

a.info span {
  display: none;
}

a.info:hover span, a.info:focus span, a.info:active span {
  display: inherit;
  top:1em; left:1em; width:12em;
  border:1px solid #0cf;
  background-color:#cff;
  color:#000;
  text-align: center
}

.modal-footer {
  display: inline-block !important;
}

.withinIframe {
  position: absolute;
}

/***************************** 
				Store Locator 
*****************************/

#big {
  display: inline-block;
}

#small {
  display: none;
}

#backToResults {
  display: none;
}

#tempResultsDiv {
  display:  none;
}

.panel {
	line-height: 2;
}

.slButtons {
	margin-right: 5px;
	margin-bottom: 5px;
}

#stepForward {
	margin-left: 80px
}

/* PROMO SPECIFIC STYLES */
.xs-header-wrapper{
  background: #404040;
}

.header{
  padding-top: 15px;
  padding-bottom: 15px;
}

.xs-banner-wrapper{
  padding-left: 0;
  padding-right: 0;
}

.xs-banner-wrapper:not(.banner-video){
  background: #3a3a3a;
}

/*********************
		Media Queries
*********************/

@media screen and (max-width: 1000px) {
  .flex {
    flex: 100%;
    max-width: 100%;
  }
}

@media screen and (min-width: 768px){
  .xs-header-wrapper,
  .xs-banner-wrapper{
    background: none;
  }

  .header{
    background: #404040;
  }

  .xs-banner-wrapper{
    padding-left: 15px;
    padding-right: 15px;
    background: none !important;
  }

  .banner{
    background: #3a3a3a;
    border-top: 2px solid #595959;
  }
}

@media screen and (min-width: 600px) {
  h1 {
    font-size: 1.875rem;
  }

  h2 {
    font-size: 1.625rem;
  }
}

@media screen and (max-width: 512px) {
	#returnToFormBtn {
		font-size: .8em !important;
	}
}

@media screen and (max-width: 450px){
  .products .form-check.checked .form-check-label{
    position: static !important;
    left: 94px;
    line-height: 1;
  }
}

@media screen and (max-width: 360px) {
  .mapLinks {
    width: 50%;
  }

  .nav {
    overflow: visible;
  }

  .locations {
    overflow: visible;
  }
 
  #big {
    display: none;
  }

  #small {
    display: inline-block;
  }

  #backToResults {
    width: 100%;
  }

  .form-control {
  	font-size: .55em;
  }

  .btn-upload {
  	font-size: .45em;
  }

  .upload-wrapper {
  	width: 104%;
  }

  #form-submit2 {
  	font-size: .8em;
  }

  .carouselLinks {
  	font-size: .9em;
  }
}

@media screen and (max-width: 340px) {
  #returnToFormBtn {
		font-size: .7em !important;
	}
}