
:root {

  --gold: #DCCF73;
  --white: #ffffff;
  --offwhite: #fafafa;
  --black: #1a1a1a;
  --grey: #EFEFEF;
}

html{color:#222;font-size:1em;line-height:1.4}::-moz-selection{background:#b3d4fc;text-shadow:none}::selection{background:#b3d4fc;text-shadow:none}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}audio,canvas,iframe,img,svg,video{vertical-align:middle}fieldset{border:0;margin:0;padding:0}textarea{resize:vertical}.browserupgrade{margin:.2em 0;background:#ccc;color:#000;padding:.2em 0}html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}a{-webkit-transition:all 1s ease;-moz-transition:all 1s ease;-o-transition:all 1s ease;transition:all 1s ease;text-decoration:none;color:#00AEEF}a img{-webkit-transition:all 1s ease;-moz-transition:all 1s ease;-o-transition:all 1s ease;transition:all 1s ease}.smoothie{-webkit-transition:all 1s ease;-moz-transition:all 1s ease;-o-transition:all 1s ease;transition:all 1s ease}


body::-webkit-scrollbar {
  width: 11px;
}
body {
  scrollbar-width: thin;
  scrollbar-color: var(--gold) var(--white);
}
body::-webkit-scrollbar-track {
  background: var(--white);
}
body::-webkit-scrollbar-thumb {
  background-color: var(--gold);
  border-radius: 6px;
  border: 3px solid var(--gold);
}

/* ==========================================================================
   Author's custom styles
   ========================================================================== */


html { box-sizing: border-box; } *, *:before, *:after { box-sizing: inherit; }
a{-webkit-transition:all 1s ease;
         -moz-transition:all 1s ease;
               -o-transition:all 1s ease;
                     transition:all 1s ease;
text-decoration: none;
color: #1a1a1a; font-weight: 600;}
a img{-webkit-transition:all 1s ease;
         -moz-transition:all 1s ease;
               -o-transition:all 1s ease;
                     transition:all 1s ease;}
a:hover{opacity: 0.5;}
.smoothie{-webkit-transition:all 1s ease;
         -moz-transition:all 1s ease;
               -o-transition:all 1s ease;
                     transition:all 1s ease;}
h1,h2,h3,h4,h5,h6{margin: 0 0 10px 0; color: #1a1a1a; font-weight: 300; letter-spacing: 0px; font-family: 'Roboto', sans-serif; text-transform: uppercase}
h1 span{font-weight: 700;}
h2 span{font-weight: 700;}
h3 span{font-weight: 700;}
h4 span{font-weight: 700;}
h5 span{font-weight: 700;}
h6 span{font-weight: 700;}
p{margin: 0 0 10px 0;}
strong{font-weight: 800;}
img, iframe{max-width: 100%;}



.container{width: calc(100% - 40px); max-width: 1920px; margin: 0 auto; font-family: 'Roboto', sans-serif; font-weight: 300;box-shadow: 0 30px 90px rgba(0,0,0,0.25), 0 7px 20px rgba(0,0,0,0.05); }
body{background: #f6f6f6 url(../img/mapfade.png) left center no-repeat; background-size:cover; background-attachment: scroll}
.header{width: calc(100% - 40px); padding: 20px 5%; display: flex; justify-content: space-between; flex-wrap: wrap; align-items: center; position: fixed; top: 0; left: 20px; max-width: 1920px;  background: #fff; background: rgba(0,0,0,0.0); z-index: 125; border-bottom: 1px solid rgba(255,255,255,0.1); }
.logo{width: 140px; }
.logo:hover{opacity: 1;}
.sticky{background: rgba(0,0,0,0.5); border-bottom: 1px solid rgba(255,255,255,0.0);}
.sticky .logo{width: 100px;}
.navlink{color: #fff;font-weight: 400; margin-left: 40px; font-size: 16px; font-weight: 300;}
.current{font-weight: 900; color: #DCCF73;}

.hero{width: 100%; padding: 0; height: 600px; overflow: hidden; background: linear-gradient(to bottom,rgba(255,255,255,1) 0, rgba(255,255,255,1) 89.9%,  rgba(246,246,246,1) 50%, rgba(246,246,246,1) 100%); position: relative; z-index: 5;}
.herocover{position: absolute; top: 0; left: 0; width: 100%; height: 100%;  z-index: 5;background: linear-gradient(to bottom,rgba(0,0,0,0.5) 0, rgba(0,0,0,0.4) 10%, rgba(0,0,0,0) 70%, rgba(0,0,0,0) 100%); z-index: 105;}
.hero img{width: 100%; height: 100%; object-fit: cover; position: relative; z-index: 4;}

.topslide{object-position: top center;}
.centerslide{object-position: center center;}
.bottomslide{object-position: bottom center;}

.content{width: 100%; padding: 40px 5%; position: relative; z-index: 10;}
.fullcontent{width: 100%; padding: 40px 5%; margin: 0 auto; position: relative; z-index: 10;}
.welcome{background: #fff;background: rgba(255,255,255,1); margin-top: -100px; max-width: 67.6777777%; border-top-right-radius: 10px; border-bottom-right-radius: 10px;}
.right{background: #fff;background: rgba(255,255,255,1); margin-top: -100px; max-width: 50%;}

.homecontent{background: rgba(255,255,255,0.7); max-width: 67.6777777%; margin: 40px 0; border-top-right-radius: 10px; border-bottom-right-radius: 10px;}
.logcontent{background: rgba(255,255,255,0.7); max-width: 100%; margin: 40px 0; border-top-right-radius: 10px; border-bottom-right-radius: 10px;}


.splitcontent{width: 100%; padding: 0; display: flex; justify-content: space-between; flex-wrap: wrap;}
.lcontent{width: 48%; padding: 40px 40px 40px 5%; background: rgba(255,255,255,0.7); margin: 40px 0; border-top-right-radius: 10px; border-bottom-right-radius: 10px;}
.rcontent{width: 48%; padding: 40px 5% 40px 40px; background: rgba(255,255,255,0.7); margin: 40px 0; border-top-left-radius: 10px; border-bottom-left-radius: 10px;}


.footer{width: 100%; background: #fff; padding: 20px 5%; font-size: 12px;  display: flex; justify-content: space-between; flex-wrap: wrap; align-items: center; background: rgba(255,255,255,0.7)}
.footleft{width: calc(100% - 120px);}
.infinity{width: 100px;}
.footnav{width: 100%; display: flex; justify-content: flex-start; flex-wrap: wrap; margin-bottom: 10px;}
.footnav span{margin: 0 5px;}
.footnavlink{color: #1a1a1a;}

.copy span{margin: 0 5px;}
.copy a{color: #000; font-weight: 700;}

.shallowhero{width: 100%; padding: 0; height: 400px; overflow: hidden; background: linear-gradient(to bottom,rgba(255,255,255,1) 0, rgba(255,255,255,1) 89.9%,  rgba(246,246,246,1) 50%, rgba(246,246,246,1) 100%); position: relative; z-index: 5;}
.shallowhero img{width: 100%; height: 100%; object-fit: cover; position: relative; z-index: 4;}


.embed-container {
	position: relative;
	padding-bottom: 56.25%; /* 16:9 */
	padding-top: 0;
	height: 0;
}
.embed-container iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
    border: none;
}
.smallprint{font-size: 12px !important;}
.smallprint p{font-size: 12px !important; line-height: 20px;}


.footersocial{display: flex; justify-content: flex-start; flex-wrap: wrap; padding-top: 10px;}
.footersocial a{color: #1a1a1a; margin-right: 20px; font-size: 18px;}
.footersocial a:hover{ }
.footersocial a.twlink:hover{color: #55acee;opacity: 1;}
.footersocial a.lilink:hover{color: #0077B5;opacity: 1;}
.footersocial a.fblink:hover{color: #3b5998;opacity: 1;}
.footersocial a.instalink:hover{color: #DD2A7B;opacity: 1;}
/*
.footer{background: rgba(0,0,0,0.7);}
.footnavlink{color: #DCCF73}
.copy{color: #fff;}
.copy a{color: #fff; font-weight: 700;}

 ==========================================================================
   Table

   ========================================================================== */
.tablestyle {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  -webkit-box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
          box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
border-radius: 10px;
}
.tablestyle th,
td {
  padding: 10px;
  background-color: rgba(255, 255, 255, 0.2);
  color: #fff;
}
.tablestyle th {
  text-align: left;
}
.tablestyle thead th {
  background-color: rgba(41,52,61,0.8);
    color: #fff;
}
.tablestyle tbody tr:hover {
  background-color: rgba(255, 255, 255, 0.3);
}
.tablestyle tbody td {
  position: relative;
}
/*  CHANGED 22/07/21 - does it affect anything??
.tablestyle tbody td:hover:before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -9999px;
  bottom: -9999px;
  background-color: rgba(255, 255, 255, 0.2);
  z-index: -1;
}*/
table.dataTable tbody tr{background:rgba(41,52,61,0.3) !important}
.tablepanel{padding: 20px }

.datatablestyle{color:#000 !important;}

.dataTables_length{padding: 10px 0;}
            .dataTables_length label{color: #fff;} 
            .dataTables_filter{padding: 10px 0;}
            .dataTables_filter label{color: #fff;}
            .dataTables_wrapper .dataTables_info{color: #fff;}
            .dataTables_wrapper .dataTables_paginate .paginate_button{color: #fff;}
            .dataTables_wrapper .dataTables_paginate .paginate_button.disabled{color: #000;}
            .dataTables_wrapper .dataTables_paginate .paginate_button{background: rgba(255,255,255,0.5); border: none;}
            .dataTables_wrapper .dataTables_paginate .paginate_button:hover{background: rgba(255,255,255,1); border: none; color: #333 !important;}

.tablestyle1 {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  -webkit-box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
          box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
}
.tablestyle1 th,
td {
  padding: 10px;
  background-color: rgba(255, 255, 255, 0.2);
  color: #000000;
}
.tablestyle1 th {
  text-align: left;
}
.tablestyle1 thead th {
  background-color: rgba(41,52,61,0.8);
    color: #000000;
}
.tablestyle1 tbody tr:hover {
  background-color: rgba(255, 255, 255, 0.3);
}
.tablestyle1 tbody td {
  position: relative;
       color: #000000;
}
.tablestyle1 tbody td:hover:before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -9999px;
  bottom: -9999px;
  background-color: rgba(255, 255, 255, 0.2);
  z-index: -1;
}



.thedetails{font-size: 14px; padding: 10px 0;}
details {
  border-bottom: 1px solid rgba(225,225,225,0.4);
  margin-bottom: 1rem;
  cursor: pointer;
}
summary{font-weight: 500;}
summary span{width:calc(100% - 30px);}
summary i{transition: all 0.3s; width: 20px; margin-left: 10px;}
details[open] summary i {
 transform: rotate(-90deg);
}
summary{display: flex; justify-content: space-between; flex-wrap: wrap; align-content: center; padding: 10px 0; outline: none;}

summary::-webkit-details-marker {
  display: none;
}
.bodyhead{font-weight: 700; letter-spacing: 0px; font-size: 24px;}

.mapbox{width: 100%; height:400px;}
/* ==========================================================================
   LIST PAGES
   ========================================================================== */
.eachmedia{background: #fff; width: 100%; height: 200px; position: relative; margin-bottom: 15px; display: block; overflow: hidden; border-radius: 10px;}

.eachmediaimage{width: 100%; position: absolute; top: 0; left: 0; height: 100%; overflow: hidden; z-index: 2; transition: 0.1s all ease;}
.eachmediacover{position: absolute; z-index: 3; top: 0; left: 0; right: 0; bottom: 0;background: rgba(26,26,26,0.4); transition: all 0.3s ease;}
.eachmediaimage img{width: 100%; height: 100%; object-fit: cover; transition: all 0.5s ease;}
.eachmediacontent{position: absolute; z-index: 5; width:50%; height: 100%; text-align: left; padding: 20px; top: 0; left: 0; background: linear-gradient(to right,rgba(0,0,0,.58),transparent); position: relative;}
.eachmediadetails{width: 50%; margin-left: 50%; padding: 40px 20px; text-align: left; position: relative; background: #fff;}
.eachmedianame{font-size: 24px; font-weight: 300; text-transform: uppercase; margin-bottom: 5px;color: #fff;}

.eachmediajob{font-weight: 400; font-size: 14px; opacity: 1;color: #fff; }
.eachmedialink{font-weight: 300; font-size: 14px;  color: #DCCF73; color: #fff; padding: 5px 10px; border:1px solid #fff; width:auto; display: inline-block; position: absolute; bottom: 20px; left: 20px; transition: 0.3s all ease; border-radius: 3px;}

.eachmedia:hover{opacity: 1;}
.eachmedia:hover .eachmediaimage img{transform: scale(1.1,1.1);filter: blur(3px);}
.eachmedia:hover .eachmedialink{background: #fff; color: #1a1a1a;}

.card-1 {
  box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
  transition: all 0.3s cubic-bezier(.25,.8,.25,1);
}

.card-1:hover {
  box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22);
}

.wherecontent{background: rgba(255,255,255,0.7); max-width: 100%; margin: 40px 0;}
.wheregrid{width: 100%; 

    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    grid-auto-rows: minmax(300px, auto);
    grid-gap: 40px;
}

.eachwhere{background: #fff; width: 100%; position: relative; margin-bottom: 15px; display: flex; overflow: hidden; border-radius: 10px;}

.eachwhereimage{width: 100%; position: absolute; top: 0; left: 0; height: 100%; overflow: hidden; z-index: 2; transition: 0.1s all ease;}
.eachwherecover{position: absolute; z-index: 3; top: 0; left: 0; right: 0; bottom: 0;background: linear-gradient(to right,rgba(0,0,0,.68),transparent);  transition: all 0.3s ease;}
.eachwhereimage img{width: 100%; height: 100%; object-fit: cover; transition: all 0.5s ease;}
.eachwherecontent{z-index: 5; width:100%; text-align: left; padding: 20px; position: relative;}
.eachwherename{font-size: 24px; font-weight: 300; text-transform: uppercase; margin-bottom: 5px;color: #fff;}

.eachwherejob{font-weight: 400; font-size: 14px; opacity: 1;color: #fff; }
.eachwherelink{font-weight: 300; font-size: 14px;  color: #DCCF73; color: #fff; padding: 5px 10px; border:1px solid #fff; width:auto; display: inline-block; position: absolute; bottom: 20px; left: 20px; transition: 0.3s all ease; border-radius: 3px;}

.eachwhere:hover{opacity: 1;}
.eachwhere:hover .eachwhereimage img{transform: scale(1.1,1.1);filter: blur(3px);}
.eachwhere:hover .eachwherelink{background: #fff; color: #1a1a1a;}



/* ==========================================================================
   FORM
   ========================================================================== */
.formcontainer{width: calc(100% - 40px); max-width: 720px; margin: 20px auto; font-family: 'Roboto', sans-serif; font-weight: 300;box-shadow: 0 30px 90px rgba(0,0,0,0.25), 0 7px 20px rgba(0,0,0,0.05); padding: 40px; background: rgba(255,255,255,0.7);}
.theform{width:100%; margin: 0 auto; display: flex; justify-content: space-between; flex-wrap: wrap; padding: 0;}
.logform{width:100%; margin: 0px auto; display: flex; justify-content: space-between; flex-wrap: wrap; padding: 0; max-width: 700px;}
.halfinput{width:  49%; position: relative;}
.fullinput{width: 100%; position: relative;}
.dateinput{margin-bottom: 20px;}
.theform label{font-size: 12px;}
.locator{position: absolute; top: 0; left: -40px; outline: 0px solid red; height: 100%; width: 40px; display: flex; justify-content: center; align-content: center; flex-wrap: wrap;}
.getlocation{cursor: pointer; transition: all 0.3s ease;}
.getlocation:hover{opacity: 0.5;}
.dateinput input{border:1px solid #f9f9f9; padding: 10px; font-size: 0.8rem; background: rgba(0,0,0,0.05); background: #fff; outline: 1px solid #aaa; color: #0C0C0B;}
.dateinput select{border:1px solid #f9f9f9; padding: 10px; font-size: 0.8rem; background: rgba(0,0,0,0.05); background: #fff; outline: 1px solid #aaa; color: #0C0C0B;}
.fullinput select{width: 100%; border:1px solid #f9f9f9; padding: 10px; font-size: 0.8rem; background: rgba(0,0,0,0.05); background: #fff; outline: 1px solid #aaa; color: #0C0C0B; margin-bottom: 20px;}
.textinput{width: 100%; border:1px solid #f9f9f9; padding: 10px; font-size: 0.8rem; background: rgba(0,0,0,0.05); background: #fff; outline: 1px solid #aaa; color: #0C0C0B; margin-bottom: 20px;}
.textinput:focus{outline: 1px solid #0f0f0f; background: #f6f6f6;}
.submitbutton{width: 100%; border:1px solid #1a1a1a; border-radius: 2px; color: #fff; padding: 15px; transition: 0.4s; cursor: pointer; margin-bottom: 20px; text-transform: uppercase; letter-spacing: 1px; background: #1a1a1a}
.submitbutton:hover{background: #fff; color: #1a1a1a;}
textarea{height: 200px; text-align: left;}
.error{width: 100%; color: firebrick;}


.accordion {

    background-color:  #0F7F72; background: #2e3942;

    color: #fff; 

    cursor: pointer;

    padding: 22px 18px;

    width: 100%;

    border:1px solid #fff;

    text-align: left;

    outline: none;

    font-size: 1.1rem;

    transition: 0.4s;

    font-weight: 300;

}

.smallaccordion {



    padding: 10px 8px;

border:0px solid #fff;

    font-size: 14px;
    font-weight: 400;



}

.accordion.active, button.accordion:hover {

    background-color:#181a1e; color: #fff;

}



.accordion:after {

    content: '\02795';

    font-size: 13px;

    color:#FFF;

    float: right;

    margin-left: 5px;

    transition: 0.4s;

}

.accordion:hover:after{color: #fff}

.accordion.active:after {

    content: "\2796";

    color: #fff;

}
.panel {

    padding: 0 18px;

    background:rgba(41,52,61,0.7) ;

    max-height: 0px;

    overflow: hidden;

    transition: 0.6s ease-in-out;

    opacity: 0;

   

}

.innerpanel{margin: 20px auto;}

.panel.show {

    opacity: 1;

    max-height: 1000px;  

}
.printheader{display: flex; justify-content: space-between; flex-wrap: wrap;}
/* ==========================================================================
   EXAMPLE Media Queries for Responsive Design.
   These examples override the primary ('mobile first') styles.
   Modify as content requires.
   ========================================================================== */
@media only screen and (min-width: 1220px) {.navigation{display: flex!important;}.ham{display: none;}}
@media only screen and (max-width: 1220px) {
    
    .header{align-items: center; z-index: 501; transition: all 0.3s ease;}
    .fillbg{background: rgba(0,0,0,0.5);}
    .ham{display: block;}
    .navigation{display: none; width: 100%; height: auto; text-align: right; padding-top: 40px;}
    .navigation a{display: block; width: 100%; margin: 0; font-size: 24px; margin-bottom: 10px;}
}
@media only screen and (max-width: 800px) {
    .container{width: 100%;}
    .header{width: 100%; left: 0;}
    .logo{width: 100px;}
    .welcome{margin: 0; max-width: 100%; background: rgba(255,255,255,0.5);}
    .homecontent{max-width: 100%;}
    .fullcontent{padding: 0 3%;}
    .content{padding: 40px 5%;}
    .homelinkimage{width: 100%; height: 300px;}
    .homelinktext{width: 100%; padding: 20px; background: #fff;}
    .homelinkbutton{position: relative; left: 0; background: #efefef; padding: 10px 40px;}
    .eachtestimonial{width: 100%; padding: 40px 10%;}
    .testimonial{font-size: 22px;}
    .footer{margin-top: 40px;}
    .hero{padding: 0; height: 50vh;}
    
    .header{padding: 20px 5%;}
    .footer{padding: 20px 5%;}
    .latestnews{padding: 0 3%; margin-top: 40px;}
    .eachlatestnews{width: 100%;}
    .eachlatestnews:first-of-type{margin-bottom: 20px;}
    .footleft{width: 100%;}
.infinity{display: none;}
    .halfinput{width:100%;}
    .lcontent{width: 100%; margin-bottom: 20px;}
    .rcontent{width: 100%; margin-bottom: 20px;}
    
    
    @media screen and (max-width: 600px) {
  table.rstyle thead {
    border: none;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
  }

  table.rstyle tr {
    border-bottom: 3px solid #ddd;
    display: block;
  }
  
  table.rstyle td {
    border-bottom: 1px solid #ddd;
    display: block;
    text-align: right;
  }
  
  table.rstyle td::before {
    content: attr(data-label);
    float: left;
  }
        table.rstyle tr td:first-of-type{background-color: rgba(41,52,61,0.8);color: #fff;} 
        table.rstyle tr td:first-of-type a{color: #fff;} 

}
}

@media print,
       (-webkit-min-device-pixel-ratio: 1.25),
       (min-resolution: 1.25dppx),
       (min-resolution: 120dpi) {
    /* Style adjustments for high resolution devices */
}
.hidden{display:none!important}.sr-only{border:0;clip:rect(0,0,0,0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.sr-only.focusable:active,.sr-only.focusable:focus{clip:auto;height:auto;margin:0;overflow:visible;position:static;white-space:inherit;width:auto}.invisible{visibility:hidden}.clearfix:before,.clearfix:after{content:" ";display:table}.clearfix:after{clear:both}@media print{*,*:before,*:after{background:transparent!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}a[href^="#"]:after,a[href^="javascript:"]:after{content:""}pre{white-space:pre-wrap!important}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}}