@font-face{font-family:Haffer-Regular;src:url(../fonts/Haffer/Regular/Haffer-Regular.woff2)format("woff2"),url(resources/fonts/Haffer/Regular/Haffer-Regular.woff)format("woff"),url(resources/fonts/Haffer/Regular/Haffer-RegularItalic.otf)format("opentype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:Haffer-Bold;src:url(../fonts/Haffer/Bold/Haffer-Bold.woff2)format("woff2"),url(resources/fonts/Haffer/Bold/Haffer-Bold.woff)format("woff"),url(resources/fonts/Haffer/Bold/Haffer-Bold.otf)format("opentype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:Haffer-Medium;src:url(../fonts/Haffer/Medium/Haffer-Medium.woff2)format("woff2"),url(resources/fonts/Haffer/Medium/Haffer-Medium.woff)format("woff"),url(resources/fonts/Haffer/Medium/Haffer-Medium.otf)format("opentype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:Haffer-RegularItalic;src:url(../fonts/Haffer/Regular Italic/Haffer/Haffer-RegularItalic.woff2)format("woff2"),url(resources/fonts/Haffer/Regular Italic/Haffer/Haffer-RegularItalic.woff)format("woff"),url(resources/fonts/Haffer/Regular Italic/Haffer/Haffer-RegularItalic.otf)format("opentype");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:Haffer-BoldItalic;src:url(../fonts/Haffer/Bold Italic/Haffer-BoldItalic.woff2)format("woff2"),url(resources/fonts/Haffer/Bold Italic/Haffer-BoldItalic.woff)format("woff"),url(resources/fonts/Haffer/Bold Italic/Haffer-BoldItalic.otf)format("opentype");font-weight:700;font-style:italic;font-display:swap}
@font-face{font-family:P22Mackinac-Medium;src:url(../fonts/Mackinac/Medium/P22Mackinac-Medium.woff2)format("woff2"),url(resources/fonts/Mackinac/Medium/P22Mackinac-Medium.woff)format("woff"),url(resources/fonts/Mackinac/Medium/P22Mackinac-Medium.otf)format("opentype");font-weight:400;font-style:normal;font-display:swap}

:root{
  --bs-border-color:#ccc;
}
body{
  font-family: "Haffer-Regular";
  color:#555;
  /*max-width: 1024px;
  margin: auto;
  border-left: solid 1px #ddd;
  border-right: solid 1px #ddd;*/
}
a{
  text-decoration:none;
  color:#278EFF;
  font-weight:400
}
input, .form-select, select.form-select option{
  font-size:15px !important;
  color:#555 !important;
}

::placeholder,select:invalid{
  color:#999 !important;
  opacity: 0.7 !important;
  font-size:15px
}

img:focus-visible,img:focus{
  border:none;
  outline:none;
}
header{
  background: linear-gradient(to bottom right,#023A5A,#238AB9 );
  border-bottom: 1px solid #FFFFFF1A !important
}
hr{
  border-top-color:#dee2e6 !important;
  opacity: 1
}
.content{
  min-height:calc(100vh - 164px)
}

.bi {
    display: inline-block;
    fill: currentcolor;
}
.btn {
    --bs-btn-padding-y: 12px;
    --bs-btn-font-family: "Haffer-Regular";
    --bs-btn-font-size: 15px;
    --bs-btn-font-weight: 700;
    --bs-btn-line-height: 1.5;
    --bs-btn-color: #FFF;
    --bs-btn-bg: #ED1B2F;
    --bs-btn-border-color:#ED1B2F;
    --bs-btn-border-radius: 10px;
    --bs-btn-disabled-bg:#ED1B2F;
    --bs-btn-disabled-border-color:#ED1B2F;
    --bs-btn-disabled-opacity:1;
}
.btn-race-category.disabled, .btn-race-category:disabled{
    background-color:#FFF;
    color:#ED1B2F;
    border-color:#ED1B2F;
    opacity:1
}
.btn-primary{
  --bs-btn-hover-bg:#ED1B2F;
  --bs-btn-hover-border-color:#ED1B2F
}
.btn-user{
  border:solid 1px #DDD;
  border-radius:10px;
  background-color:#FFF;
}
header .dropdown-menu {
  transform:initial !important;
  inset:initial !important;
  top:36px !important;
  right:0 !important;
}
.btn-block {
    display: block;
    width: 100%;
}
.form-select{
  padding:11px 10px
}
@media (max-width:410px)
{
  .form-select{
    --bs-form-select-bg-img:none
  }
}
.form-control{
  padding-top:11px;
  padding-bottom:11px
}
.hidden{display: none}
.grecaptcha-badge{display:none}
#divPassword i{
  font-size:20px;
  color:#555
}
#divPassword a.link{
  color:#555
}
#divActivate{
  text-align:center;
}
#divActivate .bi{
  font-size:80px;
  color:#2b936d
}
#spanEmail{
  display:inline-block;
  line-height:25px;
  margin-left:5px
}
.banner-warrior{
  background:url(../i/banner-m.png) no-repeat top center;
  padding-bottom: 33.41%;
  background-size: cover
}
@media (min-width:768px){
  .banner-warrior{
    background:url(../i/banner.png) no-repeat top center;
    background-size: cover;
    padding-bottom: 21%;
  }
}
.banner-kids-obstacle{
  background:url(../i/banner-kids-obstacle-m.jpg) no-repeat top center;
  padding-bottom: 33.41%;
  background-size: contain
}
@media (min-width:768px){
  .banner-kids-obstacle{
    background:url(../i/banner-kids-obstacle.jpg) no-repeat top center;
    background-size: contain;
    padding-bottom: 21%;
  }
}
.race-category{
  border:solid 1px #DDD;
  border-radius: 15px;
  margin: 30px auto;
  color: #FFF;
  overflow:hidden;
}
@media (min-width:768px){
  .race-category{
    border-radius: 24px;
  }
}
.race-category-banner{
  background-size: contain;
  background-repeat: no-repeat;
  background-position: top center;
  padding-bottom:17.5%
}

