@charset "UTF-8";
/*	cmn-color
------------------------------------ */
/*	transition,hover
------------------------------------ */
/*	media-screen
------------------------------------ */
/*	font
------------------------------------ */
@font-face {
  font-family: "ZenKakuGothicNew-Medium";
  src: url("../fonts/ZenKakuGothicNew-Medium.ttf");
  font-display: swap;
}
@font-face {
  font-family: "ZenKakuGothicNew-Bold";
  src: url("../fonts/ZenKakuGothicNew-Bold.ttf");
  font-display: swap;
}
@font-face {
  font-family: "ZenMaruGothic-Medium";
  src: url("../fonts/ZenMaruGothic-Medium.ttf");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansCJKjp-Regular";
  src: url("../fonts/NotoSansCJKjp-Regular.otf");
  font-display: swap;
}
@font-face {
  font-family: "NotoSansCJKjp-Medium";
  src: url("../fonts/NotoSansCJKjp-Medium.otf");
  font-display: swap;
}
/*	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;
}

.nowrap {
  white-space: nowrap;
}

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

.com-txt-box p:nth-of-type(n+2) {
  margin: 35px 0 0;
}
.com-txt .ac {
  font-family: "ZenKakuGothicNew-Bold", sans-serif;
  font-size: 1.8rem;
  letter-spacing: 0.03em;
  color: #30913a;
}
@media screen and (max-width: 768px) {
  .com-txt .ac {
    font-size: 1.5rem;
  }
}

.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: 110px 0 140px;
  }
}

/*  共通パーツ
------------------------------------ */
.com-box01 {
  background: #fff;
  border-radius: 20px;
  box-shadow: 8px 8px #e5e0cf;
  border: 1px dotted #e5e0cf;
}

.com-bg01 {
  background: url(../img/top/about-bottom.png) no-repeat center bottom/100%, url(../img/top/500×400px_2.jpg);
}
.com-bg02 {
  background: url(../img/top/service-bg.png) no-repeat center -50px, url(../img/top/works-top.png) no-repeat bottom, url(../img/ptn/ptn01.jpg);
}
@media screen and (min-width: 1921px) {
  .com-bg02 {
    background-size: 100%, 100%, auto;
  }
}
.com-bg03 {
  background: url(../img/ptn/ptn03.jpg);
}

.com-tel {
  padding-left: 40px;
  background: url(../img/top/info-tel.png) no-repeat left center;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 3.5rem;
  letter-spacing: 0.08em;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .com-tel {
    font-size: 1.75rem;
  }
}

.news-post {
  width: 100%;
}
.news-post-item {
  width: 100%;
  max-width: 820px;
}
@media screen and (min-width: 768px) {
  .news-post-item:nth-of-type(n+2) {
    margin-top: 11px;
  }
}
.news-post-link {
  display: block;
  padding: 26px;
  background: #fff;
  border-radius: 20px;
}
.news-post-flx {
  display: flex;
}
.news-post-time {
  margin-top: 2px;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 1.8rem;
  letter-spacing: 0.12em;
  line-height: 1;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .news-post-time {
    font-size: 1.5rem;
  }
}
.news-post-tag {
  display: flex;
  margin-left: 20px;
  flex-wrap: wrap;
  line-height: 1;
}
.news-post-tag-txt {
  margin: 0 8px 8px 0;
  padding: 3px 12px;
  background: #30913a;
  border-radius: 999px;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  color: #fff;
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  line-height: 1.2;
}
@media screen and (max-width: 768px) {
  .news-post-tag-txt {
    font-size: 1.5rem;
  }
}
.news-post-ttl {
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
  line-height: 1.3;
}
@media screen and (max-width: 768px) {
  .news-post-ttl {
    font-size: 1.5rem;
  }
}

