/*	cmn-color
------------------------------------ */
/*	transition,hover
------------------------------------ */
/*	media-screen
------------------------------------ */
/*	font
------------------------------------ */
@font-face {
  font-family: "Noto sans Regular";
  src: url("../fonts/noto-sans-jp-r.woff") format("woff");
}
@font-face {
  font-family: "Noto sans Medium";
  src: url("../fonts/noto-sans-jp-m.woff") format("woff");
}
@font-face {
  font-family: "Noto sans Bold";
  src: url("../fonts/noto-sans-jp-b.woff") format("woff");
}
@font-face {
  font-family: "Noto Serif Regular";
  src: url("../fonts/NotoSerifCJKjp-Regular.woff") format("woff");
}
@font-face {
  font-family: "Noto Serif Medium";
  src: url("../fonts/NotoSerifCJKjp-Medium.woff") format("woff");
}
@font-face {
  font-family: "Noto Serif SemiBold";
  src: url("../fonts/NotoSerifCJKjp-SemiBold.woff") format("woff");
}
@font-face {
  font-family: "Noto Serif Bold";
  src: url("../fonts/NotoSerifCJKjp-Bold.woff") format("woff");
}
@font-face {
  font-family: "kenstein";
  src: url("../fonts/kenstein-regular.ttf");
}
@font-face {
  font-family: "zenkaku";
  src: url("../fonts/ZenKakuGothicNew-Medium.ttf");
}
@font-face {
  font-family: "zenkaku-b";
  src: url("../fonts/ZenKakuGothicNew-Bold.ttf");
}
/*	layout
------------------------------------ */
/*	cmn-color
------------------------------------ */
/*	transition,hover
------------------------------------ */
/*	media-screen
------------------------------------ */
/*	font
------------------------------------ */
@font-face {
  font-family: "Noto sans Regular";
  src: url("../fonts/noto-sans-jp-r.woff") format("woff");
}
@font-face {
  font-family: "Noto sans Medium";
  src: url("../fonts/noto-sans-jp-m.woff") format("woff");
}
@font-face {
  font-family: "Noto sans Bold";
  src: url("../fonts/noto-sans-jp-b.woff") format("woff");
}
@font-face {
  font-family: "Noto Serif Regular";
  src: url("../fonts/NotoSerifCJKjp-Regular.woff") format("woff");
}
@font-face {
  font-family: "Noto Serif Medium";
  src: url("../fonts/NotoSerifCJKjp-Medium.woff") format("woff");
}
@font-face {
  font-family: "Noto Serif SemiBold";
  src: url("../fonts/NotoSerifCJKjp-SemiBold.woff") format("woff");
}
@font-face {
  font-family: "Noto Serif Bold";
  src: url("../fonts/NotoSerifCJKjp-Bold.woff") format("woff");
}
@font-face {
  font-family: "kenstein";
  src: url("../fonts/kenstein-regular.ttf");
}
@font-face {
  font-family: "zenkaku";
  src: url("../fonts/ZenKakuGothicNew-Medium.ttf");
}
@font-face {
  font-family: "zenkaku-b";
  src: url("../fonts/ZenKakuGothicNew-Bold.ttf");
}
/*	layout
------------------------------------ */
/*	font-size  cmn
------------------------------------ */
/* =========================================

  main layout  all

========================================= */
/*	cmn parts  PC
------------------------------------ */
.sns-none {
  display: none !important;
}

.over {
  overflow: hidden;
}

.pre {
  white-space: pre-line;
}

.no-sb {
  margin: 50px auto 0;
}

.cmn-txt-box p:nth-of-type(n+2) {
  margin-top: 30px;
}

.para1 {
  background: url(../img/top/para_01.png) no-repeat center/cover;
  background-attachment: fixed;
}
.para2 {
  background: url(../img/top/para_02.png) no-repeat center/cover;
  background-attachment: fixed;
}
.para3 {
  background: url(../img/top/para_03.png) no-repeat center/cover;
  background-attachment: fixed;
}

