* {
  box-sizing: border-box;
  margin: 0;
  padding: 0; }

html {
  scroll-behavior: smooth; }

@font-face {
  font-family: "greycliffcf-bold";
  src: url("../fonts/greycliffcf-bold.otf"), url("../fonts/greycliffcf-bold.otf") format("opentype"); }
@font-face {
  font-family: "greycliffcf-demibold";
  src: url("../fonts/greycliffcf-demibold.otf"), url("../fonts/greycliffcf-demibold.otf") format("opentype"); }
@font-face {
  font-family: "greycliffcf-medium";
  src: url("../fonts/greycliffcf-medium.otf"), url("../fonts/greycliffcf-medium.otf") format("opentype"); }
@font-face {
  font-family: "greycliffcf-regular";
  src: url("../fonts/greycliffcf-regular.otf"), url("../fonts/greycliffcf-regular.otf") format("opentype"); }
@font-face {
  font-family: "greycliffcf-thin";
  src: url("../fonts/greycliffcf-thin.otf"), url("../fonts/greycliffcf-thin.otf") format("opentype"); }
@font-face {
  font-family: "hoefler";
  src: url("../fonts/hoefler.ttf"), url("../fonts/hoefler.ttf") format("truetype"); }
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 14px !important;
  line-height: 26px;
  margin: 0;
  color: #ffffff;
  background-color: #1a1a1a;
  font-family: "greycliffcf-regular";
  position: relative;
  background-image: url(../img/body_mask.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  height: auto; }

