@charset "UTF-8";
/*	cmn-color
------------------------------------ */
/*	transition,hover
------------------------------------ */
/*	media-screen
------------------------------------ */
/*	font
------------------------------------ */
/*	layout
------------------------------------ */
/*	font-size  cmn
------------------------------------ */
/*	com parts  PC
------------------------------------ */
.sns-none {
  display: none !important;
}

.over {
  overflow: hidden;
}

.com-ib {
  display: inline-block;
}

.spxs-only {
  display: none;
}
@media screen and (max-width: 390px) {
  .spxs-only {
    display: inherit;
  }
}

.f26 {
  font-size: 3rem;
}
@media screen and (max-width: 768px) {
  .f26 {
    font-size: 1.5rem;
  }
}

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

.anchor-mp {
  margin: -161px auto 0;
  padding-top: 161px;
}

.nowrap {
  white-space: nowrap;
}

@media screen and (min-width: 768px) {
  .nowrap {
    white-space: nowrap;
  }
}
.no-sb {
  margin: 50px auto 0;
}

@media screen and (min-width: 768px) {
  .com-txt-box p:nth-of-type(n+2) {
    margin-top: 40px;
  }
}

.clamp1 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}

.clamp2 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.clamp3 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

@media screen and (min-width: 768px) {
  .com-pd {
    padding: 130px 0;
  }
}

.com-noimage {
  background: url(../img/ent/logo.png) no-repeat center #ffffff;
  background-size: clamp(48px, 65%, 280px);
}

/*  共通パーツ
------------------------------------ */
.com-box {
  width: 96%;
  max-width: 1720px;
  margin: auto;
  background: url(../img/ptn/pat02.png);
  position: relative;
}
.com-box::before {
  content: "";
  width: 100%;
  height: 100%;
  margin: auto;
  background: url(../img/top/com-box-border-top.png) repeat-x left top, url(../img/top/com-box-border-top.png) repeat-x left bottom, url(../img/top/com-box-border-left.png) repeat-y left top, url(../img/top/com-box-border-left.png) repeat-y right bottom;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  box-sizing: border-box; /* 内側に配置するため */
}
.com-box-ico::before, .com-box-ico::after {
  content: "";
  display: block;
  position: absolute;
}
.com-box-ico::before {
  width: 226px;
  height: 235px;
  background: url(../img/top/service-lb.png) no-repeat left bottom/contain;
  left: -24px;
  bottom: -15px;
}
@media screen and (min-width: 768px) and (max-width: 1286px) {
  .com-box-ico::before {
    width: 135px;
  }
}
.com-box-ico::after {
  width: 208px;
  height: 216px;
  background: url(../img/top/service-rt.png) no-repeat right top/contain;
  top: -24px;
  right: -25px;
}

.com-bg01 {
  background: url(../img/top/about-l.png) no-repeat calc(50% - 666px) 158px, url(../img/top/about-r.png) no-repeat calc(50% + 666px) 321px;
  position: relative;
  z-index: 1;
}
.com-bg01::before {
  content: "";
  display: block;
  width: 100%;
  height: 239px;
  margin: auto;
  background: url(../img/top/about-shadow.png) no-repeat center top/cover;
  position: absolute;
  top: -5px;
  left: 0;
  right: 0;
  z-index: -1;
}
@media screen and (min-width: 1921px) {
  .com-bg01 {
    background-size: auto, auto, 100%;
    background-position-x: left, right;
  }
}
.com-bg02 {
  background: url(../img/top/com-bg-all.png) no-repeat center/cover;
}
.com-bg03 {
  background: url(../img/ptn/pat02.png);
}
.com-bg-illu {
  position: relative;
}
.com-bg-illu::before {
  content: "";
  width: 230px;
  height: 686px;
  background: url(../img/guide/service-illu.png) no-repeat right center/contain;
  position: absolute;
  right: calc(50% - 820px);
  bottom: -101px;
}
@media screen and (max-width: 1670px) {
  .com-bg-illu::before {
    width: 110px;
    height: 330px;
    bottom: -193px;
    right: 20px;
  }
}

.sub .com-bg01 {
  background-position-y: 60px, 89px;
}
.sub .com-bg01::before {
  content: none;
}

.com-mail {
  width: 220px;
  height: 60px;
  text-align: center;
  background: url(../img/top/info-contact-left.png) no-repeat 14px center, url(../img/top/info-contact-right.png) no-repeat calc(100% - 14px) center #ff3c36;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-style: normal;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .com-mail {
    font-size: 1.5rem;
  }
}
.com-mail {
  letter-spacing: 0.06em;
  line-height: 60px;
}

