

@font-face {
    font-family: "iconfont";
    src: url(../afonts/iconfont.woff2?t=1645624313924) format('woff2'), url(../afonts/iconfont.woff?t=1645624313924) format('woff'), url(../afonts/iconfont.ttf?t=1645624313924) format('truetype');
}

#banner_marai {
    position: fixed;
    width: 352px;
    left: 50%;
    margin-left: -176px;
    bottom: 50%;
    transform: translateY(50%);
    border-radius: 6px;
    z-index: 2014;
}
#banner_marai > span {
    position: absolute;
    right: 5px;
    top: 0;
    cursor: pointer;
}
#banner_marai > span .iconfont {
    font-size: 16px;
    color: #fff;
}

.iconfont {
    font-family: "iconfont" !important;
    font-size: 16px;
    font-style: normal;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.icon-guanbi:before {
    content: "\e64d";
}
/*BEGIN*/
.header a {
  display: block;
}
.header a img {
  display: block;
  width: 100%;
}

.part01 {
  width: 81.571%;
  margin: 5vw auto 0;
  position: relative;
  z-index: 2;
}
.part01 a,
.part01 img {
  display: block;
  width: 100%;
}

.part02 {
  padding-top: 3.571%;
  padding-bottom: 41.07%;
  background: url(../images/comfort/pic03.jpg) no-repeat center bottom;
  background-size: 100% auto;
}
.part02 .wrap {
  width: 90.964%;
  margin: 0 auto;
}
.part02 .wrap a,
.part02 .wrap img {
  display: block;
  width: 100%;
}
.part02 .txt {
  width: 87.143%;
  margin: 2.857% auto 0;
}
.part02 .txt p {
  padding-bottom: 60px;
  font-size: 30px;
  line-height: 60px;
  color: #3b3047;
  font-family: "MPLUS1p-Regular";
}

.part03 {
  padding-top: 10.536%;
  background: url(../images/comfort/pic04.jpg) no-repeat left top;
  background-size: 100% auto;
  position: relative;
}
.part03 .wrap {
  width: 19.607%;
  margin-left: 53.143%;
}
.part03 .wrap a,
.part03 .wrap img {
  display: block;
  width: 100%;
}
.part03 .txt01 {
  width: 40.714%;
  margin: 3.571% 0 2.5% 53.143%;
}
.part03 .txt01 p {
  font-size: 24px;
  line-height: 40px;
  color: #3b3047;
  font-family: "MPLUS1p-Regular";
}
.part03 .img {
  width: 50%;
  margin-left: 45.107%;
}
.part03 .img img {
  display: block;
  width: 100%;
}
.part03 .txt02 {
  position: absolute;
  right: 52.857%;
  bottom: 12.857%;
}
.part03 .txt02 p {
  font-size: 24px;
  line-height: 40px;
  color: #3b3047;
  font-family: "MPLUS1p-Regular";
}
.part03 .line {
  position: absolute;
  right: 65.5%;
  bottom: -12%;
  width: 0.2143%;
  height: 19.571%;
  background-color: #5f338d;
  z-index: 99;
}

.part04 {
  padding-top: 9.18%;
  padding-bottom: 42.035%;
  background: url(../images/comfort/pic05.jpg) no-repeat center bottom;
  background-size: 100% auto;
  position: relative;
}
.part04 .wrap {
  width: 34.143%;
  margin: 0 auto;
}
.part04 .wrap a,
.part04 .wrap img {
  display: block;
  width: 100%;
}

.part05 {
  position: relative;
  padding-bottom: 10.786%;
  background: url(../images/comfort/pic07.jpg) no-repeat;
  background-size: 100% auto;
  background-position: 0 7.714%;
}
.part05 .wrap {
  width: 61%;
  padding: 2.5% 3.571% 6.928%;
  margin: -7.714% auto 0;
  background: #fff url(../images/comfort/pic06.png) no-repeat center bottom;
  background-size: 100% auto;
  box-sizing: border-box;
}
.part05 .wrap h4 {
  font-size: 32px;
  line-height: 60px;
  color: #000;
  font-family: "MPLUS1p-Regular";
}
.part05 .wrap p {
  font-size: 28px;
  line-height: 50px;
  color: #000;
  font-family: "MPLUS1p-Regular";
}

.part06 {
  position: relative;
  padding-bottom: 6.928%;
  overflow-x: hidden;
}
.part06 h2 {
  width: 72%;
  margin: 0 auto;
}
.part06 h2 img {
  display: block;
  width: 100%;
}
.part06 h2 .line {
  display: block;
  width: 0.435%;
  height: 80px;
  background-color: #5f338d;
  margin: 5.8% auto 4.64%;
}
.part06 .picList01 .brick {
  float: left;
  width: 31.428%;
  margin-left: 2.143%;
}
.part06 .picList01 .brick a {
  display: block;
  width: 100%;
  height: auto;
  margin-bottom: 6.818%;
}
.part06 .picList01 .brick a img {
  display: block;
  width: 100%;
  transition: all 0.5s;
}
.part06 .picList01 .brick a img:hover {
  transform: scale(1.05);
}
.part06 .picList01 .brick:first-child {
  margin-left: 0.714%;
}
.part06 .picList02 .brick {
  float: left;
  width: 31.428%;
  margin-left: 2.428%;
}
.part06 .picList02 .brick a {
  display: block;
  width: 100%;
  height: auto;
  margin-bottom: 6.818%;
}
.part06 .picList02 .brick a img {
  display: block;
  width: 100%;
  transition: all 0.5s;
}
.part06 .picList02 .brick a img:hover {
  transform: scale(1.05);
}
.part06 .picList02 .brick:first-child {
  margin-left: 0.714%;
  width: 65%;
}
.part06 .picList02 .brick:first-child a {
  display: block;
  margin-bottom: 3.305%;
}
.part06 .picList02 .brick:first-child a:nth-child(1) {
  float: left;
  width: 61.758%;
}
.part06 .picList02 .brick:first-child a:nth-child(2) {
  float: right;
  width: 34.78%;
}
.part06 .picList02 .brick:first-child a:nth-child(3) {
  float: left;
  width: 46.648%;
}
.part06 .picList02 .brick:first-child a:nth-child(4) {
  float: right;
  width: 50.165%;
}

.part07 {
  position: relative;
  padding-top: 18.714%;
}
.part07 .wrap {
  width: 37.036%;
  margin-left: 21.714%;
}
.part07 .wrap a,
.part07 .wrap img {
  display: block;
  width: 100%;
}
.part07 .txt {
  width: 56.572%;
  margin: 3.928% auto 0;
}
.part07 .txt h4,
.part07 .txt p {
  font-size: 24px;
  line-height: 40px;
  color: #3b3047;
  font-family: "MPLUS1p-Regular";
}
.part07 .txt h4 {
  font-family: "MPLUS1p-Bold";
}
.part07 .swiperBox {
  width: 92.857%;
  height: auto;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
}
.part07 .swiper {
  width: 100%;
  height: auto;
  padding-top: 5.58%;
  padding-bottom: 3.9%;
}
.part07 .swiper-slide {
  text-align: center;
  font-size: 18px;
  background: #fff;
  /* Center slide text vertically */
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}
.part07 .swiper-slide img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
.part07 .swiper-pagination {
  width: 33%;
  height: 4px;
  left: 33%;
  top: initial;
  bottom: 0;
}

.part08 .title img {
  display: block;
  width: 100%;
}
.part08 .list li {
  position: relative;
  margin-bottom: 18.286%;
}
.part08 .list li .bg img {
  display: block;
  width: 100%;
}
.part08 .list li main {
  position: absolute;
  bottom: -16.571%;
  width: 39.64%;
  padding: 4.286% 3.857% 6.428%;
  background-color: #ebecf7;
  box-sizing: border-box;
  font-size: 30px;
  line-height: 58px;
  font-family: "MPLUS1p-Regular";
}
.part08 .list li main h3 img {
  display: block;
}
.part08 .list li main h3 .tit01 {
  width: 97.092%;
}
.part08 .list li main h3 .tit02 {
  width: 63%;
}
.part08 .list li main h3 .tit03 {
  width: 67%;
}
.part08 .list li main h3 .tit04 {
  width: 46.98%;
}
.part08 .list li main h3 .tit05 {
  width: 86.13%;
}
.part08 .list li main p {
  margin-top: 1em;
}
.part08 .list li main .line {
  width: 100%;
  height: 2px;
  margin-top: 3em;
  margin-bottom: 12.304%;
  background-color: #000;
}
.part08 .list li .bike {
  position: absolute;
  left: 0;
  bottom: -23.857%;
  width: 60.796%;
}
.part08 .list li .bike img {
  display: block;
  width: 100%;
}
.part08 .list li:nth-child(2n + 1) main {
  right: 3.571%;
}
.part08 .list li:nth-child(2n) main {
  left: 3.571%;
}
.part08 .list li:nth-child(5) main .line {
  margin-bottom: 12.356%;
  margin-top: 21.25%;
}

.part09 .title {
  width: 55.821%;
  margin: 9.786% auto 6%;
}
.part09 .title img {
  display: block;
  width: 100%;
}
.part09 .list li {
  position: relative;
  width: 92.857%;
  margin: 0 auto 6.428%;
}
.part09 .list li .img {
  width: 63.077%;
}
.part09 .list li .img img {
  display: block;
  width: 100%;
}
.part09 .list li .txt {
  width: 34.615%;
  padding-top: 7.7%;
}
.part09 .list li .txt h4 {
  font-size: 38px;
  line-height: 70px;
  padding-bottom: 30px;
  color: #000;
  font-family: "MPLUS1p-Medium";
}
.part09 .list li .txt p {
  font-size: 28px;
  line-height: 50px;
  color: #000;
  font-family: "MPLUS1p-Regular";
}
.part09 .list li:nth-child(2n + 1) .img {
  float: right;
}
.part09 .list li:nth-child(2n + 1) .txt {
  float: left;
}
.part09 .list li:nth-child(2n) .img {
  float: left;
}
.part09 .list li:nth-child(2n) .txt {
  float: right;
}
.d_mdianpc_mirai {
  display: block;
  position: fixed;
  right: 7.5vw;
  bottom: 12vw;
  z-index: 999;
}
.d_mdianph_mirai {
  display: none;
}
.d_imgul_topmp {
  display: none;
}
.d_imgul_toppc {
  display: block;
}
.d_imgul_top {
  width: 100%;
  padding-top: 80px;
  margin-top: 0px;
}
.d_imgul_top img {
  display: block;
  float: left;
  width: calc((100% - 40px) / 3);
  padding-bottom: 20px;
  padding-left: 20px;
}
.d_imgul_top a:nth-child(1) img {
  padding-left: 0px;
}
.d_imgul_top a:nth-child(4) img {
  padding-left: 0px;
}
.d_imgli_bot {
  width: 100%;
  margin-bottom: 3vw;
}
.d_imgli_bot img {
  width: 100%;
  height: auto;
  display: block;
  padding-top: 40px;
}
.d_imgli_bot p {
  color: #000;
  width: 88vw;
  margin: 0 auto;
  font-weight: bold;
  font-size: 1.7vw;
  padding-top: 1.5vw;
  line-height: 3vw;
}
@media (min-width: 1660px) and (max-width: 1800px) {
  .part08 .list li main {
    font-size: 26px;
    line-height: 48px;
  }
  .part09 .list li .txt h4 {
    font-size: 34px;
    line-height: 60px;
  }
}
@media (min-width: 1400px) and (max-width: 1659px) {
  .part08 .list li main {
    font-size: 24px;
    line-height: 40px;
  }
  .part09 .list li .txt h4 {
    font-size: 30px;
    line-height: 60px;
  }
  .part09 .list li .txt p {
    font-size: 24px;
    line-height: 40px;
  }
}
@media (min-width: 1280px) and (max-width: 1399px) {
  .part08 .list li main {
    font-size: 22px;
    line-height: 36px;
  }
  .part09 .list li .txt h4 {
    font-size: 24px;
    line-height: 50px;
  }
  .part09 .list li .txt p {
    font-size: 20px;
    line-height: 30px;
  }
}
@media (min-width: 1110px) and (max-width: 1279px) {
  .part08 .list li main {
    font-size: 18px;
    line-height: 36px;
  }
  .part09 .list li .txt h4 {
    font-size: 20px;
    line-height: 40px;
  }
  .part09 .list li .txt p {
    font-size: 16px;
    line-height: 30px;
  }
}
@media (min-width: 880px) and (max-width: 1109px) {
  .part08 .list li main {
    font-size: 16px;
    line-height: 30px;
  }
  .part09 .list li .txt {
    padding-top: 5%;
  }
  .part09 .list li .txt h4 {
    font-size: 20px;
    line-height: 30px;
  }
  .part09 .list li .txt p {
    font-size: 16px;
    line-height: 24px;
  }
}
@media (min-width: 0) and (max-width: 879px) {
	
    #banner_marai {
        width: 80%;
        left: 10%;
        right: initial;
        bottom: 50%;
        transform: translateY(50%);
        margin-left: 0;
    }
  .part08 .list li main {
    font-size: 14px;
    line-height: 26px;
  }
  .part09 .list li .img {
    width: 100%;
  }
  .part09 .list li .txt {
    width: 100%;
    padding-top: 5%;
    text-align: center;
  }
  .part09 .list li .txt h4 {
    font-size: 20px;
    line-height: 30px;
    font-family: "MPLUS1p-Regular";
  }
  .part09 .list li .txt p {
    font-size: 16px;
    line-height: 24px;
  }
}
@media (min-width: 0) and (max-width: 750px) {
	
    #banner_marai {
        width: 80%;
        left: 10%;
        right: initial;
        bottom: 50%;
        transform: translateY(50%);
        margin-left: 0;
    }
  .part08 .list li main {
    position: relative;
    width: 90%;
    left: 5% !important;
    right: initial;
    bottom: initial;
    top: 0;
    margin-top: -10%;
    font-size: 14px;
    line-height: 26px;
  }
  .part08 .list li .bike {
    display: none;
  }
}
/*END*/
@media (min-width: 0px) and (max-width: 1367px) {
  .part02 .txt p {
    padding-bottom: 60px;
    font-size: 24px;
    line-height: 50px;
  }
  .part05 .wrap {
    width: 70%;
    padding: 2.5% 3.571% 6.928%;
    margin: -7.714% auto 0;
    background: #fff url(../images/comfort/pic06.png) no-repeat center bottom;
    background-size: 100% auto;
    box-sizing: border-box;
  }
  .part05 .wrap h4 {
    font-size: 28px;
  }
  .part05 .wrap p {
    font-size: 24px;
  }
}
@media (min-width: 0px) and (max-width: 750px) {
	
    #banner_marai {
        width: 80%;
        left: 10%;
        right: initial;
        bottom: 50%;
        transform: translateY(50%);
        margin-left: 0;
    }
  .part01 {
    width: 96%;
  }
  .part02 .txt {
    width: 90%;
  }
  .part02 .txt p {
    font-size: 16px;
    line-height: 36px;
    padding-bottom: 30px;
  }
  .part03 .wrap {
    width: 50%;
    margin-left: 25%;
  }
  .part03 .txt01 {
    width: 90%;
    margin: 40px auto 20px;
  }
  .part03 .txt01 p {
    font-size: 16px;
    line-height: 36px;
  }
  .part03 .img {
    width: 90%;
    margin-left: 5%;
  }
  .part03 .img img {
    display: block;
    width: 100%;
  }
  .part03 .txt02 {
    position: relative;
    right: initial;
    bottom: initial;
    width: 90%;
    margin: 3.571% auto 2.5%;
  }
  .part03 .txt02 p {
    text-align: center;
    font-size: 16px;
    line-height: 36px;
  }
  .part03 .line {
    right: 50%;
    bottom: -70px;
    width: 2px;
    height: 50px;
  }
  .part05 .wrap {
    width: 90%;
  }
  .part05 .wrap h4 {
    font-size: 20px;
    line-height: 40px;
  }
  .part05 .wrap p {
    font-size: 16px;
    line-height: 36px;
  }
  .part06 h2 .line {
    height: 50px;
  }
  .part07 .wrap {
    width: 90%;
    margin-left: 5%;
  }
  .part07 .txt {
    width: 90%;
  }
  .part07 .txt h4,
  .part07 .txt p {
    font-size: 16px;
    line-height: 36px;
  }
  .d_mdianph_mirai {
    display: block;
    position: fixed;
    right: 93px;
    bottom: 36px;
    width: 150px;
    z-index: 999;
  }
  .d_mdianpc_mirai {
    display: none;
  }
  .d_imgul_topmp {
    display: block;
  }
  .d_imgul_toppc {
    display: none;
  }
  .d_imgul_top {
    width: 100%;
    padding-top: 50px;
    margin-top: 0px;
  }
  .d_imgul_top img {
    display: block;
    float: left;
    width: calc((100% - 10px) / 2);
    padding-bottom: 10px;
    padding-left: 10px;
  }
  .d_imgul_top a:nth-child(1) img {
    padding-left: 0px;
  }
  .d_imgul_top a:nth-child(4) img {
    padding-left: 10px;
  }
  .d_imgul_top a:nth-child(3) img {
    padding-left: 0px;
  }
  .d_imgul_top a:nth-child(5) img {
    padding-left: 0px;
  }
  .d_imgli_bot {
    width: 100%;
    margin-bottom: 2.5vw;
  }
  .d_imgli_bot img {
    width: 100%;
    height: auto;
    display: block;
    padding-top: 20px;
  }
  .d_imgli_bot p {
    color: #000;
    width: 88vw;
    margin: 0 auto;
    font-weight: bold;
    font-size: 3vw;
    padding-top: 2vw;
    line-height: 5.2vw;
  }
}
.top-img-link a{ display: block; width: 100%;}
.top-img-link a img{ display: block; width: 100%;}
