body {
  width: 100%;
  min-width: 1260px;
  text-align: justify;
  text-justify: inter-ideograph;
  word-wrap: break-all;
  word-wrap: break-word;
  scroll-behavior: smooth;
  color: #34312c;
  letter-spacing: 0.08em;
  font-family: "Zen Kaku Gothic New", system-ui;
  font-weight: 500;
  font-size: 16px;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  body {
    font-size: 26px;
    font-size: 3.3854166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  body {
    font-size: 17.3333333333px;
  }
}

.col-wht {
  color: #fff !important;
}
.col-blk {
  color: #34312c !important;
}
.col-main {
  color: #36aa27 !important;
}
.col-main2 {
  color: #fc770c !important;
}
.col-sub {
  color: #8e6237 !important;
}
.col-sub2 {
  color: #d7a701 !important;
}
.col-su3b {
  color: #92b32e !important;
}
.col-accent {
  color: #000 !important;
}
.col-bdr {
  color: #b0ada8 !important;
}
.col-bg {
  color: #fbf0d3 !important;
}

.bg-wht {
  background-color: #fff !important;
}
.bg-blk {
  background-color: #34312c !important;
}
.bg-main {
  background-color: #36aa27 !important;
}
.bg-main2 {
  background-color: #fc770c !important;
}
.bg-sub {
  background-color: #8e6237 !important;
}
.bg-sub2 {
  background-color: #d7a701 !important;
}
.bg-sub3 {
  background-color: #92b32e !important;
}
.bg-accent {
  background-color: #000 !important;
}
.bg-bdr {
  background-color: #b0ada8 !important;
}
.bg-bg {
  background-color: #fbf0d3 !important;
}

.ptn-stripe {
  background-image: linear-gradient(#fdf5e9 0px, #fdf5e9 10px, #fcf2e2 10px, #fcf2e2 25px);
  background-size: 100% 25px;
}

.btn-01__link {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  background: #36aa27;
  color: #fff;
  border-radius: 50rem;
}
.btn-01__link:hover {
  color: rgba(255, 255, 255, 0.8);
}

.ic-tel-20, .ic-tel-25, .ic-tel-33, .ic-mail-20, .ic-mail-25, .ic-mail-33 {
  display: flex;
  align-items: center;
  -moz-column-gap: 5px;
       column-gap: 5px;
}
.ic-tel-20::before, .ic-tel-25::before, .ic-tel-33::before, .ic-mail-20::before, .ic-mail-25::before, .ic-mail-33::before {
  content: "";
  display: block;
  width: 20px;
  aspect-ratio: 33/34;
  background-image: url("/img/common/ic-tel.png");
  background-size: 100%;
}
.ic-tel-33 {
  -moz-column-gap: 10px;
       column-gap: 10px;
}
.ic-tel-33::before {
  width: 33px;
}
.ic-mail-20::before, .ic-mail-25::before {
  aspect-ratio: 25/20;
  background-image: url("/img/common/ic-mail.png");
  background-size: 100%;
}
.ic-mail-25 {
  -moz-column-gap: 10px;
       column-gap: 10px;
}
.ic-mail-25::before {
  width: 25px;
}

.arw-wht-17 {
  position: relative;
}
.arw-wht-17::after {
  content: "";
  display: block;
  width: 17px;
  aspect-ratio: 17/18;
  background-image: url("/img/common/arrow-wht.png");
  background-size: 100%;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translate(0, -50%);
  transition: 0.3s;
}
.arw-wht-17:hover::after {
  transform: translate(-2px, -50%);
}
.arw-wht-28, .arw-blk-28 {
  position: relative;
}
.arw-wht-28::after, .arw-blk-28::after {
  content: "";
  display: block;
  width: 4.38%;
  aspect-ratio: 28/30;
  background-image: url("/img/common/arrow-blk.png");
  background-size: 100%;
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(-100%, -100%);
  transition: 0.3s;
}
.arw-wht-28:hover::after, .arw-blk-28:hover::after {
  transform: translate(calc(-100% - 2px), -100%);
}
.arw-wht-28::after {
  background-image: url("/img/common/arrow-wht.png");
  background-size: 100%;
}

.hov-opa a:hover {
  opacity: 0.8;
}
.hov-img a:hover img {
  opacity: 0.8;
}
.hov-scale a img, .hov-up a img {
  backface-visibility: hidden;
  -webkit-transform: translateZ(0) scale(1, 1);
}
.hov-scale a:hover img, .hov-up a:hover img {
  transform: scale(0.98);
}
.hov-up a:hover img {
  transform: translateY(-3px);
}

.tbl {
  width: 100%;
  table-layout: fixed;
}
.tbl td {
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}
.tbl-01-wrp, .tbl-02-wrp, .tbl-03-wrp {
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
}
.tbl-01-wrp {
  border: solid 1px #d7a701;
}
.tbl-01 th, .tbl-01 td {
  width: 50%;
  vertical-align: middle;
  text-align: center;
}
.tbl-01 th {
  width: 30%;
  padding: 24px 4%;
  background: #d7a701;
  color: #fff;
  font-weight: 500;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .tbl-01 th {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tbl-01 th {
    font-size: 22.6666666667px;
  }
}
.tbl-01 th:not(:first-child) {
  border-left: solid 1px #fff;
}
.tbl-01 td {
  padding: 20px 4%;
  font-weight: 600;
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .tbl-01 td {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tbl-01 td {
    font-size: 18.6666666667px;
  }
}
.tbl-01 td:not(:first-child) {
  border-left: solid 1px #d7a701;
}
.tbl-01 tbody tr:not(:first-child) td {
  border-top: solid 1px #d7a701;
}
.tbl-02-wrp, .tbl-03-wrp {
  border: solid 2px #8e6237;
}
.tbl-02 th, .tbl-02 td, .tbl-03 th, .tbl-03 td {
  padding: 24px 4%;
  vertical-align: middle;
  font-weight: 500;
}
.tbl-02 th, .tbl-03 th {
  width: 30%;
  background: #8e6237;
  color: #fff;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .tbl-02 th, .tbl-03 th {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tbl-02 th, .tbl-03 th {
    font-size: 20px;
  }
}
.tbl-02 td, .tbl-03 td {
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .tbl-02 td, .tbl-03 td {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tbl-02 td, .tbl-03 td {
    font-size: 18.6666666667px;
  }
}
.tbl-02 tr:not(:first-child) th, .tbl-02 tr:not(:first-child) td, .tbl-03 tr:not(:first-child) th, .tbl-03 tr:not(:first-child) td {
  border-top: solid 2px #fff;
}
.tbl-02 tr:not(:first-child) td, .tbl-03 tr:not(:first-child) td {
  border-top-color: #8e6237;
}
.tbl-03-wrp {
  border: solid 1px #b0ada8;
}
.tbl-03 th, .tbl-03 td {
  padding: 15px 4%;
  font-size: 16px;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .tbl-03 th, .tbl-03 td {
    font-size: 26px;
    font-size: 3.3854166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tbl-03 th, .tbl-03 td {
    font-size: 17.3333333333px;
  }
}
.tbl-03 th {
  position: relative;
  background: #fbf0d3;
  color: #34312c;
}
.tbl-03 td {
  padding: 15px;
  display: flex;
  flex-direction: column;
  row-gap: 8px;
}
.tbl-03 tr:not(:first-child) th, .tbl-03 tr:not(:first-child) td {
  border-top-width: 1px;
  border-top-color: #b0ada8;
}

[class^=cts-] {
  width: 100%;
  margin: 0 auto;
}

.cts-1080 {
  max-width: 1080px;
}
.cts-1280 {
  max-width: 1280px;
}

.layout-clm-2 {
  display: flex;
  flex-wrap: wrap;
  gap: 150px;
}
.layout-clm-2 .list-item,
.layout-clm-2 .layout-item {
  width: calc((100% - 150px) / 2);
}
.layout-clm-2-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 150px;
}
.layout-clm-2-c .list-item,
.layout-clm-2-c .layout-item {
  width: calc((100% - 150px) / 2);
}
.layout-clm-3 {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}
.layout-clm-3 .list-item,
.layout-clm-3 .layout-item {
  width: calc((100% - 80px) / 3);
}
.layout-clm-3-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px;
}
.layout-clm-3-c .list-item,
.layout-clm-3-c .layout-item {
  width: calc((100% - 80px) / 3);
}
.layout-clm-4 {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}
.layout-clm-4 .list-item,
.layout-clm-4 .layout-item {
  width: calc((100% - 60px) / 4);
}
.layout-clm-4-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}
.layout-clm-4-c .list-item,
.layout-clm-4-c .layout-item {
  width: calc((100% - 60px) / 4);
}

.list-blog .list-item, .list-news .list-item, .list-privacy .list-item, .list-flow .list-item, .list-faq .list-item {
  width: 100%;
}
.list-news__item {
  border-bottom: solid 1px #b0ada8;
  padding: 40px 0;
}
.list-news__item:first-child {
  padding-top: 0 !important;
}
.list-news time {
  display: block;
  line-height: 1;
  font-size: 22px;
  font-size: 2.2rem;
}
@media screen and (max-width: 768px) {
  .list-news time {
    font-size: 32px;
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-news time {
    font-size: 21.3333333333px;
  }
}
.list-news__link {
  display: flex;
  flex-direction: column;
  row-gap: 20px;
}
.list-news__bx {
  display: flex;
  align-items: center;
  -moz-column-gap: 15px;
       column-gap: 15px;
}
.list-news__ttl {
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .list-news__ttl {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-news__ttl {
    font-size: 18.6666666667px;
  }
}
.list-reason__item {
  display: flex;
  flex-direction: column;
  row-gap: 10px;
  background: #fff;
  border-radius: 7px;
  padding: 40px 20px;
  position: relative;
}
.list-reason__num, .list-reason__ttl {
  text-align: center;
  color: #36aa27;
  font-size: 22px;
  font-size: 2.2rem;
}
@media screen and (max-width: 768px) {
  .list-reason__num, .list-reason__ttl {
    font-size: 32px;
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-reason__num, .list-reason__ttl {
    font-size: 21.3333333333px;
  }
}
.list-reason__num {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(0, -50%);
  z-index: 1;
}
.list-reason__txt {
  padding: 0 7px;
}
.list-menu {
  border-top: solid 1px #b0ada8;
  border-bottom: solid 1px #b0ada8;
}
.list-menu__item {
  width: 33.3333333333%;
  aspect-ratio: 640/350;
}
.list-menu__item:not(:first-child) {
  border-left: solid 1px #b0ada8;
}
.list-menu__link {
  display: block;
  width: 100%;
  height: 100%;
  padding: 9.38%;
}
.list-menu .ttl-main {
  row-gap: 1.2vw;
}
.list-menu .ttl-main__en {
  font-size: 28px;
  font-size: 1.4583333333vw;
}
@media screen and (max-width: 1120px) {
  .list-menu .ttl-main__en {
    font-size: 18.6666666667px;
  }
}
@media screen and (min-width: 1920px) {
  .list-menu .ttl-main__en {
    font-size: 28px;
  }
}
.list-menu .ttl-main__rb {
  font-size: 40px;
  font-size: 2.0833333333vw;
}
@media screen and (max-width: 1120px) {
  .list-menu .ttl-main__rb {
    font-size: 26.6666666667px;
  }
}
@media screen and (min-width: 1920px) {
  .list-menu .ttl-main__rb {
    font-size: 40px;
  }
}
.list-bnr__item {
  width: 50%;
  aspect-ratio: 960/480;
}
.list-bnr__item:not(:first-child) {
  border-left: solid 1px #fff;
}
.list-bnr__link {
  display: block;
  width: 100%;
  height: 100%;
  padding: 12.5%;
  position: relative;
  z-index: 1;
}
.list-bnr__link::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(54, 170, 39, 0.88);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  transition: 0.3s;
}
.list-bnr__link:hover::before {
  background: rgba(38, 116, 28, 0.88);
}
.list-bnr .ttl-main__en, .list-bnr .ttl-main__rb {
  color: #fff;
}
.list-bnr .case {
  background: url("/img/top/bnr-case.png") center center no-repeat;
  background-size: cover;
}
.list-bnr .greeting {
  background: url("/img/top/bnr-greeting.png") center center no-repeat;
  background-size: cover;
}
.list-merit {
  row-gap: 60px;
}
.list-merit__item {
  display: flex;
  flex-direction: column;
  row-gap: 20px;
}
.list-merit .ttl-01 {
  text-align: center;
}
.list-flow__item {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.list-flow__ic {
  border: solid 10px #fff;
  border-radius: 50rem;
}
.list-flow dl {
  display: flex;
  flex-direction: column;
  row-gap: 20px;
  width: 730px;
  max-width: 100%;
}
.list-flow dt {
  display: flex;
  -moz-column-gap: 10px;
       column-gap: 10px;
  color: #36aa27;
  font-size: 28px;
  font-size: 2.8rem;
}
@media screen and (max-width: 768px) {
  .list-flow dt {
    font-size: 38px;
    font-size: 4.9479166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-flow dt {
    font-size: 25.3333333333px;
  }
}
.list-flow::before {
  content: "";
  display: block;
  width: 2px;
  height: 100%;
  border-left: dashed 2px #36aa27;
  position: absolute;
  top: 0;
  left: 81px;
  z-index: -1;
}
.list-voice {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}
.list-voice .list-item,
.list-voice .layout-item {
  width: calc((100% - 40px) / 2);
}
.list-voice {
  row-gap: 60px;
}
.list-voice__item {
  background: #fff;
  border-radius: 12px;
  border: solid 1px #b0ada8;
  padding: 40px;
  display: flex;
  flex-direction: column;
  row-gap: 10px;
}
.list-voice__review, .list-voice h4 {
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-voice__review, .list-voice h4 {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-voice__review, .list-voice h4 {
    font-size: 20px;
  }
}
.list-voice__review {
  display: flex;
  align-items: center;
  -moz-column-gap: 10px;
       column-gap: 10px;
}
.list-voice__review dd {
  display: flex;
  align-items: center;
  -moz-column-gap: 5px;
       column-gap: 5px;
  color: #fc770c;
  font-weight: 600;
  font-size: 17px;
  font-size: 1.7rem;
}
@media screen and (max-width: 768px) {
  .list-voice__review dd {
    font-size: 27px;
    font-size: 3.515625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-voice__review dd {
    font-size: 18px;
  }
}
.list-voice__comment {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  -moz-column-gap: 20px;
       column-gap: 20px;
}
.list-voice__comment dt {
  width: 110px;
  min-width: 110px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  row-gap: 5px;
}
.list-voice__comment dt img {
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  overflow: hidden;
}
.list-voice__comment dd {
  width: 100%;
}
.list-card {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}
.list-card .list-item,
.list-card .layout-item {
  width: calc((100% - 40px) / 2);
}
.list-card__item {
  background: #fff;
  border-radius: 12px;
  padding: 40px 45px;
  display: flex;
  flex-direction: column;
  row-gap: 20px;
}
.list-stitch {
  display: flex;
  flex-wrap: wrap;
  gap: 0px;
}
.list-stitch .list-item,
.list-stitch .layout-item {
  width: calc((100% - 0px) / 3);
}
.list-stitch__item {
  border-left: dashed 2px #36aa27;
}
.list-stitch__item:nth-child(3n-2) {
  border-left: none;
}
.list-stitch__item:nth-child(3n-1) .list-stitch__bx {
  margin: 0 auto;
}
.list-stitch__item:nth-child(3n) .list-stitch__bx {
  margin-left: auto;
}
.list-stitch__bx {
  width: 300px;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  row-gap: 20px;
}
.list-products, .list-case {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}
.list-products .list-item,
.list-products .layout-item, .list-case .list-item,
.list-case .layout-item {
  width: calc((100% - 60px) / 3);
}
.list-products, .list-case {
  row-gap: 50px;
}
.list-products__item, .list-case__item {
  background: #fff;
  border-radius: 10px;
}
.list-products__link, .list-products__bx, .list-case__link, .list-case__bx {
  display: flex;
  flex-direction: column;
  row-gap: 20px;
}
.list-products__link, .list-case__link {
  justify-content: space-between;
  width: 100%;
  height: 100%;
  padding: 30px;
}
.list-products__img, .list-case__img {
  width: 100%;
  aspect-ratio: 280/220;
  border-radius: 8px;
  overflow: hidden;
}
.list-products .txt-06, .list-case .txt-06 {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  text-align: left;
}
.list-products__price, .list-products__btn, .list-case__price, .list-case__btn {
  text-align: right;
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .list-products__price, .list-products__btn, .list-case__price, .list-case__btn {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-products__price, .list-products__btn, .list-case__price, .list-case__btn {
    font-size: 18.6666666667px;
  }
}
.list-products__btn, .list-case__btn {
  color: #36aa27;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  -moz-column-gap: 10px;
       column-gap: 10px;
}
.list-products__btn::after, .list-case__btn::after {
  content: "";
  display: block;
  width: 11px;
  aspect-ratio: 1/1;
  background-image: url("/img/common/arrow-grn.png");
  background-size: 100%;
}
.list-case {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}
.list-case .list-item,
.list-case .layout-item {
  width: calc((100% - 40px) / 2);
}
.list-case {
  row-gap: 60px;
}
.list-case__img {
  aspect-ratio: 430/320;
}
.list-faq dl {
  background: #fff;
  padding: 50px 55px;
  border-radius: 15px;
}
.list-faq dt, .list-faq dd {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  -moz-column-gap: 15px;
       column-gap: 15px;
}
.list-faq dt::before, .list-faq dd::before {
  content: "Q";
  display: block;
  width: 40px;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  padding: 0 0 3px 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fc770c;
  color: #fff;
  line-height: 1;
  font-size: 28px;
  font-size: 2.8rem;
}
@media screen and (max-width: 768px) {
  .list-faq dt::before, .list-faq dd::before {
    font-size: 38px;
    font-size: 4.9479166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-faq dt::before, .list-faq dd::before {
    font-size: 25.3333333333px;
  }
}
.list-faq dt span, .list-faq dd span {
  width: 100%;
  max-width: calc(100% - 55px);
}
.list-faq dt {
  border-bottom: solid 1px #b0ada8;
  padding-bottom: 20px;
  margin-bottom: 20px;
  color: #fc770c;
  font-size: 23px;
  font-size: 2.3rem;
}
@media screen and (max-width: 768px) {
  .list-faq dt {
    font-size: 33px;
    font-size: 4.296875vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-faq dt {
    font-size: 22px;
  }
}
.list-faq dd {
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .list-faq dd {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-faq dd {
    font-size: 18.6666666667px;
  }
}
.list-faq dd::before {
  content: "A";
  background: #36aa27;
}
.list-faq dd span {
  white-space: pre-wrap;
}

.com-gmap {
  max-width: 100%;
}
.com-gmap iframe {
  display: block;
  width: 100%;
  max-width: 100%;
  height: 100%;
}
.com-layout {
  display: flex;
}
.com-tel .tel {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  line-height: 1;
}

.tag-main__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 5px;
  font-weight: 500;
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .tag-main__list {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tag-main__list {
    font-size: 18.6666666667px;
  }
}
.tag-main__link {
  display: block;
  background: #fff;
  padding: 10px 20px;
  border-radius: 4px;
}
.tag-main__link:hover {
  opacity: 0.8;
}
.tag-sub__list, .tag-products__list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 14px;
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  .tag-sub__list, .tag-products__list {
    font-size: 24px;
    font-size: 3.125vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tag-sub__list, .tag-products__list {
    font-size: 16px;
  }
}
.tag-sub__item, .tag-products__item {
  display: flex;
  line-height: 1;
  padding: 5px 10px 7px 10px;
  border-radius: 3px;
}
.tag-sub__item {
  background: #fff;
}
.tag-sub__item::before {
  content: "#";
  display: block;
}
.tag-products__item {
  background: #d7a701;
  color: #fff;
}
.tag-products .ttl-02 {
  font-size: 22px;
  font-size: 2.2rem;
}
@media screen and (max-width: 768px) {
  .tag-products .ttl-02 {
    font-size: 32px;
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tag-products .ttl-02 {
    font-size: 21.3333333333px;
  }
}
.tag-products .col-9979 {
  background: #36aa27;
}
.tag-products .col-9980 {
  background: #fc770c;
}
.tag-products .col-9981 {
  background: #8e6237;
}

.ttl-main {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  display: flex;
  flex-direction: column;
}
.ttl-main__en, .ttl-main__rb {
  letter-spacing: 0.08em;
}
.ttl-main__en {
  line-height: 1;
  color: #fc770c;
  font-size: 28px;
  font-size: 2.8rem;
}
@media screen and (max-width: 768px) {
  .ttl-main__en {
    font-size: 38px;
    font-size: 4.9479166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-main__en {
    font-size: 25.3333333333px;
  }
}
.ttl-sub {
  border-left: solid #fc770c 6px;
  background: #fff;
  padding: 10px 20px 15px 20px;
  border-radius: 6px;
  margin-bottom: 30px;
  font-weight: 500;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .ttl-sub {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-sub {
    font-size: 22.6666666667px;
  }
}
.ttl-01 {
  border-bottom: dashed 2px #36aa27;
  padding-bottom: 15px;
  line-height: 1.7857142857;
  font-size: 28px;
  font-size: 2.8rem;
}
@media screen and (max-width: 768px) {
  .ttl-01 {
    font-size: 38px;
    font-size: 4.9479166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-01 {
    font-size: 25.3333333333px;
  }
}
.ttl-01.bdr-col-main2 {
  border-bottom-color: #fc770c;
}
.ttl-01.bdr-col-sub {
  border-bottom-color: #8e6237;
}
.ttl-01.bdr-col-sub2 {
  border-bottom-color: #d7a701;
}
.ttl-01.bdr-col-sub3 {
  border-bottom-color: #92b32e;
}
.ttl-02 {
  border-left: solid 4px #fc770c;
  padding-left: 10px;
  line-height: 1.2;
}
.ttl-03 {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  color: #36aa27;
  text-align: center;
  border-top: dashed 2px #36aa27;
  border-bottom: dashed 2px #36aa27;
  padding: 20px 0;
  font-size: 34px;
  font-size: 3.4rem;
}
@media screen and (max-width: 768px) {
  .ttl-03 {
    font-size: 44px;
    font-size: 5.7291666667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-03 {
    font-size: 29.3333333333px;
  }
}

.txt-01, .txt-plain {
  line-height: 2.125;
}
.txt-02 {
  line-height: 2.25;
}
.txt-03 {
  line-height: 1.75;
}
.txt-04 {
  line-height: 2;
}
.txt-05 {
  line-height: 1.8823529412;
  font-size: 17px;
  font-size: 1.7rem;
}
@media screen and (max-width: 768px) {
  .txt-05 {
    font-size: 27px;
    font-size: 3.515625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .txt-05 {
    font-size: 18px;
  }
}
.txt-06 {
  line-height: 1.875;
}

.header-nav__item,
.drawer-nav__item,
.footer-nav__item,
.footer-sub__item {
  line-height: 1;
}
.header-nav__link:hover,
.drawer-nav__link:hover,
.footer-nav__link:hover,
.footer-sub__link:hover {
  opacity: 0.8;
}

.header-nav .current,
.drawer-nav .current {
  color: #fc770c;
}
.header-nav .current::after,
.drawer-nav .current::after {
  content: "";
  display: block;
  width: 12px;
  aspect-ratio: 12/8;
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
  background: #fc770c;
  margin: 5px auto 0 auto;
}

.header-nav {
  margin-top: 20px;
}
.header-nav__list {
  display: flex;
  justify-content: flex-end;
  -moz-column-gap: 20px;
       column-gap: 20px;
  font-weight: 400;
  font-size: 16px;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .header-nav__list {
    font-size: 26px;
    font-size: 3.3854166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .header-nav__list {
    font-size: 17.3333333333px;
  }
}
.header-nav__link:hover {
  color: #fc770c;
}
.header-nav .current {
  font-weight: 600;
  font-size: 21px;
  font-size: 2.1rem;
}
@media screen and (max-width: 768px) {
  .header-nav .current {
    font-size: 31px;
    font-size: 4.0364583333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .header-nav .current {
    font-size: 20.6666666667px;
  }
}

.footer-nav__list {
  display: grid;
  grid-auto-flow: column;
  grid-template-rows: repeat(4, auto);
  grid-template-columns: 275px 150px;
  gap: 30px 40px;
  font-size: 17px;
  font-size: 1.7rem;
}
@media screen and (max-width: 768px) {
  .footer-nav__list {
    font-size: 27px;
    font-size: 3.515625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .footer-nav__list {
    font-size: 18px;
  }
}

.footer-sub {
  margin-top: 100px;
}
.footer-sub__list {
  display: flex;
  justify-content: flex-end;
  -moz-column-gap: 20px;
       column-gap: 20px;
  font-size: 15px;
  font-size: 1.5rem;
}
@media screen and (max-width: 768px) {
  .footer-sub__list {
    font-size: 25px;
    font-size: 3.2552083333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .footer-sub__list {
    font-size: 16.6666666667px;
  }
}
.footer-sub__item {
  line-height: 1;
}
.footer-sub__item:not(:first-child) {
  border-left: solid 1px #34312c;
  padding-left: 20px;
}

.hdbar {
  padding: 0 1.56%;
  position: sticky;
  top: 0;
  left: 0;
  z-index: 8888;
}

.mv, .sv {
  width: 100%;
  position: relative;
}
.mv img, .sv img {
  display: block;
  width: 100%;
}

.mv-cc {
  width: 780px;
  max-width: 40.625%;
  aspect-ratio: 780/310;
  background: #fff;
  border-radius: 13px;
  position: absolute;
  left: 0;
  bottom: 0;
  transform: translate(4.17vw, -4.17vw);
  z-index: 1;
}
.mv-cc img {
  max-width: 88.21%;
}

.sv {
  aspect-ratio: 1920/600;
}
.sv-ttl {
  width: 800px;
  max-width: 41.6666666667%;
  aspect-ratio: 800/110;
  background: rgba(255, 255, 255, 0.94);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
  font-size: 45px;
  font-size: 2.34375vw;
}
@media screen and (max-width: 1120px) {
  .sv-ttl {
    font-size: 30px;
  }
}
@media screen and (min-width: 1920px) {
  .sv-ttl {
    font-size: 45px;
  }
}
.sv-bg-business {
  background: url("/img/business/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-bg-kodawari {
  background: url("/img/kodawari/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-bg-products {
  background: url("/img/products/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-bg-case {
  background: url("/img/case/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-bg-company {
  background: url("/img/company/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-bg-news {
  background: url("/img/news/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-bg-contact {
  background: url("/img/contact/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-bg-complete {
  background: url("/img/complete/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-bg-site {
  background: url("/img/site/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-bg-privacy {
  background: url("/img/privacy/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-bg-notfound {
  background: url("/img/notfound/sv.png") center center no-repeat;
  background-size: cover;
}

.top-about, .top-business {
  padding: 170px 0;
}
.top-about .ttl-main, .top-business .ttl-main, .top-contact .ttl-main, .top-news .ttl-main, .top-bnr .ttl-main {
  row-gap: 20px;
}

.top-about {
  padding: 170px 0;
}
.top-about .img {
  margin-right: -220px;
}

.top-business .list-business::after {
  content: "";
  display: block;
  width: 1480px;
  height: 100%;
  border-radius: 15px;
  background: #fff;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0);
  z-index: -1;
}

.top-reason {
  padding: 0 0 100px 0;
}
.top-reason .ttl-main::before {
  content: "";
  display: block;
  width: 100vw;
  height: 50px;
  background-image: linear-gradient(#fdf5e9 0px, #fdf5e9 10px, #fcf2e2 10px, #fcf2e2 25px);
  background-size: 100% 25px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0);
  z-index: -1;
}

.top-contact {
  padding: 160px 0;
}
.top-contact h3 {
  line-height: 1.8181818182;
}
.top-contact .com-layout__item:not(:first-child) {
  border-left: solid 1px #b0ada8;
  padding-left: 40px;
}

.top-news {
  padding: 150px 0;
}
.top-news .btn {
  position: absolute;
  top: 30px;
  right: 0;
  z-index: 1;
}

#ctn-lower section {
  padding: 140px 0;
}
#ctn-lower .ttl-main {
  text-align: center;
  row-gap: 20px;
  margin-bottom: 60px;
}
#ctn-lower .ttl-main__rb {
  font-size: 48px;
  font-size: 4.8rem;
}
@media screen and (max-width: 768px) {
  #ctn-lower .ttl-main__rb {
    font-size: 58px;
    font-size: 7.5520833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  #ctn-lower .ttl-main__rb {
    font-size: 38.6666666667px;
  }
}

.lower-greeting h4 {
  margin-top: -60px;
  position: relative;
  z-index: 1;
}

#footer {
  padding: 130px 0 80px 0;
}/*# sourceMappingURL=style.css.map */