body {
  font-family: 'Montserrat', sans-serif;
}

.block-newsgrid h3 {
  font-family: 'ZCOOL XiaoWei', serif;
}

.block-banner .item figure img, .block-page-banner figure img, .block-about .image-block figure img, .block-services article figure img, .block-newsletter .image-block figure img, .block-newsletter .media-block .file-block img, .block-casestudy .data-block article figure img, .block-newsgrid figure img, .block-testimonials nav .item figure img, .block-page-packages .image-block figure img, .block-portfolio .data-block article figure img, .block-page-quote figure img, .block-page-page .image-block figure img, .block-page-post .image-block figure img {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  border: 0;
}

button,
input,
textarea {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

button:focus, button:active,
input:focus,
input:active,
textarea:focus,
textarea:active {
  outline: none;
}

.btn-arrow {
  display: inline-block;
  vertical-align: middle;
  border: none;
  background: none;
  -webkit-box-shadow: none;
          box-shadow: none;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  color: #db352a;
  cursor: pointer;
  font-weight: 600;
  -webkit-transition: .4s;
  transition: .4s;
}

.btn-arrow span {
  display: inline-block;
  margin-right: 1rem;
}

.btn-arrow svg {
  height: 10px;
  width: auto;
  display: inline-block;
}

@media (min-width: 575px) {
  .btn-arrow svg {
    height: 12px;
  }
}

@media (min-width: 768px) {
  .btn-arrow svg {
    height: 14px;
  }
}

.btn-arrow svg polyline {
  stroke: #db352a;
  -webkit-transition: .4s;
  transition: .4s;
}

.btn-arrow:hover {
  color: #000000;
}

.btn-arrow:hover svg polyline {
  stroke: #000000;
}

.btn-text {
  text-transform: uppercase;
  color: #db352a;
  font-weight: 400;
  -webkit-transition: .4s;
  transition: .4s;
}

.btn-text:hover {
  color: #000000;
}

.btn-angle {
  display: inline-block;
  vertical-align: middle;
  -webkit-transition: .4s;
  transition: .4s;
}

.btn-angle svg {
  height: 1.2rem;
  width: auto;
  display: block;
}

@media (min-width: 575px) {
  .btn-angle svg {
    height: 1.4rem;
  }
}

@media (min-width: 768px) {
  .btn-angle svg {
    height: 1.6rem;
  }
}

.btn-angle svg polyline {
  stroke: #ff4b01;
  -webkit-transition: .4s;
  transition: .4s;
}

.btn, .form-block div.wpforms-container-full .wpforms-form button[type=submit] {
  color: #ffffff;
  background-color: #ff4b01;
  border-style: solid;
  border-width: 1px !important;
  border-color: transparent;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 5px 1rem;
  font-size: .9rem;
  font-weight: 400;
  text-align: center;
  margin: 0;
  -webkit-transition: .4s;
  transition: .4s;
}

@media (min-width: 575px) {
  .btn, .form-block div.wpforms-container-full .wpforms-form button[type=submit] {
    padding: 6px 1.5rem;
    font-size: 1rem;
    border-width: 2px !important;
  }
}

@media (min-width: 768px) {
  .btn, .form-block div.wpforms-container-full .wpforms-form button[type=submit] {
    padding: 8px 2rem;
    font-size: 1.1rem;
  }
}

.btn svg, .form-block div.wpforms-container-full .wpforms-form button[type=submit] svg {
  position: relative;
  bottom: 2px;
}

.btn:hover, .form-block div.wpforms-container-full .wpforms-form button:hover[type=submit] {
  color: #ff4b01;
  background-color: transparent;
  border-color: #ff4b01;
}

.btn:hover svg polyline, .form-block div.wpforms-container-full .wpforms-form button:hover[type=submit] svg polyline {
  stroke: #ffffff;
}

.btn-small {
  padding: 5px .8rem;
}

@media (min-width: 575px) {
  .btn-small {
    padding: 6px 1rem;
  }
}

@media (min-width: 768px) {
  .btn-small {
    padding: 8px 1.2rem;
  }
}

.btn-radius, .form-block div.wpforms-container-full .wpforms-form button[type=submit] {
  border-radius: 4rem;
}

.btn-border, .form-block div.wpforms-container-full .wpforms-form button[type=submit] {
  border-color: #ff4b01;
  background-color: transparent;
  color: #ff4b01;
}

.btn-border:hover, .form-block div.wpforms-container-full .wpforms-form button:hover[type=submit] {
  background-color: #ff4b01;
  color: #ffffff;
}

.btn-secondary {
  background-color: #000000;
  color: #ffffff;
}

.btn-secondary:hover {
  color: #000000;
  background-color: transparent;
  border-color: #000000;
}

.btn-secondary.btn-border, .form-block div.wpforms-container-full .wpforms-form button.btn-secondary[type=submit] {
  border-color: #000000;
  background-color: transparent;
  color: #000000;
}

.btn-secondary.btn-border:hover, .form-block div.wpforms-container-full .wpforms-form button.btn-secondary:hover[type=submit] {
  background-color: #000000;
  color: #ffffff;
}

.field-block, .form-block div.wpforms-container-full .wpforms-form {
  position: relative;
  margin-bottom: 1rem;
}

.field-block label, .form-block div.wpforms-container-full .wpforms-form label {
  font-weight: 400;
  color: #000000;
}

.field-block input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]), .form-block div.wpforms-container-full .wpforms-form input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]), .field-block textarea, .form-block div.wpforms-container-full .wpforms-form textarea, .field-block select, .form-block div.wpforms-container-full .wpforms-form select {
  width: 100%;
  border: solid 1px #dadce0;
  border-radius: 0;
  padding: .5rem 1rem;
  height: 3rem;
  font-size: .9rem;
  font-weight: 400;
  position: relative;
  z-index: 1;
  background-color: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-transition: .4s;
  transition: .4s;
}

.field-block input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):focus, .form-block div.wpforms-container-full .wpforms-form input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):focus, .field-block textarea:focus, .form-block div.wpforms-container-full .wpforms-form textarea:focus, .field-block select:focus, .form-block div.wpforms-container-full .wpforms-form select:focus {
  border-color: #ff4b01;
}

.field-block input.js-datepicker, .form-block div.wpforms-container-full .wpforms-form input.js-datepicker {
  background-image: url("../images/icon-calendar.svg");
  background-position: 96% center;
  background-size: 1.4rem;
  background-repeat: no-repeat;
}

.field-block input[type="file"], .form-block div.wpforms-container-full .wpforms-form input[type="file"] {
  padding-top: .7rem !important;
  height: auto !important;
}

.field-block select, .form-block div.wpforms-container-full .wpforms-form select {
  background-image: url("../images/icon-sort.svg");
  background-position: right center;
  background-repeat: no-repeat;
  background-size: 1rem;
  padding-right: 2rem;
  padding-top: .5rem;
  padding-bottom: .5rem;
}

.field-block textarea, .form-block div.wpforms-container-full .wpforms-form textarea {
  height: 6rem;
  padding-top: 1rem;
}

@media (min-width: 768px) {
  .field-block textarea, .form-block div.wpforms-container-full .wpforms-form textarea {
    height: 8rem;
  }
}

.wpcf7-not-valid-tip {
  font-size: .9rem;
  margin-top: 5px;
}

