/*
Theme Name: XT Grid Theme
Author: Xtensive Web Design
Author URI: https://www.xtensive.co.uk
Description: A base theme built with CSS Grid
Version: 1.0
*/
/* Breakpoints */
/* Colors */
.site-header {
  width: 100%;
  background: #FFF;
  top: 0;
  z-index: 100; }
  .site-header .toolbar {
    width: 100%;
    background: #001A33; }
    .site-header .toolbar .container {
      padding: 0 1rem; }
      @media (min-width: 800px) {
        .site-header .toolbar .container {
          padding: 0 2rem; } }
      .site-header .toolbar .container .socials a {
        border-left: 1px solid rgba(255, 255, 255, 0.2);
        border-right: 1px solid rgba(255, 255, 255, 0.2);
        padding: 0.5rem;
        display: block;
        transition: .3s; }
        .site-header .toolbar .container .socials a:hover, .site-header .toolbar .container .socials a:focus {
          background: rgba(255, 255, 255, 0.2); }
      .site-header .toolbar .container .socials iconify-icon {
        color: #FFF; }
      .site-header .toolbar .container .contact {
        display: none; }
        @media (min-width: 800px) {
          .site-header .toolbar .container .contact {
            display: block; } }
        .site-header .toolbar .container .contact a {
          padding: 0.5rem 1rem;
          color: #FFF;
          border-left: 1px solid rgba(255, 255, 255, 0.2);
          font-size: 0.9rem;
          text-decoration-color: transparent; }
          .site-header .toolbar .container .contact a:nth-child(2) {
            border-right: 1px solid rgba(255, 255, 255, 0.2); }
  .site-header #mobile-menu {
    position: fixed;
    background: #001A33;
    width: 100%;
    height: 100svh;
    top: 0;
    left: 0;
    padding: 2rem 1rem;
    padding-top: 74px;
    margin: 0;
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    transition: .3s;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center; }
    .site-header #mobile-menu.active {
      opacity: 1;
      visibility: visible; }
      .site-header #mobile-menu.active .menu li {
        opacity: 1;
        transform: translateY(0);
        transition-delay: .2s; }
        .site-header #mobile-menu.active .menu li:nth-child(2) {
          transition-delay: .3s; }
        .site-header #mobile-menu.active .menu li:nth-child(3) {
          transition-delay: .4s; }
        .site-header #mobile-menu.active .menu li:nth-child(4) {
          transition-delay: .5s; }
        .site-header #mobile-menu.active .menu li:nth-child(5) {
          transition-delay: .6s; }
      .site-header #mobile-menu.active .menu-footer {
        opacity: 1;
        visibility: visible;
        transition-delay: .7s; }
    @media (min-width: 1000px) {
      .site-header #mobile-menu {
        display: none;
        visibility: hidden; } }
    .site-header #mobile-menu .menu {
      list-style-type: none;
      padding: 0;
      margin: 0; }
      .site-header #mobile-menu .menu li {
        margin-bottom: 1rem;
        opacity: 0;
        transform: translateY(1rem);
        transition: .3s; }
        .site-header #mobile-menu .menu li a {
          color: #FFF;
          font-size: 1.8rem;
          font-family: "playfair-display", serif;
          font-weight: 100 !important;
          text-decoration-color: transparent;
          transition: .3s; }
          .site-header #mobile-menu .menu li a:hover, .site-header #mobile-menu .menu li a:focus {
            color: #26C196; }
        .site-header #mobile-menu .menu li:last-child {
          margin-bottom: 0; }
    .site-header #mobile-menu .menu-footer {
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      padding: 2rem 1rem;
      opacity: 0;
      visibility: hidden;
      transition: .3s; }
      .site-header #mobile-menu .menu-footer a {
        font-family: "playfair-display", serif;
        color: #FFF;
        font-size: 1.5rem;
        text-decoration-color: transparent;
        transition: .3s; }
        .site-header #mobile-menu .menu-footer a:hover, .site-header #mobile-menu .menu-footer a:focus {
          color: #26C196; }
  .site-header #mobile-button {
    -webkit-appearance: none;
    appearance: none;
    background: none;
    border: 0;
    position: relative;
    cursor: pointer;
    z-index: 200; }
    @media (min-width: 1000px) {
      .site-header #mobile-button {
        display: none;
        visibility: hidden; } }
    .site-header #mobile-button.active .line {
      background: #001A33; }
      .site-header #mobile-button.active .line:before {
        transform: rotate(-45deg);
        top: 0;
        background: #FFF; }
      .site-header #mobile-button.active .line:after {
        transform: rotate(45deg);
        bottom: 0;
        background: #FFF; }
    .site-header #mobile-button .line {
      width: 30px;
      height: 2px;
      background: #001A33;
      position: relative;
      transition: .3s; }
      .site-header #mobile-button .line:before {
        content: ' ';
        position: absolute;
        top: -10px;
        width: 30px;
        height: 2px;
        left: 0;
        background: #001A33;
        transition: .3s; }
      .site-header #mobile-button .line:after {
        content: ' ';
        position: absolute;
        bottom: -10px;
        width: 30px;
        height: 2px;
        left: 0;
        background: #001A33;
        transition: .3s; }
  .site-header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1rem; }
    @media (min-width: 800px) {
      .site-header .container {
        padding: 1.5rem 2rem; } }
    .site-header .container .logo {
      width: 20%;
      padding: 0;
      z-index: 200; }
      .site-header .container .logo img {
        width: 10rem;
        height: auto; }
        .site-header .container .logo img.active {
          filter: brightness(100) invert(0); }

