body  { 
    background-color: #ffffff;
    font-family: Raleway, Arial, Helvetica, sans-serif;
    color: #4b4b4b ;
    font-size: 14px;
    line-height: 1.6;
}
#page { 
  min-height: 100vh; 
}
#page-wrapper {
  padding-top: 126px;
  padding-bottom: 50px;
}
.no-pad { padding: 0; }
.float-left { float: left; }
p, a, li, td {
    font-weight: 300;
}
a { 
  color: #999999;
  text-decoration: none;
}
p a {
    font-weight: 700;
}
footer p a {
    font-weight: 300;
}
a:hover,
a:focus {
  color: #454040;
  text-decoration: none;
}
a.green-border {
    border: 2px solid #0095a4;
    color: #0095a4;
    padding: 8px 15px;
    font-size: 18px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    display: inline-block;
}
@media (max-width: 767px) {
    a.green-border {
        margin-bottom: 40px;
    }
}
a.green-border:hover,
a.green-border:focus,
a.green-border:active {
    background: #0095a4;
    color: #ffffff;
    transition: all 0.3s ease;
}
.col-full-width {
    clear: both;    
    margin: 0 calc(50% - 50vw)
}
span.white { color: #ffffff; }
span.green { color: #0095a4; }

/* Sections */
section.header    { 
  background: #ffffff; 
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 1000;
    font-size: 14px;
}
section.header.admin-on {
    top: 80px;
}
section.header.main-nav-scrolled .header-top {
   display: none;
}
section.header.main-nav-scrolled .nav-bg {
    position: fixed;
    top: 0;
    left: 0; 
    width: 100%;
}

section.header.admin-on.main-nav-scrolled .nav-bg {
    top: 80px;
}
@media (min-width: 1500px) {
    section.header .container {
      width: 1440px;
    }
}
section.header p  { margin-bottom: 0; }
.container-fluid { 
    padding-left: 0;
    padding-right: 0;
}
section.header a {
    color: #ffffff;
    text-decoration: none;
}
section.header a:hover {
    color: #ffffff;
}
div.header {
    text-align: center;
}
div.header img {
    display: inline;
}

/* Top Nav */
.nav-bg {
    padding: 0;
    background: #ffffff;
}
@media (min-width: 768px) {
    padding-bottom: 20px;
}
#nav {
  background: #ffffff;
}
.main-nav-scrolled #nav {
    border-top: none;
    border-bottom: none;
}
.nav-bg.main-nav-scrolled {
  top: 50px;
}
.header-top.main-nav-scrolled {
   display: none;
}
#nav .container {
  position: relative;
}
#nav.toolbar-hop {
  top: 230px;
}
#nav.main-nav-scrolled.toolbar-hop {
  top: 130px;
}
/* End Top Nav */

  
header .container { padding-left: 0; padding-right: 0; }
section.main-content { margin-top: 157px; }
@media (min-width: 768px) {
    section.main-content { margin-top: 112x; }
}

.container.main .row {
  margin-left: 0;
  margin-right: 0;
}

@media (min-width: 768px) {
  .container.main .row {
    display: flex;
  }
}

/* Footer */
.footer p {
  font-size: 14px;
}
.footer a { color: #ffffff; }
#back-to-top  { 
  color: #ffffff; 
  background-color: #005869;
  opacity: 0.8; 
  position: fixed;
  height: 45px;
  width: 45px;
  right: 30px;
  bottom: 30px;
  z-index: 1000;
  line-height: 45px;
  text-align: center;
  display: none;
  transition: all 0.3s ease;
  display: none;
}
@media (min-width: 600px) {
    #back-to-top {
        display: block;
    }
}


/* End Footer */



/* Main Content */
h1 {
    color: #4b4b4b; 
    font-weight: normal;     
    font-size: 26px;
}
.page-title h1 {
    text-align: center;
}
@media (min-width: 768px) {
    h1 { 
        font-size:32px; 
    }
}
h2 { 
    font-size: 24px; 
    color: #4b4b4b; 
    font-weight: normal; 
    margin: 20px 0;
}

