@charset "utf-8";
/* CSS Document */
.topbgimg01 {
  background: url(../img/bg/top.jpg) no-repeat top center;
  background-size: 100%;
}
@media only screen and (max-width:1050px) {
  .topbgimg01 {
    background: url(../img/bg/top_tb.jpg) no-repeat top center;
    background-size: 100%;
  }
}
@media only screen and (max-width:700px) {
  .topbgimg01 {
    background: url(../img/bg/top_sp.jpg) no-repeat top center;
    background-size: 100%;
  }
}
.bgimg01 {
  background: url(../img/ttl/01.png) top center;
  background-size: 100%;
}
.bgimg02 {
  background: url(../img/ttl/02.png) top center;
  background-size: 100%;
}
.bgimg03 {
  background: url(../img/ttl/03.png) top center;
  background-size: 100%;
}
.bgimg04 {
  background: url(../img/ttl/04.png) top center;
  background-size: 100%;
}
.bgimg05 {
  background: url(../img/ttl/05.png) top center;
  background-size: 100%;
}
.bgimg06 {
  background: url(../img/ttl/06.png) top center;
  background-size: 100%;
}
.bgimg07 {
  background: url(../img/ttl/07.png) top center;
  background-size: 100%;
}
.bgimg08 {
  background: url(../img/ttl/08.png) top center;
  background-size: 100%;
}
.bgimg09 {
  background: url(../img/ttl/09.png) top center;
  background-size: 100%;
}
.bgimg10 {
  background: url(../img/ttl/10.png) top center;
  background-size: 100%;
}
.bgimg11 {
  background: url(../img/ttl/11.png) top center;
  background-size: 100%;
}
.bgimg12 {
  background: url(../img/ttl/12.png) top center;
  background-size: 100%;
}
.icon_jp {
  background: url(../img/icon/japanese.png) no-repeat 20px center !important;
  padding-left: 25px !important;
}
.icon_en {
  background: url(../img/icon/english.png) no-repeat 20px center !important;
  padding-left: 25px !important;
}
.icon_vn {
  background: url(../img/icon/vietnamese.png) no-repeat 20px center !important;
  padding-left: 25px !important;
}
.icon_zh {
  background: url(../img/icon/chinese.png) no-repeat 20px center !important;
  padding-left: 25px !important;
}
.icon_ko {
  background: url(../img/icon/korea.png) no-repeat 20px center !important;
  padding-left: 25px !important;
}
.Rimg {
  float: right;
  margin-left: 15px;
  width: 35%;
  height: auto;
}
.Limg {
  float: left;
  margin-right: 15px;
  width: 35%;
  height: auto;
}
.cate a {
  display: block;
  width: 188px;
  height: 36px;
}
.cal_wrapper {
  max-width: 1600px; /* 最大幅 */
  min-width: 300px; /* 最小幅 */
  margin: 2.0833% auto;
}
.googlecal {
  position: relative;
  padding-bottom: 100%; /* 縦横比 */
  height: 0;
  overflow: hidden;
}
.googlecal iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
  background: none !important;
}
@media only screen and (min-width: 600px) {
  /* 画面幅が600px以上の場合の縦横比の指定 */
  .googlecal {
    padding-bottom: 75%;
  }
}
.ggmap {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
}
.ggmap iframe, .ggmap object, .ggmap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
h3.privacy {
  padding: 0 25px;
  color: #333333;
  font-size: 15px;
  background: none;
  margin: 10px 0 5px;
}
h4.privacy {
  padding: 5px;
  color: #333333;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
}
ul.privacy {
  padding: 0 50px;
}
ul.privacy li {
  list-style: lower-roman;
}
ul.privacy ul {
  padding: 0 20px;
}
ul.privacy li li {
  list-style: lower-alpha;
}
h4.product {
  padding: 5px;
  color: #555555;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}
.fcolor_w {
  color: #FFFFFF !important;
}
.fcolor_w a {
  color: #FFFFFF !important;
}
table {
  width: 100% !important;
}
.Subttl {
  height: 60px !important;
  line-height: 60px !important;
  padding: 0 10px !important;
  background-color: rgba(60, 60, 60, 1.0);
}
.Subttl a {
  height: 60x !important;
  line-height: 60px !important;
  color: #FFFFFF !important;
  font-weight: normal !important;
  font-size: 16px !important;
}
/* Color */
/* Font Color */
.Col6box section .cate {
  color: #FFFFFF;
}
.Col3box h2 {
  color: #BD1B25;
}
.Col3box section .cate {
  color: #FFFFFF;
}
.Col6box section .cate {
  background: #000000;
}
.Col3box section .cate {
  background: #f5a100;
}
.red {
  color: #BD1B25;
}
.yellow {
  color: #EDE93C;
}
.white {
  color: #FFFFFF;
}
a.detailbtn {
  background: #009E84;
}
a.detailbtn:hover {
  background: url(../../common/img/bg/02.png);
}
.contenthover a.mybutton {
  background: #3c9632;
  color: #fff;
  font-size: 18px;
}
.contenthover a.mybutton:hover {
  background: #34742d;
}
.page_subttl h1 {
  font-size: 25px;
  font-weight: bold;
}
.pc {
  display: block;
}
.sp {
  display: none;
}
@media only screen and (max-width:600px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
}
.wcolor {
  color: #FFFFFF;
}
/* 例外的 */
.btn01 {
  height: 250px;
  background: url(../img/page/01.png) no-repeat center;
  width: 40%;
  margin-bottom: 2%;
}
.btn02 {
  height: 250px;
  background: url(../img/page/02.png) no-repeat center;
  width: 58%;
  margin-bottom: 2%;
}
.btn03 {
  height: 250px;
  background: url(../img/page/03.png) no-repeat center;
  width: 58%;
  margin-bottom: 2%;
}
.btn04 {
  height: 250px;
  background: url(../img/page/04.png) no-repeat center;
  width: 40%;
  margin-bottom: 2%;
}
.btn05 {
  height: 250px;
  background: url(../img/page/05.png) no-repeat center;
  width: 40%;
  margin-bottom: 2%;
}
.btn06 {
  height: 250px;
  background: url(../img/page/06.png) no-repeat center;
  width: 58%;
  margin-bottom: 2%;
}
@media screen and (max-width: 750px) {
  .btn01 {
    width: 100%;
  }
  .btn02 {
    width: 100%;
  }
  .btn03 {
    width: 100%;
  }
  .btn04 {
    width: 100%;
  }
  .btn05 {
    width: 100%;
  }
  .btn06 {
    width: 100%;
  }
}
.btn {
  position: relative;
}
.btn h3 {
  text-align: center;
  color: #FFFFFF;
  font-size: 25px;
  margin-top: 50px;
  text-shadow: 1px 1px 1px #000000;
}
.btn p {
  color: #FFFFFF;
  text-shadow: 1px 1px 1px #000000;
  font-size: 12px;
}
.btn_j {
  position: relative;
}
.btn_j h3 {
  text-align: center;
  color: #FFFFFF;
  font-size: 25px;
  margin-top: 80px;
  text-shadow: 1px 1px 1px #000000;
}
.btn_j p {
  color: #FFFFFF;
  text-shadow: 1px 1px 1px #000000;
  font-size: 12px;
}
.btn_r {
  position: relative;
}
.btn_r h3 {
  text-align: center;
  color: #FFFFFF;
  font-size: 25px;
  margin-top: 60px;
  text-shadow: 1px 1px 1px #000000;
}
.btn_r p {
  color: #FFFFFF;
  text-shadow: 1px 1px 1px #000000;
  font-size: 12px;
  text-align: center;
}
.detailbtn {
  position: absolute;
  bottom: 10px;
  left: 50%;
  margin-left: -50px;
  text-align: center;
  width: 100px;
  height: 24px;
  text-shadow: 1px 1px 1px #000000;
}
.detailbtn img {
  width: 100px;
  height: 24px;
}
.detailbtn02 {
  position: absolute;
  bottom: 10px;
  left: 50%;
  margin-left: -50px;
  text-align: center;
  width: 100px;
  height: 24px;
  text-shadow: 1px 1px 1px #000000;
}
.detailbtn02 img {
  width: 100px;
  height: 24px;
}
.Halfbox {
  margin: 5px;
  border: solid 1px #CBCBCB;
  height: 250px;
}
.Halfbox h3 {
  text-align: center;
  line-height: 70px;
  font-size: 25px;
  font-weight: normal;
  color: #FFFFFF;
}
.Halfbox p {
  font-size: 14px;
  line-height: 26px;
  width: auto;
  box-sizing: border-box;
  padding: 10px 20px 10px;
}
.border-- {
  border: solid 1px #CBCBCB;
  padding: 20px 20px 10px;
  box-sizing: border-box;
  margin-bottom: 20px;
}
.noborder-- {
  padding: 20px 0px 10px;
  box-sizing: border-box;
  margin-bottom: 20px;
  padding-left: 5px;
}
.dsn01 {
  background: #CBCBCB !important;
  text-indent: 20px !important;
  line-height: 40px !important;
  font-size: 20px !important;
  color: #FFFFFF !important;
}
.dsn02 {
  text-indent: 20px !important;
  line-height: 100px !important;
  font-size: 25px !important;
  color: #FFFFFF !important;
}
table.dsn03 th {
  background: #3C5DAF;
  color: #FFFFFF;
}
table.dsn03 td {
  text-align: right;
}
.dsn04 {
  margin-left: 10px;
  box-sizing: border-box;
  background: #FFFFFF;
  margin-bottom: -1px;
  padding: 20px;
}
table.dsn05 th {
  background: #976693;
  color: #FFFFFF;
}
table.dsn06 th {
  background: #7D80B2;
  color: #FFFFFF;
}
table.dsn07 th {
  background: #7CA04F;
  color: #FFFFFF;
}
table.dsn08 th {
  background: #3A9F90;
  color: #FFFFFF;
}
.dsn09 {
  text-indent: 20px !important;
  line-height: 100px !important;
  font-size: 25px !important;
  color: #FFFFFF !important;
  height: 60px !important;
  line-height: 60px !important;
}
h5.dsn10 {
  color: #976693 !important;
}
table.dsn10 td {
  background: #976693 !important;
  color: #FFFFFF !important;
  text-align: right !important;
  width: 50% !important;
}
h5.dsn11 {
  color: #7D80B2 !important;
}
table.dsn11 td {
  background: #7D80B2 !important;
  color: #FFFFFF !important;
  text-align: right !important;
  width: 50% !important;
}
h5.dsn12 {
  color: #7CA04F !important;
}
table.dsn12 td {
  background: #7CA04F !important;
  color: #FFFFFF !important;
  text-align: right !important;
  width: 50% !important;
}
h5.dsn13 {
  color: #3A9F90;
}
table.dsn13 td {
  background: #3A9F90;
  color: #FFFFFF;
  text-align: right;
  width: 50%;
}
h3.dsn14 {
  font-weight: bold;
  text-indent: 0px;
}
div.dsn14 {
  padding: 0 20px;
}
table.dsn15 {
  border: 3px solid #FFFFFF;
}
table.dsn15 tr {
  border: 3px solid #FFFFFF;
}
table.dsn15 td {
  bborder: 3px solid #FFFFFF;
  background: #E8E8E8;
}
table.dsn15 th {
  background: #3C82AF;
  color: #FFFFFF;
  width: 150px;
  border: 3px solid #FFFFFF;
}
h3.dsn16 {
  font-weight: bold;
  text-indent: 20px;
}
h5.dsn17 {
  text-indent: 20px;
  line-height: 30px;
  height: 30px;
  font-size: 20px;
  box-sizing: border-box;
  color: #FFFFFF;
  background: #CBCBCB;
}
h3.dsn18 {
  font-size: 25px;
  line-height: 70px;
  height: 70px;
  text-align: center;
  box-sizing: border-box;
  color: #FFFFFF;
  background: #3C82AF;
}
table.dsn18 td {
  background: #3C82AF;
  color: #FFFFFF;
  width: 50%;
  text-align: right;
}
table.dsn18 {
  margin-bottom: 10px;
}
h3.dsn19 {
  font-weight: normal;
  text-indent: 20px;
  border-top: 1px solid #CBCBCB;
  padding-top: 10px;
  width: 90%;
}
h3.dsn20 {
  font-size: 25px;
  line-height: 70px;
  height: 70px;
  text-align: center;
  box-sizing: border-box;
  color: #FFFFFF;
  background: #3C82AF;
  border-top: 5px solid #0B6A9C;
}
h3.dsn21 {
  font-size: 25px;
  line-height: 70px;
  height: 70px;
  text-align: center;
  box-sizing: border-box;
  color: #FFFFFF;
  background: #DDA0A2;
  border-top: 5px solid #D48385;
}
@media screen and (max-width: 600px) {
  h3.dsn20 {
    font-size: 18px;
    line-height: 25px;
    height: auto;
  }
  h3.dsn21 {
    font-size: 18px;
    line-height: 25px;
    height: auto;
  }
}
.dsn22 {
  background: url(../img/page/50.png) no-repeat center bottom;
  height: 190px;
  text-align: center;
}
.dsn23 {
  width: 85%;
}
.dsn24 {
  width: 15%;
}
@media screen and (max-width: 600px) {
  .dsn23 {
    width: 70%;
  }
  .dsn24 {
    width: 30%;
  }
}
@media screen and (max-width: 400px) {
  .dsn23 {
    width: 100%;
  }
  .dsn24 {
    width: 50%;
    margin: 0 auto;
    float: none;
  }
}
.dsn25 {
  padding: 5px;
  margin-top: 10px;
  text-align: center;
}
.dsn25 img {
  max-width: 100%;
}
.dsn26 {
  padding: 5px;
}
@media screen and (max-width: 640px) {
  .dsn25 {
    width: 500px !important;
    padding-bottom: 20px;
    margin: 0 auto !important;
    float: none;
  }
  .dsn26 {
    width: 500px;
    margin: 0 auto;
    float: none;
  }
}
@media screen and (max-width: 500px) {
  .dsn25 {
    width: 100% !important;
    padding-bottom: 20px;
    margin: 0 auto !important;
    float: none;
  }
  .dsn26 {
    width: 100%;
    margin: 0 auto;
    float: none;
  }
}
.dsn27 {
  color: #150067 !important;
}
.sns {
  padding: 5px;
}
.space {
  height: 50px;
  clear: both;
  width: 100%;
}
.wrapper {
  height: auto; // 高さを画面いっぱいに指定する。(vhが効かない場合の対策)
  position: relative; //横幅がウィンドウズサイズの縦幅よりもはみ出てしまう場合に、左にずらすために指定。
  width: 100%; // 横幅もいっぱいに。
}
#video {
  background: url('../video/video_bg.jpg') no-repeat; // 動画が再生を始めるまで、cssのほうでも背景を設定します。
  background-attachment: fixed; // 中央揃えになるように、fixed。
  background-position: center center; // positionも中央に。
  background-size: cover; // 画面サイズに応じてサイズを可変するように設定。
  left: 0;
  // wrapperのサイズに応じて、leftの位置をjQueryで指定するため、positionはabsoluteにします。
  position: absolute;
  top: 0;
  // z-indexは調整してください。
  z-index: 1;
}
/*ボックス全体*/
.accbox {
  padding: 0;
}
/*ラベル*/
.accbox label {
  display: block;
  margin: 1.5px 0;
  padding: 11px 12px;
  color: #FFFFFF;
  background: #FF9B2F;
  cursor: pointer;
  transition: all 0.5s;
}
/*ラベルホバー時*/
.accbox label:hover {
  background: #CBCBCB;
}
/*チェックは隠す*/
.accbox input {
  display: none;
}
/*中身を非表示にしておく*/
.accbox .accshow {
  height: 0;
  padding: 0;
  overflow: hidden;
  opacity: 0;
  transition: 0.8s;
}
/*クリックで中身表示*/
.cssacc:checked + .accshow {
  height: auto;
  padding: 5px;
  background: #FFFFFF;
  opacity: 1;
}
.bg01 {
  background: #3C82AF !important;
}
.bg02 {
  background: #6B8D2A !important;
}
}
.bg03 {
  background: #A85BAF !important;
}
.bg04 {
  background: #DF7642 !important;
}
.bg05 {
  background: #3C5DAF !important;
}
.bg06 {
  background: #AE9D24 !important;
}
.bg07 {
  background: #DF7642 !important;
}
.bg08 {
  background: #625493 !important;
}
.bg09 {
  background: #1D807D !important;
}
.bg10 {
  background: #976693 !important;
}
.bg11 {
  background: #7D80B2 !important;
}
.bg12 {
  background: #7CA04F !important;
}
.bg13 {
  background: #3A9F90 !important;
}
.bg14 {
  background: #FFFFFF !important;
}
.bg15 {
  background: #5480C5 !important;
}
.bg15_a {
  background: url(../img/icon/arrow.png) no-repeat right center, #5480C5 !important;
}
.bg16 {
  background: #AE6ACA !important;
}
.bg16_a {
  background: url(../img/icon/arrow.png) no-repeat right center, #AE6ACA !important;
}
.bg17 {
  background: #BD9A45 !important;
}
.bg17_a {
  background: url(../img/icon/arrow.png) no-repeat right center, #BD9A45 !important;
}
.bg18_a {
  background: url(../img/icon/arrow.png) no-repeat right center, #FF9B2F !important;
}
.bg19 {
  background: #973E93 !important;
}
.bg20 {
  background: #4D5998 !important;
}
.bg21 {
  background: #608D29 !important;
}
.bg22 {
  background: #007F77 !important;
}
.swiper-container {
  width: 100%;
  height: auto;
  padding: 0px;
}
.swiper-slide {
  background-position: center;
  background-size: cover;
  width: 100%;
  height: 700px;
}
@media screen and (max-width: 600px) {
  .swiper-slide {
    height: 300px;
  }
}
@media screen and (max-width: 500px) {
  .swiper-slide {
    height: 250px;
  }
}
@media screen and (max-width: 400px) {
  .swiper-slide {
    height: 200px;
  }
}