/* GLOBAL STYLES
-------------------------------------------------- */

/* FONTS
-------------------------------------------------- */

@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;600;700;800&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Dosis:wght@200;300;400;500;600;700&display=swap');

/* Padding below the footer and lighter body text */

body {
  padding-top: 0rem !important;
  padding-bottom: 0rem !important;
  color: #5a5a5a;
  font-family: 'Open Sans', sans-serif;
}

.bg-dark {
  background-color: #082543!important;
}

a {
  color: #777;
}

a:hover {
  text-decoration: none;
}

.privacy-policy-container h5 {
  font-family: 'Open Sans', sans-serif;
}

/* PAGE FADE IN
-------------------------------------------------- */

body {
  opacity: 1;
  transition: 2s opacity;
}

body.fade-out {
  opacity: 0;
  transition: none;
}

/* TYPOGRAPGY
-------------------------------------------------- */

.alt-font {
  font-family: 'Dosis', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: #111;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Dosis', sans-serif;
  line-height: 1.4;
  font-weight: 400;
}

  p {
    color: #111;
    font-size: 14px;
    font-family: "Open Sans", arial, sans-serif;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
  }

  ul.bullets li {
    color: #565656;
    font-size: 14px;
    font-family: "Open Sans", arial, sans-serif;
    line-height: 1.6;
    font-weight: 300;
    -webkit-font-smoothing: antialiased;
  }

  .text-primary {color: #e0872e !important;}

  .text {
    font-size: 16px;
    font-weight: 300;
    color: #5f5f5f;
    line-height: 1.8;
  }

  .small, small {
    font-weight: 400 !important;
  }

  .section-title {
    margin-bottom: 25px;
    font-size: 1.2em;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.5em;
    line-height: 1.4;
    color: #111;
  }

  footer .section-title {
    color: #fff;
  }

  .section-text p {
    font-size: 15px;
    font-weight: 300;
    color: #565656;
    line-height: 1.7;
  }

  .section-text p.lead {
    font-size: 1.25rem;
    font-weight: 300;
    color: #565656;
    line-height: 1.6;
  }

  .service-title {
    margin-bottom: 6px;
    font-size: 15px;
    text-transform: uppercase;
    letter-spacing: 0.2em;
  }

  .service-text {
    margin-bottom: 22px;
    color: #565656;
    font-size: 15px;
    font-weight: 300;
    line-height: 1.75;
  }

  footer.blockquote-footer {
    padding: 0px;
    font-size: 11px;
    font-weight: 600;
    color: #bbb;
    line-height: 1.7;
    text-transform: uppercase;
    letter-spacing: 2px;
  }

  blockquote p{
    font-style: italic;
    font-weight: 600 !important;
  }

  .blockquote-footer::before {
    color: #e0861b;
  }

/* BUTTONS
-------------------------------------------------- */

.btn-primary {
  color: #fff;
  background-color: #082543;
  border-color: #082543;
}

.btn-primary:hover {
  color: #fff;
  background-color: #0a1c2f;
  border-color: #0a1c2f;
}

.btn-primary-2 {
  color: #fff;
  background-color: #e0872e;
  border-color: #e0872e;
}

.btn-primary-2:hover {
  color: #fff;
  background-color: #c36e18;
  border-color: #c36e18;
}

.btn {border-radius: 2px; font-family: "Open Sans", arial, sans-serif; font-size: 12px; letter-spacing: 2px; font-weight: 400; text-transform: uppercase; height: auto;
padding: 8px 37px;}

/* -------- ARROW LINK -------- */

.a-btn-arrow {
  position: relative;
  display: inline-block;
  font-size: 11px;
  line-height: 30px;
  letter-spacing: 2px;
  font-weight: 600;
  text-decoration: none;
  padding-right: 50px;
  color: white;
}

.a-btn-arrow .arrow-right {
  background-color: white;
}

.a-btn-arrow .arrow-right:before, .a-btn-arrow .arrow-right:after {
  background-color: white;
}

.a-btn-arrow:hover, .a-btn-arrow:focus {
  text-decoration: none;
  outline-color: transparent;
  color: white;
}

.a-btn-arrow:hover .arrow-right, .a-btn-arrow:focus .arrow-right {
  right: 0;
}

.a-btn-arrow-2 {
  position: relative;
  display: inline-block;
  font-size: 11px;
  line-height: 30px;
  letter-spacing: 2px;
  font-weight: 600;
  text-decoration: none;
  padding-right: 50px;
  color: #111111;
}

.a-btn-arrow-2 .arrow-right {
  background-color: #111111;
}

.a-btn-arrow-2 .arrow-right:before, .a-btn-arrow-2 .arrow-right:after {
  background-color: #111111;
}

.a-btn-arrow-2:hover, .a-btn-arrow-2:focus {
  text-decoration: none;
  outline-color: transparent;
  color: #111111;
}

.a-btn-arrow-2:hover .arrow-right, .a-btn-arrow-2:focus .arrow-right {
  right: 0;
}

.arrow-right {
  display: inline-block;
  position: absolute;
  top: 50%;
  margin-top: -1px;
  right: 10px;
  width: 31px;
  height: 1px;
  -webkit-transition: right 0.3s ease-in;
  -o-transition: right 0.3s ease-in;
  transition: right 0.3s ease-in;
}

.arrow-right:before, .arrow-right:after {
  position: absolute;
  display: block;
  right: 0;
  width: 6px;
  height: 1px;
  content: '';
}

.arrow-right:before {
  bottom: 1px;
  -webkit-transform: translateX(0px) translateY(3px) rotate(-45deg);
  -ms-transform: translateX(0px) translateY(3px) rotate(-45deg);
  transform: translateX(0px) translateY(3px) rotate(-45deg);
}

.arrow-right:after {
  top: 1px;
  -webkit-transform: translateX(0px) translateY(-3px) rotate(45deg);
  -ms-transform: translateX(0px) translateY(-3px) rotate(45deg);
  transform: translateX(0px) translateY(-3px) rotate(45deg);
}

.arrow-right.grey {
  background-color: #7e7d7d;
}

.arrow-right.grey:before, .arrow-right.grey:after {
  background-color: #7e7d7d;
}

/* TOP BAR
-------------------------------------------------- */

.navbar-topbar {
  padding-top: .25rem;
  padding-bottom: .25rem;
  font-size: 11px;
  color: #ffffff;
  text-transform: uppercase;
  letter-spacing: 2px;
}

.navbar-topbar a {
  color: #ffffff !important;
}

.navbar-topbar a span{
  color: #e0872e !important;
}

.navbar-brand img {
  width: 200px;
  height: auto;
}

@media (max-width: 767px) {
  .navbar-topbar {
    font-size: 8px;
    letter-spacing: 1px;
  }

  .navbar-topbar.navbar-expand .navbar-nav .nav-link {
    padding-right: .3rem;
    padding-left: .3rem;
  }
}

@media (max-width: 360px) {
  .navbar-topbar {
    font-size: 8px;
    letter-spacing: 1px;
  }

  .navbar-topbar.navbar-expand .navbar-nav .nav-link {
    padding-right: .2rem;
    padding-left: .2rem;
  }
}
@media (max-width: 320px) {
  .navbar-topbar {
    font-size: 8px;
    letter-spacing: 0px;
  }

  .navbar-topbar.navbar-expand .navbar-nav .nav-link {
    padding-right: .2rem;
    padding-left: .2rem;
  }
}

/* NAVIGATION
-------------------------------------------------- */

nav.main-nav ul li {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 4px;
  color: #8b8b8b;
  font-weight: 600;
}

nav.main-nav .navbar-nav .active>.nav-link {
  color: #e0872e !important;
}

/* --------- Mobile toggle navigation  --------- */

.navbar-light .navbar-toggler, .navbar-toggler:focus, .navbar-toggler:hover {
  border: none !important;
}

button.navbar-toggler:focus {outline: none !important;}

/* PAGE HEADER
-------------------------------------------------- */

.page-header h1 {
  font-size: 30px;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.5em;
  text-align: center;
  color: #111;
}

@media (max-width: 767px) {
  .page-header h1 {
    font-size: 23px;
  }
}

/* HOME
-------------------------------------------------- */

section {
  padding: 100px 0;
}

@media (max-width: 767px) {
  section {
    padding: 75px 0;
  }
}

@media (max-width: 991px) {
  section {
    padding: 75px 0;
  }
}

@media (max-width: 1024px) {
  section {
    padding: 75px 0;
  }
}

/* --------- Main Slider  --------- */

.swiper-container {
  width: 100%;
  height: 70vh;
  margin-bottom: 20px;
}

@media (max-width: 767px) {
  .swiper-container {
    height: 40vh;
  }
}

@media (max-width: 991px) {
  .swiper-container {
    height: 40vh;
  }
}

@media (max-width: 1024px) {
  .swiper-container {
    height: 40vh;
  }
}

  @media (max-width: 1199px) and (min-width: 992px) {
  .swiper-container {
    height: 60vh;
  }
}

.swiper-button-next:after, .swiper-button-prev:after {color: #fff;}

.swiper-slide {
  text-align: center;
  font-size: 18px;
  background: #fff;
  color: #fff;
  /* Center slide text vertically */
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: flex-end;
  /**align-items: center;**/
}

.swiper-overlay {
  display: block;
  background: rgba(0,0,0,.4);
  position: absolute;
  bottom: 0;
  text-align: center;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.swiper-gradient-overlay {
  display: block;
  background: linear-gradient(to bottom,rgba(0,0,0,0),rgba(0,0,0,0.7));
  position: absolute;
  bottom: 0;
  text-align: center;
  width: 100%;
  height: 20%;
  z-index: 1;
}

@media (max-width: 991px) and (min-width: 768px) {
.swiper-gradient-overlay {
  height: 30%;
}
}

.slide-content {
  z-index: 2;
}

.slide-content h2 {
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.5em;
  max-width: 1200px;
  line-height: 50px;
  text-shadow: 0 0 7px #000;
  margin-bottom: 35px;
  font-size: 1.5rem;
}

@media (max-width: 1199px) and (min-width: 992px) {
    .slide-content h2 {
  margin-bottom: 40px;
  font-size: 1.5rem;
}
}

@media (max-width: 991px) and (min-width: 768px) {
   .slide-content h2 {
  margin-bottom: 50px;
  font-size: 1.2rem;
}
}

@media (max-width: 767px) {
  .slide-content h2 {
    font-size: 1rem;
    line-height: 30px;
    padding: 0px 100px;
    max-width: 100%;
    letter-spacing: 13px;
  }
}

@media (max-width: 991px) {
  .slide-content h2 {max-width: 700px;}
}

.swiper-pagination-bullet {
  width: 60px;
  height: 3px;
  display: inline-block;
  border-radius: 0px;
  background: #fff;
  opacity: .2;
}

.swiper-pagination-bullet-active {
  opacity: 1;
  background: #fff;
}

.swiper-button-next:focus, .swiper-button-prev:focus {border: none; outline: none;}

/* --------- Block links  --------- */

.block-link {
  position: relative;
  display: block;
  margin: 0 auto;
}

.block-link h2 {
  position: absolute;
  display: table;
  top: 50%!important;
  width: 100%;
  color: #fff;
  text-align: center;
  font-weight: 400;
  text-transform: uppercase;
  font-size: 1.4rem;
  letter-spacing: 0.8em;
  z-index: 2;
  transform: translateY(-50%);
}

@media (max-width: 767px) {
  .block-link h2 {
    font-size: 1.2rem;
    letter-spacing: 0.5em;
  }
}

@media (max-width: 1199px) {
  .block-link h2 {
    letter-spacing: 0.6em;
  }
}

.txt-overlay {
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  background: #000000;
  opacity: 0.5;
  /** background: linear-gradient(to bottom,rgba(0,0,0,0),rgba(0,0,0,1)); **/
  z-index: 1;
  transition: all .35s;
}

.txt-overlay:hover {
  opacity: 0.6;
}

.block-link .block-link-caption {
  color: #fff;
  opacity: 0;
  display: block;
  background: rgba(0,0,0,.4);
  position: absolute;
  bottom: 0;
  text-align: center;
  width: 100%;
  height: 100%;
  -webkit-transition: all .35s;
  -moz-transition: all .35s;
  transition: all .35s;
}

.row.no-gutter div:first-child {
  padding-left: 0px;
  padding-right: 10px;
}

.row.no-gutter div:last-child {
  padding-right: 0px;
  padding-left: 10px;
}

@media (max-width: 767px) {

  .row.no-gutter div:last-child, .row.no-gutter div:first-child {
    padding: 0px;
  }

  .row.no-gutter div:first-child {
    margin-bottom: 10px;
  }

}

.showcase-link .txt-overlay {
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  background: #000000;
  opacity: 0;
  /** background: linear-gradient(to bottom,rgba(0,0,0,0),rgba(0,0,0,1)); **/
  z-index: 1;
  transition: all .35s;
}

.showcase-link .txt-overlay:hover {
  opacity: 0.1;
}

/* --------- Full Width Button  --------- */

.button.button-full {
  display: block !important;
  white-space: normal;
  margin: 0;
  height: auto;
  line-height: 1.6;
  padding: 70px 0;
  font-size: 30px;
  font-weight: 200;
  text-transform: none;
  border-radius: 0;
  position: relative;
  background: rgba(0,0,0,.5);
  transition: all .35s;
}

.button.button-full:hover {background: rgba(0,0,0,.6);}

.button-full h2 {
  color: #fff;
  text-transform: uppercase;
  margin-bottom: 0px;
  letter-spacing: 0.8em;
  font-weight: 400;
  line-height: 50px;
  font-size: 1.4rem;
}

@media (max-width: 767px) {

  .button.button-full {
    padding: 50px 0;
  }

  .button-full h2 {
    font-size: 1.3rem;
    line-height: 40px;
  }
}

@media (max-width: 1199px) {
  .button-full h2 {
    letter-spacing: 0.6em;
    padding: 0 15px;
  }

  .button.button-full {
    padding: 50px 0;
  }
}

.button-overlay {
  position: absolute;
  background: rgba(0,0,0,.4);
  bottom: 0;
  text-align: center;
  width: 100%;
  height: 100%;
  z-index: 1;
}

/* SHOWCASE
-------------------------------------------------- */

/* Gallery */


/* CONTACT US
-------------------------------------------------- */

/* Contact Form */

.contact-form-cont {
  position: relative;
  max-width:550px;
  padding:80px 50px 30px 60px;
}
.contact-form-container-left {
  position: relative;
  margin:0 0 0 40px;
  padding-top:70px;
  padding-bottom:40px;
}
.gray-bg {
  background:#eee;
}
.form-control {
  border-radius:0;
  height:auto;
  box-shadow:none !important;
}
.form-control.error {
  border-color:#E42C3E;
  z-index:1;
}
label.error {
  font-weight:normal;
  visibility:hidden !important;
  display:none !important;
}
.gray-bg-container .contact-form-cont .form-control.valid , .gray-bg-container .contact-form-container-left .form-control.valid {
  border-color:#3db03f;
  z-index:1;
}
.gray-bg-container .contact-form-cont .form-control.error , .gray-bg-container .contact-form-container-left .form-control.error {
  border-color:#E42C3E;
  z-index:1;
}
input, textarea, select, .login-select, .form-control{
  border:none;
  border: 1px solid #dee2e6; 
  border-radius: 0px;
  background:transparent;
  color: #777;
  font-size: 11px;
  outline: medium none;
  padding: 15px 16px 15px 16px;
  margin-bottom: 10px;
  letter-spacing: 1px;
}

input::placeholder, textarea::placeholder {text-transform: uppercase;}

.input-border {
  border: 1px solid #dedede; 
  padding:9px 15px  ;
}
select.input-border {
  border: 1px solid #dedede; 
  padding:9px 20px 9px 10px ;
}
.w-100 {
  width:100%;
}
::-webkit-input-placeholder, .form-control::-webkit-input-placeholder {color: #4b4e53;}
::-moz-placeholder, .form-control::-moz-placeholder           {color:#4b4e53;}/* Firefox 19+*/
:-moz-placeholder, .form-control:-moz-placeholder           {color:#4b4e53;}/* Firefox 18- */
:-ms-input-placeholder, .form-control:-ms-input-placeholder      {color:#4b4e53;}


:focus::-webkit-input-placeholder {color: #a6a7a9;}
:focus::-moz-placeholder          {color:#a6a7a9;}/* Firefox 19+*/
:focus:-moz-placeholder           {color:#a6a7a9;}/* Firefox 18- */
:focus:-ms-input-placeholder      {color:#a6a7a9;}

.form-control:focus, .nl-email-input:focus {
  border-color:#e0872e;
}

/* Google ReCaptcha */

.g-recaptcha {float: right;}

/* Thank you / Error pages */

.text-vertical-center {
  display: table-cell;
  text-align: center;
  vertical-align: middle;
}

.header {
  position: relative;
  display: table;
  width: 100%;
  height: 100%;
  background: url(../img/bg.jpg) no-repeat center center scroll;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

/* Image block left  */

.page-section {
  width: 100%;
  display: block;
  position: relative;
  overflow: hidden;
}

.fes7-box {
  position: relative;
  padding-left: 47px;
  padding-bottom: 10px;
}
.fes7-box-icon {
  position: absolute;
  top: 2px;
  left: 0;
  color: #4b4e53;
  font-size: 30px;
}
.fes7-img-cont {
  overflow: hidden;
  position: absolute;
  height: 100%;
  padding: 0;
  top: 0; 
}
.fes7-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-position: 50% 50%;
  background-size: cover;
  z-index: 0;
  width: 100%;
  display: block; 
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;   
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
  background-repeat: no-repeat;
  background-position: center center;
}
.fes7-img-constr {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background-size: cover;
  background-position: 50% 50%;
  z-index: 0;
  width: 100%;
  display: block; 
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
  background-repeat: no-repeat;
  background-position: center center;  
}

@media (max-width: 992px) {
  .fes7-img-cont {
    position: relative;
  }
  .fes7-img {
    position: relative;
    height: 390px;
  }
}

/* Contact Table */

.borderless td, .borderless th {
  border: none;
  vertical-align: inherit;
}

.table.borderless>tbody>tr>td, .table.borderless>tbody>tr>th, .table.borderless>tfoot>tr>td, .table.borderless>tfoot>tr>th, .table.borderless>thead>tr>td, .table.borderless>thead>tr>th {border-top: 0px; padding-left: 0px;}

.table.borderless>thead>tr>th {
  border-bottom: 0px;
  padding-left: 0px;
}

.borderless th {
  font-weight: normal;
}

.table.opening-times>tbody>tr>td, .table.opening-times>tbody>tr>th, .table.opening-times>tfoot>tr>td, .table.opening-times>tfoot>tr>th, .table.opening-times>thead>tr>td, .table.opening-times>thead>tr>th {
  padding: 4px;
  width: 90px;
  font-weight: 200;
  letter-spacing: 1px;
}

#contactdetails tr td:nth-child(1) {
  width:25%;
}

#contactdetails a, #contactdetails p {color: #5a5a5a;}

.ci-title {
  color: #5a5a5a;
  margin-bottom: 0px;
  font-size: 15px;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.3em;
}

/* FOOTER
-------------------------------------------------- */

footer {
  padding: 100px 0px;
  color: #fff;
}

footer .footer-brand img {max-width: 255px;}

footer .footer-left p {
  font-size: 13px;
  line-height: 26px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.7);
  margin-top: 36px;
  max-width: 470px;
  margin-bottom: 0px;
}

@media (max-width: 767px) {
  footer .footer-left p {margin-bottom: 40px;}

  footer {
    padding: 60px 0px;
    color: #fff;
  }
}

footer .footer-right {
  text-align: right;
}

@media (max-width: 767px) {footer .footer-right {text-align: left;}}

footer .footer-right .section-title {
  font-size: 16px;
}

footer .footer-right ul {
  list-style-type: none;
  font-size: 13px;
  line-height: 30px;
  letter-spacing: 0.7px;
}

@media (max-width: 767px) {
  footer .footer-right ul {
    padding-left: 0px;
  }
}

footer .footer-right ul li a {
  color: #fff;
}

footer hr {
  margin: 50px 0px 50px 0px;
  border-top: 1px solid rgb(255 255 255 / 17%);
}

.copyright .copyright-left {text-align: left;}

.copyright .copyright-right {text-align: right;}

@media (max-width: 767px) {.copyright .copyright-right {text-align: left;}}

.copyright p {
  color: #fff;
  font-size: 9px;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 1px;
}

@media (max-width: 767px) {
  .copyright p {font-size: 8px; text-align: center;}
}

.copyright a {
  color: #fff;
}


/* CUSTOMIZE THE CAROUSEL
-------------------------------------------------- */

/* Carousel base class */
.carousel {
  margin-bottom: 4rem;
}
/* Since positioning the image, we need to help out the caption */
.carousel-caption {
  bottom: 3rem;
  z-index: 10;
}

/* Declare heights because of positioning of img element */
.carousel-item {
  height: 32rem;
}
.carousel-item > img {
  position: absolute;
  top: 0;
  left: 0;
  min-width: 100%;
  height: 32rem;
}

/* MARKETING CONTENT
-------------------------------------------------- */

/* Center align the text within the three columns below the carousel */
.marketing .col-lg-4 {
  margin-bottom: 1.5rem;
  text-align: center;
}
.marketing h2 {
  font-weight: 400;
}
.marketing .col-lg-4 p {
  margin-right: .75rem;
  margin-left: .75rem;
}

/* Featurettes
------------------------- */

.featurette-divider {
  margin: 5rem 0; /* Space out the Bootstrap <hr> more */
}

/* Thin out the marketing headings */
.featurette-heading {
  font-weight: 300;
  line-height: 1;
  letter-spacing: -.05rem;
}

/* RESPONSIVE CSS
-------------------------------------------------- */

@media (min-width: 40em) {
  /* Bump up size of carousel content */
  .carousel-caption p {
    margin-bottom: 1.25rem;
    font-size: 1.25rem;
    line-height: 1.4;
  }

  .featurette-heading {
    font-size: 50px;
  }
}

@media (min-width: 62em) {
  .featurette-heading {
    margin-top: 7rem;
  }
}






@media (min-width: 1200px) {
    .hidden-lg {
        display: none !important;
    }
}

@media (max-width: 1199px) and (min-width: 992px) {
    .hidden-md {
        display: none !important;
    }
}

@media (max-width: 991px) and (min-width: 768px) {
    .hidden-sm {
        display: none !important;
    }
}

@media (max-width: 767px) {
    .hidden-xs {
        display: none !important;
    }
}
