@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@200;300&family=PT+Serif:wght@400;700&display=swap');

/* Small devices (portrait tablets and large phones, 600px and up) */
@media only screen and (min-width: 600px) {
  .comp-grid {
    grid-template-columns: repeat(auto-fit, minmax(600px, 1fr));
  }
}

/* Medium devices (landscape tablets, 768px and up) */
@media screen and (min-width: 768px) {
  .section-tp {
    padding-top: 0.2em;
  }

  .comp-grid {
    grid-template-columns: repeat(auto-fit, minmax(700px, 1fr));
  }
}

/* Large devices (laptops/desktops, 992px and up) */
@media only screen and (min-width: 992px) {
  .grid-img-250 {
      max-width: 355px;
    }

    .comp-grid {
      grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    }
}


/* Extra large devices (large laptops and desktops, 1200px and up) */
@media only screen and (min-width: 1601px) {
  .grid-img-250 {
      max-width: 470px;
    }

    .grid-img-500 {
    max-width: 720px;
  }
}

.card-title {
  margin-bottom:0;
}

a, a:link {
  cursor: pointer;
}

body {
  background-color:#ffffff;
  margin:0;
}

body p {
  font-family:'Montserrat', sans-serif;
  font-size: 18px;
}

header .header-content .header-content-inner h1, h1, h2, h3, h4, h5 {
    font-family: 'PT Serif', serif!important;
    font-weight: 600!important;
}


header {
    /*background-image: linear-gradient(to bottom, rgba(0,0,0,0.8) 0%,rgba(0,0,0,0.3) 100%), url('../img/sb-awards-header-white_text2.jpg');
    background-size: cover;
    background-position: 50% 30%;
    */
    position: relative;
    max-height: 550px;
    height: 100%;
    width: 100%;
    min-height: auto;
    overflow-y: hidden;
    color: white;
    border-bottom: #e0d5a9 18px solid;

}

.header-img-wrap {
    width:100%;
    overflow: hidden;

}

.header-img-wrap img {
  width:100%;
  /*max-width:1440px;*/
}

.frnt-btn{
  font-size: 21px;
  font-family: 'Montserrat', sans-serif;
}

section#contact-us,
section#basket-wrap,
section#entryform-wrap,
section#register-wrap,
section#login-wrap,
section#winners-wrap,
section#crit-wrap,
section#sponsors-pg {
  padding: 50px 0;
}

section h2 {
    font-size: 3vw;
    line-height: 3.5vw;
}

.alert-warning,
.alert-sucess,
.alert-danger {
  font-size:18px;
  text-align: center;
}