.com-tag {
  display: flex;
  width: 100%;
  margin: 20px auto 0;
  flex-wrap: wrap;
}
.com-tag-ttl {
  margin: 35px auto 0;
  color: #269806;
  font-family: "ZenKakuGothicNew-Bold", sans-serif;
  font-size: 2rem;
  letter-spacing: 0.06em;
  line-height: 1.2;
}
@media screen and (max-width: 768px) {
  .com-tag-ttl {
    font-size: 1.5rem;
  }
}
.com-tag-item {
  width: 100%;
  max-width: 260px;
}
@media screen and (min-width: 768px) {
  .com-tag-item:not(:nth-of-type(4n-3)) {
    margin-left: 12px;
  }
  .com-tag-item:nth-of-type(n+5) {
    margin-top: 20px;
  }
}
.com-tag-link {
  padding: 17px 27px;
}
.com-tag-link-current {
  background-color: #333333;
}

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

  main layout  all

========================================= */
/* top-about  PC
------------------------------------ */
#top-about .about-inner {
  position: relative;
}
@media screen and (min-width: 768px) {
  #top-about .about-con {
    max-width: 535px;
  }
}
#top-about .about-ttl {
  display: inline-block;
  margin-top: 47px;
  padding: 10px 25px;
  background: #30913a;
  border-radius: 999px;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 2rem;
  letter-spacing: 0.03em;
  line-height: 1.5;
  color: #fff;
}
@media screen and (max-width: 768px) {
  #top-about .about-ttl {
    font-size: 1.5rem;
  }
}
#top-about .about-ttl:nth-of-type(n+2) {
  margin-top: 16px;
}
#top-about .about-txt {
  margin-top: 22px;
}
#top-about .about-map {
  position: absolute;
  right: -23px;
  top: 110px;
}

/* top-service  PC
------------------------------------ */
#top-service .service-txt {
  margin: 25px auto 0;
}
@media screen and (min-width: 768px) {
  #top-service .service-txt {
    text-align: center;
  }
}
#top-service .service-list {
  margin: 40px auto 0;
}
@media screen and (min-width: 768px) {
  #top-service .service-list {
    max-width: 1230px;
  }
}
#top-service .service-list-item {
  display: flex;
  padding: 85px 0;
  justify-content: center;
  align-items: flex-start;
}
#top-service .service-list-item:nth-of-type(n+2) {
  margin: 85px auto 0;
}
#top-service .service-list-left {
  width: 100%;
}
@media screen and (min-width: 768px) {
  #top-service .service-list-left {
    max-width: 530px;
  }
}
#top-service .service-list-ttl {
  padding-left: 90px;
  background: url(../img/top/service-ttl-ico01.png) no-repeat left center;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 4.5rem;
  letter-spacing: 0.12em;
  line-height: 1.1;
}
@media screen and (max-width: 768px) {
  #top-service .service-list-ttl {
    font-size: 2.25rem;
  }
}
#top-service .service-list-post {
  margin-top: 33px;
}
#top-service .service-list-post li {
  width: 100%;
}
#top-service .service-list-post li:nth-of-type(n+2) {
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  #top-service .service-list-post-item01 {
    max-width: 250px;
  }
  #top-service .service-list-post-item01:nth-of-type(2) {
    margin-top: 0 !important;
  }
  #top-service .service-list-post-item01:nth-of-type(n+3) {
    margin-top: 27px;
  }
}
#top-service .service-list-post-item02 a {
  padding: 36px 0 36px 135px;
  text-align: left;
}
#top-service .service-list-post-link {
  display: block;
  padding: 104px 0 40px;
  border: 1px solid #30913a;
  border-radius: 20px;
  text-align: center;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 2.6rem;
  letter-spacing: 0.1em;
  color: #30913a;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  #top-service .service-list-post-link {
    font-size: 1.5rem;
  }
}
#top-service .service-list-post-link01 {
  background: url(../img/top/service01-01.png) no-repeat center 42px, url(../img/top/service-btn.png) no-repeat calc(100% + 1px) calc(100% + 1px) #fff;
}
#top-service .service-list-post-link02 {
  background: url(../img/top/service01-02.png) no-repeat center 38px, url(../img/top/service-btn.png) no-repeat calc(100% + 1px) calc(100% + 1px) #fff;
}
#top-service .service-list-post-link03 {
  background: url(../img/top/service01-03.png) no-repeat center 40px, url(../img/top/service-btn.png) no-repeat calc(100% + 1px) calc(100% + 1px) #fff;
}
#top-service .service-list-post-link04 {
  background: url(../img/top/service01-04.png) no-repeat center 40px, url(../img/top/service-btn.png) no-repeat calc(100% + 1px) calc(100% + 1px) #fff;
}
#top-service .service-list-post-link05 {
  background: url(../img/top/service02-01.png) no-repeat 47px center, url(../img/top/service-btn.png) no-repeat calc(100% + 1px) calc(100% + 1px) #fff;
}
#top-service .service-list-post-link06 {
  background: url(../img/top/service02-02.png) no-repeat 40px center, url(../img/top/service-btn.png) no-repeat calc(100% + 1px) calc(100% + 1px) #fff;
}
#top-service .service-list-post-link07 {
  background: url(../img/top/service02-03.png) no-repeat 36px center, url(../img/top/service-btn.png) no-repeat calc(100% + 1px) calc(100% + 1px) #fff;
}
#top-service .service-list-post-link08 {
  background: url(../img/top/service03-01.png) no-repeat 34px center, url(../img/top/service-btn.png) no-repeat calc(100% + 1px) calc(100% + 1px) #fff;
}
#top-service .service-list-post-link09 {
  background: url(../img/top/service03-02.png) no-repeat 34px center, url(../img/top/service-btn.png) no-repeat calc(100% + 1px) calc(100% + 1px) #fff;
}
#top-service .service-list-post-link10 {
  background: url(../img/top/service03-03.png) no-repeat 34px center, url(../img/top/service-btn.png) no-repeat calc(100% + 1px) calc(100% + 1px) #fff;
}
#top-service .service-list-right {
  margin-left: 77px;
  position: relative;
}
#top-service .service-list-ico {
  position: absolute;
}
#top-service .service-list-ico01 {
  right: -40px;
  bottom: -32px;
}
#top-service .service-list-ico02 {
  right: -42px;
  bottom: -32px;
}
#top-service .service-list-ico03 {
  right: -41px;
  bottom: -35px;
}

