@charset "UTF-8";
@import url("root.css");
/*-----*ブレイクポイントルール*-----*/
/* スマートフォン：max-width:767px */
/* タブレット：min-width:768px */
/* PC：min-width:1025px */
/***************************************
-------------- NEWS --------------
***************************************/
#blog {
  padding: 25px 0 50px 0;
}
@media (max-width: 767px) {
  #blog {
    padding: 25px 0 50px 0;
  }
}
#blog .bgbox:not(:last-child) {
  margin-bottom: 45px;
}
@media (max-width: 767px) {
  #blog .bgbox:not(:last-child) {
    margin-bottom: 30px;
  }
}
#blog .bgbox .txtbox {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 5px;
  margin-bottom: 15px;
}
#blog .bgbox .txtbox .cattxt {
  font-size: clamp(18px, 2vw, 24px);
  font-weight: bold;
  font-style: italic;
  margin: 0;
}
#blog .bgbox .txtbox .date {
  margin: 0;
  font-size: 14px;
  font-style: italic;
  color: #626262;
}
#blog .bgbox .txtbox.cat01 {
  border-bottom: 2px solid #ef483a;
}
#blog .bgbox .txtbox.cat01 .cattxt {
  color: #ef483a;
}
#blog .bgbox .txtbox.cat02 {
  border-bottom: 2px solid #00408e;
}
#blog .bgbox .txtbox.cat02 .cattxt {
  color: #00408e;
}
#blog .bgbox .txtbox.cat03 {
  border-bottom: 2px solid #744b1c;
}
#blog .bgbox .txtbox.cat03 .cattxt {
  color: #744b1c;
}
#blog .bgbox .txtbox.cat04 {
  border-bottom: 2px solid #1f74bd;
}
#blog .bgbox .txtbox.cat04 .cattxt {
  color: #1f74bd;
}
#blog .bgbox .row .ttl {
  font-weight: bold;
  font-style: italic;
  font-size: clamp(20px, 2.1666666667vw, 26px);
  margin: 0;
  margin-bottom: 5px;
}
#blog .bgbox .row .ttl a {
  color: var(--text-color);
}
#blog .bgbox .row .ttl a:hover {
  color: var(--base-color04);
  text-decoration: underline;
}
#blog .bgbox .row .text a {
  color: var(--text-color);
}
#blog .bgbox .row .text a:hover {
  color: var(--base-color04);
  text-decoration: underline;
}

.detail_img_wrap {
  display: flex;
  gap: max(2vw,2%) min(2vw,2%);
  flex-wrap: wrap;
}

.detail_img_wrap .detail_img_box {
  width: 32%;
}
.detail_img_wrap .detail_img_box img {
  aspect-ratio: 4/3;
  object-fit: cover;
}

/***************施工事例****************/
.case_post-list {
  gap: 48px;
}

.case_post-list .col-4 .imgbox {
  position: relative;
  padding-top: 71.4285714286%;
}

.case_post-list .col-4 .imgbox img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  object-fit: cover;
}

.case_post-list .col-4 .txt_wrap .txtbox {
  display: flex;
  align-items: center;
}

@media (max-width: 767px) {
  .case_post-list .col-4 .txt_wrap .txtbox {
    display: block;
  }
}

.case_post-list .col-4 .txt_wrap .txtbox .cat {
  margin: 0;
  display: block;
  width: 137px;
  text-align: center;
  color: var(--base-color04);
  padding: 3px 0;
  position: relative;
  font-size: 14px;
  font-weight: bold;
  font-style: italic;
  letter-spacing: 0;
}

@media (max-width: 767px) {
  .case_post-list .col-4 .txt_wrap .txtbox .cat {
    width: 100px;
    font-size: 13px;
  }
}

.case_post-list .col-4 .txt_wrap .txtbox .cat .arrow {
  position: relative;
  padding-left: 24px;
}

@media (max-width: 767px) {
  .case_post-list .row .col-4 .txt_wrap .txtbox .cat .arrow {
    padding-left: 15px;
  }
}

.case_post-list .col-4 .txt_wrap .txtbox .cat .arrow::before {
  content: "";
  width: 16px;
  height: 16px;
  position: absolute;
  top: 0;
  bottom: 1px;
  left: 0;
  right: auto;
  margin: auto;
  background: url(../img/common/arrow1.png) no-repeat center center/cover;
}

@media (max-width: 767px) {
  .case_post-list .col-4 .txt_wrap .txtbox .cat .arrow::before {
    width: 11px;
    height: 11px;
  }
}

.case_post-list .col-4 .txt_wrap .text {
  font-weight: bold;
  font-style: italic;
  letter-spacing: 0;
}