.pro-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin: 50px auto 0;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
.pro-list-item {
  width: 100%;
  max-width: 240px;
}
@media screen and (min-width: 768px) {
  .pro-list-item:not(:nth-of-type(4n-3)) {
    margin-left: 40px;
  }
  .pro-list-item:nth-of-type(n+5) {
    margin-top: 60px;
  }
}
.pro-list-link {
  display: block;
  padding-bottom: 10px;
  border-bottom: 2px solid #666666;
}
.pro-list-link:hover {
  opacity: 1;
}
.pro-list-link:hover p {
  color: #8fcec3;
}
.pro-list-link:hover figure {
  opacity: 0.7;
}
.pro-list-figure {
  width: 100%;
  height: 0;
  padding-top: 100%;
  border-radius: 17px;
  overflow: hidden;
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.pro-list-ttl, .pro-list-price {
  text-align: center;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  color: #333333;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .pro-list-ttl, .pro-list-price {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
.pro-list-ttl {
  margin-top: 20px;
}

.cmn-img {
  width: 100%;
  height: 400px;
}

/*	sec01  PC
------------------------------------ */
#sec01 .bg {
  background: url(../img/top/sec01-house.png) no-repeat center/cover;
  position: relative;
}
#sec01 .sec-inner {
  background: url(../img/top/sec01-kanban.png) no-repeat left calc(100% - 120px);
}
@media screen and (min-width: 768px) {
  #sec01 .sec-inner {
    margin: -280px auto 0;
  }
}
#sec01 .head {
  max-width: 580px;
  margin: auto;
  text-align: center;
  position: relative;
}
#sec01 .head::before, #sec01 .head::after {
  content: "";
  display: inline-block;
  margin: auto;
  position: absolute;
}
#sec01 .head::before {
  width: 126px;
  height: 50px;
  background: url(../img/top/head-ico.png) no-repeat center/contain;
  left: 0;
  right: 0;
  top: -50px;
}
#sec01 .head::after {
  width: 212px;
  height: 56px;
  background: url(../img/top/head-fuki.png) no-repeat center/contain;
  left: -76px;
  right: 0;
  bottom: -51px;
}
#sec01 .head-txt {
  display: inline-block;
  padding: 0 25px;
  font-family: "Noto serif SemiBold", serif;
  font-size: 36px;
  font-size: 3.6rem;
  color: #999999;
  letter-spacing: 0.2em;
  background: #fff;
}
@media screen and (max-width: 767px) {
  #sec01 .head-txt {
    font-size: 24px;
    font-size: 2.4rem;
  }
}
#sec01 .head-txt:nth-of-type(n+2) {
  margin-top: 20px;
}
#sec01 .head-txt-lg {
  font-size: 46px;
  font-size: 4.6rem;
  color: #84cbbf;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  #sec01 .head-txt-lg {
    font-size: 28px;
    font-size: 2.8rem;
  }
}
#sec01 .ttl01 {
  max-width: 585px;
  margin: 114px auto 0;
  text-align: center;
}
#sec01 .ttl01-txt {
  display: inline-block;
  font-family: "zenkaku-b", sans-serif;
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: 0.2em;
  line-height: 2.22;
  color: #8fcec3;
}
@media screen and (max-width: 767px) {
  #sec01 .ttl01-txt {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 768px) {
  #sec01 .ttl01-txt {
    border-bottom: 1px solid #8fcec3;
  }
}
#sec01 .ttl02 {
  text-align: center;
}
#sec01 .ttl02::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin: 24px auto 30px;
  border-style: solid;
  border-width: 28px 35px 0 35px;
  border-color: #ceeae5 transparent transparent transparent;
}
#sec01 .ttl02-txt {
  font-family: "zenkaku", sans-serif;
  font-size: 22px;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  line-height: 1.82;
  color: #555555;
}
@media screen and (max-width: 767px) {
  #sec01 .ttl02-txt {
    font-size: 18px;
    font-size: 1.8rem;
  }
}
#sec01 .ttl02-txt-lg {
  padding-bottom: 20px;
  background: url(../img/top/sec01-marker.png) no-repeat left bottom;
}
#sec01 .cmn-btn-wrap {
  margin: 75px auto 0;
}
#sec01 .para {
  width: 100%;
  height: 400px;
}