#main-menu {
  display: none; }
  @media (min-width: 1000px) {
    #main-menu {
      width: 80%;
      display: flex;
      padding-right: 1rem;
      margin: 0; } }
  #main-menu .menu-main-menu-container {
    width: 100%; }
    #main-menu .menu-main-menu-container .menu {
      list-style-type: none;
      padding: 0;
      margin: 0;
      display: flex;
      align-items: center;
      justify-content: flex-end; }
      #main-menu .menu-main-menu-container .menu .menu-item-25 {
        display: none; }
      #main-menu .menu-main-menu-container .menu li {
        overflow: hidden;
        margin-left: 2rem; }
        #main-menu .menu-main-menu-container .menu li a {
          color: #000;
          font-weight: 400;
          text-decoration-color: transparent;
          position: relative;
          overflow: hidden;
          font-size: 1rem;
          transition: .3s; }
          #main-menu .menu-main-menu-container .menu li a:before {
            content: ' ';
            position: absolute;
            bottom: 0px;
            left: -100%;
            width: 100%;
            height: 2px;
            background: #26C196;
            transition: .3s; }
          #main-menu .menu-main-menu-container .menu li a:hover, #main-menu .menu-main-menu-container .menu li a:focus {
            color: #26C196; }
            #main-menu .menu-main-menu-container .menu li a:hover:before, #main-menu .menu-main-menu-container .menu li a:focus:before {
              left: 0; }

