@import url("https://use.typekit.net/czt2qsn.css");
.section.section-project-list .article .slider .slick-arrow, .section.section-project-list .gallery a img, .section.section-project-list .list .item .image img, .section.section-news-list .navi li.next a:after, .section.section-news-list .navi li.prev a:after, .section.section-news-list .list .item .image img, .section.section-about .team .item:after, .section.section-about .list .item:after, .section.section-testimonials .author .slick-arrow, .section.section-news .list .item .image img, .section.section-news .list .item:after, .section.section-projects .wrap .block .image img, .mobile-menu, #header .logo img, #header .logo svg, .header-copy .logo img, .header-copy .logo svg, #header, .header-copy, a {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.section.section-testimonials .slider .content {
  -webkit-transition: all 0.8s ease;
  transition: all 0.8s ease;
}

/* basic 
==================================== */
body {
  overflow-x: hidden;
  font-family: aller, sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: 16.5px;
  line-height: 1.3;
  color: #000;
}

input:-internal-autofill-previewed, input:-internal-autofill-selected, textarea:-internal-autofill-previewed, textarea:-internal-autofill-selected, select:-internal-autofill-previewed, select:-internal-autofill-selected {
  background-color: transparent !important;
}

.form-control {
  color: #000;
  padding: 7px 0px;
  height: auto;
  font-size: 16px;
  border: 0;
  border-bottom: 1px solid #7f7f7f;
  border-radius: 0px;
  background: transparent;
}
.form-control:focus {
  border-color: #D9D9D9;
}
@media only screen and (min-width: 992px) {
  .form-control {
    font-size: 21px;
  }
}

select.form-control {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  background: url(../images/arrowdown.svg) right 0px center no-repeat;
  background-size: 17px;
  padding-right: 40px;
  height: auto !important;
}

textarea.form-control {
  height: 160px;
}

.form-control:focus {
  color: #000;
  border-color: #D9D9D9;
  background-color: transparent;
  outline: 0;
  box-shadow: none;
}

a {
  color: #7f7f7f;
}
a:hover {
  text-decoration: none;
  color: #939190;
}

img {
  max-width: 100%;
  height: auto;
}

.container {
  padding-right: 20px;
  padding-left: 20px;
  max-width: 1386px;
}
.container.container-md {
  max-width: 1010px;
}
@media only screen and (min-width: 992px) {
  .container {
    padding-right: 40px;
    padding-left: 40px;
  }
}

.wp-block-button {
  padding: 0;
}

.btn,
.wp-block-button__link {
  border-radius: 15px;
  font-weight: 400;
  font-size: 20px;
  padding: 10px 30px;
  border-width: 2px;
  border-radius: 30px;
  line-height: 1;
}
@media only screen and (min-width: 992px) {
  .btn,
  .wp-block-button__link {
    font-size: 21px;
  }
}
.btn.btn-primary,
.wp-block-button__link.btn-primary {
  background: transparent;
  color: #000;
  border-color: #000;
  position: relative;
}
.btn.btn-primary:hover,
.wp-block-button__link.btn-primary:hover {
  background: #000;
  color: #fff;
}
.btn.btn-secondary,
.wp-block-button__link.btn-secondary {
  background: transparent;
  color: #fff;
  text-transform: uppercase;
  border-color: #fff;
  position: relative;
}
.btn.btn-secondary:hover,
.wp-block-button__link.btn-secondary:hover {
  background: #fff;
  color: #D9D9D9;
}
.btn.btn-tertiary,
.wp-block-button__link.btn-tertiary {
  background: transparent;
  color: #7f7f7f;
  text-transform: uppercase;
  border-color: #7f7f7f;
  position: relative;
}
.btn.btn-tertiary:hover,
.wp-block-button__link.btn-tertiary:hover {
  background: #7f7f7f;
  color: #fff;
}

.wp-block-buttons .wp-block-button__link {
  background: transparent;
  color: #000;
  border: 2px solid #000;
  position: relative;
  font-size: 20px;
  padding: 10px 30px;
}
.wp-block-buttons .wp-block-button__link:hover {
  background: #000;
  color: #fff;
}
@media only screen and (min-width: 992px) {
  .wp-block-buttons .wp-block-button__link {
    font-size: 21px;
  }
}

b, strong {
  font-weight: 700;
}

/* Header
========================================= */
#header, .header-copy {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 10;
  padding: 25px 0px;
  text-align: center;
}
#header .container, .header-copy .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#header .menu, .header-copy .menu {
  display: none;
}
#header .menu ul, .header-copy .menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
#header .menu ul li, .header-copy .menu ul li {
  margin-bottom: 10px;
}
@media only screen and (min-width: 992px) {
  #header .menu ul li, .header-copy .menu ul li {
    margin-bottom: 0;
  }
}
#header .menu ul li a, .header-copy .menu ul li a {
  color: #fff;
}
#header .menu ul.bottom li, .header-copy .menu ul.bottom li {
  padding-bottom: 20px;
}
#header .menu ul.bottom li a, .header-copy .menu ul.bottom li a {
  position: relative;
  padding: 10px 20px;
  border-radius: 30px;
  font-weight: 400;
}
#header .menu ul.bottom li a:hover, .header-copy .menu ul.bottom li a:hover {
  background: rgba(0, 0, 0, 0.5);
}
#header .menu ul.bottom li.last a, .header-copy .menu ul.bottom li.last a {
  background: #fff;
  color: #000;
}
#header .menu ul.bottom li.last a:hover, .header-copy .menu ul.bottom li.last a:hover {
  background: #000;
  color: #fff;
}
#header .menu ul.bottom li ul, .header-copy .menu ul.bottom li ul {
  display: none;
  position: fixed;
  text-align: left;
  padding: 15px 20px;
  border-radius: 15px;
  background: #D9D9D9;
  transform: translateY(10px);
  width: 250px;
}
#header .menu ul.bottom li ul li, .header-copy .menu ul.bottom li ul li {
  display: block;
  padding-bottom: 0;
  margin: 0 0 5px;
}
#header .menu ul.bottom li ul li a, .header-copy .menu ul.bottom li ul li a {
  color: #000;
  padding: 0;
}
#header .menu ul.bottom li ul li a:hover, .header-copy .menu ul.bottom li ul li a:hover {
  background: transparent;
  color: #7f7f7f;
}
#header .menu ul.bottom li:hover ul, .header-copy .menu ul.bottom li:hover ul {
  display: block;
  animation: fadeIn 0.5s;
}
@media only screen and (min-width: 992px) {
  #header .menu ul.bottom li, .header-copy .menu ul.bottom li {
    margin-left: 20px;
  }
}
#header .menu .block, .header-copy .menu .block {
  display: flex;
  justify-content: space-between;
  padding: 0 20px;
}
#header .menu .block .column, .header-copy .menu .block .column {
  width: 48%;
}
@media only screen and (min-width: 992px) {
  #header .menu .block, .header-copy .menu .block {
    display: block;
    padding: 0;
    margin-bottom: -30px;
  }
  #header .menu .block .column, .header-copy .menu .block .column {
    width: 100%;
  }
  #header .menu .block .column:first-child, .header-copy .menu .block .column:first-child {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    margin-bottom: 10px;
  }
}
#header .logo img, #header .logo svg, .header-copy .logo img, .header-copy .logo svg {
  width: 100%;
  max-width: 124px;
  height: auto;
  margin-top: 5px;
}
@media only screen and (min-width: 992px) {
  #header .logo img, #header .logo svg, .header-copy .logo img, .header-copy .logo svg {
    max-width: 198px;
  }
}
#header .logo path, .header-copy .logo path {
  fill: #fff;
}
#header .toggle, .header-copy .toggle {
  text-align: center;
  color: #fff;
  font-size: 18px;
  font-weight: 400;
  cursor: pointer;
}
#header.on, #header.active, .header-copy.on, .header-copy.active {
  background: #000;
}
#header.on .toggle, #header.active .toggle, .header-copy.on .toggle, .header-copy.active .toggle {
  color: #fff;
}
@media only screen and (min-width: 992px) {
  #header.on, #header.active, .header-copy.on, .header-copy.active {
    background: transparent;
  }
}
#header.alt, .header-copy.alt {
  background: #fff;
  position: sticky;
}
#header.alt .toggle, .header-copy.alt .toggle {
  color: #000;
}
#header.alt .logo path, .header-copy.alt .logo path {
  fill: #000;
}
#header.alt.active, .header-copy.alt.active {
  background: #000;
}
#header.alt.active .toggle, .header-copy.alt.active .toggle {
  color: #fff;
}
#header.alt.active .logo path, .header-copy.alt.active .logo path {
  fill: #fff;
}
@media only screen and (min-width: 992px) {
  #header.alt, .header-copy.alt {
    position: relative;
  }
  #header.alt.active, .header-copy.alt.active {
    background: transparent;
  }
  #header.alt.active .logo path, .header-copy.alt.active .logo path {
    fill: #000;
  }
  #header.alt .menu ul li a, .header-copy.alt .menu ul li a {
    color: #000;
  }
  #header.alt .menu ul li a:hover, .header-copy.alt .menu ul li a:hover {
    color: #fff;
  }
  #header.alt .menu ul li.last a, .header-copy.alt .menu ul li.last a {
    border: 2px solid #000;
    color: #000;
    background: transparent;
    padding: 8px 18px;
  }
  #header.alt .menu ul li.last a:hover, .header-copy.alt .menu ul li.last a:hover {
    background: #000;
    color: #fff;
  }
}

