@charset "UTF-8";

.category-list {
  display: flex;
  flex-direction: column;
  gap: 6px;

  @media screen and (max-width: 768px) {
    flex-direction: row;
    flex-wrap: wrap;
  }
}

.archive-news__inner.inner,
.archive-cases__inner.inner {
  @media screen and (max-width: 768px) {
    max-width: 540px;
  }
}

.archive-cases__flex {
  padding-top: 60px;
  display: flex;
  flex-wrap: wrap;
}

.archive-cases__flex.archive-cases__flex--individual,
.archive-news .archive-cases__flex {
  display: grid;
  grid-template-columns: max(18.75rem, 220px) 1fr;
  gap: 50px;

  @media screen and (max-width: 768px) {
    grid-template-columns: 1fr;
  }
}

.archive-cases__flex-side {
  width: 100%;
  max-width: 300px;

  @media screen and (max-width: 768px) {
    max-width: none;
  }
}
.archive-cases__flex-side__sticky {
  position: sticky;
  top: 100px;
}
.archive-cases__flex-side__ttl {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
  margin-bottom: 20px;
}
/* .archive-cases__flex-side ul li {
  margin-bottom: 6px;
}
.archive-cases__flex-side ul li:last-child {
  margin-bottom: 0;
} */
.archive-cases__flex-side ul li a {
  display: inline-block;
  padding: 6px 15px 4px;
  line-height: 1.6;
  font-size: 12px;
  font-weight: 500;
  border-radius: 60px;
  border: 1px solid #222;
  color: #222;
  background-color: #fff;
  box-shadow: 6px 6px 6px rgb(0 0 0 / 0.1);
  transition: 0.2s;
}
.archive-cases__flex-side ul li a.current {
  background-color: #222;
  color: #fff;
  pointer-events: none;
}
@media screen and (min-width: 992px) {
  .archive-cases__flex-side ul li a:hover {
    background-color: #222;
    color: #fff;
  }
}
.archive-cases__flex-main {
  width: 100%;
  /* max-width: calc(100% - 300px); */
  /* padding-left: 50px; */
}
.archive-cases__flex-main__content {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 50px 10px;
}
.archive-cases__flex-main.grid-4 {
  max-width: 100%;
  padding-left: 0;
}
.archive-cases__flex-main.grid-4 .archive-cases__flex-main__content {
  grid-template-columns: repeat(4, 1fr);
}
.cases-card__thumb-inner {
  padding-top: 133%;
  position: relative;
  overflow: hidden;
}
.cases-card__thumb-inner img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.5s;
}
.cases-card a {
  display: block;
  color: #222;
  padding-bottom: 10px;
}
@media screen and (min-width: 992px) {
  .cases-card a:hover .cases-card__thumb-inner img {
    transform: scale(1.1);
  }
}
.cases-card__name {
  margin: 10px 0;
  letter-spacing: 0.1em;
  line-height: 1.6;
}
.cases-card__cat {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 5px;
}
.cases-card__cat span {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.1em;
  padding: 10px 15px 8px;
  border-radius: 60px;
  border: 1px solid #222;
  box-shadow: 6px 6px 6px rgb(0 0 0 / 0.1);
}
.cases-card__thumb {
  position: relative;
}
.cases-card__thumb .btn__icon-02 {
  position: absolute;
  z-index: 1;
  top: 25px;
  right: 10px;
}

/* CASES SINGLE */
.cases-client__flex {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  align-items: flex-start;
  justify-content: flex-start;
}
.fv-lower-04__img::before {
  content: attr(data-text) !important;
}
.single-cases__intro-text-wrapper p {
  font-size: max(0.875rem, 12px);
  font-family: 'Noto Sans JP', '游ゴシック', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', Verdana, 'メイリオ', Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-weight: 400;
  color: #222222;
  line-height: 2;
  letter-spacing: 0.2em;
}
.single-cases__intro-text-wrapper p:nth-child(n + 2) {
  margin-top: 1.75rem;
}
.fv-lower-03.fv-lower-03-cases {
  height: max(46.8vw, 18.75rem);
}

.fv-lower-03-cases__slider-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -2;
}

.fv-lower-03-cases__slider {
  height: 100%;
}

.fv-lower-03-cases__slider-item {
  width: 83.3vw;
}

.fv-lower-03-cases__slider .slick-list,
.fv-lower-03-cases__slider .slick-track {
  height: 100%;
}

.fv-lower-03-cases__slider-item img {
  height: 100%;
  object-fit: cover;
}

