@charset "UTF-8";

body {
  font-family: "Noto Sans JP", sans-serif;
  position: relative;
  z-index: 0;
  background-color: transparent;
  /*
  &::before {
      content: "";
      display: block;
      width: calc(100% - 40px);
      height: 100vh;
      background-image: url(../img/body_bg_sp.svg);
      background-size: 100% auto;
      position: fixed;
      top: 0;
      left: 20px;
      z-index: -10;

      @media screen and (min-width: 960px) {
          background-image: url(../img/body_bg_pc.svg);
          width: min(calc(100% - (70px*2)), 1460px);
          left: 50%;
          translate: -50% 0;
      }
  }  */
}

body.menu-opened {
  overflow: hidden;
}

* {
  margin: 0;
  padding: 0;
  line-height: 160%;
  vertical-align: top;
  text-decoration: none;
  list-style: none;
  box-sizing: border-box;
  font-family: inherit;
  font-size: inherit;
  color: inherit;
}

img {
  vertical-align: top;
  width: 100%;
  height: auto;
}

.sp {
  display: block;
}

.pc {
  display: none;
}

/*  ===== ===== ===== ===== ===== */
/*  ===== ==== header ==== ===== */
/*  ===== ===== ===== ===== ===== */
header.is-scrolled {
  height: 58px;
}

header.is-scrolled .header_inner {
  height: 58px;
}

header {
  background-color: #fff;
  border-bottom: solid 1px #ededed;
  width: 100%;
  height: 63px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
}

header .header_inner {
  height: 63px;
  display: flex;
  align-items: center;
  padding-inline: 20px;
  position: relative;
  z-index: 0;
}

header .logo_block {
  width: min(30.6666666667vw, 115px);
}

header .logo_block a {
  display: block;
}

header .logo_block img {
  width: 100%;
  aspect-ratio: 115/29;
}

header .nav_block {
  width: 100%;
  height: -moz-fit-content;
  height: fit-content;
  font-family: "Figtree", sans-serif;
  font-weight: 800;
  font-style: italic;
}

header .nav_block.opened {
  translate: 0;
}

header .navigation {
  padding-inline: 30px;
}

header .sitemap {
  padding: 30px 30px 0;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-weight: 500;
  font-style: normal;
}

header .sitemap a {
  display: block;
  margin-right: 20px;
  line-height: 1.35;
}

header .linelink {
  background: url(../img/bg_sp_line_block.png) no-repeat center right/contain;
  background-color: #06C755;
  margin-top: 60px;
  padding: 60px 20px 60px 32px;
  color: #fff;
  position: relative;
  z-index: 0;
}