.com-tel {
  line-height: 1;
}
.com-tel-link {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.5rem;
}
@media screen and (max-width: 768px) {
  .com-tel-link {
    font-size: 1.5rem;
  }
}
.com-tel-link {
  letter-spacing: 0.06em;
  color: #fff;
}
.com-tel-link .num {
  font-size: 3.5rem;
}
@media screen and (max-width: 768px) {
  .com-tel-link .num {
    font-size: 1.75rem;
  }
}
.com-tel-note {
  display: block;
  margin-top: 5px;
}

.news-post {
  width: 100%;
  max-width: 700px;
}
.news-post-item {
  border-bottom: 1px solid #fff;
}
.news-post-item:nth-of-type(n+2) {
  margin-top: 29px;
}
.news-post-link {
  display: block;
  padding-bottom: 22px;
}
.news-post-time {
  font-family: "Yuji Syuku", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .news-post-time {
    font-size: 1.5rem;
  }
}
.news-post-time {
  letter-spacing: 0;
  line-height: 1;
}
.news-post-tag {
  display: flex;
  margin-left: 15px;
  border-left: 1px solid #fff;
  flex-wrap: wrap;
  line-height: 1.1;
}
.news-post-tag-txt {
  padding: 0 11px;
  border-right: 1px solid #fff;
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-style: normal;
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  .news-post-tag-txt {
    font-size: 1.5rem;
  }
}
.news-post-tag-txt {
  color: #ff3c36;
  letter-spacing: 0.06em;
  line-height: 1.1;
}
.news-post-ttl {
  margin-top: 17px;
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-style: normal;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .news-post-ttl {
    font-size: 1.5rem;
  }
}
.news-post-ttl {
  letter-spacing: 0.06em;
  line-height: 1.7;
}
.news-post-time, .news-post-tag-txt, .news-post-ttl {
  transition: all 0.3s ease;
}

.com-tag {
  display: flex;
  width: 100%;
  justify-content: center;
  flex-wrap: wrap;
}
.com-tag-item {
  width: 100%;
  max-width: 452px;
}
@media screen and (min-width: 768px) {
  .com-tag-item:nth-of-type(2n) {
    margin-left: 76px;
  }
  .com-tag-item:nth-of-type(n+3) {
    margin-top: 76px;
  }
}

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

  main layout  all

========================================= */
/* top-about  PC
------------------------------------ */
#top-about .about-inner {
  background: url(../img/top/about-ttl-bg.png) no-repeat center 130px;
}
#top-about .about-movie {
  margin: 167px auto 0;
  padding: 32px 0;
  border-top: 2px solid #fff;
  border-bottom: 2px solid #fff;
  position: relative;
}
#top-about .about-movie::before {
  content: "";
  width: 255px;
  height: 100px;
  margin: auto;
  background: url(../img/top/about-movie-t.png) no-repeat center top/contain;
  position: absolute;
  top: -86px;
  left: 0;
  right: 0;
}
#top-about .about-movie-frame {
  width: 100%;
  height: 0;
  margin: auto;
  padding-top: 56.25%;
  position: relative;
}
#top-about .about-txt-box {
  margin: 65px auto 0;
  text-align: center;
}
#top-about .about-illu {
  background: url(../img/top/about-illu-l.png) no-repeat calc(50% - 650px) calc(100% - 339px), url(../img/top/about-illu-r.png) no-repeat calc(50% + 600px) calc(100% - 109px);
}
#top-about .about-btn {
  margin: 68px auto 0;
}

/* top-service  PC
------------------------------------ */
#top-service .service-list {
  margin: -30px auto 0;
  padding: 100px 0 50px;
  background: url(../img/top/service-border.png) no-repeat calc(50% - 2px) 168px, url(../img/top/service-h.png) no-repeat center top;
}
#top-service .service-list-item {
  width: 100%;
  max-width: 340px;
  padding: 20px;
  background: #fff;
}
@media screen and (min-width: 768px) {
  #top-service .service-list-item:nth-of-type(2n) {
    margin-left: 400px;
  }
  #top-service .service-list-item:nth-of-type(n+3) {
    margin-top: 40px;
  }
}
#top-service .service-list-ttl {
  margin: 20px auto 0;
  padding-bottom: 8px;
  border-bottom: 1px solid;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3rem;
}
@media screen and (max-width: 768px) {
  #top-service .service-list-ttl {
    font-size: 1.5rem;
  }
}
#top-service .service-list-ttl {
  letter-spacing: 0.04em;
  color: #0e0e17;
  line-height: 1.3;
  position: relative;
}
#top-service .service-list-ttl::before {
  content: "";
  width: 30px;
  height: 30px;
  background: url(../img/top/service-arw.png) no-repeat center #ff3c36;
  position: absolute;
  right: 0;
  top: 7px;
}