.fv-lower-03.fv-lower-03-cases::before {
  content: attr(data-text) !important;
}

/* NEWS ARCHIVE */
.archive-cases__flex-main__cat {
  font-size: 22px;
  letter-spacing: 0.1em;
  font-weight: 500;
  margin-bottom: 60px;
}

/* ページネーション */
.wp-pagenavi {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-top: 80px;
  gap: 6px;
}
.wp-pagenavi a,
.wp-pagenavi span {
  margin: 0;
  border: 1px solid transparent !important;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  font-weight: 500;
  color: #0a0905;
  background-color: #fff;
  transition: all 0.3s;
}
.wp-pagenavi a.current,
.wp-pagenavi span.current {
  pointer-events: none;
  background-color: #efefef;
  font-weight: normal;
}
.wp-pagenavi a.current,
.wp-pagenavi a:hover,
.wp-pagenavi span.current,
.wp-pagenavi span:hover {
  background-color: #efefef !important;
}
.wp-pagenavi a.previouspostslink,
.wp-pagenavi a.nextpostslink {
  background-color: #fff;
}
.wp-pagenavi a.previouspostslink {
  margin-right: 14px;
}
.wp-pagenavi a.nextpostslink {
  margin-left: 14px;
}
/* .wp-pagenavi a.previouspostslink::before,
.wp-pagenavi a.nextpostslink::before{
    content: "";
    width: 13px;
    height: 14px;
    display: block;
    background: url(../images/common/arrow.svg) no-repeat center center / contain;
}
.wp-pagenavi a.previouspostslink::before{
    transform: scaleX(-1);
} */

/* RESPONSIV */
@media screen and (max-width: 768px) {
  .form__item:nth-child(n + 2) {
    margin-top: 30px;
  }
  .wp-pagenavi a,
  .wp-pagenavi span {
    width: 36px;
    height: 36px;
    font-size: 14px;
  }
  .news-singlg-sec__header {
    margin-bottom: 30px;
  }
}

/* NEWS */
.news-singlg-sec__header .news-singlg-sec__header-title {
  margin-top: 25px;
}
.news-singlg-sec__header .news-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 30px;
  margin-bottom: 10px;
}

.news-singlg-sec__header-title {
  font-size: 24px;
  font-weight: bold;
  line-height: 1.6;
}

.news-singlg-sec__header {
  padding-bottom: 10px;
  margin-bottom: 40px;
  border-bottom: 2px solid #73a7b4;
}

.news-singlg-sec__content {
  line-height: 1.8;
}

.news-singlg-sec__content figure {
  margin-top: 1.25rem;
}

@media screen and (max-width: 768px) {
  .news-singlg-sec__content figure {
    margin-top: 2.5rem;
  }
}

.news-singlg-sec__content figure img {
  aspect-ratio: 16/9;
  border-radius: 0.375rem;
  object-fit: cover;
  border: 1px solid #000000;
}

.news-singlg-sec__content p {
  margin-top: 1.25rem;
  font-size: 0.875rem;
  font-weight: 400;
  color: #000000;
  line-height: 1.8;
}

@media screen and (max-width: 768px) {
  .news-singlg-sec__content p {
    font-size: 0.9375rem;
  }
}

.news-singlg-sec__content a {
  overflow-wrap: break-word;
}

.news-singlg-sec__content h2 {
  position: relative;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.6;
  color: #ffffff;
  margin-top: 3.125rem;
  padding: 0.4375rem 0.625rem;
  background-color: #73a7b4;
}

@media screen and (max-width: 768px) {
  .news-singlg-sec__content h2 {
    font-size: 1.125rem;
    padding: 0.3rem 0.7rem;
  }
}

.news-singlg-sec__content h3 {
  position: relative;
  font-size: 1.25rem;
  font-weight: 700;
  color: #000000;
  line-height: 1.6;
  margin-top: 3.125rem;
  padding: 0.4375rem 0.625rem 0.4375rem 1.25rem;
  background-color: rgba(10, 67, 84, 0.15);
}

@media screen and (max-width: 768px) {
  .news-singlg-sec__content h3 {
    font-size: max(0.9375rem, 12px);
    margin-top: 2.5rem;
    padding: 0.2rem 0.6rem 0.2rem 1rem;
  }
}

.news-singlg-sec__content h3::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 0.25rem;
  background-color: #73a7b4;
}

