/*


    About Carousel


*/

:root {
  --aboutFinalTextWidth: min-content !important;
}

[data-language="ja"] {
  --aboutFinalTextWidth: 7em !important;
}

#about-carousel-trigger {
  --triggerSize: 100px;
  margin-top: calc(var(--sceneHeight) / 2);
  height: 1px;
}

#front-elements {
  pointer-events: none;
  color: var(--midGreen);
}

#about-carousel-anim-container {
  --desktopShift: 300px;
  position: absolute;
  width: 0;
  height: 0;
  left: calc(50% + var(--desktopShift));
  top: 50%;
}

#about-carousel-main-circle-container {
  width: 1480px !important;
}

#about-carousel-main-circle {
  border-radius: 0;
  border-top-right-radius: 450px;
  border-bottom-right-radius: 450px;
  width: calc(2000px + 180px);
  left: calc(-720px + 180px);
}

#about-carousel-main-circle-2 {
  left: 50%;
  width: 500px;
  height: 500px;
}

.circle.hc-carousel-circle {
  top: 50%;
  width: 700px;
  height: 700px;
  background: var(--backgroundColor);
  will-change: opacity, transform;
}

#about-carousel-main-6 {
  left: 50%;
  transform: translate(-50%, -50%) !important;
  width: var(--aboutFinalTextWidth);
}

#about-carousel-main-circle-texts {
  height: 100%;
}


#about-carousel {
  /* let javascript min-size setting kick in */
  height: 200px;
}

#about-carousel-main {
  /* let javascript min-size setting kick in */
  height: 200px;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1480px;
  transform: translate(-50%, -50%);
}

#about-carousel-main-cover {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  opacity: 0;
}

@media only screen and (orientation:portrait) and (max-width: 992px) {
  #about-carousel-main {
    position: relative;
    top: unset;
    left: unset;
    width: 100%;
    transform: unset;
  }

  #about-carousel-main-circle,
  #about-carousel-main-circle-2 {
    display: none !important;
  }

  #about-carousel-anim-container {
    top: 40%;
  }

  #about-carousel-main-cover {
    opacity: 1;
  }
}

@media only screen and (orientation:portrait) and (max-width: 992px) {
  #about-carousel-main-6 {
    transform: translateX(-50%) !important;
  }
}

@media only screen and (orientation:portrait) and (max-width: 400px) {
  #about-carousel-anim-container {
    top: 36%;
  }
}



@media only screen and (orientation:portrait) and (max-height: 765px) and (max-width: 560px) {
  .circle-text {
    font-size: var(--fs20) !important;
    padding: 0 3px;
  }
}


/*


    Scene 1


*/

#content-background-1 {
  height: 100vh;
}

/*


    About Content 1


*/

#background-circle-content-1 {
  top: 50%;
  left: 50%;
  will-change: background-color, width, height;
}

.hc-flex-container {
  display: flex;
  width: 100%;
}

@media only screen and (max-width: 1200px) {
  .hc-flex-container {
    display: block;
  }
}

.hc-flex-container-left {
  position: relative;
  flex: 0.43;
}

.hc-center-text-align {
  display: flex;
  align-items: center;
  min-height: min-content;
}

.hc-center-text-align-wrapper {
  padding: 10vh 0;
}

.hc-flex-inverse .hc-flex-container-left {
  position: relative;
  flex: 0.57;
}

.hc-flex-container-right {
  position: relative;
  flex: 0.57;
}

.hc-flex-inverse .hc-flex-container-right {
  position: relative;
  flex: 0.43;
}

#about-content-container-4 {
  /*height: min(665px, 100vh);*/
}

@media only screen and (max-width: 1200px) {
  #about-content-container-4 {
    height: 100%;
  }
}

#about-content-1 {
  --circleSize: 306px margin-top: -30vh;
  padding-bottom: 0;
  min-height: min-content !important;
  height: min-content;
}

#about-content-1-logo-0 {
  width: var(--circleSize);
  height: var(--circleSize);
  left: calc(100% - 353px);
  top: calc(50% - 92px);
}

#about-content-1-logo-0 .inner-circle {
  width: 105px;
}

#about-content-1-logo-1,
#about-content-1-logo-1-cover {
  width: var(--circleSize);
  height: var(--circleSize);
  left: calc(100% - 198px);
  top: calc(50% + 125px);
  will-change: background-color, opacity, width, height;
}