/* top-works  PC
------------------------------------ */
.com-works {
  display: flex;
  margin: 39px auto 0;
  flex-wrap: wrap;
}
.com-works-item {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .com-works-item {
    max-width: 320px;
  }
  .com-works-item:not(:nth-of-type(3n-2)) {
    margin-left: 60px;
  }
  .com-works-item:nth-of-type(n+4) {
    margin-top: 54px;
  }
}
.com-works-link {
  display: block;
  padding: 25px;
  transform: translateY(0);
}
@media screen and (min-width: 768px) {
  .com-works-link:hover {
    transform: translateY(-5px);
  }
}
.com-works-img {
  width: 100%;
  height: 0;
  padding-top: 100%;
  border-radius: 20px;
  overflow: hidden;
  position: relative;
}
.com-works-tag {
  display: flex;
  margin: 14px auto 0;
  flex-wrap: wrap;
}
.com-works-tag-txt {
  margin: 0 7px 7px 0;
  padding: 2px 12px;
  background: #30913a;
  border-radius: 999px;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  color: #fff;
  line-height: 1.3;
}
.com-works-ttl {
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 2rem;
  letter-spacing: 0.12em;
  line-height: 1.2;
}
@media screen and (max-width: 768px) {
  .com-works-ttl {
    font-size: 1.5rem;
  }
}

#top-works .works-btn {
  margin: 52px auto 0;
}

/* com-price  PC
------------------------------------ */
.com-price {
  background: url(../img/ptn/ptn01.jpg);
}
.com-price .tab_wrp {
  margin: 25px auto 0;
}
@media screen and (min-width: 768px) {
  .com-price .tab_wrp li {
    cursor: pointer;
    transition: all 0.3s ease;
  }
  .com-price .tab_wrp li:hover {
    opacity: 0.7;
  }
  .com-price .tab_wrp li:not(:nth-of-type(4n-3)) {
    margin-left: 13px;
  }
  .com-price .tab_wrp li:nth-of-type(n+5) {
    margin-top: 14px;
  }
}
.com-price .tab_txt {
  margin: 38px auto 0;
}
.com-price .tab_list {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
}
.com-price .tab_ttl {
  padding: 10px 30px;
  background-color: #269806;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 2.8rem;
  letter-spacing: 0.15em;
  color: #fff;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .com-price .tab_ttl {
    font-size: 1.5rem;
  }
}
.com-price .tab_con {
  padding: 3px 25px;
}
.com-price .tab_table {
  width: 100%;
}
.com-price .tab_table tr:nth-of-type(n+2) {
  border-top: 1px dashed #30913a;
}
.com-price .tab_table th, .com-price .tab_table td {
  padding: 9px 0;
}
.com-price .tab_table th {
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .com-price .tab_table th {
    font-size: 1.5rem;
  }
}
.com-price .tab_table td {
  font-family: "NotoSansCJKjp-Regular", sans-serif;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  text-align: right;
}
@media screen and (max-width: 768px) {
  .com-price .tab_table td {
    font-size: 1.5rem;
  }
}

