/*
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 */
header {
  background: #FFF;
  display: flex;
  flex-wrap: wrap;
  display: grid;
  grid-template-columns: repeat(12, 1fr); }
  header .toolbar {
    width: 100%;
    grid-column: 1/13;
    background: #F5F5F7;
    padding: 0.3rem 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem; }
    @media (min-width: 800px) {
      header .toolbar {
        justify-content: flex-end; } }
    header .toolbar a {
      color: #000;
      text-decoration: none;
      margin: 0 1rem;
      display: flex;
      align-items: center;
      text-transform: uppercase; }
    header .toolbar .iconify {
      width: 18px;
      height: 18px;
      margin-right: 0.2rem;
      color: #000; }
  header .logo {
    grid-column: 1/8;
    padding: 0.5rem;
    width: 80%; }
    @supports (display: grid) {
      header .logo {
        width: 100%; } }
    @media (min-width: 800px) {
      header .logo {
        grid-column: 1/4;
        width: 25%; }
        @supports (display: grid) {
          header .logo {
            width: 100%; } } }
    header .logo img {
      width: 100%;
      height: auto; }
  header .mobile-nav {
    grid-column: 11/13;
    justify-self: end;
    align-self: center;
    width: 20%;
    text-align: right; }
    @supports (display: grid) {
      header .mobile-nav {
        width: 100%; } }
    @media (min-width: 800px) {
      header .mobile-nav {
        display: none;
        visibility: hidden; } }
    header .mobile-nav .iconify {
      width: 1.875rem;
      height: 1.875rem; }
    header .mobile-nav button {
      background: none;
      border: none;
      cursor: pointer; }
      header .mobile-nav button:focus, header .mobile-nav button:hover, header .mobile-nav button:active {
        color: #000; }

@media (min-width: 800px) {
  #menu-item-195 a {
    color: #FFF;
    padding: 0.5rem 1.5rem;
    border-radius: 40px;
    background: #A22284; }
    #menu-item-173 a:hover {
      background: #cc2ba6;
      color: #FFF; } }

#main-menu {
  width: 100%;
  display: flex;
  grid-column: 1/13;
  position: relative;
  opacity: 0;
  visibility: hidden;
  height: 0;
  overflow: hidden;
  padding: 0 1rem;
  margin: 0;
  transition: .3s ease-in-out;
  background: #f5f5f7;
  align-items: center; }
  @media (min-width: 800px) {
    #main-menu {
      opacity: 1;
      visibility: visible;
      height: auto;
      grid-column: 4/13;
      justify-content: flex-end;
      background: none;
      width: 75%; }
      @supports (display: grid) {
        #main-menu {
          width: 100%; } } }
  #main-menu.active {
    height: 18.75rem;
    opacity: 1;
    visibility: visible;
    transition: .3s ease-in-out; }