/*	sec02  PC
------------------------------------ */
#sec02 .bg {
  background: url(../img/top/sec02-bg.png) no-repeat center/cover;
}
#sec02 .sec-inner {
  position: relative;
}
#sec02 .box {
  max-width: 490px;
  margin-left: auto;
}
#sec02 .box-figure {
  position: absolute;
  left: calc(50% - 960px);
  top: 240px;
}
#sec02 .cmn-txt-box {
  margin-top: 29px;
}

/*	sec03  PC
------------------------------------ */
#sec03 .bg {
  margin: -80px auto 0;
  background: url(../img/top/sec03-bg-ico.png) no-repeat 91.67% calc(100% - 232px)/11.71875%, url(../img/top/sec03-bg.png) no-repeat center top/cover;
}
#sec03 .list {
  margin-top: -142px;
}
#sec03 .list-item {
  text-align: center;
}
@media screen and (min-width: 768px) {
  #sec03 .list-item:nth-of-type(1) {
    margin-left: 450px;
  }
  #sec03 .list-item:nth-of-type(2) {
    margin-left: 120px;
    padding-right: 27px;
  }
  #sec03 .list-item:nth-of-type(4) {
    margin-left: 132px;
  }
  #sec03 .list-item:nth-of-type(5) {
    margin-left: 99px;
  }
  #sec03 .list-item:nth-of-type(n+3) {
    margin-top: 68px;
  }
}
#sec03 .list-txt {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  height: 68px;
  margin: 22px auto 0;
  padding: 0 30px;
  background: url(../img/top/sec03-cir.png) no-repeat left center, url(../img/top/sec03-cir.png) no-repeat right center;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 20px;
  font-size: 2rem;
  letter-spacing: 0.1em;
  color: #666666;
  line-height: 1.5;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  #sec03 .list-txt {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
#sec03 .cmn-btn-wrap {
  margin: 58px auto 0;
}
#sec03 .para {
  height: 808px;
}

/*	sec04  PC
------------------------------------ */
#sec04 .bg {
  background: url(../img/top/sec04-bg.png) no-repeat center/cover;
  position: relative;
}
#sec04 .bg::before {
  content: "";
  display: inline-block;
  width: 26.875%;
  height: 0;
  padding-top: 13.3333%;
  background: url(../img/top/sec04-ico.png) no-repeat right bottom/contain;
  position: absolute;
  bottom: -63px;
  right: 51px;
}
#sec04 .head-type01 {
  text-align: center;
}
#sec04 .head-type01-en {
  left: calc(50% - 330px);
}
#sec04 .cmn-btn-wrap {
  margin: 70px auto 0;
}