/* top-treatment  PC
------------------------------------ */
#top-treatment .treatment-txt {
  margin: 70px 0 0;
}
#top-treatment .treatment-btn {
  margin-top: 50px;
}

/* top-gallery  PC
------------------------------------ */
#top-gallery .gallery-list {
  margin: 130px auto 0;
}
#top-gallery .gallery-list-item {
  width: 100%;
  max-width: 340px;
  height: 0;
  padding-top: 220px;
  position: relative;
}
@media screen and (min-width: 768px) {
  #top-gallery .gallery-list-item:not(:nth-of-type(3n-2)) {
    margin-left: 30px;
  }
  #top-gallery .gallery-list-item:nth-of-type(n+4) {
    margin-top: 30px;
  }
}
#top-gallery .gallery-btn {
  margin: 80px auto 0;
}

/* top-news  PC
------------------------------------ */
#top-news::before {
  width: 288px;
  height: 585px;
  background-image: url(../img/top/news-d.png);
  right: calc(50% - 883px);
  bottom: -292px;
}
@media screen and (max-width: 1800px) {
  #top-news::before {
    width: 125px;
    height: 256px;
    right: 20px;
    bottom: -100px;
  }
}
#top-news .news-btn {
  margin-top: 64px;
}

/* com-contact  PC
------------------------------------ */
.com-contact {
  background: url(../img/top/contact-l.png) no-repeat calc(50% - 570px) 454px, url(../img/top/contact-r.png) no-repeat calc(50% + 570px) 454px, url(../img/ptn/pat01.png) repeat left bottom/150px;
}
.com-contact .contact-inner {
  background: url(../img/top/contact-ttl-bg.png) no-repeat center 150px;
}
.com-contact .contact-ttl {
  text-align: center;
}
.com-contact .contact-ttl .ja {
  margin-top: -10px;
  font-family: "Yuji Syuku", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 8rem;
}
@media screen and (max-width: 768px) {
  .com-contact .contact-ttl .ja {
    font-size: 4rem;
  }
}
.com-contact .contact-ttl .ja {
  letter-spacing: 0;
  line-height: 1;
}
.com-contact .contact-list {
  margin: 45px auto 0;
}
.com-contact .contact-list li:nth-of-type(n+2) {
  margin-left: 27px;
}
.com-contact .contact-mail {
  width: 300px;
  max-width: none;
  height: 80px;
  line-height: 80px;
}
.com-contact .insta {
  margin: 40px auto 0;
}
.com-contact .insta-ttl {
  text-align: center;
}
.com-contact .insta-ttl .en {
  font-family: "Yuji Syuku", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.5rem;
}
@media screen and (max-width: 768px) {
  .com-contact .insta-ttl .en {
    font-size: 1.5rem;
  }
}
.com-contact .insta-ttl .en {
  letter-spacing: 0;
  color: #ff3c36;
  line-height: 1;
}
.com-contact .insta-ttl .en .sm {
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .com-contact .insta-ttl .en .sm {
    font-size: 1.5rem;
  }
}
.com-contact .insta-ttl .ja {
  display: flex;
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-style: normal;
  font-size: 3rem;
}
@media screen and (max-width: 768px) {
  .com-contact .insta-ttl .ja {
    font-size: 1.5rem;
  }
}
.com-contact .insta-ttl .ja {
  letter-spacing: 0.06em;
  justify-content: space-between;
  align-items: center;
}
.com-contact .insta-ttl .ja::before, .com-contact .insta-ttl .ja::after {
  content: "";
  display: block;
  width: 330px;
  height: 1px;
  background: #fff;
}
.com-contact .insta-list {
  margin: 30px auto 0;
}
.com-contact .insta-list-item {
  width: 100%;
  max-width: 520px;
}
.com-contact .insta-list-link {
  display: block;
  padding: 25px 0 28px;
  text-align: center;
  background: url(../img/top/contact-insta.png) no-repeat 50px center #fff;
  line-height: 1;
}
.com-contact .insta-list-link .ttl {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.5rem;
}
@media screen and (max-width: 768px) {
  .com-contact .insta-list-link .ttl {
    font-size: 1.5rem;
  }
}
.com-contact .insta-list-link .ttl {
  letter-spacing: 0.08em;
  color: #0e0e17;
}
.com-contact .insta-list-link .id {
  display: inline-block;
  margin: 15px auto 0;
  padding: 5px 17px;
  background: #0e0e17;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-style: normal;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .com-contact .insta-list-link .id {
    font-size: 1.5rem;
  }
}
.com-contact .insta-list-link .id {
  letter-spacing: 0.08em;
  color: #fff;
}

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

  sub layout  all

