html, body {
  height: 100%;
  overflow: hidden;
  touch-action: none;
}
html.scroll-auto, body.scroll-auto {
  height: unset;
  overflow: unset;
  touch-action: unset;
}

@keyframes rolling {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-100%, 0, 0);
  }
}
@keyframes scale {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}
.deco-logo {
  display: block;
  width: 123px;
  height: auto;
  margin: 0 auto;
}

.main-min {
  display: block;
}
.main-min .min-inner {
  position: relative;
  display: inline-block;
  text-align: right;
}
.main-min .min-inner .deco {
  width: auto;
  height: 13px;
}

.deco-logo-box + .main-title {
  margin-top: 20px;
}

.main-min + .main-title {
  margin-top: 20px;
}

.main-title {
  line-height: 1.4;
}

.main-desc {
  line-height: 1.4;
}

section.active .title-box .ani-text .ani-inner {
  transform: translateY(0);
  opacity: 1;
}
section .title-box .ani-text {
  display: inline-block;
  overflow: hidden;
}
section .title-box .ani-text .ani-inner {
  display: inline-block;
  transform: translateY(100%);
  opacity: 0;
  transition: transform 1s, opacity 1s;
}

.main-visual {
  width: 100%;
  background-color: #000;
}
.main-visual.active .visual-wrap {
  opacity: 1;
}
.main-visual .visual-wrap {
  width: 100%;
  background-color: #000;
  opacity: 0;
  transition: background-color 1s, opacity 1.2s;
  transition-delay: 0s, 2.4s;
}
.main-visual .visual-wrap.active {
  background-color: #e7bc00;
}
.main-visual .visual-wrap.active2 .text-box .title-box {
  opacity: 0;
  transform: translateY(-70px);
}
.main-visual .visual-wrap.active2 .text-box .rolling-text {
  opacity: 0;
  transform: translateY(70px);
}
.main-visual .visual-wrap.active2 .bg-box::before {
  background-color: rgba(0, 0, 0, 0.7);
}
.main-visual .visual-wrap.active2 .bg-box .video {
  animation-play-state: paused;
}
.main-visual .visual-wrap .bg-box {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  -webkit-clip-path: circle(20%);
          clip-path: circle(20%);
}
.main-visual .visual-wrap .bg-box::before {
  z-index: 1;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background-color: rgba(0, 0, 0, 0.35);
  transition: background-color 0.3s;
}
.main-visual .visual-wrap .bg-box img,
.main-visual .visual-wrap .bg-box .video {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}
.main-visual .visual-wrap .text-box {
  z-index: 1;
  position: relative;
  width: 100%;
}
.main-visual .visual-wrap .text-box .rolling-text {
  position: fixed;
  left: 0;
  bottom: 0;
  display: flex;
  width: 100%;
  flex: 0 0 auto;
  white-space: nowrap;
  opacity: 0.03;
  transition: opacity 1s, transform 1s;
}
.main-visual .visual-wrap .text-box .rolling-text span {
  font-size: 2.5em;
  text-transform: uppercase;
  line-height: 1.1;
  animation: rolling 30s linear infinite;
}
.main-visual .visual-wrap .text-box .title-box {
  position: sticky;
  height: 200vh;
  top: 50%;
  transition: opacity 1s, transform 1s;
}
.main-visual .visual-wrap .text-box .title-box .ani-text .ani-inner {
  transition-delay: 2.6s;
}
.main-visual .visual-wrap .text-box .title-box .title-inner {
  display: flex;
  flex-direction: column;
  transform: translateY(-50%);
  text-shadow: 3px 3px 5px rgba(0, 0, 0, 0.2);
}
.main-visual .visual-wrap .text-box .title-box .title-inner .visual-title span {
  font-size: 1.2em;
  line-height: 1.3;
}
.main-visual .visual-wrap .text-box .title-box .title-inner .visual-desc {
  margin-top: 30px;
  line-height: 1.4;
}
.main-visual .visual-wrap .text-box .text-list {
  z-index: 1;
  position: relative;
  overflow: hidden;
}
.main-visual .visual-wrap .text-box .text-list li {
  perspective: 12.5em;
}
.main-visual .visual-wrap .text-box .text-list li.active .text-inner span {
  color: #e7bc00;
}
.main-visual .visual-wrap .text-box .text-list li .text-inner {
  box-sizing: border-box;
  line-height: 1.3;
  backface-visibility: hidden;
  text-shadow: 3px 3px 5px rgba(0, 0, 0, 0.2);
}
.main-visual .visual-wrap .text-box .text-list li .text-inner span {
  transition: color 1s;
}

