/* ------------------------------
 width: all
------------------------------ */
main section.ttl_section .wrapper .mainttl {
  background-image: url(../../../images/bg_ttl_cp.jpg);
}
main section.ttl_section .wrapper .page_info .msg_en {
  max-width: calc(100% - 80px);
  width: 1210px;
  height: auto;
}
main section.ttl_section .wrapper .page_info .t02 {
  text-align: center;
}
main section.s01 {
  width: 1104px;
  margin: 80px auto 0;
}
main section.s01 + .s02 {
  margin-top: 150px;
}
main section.s01 .wrapper h3 {
  text-align: center;
  font-size: 33px;
}
main section.s01 .wrapper .box01 {
  margin-top: 45px;
}
main section.s01 .wrapper .box01 .mainphoto {
  width: 100%;
  display: block;
}
main section.s01 .wrapper .box01 ul {
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 20px;
}
main section.s01 .wrapper .box01 ul li {
  width: 356px;
}
main section.s01 .wrapper .box01 ul li img {
  width: 100%;
  display: block;
}
main section.s01 .wrapper .box01 ul li .t01 {
  font-size: 24px;
  margin-top: 15px;
}
main section.s01 .wrapper .box01 ul li .t02 {
  font-size: 15px;
  line-height: 1.8;
  margin-top: 10px;
}
main section.s01 .wrapper .info_table {
  width: 100%;
  margin-top: 55px;
}
main section.s01 .wrapper .info_table tr + tr {
  border-top: 2px solid #e6e6e6;
}
main section.s01 .wrapper .info_table tr th {
  width: 100px;
  font-size: 17px;
  line-height: 1.8;
  vertical-align: top;
  -moz-text-align-last: justify;
       text-align-last: justify;
  padding: 15px 0;
}
main section.s01 .wrapper .info_table tr td {
  font-size: 17px;
  line-height: 1.8;
  vertical-align: top;
  padding: 15px 40px;
}
main section.s01 .wrapper .btn_viewmore {
  width: 440px;
  padding: 25px 0;
  margin: 80px auto 0;
  border: 1px solid #282828;
  background-color: #282828;
  display: block;
  text-decoration: none;
}
main section.s01 .wrapper .btn_viewmore:hover {
  opacity: 1;
  background-color: #fff;
}
main section.s01 .wrapper .btn_viewmore:hover img {
  -webkit-filter: invert(100%);
          filter: invert(100%);
}
main section.s01 .wrapper .btn_viewmore img {
  width: 145.5px;
  display: block;
  margin: 0 auto;
  -webkit-transition-duration: 0.3s;
          transition-duration: 0.3s;
}
main section.s02 {
  width: 1102px;
  margin: 100px auto 0;
}
main section.s02 .wrapper .ttl {
  text-align: center;
  font-size: 33px;
}
main section.s02 .wrapper .photolist {
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 50px;
}
main section.s02 .wrapper .photolist li {
  width: 50%;
}
main section.s02 .wrapper .photolist li img {
  width: 100%;
  display: block;
}
main section.s02 .wrapper .t01 {
  font-size: 17px;
  line-height: 2;
  margin-top: 30px;
}
main section.s02 .wrapper .info_table {
  width: 100%;
  margin-top: 55px;
}
main section.s02 .wrapper .info_table tr + tr {
  border-top: 2px solid #e6e6e6;
}
main section.s02 .wrapper .info_table tr th {
  width: 100px;
  font-size: 17px;
  line-height: 1.8;
  vertical-align: top;
  -moz-text-align-last: justify;
       text-align-last: justify;
  padding: 15px 0;
}
main section.s02 .wrapper .info_table tr td {
  font-size: 17px;
  line-height: 1.8;
  vertical-align: top;
  padding: 15px 40px;
}

/* ------------------------------
 width < $width-1
------------------------------ */
@media screen and (max-width: 860px) {
  main section.ttl_section .wrapper .page_info .msg_en {
    max-width: 100%;
  }
  main section.s01 {
    width: 100%;
    padding: 0 20px;
    margin: 50px auto 0;
  }
  main section.s01 + .s02 {
    margin-top: 70px;
  }
  main section.s01 .wrapper h3 {
    text-align: center;
    font-size: 24px;
  }
  main section.s01 .wrapper .box01 {
    margin-top: 25px;
  }
  main section.s01 .wrapper .box01 .mainphoto {
    width: 100%;
    display: block;
  }
  main section.s01 .wrapper .box01 ul {
    display: block;
    margin-top: 30px;
  }
  main section.s01 .wrapper .box01 ul li {
    width: 100%;
  }
  main section.s01 .wrapper .box01 ul li + li {
    margin-top: 20px;
  }
  main section.s01 .wrapper .box01 ul li img {
    width: 100%;
    display: block;
  }
  main section.s01 .wrapper .box01 ul li .t01 {
    font-size: 18px;
    margin-top: 10px;
  }
  main section.s01 .wrapper .box01 ul li .t02 {
    font-size: 13px;
    line-height: 1.8;
    margin-top: 5px;
  }
  main section.s01 .wrapper .info_table {
    width: 100%;
    margin-top: 30px;
  }
  main section.s01 .wrapper .info_table tr + tr {
    border-top: 2px solid #e6e6e6;
  }
  main section.s01 .wrapper .info_table tr th {
    width: 70px;
    font-size: 14px;
    line-height: 1.8;
    vertical-align: top;
    -moz-text-align-last: justify;
         text-align-last: justify;
    padding: 10px 0;
  }
  main section.s01 .wrapper .info_table tr td {
    font-size: 14px;
    line-height: 1.8;
    vertical-align: top;
    padding: 10px 0 10px 15px;
  }
  main section.s01 .wrapper .btn_viewmore {
    width: 180px;
    padding: 15px 0;
    margin: 30px auto 0;
    border: 1px solid #282828;
    background-color: #282828;
    display: block;
    text-decoration: none;
  }
  main section.s01 .wrapper .btn_viewmore:hover {
    opacity: 1;
    background-color: #fff;
  }
  main section.s01 .wrapper .btn_viewmore:hover img {
    -webkit-filter: invert(100%);
            filter: invert(100%);
  }
  main section.s01 .wrapper .btn_viewmore img {
    width: 110px;
    display: block;
    margin: 0 auto;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
  }
  main section.s02 {
    width: 100%;
    padding: 0 20px;
    margin: 50px auto 0;
  }
  main section.s02 .wrapper .ttl {
    text-align: center;
    font-size: 24px;
  }
  main section.s02 .wrapper .photolist {
    display: block;
    margin-top: 30px;
  }
  main section.s02 .wrapper .photolist li {
    width: 100%;
  }
  main section.s02 .wrapper .photolist li + li {
    margin-top: 20px;
  }
  main section.s02 .wrapper .photolist li img {
    width: 100%;
    display: block;
  }
  main section.s02 .wrapper .t01 {
    font-size: 14px;
    line-height: 2;
    margin-top: 15px;
  }
  main section.s02 .wrapper .info_table {
    width: 100%;
    margin-top: 30px;
  }
  main section.s02 .wrapper .info_table tr + tr {
    border-top: 2px solid #e6e6e6;
  }
  main section.s02 .wrapper .info_table tr th {
    width: 70px;
    font-size: 14px;
    line-height: 1.8;
    vertical-align: top;
    -moz-text-align-last: justify;
         text-align-last: justify;
    padding: 10px 0;
  }
  main section.s02 .wrapper .info_table tr td {
    font-size: 14px;
    line-height: 1.8;
    vertical-align: top;
    padding: 10px 0 10px 15px;
  }
}