/* com-contact  PC
------------------------------------ */
.com-contact {
  background: url(../img/top/contact-wave-top.png) no-repeat center top, url(../img/top/contact-wave-bottom.png) no-repeat center bottom, url(../img/top/contact-bg.png) no-repeat center/cover;
}
@media screen and (min-width: 1921px) {
  .com-contact {
    background-size: 100%, 100%, cover;
  }
}
.com-contact .ja {
  color: #269806;
  margin-top: 23px;
}
.com-contact .contact-box {
  padding: 88px 100px 89px;
  background-image: url(../img/top/contact-illu.png);
  background-repeat: no-repeat;
  background-position: calc(50% + 285px) bottom;
  background-color: #fffcf1;
}
.com-contact .contact-tel {
  margin-top: 45px;
  padding-left: 56px;
  background-image: url(../img/top/contact-tel.png);
  font-size: 4.5rem;
  font-family: "NotoSansCJKjp-Medium", sans-serif;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .com-contact .contact-tel {
    font-size: 2.25rem;
  }
}
.com-contact .contact-btn {
  display: flex;
  width: 100%;
  max-width: 380px;
  height: 75px;
  margin-top: 23px;
  background-color: #269806;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  font-family: "ZenKakuGothicNew-Bold", sans-serif;
  font-size: 2.4rem;
  letter-spacing: 0.05em;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .com-contact .contact-btn {
    font-size: 1.5rem;
  }
}
.com-contact .contact-btn::before {
  content: "";
  width: 27px;
  height: 20px;
  margin-right: 12px;
  background: url(../img/top/contact-mail.png) no-repeat center/contain;
}

/* top-information  PC
------------------------------------ */
#top-information {
  background: url(../img/top/500×400px_3.jpg);
}
#top-information .information-flx {
  margin: 43px auto 0;
}
#top-information .information-table {
  width: 100%;
}
#top-information .information-table-wrap {
  width: 100%;
  max-width: 540px;
  border-radius: 20px;
  overflow: hidden;
  background: #fff;
}
#top-information .ggmap {
  border-radius: 20px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  #top-information .ggmap {
    max-width: 500px;
  }
}

/* top-news  PC
------------------------------------ */
#top-news {
  background: url(../img/ptn/ptn01.jpg);
}
#top-news .ja {
  margin-top: 20px;
  font-size: 4rem;
}
@media screen and (max-width: 768px) {
  #top-news .ja {
    font-size: 2rem;
  }
}
#top-news .news-post {
  max-width: 820px;
}
#top-news .news-btn {
  margin-top: 170px;
}

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

  sub layout  all

========================================= */
/* com-troubles  PC
------------------------------------ */
.com-troubles .troubles-box {
  width: 100%;
  max-width: 880px;
  padding: 50px 60px 60px;
  margin: 40px auto 0;
}
.com-troubles .troubles-list li {
  padding-left: 40px;
  padding-bottom: 12px;
  border-bottom: 1px dashed #269806;
  background: url(../img/toilet/check.png) no-repeat left 15px;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 2.8rem;
  letter-spacing: 0.1em;
  line-height: 1.7;
}
@media screen and (max-width: 768px) {
  .com-troubles .troubles-list li {
    font-size: 1.5rem;
  }
}
.com-troubles .troubles-list li:nth-of-type(n+2) {
  margin-top: 14px;
}
.com-troubles .troubles-flx {
  margin: 36px auto 0;
}
.com-troubles .troubles-flx-ttl {
  text-align: center;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 3.6rem;
  letter-spacing: 0.12em;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .com-troubles .troubles-flx-ttl {
    font-size: 1.8rem;
  }
}
.com-troubles .troubles-flx-harf {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .com-troubles .troubles-flx-harf {
    max-width: 500px;
  }
}
@media screen and (min-width: 768px) {
  .com-troubles .troubles-flx .troubles-box {
    padding: 30px 37px;
    height: 328px;
  }
}
.com-troubles .troubles-flx .troubles-list li {
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .com-troubles .troubles-flx .troubles-list li {
    font-size: 1.5rem;
  }
}
@media screen and (min-width: 768px) {
  .com-troubles .troubles-flx .troubles-list li {
    white-space: nowrap;
  }
}