========================================= */
/* guide  PC
------------------------------------ */
#guide .concept-inner {
  background: url(../img/guide/concept-ttl.png) no-repeat center 80px;
}
#guide .concept-ttl {
  margin: 100px auto 0;
}
#guide .concept-flx {
  margin: 60px auto 0;
}
#guide .service-list {
  margin: 40px auto 0;
}
#guide .service-list-item {
  width: 100%;
  padding: 20px;
  background: #fff;
}
@media screen and (min-width: 768px) {
  #guide .service-list-item {
    max-width: 510px;
  }
  #guide .service-list-item:nth-of-type(n+3) {
    margin-top: 60px;
  }
}
#guide .service-list-ttl {
  margin: 10px auto 0;
}
#guide .service-list-txt {
  margin: 10px auto 0;
  color: #0e0e17;
  line-height: 1.6;
}
#guide .note-list {
  margin: 65px auto 0;
}
#guide .note-list-item:nth-of-type(n+2) {
  margin: 30px auto 0;
}
#guide .note-list-txt {
  margin: 20px auto 0;
}
#guide .faq-list {
  margin: 65px auto 0;
}
#guide .faq-list-item:nth-of-type(n+2) {
  margin-top: 30px;
}
#guide .faq-list-ttl {
  padding: 17px 70px;
  background: #fff;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-style: normal;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  #guide .faq-list-ttl {
    font-size: 1.5rem;
  }
}
#guide .faq-list-ttl {
  letter-spacing: 0.06em;
  line-height: 1.6;
  color: #0e0e17;
  position: relative;
}
#guide .faq-list-ttl::before {
  content: "Q";
  width: 40px;
  height: 40px;
  background: #ff3c36;
  text-align: center;
  border-radius: 50%;
  line-height: 40px;
  color: #fff;
  position: absolute;
  top: 50%;
  left: 20px;
  transform: translateY(-50%);
}
#guide .faq-list-txt {
  margin: 15px auto 0;
}
#guide .shop {
  background: url(../img/guide/top.png) repeat-x center top, url(../img/guide/middle.png) repeat-x center, url(../img/guide/bottom.png) repeat-x center bottom;
}
#guide .shop-table {
  margin: 75px auto 0;
}
#guide .shop-map {
  margin: 60px auto 0;
}

/* service  PC
------------------------------------ */
#service .service-inner {
  background: url(../img/service/service-ttl.png) no-repeat center 50px;
}
#service .service-list {
  margin: 80px auto 0;
}
#service .service-list-item {
  background: url(../img/top/about-l.png) no-repeat calc(50% - 666px) 0, url(../img/top/about-r.png) no-repeat calc(50% + 666px) 307px;
}
@media screen and (min-width: 1921px) {
  #service .service-list-item {
    background-size: auto, auto, 100%;
    background-position-x: left, right;
  }
}
#service .service-list-item:nth-of-type(n+2) {
  margin: 80px auto 0;
}
#service .service-list-inner {
  width: 100%;
  max-width: 1080px;
  margin: auto;
}
#service .service-list-img {
  margin: 48px auto 0;
}
#service .service-list-flx {
  display: flex;
  margin-top: 40px;
  align-items: center;
}
#service .service-list-flx-txt-box {
  margin-left: 60px;
}
#service .service-list-contents {
  display: flex;
  margin: 40px auto 0;
  justify-content: space-between;
  flex-wrap: wrap;
}
#service .service-list-contents li {
  width: 100%;
  max-width: 510px;
}
@media screen and (min-width: 768px) {
  #service .service-list-contents li:nth-of-type(n+3) {
    margin-top: 40px;
  }
}

