@charset "UTF-8";

/* ========================================
  @media screen and (min-width: 768px),print 
======================================== */
@media screen and (min-width: 768px),print {

.p-fv {
  margin-bottom: 260px;
}

.l-inner.l-fv {
  padding: 0px 0 0;
  position: relative;
}

.l-inner.l-fv:before {
  background: #fff;
  bottom: -109px;
  content: "";
  height: 436px;
  left: 0;
  position: absolute;
  width: min(80%, 1280px);
}

.p-fv__contents {
  align-items: flex-end;
  display: grid;
  gap: 0 clamp(1rem, -0.833rem + 3.82vw, 3.75rem);
  grid-template-columns: 37.3717948718% 58.5897435897%;
  margin-left: auto;
  position: relative;
  width: min(95%, 1560px);
  z-index: 10;
}

.p-fv__en {
  margin-bottom: 20px;
}

.p-fv__ttl {
  background: #877F5E;
  color: #fff;
  font-size: clamp(1.5rem, 0.833rem + 1.39vw, 2.5rem);
  /* font-weight: 600; */
  letter-spacing: 0.1em;
  line-height: 1.8;
  margin-bottom: 22px;
  padding: 0px 28px 0px 19px;
  width: -moz-fit-content;
  width: fit-content;
}

.p-fv__txt {
  font-size: 17px;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.8823529412;
}

.p-fv__contents-right img {
  height: auto;
  width: 100%;
}


.point-box {
  width: min(95%, 1400px);
  margin-inline: auto;
  background: #FFFFFF;
  margin-bottom: 150px;
}
.point-box .ttl-frame {
  background: #877F5E;
  padding: 49px 0 63px;
  color: #FFFFFF;
  position: relative;
}
.point-box .ttl-frame .en-ttl {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
}
.point-box .ttl-frame h2 {
  font-size: 38px;
  line-height: 1.4210526316;
  letter-spacing: 0.1em;
  font-weight: 700;
  text-align: center;
}
.point-box .ttl-frame h2 span {
  font-size: 22px;
  line-height: 1.4090909091;
  letter-spacing: 0.1em;
  font-weight: 700;
  display: block;
  margin: 0 0 6px;
}
.point-box .content-box {
  width: min(95%, 1200px);
  margin-inline: auto;
  position: relative;
  padding: 58px 50px 53px;
  top: -26px;
  background: #fff;
}
.point-box .content-box .img {
  margin: 0 0 25px;
}
.point-box .content-box .img img {
  width: 100%;
}
.point-box .content-box h4 {
  font-size: 18px;
  line-height: 1.8888888889;
  letter-spacing: 0.05em;
  font-weight: 700;
  text-align: left;
  margin: 0 0 18px;
}
.point-box .bottom-frame {
  display: grid;
  grid-template-columns: 58.18% 36.36%;
  gap: 60px;
}
.point-box .txt {
  font-size: clamp(0.875rem, 0.792rem + 0.17vw, 1rem);
  line-height: 2.125;
  letter-spacing: 0.05em;
  font-weight: 500;
  margin: 0 0 34px;
}
.point-box .txt span {
  font-weight: 700;
}
.point-box .bottom-frame .photo-box {
  position: relative;
  margin: 5px 0 0;
}
.point-box .bottom-frame .photo {
  width: 400px;
}
.point-box .bottom-frame .photo img {
  width: 100%;
}
.point-box .bottom-frame .photo-deco {
  position: absolute;
  top: -30px;
  right: -20px;
  width: 160px;
}
.point-box .bottom-frame .photo-deco img {
  width: 100%;
}

.point-box .top-frame {
  display: grid;
  grid-template-columns: 58.18% 36.36%;
  gap: 60px;
  padding: 0 0 42px;
  margin: 0 0 40px;
}
.point-box .top-frame h3 {
  font-size: 18px;
  line-height: 1.8888888889;
  letter-spacing: 0.05em;
  font-weight: 700;
  margin: 0 0 18px;
}
.point-box .top-frame .txt-box {
  margin: 17px 0 0;
}
.point-box .top-frame .photo {
  width: 400px;
}
.point-box .top-frame .photo img {
  width: 100%;
}

.point-box .inner-box01 {
  background: #ECE6DC;
  padding: 40px 60px 33px;
  margin: 0 0 55px;
}
.point-box .inner-box01 h3 {
  font-size: clamp(1.075rem, 1.042rem + 0.07vw, 1.125rem);
  line-height: 1.6;
  letter-spacing: 0.05em;
  font-weight: 700;
  border-bottom: 2px solid #1E1D1B;
  margin: 0 0 14px;
  display: inline-block;
}
.point-box .inner-box01 h3 span {
  font-size: clamp(0.75rem, 0.667rem + 0.17vw, 0.875rem);
  font-weight: 500;
  line-height: 2.4286;
  letter-spacing: 0.05em;
}
.point-box .inner-box01 .txt {
  margin: 0;
}
.point-box .inner-box02 {
  background: #F8F6F1;
}
.point-box .inner-box02 {
  background: #F8F6F1;
  padding: 0 0 33px;
  margin: 0 0 60px;
}
.point-box .inner-box02 .inner {
  display: grid;
  grid-template-columns: 38.77% 57.14%;
  gap: 40px;
  padding: 36px 60px 0;
  margin: 0 0 30px;
}
.point-box .inner-box02 h3 {
  background: #B5AE92;
  color: #FFFFFF;
  font-size: 18px;
  line-height: 1.8888888889;
  letter-spacing: 0.05em;
  font-weight: 700;
  text-align: center;
  padding: 9px 0;
}
.point-box .inner-box02 .inner .txt {
  margin: 0;
}

/* point01 */
.point01 .img01 {
  text-align: center;
  margin: 28px auto 40px;
  width: 90.90%;
}
.point01 .img01 img {
  width: 100%;
}
.point01 .img02 {
  width: 100%;
  text-align: center;
}
.point01 .img02 img {
  width: 100%;
}
.point01 .content-box h5 {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.4090;
  letter-spacing: 0.1em;
  text-align: center;
  margin: 0 0 39px;
}
.point01 .js-scrollable {
  background: #F8F6F1;
  padding: 60px 70px;
}
/* point02 */
.point02 .inner-box01 {
  margin: 0 0 40px;
}
.point02 .middle-txt {
  text-align: center;
}
.point02 .img01 {
  text-align: center;
  margin: 0 0 23px;
}
.point02 .img01 img {
  width: 100%;
}
.point02 .inner-box02 .img {
  margin: 5px 0 0;
}
.point02 .inner-box02 .bottom-txt {
  margin: -6px 60px 0;
}
.point02 .bottom-frame {
  gap: 50px;
}
.point02 .bottom-frame .photo {
  width: 410px;
}
.point02 .bottom-frame .txt-box {
  margin: 14px 0 0;
}
/* point03 */
.point03 {
  margin-bottom: 182px;
}
.point03 .top-frame {
  padding: 0;
  margin: 0 0 34px;
}
.point03 .photo-box {
  margin: 3px 0 0;
  position: relative;
}
.point03 .photo-box .photo01 {
  /* width: 400px; */
}
.point03 .photo-box .photo01 img {
  width: 100%;
}
.point03 .photo-box .photo02 {
  position: absolute;
  bottom: 26px;
  right: 19px;
  width: 180px;
}
.point03 .photo-box .photo02 img {
  width: 100%;
}
.point03 .txt {
  margin: 0 0 19px;
}
.point03 .txt-bold {
  font-weight: 700;
}
.point03 .bottom-box {
  display: grid;
  grid-template-columns: 26.08% 69.56%;
  gap: 40px;
  margin: 0 90px;
}
.point03 .bottom-box .txt {
  margin: 13px 0 0;
}
.point03 .bottom-box .photo img {
  width: 100%;
}


.p-bottom {
  background: url(../images/safe/fv_bottom.jpg) no-repeat top center/cover;
  margin-bottom: -137px;
  margin-inline: auto;
  max-width: 1920px;
  width: 100%;
}

.l-inner.l-bottom {
  padding: 100px 0px 189px;
}

.p-bottom__icon {
  margin-bottom: 6px;
  text-align: center;
}

.p-bottom__ttl span {
  border-bottom: 1px dashed #1E1D1B;
  display: block;
  font-size: 34px;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.6470588235;
  margin-inline: auto;
  width: -moz-fit-content;
  width: fit-content;
}

.p-page__link {
  margin-bottom: 126px;
}

.l-inner.l-page__link {
  margin-inline: auto;
  width: min(85%, 810px);
}

.p-page__link-items {
  display: grid;
  gap: 0 50px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  justify-content: center;
}

.p-page__link-item a {
  display: inline-block;
}

.p-page__link-item a img {
  height: auto;
  width: 100%;
}


}