@media screen and (min-width: 768px) {
  .com-merits {
    background: url(../img/toilet/com-bg02.jpg) no-repeat center bottom/cover;
  }
}
.com-merits .merits-list {
  margin: 90px auto 0;
}
.com-merits .merits-list-item {
  display: flex;
  width: 100%;
  height: 232px;
  justify-content: center;
  align-items: center;
  position: relative;
}
@media screen and (min-width: 768px) {
  .com-merits .merits-list-item {
    max-width: 510px;
  }
  .com-merits .merits-list-item:nth-of-type(2n) {
    margin-left: 60px;
  }
  .com-merits .merits-list-item:nth-of-type(n+3) {
    margin-top: 106px;
  }
}
.com-merits .merits-list-fuki {
  width: 128px;
  height: 95px;
  padding-top: 20px;
  text-align: center;
  background: url(../img/toilet/merit-fuki.png) no-repeat left top/contain;
  font-family: "ZenMaruGothic-Medium", sans-serif;
  font-size: 2.2rem;
  letter-spacing: 0.12em;
  color: #fff;
  line-height: 1.18;
  position: absolute;
  top: -56px;
  left: 0;
}
@media screen and (max-width: 768px) {
  .com-merits .merits-list-fuki {
    font-size: 1.5rem;
  }
}
.com-merits .merits-list-ttl {
  text-align: center;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 2.8rem;
  letter-spacing: 0.03em;
  line-height: 1.57;
}
@media screen and (max-width: 768px) {
  .com-merits .merits-list-ttl {
    font-size: 1.5rem;
  }
}
.com-merits .merits-list-ttl .ac {
  font-family: "ZenKakuGothicNew-Bold", sans-serif;
  font-size: 3.2rem;
  letter-spacing: 0.03em;
  color: #269806;
}
@media screen and (max-width: 768px) {
  .com-merits .merits-list-ttl .ac {
    font-size: 1.6rem;
  }
}
.com-merits .merits-contents {
  margin: 40px auto 0;
}
.com-merits .merits-contents:nth-of-type(n+2) {
  margin-top: 100px;
}

.com-service .service-list {
  margin: 50px auto 0;
  flex-wrap: wrap;
}
.com-service .service-list-item {
  width: 100%;
  max-width: 320px;
  padding: 27px 25px 31px;
  background: url(../img/sub/service-bg.jpg);
  border-radius: 20px;
}
@media screen and (min-width: 768px) {
  .com-service .service-list-item:not(:nth-of-type(3n-2)) {
    margin-left: 60px;
  }
  .com-service .service-list-item:nth-of-type(n+4) {
    margin-top: 58px;
  }
}
.com-service .service-list-ttl {
  display: flex;
  text-align: center;
  font-family: "ZenKakuGothicNew-Bold", sans-serif;
  font-size: 3rem;
  letter-spacing: 0.08em;
  color: #269806;
  line-height: 1.16;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .com-service .service-list-ttl {
    height: 69.59px;
  }
}
@media screen and (max-width: 768px) {
  .com-service .service-list-ttl {
    font-size: 1.5rem;
  }
}
.com-service .service-list-ttl.sm {
  display: block;
}
.com-service .service-list-ttl.sm span {
  display: block;
  font-family: "ZenKakuGothicNew-Bold", sans-serif;
  font-size: 2.3rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .com-service .service-list-ttl.sm span {
    font-size: 1.5rem;
  }
}
.com-service .service-list-txt {
  margin: 12px auto 0;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 1.7rem;
  letter-spacing: 0.03em;
  line-height: 1.47;
}
@media screen and (max-width: 768px) {
  .com-service .service-list-txt {
    font-size: 1.5rem;
  }
}
.com-service .service-list-note {
  max-width: 320px;
  margin: 10px 0 0 auto;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 1.5rem;
  letter-spacing: 0;
  line-height: 1.2;
}
@media screen and (max-width: 768px) {
  .com-service .service-list-note {
    font-size: 1.5rem;
  }
}
.com-service .service-image {
  display: flex;
  justify-content: center;
}
.com-service .service-image li {
  width: 50%;
  height: 400px;
  position: relative;
}
.com-service .service-contents {
  margin: 48px auto 0;
}
.com-service .service-contents:nth-of-type(n+2) {
  margin-top: 100px;
}