/* about  PC
------------------------------------ */
#about .commit {
  background-position-y: 247px, calc(100% - 220px);
}
#about .commit-ttl .en {
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-style: normal;
  font-size: 4rem;
}
@media screen and (max-width: 768px) {
  #about .commit-ttl .en {
    font-size: 2rem;
  }
}
#about .commit-ttl .en {
  color: #ff3c36;
}
#about .commit-ttl .ja {
  margin: 40px auto 0;
  padding: 0 80px;
  background-image: url(../img/about/commit-l.png), url(../img/about/commit-r.png);
}
#about .commit-img {
  margin: 90px auto 0;
}
#about .commit-list {
  margin: 60px auto 0;
}
#about .commit-list-item:nth-of-type(n+2) {
  margin: 30px auto 0;
}
#about .commit-list-ttl {
  text-align: left;
  padding-left: 21px;
}
#about .commit-list-ttl .ac {
  margin-right: 10px;
}
#about .commit-list-txt {
  margin-top: 30px;
}
#about .price-flx {
  margin: 68px auto 0;
}
#about .price-flx-con {
  width: 100%;
}
@media screen and (min-width: 768px) {
  #about .price-flx-con {
    max-width: 510px;
  }
}
#about .price-flx-note {
  margin-top: 15px;
}
#about .price-table {
  width: 100%;
}
#about .price-table td {
  text-align: right;
}
#about .note {
  background: url(../img/about/note-l.png) no-repeat calc(50% - 730px) 236px, url(../img/about/note-r.png) no-repeat calc(50% + 730px) 247px;
}
#about .note-list {
  margin: 55px auto 0;
}
#about .note-list-item:nth-of-type(n+2) {
  margin-top: 24px;
}
#about .note-list-txt {
  margin: 20px auto 0;
}
#about .profile {
  background: url(../img/top/com-bg02-top.png) repeat-x center top, url(../img/top/com-bg02-bottom.png) repeat-x center bottom;
}
#about .profile-txt-box {
  margin-top: 50px;
}
#about .profile-dl {
  display: flex;
  margin-top: 34px;
  align-items: center;
}
#about .profile-dl dt {
  padding: 0 20px;
  background: #ff3c36;
  text-align: center;
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-style: normal;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  #about .profile-dl dt {
    font-size: 1.5rem;
  }
}
#about .profile-dl dt {
  letter-spacing: 0.06em;
  color: #fff;
}
#about .profile-dl dd {
  margin-left: 16px;
}

/* gallery  PC
------------------------------------ */
#gallery .gallery {
  background: url(../img/gallery/top.png) repeat-x center top, url(../img/gallery/bottom.png) repeat-x center bottom;
}
#gallery .gallery-flx {
  margin: 80px auto 0;
}
#gallery .gallery-tag {
  width: 100%;
  max-width: 180px;
  margin-top: -20px;
}
#gallery .gallery-tag-item {
  padding: 20px 14px;
  border-bottom: 1px solid #fff;
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-style: normal;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  #gallery .gallery-tag-item {
    font-size: 1.5rem;
  }
}
#gallery .gallery-tag-item {
  letter-spacing: 0.06em;
  line-height: 1.6;
  position: relative;
}
#gallery .gallery-tag-item::before {
  content: "";
  width: 6px;
  height: 6px;
  background: #ff3c36;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
#gallery .gallery-list {
  width: 100%;
}
@media screen and (min-width: 768px) {
  #gallery .gallery-list {
    max-width: 850px;
  }
  #gallery .gallery-list-item:nth-of-type(n+2) {
    margin-top: 50px;
  }
}
#gallery .gallery-list-ttl {
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  #gallery .gallery-list-ttl {
    font-size: 1.5rem;
  }
}
#gallery .gallery-list-img {
  display: flex;
  margin: 40px auto 0;
  flex-wrap: wrap;
}
#gallery .gallery-list-img li {
  width: 100%;
  max-width: 260px;
  height: 0;
  padding-top: 300px;
  position: relative;
}
@media screen and (min-width: 768px) {
  #gallery .gallery-list-img li:not(:nth-of-type(3n-2)) {
    margin-left: 35px;
  }
  #gallery .gallery-list-img li:nth-of-type(n+4) {
    margin-top: 35px;
  }
}

/* news  PC
------------------------------------ */
#news .com-news-link {
  width: 100%;
  padding: 30px;
}
#news .detail-box {
  width: 100%;
  padding: 50px;
}

/* contact  PC
------------------------------------ */
#contact input[type=radio] + label, #contact input[type=checkbox] + label {
  color: #fff;
}
#contact .contact-form-table a {
  color: #fff;
}

/* site  PC
------------------------------------ */
#site .site-box {
  padding: 50px;
}
#site .site-li {
  border-color: #fff !important;
}
#site .site-link {
  color: #fff;
}
#site .site-link::before {
  border-color: #fff !important;
}/*# sourceMappingURL=all.css.map */