#about-content-1-logo-1-cover {
  width: 0;
  height: 0;
}

#about-content-1-logo-1 .inner-circle {
  width: 140px;
}

#about-content-1-trigger {
  position: absolute;
  top: -10vh;
  height: calc(100% + 10vh);
}

.hc-top-trigger {
  position: absolute;
  top: calc(50% - 50vh);
}

#about-content-logo-container {
  position: absolute;
  left: 0;
  top: calc(50% - 100vh);
  width: 100vw;
  height: 200vh;
  overflow: hidden;
  pointer-events: none;
}

#about-content-text-container {
  height: min-content;
  min-height: min-content;
  color: var(--midGreen);
}

#background-circle-content-1 {
  will-change: width, height, background;
}

#about-content-container-2 {
  color: var(--lightGreen);
  will-change: color;
}


#about-content-2-circle-trigger {
  position: absolute;
  top: 0;
  height: 50vh;
}

#about-content-2-circle {
  will-change: width, height;
}

#about-content-2-trigger {
  position: absolute;
  height: 50vh;
  top: 0;
  left: 0;
}

@media only screen and (max-width: 1200px) {
  #about-content-text-container {
    padding-top: 120px;
    height: auto;
  }

  #about-content-text-container .hc-center-text-align-wrapper {
    padding-bottom: 0;
  }

  .hc-top-trigger {
    top: 0;
  }

  #about-content-1-trigger {
    height: calc(600px + 20vh);
    top: unset;
    bottom: 100vh;
  }

  #about-content-logo-container {
    position: relative;
    top: 0;
    height: calc(600px + 100vh);
    padding-top: 10vh;
  }

  #about-content-1-logo-0 {
    left: calc(50% - 82px);
    top: 154px;
  }

  #about-content-1-logo-1,
  #about-content-1-logo-1-cover {
    left: calc(50% + 69px);
    top: 375px;
  }

  #about-content-2 {
    margin-top: -100vh;
  }

  #about-content-2-circle-container {
    height: 460px;
    margin-left: 35%;
  }

  #about-content-2-circle-trigger {
    top: -16vh;
    height: 100vh;
  }
}

@media only screen and (max-width: 1400px) {
  #about-content-2-circle {
    transform: translate(-50%, -50%) scale(0.7) !important;
  }
}

.hc-title {
  font-size: var(--fs33);
  margin-bottom: 22px;
  line-height: 1.25;
}

#background-cover {
  background-color: var(--darkGreen);
  opacity: 0;
  will-change: opacity;
}

#about-content-2-circle-content {
  position: relative;
  min-width: 266px;
  max-width: 266px;
  min-height: 266px;
}

#about-content-2-circle {
  width: 486px;
  height: 486px;
  position: absolute;
  left: 50%;
  top: 50%;
  background-color: var(--midGreen);
  transform: translate(-50%, -50%);
  overflow: hidden;
  border-radius: 50%;
}

.hc-centered-circle {
  display: flex;
  justify-content: center;
  align-items: center;
  will-change: width, height;
}

#about-see-more-button {
  --color: var(--lightGreen);
  --secondaryColor: var(--midGreen);
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
}

#about-content-2-circle-text {
  color: var(--lightGreen);
  font-size: var(--fs32);
}

#about-content-2-circle-button {
  color: var(--lightGreen);
  font-size: var(--fs28);
}

#about-content-3 {
  --sceneHeight: 750px;
  min-height: var(--sceneHeight) !important;
  height: var(--sceneHeight) !important;
}

#about-carousel-main-cover-circle,
#about-content-3-bg-circle {
  --height: 200px;
  --width: 200px;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 200px;
  overflow: hidden;
  /* background-repeat: no-repeat;
  background-size: calc(100% + 6px) 100%;
  background-position-x: -5px;
  background-image: url(../img/about-content-3-bg-circle.svg); */
}

#about-carousel-main-cover-rect {
  width: 100%;
  background: var(--backgroundColor);
  transition: height 0.6s ease-in-out 0.6s;
}

#about-carousel-main-cover-inner-circle,
#about-content-3-bg-circle-inner-circle {
  /* js resize */
  --radius: 0;
  background: var(--backgroundColor);
  border-radius: 50%;
  width: var(--radius);
  height: var(--radius);
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
}

