@font-face {
  font-family: "Helvetica Neue";
  src: url("../fonts/HelveticaNeue-Bold.otf") format("woff");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "Helvetica Neue";
  src: url("../fonts/HelveticaNeue-Roman.otf") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Helvetica Neue";
  src: url("../fonts/HelveticaNeue-Light.otf") format("woff");
  font-weight: light;
}
@font-face {
  font-family: "Helvetica Neue";
  src: url("../fonts/HelveticaNeue-Medium.otf") format("woff");
  font-weight: medium;
}
* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
  color: #000;
  font-family: "Helvetica Neue";
}

a {
  text-decoration: none;
  color: inherit;
}

ul {
  list-style: none;
}

body {
  background-color: #f7f5ed;
}

.container {
  max-width: 1440px;
  margin: 0 auto;
  width: 100%;
}

header {
  max-width: 1270px;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  padding: 0 20px 0;
  position: relative;
  top: 32px;
  z-index: 3;
  --h-clr: #fff;
}
header .logo svg {
  width: 398px;
  opacity: 1;
  transition: 0.5s ease-in-out;
}
header .logo svg {
  position: absolute;
  z-index: 10;
}
body.hide_logo header .logo svg {
  opacity: 0;
}
header .logo svg * {
  transition: 0.5s ease-in-out;
  fill: var(--h-clr);
}
header .menu_icon {
  width: 55px;
  height: 35px;
  cursor: pointer;
  position: relative;
  top: 35px;
}
header .menu_icon::after,
header .menu_icon::before {
  content: "";
  position: absolute;
  height: 2px;
  width: 100%;
  background-color: var(--h-clr);
  transition: 0.5s ease-in-out;
}
header .menu_icon::after {
  top: 10px;
}
header .menu_icon::before {
  bottom: 10px;
}
header .menu_icon:hover::after {
  transform: translateY(3px);
}
header .menu_icon:hover::before {
  transform: translateY(-3px);
}
header .nav_right {
  width: 100%;
  max-width: 1229px;
  display: flex;
  gap: 77px;
  position: fixed;
  justify-content: flex-end;
  z-index: 0;
}
header .nav_right ul {
  display: flex;
  flex-direction: column;
  gap: 10px;
  opacity: 0;
  transform: translate(0px, -200px);
}
header .nav_right a {
  font-size: 14px;
  font-weight: 500;
  line-height: 17.09px;
  color: var(--h-clr);
  --cta-clr: var(--h-clr);
  text-transform: uppercase;
  padding-top: 3px;
}

.flip_text {
  /* 	--cta-clr: #e2e7ea; */
  transition: 0.5s ease-in-out;
  text-shadow: 0px 0px 0px var(--cta-clr, #fff),
    0px var(--cta-offset, 23px) 0px var(--cta-clr, #fff);
  overflow: hidden;
  color: transparent !important;
  position: relative;
  width: -moz-max-content;
  width: max-content;
  padding-bottom: 3px;
  text-decoration: none !important;
  display: inline-flex;
}

.flip_text:hover {
  text-shadow: 0px var(--cta-offset-hover, -23px) 0px var(--cta-clr, #fff),
    0px 0px 0px var(--cta-clr, #fff);
}

.menu {
  position: fixed;
  width: 100vw;
  height: 100vh;
  left: 0;
  top: -80vh;
  z-index: 1;
  background-color: #f7f5ed;
  padding-top: 20.1vh;
  padding-bottom: 70px;
}
.menu .menu_inner {
  max-width: 2160px;
  margin: 0 auto;
}
.menu .menu_inner .menu_mobile {
  display: none;

  flex-direction: row;
  margin-bottom: 20px;
  justify-content: center;
  flex-wrap: wrap;
  gap: 30px;
}

.menu .menu_inner .menu_mobile li {
  transform: translateY(-15px);
  opacity: 0;
}

.menu .img {
  height: 36.73vh;
  display: flex;
  justify-content: center;
  opacity: 0;
  transform: translateY(15px);
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
  clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
}
.menu .img img {
  width: 100%;
  object-fit: cover;
}
.menu .menu_midd {
  display: flex;
  justify-content: flex-end;
  margin-top: 5.51vh;
  padding: 0 170px 0 95px;
}
.menu ul {
  display: flex;
  flex-direction: column;
  gap: 13px;
}
.menu ul:not(.menu_mobile) li:first-of-type {
  opacity: 0;
  transform: translateY(25px);
}
.menu ul:not(.menu_mobile) li:nth-child(2) {
  opacity: 0;
  transform: translateY(35px);
}
.menu ul:not(.menu_mobile) li:nth-child(3) {
  opacity: 0;
  transform: translateY(45px);
}
.menu ul a {
  font-size: 14px;
  font-weight: 500;
  line-height: 17.09px;
  color: #000;
  text-transform: uppercase;
  --cta-clr: #000;
}
.menu .menu_b {
  display: flex;
  justify-content: space-between;
  margin-top: 9.9vh;
  padding: 0 70px 0 95px;
  align-items: flex-end;
}
.menu .menu_b p {
  opacity: 0;
  transform: translateY(95px);
  font-size: 22px;
  font-weight: 400;
  line-height: 31px;
  color: #000;
  max-width: 606px;
  width: 100%;
}
.menu .menu_b li {
  text-align: left;
}

main:not(#home_page) header {
  --h-clr: #000;
}

footer {
  padding: 14px 23px;
  display: flex;
  justify-content: space-between;
}
footer * {
  font-size: 14px;
  font-weight: 400;
  line-height: 24px;
}

#projects_page header,
#projects_page .projects_grid {
  opacity: 0;
  visibility: hidden;
  transition: 1s;
}

#projects_page.animation_done header,
#projects_page.animation_done .projects_grid {
  opacity: 1;
  visibility: visible;
}

#projects_page #lottie-container {
  transition: 0.7s;
}

#projects_page.animation_done #lottie-container {
  opacity: 0;
  visibility: hidden;
}