.header-copy {
  display: none;
}

@media only screen and (min-width: 992px) {
  #header, .header-copy {
    padding: 60px 0 0px;
    text-align: left;
    position: absolute;
  }
  #header .logo path, .header-copy .logo path {
    fill: #fff;
  }
  #header .toggle, .header-copy .toggle {
    display: none;
  }
  #header .menu, .header-copy .menu {
    display: block !important;
    width: calc(100% - 200px);
    text-align: right;
  }
  #header .menu ul, .header-copy .menu ul {
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }
  #header .menu ul li, .header-copy .menu ul li {
    display: inline-block;
    position: relative;
  }
  .header-copy {
    position: fixed;
    display: block;
    padding: 30px 0;
    top: -123px;
  }
  .header-copy.active {
    background: rgba(255, 255, 255, 0.9);
  }
  .header-copy.active .logo path {
    fill: #000;
  }
  .header-copy.active .menu ul li a {
    color: #000;
  }
  .header-copy.active .menu ul li a:hover {
    color: #fff;
  }
  .header-copy.active .menu ul li.last a {
    border: 2px solid #000;
    color: #000;
    background: transparent;
    padding: 8px 18px;
  }
  .header-copy.active .menu ul li.last a:hover {
    background: #000;
    color: #fff;
  }
}
.mobile-menu {
  position: fixed;
  width: 100%;
  top: -100%;
  height: calc(100dvh - 90px);
  background: #000;
  z-index: 9;
  overflow-y: scroll;
  left: 0;
}
.mobile-menu.active {
  top: 90px;
}
.mobile-menu .close-btn {
  opacity: 1;
  text-align: center;
  display: block;
  float: none;
  margin-top: 90px;
  margin-bottom: 20px;
}
.mobile-menu .close-btn img {
  width: 33px;
}
.mobile-menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.mobile-menu ul li {
  padding: 20px 30px;
  border-bottom: 1px solid #fff;
  text-align: right;
}
.mobile-menu ul li a {
  position: relative;
  display: block;
  color: #fff;
  font-size: 32px;
  font-weight: 400;
}
.mobile-menu ul li ul {
  margin-top: 10px;
  margin-bottom: 10px;
  display: none;
}
.mobile-menu ul li ul li {
  border-bottom: 0;
  font-size: 20px;
  padding: 0;
  padding-left: 0px;
  text-transform: none;
}
.mobile-menu ul li ul li a {
  padding-left: 0;
}
.mobile-menu ul li ul li a:before {
  display: none;
}

.anchor {
  display: block;
  position: relative;
  visibility: hidden;
  top: -90px;
}
@media only screen and (min-width: 992px) {
  .anchor {
    top: -118px;
  }
}

