@charset 'utf-8';

/* common
------------------------------------------------ */
.hd-top { background: none; }
#main { padding-top: 0; }

@media screen and (max-width: 768px) {
  .topicpath { background-color: #fff; }
  #footer { margin-top: 0; }
}

/* about
------------------------------------------------ */
.about { position: relative; }

/* header
------------------------------------------------ */
.about-hd { position: relative; height: 100vh; background-color: #fff; z-index: 1; }
.about-hd-content { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }
.about-hd-content > .wrap { height: 100%; }
.about-hd-title { position: absolute; top: 170px; left: 30px; }
.about-hd-title--en,
.about-hd-title--ja { line-height: 1.2; }
.about-hd-title--en { font-family: 'Overpass', sans-serif; font-size: 4.2rem; font-weight: 600; }
.about-hd-title--ja { font-size: 1.2rem; font-weight: 700; }
.about-hd-copy { position: absolute; bottom: 104px; left: 30px; width: 154px; }

.about-hd-gallery { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: -1; }
.about-hd-gallery__frame { position: relative; width: 100%; height: 100%; overflow: hidden; }
.about-hd-gallery__move { position: relative; width: 100%; height: 100%; }
.about-hd-gallery--item { display: none; position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }
.about-hd-gallery--item.active { z-index: 2; }
.about-hd-gallery--item picture { position: absolute; top: 0; left: 0; transition: linear 12s; transform: scale(1.2); width: 100%; height: 100%; }
.about-hd-gallery--item.active picture { transform: scale(1); }

.about-hd-scroll { position: absolute; right: 25px; bottom: -25px; transform-origin: top right; transform: rotate(90deg); font-family: 'Overpass', sans-serif; font-size: 1rem; font-weight: 600; line-height: 1.2; z-index: 2; }
.about-hd-scroll > a { display: block; position: relative; padding-right: 75px; color: #998675; }
.about-hd-scroll > a::after { content: ''; position: absolute; top: 4px; left: calc(100% - 60px); width: 0; height: 1px; background-color: #998675; }

.about-hd-title--ja.lazy { transition-delay: 0.2s; }
.about-hd-copy.lazy { transition-delay: 0.4s; }

.about-hd-scroll.active > a::after { animation: ordermadeScroll cubic-bezier(0.4,0.15,0.12,1) 1.25s forwards; }

@keyframes ordermadeScroll {
  0% {
    width: 0;
  }
  100% {
    width: 65px;
  }
}

@media screen and (min-width: 769px) {
  .about-hd-title { top: 204px; left: 50px; }
  .about-hd-title--en { font-size: 5.2rem; }
  .about-hd-title--ja { font-size: 1.8rem; }
  .about-hd-copy { bottom: 168px; left: 50px; width: 276px; }
  .about-hd-scroll { right: 40px; bottom: -17px; font-size: 1.4rem; }
  .about-hd-scroll > a { padding-right: 124px; color: #fff; }
  .about-hd-scroll > a::after { left: calc(100% - 100px); background-color: #fff; }

  @keyframes ordermadeScroll {
    0% {
      width: 0;
    }
    100% {
      width: 100px;
    }
  }
}

/* content
------------------------------------------------ */
.about-content { position: relative; }

/* nav
------------------------------------------------ */
.about-nav { position: relative; }
.about-nav > .frame { position: relative; width: 100%; }
.about-nav-links { display: flex; }
.about-nav-links--item { position: relative; padding-right: 1rem; font-size: 1.35rem; font-weight: 700; line-height: 1.2; }
.about-nav-links--item:first-child { padding-left: 1rem; }
.about-nav-links--item::after,
.about-nav-links--item:first-child::before { content: '\FF5C'; position: absolute; top: 50%; right: 0; transform: translateY(-50%); }
.about-nav-links--item:first-child::before { left: 0; }
.about-nav-links--item > a { display: block; position: relative; padding: 10px 2em; }
.device-click .about-nav-links--item > a::after { content: ''; position: absolute; bottom: 0; left: 2.5em; transition: ease 0.4s; width: calc(100% - 5em); height: 3px; background-color: #534741; opacity: 0; }
.device-click .about-nav-links--item > a:hover::after { opacity: 1; }

@media screen and (max-width: 768px) {
  .about-nav { padding: 15px 0 45px; background-color: #fff; }
  .about-nav > .frame { overflow-x: auto; }
  .about-nav-links { padding: 10px 0; }
  .about-nav-links--item:first-child { padding-left: 30px; }
  .about-nav-links--item:first-child::before { left: 30px; }
  .about-nav-links--item:last-child { padding-right: 30px; }
  .about-nav-links--item:last-child::after { right: 30px; }
  .about-nav-links--item > a { white-space: nowrap; }
}

@media screen and (min-width: 769px) {
  .about-nav { margin-top: 90px; }
  .about-nav-links { flex-wrap: wrap; justify-content: center; }
  .about-nav-links--item { font-size: 1.8rem; }
  .about-nav-links--item > a { padding: 5px 2em; }
}

/* service
------------------------------------------------ */
.about-service { position: relative; }
.about-service-content { position: relative; }
.about-service-detail { position: relative; }
.about-service-detail__block { position: relative; margin-top: 40px; }
.about-service-detail__block:first-child { margin-top: 0; }
.about-service-detail--cat { display: inline-block; margin-bottom: 15px; padding: 5px 9px 2px; background-color: #aea49d; vertical-align: top; color: #fff; }
.about-service-detail--cat > span { display: inline-block; vertical-align: baseline; line-height: 1.2; }
.about-service-detail--cat > span:nth-of-type(1) { font-family: 'Overpass', sans-serif; font-size: 1.5rem; font-weight: 600; }
.about-service-detail--cat > span:nth-of-type(2) { margin-left: 0.2em; font-size: 1.1rem; font-weight: 700; }
.about-service-detail--tgroup { display: flex; position: relative; margin-bottom: 25px; }
.about-service-detail--num { position: relative; width: 36px; height: 36px; text-align: center; font-family: 'Overpass', sans-serif; font-size: 2rem; font-weight: 600; line-height: 40px; }
.about-service-detail--num > svg { position: absolute; top: 0; left: -1px; transform: rotate(-35deg); stroke-dasharray: 100px; width: 100%; height: 100%; }
.about-service-detail--num > svg circle { fill: none; r: 17.5px; stroke: #aea49d; stroke-width: 1px; }
.about-service-detail--title { margin-left: 20px; width: calc(100% - 56px); font-size: 1.8rem; font-weight: 700; line-height: 1.38888888889; }
.about-service-detail--explain { margin-bottom: 34px; font-size: 1.3rem; line-height: 1.84615384615; }
.about-service-detail--explain a { text-decoration: underline; }
.device-click .about-service-detail--explain a:hover { text-decoration: none; }
.about-service-detail__box { position: relative; }
.about-service-detail__box .lists-1 { counter-reset: lists-num 0; border-top: 1px solid #848075; }
.about-service-detail__box .lists-1 > li { border-bottom: 1px solid #848075; }
.about-service-detail__box .lists-1 dl { position: relative; }
.about-service-detail__box .lists-1 dl::before { counter-increment: lists-num 1; content: '0'counter(lists-num)'.'; position: absolute; top: 24px; left: 0; font-family: 'Overpass', sans-serif; font-size: 1.5rem; font-weight: 600; line-height: 1.2; color: #736357; }
.about-service-detail__box .lists-1 dl > dt { position: relative; padding: 20px 40px; font-size: 1.8rem; font-weight: 700; line-height: 1.2; }
.about-service-detail__box .lists-1 dl > dd { display: none; padding-bottom: 20px; font-size: 1.3rem; line-height: 1.84615384615; }
.about-service-detail__box .lists-2 { counter-reset: lists-num 0; }
.about-service-detail__box .lists-2 > li { margin-top: 30px; }
.about-service-detail__box .lists-2 > li:first-child { margin-top: 0; }
.about-service-detail__box .lists-2 dl > dt { position: relative; padding-left: 30px; font-size: 1.8rem; font-weight: 700; line-height: 1.2; }
.about-service-detail__box .lists-2 dl > dt::before { counter-increment: lists-num 1; content: '0'counter(lists-num)'.'; position: absolute; top: 4px; left: 0; font-family: 'Overpass', sans-serif; font-size: 1.5rem; font-weight: 600; line-height: 1.2; color: #736357; }
.about-service-detail__box .lists-2 dl > dd { font-size: 1.3rem; line-height: 1.2; color: #736357; }
.about-service-detail__box .lists-2 .photo { position: relative; }
.about-service-detail__box .box-1 { margin-top: 28px; }
.about-service-detail__box .box-1 > dt { font-size: 1.8rem; font-weight: 700; line-height: 1.2; }
.about-service-detail__box .box-1 > dd { margin-top: 12px; font-size: 1.3rem; line-height: 1.84615384615; }
.about-service-detail__box .box-1 > dd a { text-decoration: underline; }
.device-click .about-service-detail__box .box-1 > dd a:hover { text-decoration: none; }
.about-service-detail__box .circle-1 { display: flex; flex-wrap: wrap; justify-content: center; margin-top: 25px; }
.about-service-detail__box .circle-1 > li { display: flex; justify-content: center; align-items: center; position: relative; margin: 20px 20px 0; width: 110px; height: 110px; text-align: center; font-size: 1.5rem; font-weight: 700; line-height: 1.41010333333; }
.about-service-detail__box .circle-1 > li > svg { position: absolute; top: 0; left: -1px; transition: ease-out 1s; transform: rotate(-35deg); stroke-dasharray: 334px; stroke-dashoffset: 334px; width: 100%; height: 100%; }
.about-service-detail__box .circle-1 > li > svg circle { fill: none; r: 54.5px; stroke: #aea49d; stroke-width: 1px; transform: translateX(0%); }
.about-service-detail__box .circle-1 > li.lazy-circle-done svg { stroke-dashoffset: 0; }
.about-service-detail__box .banner { position: relative; margin-top: 45px; z-index: 1; }
.about-service-detail__box .banner > a { display: block; position: relative; padding: 25px 15px; color: #fff; }
.about-service-detail__box .banner > a::after { content: ''; position: absolute; top: 0; right: 0; width: calc(100% - 17px); height: 100%; background-color: #ada39c; border-radius: 5px; z-index: -1; }
.about-service-detail__box .banner-info { padding-left: calc(40% + 15px); }
.about-service-detail__box .banner-en { font-family: 'Overpass', sans-serif; font-size: 2.186755rem; font-weight: 600; line-height: 1; }
.about-service-detail__box .banner-ja { display: flex; align-items: center; }
.about-service-detail__box .banner-ja > span { font-size: 1.5rem; font-weight: 700; letter-spacing: 0; line-height: 1.2; }
.about-service-detail__box .banner-ja > .i-blank { margin-left: 4px; }
.about-service-detail__box .banner-photo { position: absolute; bottom: 0; left: 0; width: 132px; }
.about-service-detail__box .banner .i-arrow { position: absolute; right: 15px; bottom: 12px; width: 24px; }
.device-click .about-service-detail__box .banner > a::after { transition: ease 0.4s; }
.device-click .about-service-detail__box .banner > a:hover { opacity: 1; }
.device-click .about-service-detail__box .banner > a:hover::after { background-color: #736357; }

@media screen and (max-width: 768px) {
  .about-service { padding: 40px 30px 50px; background-color: #f1ede9; }
  .about-service-detail--illust { display: block !important; margin: 0 auto 10px; opacity: 1 !important; }
  .about-service-detail--illust.illust-3 { width: 85%; }
  .about-service-detail__box .lists-1 dl > dt { cursor: pointer; }
  .about-service-detail__box .lists-1 dl > dt::before,
  .about-service-detail__box .lists-1 dl > dt::after { content: ''; position: absolute; top: 50%; right: 0; transition: ease 0.4s; width: 14px; height: 1px; background-color: #534741; }
  .about-service-detail__box .lists-1 dl > dt::after { transform: rotate(90deg); }
  .about-service-detail__box .lists-1 dl > dt.active::after { transform: rotate(0); }
  .about-service-detail__box .lists-2 dl { display: flex; align-items: center; }
  .about-service-detail__box .lists-2 dl > dt { width: 156px; }
  .about-service-detail__box .lists-2 dl > dd { width: calc(100% - 156px); }
  .about-service-detail__box .lists-2 .photo { margin-top: 10px; }
  .about-service-detail__box .banner-ja { margin-top: 4px; }
}

@media screen and (min-width: 769px) {
  .about-service { margin-top: 140px; }
  .about-service .title-group { margin-bottom: 64px; text-align: center; }
  .about-service-content { padding-bottom: 65px; overflow: hidden; }
  .about-service-content::after { content: ''; position: absolute; top: 0; left: 0; width: 46.8521229868%; height: 100%; background-color: #f1ede9; border-radius: 0 12px 12px 0; z-index: -1; }
  .about-service-detail__block { margin-top: 100px; }
  .about-service-detail--illust { display: none; pointer-events: none; position: absolute; left: 0; width: 37.7358490566%; max-width: 440px; }
  .about-service-detail--illust.fixed { position: fixed; top: 50%; left: calc((100% - 1166px) / 2); transform: translateY(-50%); width: 32.2108345534%; }
  .about-service-detail__box { margin: 0 20px 0 auto; max-width: 485px; }
  .about-service-detail--cat { margin-bottom: 20px; padding: 7px 15px 4px; }
  .about-service-detail--cat > span:nth-of-type(1) { font-size: 1.6rem; }
  .about-service-detail--cat > span:nth-of-type(2) { font-size: 1.1rem; }
  .about-service-detail--tgroup { margin-bottom: 26px; }
  .about-service-detail--num { width: 42px; height: 42px; font-size: 2.5rem; line-height: 48px; }
  .about-service-detail--num > svg { stroke-dasharray: 110px; }
  .about-service-detail--num > svg circle { r: 19.5px; }
  .about-service-detail--title { margin-left: 30px; width: calc(100% - 72px); font-size: 2.8rem; line-height: 1.53571428571; }
  .about-service-detail--explain { margin-bottom: 60px; font-size: 1.4rem; line-height: 2; }
  .about-service-detail__box .lists-1 dl { display: flex; align-items: center; }
  .about-service-detail__box .lists-1 dl::before { top: 50%; transform: translateY(-50%); font-size: 1.6rem; }
  .about-service-detail__box .lists-1 dl > dt { padding: 0 0 0 45px; width: 240px; font-size: 2rem; }
  .about-service-detail__box .lists-1 dl > dd { display: block !important; padding: 36px 0; width: calc(100% - 240px); font-size: 1.4rem; line-height: 2; }
  .about-service-detail__box .box-1 { margin-top: 50px; }
  .about-service-detail__box .box-1 > dt { font-size: 1.8rem; }
  .about-service-detail__box .box-1 > dd { margin-top: 16px; font-size: 1.4rem; line-height: 2; }
  .about-service-detail__box .lists-2 > li { display: flex; align-items: center; margin-top: 35px; }
  .about-service-detail__box .lists-2 dl { width: 195px; }
  .about-service-detail__box .lists-2 dl > dt { padding-left: 48px; font-size: 2rem; }
  .about-service-detail__box .lists-2 dl > dt::before { top: 4px; font-size: 1.6rem; }
  .about-service-detail__box .lists-2 dl > dd { margin-top: 8px; font-size: 1.4rem; }
  .about-service-detail__box .lists-2 .photo { margin-right: calc(((1166px - 100vw) / 2) - 20px); width: calc(310px + (100vw - 1166px) / 2); }
  .about-service-detail__box .circle-1 { margin-top: 25px; }
  .about-service-detail__box .circle-1 > li { margin: 30px 30px 0; width: 162px; height: 162px; font-size: 1.8rem; line-height: 1.33333333333; }
  .about-service-detail__box .circle-1 > li > svg { stroke-dashoffset: 491px; stroke-dasharray: 491px; }
  .about-service-detail__box .circle-1 > li > svg circle { r: 79.5px; }
  .about-service-detail__box .banner { margin-top: 85px; }
  .about-service-detail__box .banner > a { padding: 26px 0; }
  .about-service-detail__box .banner > a::after { width: 100%; border-radius: 6px; }
  .about-service-detail__box .banner-info { padding-left: 192px; }
  .about-service-detail__box .banner-en { font-size: 2.6rem; }
  .about-service-detail__box .banner-ja > span { font-size: 1.3rem; }
  .about-service-detail__box .banner-ja > .i-blank { margin-left: 8px; }
  .about-service-detail__box .banner-photo { left: 36px; width: 129px; }
  .about-service-detail__box .banner .i-arrow { top: 50%; right: 20px; margin-top: -3px; bottom: auto; width: 25px; }
  .about-service-detail__box .btn-1 { margin-top: 72px; }
}

/* ordermade
------------------------------------------------ */
.about-ordermade { position: relative; }
.about-ordermade-parallax { position: relative; width: 100%; height: 40vw; overflow: hidden; }
.about-ordermade-parallax::before,
.about-ordermade-parallax::after { content: ''; position: absolute; }
.about-ordermade-parallax::before { top: 0; left: 0; width: 100%; height: 100%; background-repeat: no-repeat; background-position: center center; background-size: cover; z-index: 1; }
.about-ordermade-parallax::after { top: 26vw; left: 50%; transform: translateX(-50%); width: 120vw; height: 46vw; background-color: #fff; border-radius: 50% 50% 0 0; z-index: 2; }
.about-ordermade .title-group { margin-bottom: 10px; text-align: center; }
.about-ordermade-top--copy { font-size: 1.8rem; font-weight: 700; line-height: 1.38888888889; }
.about-ordermade-top--text { margin-top: 20px; font-size: 1.3rem; line-height: 1.84615384615; }
.about-ordermade-mid { position: relative; margin-top: 30px; padding-top: 40px; border-top: 1px solid #848075; }
.about-ordermade-mid__circle { display: flex; flex-wrap: wrap; position: relative; }
.about-ordermade-mid__circle--item { display: flex; justify-content: center; align-items: center; position: relative; text-align: center; font-size: 1.5rem; font-weight: 700; line-height: 1.2; }
.about-ordermade-mid__circle--item > svg { position: absolute; top: 0; left: -1px; transition: ease-out 1s; transform: rotate(-35deg); stroke-dasharray: 444px; stroke-dashoffset: 444px; width: 100%; height: 100%; }
.about-ordermade-mid__circle--item > svg circle { fill: none; r: 72px; stroke: #aea49d; stroke-width: 1px; }
.about-ordermade-mid__circle--item.lazy-circle-done svg { stroke-dashoffset: 0; }

@media screen and (max-width: 768px) {
  .about-ordermade > .wrap { padding: 10px 30px 0; background-color: #fff; }
  .about-ordermade-parallax::before { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-image: url(../../img/about/ordermade_parallax.jpg); z-index: -1; }
  .about-ordermade-top--illust { margin: 0 30px; }
  .about-ordermade-top--copy { text-align: center; }
  .about-ordermade-mid__circle--item { margin: 5.71428571429% 6.66666666667vw 0 0; width: 38.6666666667vw; height: 38.6666666667vw; }
  .about-ordermade-mid__circle--item:nth-of-type(-n+2) { margin-top: 0; }
  .about-ordermade-mid__circle--item:nth-of-type(2n) { margin-right: 0; }
  .about-ordermade-mid--illust { position: absolute; right: -15px; bottom: 15px; width: 51.4285714286%; }
}

@media screen and (min-width: 769px) {
  .about-ordermade { margin-top: 140px; }
  .about-ordermade-parallax { margin-bottom: 20px; height: 29.5vw; }
  .about-ordermade-parallax::before { background-image: url(../../img/about/ordermade_parallax-pc.jpg); background-attachment: fixed; }
  .about-ordermade-parallax::after { top: 19vw; width: 121vw; height: 47vw; }
  .about-ordermade > .wrap { max-width: 1140px; }
  .about-ordermade .title-group { margin-bottom: 60px; }
  .about-ordermade-top { display: flex; justify-content: center; }
  .about-ordermade-top--illust { width: 40%; }
  .about-ordermade-top__info { margin-left: 5.5%; width: 45%; }
  .about-ordermade-top--copy { font-size: 2.97345rem; line-height: 1.6; }
  .about-ordermade-top--text { margin-top: 18px; font-size: 1.4rem; line-height: 2.42857142857; }
  .about-ordermade-mid { display: flex; justify-content: center; align-items: center; margin-top: 70px; padding-top: 55px; }
  .about-ordermade-mid__circle { margin: -35px 28px 0 -35px; }
  .about-ordermade-mid__circle--item { margin: 35px 0 0 35px; width: 162px; height: 162px; font-size: 1.6rem; line-height: 1.34375; }
  .about-ordermade-mid__circle--item > svg { stroke-dasharray: 495px; stroke-dashoffset: 495px; }
  .about-ordermade-mid__circle--item > svg circle { r: 80px; }
  .about-ordermade-mid--illust { width: 33.1818181818%; }
  .about-ordermade .btn-1 { margin-top: 68px; }
}

/* flow */
.about-ordermade-flow { margin-top: 45px; padding: 32px 0; background-color: #f1ede9; border-radius: 9px; }
.about-ordermade-flow__lists--item { position: relative; }
.about-ordermade-flow__lists--num { text-align: center; }
.about-ordermade-flow__lists--num > span { display: inline-block; padding: 5px 10px 2px; min-width: 115px; background-color: #534741; text-align: center; vertical-align: top; font-family: 'Overpass', sans-serif; font-size: 1.5rem; font-weight: 600; line-height: 1.2; color: #fff; }
.about-ordermade-flow__lists--text { margin-top: 10px; text-align: center; font-size: 1.7rem; font-weight: 700; line-height: 1.47058823529; }

@media screen and (max-width: 768px) {
  .about-ordermade-flow__lists--item { margin-top: 10px; padding-bottom: 40px; }
  .about-ordermade-flow__lists--item:first-child { margin-top: 0; }
  .about-ordermade-flow__lists--item:last-child { padding-bottom: 0; }
  .about-ordermade-flow__lists--item:not(:first-child)::before { content: ''; position: absolute; top: -50px; left: 50%; transition: linear 0.4s; margin-left: -2px; width: 4px; height: 0; background: url(../../img/about/ordermade_flow_dotted.svg) repeat-y left top; background-size: 100%; z-index: 1; }
  .about-ordermade-flow__lists--text { padding-bottom: 8px; }

  .lazy-flow-done .about-ordermade-flow__lists--item:not(:first-child)::before { height: 40px; }
  .lazy-flow-done .about-ordermade-flow__lists--item:nth-of-type(3)::before { transition-delay: 0.4s; }
  .lazy-flow-done .about-ordermade-flow__lists--item:nth-of-type(4)::before { transition-delay: 0.8s; }
  .lazy-flow-done .about-ordermade-flow__lists--item:nth-of-type(5)::before { transition-delay: 1.2s; }
}

@media screen and (min-width: 769px) {
  .about-ordermade-flow { margin-top: 72px; padding: 42px 0; border-radius: 18px; }
  .about-ordermade-flow__lists { display: flex; justify-content: center; flex-wrap: wrap; margin-top: -30px; overflow: hidden; }
  .about-ordermade-flow__lists--item { margin-top: 30px; }
  .about-ordermade-flow__lists--item::after,
  .about-ordermade-flow__lists--item:nth-of-type(4):before { content: ''; position: absolute; top: 14px; left: calc(50% + 64px); transition: linear 0.4s; width: 0; height: 2px; background: url(../../img/about/ordermade_flow_dotted-pc.svg) repeat-x left top; background-size: auto 100%; z-index: 1; }
  .about-ordermade-flow__lists--num { position: relative; z-index: 2; }
  .about-ordermade-flow__lists--num > span { padding: 7px 10px 4px; min-width: 120px; font-size: 1.6rem; }
  .about-ordermade-flow__lists--text { margin-top: 10px; font-size: 1.8rem; }
  .about-ordermade-flow__lists--item:nth-of-type(1) { margin-right: 13%; }
  .about-ordermade-flow__lists--item:nth-of-type(2) { margin-right: 21%; }
  .about-ordermade-flow__lists--item:nth-of-type(4) { margin-right: 13%; margin-left: 4%; }
  .about-ordermade-flow__lists--item:nth-of-type(4)::before { left: calc((-46% + 4px)); }

  .lazy-flow-done .about-ordermade-flow__lists--item:nth-of-type(1)::after { width: 89%; }
  .lazy-flow-done .about-ordermade-flow__lists--item:nth-of-type(2)::after { transition-delay: 0.4s; width: 165%; }
  .lazy-flow-done .about-ordermade-flow__lists--item:nth-of-type(3)::after { transition-delay: 0.8s; width: 30%; }
  .lazy-flow-done .about-ordermade-flow__lists--item:nth-of-type(4)::before { transition-delay: 1.2s; width: 46%; }
  .lazy-flow-done .about-ordermade-flow__lists--item:nth-of-type(4)::after { transition-delay: 1.6s; width: 138%; }
}

/* case */
.about-ordermade-case { margin-top: 50px; padding: 32px 0; background-color: #f1ede9; border-radius: 9px; }
.about-ordermade-case__detail { margin: 0 22px; }
.about-ordermade-case__tab { display: flex; border-bottom: 2.5px solid #534741; }
.about-ordermade-case__tab--item { width: 51.2915129151%; text-align: center; font-family: 'Overpass', sans-serif; font-size: 1.4rem; font-weight: 600; line-height: 1.2; }
.about-ordermade-case__tab--item > a { display: block; padding: 12px 5px 8px; width: 100%; border-radius: 7.5px 7.5px 0 0; color: #fff; }
.about-ordermade-case__tab--item:nth-of-type(1) > a { background-color: #98918d; }
.about-ordermade-case__tab--item.active:nth-of-type(1) > a { background-color: #534741; }
.about-ordermade-case__tab--item:nth-of-type(2) > a { background-color: #aba19a; }
.about-ordermade-case__tab--item.active:nth-of-type(2) > a { background-color: #736357; }
.about-ordermade-case__tab--item:nth-of-type(3) > a { background-color: #d6cfc9; }
.about-ordermade-case__tab--item.active:nth-of-type(3) > a { background-color: #504e4c; }
.about-ordermade-case__target { display: none; padding: 22px 16px; background-color: #fff; border-radius: 0 0 7.5px 7.5px; }
.about-ordermade-case--photo { position: relative; }
.about-ordermade-case--photo i { display: none; position: absolute; background-repeat: no-repeat; background-position: center center; background-size: 100% 100%; }
.about-ordermade-case__links { counter-reset: case-num 0; }
.about-ordermade-case__links--item { font-size: 1.4rem; font-weight: 700; line-height: 1.2; }
.about-ordermade-case__links--item:not(:first-child) { margin-top: 16px; }
.about-ordermade-case__links--item > span { display: block; position: relative; padding-left: 35px; cursor: pointer; }
.about-ordermade-case__links--item > span::before { counter-increment: case-num 1; content: counter(case-num); position: absolute; top: -2px; left: 0; width: 21px; height: 21px; background-color: #534741; border-radius: 50%; text-align: center; font-family: 'Overpass', sans-serif; font-size: 1.4rem; font-weight: 600; line-height: 25px; color: #fff; }
.about-ordermade-case__slide { margin-top: 44px; opacity: 0; }
.about-ordermade-case__slide__frame { width: 100%; overflow: hidden; }
.about-ordermade-case__slide__move { display: flex; align-items: flex-end; }
.about-ordermade-case__slide--item { position: relative; }
.about-ordermade-case__slide--item .photo { position: relative; width: 100%; z-index: 1; }
.about-ordermade-case__slide--item .photo::after { content: ''; position: absolute; bottom: 0; left: 0; padding-bottom: 66.6666666667%; width: 100%; height: 0; background-color: #e2dad1; border-radius: 4.5px; overflow: hidden; z-index: -1; }
.about-ordermade-case__slide--item .photo > img { position: relative; left: 50%; transform: translateX(-50%); max-width: inherit; }
.about-ordermade-case__slide--item .name { margin-top: 8px; text-align: center; font-family: 'Overpass', sans-serif; font-size: 1.4rem; font-weight: 600; line-height: 1.2; }
.about-ordermade-case__slide--item.furniture-sofa .photo > img { margin-bottom: 6.8306010929%; width: 112.021857923%; }
.about-ordermade-case__slide--item.furniture-table .photo > img { margin-bottom: 7.65027322404%; width: 63.3879781421%; }
.about-ordermade-case__slide--item.furniture-chair .photo > img { width: 67.7595628415%; }
.about-ordermade-case__slide--item.furniture-strage .photo > img { margin-bottom: 4.09836065574%; width: 83.8797814208%; }
.about-ordermade-case__slide--item.furniture-desk .photo > img { width: 81.4207650273%; }

@media screen and (max-width: 768px) {
  .about-ordermade-case__tab { flex-wrap: wrap; }
  .about-ordermade-case__tab--item:not(:first-child) { margin-left: -27.1217712177%; }
  .about-ordermade-case__tab--item > a { white-space: nowrap; }
  .about-ordermade-case__tab--item.active { z-index: 5; }
  .about-ordermade-case__tab--item.active + .about-ordermade-case__tab--item { z-index: 4; }

  #case1 .about-ordermade-case--photo i:nth-of-type(1) { top: 6.2874251497%; left: 52.1008403361%; width: 21.8500420168%; height: 14.6932035928%; background-image: url(../../img/about/case1_num1.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(2) { top: 26.0479041916%; left: 26.8907563025%; width: 20.4766806723%; height: 14.6932035928%; background-image: url(../../img/about/case1_num2.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(3) { top: 23.6526946108%; left: 57.1428571429%; width: 20.4766806723%; height: 14.6932035928%; background-image: url(../../img/about/case1_num3.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(4) { top: 62.5748502994%; left: 42.2268907563%; width: 10.3099369748%; height: 26.9375449102%; background-image: url(../../img/about/case1_num4.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(5) { top: 35.628742515%; left: 6.3025210084%; width: 10.3099369748%; height: 24.2845808383%; background-image: url(../../img/about/case1_num5.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(6) { top: 50.2994011976%; left: 65.5462184874%; width: 20.5294537815%; height: 14.6932035928%; background-image: url(../../img/about/case1_num6.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(7) { top: 70.9580838323%; left: 60.5042016807%; width: 22.0518067227%; height: 14.6932035928%; background-image: url(../../img/about/case1_num7.svg); }

  #case2 .about-ordermade-case--photo i:nth-of-type(1) { top: 13.1736526946%; left: 48.5294117647%; width: 23.3172689076%; height: 17.7008682635%; background-image: url(../../img/about/case2_num1.svg); }
  #case2 .about-ordermade-case--photo i:nth-of-type(2) { top: 53.5928143713%; left: 65.5462184874%; width: 20.731512605%; height: 14.6932035928%; background-image: url(../../img/about/case2_num2.svg); }
  #case2 .about-ordermade-case--photo i:nth-of-type(3) { top: 82.3353293413%; left: 26.8907563025%; width: 20.7890966387%; height: 14.6932035928%; background-image: url(../../img/about/case2_num3.svg); }

  #case3 .about-ordermade-case--photo i:nth-of-type(1) { top: 29.9401197605%; left: 31.3025210084%; width: 23.3172689076%; height: 17.7008682635%; background-image: url(../../img/about/case3_num1.svg); }
  #case3 .about-ordermade-case--photo i:nth-of-type(2) { top: 76.0479041916%; left: 6.72268907563%; width: 21.7354411765%; height: 14.6932035928%; background-image: url(../../img/about/case3_num2.svg); }
  #case3 .about-ordermade-case--photo i:nth-of-type(3) { top: 68.2634730539%; left: 53.781512605%; width: 18.4034663866%; height: 16.6604191617%; background-image: url(../../img/about/case3_num3.svg); }
  #case3 .about-ordermade-case--photo i:nth-of-type(4) { top: 54.4910179641%; left: 65.3361344538%; width: 20.8444957983%; height: 14.6932035928%; background-image: url(../../img/about/case3_num4.svg); }
  #case3 .about-ordermade-case--photo i:nth-of-type(5) { top: 26.6467065868%; left: 66.8067226891%; width: 20.9363445378%; height: 23.0638922156%; background-image: url(../../img/about/case3_num5.svg); }

  .about-ordermade-case__info { margin-top: 18px; }
}

@media screen and (min-width: 769px) {
  .about-ordermade-case { margin-top: 65px; padding: 42px 0 62px; border-radius: 18px; }
  .about-ordermade-case__detail { margin: 0 50px; }
  .about-ordermade-case__tab { border-bottom-width: 5px; }
  .about-ordermade-case__tab--item { width: 33.3333%; font-size: 2rem; }
  .about-ordermade-case__tab--item > a { padding: 18px 5px 12px; border-radius: 15px 15px 0 0; }
  .about-ordermade-case__target { padding: 40px 58px; }
  .about-ordermade-case__target .multi { display: flex; flex-flow: row-reverse; align-items: center; }
  .about-ordermade-case--photo { width: 62.2171945701%; }

  #case1 .about-ordermade-case--photo i:nth-of-type(1) { top: 11.6883116883%; left: 53.6363636364%; width: 18.9102181818%; height: 9.35064935065%; background-image: url(../../img/about/case1_num1-pc.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(2) { top: 30.6493506494%; left: 26.1818181818%; width: 13%; height: 9.35064935065%; background-image: url(../../img/about/case1_num2-pc.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(3) { top: 28.5714285714%; left: 56.5454545455%; width: 13%; height: 9.35064935065%; background-image: url(../../img/about/case1_num3-pc.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(4) { top: 66.7532467532%; left: 33.8181818182%; width: 6.54545454545%; height: 17.1428571429%; background-image: url(../../img/about/case1_num4-pc.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(5) { top: 36.6233766234%; left: 13.0909090909%; width: 6.54545454545%; height: 15.4545454545%; background-image: url(../../img/about/case1_num5-pc.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(6) { top: 54.025974026%; left: 70.7272727273%; width: 13.0335090909%; height: 9.35064935065%; background-image: url(../../img/about/case1_num6-pc.svg); }
  #case1 .about-ordermade-case--photo i:nth-of-type(7) { top: 69.0909090909%; left: 65.6363636364%; width: 14%; height: 9.35064935065%; background-image: url(../../img/about/case1_num7-pc.svg); }

  #case2 .about-ordermade-case--photo i:nth-of-type(1) { top: 16.8831168831%; left: 45.8181818182%; width: 22.6363636364%; height: 16.2337662338%; background-image: url(../../img/about/case2_num1-pc.svg); }
  #case2 .about-ordermade-case--photo i:nth-of-type(2) { top: 59.7402597403%; left: 70.7272727273%; width: 12.9426%; height: 9.35064935065%; background-image: url(../../img/about/case2_num2-pc.svg); }
  #case2 .about-ordermade-case--photo i:nth-of-type(3) { top: 78.7012987013%; left: 27.2727272727%; width: 17.1818181818%; height: 15.974025974%; background-image: url(../../img/about/case2_num3-pc.svg); }

  #case3 .about-ordermade-case--photo i:nth-of-type(1) { top: 39.2207792208%; left: 31.4545454545%; width: 13%; height: 9.35064935065%; background-image: url(../../img/about/case3_num1-pc.svg); }
  #case3 .about-ordermade-case--photo i:nth-of-type(2) { top: 73.2467532468%; left: 6.72727272727%; width: 16.2727272727%; height: 15.1948051948%; background-image: url(../../img/about/case3_num2-pc.svg); }
  #case3 .about-ordermade-case--photo i:nth-of-type(3) { top: 65.7142857143%; left: 54.7272727273%; width: 16.1818181818%; height: 15.1948051948%; background-image: url(../../img/about/case3_num3-pc.svg); }
  #case3 .about-ordermade-case--photo i:nth-of-type(4) { top: 57.4025974026%; left: 68.1818181818%; width: 13.3720181818%; height: 9.35064935065%; background-image: url(../../img/about/case3_num4-pc.svg); }
  #case3 .about-ordermade-case--photo i:nth-of-type(5) { top: 36.3636363636%; left: 74.3636363636%; width: 15.9090909091%; height: 14.4155844156%; background-image: url(../../img/about/case3_num5-pc.svg); }

  .about-ordermade-case__info { width: 37.3303167421%; }
  .about-ordermade-case__links--item { font-size: 1.8rem; }
  .about-ordermade-case__links--item:not(:first-child) { margin-top: 26px; }
  .about-ordermade-case__links--item > span { padding-left: 45px; }
  .about-ordermade-case__links--item > span::before { width: 26px; height: 26px; font-size: 1.6rem; line-height: 29px; }
  .about-ordermade-case__slide { margin-top: 75px; }
  .about-ordermade-case__slide--item .name { margin-top: 12px; font-size: 1.6rem; }
}

/* company
------------------------------------------------ */
.about-company { position: relative; }
.about-company > .wrap > .frame { background-color: #efebe6; border-radius: 11px 0 0 11px; }
.about-company-info > dl { display: flex; }
.about-company-info > dl:not(:last-child) > dt,
.about-company-info > dl:not(:last-child) > dd { border-bottom: 1px solid #848075; }
.about-company-info > dl > dt { padding-top: 13px; width: 62px; font-size: 1.25rem; font-weight: 700; letter-spacing: 0.12em; line-height: 1.2; }
.about-company-info > dl > dt span { display: inline-block; margin-top: 1em; vertical-align: top; font-size: 0.7rem; }
.about-company-info > dl > dd { margin-left: 14px; padding: 10px 0; width: calc(100% - 76px); font-size: 1.3rem; letter-spacing: 0.06em; line-height: 1.61538461538; }
.about-company-info > dl > dd .map { display: flex; justify-content: center; align-items: center; padding: 8px 0 6px; max-width: 146px; background-color: #534741; text-align: center; font-family: 'Overpass', sans-serif; font-size: 1.4rem; font-weight: 600; line-height: 1.2; color: #fff; }
.about-company-info > dl > dd .map > .i-blank { margin-left: 10px; }
.about-company-info > dl > dd dl + dl { margin-top: 1.61538461538em; }
.about-company-info > dl > dd dl > dt { font-size: 1.2rem; color: #736357; }
.device-click .about-company-info > dl > dd .map:hover { background-color: #938c88; opacity: 1; }

@media screen and (max-width: 768px) {
  .about-company { padding: 45px 0 70px 30px; background-color: #fff; }
  .about-company > .wrap > .frame { padding: 30px; }
  .about-company .title-group { margin-bottom: 18px; }
  .about-company-info > dl > dd .map { margin-top: 8px; }
}

@media screen and (min-width: 769px) {
  .about-company { margin-top: 150px; overflow: hidden; }
  .about-company::after { content: ''; position: absolute; top: 0; right: 0; width: 50%; height: 100%; background-color: #efebe6; z-index: -1; }
  .about-company > .wrap > .frame { margin-left: 145px; padding: 160px 20px 52px 0; }
  .about-company .title-group { position: absolute; top: 60px; left: 85px; }
  .about-company-info { margin-left: auto; padding-left: 20px; max-width: 768px; }
  .about-company-info > dl > dt { padding-top: 18px; width: 196px; font-size: 1.79256rem; }
  .about-company-info > dl > dt span { margin-top: 0.6em; font-size: 1rem; }
  .about-company-info > dl > dd { margin-left: 10px; padding: 14px 10px; width: calc(100% - 206px); font-size: 1.6rem; line-height: 1.75; }
  .about-company-info > dl > dd .map { display: inline-flex; margin: -2px 0 0 20px; padding: 4px 12px 3px; vertical-align: middle; font-size: 1.2rem; }
  .about-company-info > dl > dd .map > .i-blank { margin-left: 8px; width: 12px; height: 9px; }
  .about-company-info > dl > dd .map > .i-blank::before,
  .about-company-info > dl > dd .map > .i-blank::after { width: 8px; height: 6px; }
  .about-company-info > dl > dd dl + dl { margin-top: 1.75em; }
  .about-company-info > dl > dd dl > dt { font-size: 1.4rem; }
}