.news-singlg-sec__content h4 {
  font-size: 1.125rem;
  font-weight: 700;
  color: #000000;
  background-color: rgba(10, 67, 84, 0.1);
  line-height: 1.3;
  margin-top: 2.5rem;
  padding: 0.3125rem 0.625rem;
}

@media screen and (max-width: 768px) {
  .news-singlg-sec__content h4 {
    font-size: max(0.875rem, 12px);
    margin-top: 1.875rem;
    padding: 0.4rem 0.6rem 0.4rem;
  }
}

.news-singlg-sec__content ul {
  margin-top: 1.25rem;
}

.news-singlg-sec__content li {
  position: relative;
  font-size: 0.9375rem;
  color: #000000;
  line-height: 1.8;
  padding-left: 1em;
  margin-top: 0.5rem;
}

.news-singlg-sec__content li:first-child {
  margin-top: 0;
}
.archive-news.lower-main,
.single-news.lower-main {
  margin-top: 2rem;
}
.archive-news.lower-main .archive-cases__flex,
.single-news.lower-main .archive-cases__flex {
  padding: 0;
}

/* FAQ */
.fv-lower-02-faq::before {
  content: 'Here to Help';
}
.faq-sec__cont {
  padding-top: 200px;
}
.faq-sec__cont__ttl {
  font-size: 28px;
  letter-spacing: 0.2em;
  margin-bottom: 40px;
  font-weight: 500;
}
.faq-sec__cont-box::before,
.faq-sec__cont-box::after {
  content: '';
  position: absolute;
  left: 0;
  width: 20px;
  background-color: #222;
  z-index: 1;
  height: 1px;
}
.faq-sec__cont-box::before {
  top: -1px;
}
.faq-sec__cont-box::after {
  bottom: -1px;
  display: none;
}
.faq-sec__cont-box {
  cursor: pointer;
  padding: 30px 20px;
  padding: 1.875rem 1.25rem;
  border-top: 1px solid #b5b5b5;
  position: relative;

  @media screen and (max-width: 768px) {
    padding: 1.875rem 0 1.875rem 0.625rem;
  }
}
.faq-sec__cont-box:last-child {
  border-bottom: 1px solid #b5b5b5;
}
.faq-sec__cont-box:last-child::after {
  display: block;
}
.faq-sec__cont-box__ttl {
  font-size: 18px;
  letter-spacing: 0.1em;
  font-weight: normal;
  padding-left: 50px;
  position: relative;

  @media screen and (max-width: 768px) {
    padding-left: 1.875rem;
    padding-right: 2.1875rem;
  }
}
.faq-sec__cont-box__ttl::before {
  content: 'Q.';
  position: absolute;
  top: -3px;
  left: 0;
  font-weight: 500;
  font-size: 20px;
  letter-spacing: 0.1em;
}
.faq-sec__cont-box__text {
  line-height: 1.6;
  padding: 20px 50px 0;
  font-size: 14px;
  letter-spacing: 0.2em;
  font-weight: normal;

  @media screen and (max-width: 768px) {
    padding: 1.25rem 1.875rem 0;
  }
}
.faq-sec__cont-box__toggle {
  position: absolute;
  top: 24px;
  right: 20px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background-color: #efefef;

  @media screen and (max-width: 768px) {
    top: 1.5rem;
    right: 0;
    width: 1.5625rem;
    height: 1.5625rem;
  }
}
.faq-sec__cont-box__toggle::before,
.faq-sec__cont-box__toggle::after {
  content: '';
  width: 30%;
  height: 2px;
  background-color: #222;
  position: absolute;
  top: 50%;
  left: 50%;
  transition: 0.2s;
}
.faq-sec__cont-box__toggle::before {
  transform: translate(-50%, -50%);
}
.faq-sec__cont-box__toggle::after {
  transform: translate(-50%, -50%) rotate(-90deg);
}
.faq-sec__cont-box.active .faq-sec__cont-box__toggle::after {
  transform: translate(-50%, -50%) rotate(0);
}