#home_page {
  height: 100vh;
  width: 100vw;
  overflow: hidden;
}
#home_page .images_slide {
  width: 100%;
  height: 100%;
  z-index: 2;
  position: relative;
}
#home_page .images_slide .splide__track,
#home_page .images_slide .gallery_splide,
#home_page .images_slide .splide__list {
  height: 100%;
}

#home_page .images_slide .slide_inner .video-background {
  position: absolute;
  width: 100vw;
  height: 100vh;
}
.page-template-home {
  overflow: hidden !important;
}
#home_page .images_slide .slide_inner .video-background video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#home_page .images_slide .slide_inner,
#home_page .images_slide .img {
  width: 100%;
  height: 100%;
}
#home_page .images_slide .img {
  display: flex;
  align-items: flex-end;
  background-color: #e8e2da;
}
#home_page .images_slide img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  mix-blend-mode: multiply;
}

body {
  overflow-x: hidden;
}

#projects_page {
  background-color: #f7f5ed;
}
#projects_page .menu {
  z-index: 3;
}
#projects_page header {
  z-index: 4;
}
#projects_page .projects_wrapper {
  height: 100%;
  z-index: 2;
  position: relative;
  max-width: 1230px;
  width: 100%;
  margin: 0 auto;
  padding-top: 212px;
}
#projects_page .gallery_splide {
  display: none;
}
#projects_page .projects_grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  position: relative;
}
#projects_page .projects_grid .project_block {
  position: relative;
  isolation: isolate;
}
#projects_page .projects_grid .project_block .p_side {
  width: 100%;
  height: 100%;
  background-color: #f7f5ed;
}
#projects_page .projects_grid .project_block .p_side img {
  width: 100%;
  height: 100%;
  /*-o-object-fit: cover;
     object-fit: cover;*/
  mix-blend-mode: multiply;
}
#projects_page .projects_grid .project_block .back_side {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  opacity: 0;
  transition: 0.5s ease-in-out;
}
#projects_page .projects_grid .project_block .p_name {
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  bottom: 18px;
  text-align: left;
  font-size: 16px;
  font-weight: 500;
  line-height: 24.2px;
  text-transform: uppercase;
  padding: 0 15px;
}
#projects_page .projects_grid .project_block:hover .back_side {
  opacity: 1;
}