.com-case {
  background: url(../img/ptn/ptn01.jpg);
}
.com-case .case-box {
  padding: 74px 0;
  background: url(../img/toilet/case-img.jpg) no-repeat center/cover;
  text-align: center;
}
.com-case .case-fuki {
  display: inline-block;
  width: 351px;
  height: 84px;
  padding-top: 20px;
  background: url(../img/toilet/case-fuki.png) no-repeat center top/contain;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 3rem;
  letter-spacing: 0.12em;
  line-height: 1;
  color: #fff;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .com-case .case-fuki {
    font-size: 1.5rem;
  }
}
.com-case .case-link {
  display: flex;
  width: 100%;
  max-width: 544px;
  margin: -17px auto 0;
  padding: 17px 0;
  background: #fff;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 5rem;
  letter-spacing: 0.12em;
  color: #30913a;
  justify-content: center;
  align-items: center;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .com-case .case-link {
    font-size: 2.5rem;
  }
}
.com-case .case-link::after {
  content: "";
  width: 42px;
  height: 42px;
  margin-left: 18px;
  background: url(../img/toilet/case-arw.png) no-repeat center/contain;
}

/* carport  PC
------------------------------------ */
@media screen and (min-width: 768px) {
  #carport .com-bg02 {
    background: url(../img/top/service-bg.png) no-repeat center -50px, url(../img/top/works-top.png) no-repeat bottom, url(../img/ptn/ptn01.jpg);
  }
}
@media screen and (min-width: 768px) and (min-width: 1921px) {
  #carport .com-bg02 {
    background-size: 100%, 100%, auto;
  }
}

/* works  PC
------------------------------------ */
#works .com-works {
  margin: 56PX auto 0;
}
#works .works-thumb {
  width: 100%;
  max-width: 600px;
  margin: auto;
  text-align: center;
}
#works .works-thumb img {
  border-radius: 20px;
}
#works .works-ttl {
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 2.4rem;
  letter-spacing: 0.12em;
  line-height: 1.7;
}
@media screen and (max-width: 768px) {
  #works .works-ttl {
    font-size: 1.5rem;
  }
}
#works .works-con {
  margin: 15px auto 0;
  padding-top: 30px;
  border-top: 1px solid #269806;
}
#works .works-tag {
  margin: 50px auto 0;
}
#works .works-tag li {
  padding: 3px 17px;
  border-radius: 10px;
  background-color: #269806;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  #works .works-tag li {
    font-size: 1.5rem;
  }
}
#works .works-price {
  display: flex;
  align-items: center;
}
#works .works-price dt, #works .works-price dd {
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 2.4rem;
  letter-spacing: 0.05em;
  color: #269806;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  #works .works-price dt, #works .works-price dd {
    font-size: 1.5rem;
  }
}
#works .works-txt {
  margin: 20px auto 0;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
  line-height: 1.75;
  white-space: pre-line;
}
@media screen and (max-width: 768px) {
  #works .works-txt {
    font-size: 1.5rem;
  }
}
#works .works-image {
  margin: 55px auto 0;
}
#works .works-image li {
  width: 100%;
  text-align: center;
}
@media screen and (min-width: 768px) {
  #works .works-image li {
    max-width: 500px;
  }
  #works .works-image li:nth-of-type(n+3) {
    margin-top: 65px;
  }
}
#works .works-image img {
  border-radius: 20px;
}
#works .com-contact {
  background: url(../img/top/contact-wave-bottom.png) no-repeat center bottom, url(../img/top/contact-bg.png) no-repeat center/cover;
}
@media screen and (min-width: 1921px) {
  #works .com-contact {
    background-size: 100%, cover;
  }
}