.txt-light {color:#E0D5A9}
.txt-white {color:#ffffff}
.txt-dark {color:#000000}
.bg-light{background:#ffffff}
.bg-dark{background:#000000}
.bg-grey{background:#F0F0F0}

.btn {
  opacity: 0.9  ;
  transition: all 0.4s
}

.btn:active:after {
  opacity: 1;
  transition: 0s
}


.btn-xl {
    padding: 15px 45px;
    font-size: 18px;
}

.btn-pad, .inputbasket {
    padding: 0.3rem 2.3rem!important;
    cursor: pointer!important;
}

.btn-white {
    color: #222222;
    background-color: #ffffff;
    border-color: #ffffff;
    font-weight: bold;
    opacity: 0.8;
}

.btn-green, .btn-green:hover, .btn-success{
    color: #ffffff;
    font-weight: bold;
    text-transform: uppercase;
    opacity: 0.8;
}

.btn-lighter {
    color: #000000;
    background-color: #E0D5A9;
    border-color: #E0D5A9;
    border-radius: 2px;
    font-weight: bold;
    opacity: 0.8;
}
.btn-green-outline {
  border-color:#406C55;
}


.btn-outline-white{
  padding-top:1.2em;
  padding-bottom:1.2em;
  border-color:#ffffff;
  color:white;
  border-width: 2px;
}

.btn-green:hover, .btn-lighter:hover, .btn-white:hover {
  opacity: 1;
  cursor: pointer;
}

 .btn-lighter:hover, .btn-outline-white:hover {
   background-color: #406C55;
   border-color: #406C55;
   color:white;
}

#ticket-btns .btn-outline-white{
  border-color:#dedede;
  background:#dedede;
  color:black;
  opacity: 0.2;
}

#ticket-btns .btn-lighter:hover,
#ticket-btns .btn-check+.btn:hover,
#ticket-btns .btn-check:checked+.btn,
#ticket-btns :not(.btn-check)+.btn:active,
#ticket-btns .btn:first-child:active,
#ticket-btns .btn.active,
#ticket-btns .btn.show {
  background-color: #E0D5A9;
  border-color: #E0D5A9;
  color:black;
  opacity: 1;
}

.text-right {
    text-align: right!important;
}

.text-left {
    text-align: left!important;
}

.text-center {
    text-align: center!important;
}

.hidden {
    visibility: hidden;
}


.subh-wrap {
  background-color: #434343;
  padding-top:2.4em;
  padding-bottom:2.4em;
}

.cerm-info {
  text-align: right;
  padding-right: 3em;
}

.ded-info {
  text-align: left;
  padding-left: 3em;
}

.nav-item {
  /*text-transform: uppercase!important;*/
  margin-left: 8px;
  font-family: 'Roboto', sans-serif;
  font-size: 16px;
}

.nav-item:first-child {
  margin-left:0;

}

.nav-link:hover, .nav-link:focus {
  cursor: pointer;
}

.comp-grid {
  display: grid;
}

.comp-pad {
    padding-left: 2em;
    padding-right: 2em;
}

.comp-item {
    padding-top: 40px;
    padding-bottom: 40px;
}

.section-tp {
    padding-top: 4em;
}

.cerm-info h2, .ded-info h2 {
  text-transform: uppercase;
}

.ded-info h2 {
  margin-bottom: 0;
}

.cerm-info h2 {
  border-bottom:4px solid white
}

.cerm-info p, .ded-info p {
  font-size:28px;
  line-height: 35px;
}

 .ded-info p {
   margin-bottom: 0.3rem;
}

#latest-comp-wrap h2, #latest-rstl-wrap h2, #about h2, #judges-frnt h2 {
    text-align: center;
    padding-bottom: 25px;
    margin-bottom: 4vh;
}

#latest-comp-wrap, #latest-rstl-wrap, #entryform-wrap form {
    padding-left: 80px;
    padding-right: 80px;
}

/** Frontpage: Sponsor slider section **/

#sponsors-mob {
  display: none;
  visibility: hidden;
}

.sponsor-wrap {
  overflow: hidden;
  padding: 20px;

  .slider {
    animation: slidein 30s linear infinite;
    white-space: nowrap;
    .logos {
      width: 120%;
      display: inline-block;
      margin: 0px 0;
      margin:10px;
        .imglogo {
        width: calc(100% / 11);
        animation: fade-in 0.5s
          cubic-bezier(0.455, 0.03, 0.515, 0.955) forwards;
        padding: 0px 25px ;
        cursor: pointer;
      }
    }
  }

}

@keyframes slidein {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-120%, 0, 0);
  }
}

@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.slider:hover{
  -webkit-animation-play-state:paused;
  -moz-animation-play-state:paused;
  -o-animation-play-state:paused;
  animation-play-state:paused;
  cursor: pointer;
}

.frnt-spon-img {
  max-width:170px;
}

/** Frontpage: about section **/

  .about-pad, #about h2 {
    text-align: left;
}

#venue{
  background:black;
}

.venue-text {
  position: relative;
  text-align:center;
}

.venue-text p {
    margin-top: 30px;

    + p {
        margin-top: 50px;
    }
}

/*** Frontpage: contact section ***/

.compbg-contact {
    padding: 0;
    background-size: 737px 497px;
}

.comp-abt {
  padding-left:80px;
  padding-right:80px;
}


/*** BOOKINGS PAGE: ***/

#book-now-wrap{
	/*background-image:linear-gradient(to right,#f1f1f1,#efefef)*/
  background-image: linear-gradient(to bottom, rgba(0,0,0,0.8) 0%,rgba(0,0,0,0.3) 100%), url('../img/bg-2.jpg');

}

