@charset "UTF-8";
/* ============================================================
// service.scss
============================================================ */
/* ------------------------------------------------------------
// Fluid Design Function
// 最小値〜最大値の間で数値を可変させる共通関数
------------------------------------------------------------ */
/* ------------------------------------------------------------
// design
------------------------------------------------------------ */
.page-header {
  position: relative;
  width: 100%;
  height: clamp(260px, 9.1324200913vw + 225.7534246575px, 360px);
  display: flex;
  align-items: center;
  overflow: hidden;
  background: url("../images/service/bg-header.webp") no-repeat center center/cover;
  background-size: cover;
  background-position: center;
}
.page-header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.1);
  z-index: 1;
}
.page-header__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 4%;
}
.page-header__title-area {
  position: relative;
  display: inline-block;
}
.page-header__en {
  font-family: "Quicksand", sans-serif;
  font-size: clamp(60px, 3.6529680365vw + 46.301369863px, 100px);
  font-weight: 700;
  line-height: 1;
  color: rgba(87, 161, 54, 0.25);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.page-header__jp {
  position: absolute;
  bottom: 0;
  left: 4px;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: clamp(24px, 0.7305936073vw + 21.2602739726px, 32px);
  font-weight: 700;
  color: #fff;
}
.page-header__deco {
  position: absolute;
  right: 5%;
  bottom: 10px;
  width: clamp(100px, 7.3059360731vw + 72.602739726px, 180px);
  z-index: 2;
  opacity: 0.8;
}
.page-header__deco img {
  width: 100%;
  height: auto;
}

.service-overview {
  max-width: 940px;
  margin-inline: auto;
  margin-bottom: clamp(60px, 2.7397260274vw + 49.7260273973px, 90px);
}
.service-overview p {
  font-size: clamp(16px, 0.3652968037vw + 14.6301369863px, 20px);
  line-height: 2.4;
  font-weight: 500;
  text-align: justify;
}
@media screen and (max-width: 575px) {
  .service-overview p {
    line-height: 2;
  }
}

.service-info {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
  gap: 40px;
  max-width: 940px;
  margin-inline: auto;
}
.service-info .info-list {
  width: 100%;
  border-top: 2px solid #ddd;
}
.service-info .info-list__item {
  display: flex;
  gap: 20px;
  padding-block: 15px;
  border-bottom: 2px solid #ddd;
}
@media screen and (max-width: 575px) {
  .service-info .info-list__item {
    flex-direction: column;
    gap: 10px;
  }
}
.service-info .info-list__item dt {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  width: clamp(120px, 5.4794520548vw + 99.4520547945px, 180px);
  font-weight: 700;
  padding: 10px 15px;
  background-color: #ddebcd;
  border-radius: 6px;
}
@media screen and (max-width: 575px) {
  .service-info .info-list__item dt {
    width: -moz-fit-content;
    width: fit-content;
    padding: 4px 12px;
  }
}
.service-info .info-list__item dd {
  flex: 1;
  display: flex;
  align-items: center;
  padding-left: 5px;
}
.service-info .info-list__item dd .u-list-dot li {
  position: relative;
  padding-left: 1.2em;
}
.service-info .info-list__item dd .u-list-dot li::before {
  content: "・";
  position: absolute;
  left: 0;
}
.service-info .c-google-maps {
  border-radius: 10px;
}
.service-info .c-google-maps iframe {
  border-radius: 10px;
}

.service-contact {
  margin-top: clamp(60px, 5.4794520548vw + 39.4520547945px, 120px);
}
.service-contact__inner {
  position: relative;
  text-align: center;
  max-width: 940px;
  margin-inline: auto;
  padding: clamp(40px, 1.8264840183vw + 33.1506849315px, 60px) clamp(20px, 1.8264840183vw + 13.1506849315px, 40px);
  border: 2px solid #57a136;
  border-radius: 20px;
}
.service-contact__title {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  font-size: clamp(20px, 1.095890411vw + 15.8904109589px, 32px);
  font-weight: 700;
  text-align: center;
  padding: 0 10px;
  background-color: #fbfcfa;
  white-space: nowrap;
}
.service-contact__lead {
  font-size: clamp(15px, 0.2739726027vw + 13.9726027397px, 18px);
  margin-bottom: 30px;
}
.service-contact__tel-wrap {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 15px;
}
.service-contact__tel {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: clamp(32px, 1.4611872146vw + 26.5205479452px, 48px);
  font-weight: 700;
  text-decoration: none;
  line-height: 1.2;
}
.service-contact__tel i {
  color: #57a136;
  font-size: 0.8em;
}
.service-contact__tel:hover {
  opacity: 0.7;
}
.service-contact__info {
  display: flex;
  justify-content: center;
  gap: 20px;
  font-size: clamp(14px, 0.3652968037vw + 12.6301369863px, 18px);
  font-weight: 700;
}
@media screen and (max-width: 575px) {
  .service-contact__info {
    flex-direction: column;
    gap: 5px;
  }
}

.service-list__inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(15px, 0.4566210046vw + 13.2876712329px, 20px);
  max-width: 940px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .service-list__inner {
    grid-template-columns: repeat(2, 1fr);
  }
}
.service-list__item {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  text-align: center;
  padding: clamp(20px, 0.9132420091vw + 16.5753424658px, 30px) 10px;
  background-color: #ede8e3;
  border-radius: 10px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
.service-list__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(100px, 1.8264840183vw + 93.1506849315px, 120px);
  height: clamp(100px, 1.8264840183vw + 93.1506849315px, 120px);
  margin-bottom: 15px;
  background-color: #fff;
  border-radius: 50%;
}
.service-list__icon img {
  width: 75%;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
  border-radius: 50%;
}
.service-list__text {
  font-size: clamp(14px, 0.1826484018vw + 13.3150684932px, 16px);
  font-weight: 700;
  line-height: 1.4;
}