.menu {
  list-style-type: none;
  padding-left: 0; }
  .menu li {
    padding: 0.5rem 0; }
    @media (min-width: 800px) {
      .menu li {
        display: inline;
        padding: 0.5rem 1rem; } }
  .menu a {
    color: #000;
    text-decoration: none;
    font-size: 1rem; }
    .menu a:hover {
      color: #A22284; }

.call-to-action {
  width: 100%;
  background: #581A4A;
  padding: 4rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center; }
  .call-to-action div {
    width: 100%;
    text-align: center; }
    @media (min-width: 800px) {
      .call-to-action div:nth-child(1) {
        width: 75%;
        text-align: left; }
      .call-to-action div:nth-child(2) {
        width: 25%;
        text-align: right; } }
    .call-to-action div h3 {
      color: #FFF;
      text-transform: uppercase;
      font-size: 2rem;
      padding: 0;
      margin: 0; }
    .call-to-action div a {
      background: #A22284;
      padding: 1rem 2rem;
      display: inline-block;
      margin-top: 2rem;
      color: #FFF;
      font-size: 1.3rem;
      text-decoration: none;
      text-transform: uppercase;
      font-weight: 900;
      border-radius: 40px;
      transition: .3s ease; }
      .call-to-action div a:hover {
        background: #cc2ba6;
        transition: .3s ease; }
      @media (min-width: 800px) {
        .call-to-action div a {
          margin-top: 0; } }

footer {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  display: grid;
  grid-template-columns: 1fr;
  padding: 2rem; }
  @media (min-width: 800px) {
    footer {
      grid-template-columns: repeat(2, 1fr); } }
  footer div {
    text-align: center;
    padding: 1rem 0;
    width: 100%; }
    @media (min-width: 800px) {
      footer div {
        width: 50%; }
        @supports (display: grid) {
          footer div {
            width: 100%; } }
        footer div:nth-child(1) {
          text-align: left; }
        footer div:nth-child(2) {
          text-align: right; } }
  footer div img {
    width: 100%;
    max-width: 300px;
    margin-bottom: 0.5rem; }
  @media (min-width: 800px) {
    footer .menu {
      text-align: left; } }
  footer .menu li {
    padding: 0 0.5rem; }
  footer .menu li:first-child {
    padding-left: 0; }
  footer .menu a {
    font-size: 1rem;
    text-transform: uppercase;
    font-weight: 100; }
  footer .iconify {
    width: 45px;
    height: 45px;
    margin: 0 0.1rem;
    border: 2px solid #581A4A;
    border-radius: 200px;
    padding: 0.3rem;
    color: #581A4A; }
    footer .iconify:hover {
      border-color: #A22284;
      color: #A22284; }
  footer a {
    color: #000;
    text-decoration: none; }

.flexslider {
  max-height: 400px;
  overflow: hidden;
  margin: 0;
  border: 0 !important; }

.slide-img {
  width: 100%;
  height: 400px;
  background-size: cover !important;
  background-position: center center !important;
  position: relative; }
  .slide-img .overlay {
    position: absolute;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    padding: 2rem;
    text-align: center; }
    .slide-img .overlay h2 {
      padding: 0;
      margin: 0;
      text-transform: uppercase;
      color: #FFF;
      font-size: 1.7rem;
      letter-spacing: 0.1rem; }
    .slide-img .overlay h4 {
      padding: 0;
      margin: 0;
      color: #FFF;
      font-size: 1.3rem;
      text-transform: uppercase;
      font-weight: 100; }

.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: 992px) {
    .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;
  border-image: linear-gradient(to left, #A22284 0%, #581A4A 100%);
  border-image-slice: 1;
  border-width: 0.625rem; }
  .error .content {
    max-width: 61.25rem;
    width: 100%;
    padding: 2rem;
    text-align: center; }
    .error .content h1 {
      font-size: 14rem;
      line-height: 1em;
      font-weight: 900;
      margin: 0;
      padding: 0;
      background: -webkit-linear-gradient(#A22284, #581A4A);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent; }
    .error .content h3 {
      font-size: 5rem;
      font-weight: 900;
      color: #000;
      margin: 0;
      padding: 0;
      line-height: 1rem; }
    .error .content h4 {
      font-size: 2rem;
      color: #000;
      margin-top: 0.625rem; }
    .error .content a {
      background: #34BAE7;
      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; }

body {
  font-size: 16px;
  padding: 0;
  margin: 0;
  font-family: lato, sans-serif; }

.logos {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 1rem 1rem 0 1rem;
  display: flex;
  flex-wrap: wrap;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 1rem 3rem; }
  @media (min-width: 576px) {
    .logos {
      grid-template-columns: repeat(3, 1fr); } }
  @media (min-width: 800px) {
    .logos {
      grid-template-columns: repeat(5, 1fr);
      grid-gap: 0 3rem; } }
  .logos img {
    width: 80%;
    margin: 0 10%; }

.std-block {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 4rem;
  text-align: center; }
  .std-block h2 {
    color: #A22284;
    text-transform: uppercase;
    font-size: 2.2rem;
    margin-top: 0; }
  .std-block p {
    font-size: 1.2rem; }

.usps {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 20px;
  padding: 0 2rem 2rem 2rem; }
  @media (min-width: 800px) {
    .usps {
      grid-template-columns: repeat(3, 1fr); } }
  .usps div {
    background: #f5f5f7;
    padding: 1rem;
    text-align: center; }
    .usps div .iconify {
      width: 50px;
      height: 50px;
      color: #A22284; }
    .usps div h4 {
      margin: 0;
      padding: 0;
      font-size: 1.2rem; }

.parallax-box {
  width: 100%;
  height: 400px;
  background-size: cover;
  background-attachment: fixed !important;
  background-position: center center !important; }
  @supports (hover: none) {
    .parallax-box {
      background-attachment: scroll !important; } }

.home-services {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 4rem 2rem;
  display: flex;
  flex-wrap: wrap; }
  .home-services h3 {
    font-size: 2.5rem;
    position: relative;
    margin-top: 0;
    text-transform: uppercase; }
    .home-services h3:after {
      content: " ";
      position: absolute;
      left: 0;
      bottom: -20px;
      width: 80px;
      height: 8px;
      background: #A22284; }
  .home-services p {
    font-size: 1.2rem; }
  .home-services a {
    background: #A22284;
    padding: 0.5rem 2rem;
    margin-top: 2rem;
    display: inline-block;
    border-radius: 40px;
    color: #FFF;
    text-decoration: none;
    transition: .3s ease;
    font-size: 1.3rem; }
    .home-services a:hover {
      background: #cc2ba6;
      transition: .3s ease; }
  .home-services .services {
    width: 100%; }
    @media (min-width: 800px) {
      .home-services .services {
        width: 66%;
        margin-right: 4%; } }
  .home-services .image {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4rem 0; }
    @media (min-width: 800px) {
      .home-services .image {
        width: 30%; } }
    .home-services .image img {
      width: 100%;
      max-width: 400px;
      object-fit: cover; }
  .home-services .list-items {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    display: grid;
    grid-template-columns: 1fr;
    grid-gap: 2rem;
    padding-top: 2rem; }
    @media (min-width: 576px) {
      .home-services .list-items {
        grid-template-columns: repeat(2, 1fr); } }
    .home-services .list-items h4 {
      font-size: 1.3rem;
      text-transform: uppercase;
      margin: 0;
      padding: 0;
      color: #581A4A; }
    .home-services .list-items p {
      margin-top: 0;
      font-size: 1rem; }

.home-testimonials {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 4rem 2rem; }
  .home-testimonials h3 {
    text-align: center;
    font-size: 2.5rem;
    text-transform: uppercase;
    margin-bottom: 4rem;
    margin-top: 0; }
  .home-testimonials .container {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    display: grid;
    grid-template-columns: 1fr;
    grid-gap: 1rem 4rem;
    text-align: center; }
    @media (min-width: 800px) {
      .home-testimonials .container {
        grid-template-columns: repeat(3, 1fr); } }
    .home-testimonials .container h4 {
      font-size: 1.3rem;
      text-transform: uppercase;
      margin-top: 0; }
    .home-testimonials .container .iconify {
      width: 25px;
      height: 25px;
      color: #A22284; }
    .home-testimonials .container div {
      width: 100%; }
      @media (min-width: 800px) {
        .home-testimonials .container div {
          width: 32%;
          margin: 1rem 0.66666667%; }
          @supports (display: grid) {
            .home-testimonials .container div {
              width: 100%;
              margin: 0; } } }

.page-header {
  width: 100%;
  height: 300px;
  position: relative;
  background-size: cover !important;
  background-position: center center !important; }
  .page-header .overlay {
    position: absolute;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center; }
    .page-header .overlay h1 {
      padding: 0;
      margin: 0;
      font-size: 3rem;
      color: #FFF;
      text-transform: uppercase; }
      @media (min-width: 800px) {
        .page-header .overlay h1 {
          font-size: 5rem; } }

.contact-page {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  padding: 4rem 2rem;
  display: flex;
  flex-wrap: wrap;
  }
  @media (min-width: 800px) {
 
  .contact-page .gform_wrapper input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]) {
    width: 100%; }
  .contact-page #gform_submit_button_1 {
    background: #A22284;
    border: 0;
    padding: 0.5rem 1.5rem;
    border-radius: 20px;
    color: #FFF;
    font-size: 1.2rem;
    cursor: pointer; }
    .contact-page #gform_submit_button_1:hover {
      background: #cc2ba6; }

@media (min-width: 800px) {
  .contact-info, .contact-form {
    width: 50%; }
    @supports (display: grid) {
      .contact-info, .contact-form {
        width: 100%; } } }

.service-point {
  width: 100%;
  max-width: 1200px;
  padding: 0 1rem;
  margin: 0 auto;
  min-height: 300px;
  display: flex;
  flex-wrap: wrap;
  margin-top: 2rem;
  margin-bottom: 2rem; }
  .service-point .image {
    width: 100%;
    background-size: cover !important;
    min-height: 300px; }
    @media (min-width: 800px) {
      .service-point .image {
        width: 50%; } }
  .service-point .content {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 2rem;
    background: #581A4A; }
    .service-point .content h3 {
      color: #FFF;
      text-transform: uppercase;
      padding: 0;
      margin: 0;
      font-size: 1.5rem; }
    .service-point .content p {
      color: #FFF; }
    @media (min-width: 800px) {
      .service-point .content {
        width: 50%; } }

.service-point:nth-child(even) {
  flex-direction: row-reverse; }
  .service-point:nth-child(even) .content {
    background: #A22284; }

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