/*
.bksection{
	position:relative;
	height:100vh
}
.bksection .section-center{
	position:absolute;
	top:50%;
	left:0;
	right:0;
	-webkit-transform:translateY(-50%);
	transform:translateY(-50%)
}
*/

#booking{
	font-family:Raleway,sans-serif
}

.booking-form-right{
  margin:auto;
	padding:90px 40px;
}

.booking-form{
	position:relative;
	/*max-width:642px;*/
	width:100%;
	margin:auto;
	padding:90px 40px;
	overflow:hidden;
	background-size:cover;
	border-radius:5px;
	z-index:20
}
.booking-form::before{
	content:'';
	position:absolute;
	left:0;
	right:0;
	bottom:0;
	top:0;
	background:rgba(0,0,0,.7);
	z-index:-1;
}
.booking-form .form-header{
	text-align:center;
	position:relative;
	margin-bottom:30px
}
.booking-form .form-header h1{
	font-weight:700;
	text-transform:capitalize;
	font-size:42px;
	margin:0;
	color:#fff
}
.booking-form .form-group{
	position:relative;
	margin-bottom:30px
}
.booking-form .form-control{
	background-color:rgba(255,255,255,.2);
	height:60px;
	padding:0 25px;
	border:none;
	border-radius:40px;
	color:#fff;
	-webkit-box-shadow:0 0 0 2px transparent;
	box-shadow:0 0 0 2px transparent;
	-webkit-transition:.2s;
	transition:.2s
}
.booking-form .form-control::-webkit-input-placeholder{
	color:rgba(255,255,255,.5)
}
.booking-form .form-control:-ms-input-placeholder{
	color:rgba(255,255,255,.5)
}
.booking-form .form-control::placeholder{
	color:rgba(255,255,255,.5)
}
.booking-form .form-control:focus{
	-webkit-box-shadow:0 0 0 2px #ff8846;
	box-shadow:0 0 0 2px #ff8846
}
.booking-form input[type=date].form-control{
	padding-top:16px
}
.booking-form input[type=date].form-control:invalid{
	color:rgba(255,255,255,.5)
}
.booking-form input[type=date].form-control+.form-label{
	opacity:1;
	top:10px
}
.booking-form select.form-control{
	-webkit-appearance:none;
	-moz-appearance:none;
	appearance:none
}
.booking-form select.form-control:invalid{
	color:rgba(255,255,255,.5)
}
.booking-form select.form-control+.select-arrow{
	position:absolute;
	right:15px;
	top:50%;
	-webkit-transform:translateY(-50%);
	transform:translateY(-50%);
	width:32px;
	line-height:32px;
	height:32px;
	text-align:center;
	pointer-events:none;
	color:rgba(255,255,255,.5);
	font-size:14px
}
.booking-form select.form-control+.select-arrow:after{
	content:'\279C';
	display:block;
	-webkit-transform:rotate(90deg);
	transform:rotate(90deg)
}
.booking-form select.form-control option{
	color:#000
}
.booking-form .form-label{
	position:absolute;
	top:-10px;
	left:25px;
	opacity:0;
	color:#ff8846;
	font-size:11px;
	font-weight:700;
	text-transform:uppercase;
	letter-spacing:1.3px;
	height:15px;
	line-height:15px;
	-webkit-transition:.2s all;
	transition:.2s all
}
.booking-form .form-group.input-not-empty .form-control{
	padding-top:16px
}
.booking-form .form-group.input-not-empty .form-label{
	opacity:1;
	top:10px
}
.booking-form .submit-btn{
	color:#fff;
	font-weight:700;
	height:60px;
	padding:10px 30px;
	width:100%;
	border-radius:40px;
	border:none;
	text-transform:uppercase;
	font-size:16px;
	letter-spacing:1.3px;
	-webkit-transition:.2s all;
	transition:.2s all
}
.booking-form .submit-btn:focus,.booking-form .submit-btn:hover{
	opacity:.9
}

/*** SPONSORS PAGE: ***/

#sponsors-pg img{
  margin-top:2.5em;
  /*margin-bottom:0.5em;*/
}