/* hero-home
========================================= */
.hero-home {
  position: relative;
  overflow: hidden;
}
@media only screen and (min-width: 992px) {
  .hero-home {
    color: #fff;
  }
  .hero-home .content {
    position: absolute;
    z-index: 2;
    top: 0;
    margin: 0 auto;
    left: 0;
    right: 0;
    height: 100%;
    display: flex;
    align-items: center;
    width: 100%;
  }
  .hero-home .content .container {
    display: flex;
    justify-content: flex-end;
  }
}
.hero-home h1 {
  font-weight: 700;
  padding: 40px 0 10px;
  margin-bottom: 0;
  line-height: 1;
  font-size: 12vw;
}
@media only screen and (min-width: 768px) {
  .hero-home h1 {
    font-size: 7vw;
  }
}
@media only screen and (min-width: 768px) and (min-width: 992px) {
  .hero-home h1 {
    padding: 0;
  }
}
@media only screen and (min-width: 768px) and (min-width: 992px) and (min-width: 1490px) {
  .hero-home h1 {
    font-size: 95px;
  }
}
.hero-home .slider {
  position: relative;
  overflow: hidden;
  background: #000;
}
.hero-home .slider .imageset {
  font-size: 0;
}
.hero-home .slider:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/arrow_overlay.png) top left 20% no-repeat;
  background-size: auto 100%;
  z-index: 2;
}
@media only screen and (min-width: 992px) {
  .hero-home .slider:before {
    background-position: top left 30%;
  }
}
.hero-home .image {
  position: relative;
  background: #000;
  height: 520px;
}
.hero-home .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.5;
}
@media only screen and (min-width: 992px) {
  .hero-home .image {
    height: 100vh;
  }
}
.hero-home .bg {
  position: relative;
  height: 100dvh;
  background: #000;
}
.hero-home .bg:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/arrow_overlay.png) top left 20% no-repeat;
  background-size: auto 100%;
  z-index: 2;
}
@media only screen and (min-width: 992px) {
  .hero-home .bg:before {
    background-position: top left 30%;
  }
}
.hero-home .bg .vimeo-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
  opacity: 0.5;
}
.hero-home .bg .vimeo-wrapper iframe {
  width: 100vw;
  height: 56.25vw; /* Given a 16:9 aspect ratio, 9/16*100 = 56.25 */
  min-height: 100vh;
  min-width: 177.77vh; /* Given a 16:9 aspect ratio, 16/9*100 = 177.77 */
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.hero-home .bg .video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
  opacity: 0.5;
}
.hero-home .bg .video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.section {
  padding: 70px 0;
}
@media only screen and (min-width: 992px) {
  .section {
    padding: 150px 0;
  }
}
.section.alt-bg {
  background: #EDE4D6;
}
.section.section-page h1 {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-page h1 {
    font-size: 45px;
  }
}
.section.section-page .link {
  margin-top: 30px;
}
@media only screen and (min-width: 992px) {
  .section.section-page .link {
    margin-top: 50px;
  }
}
.section.section-page h1 a, .section.section-page h2 a, .section.section-page h3 a, .section.section-page h4 a, .section.section-page ul a, .section.section-page ol a, .section.section-page p a {
  color: #000;
}
.section.section-page h1 a:hover, .section.section-page h2 a:hover, .section.section-page h3 a:hover, .section.section-page h4 a:hover, .section.section-page ul a:hover, .section.section-page ol a:hover, .section.section-page p a:hover {
  color: #7f7f7f;
}
.section.section-page h2 {
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 300;
  font-weight: 700;
  margin-top: 30px;
}
@media only screen and (min-width: 992px) {
  .section.section-page h2 {
    font-size: 27px;
  }
}
.section.section-page h4 {
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 300;
  font-weight: 700;
}
@media only screen and (min-width: 992px) {
  .section.section-page h4 {
    font-size: 27px;
  }
}
.section.section-page.sitemap ul, .section.section-page.sitemap ol {
  margin-left: 30px;
  padding: 0;
  margin-bottom: 30px;
  list-style: none;
}
.section.section-page.sitemap ul li, .section.section-page.sitemap ol li {
  margin-bottom: 5px;
  font-weight: 700;
}
@media only screen and (min-width: 992px) {
  .section.section-page.sitemap ul li, .section.section-page.sitemap ol li {
    font-size: 20px;
    margin-bottom: 10px;
  }
}
.section.section-home {
  position: relative;
  background: #fff;
  overflow: hidden;
}
.section.section-home h2 {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-home h2 {
    font-size: 45px;
  }
}
.section.section-home .link, .section.section-home .wp-block-button {
  margin-top: 30px;
  width: 100%;
}
.section.section-home .intro {
  font-size: 18px;
}
@media only screen and (min-width: 992px) {
  .section.section-home .intro {
    font-size: 27px;
    display: flex;
    justify-content: space-between;
  }
  .section.section-home .intro .column {
    width: 49%;
  }
  .section.section-home .intro .column:last-child {
    width: 40%;
    position: relative;
    padding-bottom: 80px;
  }
  .section.section-home .intro .column .link {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
  }
}
.section.section-home .intro .image {
  margin-bottom: 60px;
}
@media only screen and (min-width: 992px) {
  .section.section-home .intro .image {
    margin-bottom: 0;
  }
}
.section.section-home .intro .image img {
  width: 100%;
}
.section.section-sub {
  background: #000;
  color: #fff;
}
@media only screen and (min-width: 992px) {
  .section.section-sub {
    padding: 115px 0;
  }
}
.section.section-sub h2 {
  font-weight: 400;
  font-size: 18px;
  text-align: center;
  margin-bottom: 20px;
}
@media only screen and (min-width: 992px) {
  .section.section-sub h2 {
    text-align: left;
    font-size: 33px;
    margin-bottom: 0;
  }
}
.section.section-sub [data-status=invalid] .form {
  border-color: red;
}
.section.section-sub .form {
  display: flex;
  background: #fff;
  border-radius: 30px;
  border: 2px solid #fff;
}
.section.section-sub .form .form-group {
  margin-bottom: 0;
  width: 150px;
}
@media only screen and (min-width: 992px) {
  .section.section-sub .form .form-group {
    width: 162px;
  }
}
.section.section-sub .form .form-group .form-control {
  border: 0;
  padding: 10px 20px;
}
@media only screen and (min-width: 992px) {
  .section.section-sub .form .form-group .form-control {
    font-size: 30px;
    padding: 8px 30px;
    line-height: 1;
  }
}
.section.section-sub .form .form-group .btn-submit {
  background: #000;
  color: #fff;
  min-width: auto;
  width: 100%;
}
@media only screen and (min-width: 992px) {
  .section.section-sub .form .form-group .btn-submit {
    font-size: 30px;
  }
}
.section.section-sub .form .form-group:first-child {
  width: calc(100% - 150px);
}
@media only screen and (min-width: 992px) {
  .section.section-sub .form .form-group:first-child {
    width: calc(100% - 162px);
  }
}
.section.section-sub .wpcf7-not-valid-tip {
  display: none;
}
.section.section-sub .wpcf7-spinner {
  right: -60px;
}
.section.section-sub .wpcf7 form .wpcf7-response-output {
  margin-top: 20px;
}
@media only screen and (min-width: 992px) {
  .section.section-sub .block {
    display: flex;
    justify-content: space-between;
  }
  .section.section-sub .block .column {
    width: 50%;
  }
  .section.section-sub .block .column h2 {
    padding-top: 10px;
  }
  .section.section-sub .block .column:last-child {
    width: 48%;
  }
}
@media only screen and (min-width: 992px) and (min-width: 1490px) {
  .section.section-sub .block .column {
    width: 40%;
  }
  .section.section-sub .block .column:last-child {
    width: 58%;
    max-width: 750px;
  }
}
.section.section-projects {
  background: #EDE4D6;
  position: relative;
  overflow: hidden;
}
.section.section-projects .heading .link {
  display: flex;
}
.section.section-projects .heading .link a {
  margin-right: 10px;
}
@media only screen and (min-width: 768px) {
  .section.section-projects .heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .section.section-projects .heading h1, .section.section-projects .heading h2 {
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-projects .heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
.section.section-projects h2 {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-projects h2 {
    font-size: 45px;
  }
}
.section.section-projects .wrap {
  margin-top: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-projects .wrap {
    border-top: 1px solid #000;
    margin-top: 60px;
  }
}
.section.section-projects .wrap .block .image {
  margin-bottom: 20px;
  width: 85%;
  height: 68vw;
  background: #000;
  position: relative;
  overflow: hidden;
}
@media only screen and (min-width: 992px) {
  .section.section-projects .wrap .block .image {
    width: 100%;
    height: 525px;
  }
}
.section.section-projects .wrap .block .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media only screen and (min-width: 992px) {
  .section.section-projects .wrap .block {
    display: flex;
    justify-content: space-between;
  }
}
.section.section-projects .wrap .block .column {
  display: block;
  margin-bottom: 40px;
  position: relative;
  color: #000;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.1;
}
.section.section-projects .wrap .block .column:hover img {
  opacity: 0.5;
}
.section.section-projects .wrap .block .column p {
  margin-bottom: 0;
}
.section.section-projects .wrap .block .column:before {
  content: "";
  position: absolute;
  top: 0;
  width: calc(100% + 20px);
  height: 1px;
  left: 0;
  background: #000;
  z-index: 1;
}
@media only screen and (min-width: 992px) {
  .section.section-projects .wrap .block .column {
    width: calc(33.33% - 11px);
    font-size: 21px;
    margin-bottom: 0;
  }
  .section.section-projects .wrap .block .column:first-child:before {
    display: none;
  }
  .section.section-projects .wrap .block .column:nth-child(2) {
    margin-top: 80px;
  }
  .section.section-projects .wrap .block .column:nth-child(2):before {
    left: -17px;
    width: 100vw;
  }
  .section.section-projects .wrap .block .column:nth-child(3) {
    margin-top: 160px;
  }
  .section.section-projects .wrap .block .column:nth-child(3):before {
    left: -17px;
    width: 100vw;
  }
}
.section.section-news {
  position: relative;
  overflow: hidden;
}
.section.section-news .heading .link {
  display: flex;
}
.section.section-news .heading .link a {
  margin-right: 10px;
}
@media only screen and (min-width: 768px) {
  .section.section-news .heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .section.section-news .heading h1, .section.section-news .heading h2 {
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-news .heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
.section.section-news h2 {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-news h2 {
    font-size: 45px;
  }
}
.section.section-news .list {
  font-weight: 400;
  margin-top: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-news .list {
    border-bottom: 1px solid #000;
    margin-top: 60px;
  }
}
.section.section-news .list a {
  color: #000;
}
.section.section-news .list a:hover {
  color: #7f7f7f;
}
.section.section-news .list .item {
  position: relative;
  overflow: hidden;
  margin-bottom: 50px;
  font-size: 14px;
  color: #000;
  display: block;
  cursor: pointer;
}
.section.section-news .list .item .date, .section.section-news .list .item .body, .section.section-news .list .item .more {
  width: 100%;
}
.section.section-news .list .item .date {
  align-self: flex-start;
  margin-bottom: 5px;
}
.section.section-news .list .item .more {
  margin-bottom: 0;
  align-self: flex-end;
  font-weight: 700;
}
.section.section-news .list .item .body {
  margin-bottom: 30px;
}
.section.section-news .list .item .body h3 {
  font-weight: 700;
  font-size: 14px;
}
@media only screen and (min-width: 992px) {
  .section.section-news .list .item .body h3 {
    font-size: 21px;
    margin-bottom: 40px;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-news .list .item .body {
    margin-bottom: 0;
  }
}
.section.section-news .list .item .body p {
  display: none;
  font-weight: 300;
}
@media only screen and (min-width: 992px) {
  .section.section-news .list .item .body p {
    display: block;
    font-size: 16.5px;
    max-width: 520px;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-news .list .item {
    margin-bottom: 0;
    font-size: 21px;
  }
  .section.section-news .list .item:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: #939090;
    z-index: 2;
    opacity: 0;
  }
  .section.section-news .list .item:hover:after {
    opacity: 0.5;
  }
  .section.section-news .list .item .container {
    display: flex;
    min-height: 420px;
  }
  .section.section-news .list .item .container .column {
    width: calc(100% - 420px);
  }
  .section.section-news .list .item .container .column:first-child {
    width: 440px;
  }
  .section.section-news .list .item .container .column:last-child {
    display: flex;
    flex-wrap: wrap;
    padding: 20px;
    max-width: 620px;
    margin: 0 auto;
  }
  .section.section-news .list .item:nth-child(2n) .container {
    flex-direction: row-reverse;
  }
}
.section.section-news .list .item:hover .image img {
  opacity: 0.5;
}
.section.section-news .list .item .image {
  margin-bottom: 20px;
  width: 85%;
  height: 68vw;
  background: #000;
  position: relative;
  overflow: hidden;
  display: block;
}
@media only screen and (min-width: 992px) {
  .section.section-news .list .item .image {
    width: 100%;
    height: 100%;
    margin-bottom: 0;
  }
}
.section.section-news .list .item .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media only screen and (min-width: 992px) {
  .section.section-news .list .item .image img {
    position: absolute;
    left: 0;
    top: 0;
  }
}
.section.section-news .list .item:before {
  width: calc(100% + 20px);
  content: "";
  left: 20px;
  top: 0;
  position: absolute;
  background: #000;
  height: 1px;
}
@media only screen and (min-width: 992px) {
  .section.section-news .list .item:before {
    left: 0%;
    width: 100%;
  }
}
.section.section-testimonials {
  position: relative;
  overflow: hidden;
}
.section.section-testimonials .slider {
  position: relative;
  overflow: hidden;
  padding-bottom: 50px;
  font-size: 18px;
}
.section.section-testimonials .slider .content {
  opacity: 0;
  transform: translateY(40px);
}
.section.section-testimonials .slider .slick-active .content {
  opacity: 1;
  transform: none;
}
@media only screen and (min-width: 992px) {
  .section.section-testimonials .slider {
    font-size: 33px;
    width: 50%;
    padding-bottom: 40px;
  }
}
.section.section-testimonials .author {
  padding-bottom: 65px;
  position: relative;
}
.section.section-testimonials .author:before {
  width: 150vw;
  content: "";
  left: -50vw;
  position: absolute;
  bottom: 66px;
  background: #000;
  height: 1px;
}
@media only screen and (min-width: 992px) {
  .section.section-testimonials .author:before {
    bottom: 80px;
  }
}
.section.section-testimonials .author .content {
  padding-bottom: 20px;
  font-size: 14px;
}
.section.section-testimonials .author .content p {
  margin-bottom: 0;
}
@media only screen and (min-width: 992px) {
  .section.section-testimonials .author {
    padding-top: 30px;
    padding-bottom: 0;
  }
  .section.section-testimonials .author .content {
    width: 50%;
    margin-right: 0;
    margin-left: auto;
    font-size: 21px;
    padding-bottom: 0;
  }
}
.section.section-testimonials .author .slick-arrow {
  position: absolute;
  bottom: 0;
  border: 0;
  font-size: 0;
  width: 24px;
  height: 36px;
  background: url(../images/arrow_left.svg) center no-repeat;
  background-size: contain;
  outline: 0;
}
.section.section-testimonials .author .slick-arrow:hover {
  opacity: 0.5;
}
@media only screen and (min-width: 992px) {
  .section.section-testimonials .author .slick-arrow {
    width: 30px;
    height: 48px;
  }
}
.section.section-testimonials .author .slick-arrow.slick-prev {
  left: 0px;
}
.section.section-testimonials .author .slick-arrow.slick-next {
  left: 40px;
  transform: scaleX(-1);
}
@media only screen and (min-width: 992px) {
  .section.section-testimonials .author .slick-arrow.slick-next {
    left: 60px;
  }
}
.section.section-about {
  position: relative;
  overflow: hidden;
}
.section.section-about .heading .link {
  display: flex;
}
.section.section-about .heading .link a {
  margin-right: 10px;
}
@media only screen and (min-width: 768px) {
  .section.section-about .heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .section.section-about .heading h1, .section.section-about .heading h2 {
    margin-bottom: 0;
  }
}
.section.section-about h1 {
  margin-bottom: 20px;
  font-size: 36px;
  font-weight: 700;
}
@media only screen and (min-width: 992px) {
  .section.section-about h1 {
    font-size: 60px;
  }
}
.section.section-about .wrap {
  margin-top: 40px;
  border-top: 1px solid #000;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap {
    margin-top: 50px;
  }
}
.section.section-about .wrap .intro h3 {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
  margin-bottom: 20px;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .intro h3 {
    font-size: 45px;
  }
}
.section.section-about .wrap .intro h4 {
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 300;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .intro h4 {
    font-size: 27px;
  }
}
.section.section-about .wrap .intro .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .intro {
    display: flex;
    justify-content: space-between;
  }
}
.section.section-about .wrap .intro .column:first-child {
  padding: 40px 0 30px;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .intro .column:first-child {
    padding: 50px 0 0;
    width: 40%;
    max-width: 420px;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .intro .column {
    width: 55.2%;
  }
}
.section.section-about .wrap .vision {
  margin-top: 70px;
}
.section.section-about .wrap .vision h3 {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .vision h3 {
    font-size: 45px;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .vision {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-top: 150px;
  }
  .section.section-about .wrap .vision h3 {
    margin-bottom: 0;
  }
  .section.section-about .wrap .vision p:last-child {
    margin-bottom: 0;
  }
}
.section.section-about .wrap .vision .column {
  font-size: 18px;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .vision .column:first-child {
    width: 40%;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .vision .column {
    width: 55.2%;
    font-size: 33px;
    line-height: 1.2;
  }
}
.section.section-about .wrap .mission {
  margin-top: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .mission {
    margin-top: 80px;
  }
}
.section.section-about .wrap .mission h3 {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
  margin-bottom: 20px;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .mission h3 {
    font-size: 45px;
  }
}
.section.section-about .wrap .mission h4 {
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 300;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .mission h4 {
    font-size: 27px;
  }
}
.section.section-about .wrap .mission ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.section.section-about .wrap .mission ul li {
  padding: 15px 0;
  border-bottom: 1px solid #000;
}
.section.section-about .wrap .mission ul li:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .mission ul li {
    font-size: 21px;
    padding: 30px 0;
  }
  .section.section-about .wrap .mission ul li:first-child {
    padding-top: 0;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .mission {
    display: flex;
    justify-content: space-between;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .mission .column:first-child {
    width: 40%;
    max-width: 420px;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .mission .column {
    width: 55.2%;
  }
}
.section.section-about .wrap .text-wrap {
  font-size: 24px;
  padding: 40px 0 0;
}
@media only screen and (min-width: 992px) {
  .section.section-about .wrap .text-wrap {
    font-size: 33px;
    line-height: 1.2;
    padding: 50px 0;
    max-width: 98%;
  }
}
.section.section-about .list {
  font-weight: 400;
  margin-top: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-about .list {
    border-bottom: 1px solid #000;
    margin-top: 60px;
  }
}
.section.section-about .list .item {
  position: relative;
  overflow: hidden;
  margin-bottom: 50px;
  font-size: 14px;
  color: #000;
  display: block;
}
.section.section-about .list .item .body {
  width: 100%;
}
.section.section-about .list .item .body h3 {
  font-weight: 700;
  font-size: 16.5px;
}
@media only screen and (min-width: 992px) {
  .section.section-about .list .item .body h3 {
    font-size: 21px;
    margin-bottom: 40px;
  }
}
.section.section-about .list .item .body .link {
  margin-top: 30px;
}
.section.section-about .list .item .body p {
  font-weight: 300;
}
@media only screen and (min-width: 992px) {
  .section.section-about .list .item .body p {
    display: block;
    font-size: 16.5px;
    max-width: 520px;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-about .list .item {
    margin-bottom: 0;
    font-size: 21px;
  }
  .section.section-about .list .item .container {
    display: flex;
    min-height: 420px;
    align-items: center;
  }
  .section.section-about .list .item .container .column {
    width: calc(100% - 420px);
  }
  .section.section-about .list .item .container .column:first-child {
    width: 440px;
  }
  .section.section-about .list .item .container .column:last-child {
    padding: 20px;
    max-width: 620px;
    margin: 0 auto;
    align-self: center;
  }
  .section.section-about .list .item:nth-child(2n) .container {
    flex-direction: row-reverse;
  }
}
.section.section-about .list .item .image {
  margin-bottom: 20px;
  width: 85%;
  height: 68vw;
  background: #000;
  position: relative;
  overflow: hidden;
  display: block;
}
@media only screen and (min-width: 992px) {
  .section.section-about .list .item .image {
    width: 100%;
    height: 100%;
    margin-bottom: 0;
  }
}
.section.section-about .list .item .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.section.section-about .list .item:before {
  width: calc(100% + 20px);
  content: "";
  left: 20px;
  top: 0;
  position: absolute;
  background: #000;
  height: 1px;
  z-index: 1;
}
@media only screen and (min-width: 992px) {
  .section.section-about .list .item:before {
    left: 0%;
    width: 100%;
  }
}
.section.section-about .team {
  font-weight: 400;
  margin-top: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-about .team {
    border-bottom: 1px solid #000;
    margin-top: 60px;
  }
}
.section.section-about .team .item {
  position: relative;
  overflow: hidden;
  margin-bottom: 50px;
  font-size: 14px;
  color: #000;
  display: block;
}
.section.section-about .team .item .body {
  width: 100%;
}
.section.section-about .team .item .body h3 {
  font-weight: 300;
  font-size: 16.5px;
}
@media only screen and (min-width: 992px) {
  .section.section-about .team .item .body h3 {
    font-size: 21px;
    margin-bottom: 40px;
  }
}
.section.section-about .team .item .body .hidden {
  display: none;
}
.section.section-about .team .item .body .more {
  margin-top: 30px;
  font-weight: 700;
  color: #000;
  display: inline-block;
}
.section.section-about .team .item .body .more:hover {
  color: #7f7f7f;
}
@media only screen and (min-width: 992px) {
  .section.section-about .team .item .body .more {
    font-size: 21px;
  }
}
.section.section-about .team .item .body p {
  font-weight: 300;
}
@media only screen and (min-width: 992px) {
  .section.section-about .team .item .body p {
    display: block;
    font-size: 16.5px;
    max-width: 520px;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-about .team .item {
    margin-bottom: 0;
    font-size: 21px;
  }
  .section.section-about .team .item .container {
    display: flex;
    min-height: 420px;
  }
  .section.section-about .team .item .container .column {
    width: calc(100% - 420px);
  }
  .section.section-about .team .item .container .column:first-child {
    width: 440px;
  }
  .section.section-about .team .item .container .column:last-child {
    padding: 20px;
    max-width: 620px;
    margin: 0 auto;
    align-self: center;
  }
  .section.section-about .team .item:nth-child(2n) .container {
    flex-direction: row-reverse;
  }
}
.section.section-about .team .item .image {
  margin-bottom: 20px;
  width: 85%;
  height: 68vw;
  background: #000;
  position: relative;
  overflow: hidden;
  display: block;
}
@media only screen and (min-width: 992px) {
  .section.section-about .team .item .image {
    width: 100%;
    height: 100%;
    margin-bottom: 0;
    max-height: 420px;
  }
}
.section.section-about .team .item .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}
.section.section-about .team .item:before {
  width: calc(100% + 20px);
  content: "";
  left: 20px;
  top: 0;
  position: absolute;
  background: #000;
  height: 1px;
  z-index: 1;
}
@media only screen and (min-width: 992px) {
  .section.section-about .team .item:before {
    left: 0%;
    width: 100%;
  }
}
.section.section-values {
  background: #EDE4D6;
}
.section.section-values h2 {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-values h2 {
    font-size: 45px;
  }
}
.section.section-values .heading {
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  font-size: 24px;
  padding: 30px 0;
}
.section.section-values .heading p:last-child {
  margin-bottom: 0;
}
@media only screen and (min-width: 992px) {
  .section.section-values .heading {
    font-size: 33px;
    line-height: 1.2;
    padding: 50px 0;
  }
}
.section.section-values .list .item {
  padding: 50px 0;
  border-bottom: 1px solid #000;
}
.section.section-values .list .item .container {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.section.section-values .list .item .container .icon {
  width: 50px;
  height: 50px;
}
@media only screen and (min-width: 992px) {
  .section.section-values .list .item .container .icon {
    width: 100px;
    height: 100px;
  }
}
.section.section-values .list .item .container .icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.section.section-values .list .item .container h3 {
  width: calc(100% - 50px);
  padding-left: 20px;
  font-weight: 700;
  font-size: 24px;
}
@media only screen and (min-width: 992px) {
  .section.section-values .list .item .container h3 {
    font-size: 33px;
    width: 330px;
    padding-left: 40px;
  }
}
.section.section-values .list .item .container .text {
  margin-top: 20px;
}
.section.section-values .list .item .container .text p:last-child {
  margin-bottom: 0;
}
@media only screen and (min-width: 992px) {
  .section.section-values .list .item .container .text {
    width: calc(100% - 430px);
    margin-top: 0;
    padding-left: 20px;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-values .list .item {
    padding: 25px 0;
  }
}
.section.section-news-list {
  position: relative;
  overflow: hidden;
}
.section.section-news-list h1 {
  margin-bottom: 20px;
  font-size: 36px;
  font-weight: 700;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list h1 {
    font-size: 60px;
  }
}
.section.section-news-list .heading .link {
  display: flex;
}
.section.section-news-list .heading .link a {
  margin-right: 10px;
}
@media only screen and (min-width: 768px) {
  .section.section-news-list .heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .section.section-news-list .heading h1, .section.section-news-list .heading h2 {
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
.section.section-news-list .wrap {
  position: relative;
}
.section.section-news-list .container {
  margin-bottom: -50px;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .container {
    margin-bottom: -110px;
  }
}
.section.section-news-list .list {
  margin-top: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .list {
    margin-top: 60px;
    display: flex;
    flex-wrap: wrap;
    margin-left: -12px;
    margin-right: -12px;
  }
}
.section.section-news-list .list .item {
  margin-bottom: 50px;
  font-size: 14px;
  color: #000;
  display: block;
  position: relative;
}
.section.section-news-list .list .item:hover {
  color: #7f7f7f;
}
.section.section-news-list .list .item:hover .image img {
  opacity: 0.5;
}
.section.section-news-list .list .item h2 {
  font-weight: 700;
  font-size: 16.5px;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .list .item h2 {
    font-size: 21px;
    margin-bottom: 20px;
  }
}
.section.section-news-list .list .item .date {
  font-weight: 400;
}
.section.section-news-list .list .item .date, .section.section-news-list .list .item .more {
  font-size: 16.5px;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .list .item .date, .section.section-news-list .list .item .more {
    font-size: 21px;
  }
}
.section.section-news-list .list .item .more {
  font-weight: 700;
}
.section.section-news-list .list .item .image {
  margin-bottom: 20px;
  width: 85%;
  height: 55vw;
  background: #000;
  position: relative;
  overflow: hidden;
  display: block;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .list .item .image {
    width: 100%;
    height: 309px;
  }
}
.section.section-news-list .list .item .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.section.section-news-list .list .item:before {
  width: calc(100% + 20px);
  content: "";
  left: 0px;
  top: 0;
  position: absolute;
  background: #000;
  height: 1px;
  z-index: 1;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .list .item:before {
    display: none;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .list .item {
    margin-bottom: 110px;
    font-size: 16.5px;
    width: 33.33%;
    padding: 0 12px;
  }
  .section.section-news-list .list .item:nth-child(3n+1):before {
    display: block;
    width: 150vw;
    left: -50vw;
    z-index: 2;
  }
}
.section.section-news-list .article {
  border-top: 1px solid #000;
  margin-top: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .article {
    margin-top: 50px;
  }
}
.section.section-news-list .article .container {
  max-width: 850px;
}
.section.section-news-list .article .date {
  font-weight: 400;
  margin-bottom: 30px;
}
.section.section-news-list .article h2 {
  font-weight: 800;
  font-size: 22px;
  line-height: 1.1;
  margin-top: 30px;
  margin-bottom: 20px;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .article h2 {
    font-size: 28px;
    margin-top: 40px;
  }
}
.section.section-news-list .article h3, .section.section-news-list .article h4, .section.section-news-list .article h5 {
  font-weight: 800;
  margin-bottom: 20px;
  margin-top: 30px;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .article h3, .section.section-news-list .article h4, .section.section-news-list .article h5 {
    margin-top: 40px;
  }
}
.section.section-news-list .article ul, .section.section-news-list .article ol {
  margin-left: -24px;
}
.section.section-news-list .article p a {
  color: #000;
  text-decoration: underline;
}
.section.section-news-list .article p a:hover {
  color: #7f7f7f;
}
.section.section-news-list .article .featured {
  margin-bottom: 15px;
}
@media only screen and (min-width: 992px) {
  .section.section-news-list .article .featured {
    margin-bottom: 30px;
  }
}
.section.section-news-list .article .featured img {
  width: 100%;
}
.section.section-news-list .article .wp-block-image {
  margin: 20px 0;
}
@media only screen and (min-width: 768px) {
  .section.section-news-list .article .wp-block-image {
    margin: 30px 0;
  }
}
.section.section-news-list .article .wp-block-image img {
  width: 100%;
}
.section.section-news-list .article .wp-block-embed {
  margin: 20px 0;
}
@media only screen and (min-width: 768px) {
  .section.section-news-list .article .wp-block-embed {
    margin: 30px 0;
  }
}
.section.section-news-list .article .wp-block-embed .wp-block-embed__wrapper {
  overflow: hidden;
  padding-top: 56.25%;
  position: relative;
}
.section.section-news-list .article .wp-block-embed iframe {
  border: 0;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.section.section-news-list .navi {
  list-style: none;
  margin: 20px 0 0;
  padding: 0;
  display: flex;
  justify-content: space-between;
}
.section.section-news-list .navi li {
  width: 33.33%;
}
.section.section-news-list .navi li:nth-child(2) {
  text-align: center;
}
.section.section-news-list .navi li:nth-child(3) {
  text-align: right;
}
.section.section-news-list .navi li.prev a {
  position: relative;
  padding-left: 25px;
}
.section.section-news-list .navi li.prev a:after {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  margin-top: -7px;
  width: 20px;
  height: 16px;
  background: url("../images/arrow_left.svg") center no-repeat;
  background-size: contain;
}
.section.section-news-list .navi li.next a {
  position: relative;
  padding-right: 25px;
}
.section.section-news-list .navi li.next a:after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  margin-top: -7px;
  width: 20px;
  height: 16px;
  background: url("../images/arrow_left.svg") center no-repeat;
  background-size: contain;
  transform: scaleX(-1);
}
@media only screen and (min-width: 768px) {
  .section.section-news-list .navi {
    margin-top: 40px;
  }
}
.section.section-news-list .navi a {
  color: #000;
}
.section.section-news-list .navi a:hover {
  color: #7f7f7f;
}
.section.section-contact {
  position: relative;
  overflow: hidden;
}
.section.section-contact .heading .link {
  display: flex;
}
.section.section-contact .heading .link a {
  margin-right: 10px;
}
@media only screen and (min-width: 768px) {
  .section.section-contact .heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .section.section-contact .heading h1, .section.section-contact .heading h2 {
    margin-bottom: 0;
  }
}
.section.section-contact h1 {
  margin-bottom: 20px;
  font-size: 36px;
  font-weight: 700;
}
@media only screen and (min-width: 992px) {
  .section.section-contact h1 {
    font-size: 60px;
  }
}
.section.section-contact .wrap {
  margin-top: 40px;
  border-top: 1px solid #000;
}
@media only screen and (min-width: 992px) {
  .section.section-contact .wrap {
    margin-top: 50px;
  }
}
.section.section-contact .wrap .intro h3 {
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 300;
}
@media only screen and (min-width: 992px) {
  .section.section-contact .wrap .intro h3 {
    font-size: 27px;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-contact .wrap .intro h3 {
    margin-bottom: 40px;
  }
}
.section.section-contact .wrap .intro .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media only screen and (min-width: 992px) {
  .section.section-contact .wrap .intro {
    display: flex;
    justify-content: space-between;
  }
}
.section.section-contact .wrap .intro .column:first-child {
  padding: 40px 0 30px;
}
@media only screen and (min-width: 992px) {
  .section.section-contact .wrap .intro .column:first-child {
    padding: 50px 20px 0 0;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-contact .wrap .intro .column {
    width: 50%;
  }
}
.section.section-contact .form .form-control {
  font-weight: 800;
}
@media only screen and (min-width: 992px) {
  .section.section-contact .form .form-group {
    margin-bottom: 40px;
  }
}
.section.section-governance {
  background: #EDE4D6;
}
.section.section-governance h2 {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-governance h2 {
    font-size: 45px;
  }
}
.section.section-governance h3 {
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 300;
  margin-bottom: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-governance h3 {
    font-size: 27px;
  }
}
.section.section-governance .content {
  border-top: 1px solid #000;
  padding: 30px 0 0;
}
@media only screen and (min-width: 992px) {
  .section.section-governance .content {
    padding: 50px 0 0;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-governance .block {
    display: flex;
    justify-content: space-between;
  }
  .section.section-governance .block .column {
    width: 75.4%;
  }
  .section.section-governance .block .column:first-child {
    width: 24.6%;
    padding-right: 20px;
  }
}
.section.section-governance .block .items {
  margin-bottom: -40px;
}
@media only screen and (min-width: 768px) {
  .section.section-governance .block .items {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -11px -40px;
  }
}
.section.section-governance .block .items .item {
  margin-bottom: 40px;
}
.section.section-governance .block .items .item h4 {
  font-size: 18px;
}
@media only screen and (min-width: 768px) {
  .section.section-governance .block .items .item h4 {
    font-size: 21px;
  }
}
@media only screen and (min-width: 768px) {
  .section.section-governance .block .items .item {
    width: 33.33%;
    padding: 0 11px;
  }
}
.section.section-governance .block .items .item .image {
  margin-bottom: 20px;
  display: block;
}
.section.section-governance .block .items .item .image img {
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .section.section-governance .block .items .item .image {
    margin-bottom: 30px;
  }
}
.section.section-project-list {
  position: relative;
  overflow: hidden;
}
.section.section-project-list .heading .link {
  display: flex;
}
.section.section-project-list .heading .link a {
  margin-right: 10px;
}
@media only screen and (min-width: 768px) {
  .section.section-project-list .heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .section.section-project-list .heading h1, .section.section-project-list .heading h2 {
    margin-bottom: 0;
  }
}
.section.section-project-list h1 {
  margin-bottom: 20px;
  font-size: 36px;
  font-weight: 700;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list h1 {
    font-size: 60px;
  }
}
.section.section-project-list h1 span {
  font-weight: 300;
}
.section.section-project-list h2 {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
  margin-bottom: 20px;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list h2 {
    font-size: 45px;
  }
}
.section.section-project-list .wrap {
  margin-top: 40px;
  border-top: 1px solid #000;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .wrap {
    margin-top: 50px;
  }
}
.section.section-project-list .wrap .intro .acf-map {
  background: #ddd;
  height: 300px;
}
.section.section-project-list .wrap .intro .image {
  height: 300px;
}
.section.section-project-list .wrap .intro .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .wrap .intro {
    display: flex;
    justify-content: space-between;
  }
  .section.section-project-list .wrap .intro .image, .section.section-project-list .wrap .intro .acf-map {
    height: 100%;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .wrap .intro .column {
    width: calc(50% - 11px);
  }
}
.section.section-project-list .list {
  margin-top: 40px;
  margin-bottom: -50px;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .list {
    margin-top: 60px;
    display: flex;
    flex-wrap: wrap;
    margin-left: -12px;
    margin-right: -12px;
    margin-bottom: -110px;
  }
}
.section.section-project-list .list .item {
  margin-bottom: 50px;
  color: #000;
  display: block;
  position: relative;
  font-weight: 400;
}
.section.section-project-list .list .item:hover {
  color: #7f7f7f;
}
.section.section-project-list .list .item:hover .image img {
  opacity: 0.5;
}
.section.section-project-list .list .item h3 {
  font-weight: 700;
  font-size: 16.5px;
  margin-bottom: 0;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .list .item h3 {
    font-size: 21px;
  }
}
.section.section-project-list .list .item .image {
  margin-bottom: 20px;
  width: 85%;
  height: 55vw;
  background: #000;
  position: relative;
  overflow: hidden;
  display: block;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .list .item .image {
    width: 100%;
    height: 300px;
  }
}
.section.section-project-list .list .item .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.section.section-project-list .list .item:before {
  width: calc(100% + 20px);
  content: "";
  left: 0px;
  top: 0;
  position: absolute;
  background: #000;
  height: 1px;
  z-index: 1;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .list .item:before {
    display: none;
  }
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .list .item {
    margin-bottom: 110px;
    font-size: 16.5px;
    width: 33.33%;
    padding: 0 12px;
    font-size: 21px;
  }
  .section.section-project-list .list .item:nth-child(3n+1):before {
    display: block;
    width: 150vw;
    left: -50vw;
    z-index: 2;
  }
}
@media only screen and (min-width: 992px) and (min-width: 1200px) {
  .section.section-project-list .list .item {
    width: 25%;
  }
  .section.section-project-list .list .item:nth-child(3n+1):before {
    display: none;
  }
  .section.section-project-list .list .item:nth-child(4n+1):before {
    display: block;
    width: 150vw;
    left: -50vw;
    z-index: 2;
  }
}
.section.section-project-list .gallery {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.section.section-project-list .gallery a {
  display: block;
  width: calc(50% - 6px);
  margin-bottom: 12px;
  position: relative;
  overflow: hidden;
  height: 200px;
  background: #000;
}
.section.section-project-list .gallery a:hover img {
  opacity: 0.5;
}
.section.section-project-list .gallery a img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .gallery a {
    height: 495px;
    width: calc(50% - 11px);
    margin-bottom: 22px;
  }
}
.section.section-project-list .article .slider {
  font-size: 0;
  padding-bottom: 60px;
  margin-bottom: 20px;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .article .slider {
    padding-bottom: 80px;
  }
}
.section.section-project-list .article .slider .slick-arrow {
  position: absolute;
  bottom: 0;
  border: 0;
  font-size: 0;
  width: 24px;
  height: 36px;
  background: url(../images/arrow_left.svg) center no-repeat;
  background-size: contain;
  outline: 0;
}
.section.section-project-list .article .slider .slick-arrow:hover {
  opacity: 0.5;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .article .slider .slick-arrow {
    width: 30px;
    height: 48px;
  }
}
.section.section-project-list .article .slider .slick-arrow.slick-prev {
  right: 40px;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .article .slider .slick-arrow.slick-prev {
    right: 60px;
  }
}
.section.section-project-list .article .slider .slick-arrow.slick-next {
  right: 0px;
  transform: scaleX(-1);
}
.section.section-project-list .article h3 {
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 300;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .article h3 {
    font-size: 27px;
  }
}
.section.section-project-list .article .text {
  max-width: 622px;
  margin-bottom: 60px;
}
@media only screen and (min-width: 992px) {
  .section.section-project-list .article .text {
    margin-bottom: 150px;
  }
}

footer {
  position: relative;
  z-index: 1;
  padding: 40px 0;
  background: #000;
  color: #fff;
  border-top: 1px solid #fff;
}
@media only screen and (min-width: 992px) {
  footer {
    padding: 75px 0;
  }
}
footer .block {
  margin-bottom: 40px;
}
@media only screen and (min-width: 992px) {
  footer .block {
    margin-bottom: 140px;
  }
}
footer .block .img img {
  width: 100%;
  max-width: 468px;
}
@media only screen and (min-width: 992px) {
  footer .block .img {
    text-align: right;
  }
}
footer .block .footer-logo {
  display: flex;
  margin: 0 -10px;
}
@media only screen and (min-width: 992px) {
  footer .block .footer-logo {
    margin: 0 -20px;
  }
}
footer .block .footer-logo a {
  display: block;
  padding: 0 10px;
}
footer .block .footer-logo a:hover {
  opacity: 0.8;
}
@media only screen and (min-width: 992px) {
  footer .block .footer-logo a {
    padding: 0 20px;
  }
}
footer .block .footer-logo img {
  max-height: 70px;
}
@media only screen and (min-width: 992px) {
  footer .block .footer-logo img {
    max-height: 90px;
  }
}
footer .block p {
  font-weight: 300;
  font-size: 16px;
}
footer .block .item {
  margin-bottom: 40px;
}
footer .block ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
footer .block ul li {
  margin-bottom: 10px;
}
footer .block ul li a {
  color: #fff;
}
footer .block ul li a:hover {
  color: #939190;
}
footer .block ul.social {
  margin-top: 20px;
}
footer .block ul.social img {
  width: 30px;
}
@media only screen and (min-width: 992px) {
  footer .block .column:first-child {
    display: flex;
    justify-content: space-between;
  }
  footer .block .column:first-child .item {
    width: 35%;
    margin-bottom: 0;
  }
  footer .block .column:first-child .item:first-child {
    width: 23%;
  }
}
@media only screen and (min-width: 992px) {
  footer .block {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  footer .block .column:first-child {
    width: 55%;
    max-width: 680px;
  }
  footer .block .column:last-child {
    width: 40%;
    max-width: 468px;
  }
}
footer .bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
footer .bottom p {
  margin-bottom: 0;
  font-weight: 700;
  line-height: 1.1;
  font-size: 22px;
  text-align: left;
}
@media only screen and (min-width: 992px) {
  footer .bottom p {
    font-size: 45px;
    line-height: 1;
  }
}
footer .bottom .logo img {
  width: 100%;
  max-width: 73px;
}
@media only screen and (min-width: 992px) {
  footer .bottom .logo img {
    max-width: 118px;
  }
}

@keyframes float {
  0% {
    transform: translatey(0px);
  }
  50% {
    transform: translatey(-20px);
  }
  100% {
    transform: translatey(0px);
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.wpcf7-not-valid-tip {
  font-size: 14px !important;
  margin-top: 5px;
  text-align: center;
}

.wpcf7-spinner {
  background-color: #7f7f7f !important;
  position: absolute !important;
  right: 0;
  top: 10px;
}
@media only screen and (min-width: 992px) {
  .wpcf7-spinner {
    top: 15px;
  }
}

.wpcf7 form .wpcf7-response-output {
  padding: 0 !important;
  border: 0 !important;
  text-align: center;
  font-weight: 600;
}

.grecaptcha-badge {
  display: none !important;
}

.infomarker {
  display: flex;
  align-items: center;
  width: 150px;
}
.infomarker .marker-img {
  display: block;
  width: 50px;
  height: 50px;
}
.infomarker .marker-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.infomarker p {
  margin-bottom: 0;
  width: calc(100% - 50px);
  padding-left: 10px;
}

.gm-ui-hover-effect {
  width: 30px !important;
  height: 30px !important;
}

.gm-ui-hover-effect > span {
  width: 20px !important;
  height: 20px !important;
  margin: 5px !important;
}

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