#project_page {
  background-color: #f7f5ed;
  --project-clr: #3596be;
}
#project_page .menu {
  z-index: 3;
  top: -100vh;
}
#project_page header {
  z-index: 4;
}
#project_page header .logo svg * {
  transition: 0.9s ease-in-out;
  fill: var(--project-clr);
}
#project_page .main_img {
  height: 982px;
  z-index: 2;
  position: relative;
  height: 100vh;
  margin-top: 0;
  width: 0px;
  overflow: hidden;
  margin-right: auto;
  display: none;
}
#project_page .main_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  transform: scale(1) translateX(-50px);
  transform-origin: left;
}
#project_page .p_details {
  margin-top: 253px;
  position: relative;
  display: flex;
  gap: 52px;
  padding-left: 95px;
  padding-right: 24px;
  opacity: 0;
  transform: translateY(-100px);
}
#project_page .p_details .details_info {
  width: 300px;
  max-width: 100%;
  height: max-content;
  position: sticky;
  top: 70px;
}
#project_page .p_details .details_info .p_name {
  color: var(--project-clr);
  font-size: 26px;
  font-weight: 500;
  line-height: 31.75px;
}
#project_page .p_details .details_info ul {
  margin-top: 20px;
}
#project_page .p_details .details_info ul li {
  font-size: 14px;
  font-weight: 400;
  line-height: 16.7px;
  color: rgba(0, 0, 0, 0.5019607843);
}
#project_page .p_details .details_info p {
  font-size: 14px;
  font-weight: 400;
  line-height: 24px;
  color: #000;
  margin-top: 750px;
  position: sticky;
  top: 180px;
  width: 100%;
  max-width: 320px;
}
#project_page .p_details .more_images {
  max-width: 790px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 100px;
  flex-grow: 1;
}
#project_page .p_details .more_images .img {
  height: 80vh;
  max-width: 100%;
  width: 100%;
  background-color: #f7f5ed;
  display: flex;
}
#project_page .p_details .more_images .img:first-child img {
  object-position: top;
}
#project_page .p_details .more_images .img img {
  max-width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  mix-blend-mode: multiply;
  margin: 0 auto;
}
#project_page .p_details .controllers {
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 5.091649694501018vh, 50px);
  position: sticky;
  top: 28.98vh;
  height: -moz-max-content;
  height: max-content;
}
#project_page .p_details .controllers .ctrl {
  padding: 2px 0;
  cursor: pointer;
}
#project_page .p_details .controllers .ctrl .inner {
  width: 46px;
  height: 2px;
  background-color: rgba(0, 0, 0, 0.2509803922);
}
#project_page .p_details .controllers .ctrl.active .inner {
  background-color: var(--project-clr);
}
#project_page .next_p_wrapper {
  margin-top: 92px;
  display: block;
  overflow: hidden;
  position: relative;
  isolation: isolate;
  background-size: cover;
  background-position: center;
}
#project_page .next_p_wrapper .next_project {
  padding-top: 93px;
  padding-left: 95px;
  padding-bottom: 104px;
}
#project_page .next_p_wrapper::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background: rgba(0, 0, 0, 0.2);
  pointer-events: none;
  mix-blend-mode: multiply;
}
#project_page .next_p_wrapper span {
  font-size: 14px;
  font-weight: 400;
  line-height: 16.7px;
  color: #fff;
}
#project_page .next_p_wrapper .p_name {
  font-size: 26px;
  font-weight: 500;
  line-height: 31.75px;
  margin-top: 18px;
  color: #fff;
}
#project_page .next_p_wrapper ul {
  margin-top: 18px;
}
#project_page .next_p_wrapper ul li {
  font-size: 14px;
  font-weight: 400;
  line-height: 16.7px;
  color: #fff;
}

