/* スマホ */
.menu li span {
  margin-left: 10px;
}
.fv {
      position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
}
.fv_top{
  position: relative;
  width: 100%;
  height: 85vh;
  overflow: hidden;

}
    .lang-select {
      position: absolute;
      top: 5%;
      right: 5%;
      font-size: 16px;
      z-index: 9;
      display: flex;
    }
    .main-text {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      line-height: 2;
      z-index: 9;
      width: 100%;
    }
    .scroll-indicator {
      position: absolute;
      left: 50%;
      bottom: 0px;
      transform: translateX(-50%);
      font-size: 14px;
      z-index: 9;
    }
    .scroll-indicator span {
    display: block;
    margin: 10px 0;
    }
    .scroll-indicator::after {
      content: "";
      display: block;
      width: 1px;
      height: 40px;
      background-color: #000;
      margin: 5px auto 0;
    }
        .scroll-indicator::before {
      content: "";
      display: block;
      width: 1px;
      height: 40px;
      background-color: #000;
      margin: 5px auto 0;
    }
.slider-sp {
  position: relative;
  width: 100%;
  height: 100%; /* 親の高さにフィット */
}
.slider-sp img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  z-index: 0; /* 背景に */
}
.slider-sp img.active {
  opacity: 1;
}
.news-section, .service-section, .contact-section {
  background: url("../image/background_image.png") repeat; 
  padding-top: 80px;
} 
.news-section h2, .service-section h2, .contact-section h2 {
    margin-bottom: 40px;
    font-size: 1.8rem;
}
.news-list {
  list-style: none;
  padding: 30px;
  background-color: #fff;
  max-width: 640px;
  margin: 0 auto;
}
.news-list li {
    display: flex;
      flex-direction: row;
  border-bottom: 1px solid #B68E3C;
  padding: 10px 0;
  font-size: 14px;
  width: 90%;
  margin: 0 auto;
  text-align: left;
  align-items: center;
}
.news-list li span {
line-height: 1.2;
}
.news-list li:first-child {
  padding-top: 0;
}
.news-list .date {
  padding-right: 20px;
}
.more-link {
  display: block;
  text-align: center;
  color: #990000;
  margin-top: 40px;
  font-size: 16px;
  text-decoration: none;
  border-bottom: 1px solid #990000;
  width: max-content;
  margin-left: auto;
  margin-right: auto;
}
.service-image_purchase {
  background-image: url("../image/top_service_image.png"); 
  background-size: cover;
  background-position: center;
  height: 300px;
  position: relative;
  z-index: 1;
  max-width: 600px;
  margin: 0 auto;
}
.service-image_sale {
  background-image: url("../image/top_service_image-1.png");
  background-size: cover;
  background-position: center;
  height: 300px;
  position: relative;
  z-index: 1;
  max-width: 600px;
  margin: 40px auto 0;
}
.service-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border: 1px solid #333;
  padding: 10px 20px;
  background: rgba(255, 255, 255, 0.5);
  font-size: 18px;
}
.phone-box {
  display: inline-block;
  padding: 12px 40px;
  border: 1px solid #333;
  font-size: 16px;
  background-color: #fff;
  transition: 0.3s;
  max-width: 500px;
  margin: 0 auto;
  width: 50%;
}
.contact-info {
    display: flex;
    flex-direction: column; /* ← 常に縦並びにする */
    gap: 20px;
}
.phone-box a {
  color: #333;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: center;
}
.phone-box img {
    width: 15px;
    height: 15px;
}
.line-contact {
  display: inline-block;
  padding: 12px 37px;
  border: 1px solid #06C755;
  font-size: 14px;
  background-color: #fff;
  transition: 0.3s;
  margin: 0 auto 20px;
  width: 52%;
  max-width: 500px;
}
.line-contact a {
  color: #06C755;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: center;
}
.contact-section {
padding:80px 8%;
}
.contact-section address h3 {
padding-bottom: 10px;
border-bottom: 2px solid #B68E3C;
width: 80%;
margin: 0 auto;
font-weight: 500;
max-width: 600px;
}
.contact-section address li:first-child {
    padding: 20px 0px 10px;
}
.contact-section ul{
  line-height: 1.6;
  font-size: 14px;
}
.contact-section address li:nth-child(2) {
    padding-bottom: 10px;
}
.shinsaibashishop-info {
    margin-bottom: 40px;
}
/* タブレット */
@media screen and (min-width: 780px) {
  .fv {
  height: 100vh;
}
  .main-text {
    font-size: 22px;
  }
  .slider-sp {
    display: none;
  }
  .slider-pc {
  position: relative;
  width: 100%;
  height: 100%; /* 親の高さにフィット */
}
.slider-pc img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  z-index: 0; /* 背景に */
}
.slider-pc img.active {
  opacity: 1;
}
    .lang-select {
      font-size: 18px;
    }
  .news-section, .service-section, .contact-section {
    padding-top: 96px;
  }
  .news-section h2,.service-section h2,.contact-section h2 {
    font-size: 2.3rem;
  }
  .news-list {
    padding: 40px;
  }
  .news-list li {
    font-size: 16px;
    padding: 20px 0;
  }
  .more-link {
    font-size: 18px;
    margin-top: 48px;
  }
  .service-image_purchase, .service-image_sale {
    height: 400px;
    max-width: 800px;
  }
  .service-text {
    font-size: 25px;
  }
  .phone-box, .line-contact {
    font-size: 18px;
  }
  .contact-section {
    padding-bottom: 96px;
  }
  .contact-section address h3 {
    font-size: 20px;
  }
  .contact-info {
    gap: 32px;
}
  .contact-section ul {
    font-size: 16px;
  }
  .shinsaibashishop-info {
    margin-bottom: 56px;
  }
}