.main-service {
  z-index: 1;
  position: relative;
  background-color: #fff;
}
.main-service .service-wrap .service-list {
  display: flex;
  gap: 3px;
}
.main-service .service-wrap .service-list .list-item {
  position: relative;
  height: 1000px;
  opacity: 0;
  -webkit-clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0% 100%);
          clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0% 100%);
  transition: width 0.6s, opacity 1s, -webkit-clip-path 1s;
  transition: width 0.6s, clip-path 1s, opacity 1s;
  transition: width 0.6s, clip-path 1s, opacity 1s, -webkit-clip-path 1s;
}
.main-service .service-wrap .service-list .list-item.active-ani {
  opacity: 1;
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
          clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
}
.main-service .service-wrap .service-list .list-item:not(.active) {
  width: 10%;
}
.main-service .service-wrap .service-list .list-item:not(.active) .text-box {
  padding: 5vw 2.5vw;
  padding-right: unset !important;
}
.main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner {
  transform: translateY(164px);
  opacity: 0.9;
}
.main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .service-title {
  margin-top: 20px;
}
.main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .service-title span {
  font-size: 0.57em;
}
.main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .service-desc {
  opacity: 0;
}
.main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .hash-list {
  opacity: 0;
}
.main-service .service-wrap .service-list .list-item.active {
  width: 70%;
}
.main-service .service-wrap .service-list .list-item.active .bg-box::before {
  background-color: rgba(0, 0, 0, 0.2);
}
.main-service .service-wrap .service-list .list-item.active .text-box {
  padding: 5vw;
}
.main-service .service-wrap .service-list .list-item.active .text-box .text-inner .service-min {
  text-shadow: 3px 3px 5px rgba(0, 0, 0, 0.2);
}
.main-service .service-wrap .service-list .list-item.active .text-box .text-inner .service-title {
  margin-top: 30px;
  text-shadow: 3px 3px 5px rgba(0, 0, 0, 0.2);
}
.main-service .service-wrap .service-list .list-item.active .text-box .text-inner .service-desc {
  opacity: 1;
  text-shadow: 3px 3px 5px rgba(0, 0, 0, 0.2);
}
.main-service .service-wrap .service-list .list-item.active .text-box .text-inner .hash-list {
  opacity: 1;
  flex-wrap: wrap;
}
.main-service .service-wrap .service-list .list-item .bg-box {
  position: relative;
  width: 100%;
  height: 100%;
}
.main-service .service-wrap .service-list .list-item .bg-box::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background-color: rgba(0, 0, 0, 0.4);
  transition: background-color 0.6s;
}
.main-service .service-wrap .service-list .list-item .bg-box img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}
.main-service .service-wrap .service-list .list-item .text-box {
  z-index: 1;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  padding: 70px 5vw;
  color: #FFF;
  overflow: hidden;
  transition: padding 0.6s;
}
.main-service .service-wrap .service-list .list-item .text-box .text-inner {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  overflow: hidden;
  transition: transform 0.6s, opacity 0.6s;
}
.main-service .service-wrap .service-list .list-item .text-box .text-inner .service-min {
  white-space: nowrap;
  transition: text-shadow 0.6s;
}
.main-service .service-wrap .service-list .list-item .text-box .text-inner .service-title {
  line-height: 0;
  white-space: nowrap;
  transition: text-shadow 0.6s, margin-top 0.6s;
}
.main-service .service-wrap .service-list .list-item .text-box .text-inner .service-title span {
  transition: font-size 0.6s;
}
.main-service .service-wrap .service-list .list-item .text-box .text-inner .service-desc {
  line-height: 1.5;
  margin-top: 30px;
  white-space: nowrap;
  transition: opacity 0.6s, text-shadow 0.6s, height 0.6s;
}
.main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list {
  display: flex;
  width: 600px;
  gap: 10px;
  margin-top: 40px;
  transition: flex-wrap 0.6s, opacity 0.6s, height 0.6s;
}
.main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list li {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
  height: 40px;
  border-radius: 40px;
  box-sizing: border-box;
  padding: 0 20px;
  border: 1px solid #FFF;
  white-space: nowrap;
}