header .linelink .add_line {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

header .linelink .title {
  padding-left: 73px;
  position: relative;
  z-index: 0;
}

header .linelink .title::before {
  content: "";
  display: block;
  width: 42px;
  aspect-ratio: 1/1;
  background: url(../img/icon_sp_line_block.svg) no-repeat center/100% auto;
  position: absolute;
  top: 10px;
  left: 0;
}

header .linelink .title::after {
  content: "";
  display: block;
  width: 49px;
  aspect-ratio: 49/50;
  background: url(../img/icon_line_block_arrow.svg) no-repeat center/100% auto;
  position: absolute;
  bottom: 0;
  right: 0;
  translate: 0 50%;
}

header .linelink span {
  display: inline-block;
}

header .linelink .en {
  font-size: 26.4px;
  line-height: 1;
}

header .linelink .copy_text {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4375;
  margin-top: 10px;
}

header .hum_btn {
  margin-left: auto;
  text-transform: uppercase;
  font-size: 14px;
  font-family: "Figtree", sans-serif;
  font-weight: 700;
  font-style: italic;
  z-index: 10;
  padding-top: 10px;
}

header .hum_btn span {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

header .hum_btn span::before {
  content: "";
  display: block;
  width: 27px;
  height: 5px;
  border-top: solid 2px #000;
  border-bottom: solid 2px #000;
}

header .hum_btn.opened span::before {
  height: 2px;
  border-top: solid 2px #000;
  border-bottom: none;
}

/*  ===== ===== ===== ===== ===== */
/*  ===== ===== footer ===== ===== */
/*  ===== ===== ===== ===== ===== */
footer {
  margin-top: 110px;
  padding-bottom: 132px;
}

footer .line_link {
  background: url(../img/bg_sp_line_block.png) no-repeat center right/contain;
  background-color: #06C755;
  margin-top: 60px;
  padding: 60px 20px 60px 32px;
  color: #fff;
}

footer .line_link .line_cnt {
  position: relative;
  z-index: 0;
}

footer .line_link .line_cnt a {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  z-index: 0;
  z-index: 1;
}

footer .line_link .title {
  padding-left: 73px;
  position: relative;
  z-index: 0;
  font-family: "Figtree", sans-serif;
  font-weight: 900;
  font-style: italic;
}

footer .line_link .title::before {
  content: "";
  display: block;
  width: 42px;
  aspect-ratio: 1/1;
  background: url(../img/icon_sp_line_block.svg) no-repeat center/100% auto;
  position: absolute;
  top: 10px;
  left: 0;
}

footer .line_link .title::after {
  content: "";
  display: block;
  width: 49px;
  aspect-ratio: 49/50;
  background: url(../img/icon_line_block_arrow.svg) no-repeat center/100% auto;
  position: absolute;
  bottom: 0;
  right: 0;
  translate: 0 50%;
}

footer .line_link span {
  display: inline-block;
}

footer .line_link .en {
  font-size: 26.4px;
  line-height: 1;
}

footer .line_link .copy_text {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4375;
  margin-top: 10px;
}

footer .activities_block {
  margin-top: 70px;
  padding: 0 20px;
}

footer .activities_block .inner {
  padding: 30px 35px;
  border: solid 1px #000;
  max-width: 1460px;
  margin-inline: auto;
}

footer .activities_block .inner .title {
  font-size: 15px;
  font-weight: 900;
}

footer .activities_block .inner .lead {
  font-size: 15px;
  font-weight: 500;
  margin-top: 8px;
  line-height: 1.8666666667;
}

footer .company_block {
  margin-top: 100px;
  padding: 0 20px;
}

footer .company_block .logo {
  width: min(56.2666666667%, 323px);
}

footer .company_block .company {
  margin-top: 60px;
}

footer .company_block .company .tag {
  opacity: 0.5;
  font-size: 13px;
  line-height: 1;
  font-weight: 500;
}

footer .company_block .company .name {
  font-size: 16px;
  font-weight: 700;
  margin-top: 13px;
}

footer .company_block .company .info {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.6428571429;
  margin-top: 12px;
}

footer .nav_block {
  margin-top: 70px;
  padding: 0 20px;
}

footer .nav_block .inner {
  display: flex;
  flex-direction: column-reverse;
}

footer .nav_block .copyrights {
  font-size: 11px;
  font-weight: 500;
  margin-top: 20px;
}

footer .nav_block .sitemap {
  font-size: 14px;
  font-weight: 500;
}

/*  ===== ===== ===== ===== ===== */
/*  ===== ===== 全ページ ===== ===== */
/*  ===== ===== ===== ===== ===== */
/* ===== ===== タイトル ===== ===== */
.section_title {
  font-family: "Figtree", sans-serif;
  font-weight: 900;
  font-style: italic;
  font-size: 26.4px;
  line-height: 1;
}

main {
  width: 100%;
  overflow-x: clip;
  margin-top: 63px;
  letter-spacing: 0.03em;
  line-break: strict;
  position: relative;
  z-index: 0;
}

.pagettl_wrap {
  padding: 80px 20px 40px;
}

.fixed_bnr {
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  bottom: 0;
  right: 0;
  z-index: 1;
  background-color: #06C755;
  color: #fff;
  aspect-ratio: 1/1;
  border-radius: 50%;
  scale: .8;
  opacity: 0;
  pointer-events: none;
  transition: all .35s linear;
}

.fixed_bnr.active {
  opacity: 1;
  pointer-events: initial;
}

.fixed_bnr a {
  display: block;
  font-family: "Figtree", sans-serif;
  font-weight: 900;
  font-style: italic;
  font-size: min(calc(10/390*100vw), 15px);
  letter-spacing: 0.045em;
  width: min(calc(120/390*100vw), 175px);

  padding: 15px 6px;
  text-align: center;
}

.fixed_bnr a span {
  display: inline-block;
  line-height: 1.08;
  margin: 0;
  padding: 0;
  vertical-align: bottom;
}

.fixed_bnr a .title {
  font-size: 200%;
}

.fixed_bnr a .price {
  font-size: 208%;
}

.fixed_bnr a .middle {
  font-size: 180%;
  letter-spacing: 0;
  margin-left: 2px;
}

.fixed_bnr a .bottom {
  margin-top: 6px;
}

/*  ===== ===== ===== ===== ===== */
/*  ===== ===== TOP ===== ===== */
/*  ===== ===== ===== ===== ===== */
.index {
  /* ===== ===== mv ===== ===== */
  /* ===== ===== concept ===== ===== */
  /* ===== ===== 共通：swiperのコントローラー各種 ===== ===== */
  /* ===== ===== ギャラリー ===== ===== */
  /* ===== ===== ファブリック ===== ===== */
  /* ===== ===== ファブリック ===== ===== */
  /* ===== ===== 制作の流れ ===== ===== */
  /* ===== ===== ニュース ===== ===== */
  /* ===== ===== ストア情報 ===== ===== */
}

.index .mv_swiper .swiper-slide {
  overflow-x: clip;
  /* box-shadow: 0px 4px 20px rgba(0, 0, 0, 0.1); */
}

.index .mv_swiper .swiper-pagination {
  position: initial;
  margin-top: 20px;
  display: flex;
  justify-content: center;
  gap: 10px;
}

.index .mv_swiper .swiper-pagination-bullet {
  position: initial;
  margin: 0;
  width: 10px;
  height: auto;
  aspect-ratio: 1/1;
  background-color: #fff;
  border: solid 2px #000;
  opacity: 1;
}

.index .mv_swiper .swiper-pagination-bullet-active {
  background-color: #000;
}

.index .concept_wrap {
  margin-top: 60px;
  padding: 0 20px;
}

.index .concept_wrap .text_block .title {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  font-size: 20px;
  font-weight: 900;
}

.index .concept_wrap .text_block .lead {
  margin-top: 18px;
  font-size: 18px;
  font-weight: 500;
  text-align: justify;
  text-justify: inter-ideograph;
  line-break: strict;
}

.index .swiper_control {
  position: relative;
  margin-top: 32px;
  padding-right: 20px;
}

.index .swiper_control *:not(.swiper-pagination-progressbar-fill) {
  position: initial;
  top: unset;
  bottom: unset;
  left: unset;
  right: unset;
}

.index .swiper_control .swiper-pagination-progressbar-fill {
  background-color: #000;
}

.index .swiper_control .arrowbtn {
  display: none;
}

.index .swiper_wrap .fabric_line {
  font-weight: 900;
}

.index .gallery_wrap {
  margin-top: 90px;
  padding-left: 20px;
}

.index .gallery_wrap .tab_block {
  margin-top: 24px;
}

.index .gallery_wrap .tab_block .tabbox {
  display: flex;
  justify-content: flex-start;
  gap: 20px;
}

.index .gallery_wrap .tab_block button {
  border: none;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font-family: "Figtree", sans-serif;
  font-weight: 900;
  font-style: italic;
  font-size: 18px;
  line-height: 1;
  color: rgba(0, 0, 0, 0.15);
}

.index .gallery_wrap .tab_block button.active {
  color: #000;
  border-bottom: solid 6px #000;
}

.index .gallery_wrap .cnt_block {
  margin-top: 26px;
}

.index .gallery_wrap .gallery_swiper {
  display: none;
}

.index .gallery_wrap .gallery_swiper.is-active {
  display: block;
}

.index .gallery_wrap .swiper_wrap .swiper-slide {
  width: 78.0281690141%;
  margin-right: 15px;
}

.index .gallery_wrap .swiper_wrap .textbox {
  font-family: "Figtree", sans-serif;
  font-weight: 500;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.6;
  margin-top: 12px;
}

.index .fabric_wrap {
  margin-top: 100px;
  padding-left: 20px;
}

.index .fabric_wrap .cnt_block {
  margin-top: 25px;
}

.index .fabric_wrap .swiper_wrap .swiper-slide {
  width: 61.4084507042%;
  margin-right: 15px;
}

.index .fabric_wrap .swiper_wrap .textbox {
  margin-top: 12px;
  font-size: 15px;
  font-family: "Figtree", sans-serif;
}

.index .fabric_wrap .swiper_wrap .name {
  font-weight: 500;
  line-height: 1.25;
  margin-top: 6px;
}

.index .fabric_wrap .swiper_wrap .price {
  font-weight: 500;
  font-style: normal;
  margin-top: 6px;
  line-height: 1.15;
}

.index .price_wrap {
  margin-top: 100px;
  padding-inline: 20px;
}

.index .price_wrap .cnt_block {
  margin-top: 25px;
}

.index .howto_wrap {
  margin-top: 100px;
  padding: 0 20px;
}

.index .howto_wrap .subtitle_block {
  margin-top: 20px;
}

.index .howto_wrap .subtitle_block p {
  font-weight: 700;
  font-size: 18px;
}

.index .howto_wrap .cnt_block {
  margin-top: 30px;
}

.index .howto_wrap .cnt_step ul .step_image {
  width: 53.7313432836%;
  /* box-shadow: 2px 4px 20px rgba(0, 0, 0, 0.1); */
}

.index .howto_wrap .cnt_step ul .step_text {
  flex: 1;
  padding-right: 37px;
  margin-top: 40px;
}

.index .howto_wrap .cnt_step ul .step_text .num {
  font-family: "Figtree", sans-serif;
  font-weight: 500;
  font-style: italic;
  font-size: 14px;
  line-height: 1;
}

.index .howto_wrap .cnt_step ul .step_text .info {
  font-weight: 700;
  line-height: 1.25;
  margin-top: 4px;
}

.index .news_wrap {
  margin-top: 110px;
  padding: 0 20px;
}

.index .news_wrap .cnt_block {
  margin-top: 25px;
}

.index .news_wrap .acd_item {
  margin-top: 3px;
}

.index .news_wrap .acd_item summary.haslink {
  pointer-events: none;
  position: relative;
  z-index: 0;
}

.index .news_wrap .acd_item summary.haslink a {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: initial;
}

.index .news_wrap .acd_item summary.haslink .title::before {
  display: none;
}

.index .news_wrap .acd_item summary.haslink .title::after {
  width: 14px;
  height: auto;
  aspect-ratio: 1/1;
  background-color: transparent;
  background: url(../img/icon_swiper_arrow_dis.svg) no-repeat center/320% auto;
  scale: -1;
  right: 0;
}

.index .news_wrap .acd_item summary {
  background-color: #F6F6F6;
  padding: 25px 25px 32px;
}

.index .news_wrap .acd_item .date {
  display: block;
  font-family: "Figtree", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 14px;
  line-height: 0.9333333333;
  opacity: 0.5;
}

.index .news_wrap .acd_item .title {
  display: block;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.6;
  margin-top: 6px;
  position: relative;
  z-index: 0;
  padding-right: 18px;
}

.index .news_wrap .acd_item .title::before {
  content: "";
  display: block;
  width: 14px;
  height: 2px;
  position: absolute;
  right: 0;
  top: calc(50% - 1px);
  background-color: #000;
}

.index .news_wrap .acd_item .title::after {
  content: "";
  display: block;
  width: 2px;
  height: 14px;
  position: absolute;
  right: 6px;
  top: 50%;
  background-color: #000;
  translate: 0 -50%;
  transition: opacity 0.15s linear, rotate 0.2s ease-in;
}

.index .news_wrap .acd_item .news_cnt {
  background-color: #F6F6F6;
  padding: 1px 25px 20px;
}

.index .news_wrap .acd_item .news_cnt_inner p {
  font-size: 15px;
  line-height: 1.8666666667;
}

.index .news_wrap .acd_item .news_cnt_inner img {
  display: block;
  width: min(100%, 640px);
  margin: 0.8em auto 0;
}

.index .news_wrap .acd_item .news_cnt_inner a {
  font-weight: 500;
  letter-spacing: 0.05em;
  text-decoration: underline;
  text-underline-offset: 2px;
  color: #555;
  display: inline-block;
  margin-left: 4px;
}

.index .news_wrap .acd_item[open] .title::after {
  opacity: 0;
  rotate: 90deg;
}

.index .news_wrap .acd_item[open] .news_cnt {
  margin-top: -1px;
}

.index .store_wrap {
  margin-top: 100px;
  padding: 0 20px;
}

.index .store_wrap .store_info {
  margin-top: 40px;
}

.index .store_wrap .store_info .name {
  font-size: 18px;
  font-weight: 700;
}

.index .store_wrap .store_info .address {
  font-size: 15px;
  font-weight: 500;
  margin-top: 19px;
}

.index .store_wrap .store_info dl {
  display: flex;
  font-size: 14px;
  font-weight: 500;
  gap: 11px;
}

.index .store_wrap .store_info dl dt {
  display: flex;
  align-items: center;
  min-width: 75px;
}

.index .store_wrap .store_info dl dt::after {
  content: "：";
  display: inline-block;
  font-size: 14px;
}

.index .store_wrap .store_info dl dd {
  flex: 1;
}

.index .store_wrap .store_info dl:nth-child(1) {
  margin-top: 14px;
}

.index .store_wrap .embed_map {
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  margin-top: 40px;
}

.index .store_wrap .embed_map iframe {
  width: 100%;
  height: 100%;
}

.subpage.term p,
.subpage.term li {
  font-size: 15px;
  font-weight: 500;
  line-height: 2.1333333333;
}

.subpage.term .page_cnt_container {
  padding: 0 20px;
}

.subpage.term .page_cnt_container article {
  margin-top: 60px;
}

.subpage.term .page_cnt_container article:nth-child(1) {
  margin-top: 0;
}

.subpage.term .page_cnt_container h3 {
  font-size: 16px;
  font-weight: 900;
}

.subpage.term .page_cnt_container h3+p {
  margin-top: 10px;
}

.subpage.term .page_cnt_container h4+p {
  margin-top: 8px;
}

.subpage.term .page_cnt_container h4 {
  font-size: 15px;
  font-weight: 700;
  margin-block: 1em;
  opacity: 0.65;
  letter-spacing: 0.05em;
}

.subpage.term .page_cnt_container ol,
.subpage.term .page_cnt_container ul {
  margin-top: 8px;
}

.subpage.term .page_cnt_container ol li:not(ul li) {
  list-style: decimal;
  list-style-position: inside;
  margin-top: 16px;
  text-indent: -1em;
  padding-left: 1em;
}

.subpage.term .page_cnt_container ol ol {
  padding-left: 0.5em;
}

.subpage.term .page_cnt_container ol ol li:not(ul li) {
  list-style: decimal-leading-zero;
  list-style-position: inside;
  text-indent: -1em;
  padding-left: 1em;
}

.subpage.term .page_cnt_container ul {
  padding-left: 0.5em;
}

.subpage.term .page_cnt_container ul li {
  list-style: disc;
  list-style-position: inside;
  margin-top: 5px;
  text-indent: -1.45em;
  padding-left: 1em;
  line-height: 1.6;
}

.subpage.term .caption {
  display: inline-block;
  font-size: 80%;
  opacity: 0.8;
  letter-spacing: 0.075em;
  line-height: 1.5;
  margin-block: 0.65em;
}

@media screen and (min-width: 960px) {
  .sp {
    display: none;
  }

  .pc {
    display: block;
  }

  header.is-scrolled {
    height: 96px;
  }

  header.is-scrolled .header_inner {
    height: 96px;
  }

  header {
    height: 118px;
  }

  header .header_inner {
    height: 118px;
    padding-inline: 70px;
  }

  header .logo_block {
    width: 207px;
  }

  header .nav_block {
    position: relative;
  }

  header .navigation {
    padding: 0;
  }

  header .navigation ul {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 30px;
    font-size: 16px;
    font-weight: 500;
    line-height: 1;
  }

  header .sitemap {
    display: none;
  }

  header .linelink {
    display: none;
  }

  header .hum_btn {
    display: none;
  }

  footer {
    margin-top: 210px;
  }

  footer .line_link {
    background-image: url(../img/bg_footer_line_block_pc.png);
    padding: 63px max(20px, (100% - 1460px) / 2) 75px;
  }

  footer .line_link .line_cnt {
    max-width: 1460px;
    margin-inline: auto;
  }

  footer .line_link .title {
    padding-left: 123px;
  }

  footer .line_link .title::before {
    width: 63px;
    top: 50%;
    translate: 0 -50%;
  }

  footer .line_link .title::after {
    width: 84px;
    bottom: 50%;
    translate: 0 50%;
  }

  footer .line_link span {
    display: block;
  }

  footer .line_link .en {
    /* font-size: 68px; */
    font-size: clamp(26.4px, 2.55vw, 40.8px);
  }

  footer .line_link .copy_text {
    font-size: 20px;
    margin-top: 15px;
  }

  footer .activities_block {
    padding-inline: max(20px, (100% - 1460px) / 2);
    margin-top: 100px;
  }

  footer .activities_block .inner {
    padding: 60px 60px 54px;
  }

  footer .activities_block .inner .title {
    font-size: 20px;
  }

  footer .activities_block .inner .lead {
    font-size: 18px;
  }

  footer .company_block {
    padding-inline: max(20px, (100% - 1460px) / 2);
  }

  footer .company_block .inner {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    max-width: 1460px;
    margin: 185px auto 0;
  }

  footer .company_block .logo {
    margin-top: 0;
  }

  footer .company_block .company {
    margin-top: 0;
    padding-right: min(2.602739726%, 40px);
  }

  footer .company_block .company .tag {
    font-size: 15px;
  }

  footer .company_block .company .name {
    font-size: 20px;
  }

  footer .company_block .company .info {
    font-size: 18px;
  }

  footer .nav_block {
    padding-inline: max(20px, (100% - 1460px) / 2);
    margin-top: 120px;
  }

  footer .nav_block .inner {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    width: min(100%, 1460px);
    margin: 0 auto;
  }

  footer .nav_block .copyrights {
    font-size: 14px;
    margin-top: 0;
  }

  footer .nav_block .sitemap {
    display: flex;
    gap: 20px;
    font-size: 16px;
  }

  .section_title {
    font-size: clamp(26.4px, 2.55vw, 40.8px);
  }

  main {
    margin-top: 118px;
  }

  .pagettl_wrap {
    max-width: 960px;
    margin-inline: auto;
    padding: 86px 20px 80px;
  }

  .index .mv_swiper .swiper-pagination {
    margin-top: 30px;
  }

  .index .concept_wrap {
    max-width: 960px;
    margin: 100px auto 0;
  }

  .index .concept_wrap .text_block .title {
    font-size: 30px;
  }

  .index .concept_wrap .text_block .lead {
    font-size: 24px;
  }

  .index .swiper_control {
    display: flex;
    align-items: center;
    gap: 40px;
    padding-right: 70px;
    max-width: 1460px;
    margin-inline: 0 auto;
  }

  .index .swiper_control .arrowbtn {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .index .swiper_control .arrowbtn .swiper-button-prev {
    margin: 0;
    padding: 0;
    background: url(../img/icon_swiper_arrow.svg) no-repeat center/100% auto;
    scale: -1;
  }

  .index .swiper_control .arrowbtn .swiper-button-prev svg {
    display: none;
  }

  .index .swiper_control .arrowbtn .swiper-button-prev.swiper-button-disabled {
    background-image: url(../img/icon_swiper_arrow_dis.svg);
    scale: 1;
    opacity: 1;
  }

  .index .swiper_control .arrowbtn .swiper-button-next {
    margin: 0;
    padding: 0;
    background: url(../img/icon_swiper_arrow.svg) no-repeat center/100% auto;
  }

  .index .swiper_control .arrowbtn .swiper-button-next svg {
    display: none;
  }

  .index .swiper_control .arrowbtn .swiper-button-next.swiper-button-disabled {
    background-image: url(../img/icon_swiper_arrow_dis.svg);
    scale: -1;
    opacity: 1;
  }

  .index .gallery_wrap {
    padding-left: max(20px, (100% - 1460px) / 2);
    margin-top: 120px;
  }

  .index .gallery_wrap .inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  .index .gallery_wrap .inner .tab_block {
    padding-right: max(20px, calc(100% - 1460px));
    margin-top: 0;
  }

  .index .gallery_wrap .tab_block button {
    font-size: 28.8px;
  }

  .index .gallery_wrap .cnt_block {
    width: 100%;
  }

  .index .gallery_wrap .swiper_wrap .swiper-slide {
    width: 30.4575163399%;
    margin-right: 30px;
  }

  .index .gallery_wrap .swiper_wrap .textbox {
    font-size: 18px;
    margin-top: 17px;
  }

  .index .fabric_wrap {
    padding-left: max(20px, (100% - 1460px) / 2);
  }

  .index .fabric_wrap .swiper_wrap .swiper-slide {
    width: 23.4931506849%;
    margin-right: 30px;
  }

  .index .fabric_wrap .swiper_wrap .textbox {
    margin-top: 16px;
    font-size: 18px;
  }

  .index .price_wrap {
    padding-inline: max(20px, (100% - 1460px) / 2);
  }

  .index .howto_wrap {
    padding: 0 max(20px, (100% - 1460px) / 2);
  }

  .index .howto_wrap .inner {
    display: flex;
    flex-wrap: wrap;
  }

  .index .howto_wrap .subtitle_block {
    margin-left: 105px;
    margin-top: 0;
  }

  .index .howto_wrap .cnt_block {
    width: 100%;
    margin-top: 55px;
  }

  .index .howto_wrap .cnt_step ul {
    display: flex;
    gap: 30px;
  }

  .index .howto_wrap .cnt_step ul li {
    width: calc((100% - 60px) / 3);
  }

  .index .howto_wrap .cnt_step ul li:nth-child(1) .step_image::after,
  .index .howto_wrap .cnt_step ul li:nth-child(2) .step_image::after {
    content: "";
    display: block;
    width: 14px;
    aspect-ratio: 1/1.08;
    background-color: #000;
    position: absolute;
    right: -21px;
    top: 50%;
    translate: 0 -50%;
    -webkit-clip-path: polygon(0 0, 0% 100%, 100% 50%);
    clip-path: polygon(0 0, 0% 100%, 100% 50%);
  }

  .index .howto_wrap .cnt_step ul .step_image {
    width: 100%;
    position: relative;
    z-index: 0;
  }

  .index .howto_wrap .cnt_step ul .step_text {
    margin-top: 24px;
  }

  .index .howto_wrap .cnt_step ul .step_text .num {
    font-size: 16px;
  }

  .index .howto_wrap .cnt_step ul .step_text .info {
    font-size: 20px;
  }

  .index .news_wrap {
    margin-top: 170px;
    padding-inline: max(20px, (100% - 1460px) / 2);
  }

  .index .news_wrap .inner {
    display: flex;
    justify-content: space-between;
  }

  .index .news_wrap .cnt_block {
    margin-top: 0;
    width: min(72.2222222222vw, 1105px);
  }

  .index .store_wrap {
    padding: 0 max(20px, (100% - 1460px) / 2);
    margin-top: 180px;
  }

  .index .store_wrap .inner {
    display: flex;
    justify-content: space-between;
  }

  .index .store_wrap .title_block {
    flex: 1;
    padding-right: 30px;
  }

  .index .store_wrap .cnt_block {
    width: 50%;
  }

  .index .store_wrap .store_info .name {
    font-size: 20px;
  }

  .index .store_wrap .store_info .address {
    font-size: 18px;
    line-height: 1.8333333333;
    margin-top: 24px;
    margin-bottom: 27px;
  }

  .index .store_wrap .store_info dl {
    margin-top: 6px;
    font-size: 18px;
  }

  .index .store_wrap .embed_map {
    aspect-ratio: 730/400;
    margin-top: 0;
  }

  .subpage.term p,
  .subpage.term li {
    font-size: 18px;
  }

  .subpage.term .page_cnt_container {
    max-width: 960px;
    margin-inline: auto;
  }

  .subpage.term .page_cnt_container article {
    margin-top: 80px;
  }

  .subpage.term .page_cnt_container h3 {
    font-size: 20px;
  }

  .subpage.term .page_cnt_container h4 {
    font-size: 18px;
  }
}

@media screen and (max-width: 959px) {
  header .nav_block {
    overflow-y: auto;
    height: 100vh;
    background-color: #fff;
    padding-top: 75px;
    font-size: 22.8px;
    position: absolute;
    left: 0;
    top: 0;
    translate: 100% 0;
    transition: all 0.35s linear;
  }

  .index .howto_wrap .cnt_step ul li {
    display: flex;
    flex-direction: row-reverse;
    position: relative;
    z-index: 0;
    margin-top: 47px;
  }

  .index .howto_wrap .cnt_step ul li::after {
    content: "";
    display: block;
    width: 10px;
    aspect-ratio: 1.08/1;
    background-color: #000;
    position: absolute;
    left: 0;
    bottom: -15px;
    -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
    clip-path: polygon(0 0, 50% 100%, 100% 0);
  }

  .index .howto_wrap .cnt_step ul li:last-child::after {
    display: none;
  }
}

@media screen and (min-width: 1600px) {
  .index .swiper_control {
    padding: 0;
  }
}


/* add 20251224 */