.orderpage-concept {
  padding-top: 100px;
}
.orderpage-concept .heading {
  text-align: center;
  opacity: 0;
  transform: translateY(50px);
}
.orderpage-concept .heading h2 {
  font-size: 4.2rem;
  font-weight: 400;
  color: #222222;
}
.orderpage-concept .content {
  margin-top: 56px;
}
.orderpage-concept .content .desc {
  text-align: center;
  line-height: 2.4;
  opacity: 0;
  transform: translateY(50px);
}
.orderpage-concept .content .images {
  margin-top: 56px;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
.orderpage-concept .content .images .image {
  width: 24%;
  aspect-ratio: 1/0.9;
  overflow: hidden;
  opacity: 0;
}
.orderpage-concept .content .images .image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.orderpage-concept.visible .heading {
  opacity: 1;
  transform: translateY(0);
  transition-duration: 1.5s;
  transition-delay: 0.25s;
}
.orderpage-concept.visible .content .desc {
  opacity: 1;
  transform: translateY(0);
  transition-duration: 1.5s;
  transition-delay: 1.1s;
}
.orderpage-concept.visible .content .images .image {
  opacity: 1;
  transition-duration: 1s;
}
.orderpage-concept.visible .content .images .image:nth-of-type(1) {
  transition-delay: 2s;
}
.orderpage-concept.visible .content .images .image:nth-of-type(2) {
  transition-delay: 2.5s;
}
.orderpage-concept.visible .content .images .image:nth-of-type(3) {
  transition-delay: 3s;
}
.orderpage-concept.visible .content .images .image:nth-of-type(4) {
  transition-delay: 3.5s;
}

.orderpage-lineup {
  margin-top: 100px;
  padding-top: 100px;
  padding-bottom: 100px;
  background-color: #F5F2EC;
}
.orderpage-lineup .heading-gr {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.orderpage-lineup .heading-gr .heading {
  text-align: center;
}
.orderpage-lineup .content {
  margin-top: 56px;
}
.orderpage-lineup .content > ul {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.orderpage-lineup .content > ul > li {
  position: relative;
  background-color: #fff;
  padding: 40px;
  display: flex;
  align-items: flex-end;
  box-shadow: 5px 5px 10px 0 rgba(0, 0, 0, 0.16);
}
.orderpage-lineup .content > ul > li:nth-of-type(1)::after {
  background-image: url(../img/order/lineup/txt-s.svg);
}
.orderpage-lineup .content > ul > li:nth-of-type(2)::after {
  background-image: url(../img/order/lineup/txt-rs.svg);
}
.orderpage-lineup .content > ul > li:nth-of-type(3)::after {
  background-image: url(../img/order/lineup/txt-n.svg);
}
.orderpage-lineup .content > ul > li:nth-of-type(4)::after {
  background-image: url(../img/order/lineup/txt-ne.svg);
}
.orderpage-lineup .content > ul > li::before {
  width: 145px;
  height: 145px;
  content: "";
  -webkit-clip-path: polygon(0 0, 0% 100%, 100% 0);
          clip-path: polygon(0 0, 0% 100%, 100% 0);
  background-color: #F5F2EC;
  position: absolute;
  top: 0;
  left: 0;
}
.orderpage-lineup .content > ul > li::after {
  content: "";
  width: 145px;
  height: 145px;
  position: absolute;
  top: 40px;
  left: 0;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  text-align: center;
}
.orderpage-lineup .content > ul > li .txt-gr {
  padding-left: 145px;
  padding-right: 32px;
  width: calc(100% - 530px);
}
.orderpage-lineup .content > ul > li .txt-gr h3 {
  margin-bottom: 24px;
  color: #222222;
  font-weight: 600;
  font-size: 2.8rem;
}
.orderpage-lineup .content > ul > li .txt-gr .box {
  margin-top: 24px;
  padding: 32px;
  background-color: #F5F2EC;
}
.orderpage-lineup .content > ul > li .txt-gr .box ul li {
  color: #222222;
  font-size: 1.6rem;
}
.orderpage-lineup .content > ul > li .txt-gr .box .childheading {
  color: #A2A28F;
  font-weight: 600;
  font-size: 2rem;
  margin-bottom: 16px;
}
.orderpage-lineup .content > ul > li .txt-gr .box ul li {
  padding: 8px 0 16px 32px;
  position: relative;
}
.orderpage-lineup .content > ul > li .txt-gr .box ul li::before {
  position: absolute;
  top: 8px;
  left: 0;
  content: "";
  width: 28px;
  height: 25px;
  background-image: url(../img/order/lineup/icon-check.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
}
.orderpage-lineup .content > ul > li .image {
  width: 530px;
}

.orderpage-comparison {
  padding-top: 100px;
  padding-bottom: 100px;
}
.orderpage-comparison .content {
  margin-top: 56px;
}
.orderpage-comparison .content .table-outer {
  position: relative;
  padding: 40px 8px 0;
}
.orderpage-comparison .content table {
  position: relative;
  z-index: 0;
  width: 100%;
  border: solid #ccc 1px;
}
.orderpage-comparison .content table::after {
  content: "";
  position: absolute;
  left: 15.727273%;
  top: -40px;
  z-index: 101;
  width: 28.545455%;
  height: calc(100% + 40px);
  pointer-events: none;
  border: solid 3.5px #CBBC9E;
}
.orderpage-comparison .content table thead {
  width: 100%;
}
.orderpage-comparison .content table thead tr th {
  border: solid #ccc 1px;
  padding: 24px 16px;
  font-size: 1.6rem;
  text-align: center;
  background-color: #fff;
  width: 28.545455%;
  position: relative;
  z-index: 0;
}
.orderpage-comparison .content table thead tr th .logo {
  position: absolute;
  top: -13px;
  left: 0;
  z-index: 2;
  width: 100%;
  font-size: 2.2rem;
  height: 100%;
  color: #fff;
}
.orderpage-comparison .content table thead tr th:first-of-type {
  color: #fff;
  background-color: #777;
  width: 15.727273%;
}
.orderpage-comparison .content table thead tr th:nth-of-type(2) {
  position: relative;
}
.orderpage-comparison .content table thead tr th:nth-of-type(2)::after {
  content: "";
  position: absolute;
  z-index: 0;
  pointer-events: none;
  height: calc(100% + 40px);
  width: 100%;
  top: -40px;
  left: 0;
  background-color: #CBBC9E;
}
.orderpage-comparison .content table thead tr th:last-of-type {
  position: relative;
  background-color: #fff;
}
.orderpage-comparison .content table thead tr th:last-of-type .image {
  position: absolute;
  left: 5%;
  width: 90%;
  top: 40%;
  z-index: 101;
  transform: translateY(-50%);
}
.orderpage-comparison .content table tbody tr {
  border-bottom: dashed #ccc 1px;
}
.orderpage-comparison .content table tbody tr:nth-of-type(even) {
  background-color: #fff;
}
.orderpage-comparison .content table tbody tr:nth-of-type(odd) {
  background-color: #F5F2EC;
}
.orderpage-comparison .content table tbody tr th {
  padding: 24px 16px;
  border-right: solid 1px #ccc;
  width: 15.727273%;
  font-size: 1.6rem;
  color: #2D5691;
}
.orderpage-comparison .content table tbody tr th:first-of-type {
  color: #fff;
  background-color: #323232;
  width: 15%;
}
.orderpage-comparison .content table tbody tr td {
  padding: 24px 16px;
  width: 28.33%;
  border-right: solid 1px #ccc;
  text-align: center;
  font-size: 1.6rem;
}
.orderpage-comparison .content table tbody tr td:first-of-type {
  color: #222222;
  font-weight: 600;
  font-size: 1.6rem;
}

.orderpage-works {
  padding-top: 100px;
  padding-bottom: 100px;
}
.orderpage-works .content {
  margin-top: 56px;
}
.orderpage-works .content .static-list .static-wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
}
.orderpage-works .content .static-list .static-wrapper .item {
  width: 25%;
}
.orderpage-works .content .btn {
  margin-top: 56px;
  text-align: center;
}

.orderpage-flow {
  padding-top: 100px;
  padding-bottom: 100px;
  background-color: #F5F2EC;
}
.orderpage-flow .content {
  margin-top: 72px;
}
.orderpage-flow .content .items ol {
  display: flex;
  justify-content: space-between;
}
.orderpage-flow .content .items ol li {
  position: relative;
  width: 22%;
  background-color: #fff;
  padding: 40px 24px;
  border-radius: 10px;
  opacity: 0;
  transform: translateX(-50px);
}
.orderpage-flow .content .items ol li::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -5.3%;
  transform: translateY(-50%) translateX(100%);
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/order/flow/icon-arrow.svg);
  width: 29px;
  height: 26px;
}
.orderpage-flow .content .items ol li:last-of-type::after {
  display: none;
}
.orderpage-flow .content .items ol li .num-gr {
  padding: 8px 0;
  position: absolute;
  top: 0;
  left: 10%;
  width: 80%;
  background-color: #A2A28F;
  border-radius: 10px 10px 0 0;
  font-size: 1.6rem;
  color: #fff;
  transform: translateY(-100%);
  text-align: center;
}
.orderpage-flow .content .items ol li .num-gr .num {
  margin-left: 2.4px;
  font-size: 2.4rem;
}
.orderpage-flow .content .items ol li .heading-gr {
  position: relative;
}
.orderpage-flow .content .items ol li .heading-gr h3 {
  font-size: 2rem;
  font-weight: 600;
  text-align: center;
}
.orderpage-flow .content .items ol li .heading-gr .caution {
  position: absolute;
  left: 0;
  width: 100%;
  bottom: -28px;
  margin-top: 8px;
  font-size: 1.4rem;
  text-align: center;
  color: #222;
}
.orderpage-flow .content .items ol li .illust {
  margin-top: 40px;
  width: 75%;
  margin-left: auto;
  margin-right: auto;
}
.orderpage-flow .content .items ol li .illust img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.orderpage-flow .content .items ol li .desc {
  margin-top: 16px;
}
.orderpage-flow .content .items ol li .desc p {
  font-size: 1.6rem;
  line-height: 2;
}
.orderpage-flow .content .items ol.visible li {
  opacity: 1;
  transform: translateX(0);
  transition-duration: 1.5s;
}
.orderpage-flow .content .items ol.visible li:nth-of-type(1) {
  transition-delay: 0;
}
.orderpage-flow .content .items ol.visible li:nth-of-type(2) {
  transition-delay: 0.75s;
}
.orderpage-flow .content .items ol.visible li:nth-of-type(3) {
  transition-delay: 1.25s;
}
.orderpage-flow .content .items ol.visible li:nth-of-type(4) {
  transition-delay: 1.75s;
}

.orderpage-faq {
  padding-top: 100px;
  padding-bottom: 100px;
}
.orderpage-faq .content {
  margin-top: 56px;
}
.orderpage-faq .content .faq-group {
  margin-top: 40px;
}
.orderpage-faq .content .faq-group .faq-group__title {
  font-size: 3.2rem;
  font-weight: 600;
  color: #3A6F53;
}
.orderpage-faq .content .faq-group .faq-group__list {
  margin-top: 16px;
  background-color: #F5F2EC;
  padding: 32px;
}
.orderpage-faq .content .faq-group .faq-group__list .faq-item {
  border-bottom: solid 1px #ccc;
  padding: 24px 0;
}
.orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question {
  position: relative;
  font-size: 2rem;
  font-weight: 600;
}
.orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question::marker {
  display: none;
}
.orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question .txt {
  padding-right: 16px;
  display: block;
}
.orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question i {
  position: absolute;
  right: 16px;
  top: 3px;
}
.orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question i::after {
  font-family: "Font Awesome 6 Free";
  content: "+";
  font-weight: 900;
  font-size: 2.2rem;
  color: #3A6F53;
  margin-left: 16px;
}
.orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question.is-open i::after {
  content: "-";
  font-size: 2.2rem;
}
.orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__answer {
  margin-top: 16px;
  font-size: 1.6rem;
  line-height: 2;
  font-weight: 400;
}

@media screen and (max-width: 768px) {
  .orderpage-concept {
    padding-left: 16px;
    padding-right: 16px;
    padding-top: 40px;
  }
  .orderpage-concept .heading h2 {
    font-size: 2.4rem;
    line-height: 1.8;
  }
  .orderpage-concept .content {
    margin-top: 24px;
  }
  .orderpage-concept .content .desc {
    text-align: center;
    line-height: 2;
  }
  .orderpage-concept .content .images {
    margin-top: 24px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 8px 0;
  }
  .orderpage-concept .content .images .image {
    width: 48.75%;
  }
  .orderpage-lineup {
    margin-top: 40px;
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .orderpage-lineup .heading-gr {
    display: block;
  }
  .orderpage-lineup .heading-gr h2 {
    font-size: 2.4rem;
  }
  .orderpage-lineup .content {
    margin-top: 24px;
  }
  .orderpage-lineup .content > ul {
    gap: 16px;
  }
  .orderpage-lineup .content > ul > li {
    padding: 24px 16px;
    flex-direction: column-reverse;
  }
  .orderpage-lineup .content > ul > li::before {
    width: 64px;
    height: 64px;
  }
  .orderpage-lineup .content > ul > li::after {
    width: 64px;
    height: 64px;
    top: 16px;
  }
  .orderpage-lineup .content > ul > li .txt-gr {
    margin-top: 24px;
    padding-left: 0px;
    padding-right: 0px;
    width: 100%;
  }
  .orderpage-lineup .content > ul > li .txt-gr h3 {
    margin-bottom: 12px;
    font-size: 2rem;
    border-bottom: solid 1px #ccc;
    padding-bottom: 8px;
  }
  .orderpage-lineup .content > ul > li .txt-gr .box {
    margin-top: 12px;
    padding: 16px;
  }
  .orderpage-lineup .content > ul > li .txt-gr .box ul li {
    font-size: 1.4rem;
  }
  .orderpage-lineup .content > ul > li .txt-gr .box .childheading {
    font-size: 1.6rem;
  }
  .orderpage-lineup .content > ul > li .txt-gr .box ul li {
    padding: 8px 0 16px 24px;
  }
  .orderpage-lineup .content > ul > li .txt-gr .box ul li::before {
    top: 8px;
    left: 0;
    width: 20px;
    height: 20px;
  }
  .orderpage-lineup .content > ul > li .image {
    width: calc(100% - 17px);
    margin-left: auto;
    margin-right: 0;
    margin-top: 16px;
  }
  .orderpage-comparison {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .orderpage-comparison .content {
    margin-top: 28px;
  }
  .orderpage-comparison .content .table-outer {
    width: 100%;
    padding-bottom: 12px;
    overflow-x: auto;
  }
  .orderpage-comparison .content table {
    width: 720px;
  }
  .orderpage-comparison .content table thead tr th {
    padding: 12px 12px;
    font-size: 1.4rem;
  }
  .orderpage-comparison .content table thead tr th .logo {
    position: absolute;
    top: -20px;
    font-size: 1.6rem;
  }
  .orderpage-comparison .content table tbody tr th {
    padding: 24px 16px;
    width: 15.727273%;
    font-size: 1.4rem;
  }
  .orderpage-comparison .content table tbody tr td {
    padding: 24px 16px;
    width: 28.545455%;
    text-align: center;
    font-size: 1.4rem;
  }
  .orderpage-works {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .orderpage-works .content {
    margin-top: 28px;
  }
  .orderpage-works .content .static-list {
    padding-left: 16px;
    padding-right: 16px;
  }
  .orderpage-works .content .static-list .static-wrapper {
    display: flex;
    justify-content: space-between;
    gap: 16px 0;
  }
  .orderpage-works .content .static-list .static-wrapper .item {
    width: 48.75%;
  }
  .orderpage-works .content .btn {
    margin-top: 28px;
  }
  .orderpage-flow {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .orderpage-flow .content {
    margin-top: 48px;
  }
  .orderpage-flow .content .items ol {
    display: flex;
    flex-direction: column;
    gap: 40px;
  }
  .orderpage-flow .content .items ol li {
    position: relative;
    width: calc(100% - 32px);
    margin-left: auto;
    margin-right: auto;
    padding: 24px 16px;
    border-radius: 8px;
    margin-top: 16px;
    background-color: #fff;
  }
  .orderpage-flow .content .items ol li::after {
    top: inherit;
    bottom: -32px;
    left: 50%;
    transform: rotate(90deg) translateX(-50%);
    transform-origin: top;
    width: 20px;
    height: 20px;
  }
  .orderpage-flow .content .items ol li:last-of-type::after {
    display: none;
  }
  .orderpage-flow .content .items ol li .num-gr {
    padding: 4px 0;
    left: 10%;
    width: 80%;
    font-size: 1.3rem;
  }
  .orderpage-flow .content .items ol li .num-gr .num {
    font-size: 1.8rem;
  }
  .orderpage-flow .content .items ol li .heading-gr {
    position: relative;
  }
  .orderpage-flow .content .items ol li .heading-gr h3 {
    font-size: 2rem;
    font-weight: 600;
    text-align: center;
  }
  .orderpage-flow .content .items ol li .heading-gr .caution {
    bottom: -28px;
    margin-top: 8px;
    font-size: 1.4rem;
  }
  .orderpage-flow .content .items ol li .illust {
    margin-top: 40px;
    width: 65%;
  }
  .orderpage-flow .content .items ol li .desc {
    margin-top: 8px;
  }
  .orderpage-flow .content .items ol li .desc p {
    font-size: 1.4rem;
    line-height: 1.8;
  }
  .orderpage-faq {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .orderpage-faq .content {
    margin-top: 24px;
  }
  .orderpage-faq .content .faq-group {
    margin-top: 24px;
  }
  .orderpage-faq .content .faq-group .faq-group__title {
    font-size: 2rem;
  }
  .orderpage-faq .content .faq-group .faq-group__list {
    margin-top: 12px;
    padding: 24px 16px;
  }
  .orderpage-faq .content .faq-group .faq-group__list .faq-item {
    padding: 16px 0;
  }
  .orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question {
    font-size: 1.6rem;
  }
  .orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question .txt {
    padding-right: 18px;
  }
  .orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question i {
    position: absolute;
    right: 0px;
    top: 4.2px;
  }
  .orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question i::after {
    font-size: 1.6rem;
  }
  .orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__question.is-open i::after {
    content: "-";
    font-size: 2.2rem;
  }
  .orderpage-faq .content .faq-group .faq-group__list .faq-item .faq-item__answer {
    margin-top: 16px;
    font-size: 1.6rem;
    line-height: 2;
    font-weight: 400;
  }
}/*# sourceMappingURL=order.css.map */