.mom-logo {
  height:100px!important;
  margin-top: 10px !important;

}
#sponsors-pg > div > div > a{
  display:block;

}

/*** BASKET PAGE: ***/

.cart-wrap {
    border-bottom: 1px solid #ededed;
    height: 100%;
    padding-top: 2em;
    padding-bottom: 2em;
}

.cart-wrap:last-child {
  border-bottom:none;
}

.cart_item_info .item-a h3{
    color: #000000;
    text-decoration: none;
    font-weight: 400;
    text-transform: uppercase;
    font-size: 25px;
}

.cart_item_info .item-b {
    line-height: 25px;
    font-size: 20px;
    text-transform: capitalize;
}

.cart_item_price {
    font-size: 25px;
    color: #444;
}
.brand-owner-text {
    color: #999999!important;
}

#vat-bar h5 {
    padding-bottom: 5px;
    font-weight: bold;
    color: darkgoldenrod;
    text-decoration: underline;
    font-size: 16px;
}

#vat-bar {
    text-align: right;
    margin-top: 0.5em;
    padding: 10px 0px;
    border-radius: 8px;
}

#vatno-bar {
    margin-bottom: 0.5em;
}

.company_info {
    font-size: 20px;
}

#checkoutBtn, #vatno-bar {
    padding-right: 0;
}

#vatNumber, #vatNumber:focus {
    border: none;
    background: #eeeeee;
    border-radius: 0;
}

.cart_total {
    color: #777;
    border-bottom: 1px dashed #dedede;
    padding-top: 1em;
    padding-bottom: 1em;

}

.cart_total .total-a {
    text-align: right;
    font-size: 18px;
}

.cart_total .total-b {
    text-align: right;
    padding-left: 0;
    font-size: 18px;
    padding-right: 15px;
}

.pay_section {
    margin-top: 1.5em;
}

.login-btn {
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row-reverse wrap;
    flex-flow: wrap;
    justify-content: flex-end;
}

rdo_options {
  margin-bottom: 1rem;
}

#rdo_options label {
    padding-right: 1em;
}

.remove_cart_div {
    text-align: right;
}

#basket-wrap .btn {
  font-size:18px;
}

.inputbasket {
  font-size: 18px;
  border:none;
  background-color:#f2f2f2;
  vertical-align: middle;
}

section#entryform-wrap input,
section#entryform-wrap select,
section#register-wrap select,
section#register-wrap input,
section#login-wrap input,
section#login-wrap select{
  min-height: 50px;
  border:none;
  margin-bottom:1em;
  background: #ededed;

}

section#login-wrap [type="checkbox"]{
  width: 1.2em;
  height:1.2em;
  min-height: auto;

}

section#entryform-wrap input:hover,
section#entryform-wrap select:hover
section#login-wrap input:hover,
section#login-wrap select:hover {
  cursor: pointer;
}

section#entryform-wrap input:focus,
section#entryform-wrap select:focus
section#login-wrap input:focus,
section#login-wrap select:focus {
  background:#fbeeca;
}

#don-wrap {
  padding-right:4em;
}
.don-box {
   padding-top: 2em;
   padding-bottom: 2em;
   padding-left:1em;
   padding-right:1em;
   border: 1px solid #dedede;
   border-radius: 15px;
   text-align: center;
   background: rgb(239,239,239);
   background: linear-gradient(8deg, rgba(239,239,239,1) 0%, rgba(243,243,243,1) 52%, rgba(255,255,255,1) 100%);
}

#don-wrap .btn-outline-primary {
  color: #406C55;
}
#don-wrap .btn-check:checked+.btn,#don-wrap  :not(.btn-check)+.btn:active, #don-wrap .btn:first-child:active, #don-wrap .btn.active, #don-wrap .btn.show {
 background-color: #406C55;
 border-color:#406C55 ;
 color:white;
}

.donate-val-box .don-amnt{
  font-size: 20px;
  font-weight: bold;
}

.don-option{
  transition: all .3s;
}


.don-option:hover, .don-option:focus, .don-option-active {
  background-color: #E0D5A9;
  cursor: pointer;
  border: 2px solid #E0D3A9;
  border-radius: 8px;
  padding: 0.4em;
}