/* ========================================
@media screen and (min-width:768px) and (max-width:1400px)
======================================== */
@media screen and (min-width:768px) and (max-width:1400px) {
  .point-box .bottom-frame .photo {
    margin: 0.357vw 0 0;
    width: 28.571vw;
  }
  .point-box .top-frame .photo {
    width: 28.571vw;
  }
}

/* ========================================
@media screen and (min-width:768px) and (max-width:1200px)
======================================== */
@media screen and (min-width:768px) and (max-width:1200px) {
  .point-box .bottom-box .txt {
    font-size: clamp(0.75rem, 0.583rem + 0.35vw, 1rem);
  }
  .point03 .photo-box .photo01 {
    width: 33.333vw; 
 }
 .point03 .photo-box .photo02 {
   position: absolute;
   top: 13.167vw;
   right: 1.583vw;
   width: 15vw;
 }
}


/* ========================================
@media screen and (max-width: 767px)
======================================== */
@media screen and (max-width: 767px) {
.p-fv {
  margin-bottom: 29.493vw;
}

.l-inner.l-fv {
  padding: 0 0 9.87vw;
  position: relative;
}

.l-inner.l-fv:before {
  background: #fff;
  bottom: 0vw;
  content: "";
  height: 106.522vw;
  left: 0;
  position: absolute;
  width: 100%;
}

.p-fv__contents {
  display: grid;
  gap: 9.729vw 0;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  margin: 0;
  position: relative;
  width: 100%;
  z-index: 10;
}

.p-fv__contents-left {
  margin-inline: auto;
  order: 2;
  width: min(95%, 89.3vw);
}

.p-fv__en {
  margin-bottom: 3.415vw;
}

.p-fv__en img {
  width: 83.4vw;
  height: auto;
}

.p-fv__ttl {
  background: #877F5E;
  color: #fff;
  font-size: 7.729vw;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.6875;
  margin-bottom: 3.797vw;
  padding: 0.932vw 5.213vw 1vw 3.623vw;
  width: -moz-fit-content;
  width: fit-content;
}

.p-fv__txt {
  font-size: 3.865vw;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 2.125;
}

.p-fv__contents-right {
  margin-left: auto;
  order: 1;
  width: min(95%, 94.6vw);
}

.p-fv__contents-right img {
  height: auto;
  width: 100%;
}


.point-box {
  width: min(95%, 94.3vw);
  margin-inline: auto;
  background: #FFFFFF;
  margin-bottom: 18vw;
}
.point-box .ttl-frame {
  background: #877F5E;
  padding: 9vw 0 11.2vw;
  color: #FFFFFF;
  position: relative;
}
.point-box .ttl-frame .en-ttl {
  position: absolute;
  top: -3.6vw;
  left: 50%;
  transform: translateX(-50%);
  width: 35.8vw;
}
.point-box .ttl-frame .en-ttl img {
  width: 100%;
}
.point-box .ttl-frame h2 {
  font-size:6.763vw;
  line-height: 1.4285714;
  letter-spacing: 0.12em;
  font-weight: 700;
  text-align: center;
}
.point-box .ttl-frame h2 span {
  font-size:4.831vw;
  line-height: 1.55;
  letter-spacing: 0.1em;
  font-weight: 700;
  display: block;
  margin: 0 0 2.4vw;
}
.point-box .content-box {
  width: min(95%, 87vw);
  margin-inline: auto;
  position: relative;
  padding: 5.2vw 2.4vw 5.4vw;
  top: -7.4vw;
  background: #fff;
}
.point-box .content-box .js-scrollable {
  margin: 0;
}
.point-box .content-box .img img {
  width: 100%;
}
.point-box .content-box h4 {
  font-size:3.865vw;
  line-height:2;
  letter-spacing: 0.05em;
  font-weight: 700;
  text-align: left;
  padding: 0 0 3.2vw;
  margin: 0 0 7.6vw;
  order: 1;
}
.point-box .bottom-frame {
  display: flex;
  flex-direction: column-reverse;
}
.point-box .bottom-frame .txt-box {
  display: contents;
}
.point-box .bottom-frame .photo-box {
  position: relative;
}
.point-box .bottom-frame .photo-deco {
  position: absolute;
  top: -9vw;
  left: 50%;
  width: 38.7vw;
  transform: translateX(-50%);
}
.point-box .bottom-frame .photo-deco img {
  width: 100%;
}


.point-box .txt {
  font-size:3.865vw;
  line-height: 2.125;
  letter-spacing: 0.05em;
  font-weight: 500;
  margin: 0 0 8vw;
}
.point-box .txt span {
  font-weight: 700;
}
.point-box .txt:last-child {
  margin: 0;
}
.point-box .bottom-frame .photo {
  margin: 2.6vw 0 6vw;
  width: 100%;
}
.point-box .bottom-frame .photo img {
  width: 100%;
}
.point-box .top-frame {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1vw;
  padding: 0 0 1vw;
  margin: 0 0 0;
}
.point-box .top-frame .txt-box {
  display: contents;
}
.point-box .top-frame .photo {
  width: 100%;
  order: 2;
  margin: 0 0 3vw;
}
.point-box .top-frame .photo img {
  width: 100%;
}
.point-box .top-frame .txt {
  order: 3;
  margin: 0 0 7vw;
}
.point-box .scroll-txt {
  margin: 0 0 4.2vw;
}
.point-box .inner-box01 {
  background: #ECE6DC;
  padding: 6.2vw 5vw 6vw;
  margin: 0 0 8.6vw;
  text-align: center;
}
.point-box .inner-box01 h3 {
  font-size:4.348vw;
  line-height: 1.7777;
  letter-spacing: 0.05em;
  font-weight: 700;
  border-bottom: 0.6vw solid #1E1D1B;
  margin: 0 0 3.4vw;
  display: inline-block;
}
.point-box .inner-box01 h3 span {
  font-size:3.382vw;
  font-weight: 500;
  line-height: 2.4286;
  letter-spacing: 0.05em;
  display: block;
}
.point-box .inner-box01 .txt {
  margin: 0;
  text-align: left;
  font-size: 3.382vw;
  line-height: 2;
}
.point-box .inner-box02 {
  background: #F8F6F1;
  padding: 0 0 12vw;
}
.point-box .inner-box02 h3 {
  background: #B5AE92;
  color: #FFFFFF;
  font-size:4.348vw;
  line-height: 1.8888888889;
  letter-spacing: 0.05em;
  font-weight: 700;
  text-align: center;
  padding: 2.2vw 0;
}

/* スクロールバー全体のスタイル */
.js-scrollable::-webkit-scrollbar {
  width: 100%; /* スクロールバーの幅 */
  height: 11px; /* 横スクロールバーの高さ */
}
/* スクロールバーのつまみのスタイル */
.js-scrollable::-webkit-scrollbar-thumb {
  background-color: #AFAFAF;/* スクロールバーのつまみの色 */
}
/* スクロールバーの背景（トラック）のスタイル */
.js-scrollable::-webkit-scrollbar-track {
  background-color: #E3E3E3; /* 背景の色 */
}


/* point01 */
.point01 .img01 {
  margin: 8vw auto 6.4vw;
}
.point01 .img02 {
  width: 205vw;
  margin: 0 0 2vw;
}
.point01 .img02 img {
  width: 100%;
}
.point01 .content-box h5 {
  font-size:4.348vw;
  font-weight: 700;
  line-height: 1.7222;
  letter-spacing: 0.1em;
  text-align: center;
  margin: 0 0 3.4vw;
}
/* point02 */
.point02 .inner-box01 {
  margin: 0 0 10vw;
}
.point02 .content-box h4 {
  padding: 0;
  margin: 0 0 3vw;
}
.point02 .img01 {
  width: 184vw;
  margin: 0 0 2.4vw;
}
.point02 .img01 img {
  width: 100%;
}
.point02 .inner-box02 {
  padding: 0 0 8vw;
  margin: 0 0 8.4vw;
}
.point02 .inner-box02 .inner {
  display: flex;
  flex-direction: column;
  padding: 5vw 4.87vw 4vw;
}
.point02 .inner-box02 .inner .txt-box {
  display: contents;
}
.point02 .inner-box02 .inner .txt-box .txt {
  order: 3;
}
.point02 .inner-box02 .img {
  order: 2;
  margin: 0 0 6vw;
}
.point02 .inner-box02 .bottom-txt {padding: 0 4.87vw 0;}
.point02 .bottom-frame h4 {
  margin: 0 0 3.4vw;
}
.point02 .bottom-frame .photo {
  margin: 0 0 3.4vw;
}
/* point03 */
.point03 {
  margin-bottom: 23.4vw;
}
.point03 .top-frame h3{
  font-size: 3.865vw;
  line-height: 2;
  letter-spacing: 0.05em;
  font-weight: 700;
  margin: 0 6vw 5vw;
}
.point03 .photo-box {
  display: contents;
}
.point03 .photo-box .photo01 {margin: 0 0 5vw;}
.point03 .photo-box .photo02 {order: 4;margin: 0 0 5vw;}
.point03 .txt-bold {
  font-weight: 700;
  order: 5!important;
}
.point03 .bottom-box {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6vw;
}




.p-bottom {
  background: url(../images/safe/sp_fv_bottom.jpg) no-repeat top center/cover;
  margin-bottom: -114.942vw;
  margin-inline: auto;
  width: 100%;
}

.l-inner.l-bottom {
  padding: 14.493vw 0 120.498vw;
}

.p-bottom__icon {
  margin-bottom: 1.449vw;
  text-align: center;
}

.p-bottom__icon img {
  height: auto;
  width: 26.087vw;
}

.p-bottom__ttl {
  margin-bottom: 1vw;
}

.p-bottom__ttl span {
  border-bottom: 0.4vw dashed #1E1D1B;
  display: block;
  font-size: 5.797vw;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1.7916666667;
  margin-inline: auto;
  width: -moz-fit-content;
  width: fit-content;
}

.p-page__link {
  margin-bottom: 34.324vw;
}

.l-inner.l-page__link {
  margin-inline: auto;
  width: min(95%, 91.7vw);
}

.p-page__link-items {
  display: grid;
  gap: 9.662vw 0;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  justify-content: center;
}

.p-page__link-item a {
  display: inline-block;
}

.p-page__link-item a img {
  height: auto;
  width: 100%;
}

}
  