/*	cmn-contact  PC
------------------------------------ */
.cmn-contact .bg {
  background: url(../img/top/cmn-contact-l.png) no-repeat calc(50% - 740px) 125px, url(../img/top/cmn-contact-r.png) no-repeat calc(50% + 695px) 73%;
  background-color: #fff;
}
@media screen and (max-width: 1574px) {
  .cmn-contact .bg {
    background: url(../img/top/cmn-contact-l.png) no-repeat 15px/8.2%, url(../img/top/cmn-contact-r.png) no-repeat calc(100% - 15px)/3.75%;
    background-color: #fff;
  }
}
@media screen and (max-width: 1305px) {
  .cmn-contact .bg {
    background: url(../img/top/cmn-contact-l.png) no-repeat 15px 5%/8.2%, url(../img/top/cmn-contact-r.png) no-repeat calc(100% - 15px) 95%/3.75%;
    background-color: #fff;
  }
}
.cmn-contact .list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.cmn-contact .list-item {
  width: 100%;
  max-width: 460px;
}
.cmn-contact .list-item:nth-of-type(n+2) {
  margin-left: 120px;
}
.cmn-contact .list-link {
  display: block;
  padding: 95px 0 80px 80px;
  background: url(../img/top/cmn-contact-house.png) no-repeat center/contain;
}
@media screen and (min-width: 768px) {
  .cmn-contact .list-link-voice {
    padding-left: 112px;
  }
}
.cmn-contact .list-link:hover .list-ja {
  color: #8fcec3;
}
.cmn-contact .list-en {
  display: inline-block;
  font-family: "kenstein", serif;
  font-size: 40px;
  font-size: 4rem;
  letter-spacing: 0.025em;
  color: #8fcec3;
  -webkit-transform: rotate(-5deg);
          transform: rotate(-5deg);
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .cmn-contact .list-en {
    font-size: 22px;
    font-size: 2.2rem;
  }
}
.cmn-contact .list-ja {
  display: block;
  margin-top: 5px;
  padding-left: 66px;
  font-family: "zenkaku", sans-serif;
  font-size: 20px;
  font-size: 2rem;
  letter-spacing: 0.1em;
  color: #666666;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .cmn-contact .list-ja {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

/*	access  PC
------------------------------------ */
.access .para {
  width: 100%;
  height: 480px;
}
.access .bg {
  background: url(../img/top/contact-bg.png) no-repeat center/cover;
}
.access .sec-inner {
  width: 100%;
  max-width: 1120px;
  position: relative;
}
.access .box {
  width: 100%;
  max-width: 560px;
  padding: 127px 0;
  background: rgba(227, 225, 214, 0.9);
  position: absolute;
  top: -280px;
  right: 0;
}
.access .head-type01 {
  text-align: center;
}
.access .head-type01-en {
  color: #fff;
  top: -54px;
  left: calc(50% - 190px);
}
.access .head-type01-ja {
  color: #666666;
}
.access .list {
  margin: 35px auto 0;
}
.access .list-item {
  text-align: center;
}
.access .list-item:nth-of-type(n+2) {
  margin-top: 20px;
}
.access .list-tel {
  display: block;
  width: 100%;
  max-width: 300px;
  margin: auto;
  height: 80px;
  padding-left: 29px;
  background: url(../img/top/contact-tel.png) no-repeat 42px center;
  background-color: #707070;
  text-align: center;
  line-height: 80px;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 28px;
  font-size: 2.8rem;
  letter-spacing: 0.025em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .access .list-tel {
    font-size: 21px;
    font-size: 2.1rem;
  }
}
.access .list-mail {
  background: url(../img/top/contact-mail.png) no-repeat 50px center;
}
.access .list-shop {
  background: url(../img/top/contact-cart.png) no-repeat 55px center;
}
.access .cmn-btn {
  max-width: 300px;
  padding-left: 30px;
}
.access .cmn-btn:hover {
  background-color: #666666;
}
.access .ggmap {
  max-width: 560px;
  margin: 0;
}

/*	news  PC
------------------------------------ */
#news .bg {
  background-color: #fff;
}
#news .head-type01 {
  position: relative;
}
#news .head-type01::before, #news .head-type01::after {
  content: "";
  display: inline-block;
  position: absolute;
}
#news .head-type01::before {
  width: 212px;
  height: 56px;
  background: url(../img/top/news-fuki.png) no-repeat center/contain;
  left: -63px;
  bottom: -41px;
}
#news .head-type01::after {
  width: 60px;
  height: 90px;
  background: url(../img/top/door.png) no-repeat center/contain;
  bottom: -170px;
  left: -15px;
}
#news .head-type01-en {
  left: -33px;
  -webkit-transform: rotate(-10deg);
          transform: rotate(-10deg);
}
#news .head-type01-ja {
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 767px) {
  #news .head-type01-ja {
    font-size: 20px;
    font-size: 2rem;
  }
}
#news .list {
  width: 100%;
  max-width: 750px;
}
#news .list-item:nth-of-type(n+2) {
  margin-top: 10px;
}
#news .list-link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  padding: 16px 30px;
  background-color: #f7f6f3;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