@media screen and (max-width: 991px) {
  .archive-cases__flex-main__content,
  .archive-cases__flex-main.grid-4 .archive-cases__flex-main__content {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media screen and (max-width: 375px) {
  .archive-cases__flex-main__content,
  .archive-cases__flex-main.grid-4 .archive-cases__flex-main__content {
    grid-template-columns: repeat(1, 1fr);
  }
}




/* HEADER */

.header__logo-link{
    width:10rem;
}
.header__inner.headerChange .header__logo-link{
    width:8rem;
}
@media only screen and (min-width:768px){
    .header__logo-link{
        width:15rem;
    }
}

/* FOOTER */

.footer__logo{
    max-width:10rem;
}
@media only screen and (min-width:768px){
    .footer__logo{
        max-width:15rem;
    }
}


/* LOGO SPACE */
.fv-lower-01,
.fv-lower-02,
.fv-lower-03,
.fv-company{
    padding-top:4.5rem;
}
@media only screen and (min-width:768px){
    .fv-lower-01,
    .fv-lower-02,
    .fv-lower-03,
    .fv-company{
        padding-top:8.25rem;
    }
}


/* TOP */
.mv__title-wrapper {
    text-shadow: 1px 1px 3px #5b5b5b;
}

@media only screen and (max-width:480px){
    .mv__title-wrapper{
        top:48%;
    }
}

.swiper-button-prev-top-cases,
.swiper-button-next-top-cases{
  background:transparent !important;
  border: 0 !important;
  outline: 0 !important;
}



/* CORPORATE */
.water__info-item,
.mechanical__info-item{
    letter-spacing:0;
}
@media only screen and (max-width:1880px) and (min-width:769px){
    .lower-main__container{
        display:flex;
        justify-content:space-between
    }
    .lower-main__side{
        width:20rem;
    }
    .lower-main__content{
        width:calc(100% - 24rem);
    }
    .water__wrapper,
    .mechanical__wrapper{
        width:100%;
    }
}

.swiper-button-prev-service-cases,
.swiper-button-next-service-cases{
    background:transparent !important;
    border: 0 !important;
    outline: 0 !important;
}


/* CONTACT */
@media only screen and (max-width:768px){
    .fv-lower-02-contact{
        height:36rem;
    }
}
.contact-mv__banner{
    margin-top: 20px;
    width: 100%;
    margin-left: auto;
}
@media only screen and (min-width:481px){
    .contact-mv__banner{
        margin-top: 30px;
        width:320px;
    }
}
@media only screen and (min-width:768px){
    .contact-mv__banner{
        width:366px;
    }
}
@media only screen and (min-width:992px){
    .contact-mv__banner{
        width:500px;
    }
}


/* ARCHIVE - INFO */
@media only screen and (max-width:768px){
    .archive-news.lower-main .archive-cases__flex,
    .single-news.lower-main .archive-cases__flex,
    .archive-cases__flex.archive-cases__flex--individual,
    .archive-news .archive-cases__flex{
        display:block;
    }
    .archive-cases__flex-side{
        margin-bottom:40px;
    }
    .news__item-img{
        width:100%;
    }

    .news__title-wrapper{
        padding-right:2rem;
    }
    .btn__icon-06.btn__icon-06--news{
        right:0;
    }
}

@media only screen and (max-width:480px){
    .news__item-link{
        padding:20px 0;
    }
}

/**/
@media only screen and (min-width:769px){
    .fv-lower-04{
        margin-top:8.5rem;
    }
}


/* FAQ */
@media only screen and (min-width:769px){
    .faq-sec__cont-box{
        padding-right:64px;
    }
}

@media only screen and (min-width:769px) and (max-width:1025px){
    .faq-sec__cont-box__toggle{
        top:11px;
    }
}

@media only screen and (max-width:768px){
    .faq-sec__cont-box__ttl{
        line-height:1.5;
    }
}

/* SHIMASUI24 */
.lp-fv__contact{
    z-index:9;
}

.lp-fv__breadcrumb{
    padding-top:4.5rem;
}
@media only screen and (min-width:769px){
    .lp-fv__breadcrumb{
        padding-top:8.5rem;
    }
}


/* CONTACT */
.wpcf7-form-control-wrap{
    margin-top:0;
}
.form__privacy-text{
    margin-bottom:1rem;
}
.wpcf7-spinner{
    display: none !important;
}

.btn.btn-contact{
    padding:0 !important;
    max-height:unset;
}
.btn-contact__submit{
    width:100%;
    height:3.6rem;
    text-align: left;
    padding: 0 20px;
    padding-right: 56px;
}

/* NEWS SINGLE */

.news-singlg-sec__content ol{
    list-style:decimal;
}
.news-singlg-sec__content ul{
    list-style:disc;
}
.news-singlg-sec__content>ol{
    margin-top:2rem;
}
.news-singlg-sec__content>ul{
    margin-top:2rem;
}

.news-singlg-sec__content li{
    margin-left:2rem;
    padding-left:0;
}