.main-consult {
  z-index: 1;
  position: relative;
  background-color: #fff;
}
.main-consult .consult-wrap form {
  display: block;
}
.main-consult .consult-wrap .form-inner {
  opacity: 0;
  transition: opacity 1.5s;
}
.main-consult .consult-wrap .form-inner.active {
  opacity: 1;
}
.main-consult .consult-wrap .form-inner .required-text {
  display: block;
}
.main-consult .consult-wrap .form-inner .input-box + .input-box {
  margin-top: 45px;
}
.main-consult .consult-wrap .form-inner .input-box .radio-list {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}
.main-consult .consult-wrap .form-inner .input-box .radio-list li .btn-radio {
  cursor: pointer;
}
.main-consult .consult-wrap .form-inner .input-box .radio-list li .btn-radio .input-check:checked + .text {
  border-color: #e7bc00;
  background-color: #e7bc00;
  color: #FFF;
  font-weight: 600;
}
.main-consult .consult-wrap .form-inner .input-box .radio-list li .btn-radio .text {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 10px;
  box-sizing: border-box;
  border: 1px solid #615f5d;
  padding: 0 20px;
  height: 60px;
  color: #615f5d;
  background-color: transparent;
  font-weight: 500;
  overflow: hidden;
  transition: border-color 0.3s, background-color 0.3s, color 0.3s;
}
.main-consult .consult-wrap .form-inner .input-box .label {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin-bottom: 15px;
}
.main-consult .consult-wrap .form-inner .input-box .input-text,
.main-consult .consult-wrap .form-inner .input-box .input-textarea {
  display: block;
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #ccc;
  font-weight: 500;
  border-radius: 10px;
  transition: border-color 0.3s, box-shadow 0.3s;
}
.main-consult .consult-wrap .form-inner .input-box .input-text:focus,
.main-consult .consult-wrap .form-inner .input-box .input-textarea:focus {
  border-color: #e7bc00;
  box-shadow: 3px 3px 10px rgba(231, 188, 0, 0.25);
}
.main-consult .consult-wrap .form-inner .input-box .input-text::-moz-placeholder, .main-consult .consult-wrap .form-inner .input-box .input-textarea::-moz-placeholder {
  font-weight: inherit;
  font-size: inherit;
  color: #ccc;
}
.main-consult .consult-wrap .form-inner .input-box .input-text::placeholder,
.main-consult .consult-wrap .form-inner .input-box .input-textarea::placeholder {
  font-weight: inherit;
  font-size: inherit;
  color: #ccc;
}
.main-consult .consult-wrap .form-inner .input-box .input-text {
  height: 60px;
  padding: 0 20px;
}
.main-consult .consult-wrap .form-inner .input-box .input-textarea {
  padding: 20px;
  height: 300px;
  line-height: 1.4;
}
.main-consult .consult-wrap .form-inner .input-box .warning-text {
  display: block;
  margin-top: 7px;
  box-sizing: border-box;
  padding: 0 20px;
  opacity: 0.75;
}
.main-consult .consult-wrap .form-inner .terms-box {
  box-sizing: border-box;
  padding: 45px 0;
  border-bottom: 1px solid #ddd;
  display: flex;
  align-items: center;
  gap: 20px;
}
.main-consult .consult-wrap .form-inner .terms-box .btn-terms-check {
  cursor: pointer;
}
.main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .input-check:checked + .check-inner .square {
  border-color: #e7bc00;
  background-color: #e7bc00;
  color: #FFF;
}
.main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .input-check:checked + .check-inner .text::before {
  width: 95%;
}
.main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .check-inner {
  display: flex;
  align-items: center;
  gap: 10px;
}
.main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .check-inner .square {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border: 1px solid #615f5d;
  color: #615f5d;
  background-color: transparent;
  border-radius: 3px;
  box-sizing: border-box;
  transition: border-color 0.3s, color 0.3s, background-color 0.3s;
}
.main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .check-inner .square .icon {
  font-size: 16px;
}
.main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .check-inner .text {
  position: relative;
}
.main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .check-inner .text::before {
  content: "";
  z-index: -1;
  display: block;
  width: 0;
  height: 50%;
  position: absolute;
  left: 0;
  bottom: -15%;
  background-color: rgba(231, 188, 0, 0.5);
  transition: width 0.3s;
}
.main-consult .consult-wrap .form-inner .terms-box .btn-terms-popup {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
  padding: 0 16px;
  height: 50px;
  border-radius: 7px;
  transition: background-color 0.3s;
}
.main-consult .consult-wrap .form-inner .btn-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 0 50px;
  height: 70px;
  border-radius: 13px;
  margin-top: 45px;
}