/* contact  PC
------------------------------------ */
#contact .contact-list {
  margin: 35px auto 0;
}
#contact .contact-list-item:nth-of-type(n+2) {
  margin: 100px auto 0;
}
#contact .contact-list-ttl {
  height: 70px;
  text-align: center;
  font-family: "ZenKakuGothicNew-Bold", sans-serif;
  font-size: 3rem;
  letter-spacing: 0.08em;
  line-height: 1;
  color: #fff;
  border-radius: 999px;
  background: #30913a;
  line-height: 70px;
  position: relative;
}
@media screen and (max-width: 768px) {
  #contact .contact-list-ttl {
    font-size: 1.5rem;
  }
}
#contact .contact-list-ttl::before {
  content: "";
  width: 0;
  height: 0;
  margin: auto;
  border-style: solid;
  border-right: 15px solid transparent;
  border-left: 15px solid transparent;
  border-top: 12px solid #30913a;
  border-bottom: 0;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -12px;
}
#contact .contact-list-ttl02 {
  background-color: #126031;
}
#contact .contact-list-ttl02::before {
  border-top: 12px solid #126031;
}
#contact .contact-list-txt {
  margin: 42px auto 0;
  text-align: center;
  line-height: 1.77;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  font-size: 1.8rem;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 768px) {
  #contact .contact-list-txt {
    font-size: 1.5rem;
  }
}
#contact .contact-list-tel {
  padding-left: 56px;
  background-image: url(../img/contact/tel.png);
  font-family: "NotoSansCJKjp-Medium", sans-serif;
  font-size: 4.5rem;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  #contact .contact-list-tel {
    font-size: 2.25rem;
  }
}
#contact .contact-list-tel-wrap {
  margin: 33px auto 0;
}

/* news  PC
------------------------------------ */
#news .com-news {
  margin: 75px auto 0;
}
#news .com-news-item:nth-of-type(n+2) {
  margin-top: 89px;
}
#news .com-news-link {
  padding: 0;
  justify-content: space-between;
}
#news .com-news-ttl {
  font-family: "ZenKakuGothicNew-Bold", sans-serif;
  font-size: 2.8rem;
  letter-spacing: 0.06em;
  line-height: 2;
  color: #269806;
}
@media screen and (max-width: 768px) {
  #news .com-news-ttl {
    font-size: 1.5rem;
  }
}
#news .com-news-txt {
  line-height: 1.75;
}
#news .com-news-img {
  border-radius: 15px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  #news .com-news-img {
    width: 390px;
    height: 0;
    padding-top: 260px;
  }
}
#news .com-news-con {
  max-width: 640px;
}
#news .com-news-con-none {
  max-width: none;
}
#news .news-post-tag {
  margin-top: 19px;
  margin-left: 0;
}
#news .detail-box {
  padding: 30px;
}
#news .detail .news-post-flx {
  display: block;
}
#news .detail .news-post-tag-txt::before {
  content: none !important;
}

/* site  PC
------------------------------------ */
#site .dropdown-menu {
  padding-bottom: 0;
}
#site .dropdown-menu::before {
  content: none;
}
#site .dropdown-menu__list {
  margin-top: 11px;
  padding-left: 33px;
  padding-bottom: 30px;
  line-height: 1;
}
#site .dropdown-menu__list li:nth-of-type(n+2) {
  margin-top: 20px;
}
#site .dropdown-menu__link {
  padding-left: 17px;
  font-family: "ZenKakuGothicNew-Medium", sans-serif;
  color: #333333;
  letter-spacing: 0.08em;
  position: relative;
}
#site .dropdown-menu__link::before {
  content: "";
  width: 6px;
  height: 6px;
  margin: auto;
  border-top: 1px solid #333333;
  border-right: 1px solid #333333;
  position: absolute;
  left: 0;
  top: 50%;
  transform: rotate(45deg) translateY(-50%);
}
#site .dropdown-menu__link.current {
  opacity: 0.5;
}/*# sourceMappingURL=all.css.map */