.r5k-run{
  background-image: url(../i/5k-run.svg);
}
.r5k-run-early-bird{
  background-image: url(../i/5k-run-early-bird.svg);
}
.r5k-run-final-sale{
  background-image: url(../i/5k-run-final-sale.svg);
}
.r5k-run-early-bird-new{
  background-image: url(../i/5k-run-early-bird-new.svg);
}
.r5k-run-loyalty{
  background-image: url(../i/5k-run-loyalty.svg);
}

.kids-run{
  background-image: url(../i/kids-run.svg);
}
.kids-run-loyalty{
  background-image: url(../i/kids-run-loyalty.svg);
}
.kids-run-early-bird{
  background-image: url(../i/kids-run-early-bird.svg);
}
.kids-run-final-sale{
  background-image: url(../i/kids-run-final-sale.svg);
}
.btn-race-category,.btn-race-category:hover{
  background: #ED1B2F;
  padding:8px 20px;
  color:#FFF
}
@media (min-width:500px) {
  .btn-race-category,.btn-race-category:hover{
    padding:12px 35px;
    font-size:18px
  }
}
.form-group{
  margin-top: 30px
}
.form-info{
  font-size: 13px;color:#8A8A8A;margin-top:3px;margin-left:5px
}
.form-error{
  font-size: 13px;color:#FFF;margin-top:5px;margin-left:5px
}
.nav-tabs{margin:0 12px}
.nav-tabs .nav-link.active{
  color:#278EFF !important;
  font-weight:700;
  background-color:initial !important;
  border-color:transparent;
  border-bottom:solid 3px
}
.nav-tabs .nav-link{
  color:#555;
  padding: 10px 4px !important
}
.nav-tabs .nav-link:hover{
  background-color:#f3f3f3
}
@media (min-width:375px)
{
  .nav-tabs .nav-link{
    padding: 10px 11px !important
  }
}
@media (min-width:400px)
{
  .nav-tabs .nav-link{
    padding: 10px 15px !important
  }
}
h2{
  color: #171C60;
  font-weight: 700;
  font-size: 24px;
  font-family:P22Mackinac-Medium
}
.select-time{
  display: inline-block;
  width: 29%;
  max-width: 100px;
  margin-right: 7px
}
.btn-orange,.btn-orange:hover
{
  background-color: #ED1B2F;
  color:#FFF;
}