#news .list-link:hover {
  background-color: #666666;
}
#news .list-link:hover p, #news .list-link:hover time {
  color: #fff !important;
}
#news .list-time {
  font-family: "Noto sans Bold", sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  color: #444444;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  #news .list-time {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
#news .list-tag {
  display: inline-block;
  margin: 0 5px 5px 0;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 15px;
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  line-height: 1;
  color: #444444;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  #news .list-tag {
    font-size: 13px;
    font-size: 1.3rem;
  }
}
#news .list-ttl {
  width: 100%;
  max-width: 568px;
  font-family: "Noto sans Regular", sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 1;
  color: #666666;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  #news .list-ttl {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
#news .list-ttl-box {
  margin-left: 20px;
  padding-left: 30px;
  border-left: 1px solid #8fcec3;
}
#news .btn {
  padding: 0 48px 12px 0;
  background: url(../img/top/blog-btn.png) no-repeat bottom right;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  color: #666666;
}
@media screen and (max-width: 767px) {
  #news .btn {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
#news .btn-wrap {
  margin-top: 35px;
  text-align: right;
}
#news .cmn-txt {
  margin: auto;
  padding-bottom: 100px;
}

/* =========================================

  sub layout  all

========================================= */
/*	commitment  PC
------------------------------------ */
#commitment .sec01 .bg {
  background: url(../img/commitment/sec01-bg.png) no-repeat center bottom/cover;
}
#commitment .sec01 .list {
  margin: 45px auto 0;
}
#commitment .sec01 .list-item {
  position: relative;
  z-index: 1;
}
#commitment .sec01 .list-item:nth-of-type(n+2) {
  margin-top: 98px;
}
@media screen and (min-width: 768px) {
  #commitment .sec01 .list-item:nth-of-type(2n) .list-box {
    margin-left: auto;
  }
  #commitment .sec01 .list-item:nth-of-type(2n) .list-figure {
    left: 0;
  }
  #commitment .sec01 .list-item:nth-of-type(2n) .list-num {
    right: 0;
  }
  #commitment .sec01 .list-item:nth-of-type(2n-1) .list-figure {
    right: 0;
  }
  #commitment .sec01 .list-item:nth-of-type(2n-1) .list-num {
    left: 0;
  }
}
#commitment .sec01 .list-box {
  width: 100%;
  max-width: 620px;
  height: 360px;
  padding: 50px 45px 80px;
  background: #fff;
}
#commitment .sec01 .list-num {
  font-family: "zenkaku", sans-serif;
  font-size: 88px;
  font-size: 8.8rem;
  letter-spacing: 0.1em;
  color: #ececec;
  line-height: 1;
  position: absolute;
  top: 275px;
}
@media screen and (max-width: 767px) {
  #commitment .sec01 .list-num {
    font-size: 44px;
    font-size: 4.4rem;
  }
}
#commitment .sec01 .list-ttl {
  display: inline-block;
  padding: 0 25px;
  background: url(../img/top/sec03-cir.png) no-repeat left center, url(../img/top/sec03-cir.png) no-repeat right center;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 20px;
  font-size: 2rem;
  letter-spacing: 0.1em;
  color: #666666;
}
@media screen and (max-width: 767px) {
  #commitment .sec01 .list-ttl {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 768px) {
  #commitment .sec01 .list-figure {
    position: absolute;
    top: 40px;
    z-index: -1;
  }
}
#commitment .sec01 .list-txt {
  margin-top: 27px;
}
#commitment .sec02 .bg {
  background: url(../img/commitment/qa-bg.png) no-repeat center/cover;
}
#commitment .sec02 .list {
  margin: 40px auto 0;
}
#commitment .sec02 .list-item:nth-of-type(n+2) {
  margin-top: 60px;
}
#commitment .sec02 .list-qa {
  width: 100%;
  max-width: 980px;
  margin-left: auto;
  position: relative;
}
#commitment .sec02 .list-qa::before {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background-color: #dcdcdc;
  text-align: center;
  font-family: "zenkaku-b", sans-serif;
  font-size: 30px;
  font-size: 3rem;
  letter-spacing: 0;
  color: #ffffff;
  line-height: 70px;
  position: absolute;
  left: -100px;
  top: 0;
}
@media screen and (max-width: 767px) {
  #commitment .sec02 .list-qa::before {
    font-size: 22px;
    font-size: 2.2rem;
  }
}
#commitment .sec02 .list-q {
  padding: 18px 18px 5px;
  border-bottom: 2px solid #dcdcdc;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  color: #666666;
}
@media screen and (max-width: 767px) {
  #commitment .sec02 .list-q {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
#commitment .sec02 .list-q::before {
  content: "Q";
}
#commitment .sec02 .list-a {
  margin-top: 31px;
  padding: 20px;
  background-color: #fff;
  font-family: "Noto sans Regular", sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  color: #666666;
  white-space: pre-line;
}
@media screen and (max-width: 767px) {
  #commitment .sec02 .list-a {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
#commitment .sec02 .list-a::before {
  content: "A";
}
#commitment .cmn-img {
  background: url(../img/commitment/img-para.png) no-repeat center/cover;
}