.site-footer {
  background: #001A33;
  padding: 4rem 2rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center; }
  .site-footer img {
    width: 100%;
    max-width: 250px;
    filter: brightness(100) invert(0); }
  .site-footer .phone {
    width: 100%;
    margin: 2rem 0;
    font-size: 1.5rem;
    color: #FFF;
    text-decoration-color: transparent; }
  .site-footer .small {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.8); }
    .site-footer .small a {
      color: rgba(255, 255, 255, 0.8);
      text-decoration-color: transparent; }
      .site-footer .small a:hover, .site-footer .small a:focus {
        text-decoration-color: rgba(255, 255, 255, 0.8); }
  .site-footer .menu {
    display: flex;
    flex-wrap: wrap;
    padding: 0;
    margin: 0 0 0 0;
    text-align: center;
    list-style-type: none;
    align-items: center;
    justify-content: center; }
    .site-footer .menu li {
      margin-bottom: 1rem; }
      .site-footer .menu li a {
        margin: 0 1rem;
        font-size: 1rem;
        color: #FFF;
        text-transform: lowercase;
        text-decoration-color: transparent;
        transition: .3s; }
        .site-footer .menu li a:hover, .site-footer .menu li a:focus {
          color: #26C196; }

.carousel {
  width: 100%;
  height: calc(100svh - 110px);
  overflow: hidden;
  position: relative;
  z-index: 1; }
  .carousel .slick-arrows {
    z-index: 50;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 1rem;
    position: absolute; }
    .carousel .slick-arrows button {
      -webkit-appearance: none;
      appearance: none;
      background: none;
      border: 0;
      cursor: pointer; }
      .carousel .slick-arrows button iconify-icon {
        color: #FFF; }
      .carousel .slick-arrows button:hover iconify-icon, .carousel .slick-arrows button:focus iconify-icon {
        color: #26C196; }
  .carousel .slides {
    width: 100%;
    height: calc(100svh - 110px);
    position: relative;
    padding: 0;
    margin: 0; }
    .carousel .slides li {
      position: relative;
      height: calc(100svh - 110px); }
      .carousel .slides li img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        position: relative; }
      .carousel .slides li .overlay {
        position: absolute;
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
        background: rgba(0, 26, 51, 0.4);
        background: linear-gradient(90deg, rgba(0, 26, 51, 0.7) 0%, rgba(0, 26, 51, 0.2) 100%); }
        .carousel .slides li .overlay .container {
          width: 100%;
          max-width: 1800px;
          margin: 0 auto;
          height: 100%;
          padding: 1rem;
          display: flex;
          flex-direction: column;
          align-items: flex-start;
          justify-content: center; }
          @media (min-width: 800px) {
            .carousel .slides li .overlay .container {
              padding: 1rem 2rem; } }
          .carousel .slides li .overlay .container .title {
            font-size: calc(2rem + 0.5vw);
            font-family: "playfair-display", serif;
            color: #FFF;
            padding: 0;
            margin: 0;
            opacity: 0;
            transform: translateY(1rem);
            animation: fadeup 1s ease;
            animation-fill-mode: forwards; }
          .carousel .slides li .overlay .container p {
            color: #FFF;
            font-size: 1.2rem;
            margin: 0;
            padding: 0;
            opacity: 0;
            transform: translateY(1rem);
            animation: fadeup 1s ease;
            animation-fill-mode: forwards;
            animation-delay: .2s; }
          .carousel .slides li .overlay .container .btn {
            margin-top: 2rem;
            opacity: 0;
            transform: translateY(1rem);
            animation: fadeup 1s ease;
            animation-fill-mode: forwards;
            animation-delay: .4s; }

.blog-header {
  width: 100%;
  background: #333;
  padding: 2rem;
  text-align: center; }
  .blog-header h2 {
    color: #FFF; }

.blog-main {
  display: flex;
  flex-wrap: wrap;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-gap: 1.25rem;
  padding: 2rem;
  max-width: 75rem;
  margin: 0 auto; }
  @media (min-width: 576px) {
    .blog-main {
      grid-template-columns: repeat(2, 1fr); } }
  @media (min-width: 1000px) {
    .blog-main {
      grid-template-columns: repeat(3, 1fr); } }

.blog-post {
  display: flex;
  flex-direction: column;
  text-decoration: none; }
  @media (min-width: 576px) {
    .blog-post {
      width: 48%;
      margin: 0 1%; }
      @supports (display: grid) {
        .blog-post {
          width: 100%;
          margin: 0; } } }
  .blog-post .image {
    width: 100%;
    height: 300px;
    background-size: cover !important;
    background-position: center center !important; }
  .blog-post .meta {
    color: #000;
    text-transform: uppercase;
    font-size: 0.9rem; }
  .blog-post .title {
    color: #000;
    font-size: 1.2rem; }
  .blog-post p {
    color: #000; }

.post-single {
  width: 100%;
  max-width: 75rem;
  padding: 2rem;
  margin: 0 auto; }
  .post-single .attachment-post-thumbnail {
    width: 100%;
    height: auto; }

.share-buttons {
  font-size: 0.7rem;
  line-height: 0.7rem;
  letter-spacing: 0.063rem;
  text-transform: uppercase;
  margin: 0 0 3.75rem;
  z-index: 2;
  position: relative;
  text-align: center;
  list-style-type: none;
  padding: 0;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-content: flex-start; }
  .share-buttons li {
    height: auto;
    flex: 0 1 auto;
    width: calc(33.3333333% - 1px);
    margin-right: 0.063rem; }
    .share-buttons li:last-child {
      width: 33.3333333%;
      margin-right: 0; }
      .share-buttons li:last-child a {
        border-radius: 0 0.188rem 0.188rem 0; }
    .share-buttons li:first-child a {
      border-radius: 0.188rem 0 0 0.188rem; }
  .share-buttons svg {
    fill: #fff;
    margin-right: 0.313rem;
    width: 1rem;
    height: 1rem; }
  .share-buttons a {
    display: block;
    padding: 0.75rem 0.75rem 0.563rem;
    text-align: center;
    color: White; }

.share-twitter {
  background: #1da1f2; }

.share-facebook {
  background: #3b5998; }

.share-pinterest {
  background: #b5071a; }

.error {
  width: 100%;
  height: 100vh;
  background: #f6f6f6;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column; }
  .error .content {
    max-width: 61.25rem;
    width: 100%;
    padding: 2rem;
    text-align: center; }
    .error .content h1 {
      font-size: 14rem;
      font-weight: 900;
      margin: 0;
      padding: 0;
      color: #000; }
    .error .content h3 {
      font-size: 5rem;
      font-weight: 900;
      color: #000;
      margin: 0;
      padding: 0; }
    .error .content h4 {
      font-size: 2rem;
      color: #000;
      margin-top: 0.625rem; }
    .error .content a {
      background: #FFF;
      border: 3px solid #000;
      color: #000;
      margin-top: 0.625rem;
      padding: 0.5rem 2rem;
      display: inline-block; }
      .error .content a:hover {
        background: #000;
        text-decoration: none;
        color: #FFF; }

html {
  box-sizing: border-box; }

* {
  box-sizing: inherit;
  font-family: "indivisible", sans-serif; }

h1, h2, h3 {
  font-family: "playfair-display", serif; }

body {
  font-size: 16px;
  padding: 0;
  margin: 0; }

p {
  font-size: 1rem;
  line-height: 1.6rem; }

.entry-content .alignwide {
  margin-left: -80px;
  margin-right: -80px; }

.entry-content .alignfull {
  margin-left: calc( -100vw / 2 + 100% / 2 );
  margin-right: calc( -100vw / 2 + 100% / 2 );
  max-width: 100vw; }

.alignfull img {
  width: 100vw; }

.js-scroll {
  opacity: 0;
  transition: opacity 500ms; }

.js-scroll.scrolled {
  opacity: 1; }

.scrolled.fade-in {
  animation: fade-in 1s ease-in-out both; }

@keyframes fadeup {
  from {
    opacity: 0;
    transform: translateY(1rem); }
  to {
    opacity: 1;
    transform: translateY(0); } }
.container {
  width: 100%;
  max-width: 1800px;
  margin: 0 auto; }

.btn, #gform_submit_button_1, #gform_submit_button_2, #gform_submit_button_3 {
  background: #26C196;
  padding: 1.2rem 2rem;
  border-radius: 100px;
  color: #001A33;
  text-decoration-color: transparent;
  font-weight: 600;
  font-size: 1rem;
  transition: .3s;
  border: 0;
  cursor: pointer; }
  .btn:hover, .btn:focus, #gform_submit_button_1:hover, #gform_submit_button_1:focus, #gform_submit_button_2:hover, #gform_submit_button_2:focus, #gform_submit_button_3:hover, #gform_submit_button_3:focus {
    background: #6be2c1; }

#gform_submit_button_2 {
  padding: 0.8rem 2rem; }

.home-text {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 6rem 2rem;
  text-align: center; }
  .home-text h1 {
    font-size: calc(2rem + 0.5vw);
    line-height: 2rem;
    padding: 0;
    margin: 0 0 2rem 0;
    color: #001A33; }
  .home-text .btn {
    margin-top: 1rem;
    display: inline-block; }

.greenhead-block {
  width: 100%;
  background: #C5CFDA;
  display: flex;
  flex-wrap: wrap; }
  @media (min-width: 800px) {
    .greenhead-block {
      flex-direction: row-reverse; } }
  .greenhead-block .image {
    width: 100%;
    height: 500px; }
    @media (min-width: 800px) {
      .greenhead-block .image {
        width: 50%;
        height: 600px; } }
    .greenhead-block .image img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
  .greenhead-block .content {
    padding: 4rem 2rem;
    width: 100%; }
    @media (min-width: 800px) {
      .greenhead-block .content {
        width: 50%;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: center; } }
    .greenhead-block .content h2 {
      font-size: calc(2rem + 0.5vw);
      padding: 0;
      margin: 0;
      color: #001A33;
      position: relative; }
      .greenhead-block .content h2:before {
        content: "Welcome to";
        position: absolute;
        top: -0.5rem;
        left: 0;
        font-size: 1rem; }
    .greenhead-block .content p {
      margin: 1rem 0 0 0; }
    .greenhead-block .content .btn {
      display: inline-block;
      margin-top: 2rem; }

.content-blocks {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 8rem 2rem;
  display: flex;
  flex-wrap: wrap; }
  .content-blocks .content-block {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 4rem; }
    .content-blocks .content-block:last-child {
      margin-bottom: 0; }
    @media (min-width: 800px) {
      .content-blocks .content-block {
        margin-bottom: 8rem; }
        .content-blocks .content-block:nth-child(even) {
          flex-direction: row-reverse; }
          .content-blocks .content-block:nth-child(even) .content {
            padding-left: 0;
            padding-right: 3rem; } }
    .content-blocks .content-block .image {
      width: 100%;
      height: 350px;
      border-radius: 10px;
      overflow: hidden; }
      @media (min-width: 800px) {
        .content-blocks .content-block .image {
          width: 50%;
          height: 450px; } }
      .content-blocks .content-block .image img {
        width: 100%;
        height: 100%;
        object-fit: cover; }
    .content-blocks .content-block .content {
      width: 100%;
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      justify-content: center; }
      @media (min-width: 800px) {
        .content-blocks .content-block .content {
          width: 50%;
          padding-left: 3rem; } }
      .content-blocks .content-block .content h2 {
        font-size: calc(2rem + 0.5vw);
        padding: 0;
        margin: 1rem 0 0 0;
        color: #001A33; }
      .content-blocks .content-block .content .btn {
        display: inline-block;
        margin-top: 1rem; }

.page-header {
  width: 100%;
  height: 450px;
  position: relative; }
  .page-header img {
    width: 100%;
    height: 100%;
    object-fit: cover; }
  .page-header .overlay {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: rgba(0, 26, 51, 0.6);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center; }
    .page-header .overlay h1 {
      font-size: calc(3.5rem + 0.5vw);
      padding: 0;
      margin: 0 0 0 0;
      color: #FFF;
      opacity: 0;
      transform: translateY(1rem);
      transition: .3s;
      animation: fadeup 1s ease;
      animation-fill-mode: forwards; }
    .page-header .overlay p {
      width: 100%;
      max-width: 800px;
      margin: 0 auto;
      color: #FFF;
      font-size: 1.2rem;
      opacity: 0;
      transform: translateY(1rem);
      transition: .3s;
      animation: fadeup 1s ease;
      animation-fill-mode: forwards;
      animation-delay: .2s; }

.std-content {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  padding: 4rem 2rem;
  opacity: 0;
  transform: translateY(1rem);
  transition: .3s;
  animation: fadeup 1s ease;
  animation-fill-mode: forwards;
  animation-delay: .4s; }
  .std-content .gfield_label {
    font-weight: 400 !important; }
  .std-content .gfield_required {
    color: #094EA2 !important; }
  .std-content .gfield_consent_label a {
    color: #094EA2; }
  .std-content input[type='text'], .std-content input[type='email'], .std-content input[type='tel'], .std-content textarea {
    -webkit-appearance: none;
    appearance: none;
    border: 0;
    background: #eee;
    border-radius: 100px;
    height: 45px;
    padding: 1rem !important; }
  .std-content textarea {
    height: 150px;
    border-radius: 10px; }

.greenhead-development {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 4rem 2rem;
  display: flex;
  flex-wrap: wrap; }
  @media (min-width: 800px) {
    .greenhead-development {
      padding: 4rem; } }
  .greenhead-development article {
    width: 100%;
    opacity: 0;
    transform: translateY(1rem);
    animation: fadeup 1s ease;
    animation-fill-mode: forwards;
    animation-delay: .6s; }
    @media (min-width: 800px) {
      .greenhead-development article {
        width: 65%;
        padding-right: 4rem; } }
    .greenhead-development article h2 {
      font-size: calc(2rem + 0.5vw);
      line-height: 2.8rem;
      padding: 0;
      margin: 0 0 2rem 0;
      color: #094EA2; }
  .greenhead-development aside {
    width: 100%;
    opacity: 0;
    transform: translateY(1rem);
    animation: fadeup 1s ease;
    animation-fill-mode: forwards;
    animation-delay: .6s; }
    @media (min-width: 800px) {
      .greenhead-development aside {
        width: 30%;
        margin-left: 5%; } }
    .greenhead-development aside .box {
      background: #C5CFDA;
      border-radius: 10px; }
      .greenhead-development aside .box .gravity-theme {
        padding: 1rem; }
        .greenhead-development aside .box .gravity-theme .gfield_label {
          font-weight: 400 !important;
          font-size: 0.9rem; }
        .greenhead-development aside .box .gravity-theme .gfield_required {
          color: #001A33;
          font-size: 0.9rem; }
        .greenhead-development aside .box .gravity-theme input[type='text'], .greenhead-development aside .box .gravity-theme input[type='tel'], .greenhead-development aside .box .gravity-theme input[type='email'] {
          border-radius: 20px;
          background: #FFF;
          border: 0; }
        .greenhead-development aside .box .gravity-theme .gfield_consent_label {
          font-size: 0.9rem; }
          .greenhead-development aside .box .gravity-theme .gfield_consent_label a {
            color: #001A33; }
      .greenhead-development aside .box h2 {
        background: #001A33;
        padding: 1rem 1rem 1.2rem 1rem;
        margin: 0;
        border-top-left-radius: 10px;
        border-top-right-radius: 10px;
        text-align: center;
        color: #FFF;
        font-size: calc(1.2rem + 0.5vw);
        line-height: 2rem; }

#input_2_7, #input_3_8, #input_3_10, #input_3_11, #input_3_12 {
  -webkit-appearance: menulist-button;
  height: 30px;
  border: 1px solid #CCC;
  background: #FFF; }

/* animation css
opacity: 0;
      -webkit-animation: fadein 2s;
      -moz-animation: fadein 2s;
      -ms-animation: fadein 2s;
      -o-animation: fadein 2s;
      animation: fadein 2s;
      animation-delay: 1s;
      -webkit-animation-fill-mode: forwards;   */

/*# sourceMappingURL=style.css.map */