/*** REGISTER PAGE: ***/

#register-wrap{
	/*background-image:linear-gradient(to right,#f1f1f1,#efefef)*/
  background-image: linear-gradient(to bottom, rgba(0,0,0,0.5) 0%,rgba(0,0,0,1) 100%), url('../img/bg-reg.jpg');
  background-repeat: no-repeat;
  background-size: cover;
}

section#register-wrap .card-body {
  padding-left:2em;
  padding-right:2em;
}

section#register-wrap .bg-lighter {
  padding-top:10px!important;
  padding-bottom:10px!important;
}


/*** WINNERS PAGE: ***/
#past-winners .card{
  border-color:white;
}

.judges-container p{
  font-family: sans-serif !important;
}

.tr-border-top{
  border-top: 2px solid !important;
}

@media only screen and (max-width: 899px) {
  .cerm-info p, .ded-info p {
    font-size: 23px;
    line-height: 26px;
  }
  .cerm-info h2 {
    border-bottom: 0 none transparent;
  }

}

@media screen and (max-width: 560px) {

    /*fix AOS gap */
    HTML, body {
    width: 100%;
    overflow-x: hidden;
  }

    section h2 {
      font-size: 28px;
      padding-bottom: 5px;
      margin-bottom: 2vh;
      margin-top: 2vh;
      line-height: 27px;
    }

    .about-pad, #about h2, #contact-frnt {
      text-align: center;
    }

    #about .comp-item, #about .mt-5 {
      padding-bottom: 15px;
      padding-top: 15px;
      margin-top:0px!important ;
    }

     #about .pt-3 {
       padding-top: 0!important;
     }

    .text-right, .text-left {
      text-align: center!important;
    }

    .venue-text {
      top: 0;
    }

    .venue-text p
    + p {
      margin-top:0px;
    }

    .compbg-contact {
      padding-top: 40px;
      padding-bottom: 40px;
    }

    .compbg-contact .d-grid {
      display: block!important;
    }

    .comp-abt {
      padding-left: 30px;
      padding-right: 30px;
    }

    .section-tp {
    padding-top: 1.5em;
    padding-bottom: 1.5em;
    }

    #latest-comp-wrap, #latest-rstl-wrap, #entryform-wrap form {
        padding-left: 8px;
        padding-right: 8px;
    }

    #past-winners .card {
      width:100%!important;
      max-width:100%!important;
    }

    #basket-wrap div {
      text-align: center;

    }

    .cerm-info, .ded-info {
      text-align:center;
      padding-right: 0;
      padding-left: 0;
    }

    .cerm-info h2 {
      border:none;

    }
    .ded-info h2{
      color: #E0D5A9;
    }

    .login-btn {
      flex-flow: column;
    }

    .login-btn .justify-content-end {

    }

    .login-btn .btn {
      width: 80%;
    }

/*
		.imglogo {
    width:150px!important;
		animation: fade-in 0.5s
		  cubic-bezier(0.455, 0.03, 0.515, 0.955) forwards;
		padding: 5px!important;
	  }
    */

    #sponsors {
      display: none;
      visibility: hidden;
    }

    #sponsors-mob {
      display: block;
      visibility: visible;
      padding-top:20px;
      padding-bottom:10px;
    }
/*
    #sponsors-mob .row>*, #sponsors-pg .row>*  {
      width:30%;
      text-align: center;
    }

    */

    #sponsors-mob img  {
      margin:1em 0em 1em;
      height:60px;
    }


    .booking-form,.booking-form-right{
      padding:20px;
    }

    .book-inner-wrap {
      order: 2;
    }

    .book-inner-text-wrap {
      order: 1;
    }

    .hide-mob {
      display:none;
      visibility:hidden;
    }

    #don-wrap {
      padding-right:0;
    }

    .donate-val-box .don-amnt {
      font-size: 28px;

    }

}

/*
@media screen and (min-width: 1180px) {
  .grid-img-250 {
      max-width: 300px;
  }
  .grid-img-500 {
    max-width: 610px;
  }
}
*/