.modal-backdrop {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 123;
  width: 100%;
  height: 100%;
  background-color: #000000;
  opacity: 0.3;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-modal {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  z-index: 125;
  opacity: 0;
  overflow-x: hidden;
  overflow-y: scroll;
  visibility: hidden;
  -webkit-transition: all .4s;
  transition: all .4s;
  text-align: center;
}

.block-modal.active {
  display: block;
  opacity: 1;
  visibility: visible;
}

.block-modal.active .content {
  -webkit-transform: translateY(0px) scale(1);
          transform: translateY(0px) scale(1);
}

.block-modal .content {
  display: inline-block;
  vertical-align: middle;
  position: relative;
  width: 700px;
  max-width: 90%;
  margin: 5% auto;
  background-color: #ffffff;
  -webkit-box-shadow: 0 0 35px rgba(0, 0, 0, 0.2);
          box-shadow: 0 0 35px rgba(0, 0, 0, 0.2);
  -webkit-transform: translateY(-400px) scale(0.8);
          transform: translateY(-400px) scale(0.8);
  -webkit-transition-delay: .3s;
          transition-delay: .3s;
  -webkit-transition: all .4s;
  transition: all .4s;
  text-align: left;
}

.block-modal .content .cross {
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 5;
  width: 30px;
  height: 30px;
  cursor: pointer;
  -webkit-transition: all 1s;
  transition: all 1s;
}

.block-modal .content .cross::before, .block-modal .content .cross::after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  display: block;
  content: '';
  background-color: #000000;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: all .4s;
  transition: all .4s;
}

.block-modal .content .cross::before {
  width: 90%;
  height: 2px;
}

.block-modal .content .cross::after {
  width: 2px;
  height: 90%;
}

.block-modal .content .cross:hover::before, .block-modal .content .cross:hover::after {
  opacity: 0.8;
}

.block-modal .content .cross:hover::before {
  width: 80%;
}

.block-modal .content .cross:hover::after {
  height: 80%;
}

.block-modal .data {
  padding: 3rem 2rem;
}

.block-modal h4 {
  text-transform: uppercase;
}

.block-hos {
  width: 100%;
  height: 4rem;
}

@media (min-width: 575px) {
  .block-hos {
    height: 6rem;
  }
}

body div.wpcf7-response-output {
  text-align: center;
}

nav {
  outline: none;
}