#about-carousel-main-cover-circle {
  --radius: 1700px;
  bottom: unset;
  top: -100px;
}

#about-content-3-text-circle-1 {
  width: 526px;
  height: 526px;
  top: -170px;
  left: calc(50% + 240px);
}

#about-content-3-text-circle-1-inside {
  width: 306px;
  min-width: 306px;
  font-size: var(--fs18);
  line-height: 1.5;
  color: var(--darkGreen);
}

#about-content-3-text-circle-2 {
  width: 264px;
  height: 264px;
  top: -214px;
  left: calc(50% - 59px);
}

#about-content-3-text-circle-2-inside {
  font-size: var(--fs33);
  width: 146px;
  min-width: 146px;
  color: var(--darkGreen);
}

#about-content-3-circles {
  position: absolute;
  left: 50%;
  bottom: 200px;
  width: 0;
  height: 0;
}

#about-content-4,
#about-content-5 {
  background-color: var(--backgroundColor);
  color: var(--darkGreen);
  height: min-content;
  min-height: min-content;
}

#about-content-4 {
  margin-top: 0;
}

#about-content-4-circle-1 {
  left: 220px;
  top: calc(10vh + 20px);
}

#about-content-4-circle-2 {
  left: 401px;
  top: calc(10vh + 220px);
}

#about-content-4-circle-trigger {
  position: absolute;
  top: -30vh;
  height: 100vh;
}

#about-content-5-text-circle-1 {
  width: 310px;
  height: 310px;
  top: calc(10vh + 96px);
  left: calc(100% - 220px);
}

#about-content-5-text-circle-1-inside {
  color: var(--backgroundColor);
  font-size: var(--fs30);
  width: 210px;
  min-width: 210px;
}

#about-content-5-circle-trigger {
  position: absolute;
  top: -30vh;
  height: 50vh;
}

@media only screen and (max-width: 1200px) {

  #about-content-4,
  #about-content-5 {
    height: min-content;
  }

  #about-content-3-bg-circle {
    left: 50%;
    transform: translateX(-50%);
    width: 1200px;
    height: 100px;
  }

  #about-content-3-circles {
    bottom: 100px;
  }

  #about-content-3 {
    --contentCircleTop3: 443px;
    margin-top: -170px;
    min-height: min(930px, 75vh) !important;
    height: 630px !important;
  }

  #about-content-3-text-circle-1-inside {
    font-size: var(--fs14);
    width: 205px;
    min-width: 205px;
  }

  #about-content-3-text-circle-1 {
    left: 0;
    top: -110px;
  }

  #about-content-3-text-circle-2 {
    left: -121px;
    top: -269px;
  }

  #about-content-3-text-circle-2-inside {
    font-size: var(--fs24);
    width: 106px;
    min-width: 106px;
  }

  #about-content-4 {
    margin-top: 0;
    height: min-content;
  }

  #about-content-4-circle-container {
    height: 577px;
  }

  #about-content-4-circle-1 {
    left: calc(50% - 67px);
    top: 129px;
  }

  #about-content-4-circle-1 .inner-circle {
    width: 175px;
    height: 175px;
  }

  #about-content-4-circle-2 {
    left: calc(50% + 38px);
    top: 254px;
  }

  #about-content-4-circle-2 .inner-circle {
    width: 240px;
    height: 240px;
  }

  #about-content-5-text-circle-1 {
    width: 313px;
    height: 313px;
    top: -154px;
    left: 112px;
  }

  #about-content-5-text-circle-1-inside {
    width: 120px;
    font-size: var(--fs20);
    width: 146px;
    min-width: 146px;
  }

  #about-content-5-circle-trigger {
    position: absolute;
    top: -50vh;
    height: 30vh;
  }
}

#about-content-text-4 .hc-center-text-align-wrapper {
  min-height: 560px;
}


#about-content-text-5 .hc-center-text-align-wrapper {
  min-height: 420px;
}

@media only screen and (max-width: 1200px) {
  #about-content-text-5 .hc-center-text-align-wrapper {
    min-height: 0;
  }
}

@media only screen and (max-width: 600px) {
  #about-content-text-5 .hc-center-text-align-wrapper {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}