/*	items  PC
------------------------------------ */
#items .sec01 .bg {
  position: relative;
}
#items .sec01 .bg::before {
  content: "";
  display: inline-block;
  width: 26.51%;
  height: 0;
  padding-top: 21.667%;
  background: url(../img/items/sec01-ico.png) no-repeat left bottom/contain;
  position: absolute;
  bottom: -95px;
  left: 0;
}
#items .sec01 .sec-inner {
  width: 100%;
  max-width: 1137px;
  background: url(../img/items/sec01-l.png) no-repeat left bottom, url(../img/items/sec01-r.png) no-repeat calc(100% - 40px) bottom;
}
#items .sec01 .list {
  width: 100%;
  max-width: 420px;
  margin: 25px auto 0;
  text-align: center;
}
#items .sec01 .list-item {
  display: inline-block;
  border-bottom: 1px solid #8fcec3;
  font-family: "zenkaku-b", sans-serif;
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: 0.2em;
  color: #8fcec3;
}
@media screen and (max-width: 767px) {
  #items .sec01 .list-item {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
#items .sec01 .list-item:nth-of-type(n+2) {
  margin-top: 27px;
}
#items .sec02 .bg {
  background-size: auto auto;
  background-color: rgb(255, 255, 255);
  background-image: -webkit-repeating-linear-gradient(left, transparent, transparent 2px, rgb(250, 247, 242) 2px, rgb(250, 247, 242) 8px);
  background-image: repeating-linear-gradient(90deg, transparent, transparent 2px, rgb(250, 247, 242) 2px, rgb(250, 247, 242) 8px);
}
#items .sec02 .cmn-btn-wrap {
  margin: 70px auto 0;
}
#items .cmn-img {
  background: url(../img/items/img.png) no-repeat center/cover;
}
#items .detail-flex {
  width: 100%;
}
#items .detail-figure {
  width: 100%;
  height: 0;
  padding-top: 67%;
  border-radius: 15px;
  overflow: hidden;
  position: relative;
}
#items .detail-figure-wrap {
  width: 100%;
  max-width: 500px;
}
#items .detail-figure .ofj {
  -o-object-fit: contain;
     object-fit: contain;
  font-family: "object-fit: cover;";
}
#items .detail-txt {
  white-space: pre-line;
}
#items .detail-txt-box {
  width: 100%;
  max-width: 500px;
}
#items .detail-txt-wrap {
  margin-top: 20px;
}
#items .detail-ttl {
  font-family: "Noto sans Bold", sans-serif;
  font-size: 32px;
  font-size: 3.2rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  #items .detail-ttl {
    font-size: 22px;
    font-size: 2.2rem;
  }
}
#items .detail-price {
  font-family: "Noto sans Medium", sans-serif;
  font-size: 25px;
  font-size: 2.5rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  #items .detail-price {
    font-size: 20px;
    font-size: 2rem;
  }
}
#items .detail-btn-wrap {
  margin: 30px auto 0;
}
#items .detail-img {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin: 50px auto 0;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  #items .detail-img-item {
    width: 100%;
    max-width: 210px;
  }
  #items .detail-img-item:not(:nth-of-type(5n-4)) {
    margin-left: 7.5px;
  }
  #items .detail-img-item:nth-of-type(n+6) {
    margin-top: 7.5px;
  }
}
#items .detail-img-figure {
  width: 100%;
  height: 0;
  padding-top: 100%;
  border-radius: 13px;
  overflow: hidden;
  position: relative;
}