.block-mobile-nav {
  background-color: #db352a;
  color: #ffffff;
  font-weight: 400;
  width: 260px;
  height: 100%;
  position: fixed;
  top: 0;
  right: -260px;
  z-index: 321;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

.block-mobile-nav.active {
  right: 0;
}

.block-mobile-nav .contain {
  width: 100%;
  height: 100%;
  padding: 1rem 1rem 1rem 2rem;
  overflow-x: hidden;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
}

.block-mobile-nav nav ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.block-mobile-nav nav ul li {
  position: relative;
  margin: 0;
  padding: 0.5rem 0;
}

.block-mobile-nav nav ul li a {
  display: block;
  color: #ffffff;
  font-size: .9rem;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.block-mobile-nav address {
  margin: auto 0 0 0;
  padding: 2rem 0 3rem;
  text-align: center;
  font-style: normal;
}

.block-mobile-nav address p {
  border-top: solid 1px rgba(0, 0, 0, 0.2);
  font-weight: 300;
  padding: 1.5rem 0 0;
}

.block-mobile-nav address .phone-block {
  color: #ffffff;
  font-size: 1.5rem;
  line-height: 1;
}

.block-mobile-nav address .phone-block a {
  color: #ffffff;
}

.block-mobile-nav address .social-block {
  display: block;
  text-align: center;
  border-top: solid 1px rgba(0, 0, 0, 0.2);
  padding: 1.5rem 0 0 0;
  margin: 1.5rem 2rem 0;
}

@media (min-width: 1200px) {
  .block-mobile-nav address .social-block {
    display: none;
  }
}

.block-mobile-nav address .social-block a {
  color: #ffffff;
  height: 20px;
  margin: 0 .5rem;
  font-size: 1.2rem;
}

.block-mobile-nav address .social-block a svg {
  width: 1rem;
  height: 1rem;
  display: inline-block;
}

.block-mobile-nav address .social-block a svg polygon {
  fill: #ffffff;
}

.block-wrapper {
  width: 100%;
  overflow: hidden;
}

.block-wrapper.active .block-ui {
  right: 260px;
}

@media (min-width: 1200px) {
  .block-wrapper.active .block-ui {
    right: 0;
  }
}

.block-wrapper .block-ui {
  position: relative;
  right: 0;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-down {
  width: 1.6rem;
  position: absolute;
  bottom: 3rem;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 24;
}

.block-down button {
  position: relative;
  background-color: transparent;
  border: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  height: 0;
  margin: 0;
  padding: 0 0 180%;
  display: block;
}

.block-down .chevron {
  position: relative;
  left: -.7rem;
}

.block-down .chev {
  position: absolute;
  width: 18px;
  height: 3px;
  opacity: 0;
  -webkit-transform: scale3d(0.5, 0.5, 0.5);
          transform: scale3d(0.5, 0.5, 0.5);
  -webkit-animation: move 3s ease-out infinite;
          animation: move 3s ease-out infinite;
}

.block-down .chev:first-child {
  -webkit-animation: move 3s ease-out 1s infinite;
          animation: move 3s ease-out 1s infinite;
}

.block-down .chev:nth-child(2) {
  -webkit-animation: move 3s ease-out 2s infinite;
          animation: move 3s ease-out 2s infinite;
}

.block-down .chev::before, .block-down .chev::after {
  content: '';
  position: absolute;
  top: 0;
  height: 100%;
  width: 51%;
  background: #ffffff;
}

.block-down .chev::before {
  left: 0;
  -webkit-transform: skew(0deg, 30deg);
          transform: skew(0deg, 30deg);
}

.block-down .chev::after {
  right: 0;
  width: 50%;
  -webkit-transform: skew(0deg, -30deg);
          transform: skew(0deg, -30deg);
}

@-webkit-keyframes move {
  25% {
    opacity: 1;
  }
  33% {
    opacity: 1;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  67% {
    opacity: 1;
    -webkit-transform: translateY(25px);
            transform: translateY(25px);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateY(40px) scale3d(0.5, 0.5, 0.5);
            transform: translateY(40px) scale3d(0.5, 0.5, 0.5);
  }
}

@keyframes move {
  25% {
    opacity: 1;
  }
  33% {
    opacity: 1;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  67% {
    opacity: 1;
    -webkit-transform: translateY(25px);
            transform: translateY(25px);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateY(40px) scale3d(0.5, 0.5, 0.5);
            transform: translateY(40px) scale3d(0.5, 0.5, 0.5);
  }
}

.jarallax {
  position: relative;
  z-index: 0;
}

.jarallax > .jarallax-img {
  position: absolute;
  -o-object-fit: cover;
     object-fit: cover;
  /* support for plugin https://github.com/bfred-it/object-fit-images */
  font-family: 'object-fit: cover;';
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.mejs__overlay-button {
  position: relative;
  background-color: rgba(219, 53, 42, 0.4) !important;
  border-radius: 50%;
  background-image: none;
  outline: none;
}

.mejs__overlay-button::before {
  width: 60%;
  height: 60%;
  border-radius: 50%;
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  background-color: rgba(219, 53, 42, 0.8);
  -webkit-transition: .4s;
  transition: .4s;
}

.mejs__overlay-button::after {
  width: 0;
  height: 0;
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-20%, -50%);
          transform: translate(-20%, -50%);
  border-width: 10px;
  border-style: solid;
  border-color: transparent transparent transparent #ffffff;
}

.mejs__overlay-button:hover::before {
  -webkit-animation: rounscale 2s ease-in-out infinite;
          animation: rounscale 2s ease-in-out infinite;
}

@-webkit-keyframes rounscale {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  50% {
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes rounscale {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  50% {
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

.form-block div.wpforms-container-full .wpforms-form .wpforms-field-label {
  font-size: .9rem;
  font-weight: 500;
}

.form-block div.wpforms-container-full .wpforms-form .wpforms-recaptcha-container {
  padding: 0;
}

.form-block .grecaptcha-badge {
  z-index: 97;
}

body {
  margin: 0;
  color: #666666;
  font-size: 0.9rem;
  font-weight: 300;
  line-height: 1.5;
}

body.modal-open {
  width: 100vw;
  height: 100vh;
  overflow: hidden;
}

body.admin-bar .block-header,
body.admin-bar .block-mobile-nav {
  top: 32px;
}

a {
  text-decoration: none;
  outline-width: 0;
}

a:hover {
  text-decoration: none;
  outline-width: 0;
}

a:active {
  text-decoration: none;
  outline-width: 0;
}

a:visited {
  text-decoration: none;
  outline-width: 0;
}

a:focus {
  text-decoration: none;
  outline-width: 0;
}

button,
input,
select,
textarea {
  outline: none;
  outline-width: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
}

button:hover,
input:hover,
select:hover,
textarea:hover {
  outline: none;
  outline-width: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
}

button:active,
input:active,
select:active,
textarea:active {
  outline: none;
  outline-width: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
}

button:visited,
input:visited,
select:visited,
textarea:visited {
  outline: none;
  outline-width: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
}

button:focus,
input:focus,
select:focus,
textarea:focus {
  outline: none;
  outline-width: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 600;
  color: #000000;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
  color: inherit;
}

h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover {
  color: inherit;
}

.h1,
h1 {
  font-size: 1.3rem;
  text-transform: uppercase;
  line-height: 1;
  margin-bottom: 0.5rem;
}

@media (min-width: 575px) {
  .h1,
  h1 {
    font-size: 1.4rem;
  }
}

@media (min-width: 768px) {
  .h1,
  h1 {
    font-size: 1.5rem;
    margin-bottom: 1rem;
  }
}

@media (min-width: 992px) {
  .h1,
  h1 {
    font-size: 1.6rem;
  }
}

@media (min-width: 1200px) {
  .h1,
  h1 {
    font-size: 1.8rem;
  }
}

.h2,
h2 {
  font-size: 1.2rem;
  text-transform: uppercase;
  line-height: 1;
  margin-bottom: 0.5rem;
}

@media (min-width: 575px) {
  .h2,
  h2 {
    font-size: 1.3rem;
  }
}

@media (min-width: 768px) {
  .h2,
  h2 {
    font-size: 1.5rem;
    margin-bottom: 1rem;
  }
}

@media (min-width: 992px) {
  .h2,
  h2 {
    font-size: 1.6rem;
  }
}

.h3,
h3 {
  font-size: 1.1rem;
  line-height: 1;
}

@media (min-width: 575px) {
  .h3,
  h3 {
    font-size: 1.2rem;
  }
}

@media (min-width: 768px) {
  .h3,
  h3 {
    font-size: 1.3rem;
  }
}

@media (min-width: 992px) {
  .h3,
  h3 {
    font-size: 1.5rem;
  }
}

.h4,
h4 {
  font-size: 1.1rem;
}

@media (min-width: 575px) {
  .h4,
  h4 {
    font-size: 1.2rem;
  }
}

@media (min-width: 768px) {
  .h4,
  h4 {
    font-size: 1.3rem;
  }
}

.h5,
h5 {
  font-size: 1rem;
}

@media (min-width: 575px) {
  .h5,
  h5 {
    font-size: 1.1rem;
  }
}

@media (min-width: 768px) {
  .h5,
  h5 {
    font-size: 1.2rem;
  }
}

.h6,
h6 {
  font-size: 0.9rem;
}

@media (min-width: 575px) {
  .h6,
  h6 {
    font-size: 1rem;
  }
}

@media (min-width: 768px) {
  .h6,
  h6 {
    font-size: 1.1rem;
  }
}

a {
  color: #ff4b01;
}

a:hover {
  color: inherit;
}

p {
  margin-bottom: 1rem;
}

small {
  font-size: 90%;
  font-weight: inherit;
}

b {
  font-weight: 500;
}

strong {
  font-weight: 600;
}

label {
  font-weight: 400;
}

button {
  color: inherit;
  font-weight: inherit;
}

nav {
  display: block;
}

img {
  max-width: 100%;
}

.block-header {
  width: 100%;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 99;
  font-weight: 500;
  color: #ffffff;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-header::before {
  width: 100%;
  height: 100%;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  -webkit-transition: .4s;
  transition: .4s;
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
  background-color: #ffffff;
}

.block-header.expanded {
  right: 260px;
}

@media (min-width: 1200px) {
  .block-header.expanded {
    right: 0;
  }
}

.block-header.fixed {
  color: #000000;
}

.block-header.fixed::before {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.block-header.fixed .container {
  height: 4rem;
}

@media (min-width: 1200px) {
  .block-header.fixed .container {
    height: 5rem;
  }
}

.block-header.fixed .center-block img {
  height: 3rem;
}

@media (min-width: 1200px) {
  .block-header.fixed .center-block img {
    height: 4rem;
  }
}

.block-header.fixed ul li a {
  color: #000000;
}

.block-header.fixed ul li a:hover {
  color: #db352a;
}

.block-header.fixed .mobile-block .menu-block span {
  background-color: #000000;
}

.block-header.fixed .mobile-block .menu-block span:nth-child(2)::before, .block-header.fixed .mobile-block .menu-block span:nth-child(2)::after {
  background-color: #000000;
}

.block-header.header-page {
  color: #000000;
}

.block-header.header-page ul li a {
  color: #000000;
}

.block-header.header-page ul li a:hover {
  color: #db352a;
}

.block-header .btn, .block-header .form-block div.wpforms-container-full .wpforms-form button[type=submit], .form-block div.wpforms-container-full .wpforms-form .block-header button[type=submit] {
  font-size: .9rem;
  font-weight: 500;
}

.block-header .left-block {
  width: 50%;
  padding-right: 5rem;
}

.block-header .right-block {
  width: 50%;
  padding-left: 5rem;
}

.block-header ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.block-header ul li {
  margin: 0 1rem;
  padding: 0;
}

.block-header ul li a {
  color: #ffffff;
  font-weight: 500;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-header ul li a:hover {
  color: #db352a;
}

.block-header ul li.current_page_item a {
  color: #db352a;
}

.block-header .container {
  position: relative;
  height: 6rem;
  -webkit-transition: .4s;
  transition: .4s;
}

@media (min-width: 1200px) {
  .block-header .container {
    height: 8rem;
  }
}

.block-header .center-block {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 5;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.block-header .center-block a {
  display: block;
}

.block-header .center-block img {
  width: auto;
  height: 5rem;
  display: block;
  -webkit-transition: .4s;
  transition: .4s;
}

@media (min-width: 1200px) {
  .block-header .center-block img {
    height: 6rem;
  }
}

.block-header .mobile-block .menu-block {
  position: relative;
  width: 3rem;
  padding: 0;
  cursor: pointer;
  text-align: right;
  background: none;
  border: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.block-header .mobile-block .menu-block.active span {
  -webkit-transform: translateY(-90px);
          transform: translateY(-90px);
  opacity: 0;
}

.block-header .mobile-block .menu-block.active span:nth-child(2) {
  width: 100%;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1;
}

.block-header .mobile-block .menu-block.active span:nth-child(2)::before {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.block-header .mobile-block .menu-block.active span:nth-child(2)::after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.block-header .mobile-block .menu-block.active span:nth-child(3) {
  -webkit-transform: translateY(90px);
          transform: translateY(90px);
}

.block-header .mobile-block .menu-block div {
  width: 1.4rem;
  margin: .5rem auto;
}

.block-header .mobile-block .menu-block div::after {
  display: block;
  clear: both;
  content: '';
}

.block-header .mobile-block .menu-block span {
  display: block;
  float: right;
  position: relative;
  width: 100%;
  height: 2px;
  margin: 2px 0;
  border-radius: 3px;
  background-color: #ffffff;
}

.block-header .mobile-block .menu-block span:nth-child(2) {
  background-color: transparent;
}

.block-header .mobile-block .menu-block span:nth-child(2)::before, .block-header .mobile-block .menu-block span:nth-child(2)::after {
  width: 100%;
  height: 100%;
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  background-color: #ffffff;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-banner {
  position: relative;
  color: #ffffff;
}

.block-banner .item {
  width: 100%;
  height: 100vh;
  position: relative;
}

.block-banner .item figure {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  margin: 0;
}

.block-banner .data-block {
  width: 100%;
  height: 100%;
}

.block-banner .container {
  position: relative;
  z-index: 1;
}

.block-banner article {
  width: 900px;
  max-width: 100%;
}

.block-banner article h1, .block-banner article h2, .block-banner article h3 {
  margin: 0 0 .5rem;
  text-transform: none;
  color: #ffffff;
  font-size: 1.6rem;
  font-weight: 600;
}

@media (min-width: 768px) {
  .block-banner article h1, .block-banner article h2, .block-banner article h3 {
    font-size: 1.8rem;
  }
}

@media (min-width: 1200px) {
  .block-banner article h1, .block-banner article h2, .block-banner article h3 {
    font-size: 2rem;
  }
}

.block-banner .action {
  margin-top: 1rem;
}

.block-banner .btn, .block-banner .form-block div.wpforms-container-full .wpforms-form button[type=submit], .form-block div.wpforms-container-full .wpforms-form .block-banner button[type=submit] {
  padding: 6px 1.2rem 5px;
  text-transform: uppercase;
  font-weight: 400;
  font-size: .7rem;
}

@media (min-width: 575px) {
  .block-banner .btn, .block-banner .form-block div.wpforms-container-full .wpforms-form button[type=submit], .form-block div.wpforms-container-full .wpforms-form .block-banner button[type=submit] {
    padding: 6px 1.2rem 5px;
    font-size: .8rem;
  }
}

@media (min-width: 768px) {
  .block-banner .btn, .block-banner .form-block div.wpforms-container-full .wpforms-form button[type=submit], .form-block div.wpforms-container-full .wpforms-form .block-banner button[type=submit] {
    padding: 8px 1.5rem 7px;
    font-size: .9rem;
  }
}

.block-banner .btn-arrow {
  margin: 1rem 0 0 0;
  width: 2.8rem;
  height: 2.8rem;
  line-height: 2.6rem;
  border-radius: 50%;
  background-color: #ffffff;
  display: block;
  text-align: center;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-banner .btn-arrow svg polyline {
  stroke: #ff4b01;
}

.block-banner .btn-arrow:hover {
  background-color: #ff4b01;
}

.block-banner .btn-arrow:hover svg polyline {
  stroke: #ffffff;
}

.block-banner footer {
  position: absolute;
  left: 0;
  bottom: 3rem;
  z-index: 5;
  width: 100%;
}

.block-banner .social-block {
  width: 3rem;
  position: absolute;
  bottom: 3rem;
  right: 1.5rem;
  text-align: center;
  font-size: 1.1rem;
}

.block-banner .social-block a {
  width: 100%;
  margin: 5px 0;
  display: block;
  color: #ffffff;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-banner .social-block a svg {
  width: 1rem;
  height: 1rem;
  display: inline-block;
}

.block-banner .social-block a svg polygon {
  fill: #ffffff;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-banner .social-block a:hover {
  color: #db352a;
}

.block-banner .social-block a:hover svg polygon {
  fill: #db352a;
}

.block-banner .number-block {
  font-size: 1.4rem;
}

@media (min-width: 575px) {
  .block-banner .number-block {
    font-size: 1.6rem;
  }
}

@media (min-width: 768px) {
  .block-banner .number-block {
    font-size: 1.8rem;
  }
}

.block-banner .number-block small {
  font-size: .9rem;
}

.block-banner .number-block small span {
  margin-left: 5px;
}

.block-page-banner {
  position: relative;
  color: #ffffff;
}

.block-page-banner .container {
  position: relative;
  z-index: 1;
  padding-top: 35vh;
  padding-bottom: 20vh;
}

.block-page-banner figure {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  margin: 0;
}

.block-page-banner article {
  width: 500px;
  max-width: 100%;
  margin: auto;
  text-align: center;
  font-weight: 400;
}

.block-page-banner article h1 {
  color: #ffffff;
  text-transform: none;
  font-size: 2rem;
  font-weight: 600;
}

.block-page-banner article p {
  margin: 0;
}

.block-page-banner .btn-arrow {
  margin: 1rem 0 0 0;
  width: 2.8rem;
  height: 2.8rem;
  line-height: 2.6rem;
  border-radius: 50%;
  background-color: #ffffff;
  display: inline-block;
  text-align: center;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-page-banner .btn-arrow svg polyline {
  stroke: #ff4b01;
}

.block-page-banner .btn-arrow:hover {
  background-color: #ff4b01;
}

.block-page-banner .btn-arrow:hover svg polyline {
  stroke: #ffffff;
}

.block-page-banner .social-block {
  width: 3rem;
  position: absolute;
  bottom: 2rem;
  right: 0;
  text-align: center;
  font-size: 1.1rem;
}

.block-page-banner .social-block a {
  width: 100%;
  margin: 5px 0;
  display: block;
  color: #ffffff;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-page-banner .social-block a svg {
  width: 1rem;
  height: 1rem;
  display: inline-block;
}

.block-page-banner .social-block a svg polygon {
  fill: #ffffff;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-page-banner .social-block a:hover {
  color: #db352a;
}

.block-page-banner .social-block a:hover svg polygon {
  fill: #db352a;
}

.block-section .title-block {
  text-transform: uppercase;
  color: #666666;
  font-size: .9rem;
}

.block-section .caption-block {
  display: inline-block;
  width: 400px;
  max-width: 100%;
  color: #000000;
  font-size: 1.8rem;
  font-weight: 700;
  text-transform: none;
  margin-bottom: 1rem;
}

@media (min-width: 768px) {
  .block-section .caption-block {
    margin-bottom: 2rem;
    font-size: 2.2rem;
  }
}

@media (min-width: 1200px) {
  .block-section .caption-block {
    font-size: 2.6rem;
  }
}

@media (min-width: 768px) {
  .block-about .data-block {
    margin-right: 3rem;
  }
}

.block-about .feature-block {
  text-align: center;
  margin-top: 1.5rem;
}

.block-about .feature-block span {
  display: inline-block;
  height: 4rem;
  margin-bottom: 1rem;
}

.block-about .feature-block span img {
  width: auto;
  height: 100%;
  display: block;
}

.block-about .feature-block h5 {
  font-size: .9rem;
  font-weight: 600;
  text-transform: uppercase;
  text-align: left;
}

.block-about .feature-block p {
  text-align: left;
}

.block-about .image-block {
  width: 100%;
  height: 50vw;
  position: relative;
  margin-top: 3rem;
}

@media (min-width: 1200px) {
  .block-about .image-block {
    height: 80%;
    position: absolute;
    bottom: 0;
    left: 0;
    margin-top: 0;
  }
}

.block-about .image-block .dot-block {
  width: 12rem;
  height: 11rem;
  background-image: url("../images/texture-dot.png") !important;
  background-position: top left;
  background-repeat: repeat;
  background-size: 10px;
  position: absolute;
  top: -2rem;
  left: -4rem;
  z-index: 0;
}

@media (min-width: 1200px) {
  .block-about .image-block .dot-block {
    top: -3rem;
  }
}

.block-about .image-block figure {
  display: block;
  margin: 0;
  margin-right: -20vw;
  height: 100%;
  position: relative;
  z-index: 1;
}

.block-services {
  background-color: #f9f9f8;
}

.block-services header {
  position: relative;
  z-index: 2;
}

.block-services .btn-arrow {
  position: relative;
  z-index: 2;
}

.block-services .caption-block {
  width: 600px;
  font-size: 2rem;
  font-weight: 600;
  margin-bottom: 3rem;
}

.block-services article {
  margin-top: 2rem;
  position: relative;
  z-index: 0;
  padding-bottom: 4rem;
}

@media (min-width: 768px) {
  .block-services article {
    margin-left: 30%;
    margin-top: -2rem;
    margin-right: -10vw;
  }
}

@media (min-width: 1200px) {
  .block-services article {
    margin-right: -20vw;
    margin-top: -6rem;
  }
}

.block-services article .circle-block {
  position: absolute;
  top: 3rem;
  left: 2.5rem;
  z-index: -1;
  width: 34rem;
  height: 34rem;
  -webkit-transform: translate(-50%, -50%) !important;
          transform: translate(-50%, -50%) !important;
}

.block-services article .circle-block span {
  width: 60%;
  height: 60%;
  position: absolute !important;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  border-radius: 50%;
  border: solid 1px #f1e5e5;
}

.block-services article .circle-block .circle-2 {
  width: 100%;
  height: 100%;
}

.block-services article figure {
  margin: 0;
  width: 100%;
  height: 0;
  padding-bottom: 60%;
  overflow: hidden;
  position: relative;
  z-index: 0;
}

.block-services article .tns-inner {
  margin: 0 !important;
}

.block-services article .tns-outer {
  position: relative;
  z-index: 2;
}

.block-services article footer {
  width: 80%;
  height: 4rem;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 0;
  background-color: #ffffff;
  -webkit-box-shadow: 0px 15px 23px rgba(0, 0, 0, 0.1);
          box-shadow: 0px 15px 23px rgba(0, 0, 0, 0.1);
  padding: 5px 7px;
}

@media (min-width: 768px) {
  .block-services article footer {
    width: 60%;
  }
}

@media (min-width: 1200px) {
  .block-services article footer {
    width: 45%;
  }
}

.block-services article footer::before {
  width: 100%;
  height: 5rem;
  content: '';
  background-color: #ffffff;
  position: absolute;
  bottom: 100%;
  left: 0;
  z-index: 0;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#f9f9f8), to(#ffffff));
  background-image: linear-gradient(to bottom, #f9f9f8, #ffffff);
}

.block-services article footer nav {
  position: absolute;
  top: 50%;
  right: 1rem;
  z-index: 1;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  font-size: 1.4rem;
}

.block-services article footer nav::after {
  display: block;
  clear: both;
  content: '';
}

.block-services article footer nav button {
  background: none;
  color: #000000;
  border: none;
  padding: 0;
  width: 1.2rem;
  height: 2rem;
  line-height: 1rem;
  display: block;
  float: left;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-services article footer nav button[disabled] {
  color: #666666;
}

.block-services article footer .item {
  display: none;
  color: #000000;
}

.block-services article footer .active {
  display: block;
}

.block-services article footer h3 {
  font-size: .9rem;
  font-weight: 600;
}

.block-services article footer p {
  margin: 0;
}

.block-newsletter {
  position: relative;
  padding-top: 3rem;
}

@media (min-width: 768px) {
  .block-newsletter {
    padding-top: 5rem;
  }
}

@media (min-width: 1200px) {
  .block-newsletter {
    padding-top: 9rem;
  }
}

.block-newsletter .image-block {
  width: 20rem;
  height: 130%;
  position: absolute;
  bottom: 0;
  right: 100%;
  z-index: 0;
  margin-right: 4rem;
}

.block-newsletter .image-block .dot-block {
  width: 12rem;
  height: 12rem;
  position: absolute;
  right: -2rem;
  top: -2rem;
  z-index: -1;
  background-image: url("../images/texture-dot.png") !important;
  background-position: top left;
  background-repeat: repeat;
  background-size: 10px;
}

.block-newsletter .image-block figure {
  margin: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.block-newsletter .caption-block {
  width: 300px;
}

.block-newsletter .data-block {
  position: relative;
}

@media (min-width: 1200px) {
  .block-newsletter .data-block {
    margin-left: 8rem;
    padding-left: 25rem;
  }
}

.block-newsletter .data-block article {
  position: relative;
  z-index: 2;
}

@media (min-width: 1200px) {
  .block-newsletter .data-block article {
    width: 25rem;
    position: absolute;
    top: 0;
    left: 0;
  }
}

.block-newsletter .data-block article p {
  color: #666666;
  font-size: .8rem;
  margin-bottom: 2rem;
}

@media (min-width: 1200px) {
  .block-newsletter .data-block article p {
    margin-bottom: 1rem;
  }
}

.block-newsletter .data-block article p span {
  color: #db352a;
}

.block-newsletter .newsletter-block {
  position: relative;
  margin-bottom: 2rem;
  width: 280px;
  max-width: 100%;
}

@media (min-width: 1200px) {
  .block-newsletter .newsletter-block {
    width: 100%;
  }
}

.block-newsletter .newsletter-block img {
  position: absolute;
  top: 50%;
  left: 1rem;
  z-index: 5;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 1.2rem;
  height: 1.2rem;
  display: block;
}

.block-newsletter .newsletter-block div.wpforms-container-full .wpforms-form input[type="email"] {
  width: 100%;
  height: 3rem;
  background-color: #ffffff;
  border: solid 1px #eee;
  -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
          box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  padding-left: 3rem;
  padding-right: 1rem;
}

.block-newsletter .newsletter-block div.wpforms-container-full .wpforms-form input[type="email"]:focus {
  border-color: #dadce0;
}

.block-newsletter .newsletter-block div.wpforms-container-full .wpforms-form button[type=submit] {
  width: 5rem;
  height: 3rem;
  line-height: 3rem;
  padding: 0;
  font-weight: 500;
  background-color: #db352a;
  color: #ffffff;
  border: none;
  border-radius: 0;
  position: absolute;
  top: 0;
  left: 100%;
}

.block-newsletter .newsletter-block div.wpforms-container-full .wpforms-form .wpforms-field {
  padding: 0;
}

.block-newsletter .newsletter-block div.wpforms-container-full .wpforms-form .wpforms-submit-container {
  position: static;
  padding: 0;
}

.block-newsletter .newsletter-block div.wpforms-container-full .wpforms-form label.wpforms-error {
  position: absolute;
  top: 100%;
  margin-top: .5rem;
}

.block-newsletter .newsletter-block div.wpforms-container-full .wpforms-form .wpforms-recaptcha-container {
  padding: 0;
}

.block-newsletter .newsletter-block .wpforms-confirmation-container-full {
  padding-left: 3rem;
  margin-bottom: 1rem;
}

@media (min-width: 1200px) {
  .block-newsletter .newsletter-block .wpforms-confirmation-container-full {
    margin-right: 1rem;
  }
}

.block-newsletter .newsletter-block .wpforms-confirmation-container-full p {
  margin: 0;
}

.block-newsletter #mce-error-response {
  color: #f44336;
}

.block-newsletter #mce-success-response {
  color: #4caf50;
}

.block-newsletter .media-block {
  position: relative;
  padding-bottom: 4rem;
}

@media (min-width: 1200px) {
  .block-newsletter .media-block {
    margin-right: -5vw;
  }
}

.block-newsletter .media-block .items {
  position: relative;
  z-index: 1;
}

.block-newsletter .media-block .file-block {
  width: 100%;
  height: 0;
  padding-bottom: 50%;
  overflow: hidden;
  position: relative;
  z-index: 0;
}

.block-newsletter .media-block .linenumber-block {
  position: relative;
  font-weight: 600;
}

.block-newsletter .media-block .linenumber-block div {
  width: 2rem;
  height: 2rem;
  line-height: 2rem;
  text-align: center;
  display: inline-block;
  vertical-align: middle;
}

.block-newsletter .media-block .linenumber-block div:last-child {
  color: #000000;
}

.block-newsletter .media-block .linenumber-block span {
  display: inline-block;
  vertical-align: middle;
  width: 2rem;
  height: 1px;
  background-color: #000000;
}

@media (min-width: 575px) {
  .block-newsletter .media-block .linenumber-block span {
    width: 3rem;
  }
}

@media (min-width: 768px) {
  .block-newsletter .media-block .linenumber-block span {
    width: 6rem;
  }
}

.block-newsletter .media-block nav {
  margin-left: 2rem;
}

.block-newsletter .media-block button[disabled] svg polyline {
  stroke: #666666;
}

.block-newsletter .media-block .btn-arrow {
  width: 2.4rem;
  text-align: center;
}

.block-newsletter .media-block .btn-arrow svg {
  height: 10px;
}

.block-newsletter .media-block .btn-arrow svg polyline {
  stroke-width: 4px;
}

.block-newsletter .media-block .arrow-left svg polyline {
  stroke: #666666;
}

.block-newsletter .media-block .arrow-left:hover svg polyline {
  stroke: #000000;
}

.block-newsletter .media-block .arrow-right svg polyline {
  stroke: #db352a;
}

.block-newsletter .media-block .arrow-right:hover svg polyline {
  stroke: #000000;
}

.block-newsletter .media-block footer {
  width: 100%;
  height: 4rem;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 0;
}

.block-newsletter .media-block footer .dot-block {
  width: 10rem;
  height: 10rem;
  position: absolute;
  right: -2rem;
  bottom: 0;
  z-index: -1;
  background-image: url("../images/texture-dot.png") !important;
  background-position: top left;
  background-repeat: repeat;
  background-size: 10px;
}

.block-casestudy header {
  position: relative;
  margin-bottom: 3rem;
}

.block-casestudy header .caption-block {
  margin-bottom: 0;
}

.block-casestudy header .btn-border, .block-casestudy header .form-block div.wpforms-container-full .wpforms-form button[type=submit], .form-block div.wpforms-container-full .wpforms-form .block-casestudy header button[type=submit] {
  position: absolute;
  right: 0;
  bottom: 0;
  border-color: #666666;
  background-color: transparent;
  color: #666666;
  border-radius: .5rem;
  padding: 4px 1rem;
}

@media (min-width: 575px) {
  .block-casestudy header .btn-border, .block-casestudy header .form-block div.wpforms-container-full .wpforms-form button[type=submit], .form-block div.wpforms-container-full .wpforms-form .block-casestudy header button[type=submit] {
    padding: 4px 1.5rem;
  }
}

@media (min-width: 768px) {
  .block-casestudy header .btn-border, .block-casestudy header .form-block div.wpforms-container-full .wpforms-form button[type=submit], .form-block div.wpforms-container-full .wpforms-form .block-casestudy header button[type=submit] {
    padding: 5px 2rem;
  }
}

.block-casestudy header .btn-border:hover, .block-casestudy header .form-block div.wpforms-container-full .wpforms-form button:hover[type=submit], .form-block div.wpforms-container-full .wpforms-form .block-casestudy header button:hover[type=submit] {
  background-color: #666666;
  color: #ffffff;
}

.block-casestudy .data-block {
  position: relative;
  padding-bottom: 5rem;
  padding-right: 3rem;
  margin-right: 2rem;
}

@media (min-width: 768px) {
  .block-casestudy .data-block {
    margin-top: 4rem;
    padding-bottom: 8rem;
  }
}

.block-casestudy .data-block::after {
  width: 999999999px;
  height: 85%;
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  margin-left: -1px;
  background-color: #f9f9f8;
}

.block-casestudy .data-block article {
  position: relative;
  z-index: 1;
}

@media (min-width: 768px) {
  .block-casestudy .data-block article {
    margin-left: -10vw;
  }
}

@media (min-width: 1200px) {
  .block-casestudy .data-block article {
    margin-left: -20vw;
  }
}

.block-casestudy .data-block article figure {
  width: 100%;
  height: 0;
  margin: 0;
  padding-bottom: 60%;
  overflow: hidden;
  position: relative;
  z-index: 0;
}

.block-casestudy .data-block nav {
  width: 3rem;
  position: absolute;
  right: 0;
  top: 50%;
  z-index: 1;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.block-casestudy .data-block nav button {
  width: 100%;
  padding: 1rem 0;
}

.block-casestudy .data-block nav button[disabled] svg polyline {
  stroke: #666666;
}

.block-casestudy .data-block nav .btn-arrow svg {
  height: 1.4rem;
}

.block-casestudy .data-block nav .arrow-up svg polyline {
  stroke: #666666;
}

.block-casestudy .data-block nav .arrow-up:hover svg polyline {
  stroke: #000000;
}

.block-casestudy .data-block nav .arrow-down svg polyline {
  stroke: #db352a;
}

.block-casestudy .data-block nav .arrow-down:hover svg polyline {
  stroke: #000000;
}

.block-casestudy .data-block footer {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 5rem;
}

@media (min-width: 768px) {
  .block-casestudy .data-block footer {
    height: 8rem;
  }
}

.block-casestudy .data-block footer .linenumber-block {
  position: relative;
  font-weight: 600;
  margin-left: 1rem;
}

.block-casestudy .data-block footer .linenumber-block div {
  width: 2rem;
  height: 2rem;
  line-height: 2rem;
  text-align: center;
  display: inline-block;
  vertical-align: middle;
}

.block-casestudy .data-block footer .linenumber-block div:last-child {
  color: #000000;
}

.block-casestudy .data-block footer .linenumber-block span {
  display: inline-block;
  vertical-align: middle;
  width: 2rem;
  height: 1px;
  background-color: #000000;
}

@media (min-width: 575px) {
  .block-casestudy .data-block footer .linenumber-block span {
    width: 3rem;
  }
}

@media (min-width: 768px) {
  .block-casestudy .data-block footer .linenumber-block span {
    width: 6rem;
  }
}

.block-casestudy .data-block footer .btn-arrow {
  margin-right: 3rem;
}

.block-latestnews header {
  margin-bottom: 4rem;
}

.block-latestnews .caption-block {
  margin-bottom: 0;
}

.block-latestnews .data-block {
  position: relative;
}

.block-latestnews .data-block .dot-block {
  width: 6rem;
  height: 6rem;
  background-image: url("../images/texture-dot.png") !important;
  background-position: top left;
  background-repeat: repeat;
  background-size: 7px;
  position: absolute;
  top: -2rem;
  left: -2.5rem;
  z-index: 0;
}

.block-latestnews .data-block .items {
  position: relative;
  z-index: 1;
}

.block-newsgrid {
  margin: 0 0 2rem;
}

.block-newsgrid figure {
  width: 100%;
  height: 0;
  margin: 0 0 1rem;
  padding-bottom: 90%;
  overflow: hidden;
  position: relative;
  z-index: 0;
}

.block-newsgrid figure a {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  width: 100%;
  height: 100%;
  background-color: transparent;
}

.block-newsgrid .category-block {
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: .5rem;
}

.block-newsgrid h3 {
  margin: 0 0 1rem;
}

.block-newsgrid time {
  font-weight: 400;
  font-style: italic;
}

.block-testimonials {
  background-color: #f4f3f1;
}

.block-testimonials nav {
  position: relative;
  border-right: solid 1px #666666;
  padding-bottom: 2rem;
}

@media (min-width: 768px) {
  .block-testimonials nav {
    padding-top: 2rem;
  }
}

.block-testimonials nav .items {
  position: relative;
}

.block-testimonials nav .item {
  position: relative;
  margin-top: 1rem;
  margin-bottom: 1rem;
  cursor: pointer;
}

.block-testimonials nav .item.tns-nav-active {
  color: #db352a;
}

.block-testimonials nav .item.tns-nav-active h4 {
  color: #db352a;
}

.block-testimonials nav .item figure {
  width: 30%;
  height: 0;
  margin: 0;
  padding-bottom: 18%;
  overflow: hidden;
  position: relative;
  z-index: 0;
}

.block-testimonials nav .item div {
  width: 65%;
}

.block-testimonials nav .item h4 {
  font-size: 1rem;
  margin-bottom: 5px;
}

.block-testimonials nav .item span {
  font-weight: 400;
  font-size: .8rem;
}

.block-testimonials nav svg {
  width: 10px;
  height: auto;
  display: block;
  position: absolute;
  top: 15%;
  right: -17px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: .4s;
  transition: .4s;
}

.block-testimonials nav .item-1.tns-nav-active ~ svg {
  top: 15%;
}

.block-testimonials nav .item-2.tns-nav-active ~ svg {
  top: 50%;
}

.block-testimonials nav .item-3.tns-nav-active ~ svg {
  top: 80%;
}

.block-testimonials article {
  font-size: 1rem;
  font-weight: 400;
}

.block-testimonials article .item {
  position: relative;
  padding-left: 3rem;
  padding-top: 1rem;
}

@media (min-width: 768px) {
  .block-testimonials article .item {
    margin-left: 2rem;
  }
}

.block-testimonials article .item img {
  position: absolute;
  top: 0;
  left: 0;
  width: 2rem;
}

.block-testimonials article .item p:last-child {
  margin: 0;
}

.block-testimonials article footer {
  margin-left: 3rem;
  margin-top: 1rem;
}

@media (min-width: 768px) {
  .block-testimonials article footer {
    margin-left: 5rem;
    margin-top: 2rem;
  }
}

.block-testimonials article footer span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: solid 1px #666666;
  background-color: transparent;
  display: inline-block;
  margin-right: 5px;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-testimonials article footer .active {
  border-color: #db352a;
  background-color: #db352a;
}

.block-footer {
  padding: 3rem 0 1rem;
  font-weight: 400;
}

@media (min-width: 768px) {
  .block-footer {
    padding: 5rem 0 1rem;
  }
}

.block-footer .data-block {
  background-color: #f9f9f8;
  padding-bottom: 2rem;
}

.block-footer .quote-block {
  background-color: #ff4b01;
  color: #000000;
  background-image: url("../images/background-quote.jpg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  margin-left: 2rem;
  margin-right: -5vw;
  padding: 1.5rem;
  text-transform: none;
  line-height: 1.6;
  font-weight: 600;
  position: relative;
  top: -1rem;
}

@media (min-width: 768px) {
  .block-footer .quote-block {
    margin-left: 5rem;
    margin-right: -10vw;
    padding: 2rem 1.5rem;
  }
}

@media (min-width: 1200px) {
  .block-footer .quote-block {
    margin-left: 10rem;
    margin-right: -20vw;
    padding: 3rem 2rem;
    top: -2rem;
  }
}

.block-footer .quote-block::before {
  width: 100%;
  height: 100%;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  background-color: #ff4b01;
  opacity: .9;
}

.block-footer .quote-block div {
  width: 240px;
  max-width: 100%;
  position: relative;
  z-index: 1;
}

@media (min-width: 575px) {
  .block-footer .quote-block div {
    width: 350px;
  }
}

@media (min-width: 768px) {
  .block-footer .quote-block div {
    width: 500px;
  }
}

@media (min-width: 1200px) {
  .block-footer .quote-block div {
    width: 800px;
  }
}

.block-footer .quote-block a {
  display: inline-block;
  color: #ffffff;
  position: relative;
}

.block-footer .quote-block a::after {
  width: 100%;
  height: 2px;
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: #ffffff;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-footer .quote-block a:hover::after {
  width: 0;
}

.block-footer nav {
  display: none;
}

@media (min-width: 768px) {
  .block-footer nav {
    display: block;
  }
}

.block-footer nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.block-footer nav ul li {
  margin: 0 1rem .5rem 0;
  padding: 0;
  display: inline-block;
}

.block-footer nav a {
  color: #000000;
  -webkit-transition: .4s;
  transition: .4s;
}

.block-footer nav a:hover {
  color: #ff4b01;
}

.block-footer .copy-block {
  color: #000000;
  padding-top: 1rem;
  text-align: center;
}

@media (min-width: 768px) {
  .block-footer .copy-block {
    text-align: left;
  }
}

@media (min-width: 1200px) {
  .block-footer .copy-block {
    padding-top: 2rem;
  }
}

.block-footer .copy-block img {
  height: 1rem;
}

.block-footer .social-block {
  padding-top: 1rem;
  text-align: center;
}

@media (min-width: 768px) {
  .block-footer .social-block {
    text-align: right;
  }
}

@media (min-width: 1200px) {
  .block-footer .social-block {
    padding-top: 2rem;
  }
}

.block-footer .social-block a {
  display: inline-block;
  width: 2rem;
  height: 2rem;
  line-height: 2rem;
  border-radius: 50%;
  background-color: #000000;
  color: #ffffff;
  font-size: 1.1rem;
  text-align: center;
  margin-left: 3px;
  margin-right: 3px;
  -webkit-transition: .4s;
  transition: .4s;
}

@media (min-width: 768px) {
  .block-footer .social-block a {
    margin-left: .5rem;
    margin-right: 0;
  }
}

.block-footer .social-block a svg {
  width: 1rem;
  height: 1rem;
  display: inline-block;
}

.block-footer .social-block a svg polygon {
  fill: #ffffff;
}

.block-footer .social-block a:hover {
  background-color: #db352a;
}

.block-page-packages header {
  text-align: center;
}

@media (min-width: 1200px) {
  .block-page-packages .data-block {
    margin-left: 2rem;
  }
}

.block-page-packages .caption-block {
  width: 100%;
  font-size: 1.8rem;
}

@media (min-width: 768px) {
  .block-page-packages .caption-block {
    font-size: 2rem;
  }
}

@media (min-width: 1200px) {
  .block-page-packages .caption-block {
    font-size: 2.2rem;
  }
}

.block-page-packages .feature-block {
  margin-bottom: 3rem;
}

.block-page-packages .feature-block span {
  display: inline-block;
  height: 4rem;
  margin-bottom: 1rem;
}

.block-page-packages .feature-block span img {
  width: auto;
  height: 100%;
  display: block;
}

.block-page-packages .feature-block h5 {
  font-size: .9rem;
  font-weight: 600;
  text-transform: uppercase;
  text-align: center;
}

.block-page-packages .feature-block p {
  text-align: justify;
}

.block-page-packages .feature-block strong {
  color: #000000;
  font-weight: 400;
  text-align: center;
  display: block;
}

.block-page-packages .feature-block blockquote {
  text-align: left;
  color: #000000;
  font-size: .8rem;
  font-style: italic;
}

.block-page-packages .image-block {
  width: 100%;
  height: 50vw;
  position: relative;
  margin-top: 3rem;
}

@media (min-width: 1200px) {
  .block-page-packages .image-block {
    width: 100%;
    height: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
  }
}

.block-page-packages .image-block .dot-block {
  width: 8rem;
  height: 8rem;
  background-image: url("../images/texture-dot.png") !important;
  background-position: top left;
  background-repeat: repeat;
  background-size: 10px;
  position: absolute;
  top: 0;
  right: -3rem;
  z-index: 0;
}

@media (min-width: 1200px) {
  .block-page-packages .image-block .dot-block {
    top: -1rem;
  }
}

.block-page-packages .image-block figure {
  display: block;
  margin: 0;
  margin-left: -20vw;
  height: 100%;
  position: relative;
  z-index: 1;
}

.block-portfolio .data-block {
  position: relative;
  padding-bottom: 5rem;
  margin-right: 2rem;
}

@media (min-width: 768px) {
  .block-portfolio .data-block {
    padding-bottom: 8rem;
  }
}

.block-portfolio .data-block::before, .block-portfolio .data-block::after {
  width: 999999999px;
  height: 85%;
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  margin-right: -1px;
  background-color: #f9f9f8;
}

.block-portfolio .data-block::after {
  left: 0;
  right: auto;
  margin-left: -1px;
  margin-right: auto;
}

.block-portfolio .data-block article {
  position: relative;
  z-index: 1;
  margin-left: 5rem;
}

@media (min-width: 768px) {
  .block-portfolio .data-block article {
    margin-right: -10vw;
    margin-left: 10rem;
  }
}

@media (min-width: 1200px) {
  .block-portfolio .data-block article {
    margin-right: -20vw;
  }
}

.block-portfolio .data-block article figure {
  width: 100%;
  height: 0;
  margin: 0;
  padding-bottom: 60%;
  overflow: hidden;
  position: relative;
  z-index: 0;
}

.block-portfolio .data-block footer {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 5rem;
}

@media (min-width: 768px) {
  .block-portfolio .data-block footer {
    height: 8rem;
  }
}

.block-portfolio .data-block footer .linenumber-block {
  position: relative;
  font-weight: 600;
  margin-left: 1rem;
}

.block-portfolio .data-block footer .linenumber-block div {
  width: 2rem;
  height: 2rem;
  line-height: 2rem;
  text-align: center;
  display: inline-block;
  vertical-align: middle;
}

.block-portfolio .data-block footer .linenumber-block div:last-child {
  color: #000000;
}

.block-portfolio .data-block footer .linenumber-block span {
  display: inline-block;
  vertical-align: middle;
  width: 2rem;
  height: 1px;
  background-color: #000000;
}

@media (min-width: 575px) {
  .block-portfolio .data-block footer .linenumber-block span {
    width: 3rem;
  }
}

@media (min-width: 768px) {
  .block-portfolio .data-block footer .linenumber-block span {
    width: 6rem;
  }
}

.block-portfolio .data-block footer nav .arrow-left svg polyline {
  stroke: #666666;
}

.block-portfolio .data-block footer nav .arrow-left:hover svg polyline {
  stroke: #000000;
}

.block-portfolio .data-block footer nav .arrow-right svg polyline {
  stroke: #db352a;
}

.block-portfolio .data-block footer nav .arrow-right:hover svg polyline {
  stroke: #000000;
}

.block-portfolio .data-block footer .arrow-right {
  margin-right: 1rem;
}

@media (min-width: 768px) {
  .block-portfolio .data-block footer .arrow-right {
    margin-right: 2rem;
  }
}

@media (min-width: 1200px) {
  .block-portfolio .data-block footer .arrow-right {
    margin-right: 3rem;
  }
}

.block-page-quote .image-block {
  width: 100%;
  height: 50vw;
  position: relative;
  margin-top: 3rem;
}

@media (min-width: 1200px) {
  .block-page-quote .image-block {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
}

.block-page-quote .image-block .dot-block {
  width: 12rem;
  height: 11rem;
  background-image: url("../images/texture-dot.png") !important;
  background-position: top left;
  background-repeat: repeat;
  background-size: 10px;
  position: absolute;
  top: -2rem;
  right: -7rem;
  z-index: 0;
}

@media (min-width: 1200px) {
  .block-page-quote .image-block .dot-block {
    top: -4rem;
  }
}

.block-page-quote figure {
  display: block;
  margin: 0;
  margin-right: -20vw;
  margin-left: 2rem;
  height: 100%;
  position: relative;
  z-index: 1;
}

.block-page-faq {
  background-color: #f9f9f8;
}

.block-accordion {
  border-bottom: solid 1px #dadce0;
}

.block-accordion h3 {
  position: relative;
  margin: 0;
  padding: 1rem 2.5rem 1rem 0;
  font-size: 1rem;
  font-weight: 400;
  cursor: pointer;
}

.block-accordion h3 span {
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 2rem;
  height: 100%;
  color: #ff4b01;
  font-size: 1.4rem;
}

@media (min-width: 768px) {
  .block-accordion h3 span {
    width: 3rem;
  }
}

.block-accordion h3 span i {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transition: .4s;
  transition: .4s;
  -webkit-transform: translate(-50%, -50%) rotate(0);
          transform: translate(-50%, -50%) rotate(0);
}

.block-accordion .text-block {
  display: none;
  padding: 0 2.5rem 1rem 0;
}

.block-accordion.expanded h3 span i {
  -webkit-transform: translate(-50%, -50%) rotate(180deg);
          transform: translate(-50%, -50%) rotate(180deg);
}

@media (min-width: 768px) {
  .block-page-page .data-block {
    margin-right: 3rem;
  }
}

.block-page-page .caption-block {
  width: 100%;
}

.block-page-page .image-block {
  width: 100%;
  height: 50vw;
  position: relative;
  margin-top: 3rem;
}

@media (min-width: 1200px) {
  .block-page-page .image-block {
    width: 100%;
    height: 80%;
    position: absolute;
    bottom: 0;
    left: 0;
  }
}

.block-page-page .image-block .dot-block {
  width: 8rem;
  height: 8rem;
  background-image: url("../images/texture-dot.png") !important;
  background-position: top left;
  background-repeat: repeat;
  background-size: 10px;
  position: absolute;
  top: -1rem;
  left: -3rem;
  z-index: 0;
}

@media (min-width: 1200px) {
  .block-page-page .image-block .dot-block {
    top: -3rem;
  }
}

.block-page-page .image-block figure {
  display: block;
  margin: 0;
  margin-right: -20vw;
  height: 100%;
  position: relative;
  z-index: 1;
}

.block-page-post .caption-block {
  width: 100%;
}

.block-page-post .image-block {
  width: 100%;
  height: 50vw;
  position: relative;
  margin-top: 3rem;
}

@media (min-width: 1200px) {
  .block-page-post .image-block {
    width: 50%;
    height: 25vw;
    float: right;
    margin-left: 3rem;
  }
}

.block-page-post .image-block .dot-block {
  width: 8rem;
  height: 8rem;
  background-image: url("../images/texture-dot.png") !important;
  background-position: top left;
  background-repeat: repeat;
  background-size: 10px;
  position: absolute;
  top: -1rem;
  left: -3rem;
  z-index: 0;
}

@media (min-width: 1200px) {
  .block-page-post .image-block .dot-block {
    top: -3rem;
  }
}

.block-page-post .image-block figure {
  display: block;
  margin: 0;
  margin-right: -20vw;
  height: 100%;
  position: relative;
  z-index: 1;
}

.block-page-contact h2 {
  text-transform: none;
}

.block-page-contact .address-block {
  margin-bottom: 4rem;
}

.block-page-contact .address-block .item {
  padding-left: 2rem;
  padding-top: 5px;
  position: relative;
  margin-bottom: 1rem;
}

@media (min-width: 768px) {
  .block-page-contact .address-block .item {
    margin-bottom: 1.5rem;
  }
}

@media (min-width: 1200px) {
  .block-page-contact .address-block .item {
    padding-left: 2.5rem;
  }
}

.block-page-contact .address-block .item .icon {
  position: absolute;
  top: 0;
  left: 0;
  width: 2rem;
  line-height: 2rem;
  text-align: center;
  color: #db352a;
  font-size: 1.4rem;
}

@media (min-width: 768px) {
  .block-page-contact .address-block .item .icon {
    font-size: 1.6rem;
  }
}

@media (min-width: 1200px) {
  .block-page-contact .address-block .item .icon {
    font-size: 1.8rem;
  }
}

.block-page-contact .address-block .item .icon .fa-envelope-o {
  position: relative;
  top: -2px;
  font-size: 1rem;
}

@media (min-width: 768px) {
  .block-page-contact .address-block .item .icon .fa-envelope-o {
    font-size: 1.2rem;
  }
}

@media (min-width: 1200px) {
  .block-page-contact .address-block .item .icon .fa-envelope-o {
    font-size: 1.4rem;
  }
}

.block-page-contact .address-block .item .icon svg {
  width: 1rem;
  height: 1rem;
  display: block;
  margin: auto;
}

@media (min-width: 768px) {
  .block-page-contact .address-block .item .icon svg {
    width: 1.2rem;
    height: 1.2rem;
  }
}

@media (min-width: 1200px) {
  .block-page-contact .address-block .item .icon svg {
    width: 1.4rem;
    height: 1.4rem;
  }
}

.block-page-contact .address-block .item .icon svg polygon {
  fill: #db352a;
}

.block-page-contact .address-block .item a {
  color: #666666;
}

.block-editor ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.block-editor ul li {
  position: relative;
  margin: 0;
  padding: 0 0 1rem 2rem;
}

.block-editor ul li::before {
  width: 1.4rem;
  height: 1.4rem;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  background-image: url("../images/icon-tick.svg");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}

.gap {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

@media (min-width: 575px) {
  .gap {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
}

@media (min-width: 768px) {
  .gap {
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
  }
}

@media (min-width: 992px) {
  .gap {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
}

.gap-up {
  padding-top: 2rem;
}

@media (min-width: 575px) {
  .gap-up {
    padding-top: 3rem;
  }
}

@media (min-width: 768px) {
  .gap-up {
    padding-top: 3.5rem;
  }
}

@media (min-width: 992px) {
  .gap-up {
    padding-top: 4rem;
  }
}

.gap-down {
  padding-bottom: 2rem;
}

@media (min-width: 575px) {
  .gap-down {
    padding-bottom: 3rem;
  }
}

@media (min-width: 768px) {
  .gap-down {
    padding-bottom: 3.5rem;
  }
}

@media (min-width: 992px) {
  .gap-down {
    padding-bottom: 4rem;
  }
}

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