.main-review {
  z-index: 1;
  position: relative;
  background-color: #fff;
  overflow: hidden;
}
.main-review::before {
  content: "";
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background-color: rgba(0, 0, 0, 0.75);
}
.main-review .bg {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.main-review .review-wrap {
  z-index: 2;
  position: relative;
}
.main-review .review-wrap .review-slider {
  opacity: 0;
  transition: opacity 1.5s;
}
.main-review .review-wrap .review-slider.active {
  opacity: 1;
}
.main-review .review-wrap .review-slider .slider-item {
  position: relative;
  width: 450px;
  height: 312px;
  box-sizing: border-box;
  padding: 50px 30px;
  margin-right: 75px;
}
.main-review .review-wrap .review-slider .slider-item .slider-bg {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.main-review .review-wrap .review-slider .slider-item .text-box {
  z-index: 1;
  position: relative;
}
.main-review .review-wrap .review-slider .slider-item .text-box .review-type {
  display: block;
}
.main-review .review-wrap .review-slider .slider-item .text-box .review-name {
  margin: 20px 0;
}
.main-review .review-wrap .review-slider .slider-item .text-box .review-desc {
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.5;
}
.main-review .review-wrap .slick-dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
}
.main-review .review-wrap .slick-dots li.slick-active .btn-dot {
  background-color: #e7bc00 !important;
}
.main-review .review-wrap .slick-dots li .btn-dot {
  display: flex;
  border-radius: 100%;
  width: 10px;
  height: 10px;
  background-color: rgba(255, 255, 255, 0.25);
  transition: background-color 0.3s;
}

.main-story {
  z-index: 1;
  position: relative;
  background-color: #fff;
  overflow: hidden;
}
.main-story.active .story-wrap .flex-title .slider-btn-box {
  opacity: 1;
}
.main-story .story-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.main-story .story-wrap .flex-title {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
.main-story .story-wrap .flex-title .slider-btn-box {
  display: flex;
  gap: 15px;
  opacity: 0;
  transition: opacity 1.5s;
  transition-delay: 0.3s;
}
.main-story .story-wrap .flex-title .slider-btn-box .btn-slider {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 50px;
  height: 50px;
  border-radius: 100%;
  border: 1px solid #615f5d;
  color: #615f5d;
  background-color: transparent;
  transition: background-color 0.3s, color 0.3s, border-color 0.3s;
}
.main-story .story-wrap .story-slider {
  width: 95%;
  max-width: calc((100% - 1760px) / 2 + 1760px);
  opacity: 0;
  transition: opacity 1.5s;
}
.main-story .story-wrap .story-slider.active {
  opacity: 1;
}
.main-story .story-wrap .story-slider .slider-item {
  margin-right: 50px;
  width: 550px;
}
.main-story .story-wrap .story-slider .slider-item a {
  display: block;
  width: 100%;
}
.main-story .story-wrap .story-slider .slider-item .bg-box {
  width: 100%;
  height: 415px;
  box-sizing: border-box;
  border: 1px solid #ddd;
  overflow: hidden;
  border-radius: 15px;
}
.main-story .story-wrap .story-slider .slider-item .bg-box img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
  transition: transform 0.6s;
  transition-timing-function: linear;
}
.main-story .story-wrap .story-slider .slider-item .text-box {
  margin-top: 25px;
}
.main-story .story-wrap .story-slider .slider-item .text-box .story-info {
  display: flex;
  align-items: center;
}
.main-story .story-wrap .story-slider .slider-item .text-box .story-subject {
  position: relative;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-top: 25px;
  width: -moz-fit-content;
  width: fit-content;
}
.main-story .story-wrap .story-slider .slider-item .text-box .story-subject::before {
  content: "";
  z-index: -1;
  display: block;
  width: 0;
  height: 50%;
  position: absolute;
  left: 0;
  bottom: 0;
  background-color: rgba(231, 188, 0, 0.5);
  transition: width 0.3s;
}
.main-story .story-wrap .slick-dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
}
.main-story .story-wrap .slick-dots li.slick-active .btn-dot {
  background-color: #e7bc00 !important;
}
.main-story .story-wrap .slick-dots li .btn-dot {
  display: flex;
  border-radius: 100%;
  width: 10px;
  height: 10px;
  background-color: rgba(231, 188, 0, 0.25);
  transition: background-color 0.3s;
}

.main-cta {
  z-index: 1;
  position: relative;
  background-color: #fff;
}
.main-cta .cta-wrap .title-box .main-desc.active .ani-span {
  opacity: 1;
}
.main-cta .cta-wrap .title-box .main-desc .ani-span {
  opacity: 0;
  transition: opacity 1.5s;
}
.main-cta .cta-wrap .title-box .main-desc .ani-span:nth-of-type(2) {
  transition-delay: 0.3s;
}
.main-cta .cta-wrap .title-box .main-desc .ani-span:nth-of-type(3) {
  transition-delay: 0.6s;
}
.main-cta .cta-wrap .title-box .main-desc .ani-span:nth-of-type(4) {
  transition-delay: 0.9s;
}
.main-cta .cta-wrap .cta-box {
  display: flex;
  gap: 30px;
}
.main-cta .cta-wrap .cta-box.active .link-cta {
  transform: translateY(0);
  opacity: 1;
}
.main-cta .cta-wrap .cta-box .link-cta {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 50%;
  height: 200px;
  border-radius: 15px;
  overflow: hidden;
  opacity: 0;
  transform: translateY(70px);
  transition: transform 1.5s, opacity 1.5s;
}
.main-cta .cta-wrap .cta-box .link-cta:nth-of-type(2) {
  transition-delay: 0.3s;
}
.main-cta .cta-wrap .cta-box .link-cta.link-cta-contact::before {
  background-color: rgba(0, 0, 0, 0.6);
}
.main-cta .cta-wrap .cta-box .link-cta::before {
  content: "";
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background-color: rgba(0, 0, 0, 0.75);
}
.main-cta .cta-wrap .cta-box .link-cta .bg {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
  transition: transform 0.6s;
  transition-timing-function: linear;
}
.main-cta .cta-wrap .cta-box .link-cta .cta-title {
  z-index: 2;
  position: relative;
  line-height: 1.4;
}