.navbar {
  width: 100%;
  height: 132px;
  border-bottom: 1px solid #ffffff;
  display: flex;
  align-items: center; }
  .navbar__container {
    width: 100%;
    max-width: 1693px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px; }
  .navbar__area {
    display: flex;
    align-items: center;
    justify-content: space-between; }
  .navbar__logo {
    display: flex;
    align-items: center; }
    .navbar__logo--img {
      border-right: 1px solid #f3c1c0;
      padding-right: 23px;
      margin-right: 23px; }
      .navbar__logo--img img {
        width: 144px;
        display: block; }
    .navbar__logo--text p {
      font-size: 18px;
      line-height: 20px;
      font-family: "greycliffcf-bold";
      color: #ffffff; }
  .navbar__center {
    display: flex;
    align-items: center;
    gap: 17px; }
    .navbar__center--list {
      list-style: none; }
    .navbar__center--link {
      font-size: 25px;
      line-height: 20px;
      font-family: "greycliffcf-bold";
      color: #ffffff;
      text-decoration: none;
      text-transform: uppercase; }
  .navbar__right {
    display: flex;
    align-items: center;
    gap: 30px; }
    .navbar__right--list {
      list-style: none; }
      .navbar__right--list .hamburger img {
        display: block;
        width: 53px; }
    .navbar__right--btn {
      width: 232px;
      height: 71px;
      display: flex;
      align-items: center;
      justify-content: center;
      background-color: #ffffff;
      font-size: 25px;
      line-height: 30px;
      font-family: "greycliffcf-bold";
      color: #1a1a1a;
      text-decoration: none;
      border-radius: 100px;
      -webkit-transition: ease-out 0.4s;
      -moz-transition: ease-out 0.4s;
      transition: ease-out 0.4s; }
      .navbar__right--btn:hover {
        color: #ffffff;
        box-shadow: inset 0px 100px 0px #40b49c; }

@media only screen and (min-width: 1200px) and (max-width: 1450px) {
  .navbar {
    height: 90px; }
    .navbar__container {
      max-width: 1393px; }
    .navbar__logo--img {
      padding-right: 17px;
      margin-right: 17px; }
      .navbar__logo--img img {
        width: 110px; }
    .navbar__logo--text p {
      font-size: 14px;
      line-height: 18px; }
    .navbar__center {
      gap: 17px; }
      .navbar__center--list {
        list-style: none; }
      .navbar__center--link {
        font-size: 18px;
        line-height: 20px; }
    .navbar__right {
      gap: 22px; }
      .navbar__right--list {
        list-style: none; }
        .navbar__right--list .hamburger img {
          width: 40px; }
      .navbar__right--btn {
        width: 180px;
        height: 55px;
        font-size: 18px;
        line-height: 24px; } }
@media only screen and (min-width: 750px) and (max-width: 1023px) {
  .navbar {
    height: 90px; }
    .navbar__container {
      max-width: 1393px; }
    .navbar__logo--img {
      padding-right: 17px;
      margin-right: 17px; }
      .navbar__logo--img img {
        width: 110px; }
    .navbar__logo--text p {
      font-size: 14px;
      line-height: 18px; }
    .navbar__center {
      gap: 17px; }
      .navbar__center--list {
        list-style: none; }
      .navbar__center--link {
        font-size: 18px;
        line-height: 20px; }
    .navbar__right {
      gap: 22px; }
      .navbar__right--list {
        list-style: none; }
        .navbar__right--list .hamburger img {
          width: 40px; }
      .navbar__right--btn {
        width: 180px;
        height: 55px;
        font-size: 18px;
        line-height: 24px; } }
@media screen and (max-width: 749px) {
  .navbar {
    height: 70px; }
    .navbar__container {
      max-width: 380px; }
    .navbar__logo--img {
      padding-right: 17px;
      margin-right: 17px;
      margin-top: 5px; }
      .navbar__logo--img img {
        width: 80px;
        display: block;
        margin: 0; }
    .navbar__logo--text p {
      font-size: 10px;
      line-height: 14px; }
    .navbar__center {
      display: none;
      gap: 17px; }
      .navbar__center--list {
        list-style: none; }
      .navbar__center--link {
        font-size: 18px;
        line-height: 20px; }
    .navbar__right {
      gap: 22px; }
      .navbar__right--list {
        list-style: none; }
        .navbar__right--list .hamburger img {
          width: 40px; }
      .navbar__right--btn {
        display: none;
        width: 180px;
        height: 55px;
        font-size: 18px;
        line-height: 24px; } }
.loader {
  position: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  opacity: 1;
  background-color: #000;
  z-index: 99; }

.wrapper {
  text-align: center; }
  .wrapper h1 {
    color: #000;
    font-size: 92px;
    line-height: 120px;
    text-transform: uppercase;
    font-weight: 700;
    font-family: "Josefin Sans", sans-serif;
    background: linear-gradient(to left, #fff 26%, #000 50%);
    background-size: auto auto;
    background-clip: border-box;
    background-size: 200% auto;
    text-fill-color: transparent;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: textclip 2.5s linear infinite;
    display: inline-block; }
  .wrapper img {
    margin: 0 auto;
    width: 670px; }
  .wrapper svg path {
    stroke: white;
    stroke-width: 2;
    fill: white;
    stroke-dasharray: 1113;
    stroke-dashoffset: 1115;
    animation: dash 2s linear infinite; }
@keyframes dash {
  0% {
    stroke-dashoffset: 0;
    /* works, know why */
    fill: white; }
  20% {
    stroke-dashoffset: 200;
    /* works, know why */
    fill: transparent; }
  40% {
    stroke-dashoffset: 400;
    /* works, know why */
    fill: transparent; }
  60% {
    stroke-dashoffset: 600;
    /* works, know why */
    fill: transparent; }
  80% {
    stroke-dashoffset: 800;
    /* works, know why */
    fill: transparent; }
  100% {
    stroke-dashoffset: 1115;
    /* works, know why */
    fill: white; } }
@media screen and (max-width: 749px) {
  .wrapper svg {
    width: 50%; } }
.banner {
  padding-top: 100px; }
  .banner__container {
    max-width: 1693px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 40px; }
  .banner__question {
    display: flex;
    align-items: center;
    gap: 13px; }
    .banner__question span {
      font-size: 21px;
      color: #f3c1c0;
      line-height: 25px;
      text-transform: uppercase;
      font-family: "greycliffcf-regular"; }
    .banner__question .line {
      width: 354px;
      height: 1px;
      background-color: #f3c1c0; }
  .banner__tagline {
    padding-top: 55px; }
    .banner__tagline h1 {
      font-size: 100px;
      color: #ffffff;
      line-height: 120px;
      text-transform: capitalize;
      font-family: "greycliffcf-medium"; }
  .banner__btn {
    padding-top: 73px;
    display: flex;
    align-items: center;
    gap: 23px; }
    .banner__btn--text {
      font-size: 30px;
      color: #ffffff;
      line-height: 37px;
      text-transform: capitalize;
      font-family: "greycliffcf-medium"; }
    .banner__btn--icon {
      transition: all 0.3s ease; }
      .banner__btn--icon img {
        width: 60px;
        display: block; }
    .banner__btn:hover .banner__btn--icon {
      transition: all 0.3s ease;
      padding-left: 20px; }

@media only screen and (min-width: 1200px) and (max-width: 1450px) {
  .banner {
    padding-top: 70px;
    padding-bottom: 40px; }
    .banner__container {
      max-width: 1393px; }
    .banner__question {
      display: flex;
      align-items: center;
      gap: 13px; }
      .banner__question span {
        font-size: 18px;
        line-height: 22px; }
      .banner__question .line {
        width: 290px; }
    .banner__tagline {
      padding-top: 40px; }
      .banner__tagline h1 {
        font-size: 76px;
        line-height: 92px; }
    .banner__btn {
      padding-top: 50px;
      gap: 23px; }
      .banner__btn--text {
        font-size: 24px;
        line-height: 32px; }
      .banner__btn--icon img {
        width: 40px; } }
@media only screen and (min-width: 1024px) and (max-width: 1199px) {
  .banner {
    padding-top: 70px;
    padding-bottom: 50px; }
    .banner__container {
      max-width: 1000px;
      padding-left: 20px;
      padding-right: 20px; }
    .banner__question {
      display: flex;
      align-items: center;
      gap: 13px; }
      .banner__question span {
        font-size: 18px;
        line-height: 22px; }
      .banner__question .line {
        width: 260px; }
    .banner__tagline {
      padding-top: 40px; }
      .banner__tagline h1 {
        font-size: 62px;
        line-height: 80px; }
    .banner__btn {
      padding-top: 50px;
      gap: 23px; }
      .banner__btn--text {
        font-size: 20px;
        line-height: 32px; }
      .banner__btn--icon img {
        width: 40px; } }
@media only screen and (min-width: 750px) and (max-width: 1023px) {
  .banner {
    padding-top: 70px;
    padding-bottom: 50px; }
    .banner__container {
      max-width: 1000px;
      padding-left: 20px;
      padding-right: 20px; }
    .banner__question {
      display: flex;
      align-items: center;
      gap: 13px; }
      .banner__question span {
        font-size: 18px;
        line-height: 22px; }
      .banner__question .line {
        width: 260px; }
    .banner__tagline {
      padding-top: 40px; }
      .banner__tagline h1 {
        font-size: 52px;
        line-height: 65px; }
    .banner__btn {
      padding-top: 50px;
      gap: 23px; }
      .banner__btn--text {
        font-size: 20px;
        line-height: 32px; }
      .banner__btn--icon img {
        width: 40px; } }
@media screen and (max-width: 749px) {
  .banner {
    padding-top: 70px;
    padding-bottom: 50px; }
    .banner__container {
      max-width: 380px;
      padding-left: 20px;
      padding-right: 20px; }
    .banner__question {
      display: flex;
      align-items: center;
      gap: 13px; }
      .banner__question span {
        font-size: 14px;
        line-height: 22px; }
      .banner__question .line {
        width: 130px; }
    .banner__tagline {
      padding-top: 40px; }
      .banner__tagline h1 {
        font-size: 38px;
        line-height: 50px; }
    .banner__btn {
      padding-top: 50px;
      gap: 23px; }
      .banner__btn--text {
        font-size: 16px;
        line-height: 27px; }
      .banner__btn--icon img {
        width: 27px; } }
.design {
  margin-top: 50px; }
  .design__inner {
    display: flex;
    position: relative;
    width: 100%;
    max-height: 100vh;
    overflow: hidden; }
    .design__inner::before {
      content: "";
      display: block;
      padding-bottom: calc(100% / (16 / 9)); }
  .design__images--img {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 160%;
    object-fit: cover; }
  .design__images .svg {
    display: block;
    position: absolute;
    left: 0%;
    top: 0%;
    right: 0%;
    bottom: 0%;
    scale: 1.3;
    z-index: 100; }
  .design__images .desktop {
    display: block; }
  .design__images .ipad {
    display: none; }
  .design__content {
    position: relative;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    flex-direction: column;
    opacity: 0; }
    .design__content--section {
      position: relative;
      display: flex;
      flex-direction: column; }
      .design__content--section .loop-container {
        margin-top: 200px;
        white-space: nowrap;
        font-family: "greycliffcf-bold";
        font-size: 163px;
        line-height: 180px; }
        .design__content--section .loop-container .item {
          position: absolute; }
        .design__content--section .loop-container .item-1 {
          position: absolute; }
    .design__content--scroll {
      position: absolute;
      left: 25%;
      top: 250%;
      opacity: 0;
      z-index: 20;
      display: flex;
      flex-direction: column;
      align-items: center; }
      .design__content--scroll .circle {
        width: 119px;
        height: 119px;
        border-radius: 100%;
        border: 1px solid #ffffff;
        display: flex;
        justify-content: center;
        align-items: center; }
        .design__content--scroll .circle .name {
          font-size: 25px;
          color: #ffffff;
          font-family: "hoefler";
          writing-mode: vertical-rl; }
      .design__content--scroll .liness {
        width: 1px;
        height: 624px;
        background-color: #ffffff; }
  .design__info {
    background-color: #ffffff;
    padding-top: 144px;
    padding-bottom: 200px;
    position: relative;
    z-index: 19; }
    .design__info .line-p {
      position: absolute;
      left: 28%;
      top: 0%;
      opacity: 1;
      z-index: 20;
      width: 1px;
      height: 79%;
      background-color: #000000; }
    .design__info--container {
      max-width: 1256px;
      margin-left: auto;
      position: relative; }
      .design__info--container p {
        color: #000000;
        font-size: 40px;
        line-height: 80px; }
        .design__info--container p span {
          font-family: "hoefler"; }

.design-mobile {
  display: none; }

@media only screen and (min-width: 1200px) and (max-width: 1450px) {
  .design__inner {
    display: flex;
    position: relative;
    width: 100%;
    max-height: 100vh;
    overflow: hidden; }
    .design__inner::before {
      content: "";
      display: block;
      padding-bottom: calc(100% / (16 / 9)); }
  .design__images--img {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 160%;
    object-fit: cover; }
  .design__images .svg {
    display: block;
    position: absolute;
    left: 0%;
    top: 0%;
    right: 0%;
    bottom: 0%;
    scale: 1.3;
    z-index: 100; }
  .design__images .desktop {
    display: block; }
  .design__images .ipad {
    display: none; }
  .design__content--section .loop-container {
    font-size: 140px;
    line-height: 152px; }
  .design__content--scroll {
    left: 15%;
    top: 250%; }
    .design__content--scroll .circle {
      width: 100px;
      height: 100px; }
      .design__content--scroll .circle .name {
        font-size: 20px; }
    .design__content--scroll .liness {
      height: 424px; }
  .design__info {
    padding-top: 120px;
    padding-bottom: 160px;
    position: relative;
    z-index: 19; }
    .design__info .line-p {
      position: absolute;
      left: 18.55%;
      height: 65%; }
    .design__info--container {
      max-width: 70%; }
      .design__info--container p {
        font-size: 30px;
        line-height: 38px; } }
@media only screen and (min-width: 1024px) and (max-width: 1199px) {
  .design-pc {
    display: none; }

  .design__inner {
    display: flex;
    position: relative;
    width: 100vw;
    max-height: 100vh;
    overflow: hidden; }
    .design__inner::before {
      content: "";
      display: block;
      padding-bottom: calc(100% / (16 / 9)); }
  .design__images--img {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 160%;
    object-fit: cover; }
  .design__images .svg {
    display: block;
    position: absolute;
    left: 0%;
    top: 0%;
    right: 0%;
    bottom: 0%;
    scale: 1.3;
    z-index: 100; }
  .design__images .desktop {
    display: none; }
  .design__images .ipad {
    display: block; }
  .design__content--section .loop-container {
    font-size: 140px;
    line-height: 152px; }
  .design__content--scroll {
    left: 15%;
    top: 250%; }
    .design__content--scroll .circle {
      width: 100px;
      height: 100px; }
      .design__content--scroll .circle .name {
        font-size: 20px; }
    .design__content--scroll .liness {
      height: 424px; }
  .design__info {
    padding-top: 85px;
    padding-bottom: 100px;
    position: relative;
    z-index: 19; }
    .design__info .line-p {
      position: absolute;
      left: 15%;
      height: 65%; }
    .design__info--container {
      max-width: 77%;
      padding-right: 30px; }
      .design__info--container p {
        font-size: 30px;
        line-height: 38px; } }
@media only screen and (min-width: 750px) and (max-width: 1023px) {
  .design-pc {
    display: none; }

  .design__info {
    padding-top: 65px;
    padding-bottom: 60px;
    position: relative;
    z-index: 19; }
    .design__info .line-p {
      position: absolute;
      left: 12%;
      height: 65%; }
    .design__info--container {
      max-width: 80%;
      padding-right: 30px; }
      .design__info--container p {
        font-size: 27px;
        line-height: 36px; } }
@media screen and (max-width: 749px) {
  .design-pc {
    display: none; }

  .design__info {
    padding-top: 55px;
    padding-bottom: 55px;
    position: relative;
    z-index: 19; }
    .design__info .line-p {
      position: absolute;
      left: 10%;
      height: 65%; }
    .design__info--container {
      max-width: 80%;
      padding-right: 30px; }
      .design__info--container p {
        font-size: 22px;
        line-height: 32px; } }
.portfolio {
  background-color: #ffffff;
  padding-top: 40px;
  padding-bottom: 80px;
  margin-top: -10px; }
  .portfolio__container {
    padding-left: 30px;
    padding-right: 30px; }
  .portfolio__row {
    display: grid;
    grid-template-columns: 2fr 2fr 2fr;
    gap: 30px; }
  .portfolio__base {
    height: 33vw;
    overflow: hidden;
    position: relative; }
    .portfolio__base--content {
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      top: 0;
      transition: transform 0.3s ease; }
      .portfolio__base--content:hover {
        transition: all 0.2s ease-in-out; }
        .portfolio__base--content:hover .portfolio__base--img img {
          transform: scale(1.1); }
        .portfolio__base--content:hover .portfolio__base--bg {
          transition: all 0.4s ease-in-out;
          transform: scale(1); }
    .portfolio__base--img img {
      display: block;
      width: 100%;
      object-fit: cover;
      object-position: top;
      height: 33vw;
      transition: transform 0.3s ease; }
    .portfolio__base--bg {
      position: absolute;
      top: 13%;
      left: 13%;
      bottom: 13%;
      right: 13%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-direction: column;
      transition: all 0.4s ease-in-out;
      transform: scale(0);
      z-index: 3; }
      .portfolio__base--bg .bg-content {
        position: relative;
        background-color: #000;
        width: 100%;
        height: 100%;
        opacity: 0.6; }
      .portfolio__base--bg .bg-text {
        z-index: 4;
        position: absolute;
        text-align: center; }
        .portfolio__base--bg .bg-text span {
          display: block;
          font-size: 25px;
          font-family: "hoefler";
          line-height: 30px;
          color: #ffffff; }
        .portfolio__base--bg .bg-text p {
          font-size: 40px;
          font-family: "greycliffcf-bold";
          line-height: 50px;
          color: #ffffff; }
  .portfolio__btn {
    padding-top: 90px;
    padding-bottom: 90px;
    max-width: 304px;
    margin: 0 auto; }
    .portfolio__btn a {
      font-size: 40px;
      line-height: 80px;
      color: #000;
      font-family: "hoefler";
      text-decoration: none;
      position: relative;
      padding-top: 20px;
      padding-bottom: 20px;
      transition: 0.3s ease-in;
      display: flex;
      align-items: center;
      justify-content: center; }
      .portfolio__btn a:hover {
        transition: 0.3s ease-in; }
        .portfolio__btn a:hover::before {
          transition: 0.3s ease-in;
          left: 30px; }
        .portfolio__btn a:hover::after {
          transition: 0.3s ease-in;
          right: 30px; }
      .portfolio__btn a::before {
        content: "";
        background-color: #707070;
        width: 200px;
        height: 1px;
        position: absolute;
        left: 0px;
        right: 0;
        top: -8px;
        transition: 0.3s ease-in;
        margin: 0 auto; }
      .portfolio__btn a::after {
        content: "";
        background-color: #707070;
        width: 200px;
        height: 1px;
        position: absolute;
        right: 0px;
        left: 0px;
        bottom: 0px;
        transition: 0.3s ease-in;
        margin: 0 auto; }

@media only screen and (min-width: 1200px) and (max-width: 1450px) {
  .portfolio {
    padding-top: 20px;
    padding-bottom: 60px; }
    .portfolio__base {
      height: 33vw; }
      .portfolio__base--bg {
        position: absolute;
        top: 12%;
        left: 12%;
        bottom: 12%;
        right: 12%; }
        .portfolio__base--bg .bg-text span {
          font-size: 20px;
          line-height: 27px; }
        .portfolio__base--bg .bg-text p {
          font-size: 30px;
          line-height: 37px; }
    .portfolio__btn a {
      font-size: 30px;
      line-height: 38px; } }
@media only screen and (min-width: 1024px) and (max-width: 1199px) {
  .portfolio {
    padding-top: 20px;
    padding-bottom: 60px; }
    .portfolio__base {
      height: 32vw; }
      .portfolio__base--img img {
        height: 32vw; }
      .portfolio__base--bg {
        position: absolute;
        top: 12%;
        left: 12%;
        bottom: 12%;
        right: 12%; }
        .portfolio__base--bg .bg-text span {
          font-size: 20px;
          line-height: 27px; }
        .portfolio__base--bg .bg-text p {
          font-size: 30px;
          line-height: 37px; }
    .portfolio__btn a {
      font-size: 30px;
      line-height: 38px; } }
@media only screen and (min-width: 750px) and (max-width: 1023px) {
  .portfolio {
    padding-top: 20px;
    padding-bottom: 60px; }
    .portfolio__base {
      height: 32vw; }
      .portfolio__base--img img {
        height: 32vw; }
      .portfolio__base--bg {
        position: absolute;
        top: 12%;
        left: 12%;
        bottom: 12%;
        right: 12%; }
        .portfolio__base--bg .bg-text span {
          font-size: 20px;
          line-height: 27px; }
        .portfolio__base--bg .bg-text p {
          font-size: 30px;
          line-height: 37px; }
    .portfolio__btn a {
      font-size: 30px;
      line-height: 38px; } }
@media screen and (max-width: 749px) {
  .portfolio {
    padding-top: 20px;
    padding-bottom: 60px; }
    .portfolio__row {
      grid-template-columns: 2fr; }
    .portfolio__base {
      height: 80vw; }
      .portfolio__base--img img {
        height: 80vw; }
      .portfolio__base--bg {
        position: absolute;
        top: 10%;
        left: 10%;
        bottom: 10%;
        right: 10%;
        transform: scale(1); }
        .portfolio__base--bg .bg-text span {
          font-size: 20px;
          line-height: 27px; }
        .portfolio__base--bg .bg-text p {
          font-size: 30px;
          line-height: 37px; }
    .portfolio__btn a {
      font-size: 24px;
      line-height: 32px; } }
.about {
  background-color: #40223e;
  padding-top: 180px;
  padding-bottom: 180px; }
  .about__area {
    max-width: 1693px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
    position: relative; }
    .about__area--row {
      display: flex;
      justify-content: space-between; }
    .about__area--logo {
      position: absolute;
      left: 0;
      bottom: -45%;
      width: 40%;
      height: 575px;
      background-color: #d6d6d6;
      box-shadow: 10px 10px 30px 0px rgba(0, 0, 0, 0.15);
      -webkit-box-shadow: 10px 10px 30px 0px rgba(0, 0, 0, 0.15);
      -moz-box-shadow: 10px 10px 30px 0px rgba(0, 0, 0, 0.15);
      border-radius: 50px; }
    .about__area--tagline {
      flex-basis: 40%; }
      .about__area--tagline h2 {
        font-size: 60px;
        line-height: 70px;
        color: #ffffff;
        font-family: "greycliffcf-bold"; }
      .about__area--tagline .lg {
        display: block; }
      .about__area--tagline .md {
        display: none; }
    .about__area--information {
      flex-basis: 55%; }
      .about__area--information .information {
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-wrap: wrap; }
        .about__area--information .information__base {
          flex-basis: 45%; }
          .about__area--information .information__base.full {
            margin-top: 80px;
            flex-basis: 100%; }
          .about__area--information .information__base--title h3 {
            color: #40b49c;
            font-size: 40px;
            line-height: 52px;
            font-family: "greycliffcf-bold"; }
          .about__area--information .information__base--desc p {
            color: #ffffff;
            font-size: 26px;
            line-height: 45px;
            font-family: "greycliffcf-medium"; }

@media only screen and (min-width: 1200px) and (max-width: 1450px) {
  .about {
    padding-top: 140px;
    padding-bottom: 140px; }
    .about__area {
      max-width: 1393px; }
      .about__area--logo {
        left: 30px;
        bottom: -55%;
        width: 35%;
        height: 420px; }
      .about__area--tagline {
        flex-basis: 40%; }
        .about__area--tagline h2 {
          font-size: 45px;
          line-height: 52px; }
      .about__area--information .information__base.full {
        margin-top: 50px;
        flex-basis: 100%; }
      .about__area--information .information__base--title h3 {
        font-size: 30px;
        line-height: 42px; }
      .about__area--information .information__base--desc p {
        font-size: 20px;
        line-height: 32px; } }
@media only screen and (min-width: 1024px) and (max-width: 1199px) {
  .about {
    padding-top: 140px;
    padding-bottom: 140px; }
    .about__area {
      max-width: 1393px; }
      .about__area--logo {
        left: 30px;
        bottom: -40%;
        width: 35%;
        height: 420px; }
      .about__area--tagline {
        flex-basis: 40%; }
        .about__area--tagline h2 {
          font-size: 48px;
          line-height: 54px; }
        .about__area--tagline .lg {
          display: none; }
        .about__area--tagline .md {
          display: block; }
      .about__area--information .information__base.full {
        margin-top: 50px;
        flex-basis: 100%; }
      .about__area--information .information__base--title h3 {
        font-size: 30px;
        line-height: 42px; }
      .about__area--information .information__base--desc p {
        font-size: 20px;
        line-height: 32px; } }
@media only screen and (min-width: 750px) and (max-width: 1023px) {
  .about {
    padding-top: 80px;
    padding-bottom: 80px;
    padding-left: 20px;
    padding-right: 20px; }
    .about__area {
      max-width: 1393px; }
      .about__area--row {
        flex-wrap: wrap; }
      .about__area--logo {
        left: unset;
        right: 0%;
        bottom: unset;
        width: 38%;
        height: 280px; }
      .about__area--tagline {
        flex-basis: 100%; }
        .about__area--tagline h2 {
          font-size: 42px;
          line-height: 52px;
          width: 60%; }
        .about__area--tagline .lg {
          display: none; }
        .about__area--tagline .md {
          display: block; }
      .about__area--information {
        padding-top: 50px;
        flex-basis: 100%; }
        .about__area--information .information__base.full {
          margin-top: 50px;
          flex-basis: 100%; }
        .about__area--information .information__base--title h3 {
          font-size: 30px;
          line-height: 42px; }
        .about__area--information .information__base--desc p {
          font-size: 20px;
          line-height: 32px; } }
@media screen and (max-width: 749px) {
  .about {
    padding-top: 60px;
    padding-bottom: 60px;
    padding-left: 20px;
    padding-right: 20px; }
    .about__area {
      max-width: 1393px; }
      .about__area--row {
        flex-wrap: wrap; }
      .about__area--logo {
        display: none;
        left: unset;
        right: 0%;
        bottom: unset;
        width: 38%;
        height: 280px; }
      .about__area--tagline {
        flex-basis: 100%; }
        .about__area--tagline h2 {
          font-size: 32px;
          line-height: 38px;
          width: 100%; }
        .about__area--tagline .lg {
          display: none; }
        .about__area--tagline .md {
          display: block; }
      .about__area--information {
        flex-basis: 100%; }
        .about__area--information .information__base {
          padding-top: 40px;
          flex-basis: 100%; }
          .about__area--information .information__base.full {
            margin-top: 0px;
            flex-basis: 100%; }
          .about__area--information .information__base--title h3 {
            font-size: 30px;
            line-height: 42px; }
          .about__area--information .information__base--desc p {
            font-size: 20px;
            line-height: 32px; } }
.brand {
  background-color: #ffffff;
  height: 80vh;
  overflow: hidden; }
  .brand__area--section {
    position: relative;
    display: flex;
    flex-direction: column; }
    .brand__area--section .loop-container {
      margin-top: 200px;
      white-space: nowrap;
      font-family: "greycliffcf-demibold";
      font-size: 90px;
      line-height: 180px;
      color: #1a1a1a; }
      .brand__area--section .loop-container .itembrand1 {
        position: absolute; }
      .brand__area--section .loop-container .itembrand2 {
        position: absolute; }

@media only screen and (min-width: 1200px) and (max-width: 1450px) {
  .brand {
    padding-top: 30px; }
    .brand__area--section .loop-container {
      margin-top: 170px;
      font-size: 75px;
      line-height: 80px; } }
@media only screen and (min-width: 1024px) and (max-width: 1199px) {
  .brand {
    padding-top: 30px;
    height: 500px; }
    .brand__area--section .loop-container {
      margin-top: 120px;
      font-size: 75px;
      line-height: 80px; } }
@media only screen and (min-width: 750px) and (max-width: 1023px) {
  .brand {
    padding-top: 10px;
    height: 450px; }
    .brand__area--section .loop-container {
      margin-top: 120px;
      font-size: 67px;
      line-height: 72px; } }
@media screen and (max-width: 749px) {
  .brand {
    padding-top: 10px;
    height: 322px; }
    .brand__area--section .loop-container {
      margin-top: 85px;
      font-size: 35px;
      line-height: 42px; } }
@media only screen and (min-width: 1024px) and (max-width: 1199px) {
  .design-mobile {
    display: block; }

  .design-m__inner {
    display: flex;
    position: relative;
    width: 100%;
    max-height: 700px;
    overflow: hidden; }
  .design-m__images::after {
    background-color: #000;
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: 0.4; }
  .design-m__images--img {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 700px;
    object-fit: cover; }
  .design-m__content {
    height: 650px; }
    .design-m__content--section {
      position: relative;
      display: flex;
      flex-direction: column; }
      .design-m__content--section .loop-container {
        margin-top: 150px;
        white-space: nowrap;
        font-family: "greycliffcf-bold";
        font-size: 100px;
        line-height: 180px; }
        .design-m__content--section .loop-container .item-3 {
          position: absolute; }
        .design-m__content--section .loop-container .item-4 {
          position: absolute; }
    .design-m__content--scroll {
      position: absolute;
      left: 10.2%;
      top: unset;
      bottom: 0%;
      opacity: 1;
      z-index: 20;
      display: flex;
      flex-direction: column;
      align-items: center; }
      .design-m__content--scroll .circle {
        width: 95px;
        height: 95px;
        border-radius: 100%;
        border: 1px solid #ffffff;
        display: flex;
        justify-content: center;
        align-items: center; }
        .design-m__content--scroll .circle .name {
          font-size: 18px;
          color: #ffffff;
          font-family: "hoefler";
          writing-mode: vertical-rl; }
      .design-m__content--scroll .liness {
        width: 1px;
        height: 60px;
        background-color: #ffffff; } }
@media only screen and (min-width: 750px) and (max-width: 1023px) {
  .design-mobile {
    display: block; }

  .design-m__inner {
    display: flex;
    position: relative;
    width: 100%;
    max-height: 700px;
    overflow: hidden; }
  .design-m__images::after {
    background-color: #000;
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: 0.4; }
  .design-m__images--img {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 700px;
    object-fit: cover; }
  .design-m__content {
    height: 550px; }
    .design-m__content--section {
      position: relative;
      display: flex;
      flex-direction: column; }
      .design-m__content--section .loop-container {
        margin-top: 120px;
        white-space: nowrap;
        font-family: "greycliffcf-bold";
        font-size: 80px;
        line-height: 180px; }
        .design-m__content--section .loop-container .item-3 {
          position: absolute; }
        .design-m__content--section .loop-container .item-4 {
          position: absolute; }
    .design-m__content--scroll {
      position: absolute;
      left: 6%;
      top: unset;
      bottom: 0%;
      opacity: 1;
      z-index: 20;
      display: flex;
      flex-direction: column;
      align-items: center; }
      .design-m__content--scroll .circle {
        width: 95px;
        height: 95px;
        border-radius: 100%;
        border: 1px solid #ffffff;
        display: flex;
        justify-content: center;
        align-items: center; }
        .design-m__content--scroll .circle .name {
          font-size: 18px;
          color: #ffffff;
          font-family: "hoefler";
          writing-mode: vertical-rl; }
      .design-m__content--scroll .liness {
        width: 1px;
        height: 60px;
        background-color: #ffffff; } }
@media screen and (max-width: 749px) {
  .design-mobile {
    display: block; }

  .design-m__inner {
    display: flex;
    position: relative;
    width: 100%;
    max-height: 700px;
    overflow: hidden; }
  .design-m__images::after {
    background-color: #000;
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: 0.4; }
  .design-m__images--img {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 700px;
    object-fit: cover; }
  .design-m__content {
    height: 380px; }
    .design-m__content--section {
      position: relative;
      display: flex;
      flex-direction: column; }
      .design-m__content--section .loop-container {
        margin-top: 79px;
        white-space: nowrap;
        font-family: "greycliffcf-bold";
        font-size: 46px;
        line-height: 80px; }
        .design-m__content--section .loop-container .item-3 {
          position: absolute; }
        .design-m__content--section .loop-container .item-4 {
          position: absolute; }
    .design-m__content--scroll {
      position: absolute;
      left: 1%;
      top: unset;
      bottom: 0%;
      opacity: 1;
      z-index: 20;
      display: flex;
      flex-direction: column;
      align-items: center; }
      .design-m__content--scroll .circle {
        width: 70px;
        height: 70px;
        border-radius: 100%;
        border: 1px solid #ffffff;
        display: flex;
        justify-content: center;
        align-items: center; }
        .design-m__content--scroll .circle .name {
          font-size: 16px;
          color: #ffffff;
          font-family: "hoefler";
          writing-mode: vertical-rl; }
      .design-m__content--scroll .liness {
        width: 1px;
        height: 60px;
        background-color: #ffffff; } }
.ftr {
  padding-top: 67px; }
  .ftr__container {
    max-width: 1693px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px; }
  .ftr__cta {
    max-width: 985px;
    margin: 0 auto; }
    .ftr__cta--title h3 {
      font-size: 100px;
      line-height: 100px;
      color: #40b49c;
      font-family: "greycliffcf-bold";
      text-align: center; }
    .ftr__cta--btn {
      max-width: 394px;
      margin: 0 auto;
      padding-top: 68px;
      padding-bottom: 54px; }
      .ftr__cta--btn a {
        width: 100%;
        height: 70px;
        background-color: #ffffff;
        border-radius: 100px;
        font-size: 25px;
        line-height: 30px;
        color: #000000;
        font-family: "greycliffcf-bold";
        display: flex;
        align-items: center;
        justify-content: center;
        text-decoration: none;
        -webkit-transition: ease-out 0.4s;
        -moz-transition: ease-out 0.4s;
        transition: ease-out 0.4s; }
        .ftr__cta--btn a:hover {
          color: #ffffff;
          box-shadow: inset 0px 100px 0px #40b49c; }
  .ftr__area {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-top: 1px solid #707070;
    padding-top: 70px;
    padding-bottom: 70px; }
    .ftr__area--logo img {
      width: 189px;
      display: block; }
    .ftr__area--menu {
      display: flex;
      align-items: center; }
    .ftr__area--list {
      list-style: none;
      padding-left: 50px; }
    .ftr__area--link {
      font-size: 20px;
      line-height: 40px;
      color: #ffffff;
      font-family: "greycliffcf-thin";
      text-decoration: none; }

@media only screen and (min-width: 1200px) and (max-width: 1450px) {
  .ftr {
    padding-top: 67px; }
    .ftr__container {
      max-width: 1393px; }
    .ftr__cta {
      max-width: 785px; }
      .ftr__cta--title h3 {
        font-size: 80px;
        line-height: 87px; }
      .ftr__cta--btn {
        max-width: 312px;
        padding-top: 50px;
        padding-bottom: 54px; }
        .ftr__cta--btn a {
          height: 72px;
          font-size: 20px;
          line-height: 30px; }
    .ftr__area {
      padding-top: 50px;
      padding-bottom: 50px;
      padding-left: 20px;
      padding-right: 20px; }
      .ftr__area--logo img {
        width: 140px; }
      .ftr__area--menu {
        display: flex;
        align-items: center; }
      .ftr__area--list {
        padding-left: 40px; }
      .ftr__area--link {
        font-size: 17px;
        line-height: 26px; } }
@media only screen and (min-width: 1024px) and (max-width: 1199px) {
  .ftr {
    padding-top: 67px; }
    .ftr__container {
      max-width: 1393px; }
    .ftr__cta {
      max-width: 785px; }
      .ftr__cta--title h3 {
        font-size: 80px;
        line-height: 87px; }
      .ftr__cta--btn {
        max-width: 312px;
        padding-top: 50px;
        padding-bottom: 54px; }
        .ftr__cta--btn a {
          height: 72px;
          font-size: 20px;
          line-height: 30px; }
    .ftr__area {
      padding-top: 50px;
      padding-bottom: 50px;
      padding-left: 20px;
      padding-right: 20px; }
      .ftr__area--logo img {
        width: 140px; }
      .ftr__area--menu {
        display: flex;
        align-items: center; }
      .ftr__area--list {
        padding-left: 40px; }
      .ftr__area--link {
        font-size: 17px;
        line-height: 26px; } }
@media only screen and (min-width: 750px) and (max-width: 1023px) {
  .ftr {
    padding-top: 67px; }
    .ftr__container {
      max-width: 1393px; }
    .ftr__cta {
      max-width: 785px; }
      .ftr__cta--title h3 {
        font-size: 65px;
        line-height: 72px; }
      .ftr__cta--btn {
        max-width: 312px;
        padding-top: 50px;
        padding-bottom: 54px; }
        .ftr__cta--btn a {
          height: 72px;
          font-size: 20px;
          line-height: 30px; }
    .ftr__area {
      padding-top: 50px;
      padding-bottom: 50px;
      padding-left: 20px;
      padding-right: 20px; }
      .ftr__area--logo img {
        width: 140px; }
      .ftr__area--menu {
        display: flex;
        align-items: center; }
      .ftr__area--list {
        padding-left: 40px; }
      .ftr__area--link {
        font-size: 17px;
        line-height: 26px; } }
@media screen and (max-width: 749px) {
  .ftr {
    padding-top: 67px; }
    .ftr__container {
      max-width: 380px; }
    .ftr__cta {
      max-width: 280px; }
      .ftr__cta--title h3 {
        font-size: 34px;
        line-height: 42px; }
      .ftr__cta--btn {
        max-width: 180px;
        padding-top: 30px;
        padding-bottom: 34px; }
        .ftr__cta--btn a {
          height: 58px;
          font-size: 16px;
          line-height: 27px; }
    .ftr__area {
      padding-top: 50px;
      padding-bottom: 50px;
      padding-left: 20px;
      padding-right: 20px;
      flex-wrap: wrap; }
      .ftr__area--logo {
        flex-basis: 100%; }
        .ftr__area--logo img {
          margin: 0 auto;
          width: 140px; }
      .ftr__area--menu {
        padding-top: 20px;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-wrap: wrap; }
      .ftr__area--list {
        flex-basis: 100%;
        padding-top: 20px;
        padding-left: 0px;
        text-align: center; }
      .ftr__area--link {
        text-align: center;
        font-size: 17px;
        line-height: 26px; } }
.pc {
  display: block; }

.sp {
  display: none; }

@media screen and (max-width: 785px) {
  .pc {
    display: none; }

  .sp {
    display: block; } }
.material-menu-wrapper {
  position: absolute;
  bottom: 0;
  right: 0;
  height: 100vh;
  width: 40vw;
  overflow: hidden; }

.material-menu {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  background: transparent; }

.material-btn {
  will-change: transform;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  position: absolute;
  z-index: 2;
  top: 20px;
  right: 20px;
  width: 75px;
  height: 75px;
  background: transparent;
  cursor: pointer; }
  .material-btn.active:before {
    transform: scale(18); }
    @media (min-height: 800px) {
      .material-btn.active:before {
        transform: scale(25); } }
  .material-btn:active:before {
    opacity: 0.75; }
  .material-btn:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 75px;
    height: 75px;
    background: white;
    border-radius: 0%;
    box-shadow: 0 5px 10px rgba(0, 0, 0, 0.5);
    cursor: pointer;
    transform-origin: center 70%;
    transform: scale(1);
    transition: all 0.35s ease-out; }

.material-content {
  padding: 10% 15%;
  position: absolute;
  top: 0;
  right: 0; }
  .material-content.active {
    z-index: 2; }

nav ul {
  list-style-type: none;
  padding: 0;
  text-align: right; }
nav li {
  will-change: transform, opacity;
  margin: 25px 0;
  transform: translateY(-100px);
  opacity: 0;
  transition: all 0.4s ease-out; }
  nav li.active {
    transform: translateY(0);
    opacity: 1; }
nav li:nth-child(1) {
  transition-delay: 0.1s; }
nav li:nth-child(2) {
  transition-delay: 0.2s; }
nav li:nth-child(3) {
  transition-delay: 0.3s; }
nav li:nth-child(4) {
  transition-delay: 0.4s; }
nav a {
  text-decoration: none;
  font-size: 5vw;
  color: tomato;
  font-weight: 300; }

.material-hamburger {
  transition: all 0.3s ease-out; }
  .material-hamburger .material-patty {
    will-change: transform, opacity;
    width: 32px;
    height: 3px;
    margin: 0 0 6px 0;
    background: #333333;
    opacity: 1;
    transform: translate(0) rotate(0deg);
    transition: all 0.2s ease-out; }
    .material-hamburger .material-patty:last-child {
      margin-bottom: 0; }
  .material-hamburger.material-close {
    transform: rotate(-180deg); }
    .material-hamburger.material-close .material-patty:nth-child(1) {
      transform: translate(-10px, 4px) rotate(-45deg) scale(0.5, 1); }
    .material-hamburger.material-close .material-patty:nth-child(3) {
      transform: translate(-10px, -4px) rotate(45deg) scale(0.5, 1); }

main {
  will-change: transform, opacity;
  width: 80vw;
  height: 100vw;
  padding: 10vw;
  overflow: hidden;
  transition: all 0.35s ease-out; }
  main.active {
    opacity: 0;
    transform: translate(-700px, 0px); }
  main p {
    color: white;
    font-size: 4vw;
    font-weight: 300; }
    main p .highlight {
      background: white;
      color: tomato;
      font-size: 4vw; }

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