.btn-white,.btn-white:hover
{
  background-color: #FFF;
  color:#ED1B2F;
  border:solid 1px #ED1B2F;
}

.row-button{
  max-width: 600px;
  margin:auto
}
.jerseysize{
  display: none
}
.jerseysize+label{
  width:32%;
  max-width:145px;
  margin-left: 0;
  margin-top:7px;
  padding: 11px;
  color:#555;
  border: 1px solid #DDD;
  border-radius: 5px;
  display: inline-block;
  position: relative;
  cursor: pointer;
  text-align: center;
}
.jerseysize:checked+label{
  border-color:#FF4500;
  color:#FF4500;
}
.jerseysize:disabled+label:after {
    position: absolute;
    content: "Out of Stock";
    top: 29px;
    left: calc(50% - 32.26px);
    font-size: 11px;
    color: red;
}
.img-product{
  margin-top:30px;
  padding-bottom:100%;
  background-repeat: no-repeat;
  background-size:contain;
  background-position:center;
  border-radius:10px
}
.product-name{
  color:#555;
  font-weight: 700;
  font-size:18px;
  margin-top:10px;
  line-height:normal;
}
.product-desc
{
  color:#555;
  font-weight: 400;
  margin-bottom:15px
}
.product-desc ul
{
  padding-left:22px;
  margin:0
}
.product-price-strike
{
  display: block;
  color:#555;
  font-size:14px;
  text-decoration:line-through;
}
.product-price{
  display: inline-block;
  color:#ED1B2F;
  font-weight: 700;
  font-size:18px;
}
.number-selector {
  display: flex;
  border: 1px solid #ccc;
  border-radius: 10px;
  overflow: hidden;
  margin-top: 20px;
  align-content: stretch;
  flex-wrap: wrap;
}
.number-selector span{
  flex-grow: 1;
  text-align:center
}
.number-selector button, .number-selector span {
  padding: 7px 15px;
  background-color: #fff;
  border: none;
  font-size: 15px;
  cursor: pointer;
}

.number-selector button {
  border-right: 1px solid #ccc;
  width:44px
}

.number-selector button:last-child {
  border-right: none;
  border-left: 1px solid #ccc;

}

.number-selector button:hover {
  background-color: #eee;
}

.number-selector input {
  background-color: white;
  width: 50px;
  text-align: center;
}
.iti__search-input{
  border-radius: 0;
  padding:10px 15px;
  border-bottom:solid 1px #cecece
}
.iti__search-input:focus-visible{
  outline-color:#cecece
}
.iti__country{
  padding:10px var(--iti-spacer-horizontal) !important
}
.footer {
    margin-top: 20px;
    border-top: 1px solid #e1e6ef;
    padding: 10px 0;
    background-color: #ebebeb;
}
.cart-badge{
  background-color: #ED1B2F;
  border-radius:50%;
  font-size: 11px;
  font-style:normal;
  width: 18px;
  height: 18px;
  line-height:19px;
  color: white;
  text-align: center;
  position:absolute;
  right: -10px;
  top: -10px;
}
#spMailbox{
  font-size:20px
}
.badge-dot:empty {
    display: inline-block;
}
.badge-dot
{
    --mdb-badge-border-radius: 4.5px;
    --mdb-badge-height: 9px;
    --mdb-badge-width: 9px;
    --mdb-badge-margin-left: -0.3125rem;
    position: absolute;
    min-width: 0;
    top: -3px;
    right: -2px;
    width: 10px;
    height: 10px;
    border-radius: 10px;
    padding: 0;
    margin-left: var(--mdb-badge-margin-left);
}