/*	voice  PC
------------------------------------ */
#voice .sec01 .list {
  max-width: 1040px;
  margin: 40px auto 0;
}
#voice .sec01 .list-item {
  padding: 17px 35px;
  border: 2px solid #eeeeee;
}
#voice .sec01 .list-item:nth-of-type(n+2) {
  margin-top: 50px;
}
#voice .sec01 .list-name {
  padding-bottom: 10px;
  border-bottom: 2px solid #eeeeee;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 20px;
  font-size: 2rem;
  letter-spacing: 0.1em;
  color: #666666;
}
@media screen and (max-width: 767px) {
  #voice .sec01 .list-name {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
#voice .sec01 .list-txt {
  margin-top: 12px;
  font-size: 16px;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 1.625;
  white-space: pre-line;
}
@media screen and (max-width: 767px) {
  #voice .sec01 .list-txt {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
#voice .cmn-img {
  background: url(../img/voice/img.png) no-repeat center/cover;
}

/*	shop  PC
------------------------------------ */
#shop .sec01 .list {
  width: 100%;
  max-width: 950px;
  margin: 40px auto 0;
}
#shop .sec01 .list-item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (min-width: 768px) {
  #shop .sec01 .list-item:nth-of-type(1) {
    padding-top: 12px;
  }
  #shop .sec01 .list-item:nth-of-type(n+2) {
    margin-top: -70px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  #shop .sec01 .list-item:nth-of-type(n+2) .list-txt-box {
    padding-top: 130px;
  }
}
#shop .sec01 .list-txt-box {
  width: 100%;
  max-width: 460px;
}
#shop .sec01 .list-name {
  margin-top: 20px;
  text-align: right;
}
#shop .sec02 .cmn-table {
  margin: 40px auto 0;
}
#shop .sec02 .ggmap {
  margin: 60px auto 0;
}

/*	contact  Pc
------------------------------------ */
#contact .sec01 .cmn-txt {
  margin: 35px auto 0;
}
@media screen and (min-width: 768px) {
  #contact .sec01 .cmn-txt {
    text-align: center;
  }
}
#contact .sec01 .cmn-tel {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 300px;
  height: 80px;
  margin: auto;
  padding-left: 30px;
  background: url(../img/contact/tel.png) no-repeat 42px center;
  background-color: #707070;
  line-height: 80px;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 28px;
  font-size: 2.8rem;
  letter-spacing: 0.025em;
  color: #fff;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  #contact .sec01 .cmn-tel {
    font-size: 21px;
    font-size: 2.1rem;
  }
}
#contact .sec01 .cmn-tel-wrap {
  margin: 40px auto 0;
  text-align: center;
}
#contact .sec01 .work-txt {
  margin: 15px auto 0;
  font-family: "Noto sans Regular", sans-serif;
  text-align: center;
  font-size: 14px;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  color: #666666;
}
@media screen and (max-width: 767px) {
  #contact .sec01 .work-txt {
    font-size: 13px;
    font-size: 1.3rem;
  }
}
#contact .sec02 .wrap {
  margin: 40px auto 0;
}
#contact .sec02 .note {
  padding-bottom: 10px;
  font-family: "Noto sans Regular", sans-serif;
  font-size: 14px;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  color: #666666;
}
@media screen and (max-width: 767px) {
  #contact .sec02 .note {
    font-size: 13px;
    font-size: 1.3rem;
  }
}