#about_page {
  background-color: #e8e2da;
}
#about_page .menu {
  z-index: 3;
  top: -100vh;
}
#about_page header {
  z-index: 4;
}
#about_page .main_img {
  height: 982px;
  z-index: 2;
  position: relative;
  top: -100vh;
  height: 100vh;
  margin-top: 0;
  overflow: hidden;
  margin-right: auto;
}
#about_page .main_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  transform: scale(1) translateX(-50px);
  transform-origin: left;
}
#about_page .about_body {
  position: relative;
  z-index: 2;
}
#about_page .about_details {
  background-color: #e8e2da;
  padding-top: 55px;
  padding-bottom: 318px;
}
#about_page .about_details .inner {
  width: 100%;
  max-width: calc(100% - 340px);
  margin: 0 auto;
}
#about_page .about_details h4 {
  font-size: 14px;
  font-weight: 500;
  line-height: 21px;
  color: #000;
  text-transform: uppercase;
}
#about_page .about_details h3 {
  font-size: 44px;
  font-weight: 400;
  line-height: 54px;
  width: 100%;
  max-width: 726px;
  margin-top: 24px;
}
#about_page .about_details .details_info {
  margin-top: 37px;
  display: flex;
  gap: 20px;
}
#about_page .about_details .details_info p {
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  width: 100%;
  max-width: 576px;
}
#about_page .founder_details {
  background-color: #fff;
  padding-top: 76px;
  padding-bottom: 111px;
}
#about_page .founder_details .inner {
  display: flex;
  gap: 95px;
  width: 100%;
  max-width: calc(100% - 340px);
  margin: 0 auto;
}
#about_page .founder_details .img {
  max-width: 577px;
  width: 100%;
  aspect-ratio: 577/802;
  transform: translateY(-286px);
}
#about_page .founder_details .img img {
  width: 100%;
}
#about_page .founder_details .founder {
  width: 100%;
  max-width: 502px;
}
#about_page .founder_details .founder h4 {
  font-size: 14px;
  font-weight: 500;
  line-height: 21px;
  text-transform: uppercase;
}
#about_page .founder_details .founder h3 {
  font-size: 44px;
  font-weight: 400;
  line-height: 44px;
  margin-top: 13px;
}
#about_page .founder_details .members {
  display: flex;
  flex-direction: column;
  gap: 42px;
  margin-top: 42px;
}
#about_page .founder_details .members .member .name {
  font-size: 20px;
  font-weight: 500;
  line-height: 24.42px;
}
#about_page .founder_details .members .member .status {
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
}
#about_page .founder_details .members .member .desc {
  font-size: 16px;
  font-weight: 400;
  line-height: 26px;
  margin-top: 20px;
}
#about_page .methodology {
  background-color: #e8e2da;
  display: flex;
  padding-bottom: 154px;
  padding-top: 102px;
  position: relative;
  isolation: isolate;
}
#about_page .methodology .img {
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: 46.53%;
  z-index: -1;
}
#about_page .methodology .img img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
#about_page .methodology .inner {
  width: 100%;
  max-width: 577px;
  margin-left: 170px;
}
#about_page .methodology .inner h4 {
  font-size: 14px;
  font-weight: 500;
  line-height: 21px;
  text-transform: uppercase;
}
#about_page .methodology .inner h3 {
  font-size: 44px;
  font-weight: 400;
  line-height: 44px;
  margin-top: 30px;
}
#about_page .methodology .inner .desc {
  font-size: 16px;
  font-weight: 400;
  line-height: 26px;
  margin-top: 27px;
}
#about_page .international {
  background-color: #c5b9ad;
  padding-top: 140px;
  padding-bottom: 190px;
}
#about_page .international .inner {
  display: flex;
  gap: 10px;
  justify-content: space-between;
  max-width: calc(100% - 340px);
  margin: 0 auto;
}
#about_page .international .inner .left {
  width: 100%;
  max-width: 577px;
}
#about_page .international .inner .left h4 {
  font-size: 14px;
  font-weight: 500;
  line-height: 21px;
  text-transform: uppercase;
}
#about_page .international .inner .left h3 {
  font-size: 44px;
  font-weight: 400;
  line-height: 44px;
  margin-top: 30px;
}
#about_page .international .inner .right {
  width: 100%;
  max-width: 502px;
  font-size: 16px;
  font-weight: 400;
  line-height: 26px;
  margin-top: 50px;
}
.text-container {
  overflow: hidden;
}
.char {
  display: inline-block;
  /* opacity: 0; */
  transform: translateY(100%);
}

.fade-up {
  opacity: 0;
  transform: translateY(50px);
  transition: all 1s ease-out;
}
.fade-up.show {
  opacity: 1;
  transform: translateY(0);
}

.controllers {
  position: absolute;
  bottom: 20px;
  left: 20px;
  display: flex;
  align-items: center;
}

.controllers .num {
  font-size: 16px;
  font-weight: 500;
  line-height: 19.54px;
  margin-right: 60px;
}

.controllers .project {
  font-size: 16px;
  font-weight: 500;
  line-height: 19.54px;
  margin-right: 50px;
  color: #000000;
}

@media screen and (max-height: 730px) {
  .menu .img {
    height: 28.73vh;
  }

  .menu {
    padding-top: 25.1vh;
  }

  .menu .menu_b {
    margin-top: 3.9vh;
  }

  .menu .menu_midd {
    margin-top: 5.51vh;
  }
}