h3 { font-size:22px; color: #4b4b4b; font-weight: bold; margin: 0 0 30px 0;  }
h4 { font-size:16px; color: #4b4b4b; font-weight: 300; margin: 0 0 20px 0;  }
header img {
    margin: 23px auto 0;
    -ms-transform: scale(0.7);
    -webkit-transform: scale(0.7);
    transform: scale(0.7);   
    max-width: 235px;     
}
@media (min-width: 768px) {
    header img {
        margin-bottom: 23px;
        -ms-transform: scale(1);
        -webkit-transform: scale(1);
        transform: scale(1);         
    }
}
img {
  max-width:100%;
  height: auto;
  display: block;
}
@media (max-width: 399px) {
    img.mobile-responsive {
        transform: scale(0.7);
    }
}
p.text-align-center img,
h1.text-align-center img {
  margin: 0 auto; 35px auto;
}
img.float-right,
img.float-left  {
  margin: 0 auto 10px;
}
@media (min-width: 600px) {
  img.float-right {
    float: right;
    margin: 0 0 10px 10px;
  }
  img.float-left {
    float: left;
    margin: 0 10px 10px 0;
  }
}


/* End main content */

/* Main nav bar */
.navbar { 
    margin-bottom: 0;
    -webkit-border-radius: 0;
    -moz-border-radius: 0; 
    border-radius: 0; 
    min-height: 40px;
}

.navbar-default {
  background: #ffffff;
  color:#000000;
  border: none;
}
.navbar-header {
    width: 100%;
}

.dropdown-menu { 
    background: #0095a4; 
    color:#ffffff; 
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    min-width: 220px;
    padding: 0;
    border: none;
}
ul.nav.navbar-nav {      
  padding-left: 0;
  padding-right: 20px; 
  text-align: center;
  float: none;
}
@media (max-width: 767px) {
    .navbar-nav {
        margin-left: 0;
        margin-right: 0;
    }
}
@media (min-width: 768px) {
    ul.nav.navbar-nav {
        border-top: 1px solid #0095a4;
        border-bottom: 1px solid #0095a4;           
        padding-left: 0;
    }
}
ul.nav.navbar-nav > li {
  float: none;
  display: inline-block; 
}
ul.nav.navbar-nav.collapsing > li,
ul.nav.navbar-nav.collapse.in > li {
  display: block;
  text-align: left;
}
ul.nav.navbar-nav.collapsing li a,
ul.nav.navbar-nav.collapse.navbar-collapse li a { color:#000000; background: #d9eff1; text-decoration: none; }
ul.nav.navbar-nav.collapse.navbar-collapse li a:hover { color: #000000; background: #d9eff1; }
@media (min-width: 768px) {
    ul.nav.navbar-nav.collapse.navbar-collapse li a,
    ul.nav.navbar-nav.collapse.navbar-collapse li a:hover {
        background: #ffffff;
    }
}
ul.nav.navbar-nav.collapse.navbar-collapse ul.dropdown-menu li a { color: #ffffff; background: #0095a4; padding: 7px 15px; text-decoration: none; display: block; text-align: center; }
ul.nav.navbar-nav.collapse.navbar-collapse ul.dropdown-menu li a:hover,
ul.nav.navbar-nav.collapse.navbar-collapse ul.dropdown-menu li a:focus,
ul.nav.navbar-nav.collapse.navbar-collapse ul.dropdown-menu li a:active { color: #ffffff; background: #005869; }
.navbar-default .navbar-nav>.open>a,
.navbar-default .navbar-nav>.open>a:focus,
.navbar-default .navbar-nav>.open>a:hover { color: #ffffff; background: #005869; }

button.navbar-toggle { border: 0;}
.navbar-default .navbar-toggle:hover, .navbar-default .navbar-toggle:focus { background-color: transparent; }
.navbar-default .navbar-toggle .icon-bar       { background-color: #0096a3; }
.navbar-default .navbar-toggle .icon-bar:hover { background-color: #000000; }
.navbar-default .navbar-collapse, .navbar-default .navbar-form { border: none; }
.navbar-toggle {
    float: left;
    margin-left: 15px;
    margin-right: 0;
}

.nav > li > a {
    padding: 10px 5px;
}
@media (min-width: 1024px) {
    .nav > li > a {
        padding: 10px 15px;
    }
}

/* The line below is to hide any views that are to be incorporated into the menu */
section.main-menu .views-element-container { display: none; }

/* End Nav */



/* Footer */
section.footer { 
  color: #ffffff;
  font-weight: normal;
}
section.footer .call p {
    font-size: 20px;
    text-align: center;
}
@media (min-width: 768px) {
  section.footer .call p {
    text-align: left;
  }
}
section.footer .copyright {
    clear: left;
    text-align: center;
}
@media (min-width: 768px) {
  section.footer .copyright {
    text-align: left;
  }
}
section.footer .copyright div {
  display: inline;
}
section.footer .footer-links {
    clear: left;
    text-align: center;
} 
@media (min-width: 768px) {
  section.footer .footer-links {
    text-align: left;
  }
    .footer-logo, .icons {
        position: relative;
        top: -70px;
    }
}
section.footer .footer-logo img {
  margin: 0 auto;
  max-width: 97px;
}
section.footer p        { margin: 0; }
section.footer .copyright-wrapper {
    padding: 40px 0 10px;
    background: #0095a4;
    color: #ffffff;
}
section.footer .copyright p {
  display: inline;
  margin-top: 8px;
  margin-bottom: 8px;
}
section.footer .copyright a {
  color: #ffffff;
}
section.footer .copyright .privacy,
section.footer .copyright .icons {
    padding-top: 0;
}

@media (min-width: 768px) {
    section.footer .copyright .privacy,
    section.footer .copyright .icons {
        padding-top: 30px;
    }
}
section.footer.copyright .icons {
    float: left;
}
@media (min-width: 768px) {
    float: right;
}
section.footer .copyright .icons img {
  max-width: 30px;
}
.copyright { 
  margin: 0 auto;
}
/* End Footer */

hr {
    margin-bottom: 40px;
    margin-top: 0;
    border-top: 1px solid #ccc;
}
.paragraph {
    margin-bottom: 40px;
}
.paragraph--type--slide-with-link {
    margin-bottom: 0;
}
.paragraph.paragraph--type--_-col {
    clear: both;
    margin-top: 40px;
}
.paragraph.paragraph--type--_-col:after {
    content: '';
    display: block;
    clear: both;
}
.grey-slice {
    background: #e7e8e8;
    position: relative;
    top: 70px;
}
.grey-slice .icon {
    position: relative;
    top: -45px;
}
.grey-slice .icon img {
    margin: 0 auto;
    width: 84px;
}
.grey-slice .grey-slice-content {
    position: relative;
    top: -45px;
}

/* Slider */
.slider-wrapper {
    background: #0095a4;
}
.carousel-control {
    width: 8%;
}
@media (min-width: 400px) {
    .carousel-control {
        width: 5%;
    }
}
/*
  Bootstrap Carousel Fade Transition (for Bootstrap 3.3.x)
  CSS from:       http://codepen.io/transportedman/pen/NPWRGq
  and:            http://stackoverflow.com/questions/18548731/bootstrap-3-carousel-fading-to-new-slide-instead-of-sliding-to-new-slide
  Inspired from:  http://codepen.io/Rowno/pen/Afykb 
*/

.modal-content {
  margin: 0 auto;
}
.modal.modal-wide .modal-dialog {
  width: 90%;
}
.modal-wide .modal-body {
  overflow-y: auto;
}

.carousel-inner .views-field-body {
  background: #ffffff;
  padding-bottom: 20px;
}
.carousel-control.left,
.carousel-control.right {
  background: transparent;
}
.carousel-fade.carousel-inner > .item {
    -webkit-transition: opacity 1s ease-in-out;
    -moz-transition: opacity 1s ease-in-out;
    -o-transition: opacity 1s ease-in-out;
    -ms-transition: opacity 1s ease-in-out;    
    transition: opacity 1s ease-in-out;
}
.carousel-fade .carousel-inner .item {
  opacity: 0;
  transition-property: opacity;
}
#slider .carousel-inner > .item > img {
  margin: 0 auto;
  width: 100%;
}
.carousel-fade .carousel-inner .active {
  opacity: 1;
}

.carousel-fade .carousel-inner .active.left,
.carousel-fade .carousel-inner .active.right {
  left: 0;
  opacity: 0;
  z-index: 1;
}

.carousel-fade .carousel-inner .next.left,
.carousel-fade .carousel-inner .prev.right {
  opacity: 1;
}

.carousel-fade .carousel-control {
  z-index: 2;
}

.carousel-indicators {
  display: none;
}
@media (min-width: 768px) {
  .carousel-indicators {
    display: block;
  }
}
.carousel-indicators li {
  margin: 0 4px;
}

/*
  WHAT IS NEW IN 3.3: "Added transforms to improve carousel performance in modern browsers."
  Need to override the 3.3 new styles for modern browsers & apply opacity
*/
@media all and (transform-3d), (-webkit-transform-3d) {
    .carousel-fade .carousel-inner > .item.next,
    .carousel-fade .carousel-inner > .item.active.right {
      opacity: 0;
      -webkit-transform: translate3d(0, 0, 0);
              transform: translate3d(0, 0, 0);
    }
    .carousel-fade .carousel-inner > .item.prev,
    .carousel-fade .carousel-inner > .item.active.left {
      opacity: 0;
      -webkit-transform: translate3d(0, 0, 0);
              transform: translate3d(0, 0, 0);
    }
    .carousel-fade .carousel-inner > .item.next.left,
    .carousel-fade .carousel-inner > .item.prev.right,
    .carousel-fade .carousel-inner > .item.active {
      opacity: 1;
      -webkit-transform: translate3d(0, 0, 0);
              transform: translate3d(0, 0, 0);
    }
}

/* Contact form */
@media (min-width: 768px) {
    .contact-form {
        margin-top: 50px;
        margin-bottom: 50px;
    }
}
.contact-form:after {
    content: '';
    clear: both;
    display: block;
}
.contact-form input,
.contact-form textarea {
    border: 1px solid #dddddd;
    padding: 2px 10px;
    width: 100%;
}
label {
  font-weight: normal;
  margin-top: 5px;
}
.form-item, .form-wrapper {
  margin-bottom: 10px;
}
.form-item:after,
.form-wrapper:after {
  clear: both;
  content: '';
  display: block;
}
input[type="submit"] {
  background: #0095a4;
  color: #ffffff;
  border: 0;
  padding: 10px 20px;
  width: auto;
}
input[type="submit"]:hover {
    background: #005869;
}

/* Social Media */
.icons {
    text-align: center; 
}
@media (min-width: 768px) {
  .icons {
    text-align: right;
  }
}
.icons ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
}
.icons li {
    display: inline;
    margin-left: 5px;
    margin-right: 5px;
}
.icons a {
    text-decoration: none;
    line-height: 50px;   
    display: table-cell; 
    height: 50px;
    vertical-align: middle;
    font-size: 0;
}
.icons a:before {
  display: inline;
  font-size: 30px;
  font-weight: 400;
  font-family: fontawesome;
  transition: all 0.3s ease-in-out;
}
.icons .twitter:before {
  content: '\f099';
}
.icons .facebook:before {
  content: '\f09a';
}
.icons .instagram:before {
  content: '\f16d';
}
.icons .linkedin:before {
  content: '\f0e1';
}
.icons a:hover:before {
    color: #aaaaaa;  
    transition: all 0.3s ease-in-out;
}
.icons img {
  max-width: 35px;
}
.icons img:hover {
    -webkit-filter: brightness(50%);
    filter: brightness(50%);
    transition: all 0.2s ease-in-out;
}   
.social-media-footer {
  clear: both;
  float: left;
} 
@media (min-width: 768px) {
  .social-media-footer {
    clear: none;
    float: right;
  }
}
/* End social media */

/* Header */
header p {
    color: #ffffff;
    font-weight: bold;
    font-size: 18px;
    margin-top: 15px;
}
header a {
    color: #ffffff;
    text-decoration: none;
}


/* End header */

#slider {
    position: relative;
}
.slide-wrapper {
  position: relative;
}
.slide-wrapper .content {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 2.5vw;
}
.slide-wrapper .content h1,
.slide-wrapper .content h2,
.slide-wrapper .content h3,
.slide-wrapper .content h4,
.slide-wrapper .content h5,
.slide-wrapper .content p { 
  display: none;
}
@media (min-width: 768px) {
  .slide-wrapper .content h1,
  .slide-wrapper .content h2,
  .slide-wrapper .content h3,
  .slide-wrapper .content h4,
  .slide-wrapper .content h5,
  .slide-wrapper .content p {
    display: block;
  }
  .slide-wrapper .content h1 {
    color: white;
    margin: 0;
    font-size: clamp(18px, 4.5vw, 57.6px);
    font-weight: normal;
    /*text-shadow: 1px 1px 0 #666666;*/
    line-height: 1;
  }
}


/* Contact us page */
.field--name-field-opt-in input {
    float: right;
    margin-left: 10px;
    width: auto;
}
.field--name-field-opt-in label.option {
    display: none;
}
.field--name-field-opt-in .description {
    font-size: 12px;
}
.form-actions {
    text-align: center;
}

/* EU cookie compliance module overrides */
#sliding-popup > div {
    padding-top: 10px;
}
#sliding-popup button {
    padding-left: 15px;
    padding-right: 15px;
}
.sliding-popup-bottom .eu-cookie-withdraw-tab {
    border: 0;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    opacity: 0;
}
.sliding-popup-bottom .eu-cookie-withdraw-tab.active {
    opacity: 1;
    transition: opacity 0.1s ease-in-out;
}
.sliding-popup-bottom .eu-cookie-withdraw-tab.inactive {
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
}

.eu-cookie-compliance-default-button, .eu-cookie-compliance-hide-button, .eu-cookie-compliance-more-button-thank-you, .eu-cookie-withdraw-button {
    border: none;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    background: #ffffff;
    text-shadow: none;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
}

.eu-cookie-compliance-default-button:hover, .eu-cookie-compliance-hide-button:hover, .eu-cookie-compliance-more-button-thank-you:hover, .eu-cookie-withdraw-button:hover {
    
}

/* Gallery */
.gallery-image img {
    margin-bottom: 30px;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    -webkit-box-shadow: 10px 10px 5px 0px rgba(0,0,0,0.52);
    -moz-box-shadow: 10px 10px 5px 0px rgba(0,0,0,0.52);
    box-shadow: 10px 10px 5px 0px rgba(0,0,0,0.52);    
}

/* Contact block */
@media (max-width: 767px) {
    .contact { 
        text-align: center;
        float: none !important;
        width: 100%;
    }
}
@media (max-width: 1199px) {
    .header p {
        font-size: 14px;
    }
}
@media (min-with: 767px) {
    .header p {
        text-align: right;
    }
}

/* Site branding */
@media (max-width: 767px) {
    .logo {
        text-align: center;
        margin-top: 0;
    }
    .logo img {
        margin: 0 auto;
    }
}

/* Project images */
.project {
    position: relative;
    margin-top: 15px;
    margin-bottom: 15px;
}
.project .project-image img {
    margin: 0 auto;
}
.project .project-description {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    background: #ffffff;
    color: #4b4b4b;
    z-index: 50;
    text-align: center;
    padding: 20px;
}

.project .project-description.show {
    opacity: 0.7;
    transition: all 0.3s ease-in-out;
}

.project .project-description div {
    display: table-cell;
    vertical-align: middle;
}
.project .project-description h2,
.project .project-description p {
    max-width: 400px;
    margin: 0 auto;
}

.project h2 {
    font-family: Raleway, Arial, Helvetica, sans-serif;
}

.project a {
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: #000000;
    display: table;
}

/* Parallax */
.parallax-bg-img {
    display: none;
}
.paragraph--type--parallax {
    min-height: 400px;
    background: transparent;
    margin: 0 calc(50% - 50vw);
}