@media (orientation: portrait) {
  .main-visual .visual-wrap .text-box .text-list li {
    perspective: 10em;
  }
}
@media screen and (min-width: 991.1px) {
  .main-consult .consult-wrap .form-inner .input-box .radio-list li .btn-radio:hover .text {
    border-color: #e7bc00;
    background-color: rgba(231, 188, 0, 0.1);
  }
  .main-consult .consult-wrap .form-inner .input-box .input-text:hover,
  .main-consult .consult-wrap .form-inner .input-box .input-textarea:hover {
    border-color: #e7bc00;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-check:hover .check-inner .text::before {
    width: 95%;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-popup:hover {
    background-color: #333;
  }
  .main-review .review-wrap .slick-dots li .btn-dot:hover {
    background-color: rgba(255, 255, 255, 0.75);
  }
  .main-story .story-wrap .flex-title .slider-btn-box .btn-slider:hover {
    background-color: #e7bc00;
    border-color: #e7bc00;
    color: #fff;
  }
  .main-story .story-wrap .story-slider .slider-item a:hover .bg-box img {
    transform: scale(1.1);
  }
  .main-story .story-wrap .story-slider .slider-item a:hover .text-box .story-subject::before {
    width: 100%;
  }
  .main-story .story-wrap .slick-dots li .btn-dot:hover {
    background-color: rgba(231, 188, 0, 0.75);
  }
  .main-cta .cta-wrap .cta-box .link-cta:hover .bg {
    transform: scale(1.1);
  }
}
@media screen and (max-width: 1600px) {
  .deco-logo {
    width: 115px;
  }
  .main-min .min-inner .deco {
    height: 12px;
  }
  .deco-logo-box + .main-title {
    margin-top: 18px;
  }
  .main-min + .main-title {
    margin-top: 18px;
  }
  .main-visual .visual-wrap .text-box .title-box .title-inner .visual-desc {
    margin-top: 27px;
  }
  .main-service .service-wrap .service-list .list-item {
    height: 900px;
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner {
    transform: translateY(152px);
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .service-title {
    margin-top: 18px;
  }
  .main-service .service-wrap .service-list .list-item.active .text-box .text-inner .service-title {
    margin-top: 27px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .service-desc {
    margin-top: 27px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list {
    width: 540px;
    gap: 9px;
    margin-top: 36px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list li {
    height: 38px;
    padding: 0 19px;
  }
  .main-consult .consult-wrap .form-inner .input-box + .input-box {
    margin-top: 40px;
  }
  .main-consult .consult-wrap .form-inner .input-box .radio-list {
    gap: 14px;
  }
  .main-consult .consult-wrap .form-inner .input-box .radio-list li .btn-radio .text {
    padding: 0 19px;
    height: 57px;
  }
  .main-consult .consult-wrap .form-inner .input-box .label {
    margin-bottom: 14px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-text {
    height: 57px;
    padding: 0 19px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-textarea {
    padding: 19px;
    height: 285px;
  }
  .main-consult .consult-wrap .form-inner .input-box .warning-text {
    padding: 0 19px;
  }
  .main-consult .consult-wrap .form-inner .terms-box {
    padding: 40px 0;
    gap: 18px;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .check-inner {
    gap: 9px;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-popup {
    padding: 0 15px;
    height: 47px;
  }
  .main-consult .consult-wrap .form-inner .btn-submit {
    padding: 0 47px;
    height: 67px;
    margin-top: 40px;
  }
  .main-review .review-wrap .review-slider .slider-item {
    width: 405px;
    height: 280.8px;
    padding: 45px 27px;
    margin-right: 68px;
  }
  .main-review .review-wrap .review-slider .slider-item .text-box .review-name {
    margin: 18px 0;
  }
  .main-story .story-wrap .flex-title .slider-btn-box {
    gap: 13px;
  }
  .main-story .story-wrap .flex-title .slider-btn-box .btn-slider {
    width: 45px;
    height: 45px;
  }
  .main-story .story-wrap .story-slider .slider-item {
    margin-right: 45px;
    width: 500px;
  }
  .main-story .story-wrap .story-slider .slider-item .bg-box {
    height: 375px;
  }
  .main-story .story-wrap .story-slider .slider-item .text-box {
    margin-top: 23px;
  }
  .main-story .story-wrap .story-slider .slider-item .text-box .story-subject {
    margin-top: 23px;
  }
  .main-cta .cta-wrap .cta-box {
    gap: 27px;
  }
  .main-cta .cta-wrap .cta-box .link-cta {
    height: 180px;
  }
}
@media screen and (max-width: 1300px) {
  .deco-logo {
    width: 107px;
  }
  .main-min .min-inner .deco {
    height: 11px;
  }
  .deco-logo-box + .main-title {
    margin-top: 16px;
  }
  .main-min + .main-title {
    margin-top: 16px;
  }
  .main-visual .visual-wrap .text-box .title-box .title-inner .visual-desc {
    margin-top: 24px;
  }
  .main-service .service-wrap .service-list .list-item {
    height: 800px;
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner {
    transform: translateY(140px);
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .service-title {
    margin-top: 16px;
  }
  .main-service .service-wrap .service-list .list-item.active .text-box .text-inner .service-title {
    margin-top: 24px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .service-desc {
    margin-top: 24px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list {
    width: 480px;
    gap: 8px;
    margin-top: 32px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list li {
    height: 36px;
    padding: 0 18px;
  }
  .main-consult .consult-wrap .form-inner .input-box + .input-box {
    margin-top: 35px;
  }
  .main-consult .consult-wrap .form-inner .input-box .radio-list {
    gap: 13px;
  }
  .main-consult .consult-wrap .form-inner .input-box .radio-list li .btn-radio .text {
    padding: 0 18px;
    height: 54px;
  }
  .main-consult .consult-wrap .form-inner .input-box .label {
    margin-bottom: 13px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-text {
    height: 54px;
    padding: 0 18px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-textarea {
    padding: 18px;
    height: 270px;
  }
  .main-consult .consult-wrap .form-inner .input-box .warning-text {
    padding: 0 18px;
  }
  .main-consult .consult-wrap .form-inner .terms-box {
    padding: 35px 0;
    gap: 16px;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .check-inner {
    gap: 8px;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-popup {
    padding: 0 14px;
    height: 44px;
  }
  .main-consult .consult-wrap .form-inner .btn-submit {
    padding: 0 44px;
    height: 64px;
    margin-top: 35px;
  }
  .main-review .review-wrap .review-slider .slider-item {
    width: 360px;
    height: 249.6px;
    padding: 40px 24px;
    margin-right: 61px;
  }
  .main-review .review-wrap .review-slider .slider-item .text-box .review-name {
    margin: 16px 0;
  }
  .main-review .review-wrap .review-slider .slider-item .text-box .review-desc {
    -webkit-line-clamp: 4;
  }
  .main-story .story-wrap .flex-title .slider-btn-box {
    gap: 11px;
  }
  .main-story .story-wrap .flex-title .slider-btn-box .btn-slider {
    width: 40px;
    height: 40px;
  }
  .main-story .story-wrap .story-slider .slider-item {
    margin-right: 40px;
    width: 450px;
  }
  .main-story .story-wrap .story-slider .slider-item .bg-box {
    height: 335px;
  }
  .main-story .story-wrap .story-slider .slider-item .text-box {
    margin-top: 21px;
  }
  .main-story .story-wrap .story-slider .slider-item .text-box .story-subject {
    margin-top: 21px;
  }
  .main-cta .cta-wrap .cta-box {
    gap: 24px;
  }
  .main-cta .cta-wrap .cta-box .link-cta {
    height: 160px;
  }
}
@media screen and (max-width: 991px) {
  .deco-logo {
    width: 99px;
  }
  .main-min .min-inner .deco {
    height: 10px;
  }
  .deco-logo-box + .main-title {
    margin-top: 14px;
  }
  .main-min + .main-title {
    margin-top: 14px;
  }
  .main-visual .visual-wrap .text-box .title-box .title-inner .visual-desc {
    margin-top: 21px;
  }
  .main-service .service-wrap .service-list .list-item {
    height: 700px;
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner {
    transform: translateY(128px);
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .service-title {
    margin-top: 14px;
  }
  .main-service .service-wrap .service-list .list-item.active .text-box .text-inner .service-title {
    margin-top: 21px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .service-desc {
    margin-top: 21px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list {
    width: 420px;
    gap: 7px;
    margin-top: 28px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list li {
    height: 34px;
    padding: 0 17px;
  }
  .main-consult .consult-wrap .form-inner .input-box + .input-box {
    margin-top: 30px;
  }
  .main-consult .consult-wrap .form-inner .input-box .radio-list {
    gap: 12px;
  }
  .main-consult .consult-wrap .form-inner .input-box .radio-list li .btn-radio .text {
    padding: 0 17px;
    height: 51px;
  }
  .main-consult .consult-wrap .form-inner .input-box .label {
    margin-bottom: 12px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-text {
    height: 51px;
    padding: 0 17px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-textarea {
    padding: 17px;
    height: 255px;
  }
  .main-consult .consult-wrap .form-inner .input-box .warning-text {
    padding: 0 17px;
  }
  .main-consult .consult-wrap .form-inner .terms-box {
    padding: 30px 0;
    gap: 14px;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .check-inner {
    gap: 7px;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .check-inner .square {
    width: 18px;
    height: 18px;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-check .check-inner .square .icon {
    font-size: 15px;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-popup {
    padding: 0 13px;
    height: 41px;
  }
  .main-consult .consult-wrap .form-inner .btn-submit {
    padding: 0 41px;
    height: 61px;
    margin-top: 30px;
  }
  .main-review .review-wrap .review-slider .slider-item {
    width: 315px;
    height: 218.4px;
    padding: 35px 21px;
    margin-right: 54px;
  }
  .main-review .review-wrap .review-slider .slider-item .text-box .review-name {
    margin: 14px 0;
  }
  .main-story .story-wrap .flex-title .slider-btn-box {
    gap: 10px;
  }
  .main-story .story-wrap .flex-title .slider-btn-box .btn-slider {
    width: 35px;
    height: 35px;
  }
  .main-story .story-wrap .story-slider .slider-item {
    margin-right: 35px;
    width: 400px;
  }
  .main-story .story-wrap .story-slider .slider-item .bg-box {
    height: 295px;
  }
  .main-story .story-wrap .story-slider .slider-item .text-box {
    margin-top: 19px;
  }
  .main-story .story-wrap .story-slider .slider-item .text-box .story-subject {
    margin-top: 19px;
  }
  .main-cta .cta-wrap .cta-box {
    gap: 21px;
  }
  .main-cta .cta-wrap .cta-box .link-cta {
    height: 140px;
  }
}
@media screen and (max-width: 750px) {
  .main-service .service-wrap .service-list {
    flex-direction: column;
  }
  .main-service .service-wrap .service-list .list-item {
    width: 100% !important;
    height: auto;
  }
  .main-service .service-wrap .service-list .list-item:not(.active) {
    width: unset;
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box {
    padding: 7.5vw 5vw;
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner {
    transform: translateY(49px);
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .service-desc {
    height: 0;
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .hash-list {
    height: 0;
  }
  .main-service .service-wrap .service-list .list-item.active {
    width: unset;
  }
  .main-service .service-wrap .service-list .list-item.active .text-box {
    padding: 15vw 5vw 7.5vw 5vw;
  }
  .main-service .service-wrap .service-list .list-item .bg-box {
    position: absolute;
    left: 0;
    top: 0;
  }
  .main-service .service-wrap .service-list .list-item .text-box {
    position: relative;
    left: unset;
    bottom: unset;
    height: auto;
  }
}
@media screen and (max-width: 600px) {
  .deco-logo {
    width: 91px;
  }
  .main-min .min-inner .deco {
    height: 9px;
  }
  .deco-logo-box + .main-title {
    margin-top: 12px;
  }
  .main-min + .main-title {
    margin-top: 12px;
  }
  .main-visual .visual-wrap .text-box .title-box .title-inner .visual-desc {
    margin-top: 18px;
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner {
    transform: translateY(42px);
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .service-title {
    margin-top: 12px;
  }
  .main-service .service-wrap .service-list .list-item.active .text-box .text-inner .service-title {
    margin-top: 18px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .service-desc {
    margin-top: 18px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list {
    width: 85%;
    gap: 6px;
    margin-top: 24px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list li {
    height: 32px;
    padding: 0 16px;
  }
  .main-consult .consult-wrap .form-inner .input-box + .input-box {
    margin-top: 27px;
  }
  .main-consult .consult-wrap .form-inner .input-box .radio-list {
    gap: 11px;
  }
  .main-consult .consult-wrap .form-inner .input-box .radio-list li .btn-radio .text {
    padding: 0 16px;
    height: 48px;
    border-radius: 7px;
  }
  .main-consult .consult-wrap .form-inner .input-box .label {
    margin-bottom: 11px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-text,
  .main-consult .consult-wrap .form-inner .input-box .input-textarea {
    border-radius: 7px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-text {
    height: 48px;
    padding: 0 16px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-textarea {
    padding: 16px;
    height: 240px;
  }
  .main-consult .consult-wrap .form-inner .input-box .warning-text {
    padding: 0 16px;
  }
  .main-consult .consult-wrap .form-inner .terms-box {
    padding: 27px 0;
    gap: 12px;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-popup {
    padding: 0 12px;
    height: 38px;
    border-radius: 5px;
  }
  .main-consult .consult-wrap .form-inner .btn-submit {
    padding: 0 38px;
    height: 58px;
    margin-top: 27px;
    border-radius: 10px;
  }
  .main-review .review-wrap .review-slider .slider-item {
    width: 270px;
    height: 187.2px;
    padding: 30px 18px;
    margin-right: 47px;
  }
  .main-review .review-wrap .review-slider .slider-item .text-box .review-name {
    margin: 12px 0;
  }
  .main-review .review-wrap .review-slider .slider-item .text-box .review-desc br {
    display: none;
  }
  .main-story .story-wrap .story-slider .slider-item {
    margin-right: 30px;
    width: 350px;
  }
  .main-story .story-wrap .story-slider .slider-item .bg-box {
    height: 255px;
    border-radius: 10px;
  }
  .main-story .story-wrap .story-slider .slider-item .text-box {
    margin-top: 17px;
  }
  .main-story .story-wrap .story-slider .slider-item .text-box .story-subject {
    margin-top: 17px;
  }
  .main-cta .cta-wrap .cta-box {
    gap: 15px;
  }
  .main-cta .cta-wrap .cta-box .link-cta {
    height: 120px;
    border-radius: 10px;
  }
}
@media screen and (max-width: 450px) {
  .deco-logo {
    width: 83px;
  }
  .main-min .min-inner .deco {
    height: 8px;
  }
  .deco-logo-box + .main-title {
    margin-top: 10px;
  }
  .main-min + .main-title {
    margin-top: 10px;
  }
  .main-visual .visual-wrap .text-box .title-box .title-inner .visual-desc {
    margin-top: 15px;
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner {
    transform: translateY(35px);
  }
  .main-service .service-wrap .service-list .list-item:not(.active) .text-box .text-inner .service-title {
    margin-top: 10px;
  }
  .main-service .service-wrap .service-list .list-item.active .text-box .text-inner .service-title {
    margin-top: 15px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .service-desc {
    margin-top: 15px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list {
    width: 100%;
    gap: 5px;
    margin-top: 20px;
  }
  .main-service .service-wrap .service-list .list-item .text-box .text-inner .hash-list li {
    height: 30px;
    padding: 0 15px;
  }
  .main-consult .consult-wrap .form-inner .input-box + .input-box {
    margin-top: 25px;
  }
  .main-consult .consult-wrap .form-inner .input-box .radio-list {
    gap: 10px;
  }
  .main-consult .consult-wrap .form-inner .input-box .radio-list li .btn-radio .text {
    padding: 0 15px;
    height: 45px;
  }
  .main-consult .consult-wrap .form-inner .input-box .label {
    margin-bottom: 10px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-text {
    height: 45px;
    padding: 0 15px;
  }
  .main-consult .consult-wrap .form-inner .input-box .input-textarea {
    padding: 15px;
    height: 225px;
  }
  .main-consult .consult-wrap .form-inner .input-box .warning-text {
    padding: 0 15px;
  }
  .main-consult .consult-wrap .form-inner .terms-box {
    padding: 25px 0;
    gap: 10px;
  }
  .main-consult .consult-wrap .form-inner .terms-box .btn-terms-popup {
    padding: 0 11px;
    height: 35px;
  }
  .main-consult .consult-wrap .form-inner .btn-submit {
    padding: 0 35px;
    height: 55px;
    margin-top: 25px;
  }
  .main-review .review-wrap .review-slider .slider-item {
    width: 247.5px;
    height: 173.25px;
    padding: 28px 16px;
    margin-right: 40px;
  }
  .main-review .review-wrap .review-slider .slider-item .text-box .review-name {
    margin: 10px 0;
  }
  .main-story .story-wrap .story-slider .slider-item {
    margin-right: 25px;
    width: 300px;
  }
  .main-story .story-wrap .story-slider .slider-item .bg-box {
    height: 215px;
  }
  .main-story .story-wrap .story-slider .slider-item .text-box {
    margin-top: 15px;
  }
  .main-story .story-wrap .story-slider .slider-item .text-box .story-subject {
    margin-top: 15px;
  }
  .main-cta .cta-wrap .cta-box {
    gap: 10px;
  }
  .main-cta .cta-wrap .cta-box .link-cta {
    height: 100px;
  }
}