/*	blog  PC
------------------------------------ */
#blog .sec01 .tag-nav {
  max-width: 1080px;
  margin: auto;
}
#blog .sec01 .tag-head {
  margin: 30px auto 0;
  text-align: center;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 25px;
  font-size: 2.5rem;
  letter-spacing: 0.05em;
  color: #666666;
}
@media screen and (max-width: 767px) {
  #blog .sec01 .tag-head {
    font-size: 20px;
    font-size: 2rem;
  }
}
#blog .sec01 .tag-ul {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin: 30px auto 0;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
#blog .sec01 .tag-li {
  margin: 0 20px 20px 0;
}
#blog .sec01 .tag-link {
  display: inline-block;
  text-align: center;
  padding: 5px 20px;
  font-size: 18px;
  font-size: 1.8rem;
  font-family: "Noto sans Medium", sans-serif;
  background: #8fcec3;
  color: #fff;
}
@media screen and (max-width: 767px) {
  #blog .sec01 .tag-link {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
#blog .sec01 .list {
  width: 100%;
  max-width: 1080px;
  margin: 30px auto 0;
}
#blog .sec01 .list-item {
  max-width: 100%;
}
#blog .sec01 .list-item:nth-of-type(n+2) {
  margin-top: 30px;
}
#blog .sec01 .list-link {
  display: block;
  width: 100%;
  padding: 24px 30px 25px 40px;
  border: 2px solid #8fcec3;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
#blog .sec01 .list-link:hover {
  opacity: 0.7;
}
#blog .sec01 .list-time {
  display: inline-block;
  font-family: "Noto sans Bold", sans-serif;
  font-size: 15px;
  font-size: 1.5rem;
  letter-spacing: 0.03em;
  color: #666666;
}
@media screen and (max-width: 767px) {
  #blog .sec01 .list-time {
    font-size: 13px;
    font-size: 1.3rem;
  }
}
#blog .sec01 .list-tag {
  display: inline-block;
  margin: 0 10px 10px 0;
  padding: 0 15px;
  height: 35px;
  background-color: #8fcec3;
  line-height: 35px;
  text-align: center;
  color: #fff;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 15px;
  font-size: 1.5rem;
  letter-spacing: 0.03em;
}
@media screen and (max-width: 767px) {
  #blog .sec01 .list-tag {
    font-size: 13px;
    font-size: 1.3rem;
  }
}
#blog .sec01 .list-tag-wrap {
  width: 100%;
  max-width: 650px;
}
#blog .sec01 .list-flex-thumb .list-txt-box {
  max-width: 760px;
}
#blog .sec01 .list-txt-box {
  width: 100%;
}
#blog .sec01 .list-txt {
  margin-top: 7px;
  color: #666666;
  font-family: "Noto sans Regular", sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  #blog .sec01 .list-txt {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
#blog .sec01 .list-figure {
  width: 100%;
  max-width: 222px;
  height: 0;
  padding-top: 152px;
  border-radius: 4px;
  position: relative;
}
#blog .sec01 .list-ttl-txt {
  width: 100%;
  max-width: 600px;
  margin-left: 15px;
  color: #666666;
  font-family: "Noto sans Medium", sans-serif;
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: 0.03em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  #blog .sec01 .list-ttl-txt {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
#blog .sec01 .list-ttl {
  margin-left: 0;
}
#blog .detail .sec-inner {
  max-width: 1080px;
}
#blog .detail .head-type02 {
  font-size: 30px;
  font-size: 3rem;
}
@media screen and (max-width: 767px) {
  #blog .detail .head-type02 {
    font-size: 22px;
    font-size: 2.2rem;
  }
}
#blog .breadcrumb .fle {
  position: static;
}