@charset "UTF-8";
@font-face {
  font-family: 'Antro Vectra Bold';
  src: url("../fonts/Antro_Vectra_Bolder.otf");
}

@font-face {
  font-family: 'Antro Vectra';
  src: url("../fonts/Antro_Vectra.otf");
}

@font-face {
  font-family: 'A OTF Midashi Go MB31 Pro';
  src: url("../fonts/A-OTF_Midashi_Go_MB31_Pro.otf");
}

.mt0 {
  margin-top: 0rem !important;
}

.mr0 {
  margin-right: 0rem !important;
}

.mb0 {
  margin-bottom: 0rem !important;
}

.ml0 {
  margin-left: 0rem !important;
}

.pt0 {
  padding-top: 0rem !important;
}

.pr0 {
  padding-right: 0rem !important;
}

.pb0 {
  padding-bottom: 0rem !important;
}

.pl0 {
  padding-left: 0rem !important;
}

.mt5 {
  margin-top: 0.5rem !important;
}

.mr5 {
  margin-right: 0.5rem !important;
}

.mb5 {
  margin-bottom: 0.5rem !important;
}

.ml5 {
  margin-left: 0.5rem !important;
}

.pt5 {
  padding-top: 0.5rem !important;
}

.pr5 {
  padding-right: 0.5rem !important;
}

.pb5 {
  padding-bottom: 0.5rem !important;
}

.pl5 {
  padding-left: 0.5rem !important;
}

.mt10 {
  margin-top: 1rem !important;
}

.mr10 {
  margin-right: 1rem !important;
}

.mb10 {
  margin-bottom: 1rem !important;
}

.ml10 {
  margin-left: 1rem !important;
}

.pt10 {
  padding-top: 1rem !important;
}

.pr10 {
  padding-right: 1rem !important;
}

.pb10 {
  padding-bottom: 1rem !important;
}

.pl10 {
  padding-left: 1rem !important;
}

.mt15 {
  margin-top: 1.5rem !important;
}

.mr15 {
  margin-right: 1.5rem !important;
}

.mb15 {
  margin-bottom: 1.5rem !important;
}

.ml15 {
  margin-left: 1.5rem !important;
}

.pt15 {
  padding-top: 1.5rem !important;
}

.pr15 {
  padding-right: 1.5rem !important;
}

.pb15 {
  padding-bottom: 1.5rem !important;
}

.pl15 {
  padding-left: 1.5rem !important;
}

.mt20 {
  margin-top: 2rem !important;
}

.mr20 {
  margin-right: 2rem !important;
}

.mb20 {
  margin-bottom: 2rem !important;
}

.ml20 {
  margin-left: 2rem !important;
}

.pt20 {
  padding-top: 2rem !important;
}

.pr20 {
  padding-right: 2rem !important;
}

.pb20 {
  padding-bottom: 2rem !important;
}

.pl20 {
  padding-left: 2rem !important;
}

.mt25 {
  margin-top: 2.5rem !important;
}

.mr25 {
  margin-right: 2.5rem !important;
}

.mb25 {
  margin-bottom: 2.5rem !important;
}

.ml25 {
  margin-left: 2.5rem !important;
}

.pt25 {
  padding-top: 2.5rem !important;
}

.pr25 {
  padding-right: 2.5rem !important;
}

.pb25 {
  padding-bottom: 2.5rem !important;
}

.pl25 {
  padding-left: 2.5rem !important;
}

.mt30 {
  margin-top: 3rem !important;
}

.mr30 {
  margin-right: 3rem !important;
}

.mb30 {
  margin-bottom: 3rem !important;
}

.ml30 {
  margin-left: 3rem !important;
}

.pt30 {
  padding-top: 3rem !important;
}

.pr30 {
  padding-right: 3rem !important;
}

.pb30 {
  padding-bottom: 3rem !important;
}

.pl30 {
  padding-left: 3rem !important;
}

.mt35 {
  margin-top: 3.5rem !important;
}

.mr35 {
  margin-right: 3.5rem !important;
}

.mb35 {
  margin-bottom: 3.5rem !important;
}

.ml35 {
  margin-left: 3.5rem !important;
}

.pt35 {
  padding-top: 3.5rem !important;
}

.pr35 {
  padding-right: 3.5rem !important;
}

.pb35 {
  padding-bottom: 3.5rem !important;
}

.pl35 {
  padding-left: 3.5rem !important;
}

.mt40 {
  margin-top: 4rem !important;
}

.mr40 {
  margin-right: 4rem !important;
}

.mb40 {
  margin-bottom: 4rem !important;
}

.ml40 {
  margin-left: 4rem !important;
}

.pt40 {
  padding-top: 4rem !important;
}

.pr40 {
  padding-right: 4rem !important;
}

.pb40 {
  padding-bottom: 4rem !important;
}

.pl40 {
  padding-left: 4rem !important;
}

.mt45 {
  margin-top: 4.5rem !important;
}

.mr45 {
  margin-right: 4.5rem !important;
}

.mb45 {
  margin-bottom: 4.5rem !important;
}

.ml45 {
  margin-left: 4.5rem !important;
}

.pt45 {
  padding-top: 4.5rem !important;
}

.pr45 {
  padding-right: 4.5rem !important;
}

.pb45 {
  padding-bottom: 4.5rem !important;
}

.pl45 {
  padding-left: 4.5rem !important;
}

.mt50 {
  margin-top: 5rem !important;
}

.mr50 {
  margin-right: 5rem !important;
}

.mb50 {
  margin-bottom: 5rem !important;
}

.ml50 {
  margin-left: 5rem !important;
}

.pt50 {
  padding-top: 5rem !important;
}

.pr50 {
  padding-right: 5rem !important;
}

.pb50 {
  padding-bottom: 5rem !important;
}

.pl50 {
  padding-left: 5rem !important;
}

.mt55 {
  margin-top: 5.5rem !important;
}

.mr55 {
  margin-right: 5.5rem !important;
}

.mb55 {
  margin-bottom: 5.5rem !important;
}

.ml55 {
  margin-left: 5.5rem !important;
}

.pt55 {
  padding-top: 5.5rem !important;
}

.pr55 {
  padding-right: 5.5rem !important;
}

.pb55 {
  padding-bottom: 5.5rem !important;
}

.pl55 {
  padding-left: 5.5rem !important;
}

.mt60 {
  margin-top: 6rem !important;
}

.mr60 {
  margin-right: 6rem !important;
}

.mb60 {
  margin-bottom: 6rem !important;
}

.ml60 {
  margin-left: 6rem !important;
}

.pt60 {
  padding-top: 6rem !important;
}

.pr60 {
  padding-right: 6rem !important;
}

.pb60 {
  padding-bottom: 6rem !important;
}

.pl60 {
  padding-left: 6rem !important;
}

.mt65 {
  margin-top: 6.5rem !important;
}

.mr65 {
  margin-right: 6.5rem !important;
}

.mb65 {
  margin-bottom: 6.5rem !important;
}

.ml65 {
  margin-left: 6.5rem !important;
}

.pt65 {
  padding-top: 6.5rem !important;
}

.pr65 {
  padding-right: 6.5rem !important;
}

.pb65 {
  padding-bottom: 6.5rem !important;
}

.pl65 {
  padding-left: 6.5rem !important;
}

.mt70 {
  margin-top: 7rem !important;
}

.mr70 {
  margin-right: 7rem !important;
}

.mb70 {
  margin-bottom: 7rem !important;
}

.ml70 {
  margin-left: 7rem !important;
}

.pt70 {
  padding-top: 7rem !important;
}

.pr70 {
  padding-right: 7rem !important;
}

.pb70 {
  padding-bottom: 7rem !important;
}

.pl70 {
  padding-left: 7rem !important;
}

.mt75 {
  margin-top: 7.5rem !important;
}

.mr75 {
  margin-right: 7.5rem !important;
}

.mb75 {
  margin-bottom: 7.5rem !important;
}

.ml75 {
  margin-left: 7.5rem !important;
}

.pt75 {
  padding-top: 7.5rem !important;
}

.pr75 {
  padding-right: 7.5rem !important;
}

.pb75 {
  padding-bottom: 7.5rem !important;
}

.pl75 {
  padding-left: 7.5rem !important;
}

.mt80 {
  margin-top: 8rem !important;
}

.mr80 {
  margin-right: 8rem !important;
}

.mb80 {
  margin-bottom: 8rem !important;
}

.ml80 {
  margin-left: 8rem !important;
}

.pt80 {
  padding-top: 8rem !important;
}

.pr80 {
  padding-right: 8rem !important;
}

.pb80 {
  padding-bottom: 8rem !important;
}

.pl80 {
  padding-left: 8rem !important;
}

.mt85 {
  margin-top: 8.5rem !important;
}

.mr85 {
  margin-right: 8.5rem !important;
}

.mb85 {
  margin-bottom: 8.5rem !important;
}

.ml85 {
  margin-left: 8.5rem !important;
}

.pt85 {
  padding-top: 8.5rem !important;
}

.pr85 {
  padding-right: 8.5rem !important;
}

.pb85 {
  padding-bottom: 8.5rem !important;
}

.pl85 {
  padding-left: 8.5rem !important;
}

.mt90 {
  margin-top: 9rem !important;
}

.mr90 {
  margin-right: 9rem !important;
}

.mb90 {
  margin-bottom: 9rem !important;
}

.ml90 {
  margin-left: 9rem !important;
}

.pt90 {
  padding-top: 9rem !important;
}

.pr90 {
  padding-right: 9rem !important;
}

.pb90 {
  padding-bottom: 9rem !important;
}

.pl90 {
  padding-left: 9rem !important;
}

.mt95 {
  margin-top: 9.5rem !important;
}

.mr95 {
  margin-right: 9.5rem !important;
}

.mb95 {
  margin-bottom: 9.5rem !important;
}

.ml95 {
  margin-left: 9.5rem !important;
}

.pt95 {
  padding-top: 9.5rem !important;
}

.pr95 {
  padding-right: 9.5rem !important;
}

.pb95 {
  padding-bottom: 9.5rem !important;
}

.pl95 {
  padding-left: 9.5rem !important;
}

.mt100 {
  margin-top: 10rem !important;
}

.mr100 {
  margin-right: 10rem !important;
}

.mb100 {
  margin-bottom: 10rem !important;
}

.ml100 {
  margin-left: 10rem !important;
}

.pt100 {
  padding-top: 10rem !important;
}

.pr100 {
  padding-right: 10rem !important;
}

.pb100 {
  padding-bottom: 10rem !important;
}

.pl100 {
  padding-left: 10rem !important;
}

@media screen and (min-width: 769px) {
  .pc-mt0 {
    margin-top: 0rem !important;
  }
  .pc-mr0 {
    margin-right: 0rem !important;
  }
  .pc-mb0 {
    margin-bottom: 0rem !important;
  }
  .pc-ml0 {
    margin-left: 0rem !important;
  }
  .pc-pt0 {
    padding-top: 0rem !important;
  }
  .pc-pr0 {
    padding-right: 0rem !important;
  }
  .pc-pb0 {
    padding-bottom: 0rem !important;
  }
  .pc-pl0 {
    padding-left: 0rem !important;
  }
  .pc-mt5 {
    margin-top: 0.5rem !important;
  }
  .pc-mr5 {
    margin-right: 0.5rem !important;
  }
  .pc-mb5 {
    margin-bottom: 0.5rem !important;
  }
  .pc-ml5 {
    margin-left: 0.5rem !important;
  }
  .pc-pt5 {
    padding-top: 0.5rem !important;
  }
  .pc-pr5 {
    padding-right: 0.5rem !important;
  }
  .pc-pb5 {
    padding-bottom: 0.5rem !important;
  }
  .pc-pl5 {
    padding-left: 0.5rem !important;
  }
  .pc-mt10 {
    margin-top: 1rem !important;
  }
  .pc-mr10 {
    margin-right: 1rem !important;
  }
  .pc-mb10 {
    margin-bottom: 1rem !important;
  }
  .pc-ml10 {
    margin-left: 1rem !important;
  }
  .pc-pt10 {
    padding-top: 1rem !important;
  }
  .pc-pr10 {
    padding-right: 1rem !important;
  }
  .pc-pb10 {
    padding-bottom: 1rem !important;
  }
  .pc-pl10 {
    padding-left: 1rem !important;
  }
  .pc-mt15 {
    margin-top: 1.5rem !important;
  }
  .pc-mr15 {
    margin-right: 1.5rem !important;
  }
  .pc-mb15 {
    margin-bottom: 1.5rem !important;
  }
  .pc-ml15 {
    margin-left: 1.5rem !important;
  }
  .pc-pt15 {
    padding-top: 1.5rem !important;
  }
  .pc-pr15 {
    padding-right: 1.5rem !important;
  }
  .pc-pb15 {
    padding-bottom: 1.5rem !important;
  }
  .pc-pl15 {
    padding-left: 1.5rem !important;
  }
  .pc-mt20 {
    margin-top: 2rem !important;
  }
  .pc-mr20 {
    margin-right: 2rem !important;
  }
  .pc-mb20 {
    margin-bottom: 2rem !important;
  }
  .pc-ml20 {
    margin-left: 2rem !important;
  }
  .pc-pt20 {
    padding-top: 2rem !important;
  }
  .pc-pr20 {
    padding-right: 2rem !important;
  }
  .pc-pb20 {
    padding-bottom: 2rem !important;
  }
  .pc-pl20 {
    padding-left: 2rem !important;
  }
  .pc-mt25 {
    margin-top: 2.5rem !important;
  }
  .pc-mr25 {
    margin-right: 2.5rem !important;
  }
  .pc-mb25 {
    margin-bottom: 2.5rem !important;
  }
  .pc-ml25 {
    margin-left: 2.5rem !important;
  }
  .pc-pt25 {
    padding-top: 2.5rem !important;
  }
  .pc-pr25 {
    padding-right: 2.5rem !important;
  }
  .pc-pb25 {
    padding-bottom: 2.5rem !important;
  }
  .pc-pl25 {
    padding-left: 2.5rem !important;
  }
  .pc-mt30 {
    margin-top: 3rem !important;
  }
  .pc-mr30 {
    margin-right: 3rem !important;
  }
  .pc-mb30 {
    margin-bottom: 3rem !important;
  }
  .pc-ml30 {
    margin-left: 3rem !important;
  }
  .pc-pt30 {
    padding-top: 3rem !important;
  }
  .pc-pr30 {
    padding-right: 3rem !important;
  }
  .pc-pb30 {
    padding-bottom: 3rem !important;
  }
  .pc-pl30 {
    padding-left: 3rem !important;
  }
  .pc-mt35 {
    margin-top: 3.5rem !important;
  }
  .pc-mr35 {
    margin-right: 3.5rem !important;
  }
  .pc-mb35 {
    margin-bottom: 3.5rem !important;
  }
  .pc-ml35 {
    margin-left: 3.5rem !important;
  }
  .pc-pt35 {
    padding-top: 3.5rem !important;
  }
  .pc-pr35 {
    padding-right: 3.5rem !important;
  }
  .pc-pb35 {
    padding-bottom: 3.5rem !important;
  }
  .pc-pl35 {
    padding-left: 3.5rem !important;
  }
  .pc-mt40 {
    margin-top: 4rem !important;
  }
  .pc-mr40 {
    margin-right: 4rem !important;
  }
  .pc-mb40 {
    margin-bottom: 4rem !important;
  }
  .pc-ml40 {
    margin-left: 4rem !important;
  }
  .pc-pt40 {
    padding-top: 4rem !important;
  }
  .pc-pr40 {
    padding-right: 4rem !important;
  }
  .pc-pb40 {
    padding-bottom: 4rem !important;
  }
  .pc-pl40 {
    padding-left: 4rem !important;
  }
  .pc-mt45 {
    margin-top: 4.5rem !important;
  }
  .pc-mr45 {
    margin-right: 4.5rem !important;
  }
  .pc-mb45 {
    margin-bottom: 4.5rem !important;
  }
  .pc-ml45 {
    margin-left: 4.5rem !important;
  }
  .pc-pt45 {
    padding-top: 4.5rem !important;
  }
  .pc-pr45 {
    padding-right: 4.5rem !important;
  }
  .pc-pb45 {
    padding-bottom: 4.5rem !important;
  }
  .pc-pl45 {
    padding-left: 4.5rem !important;
  }
  .pc-mt50 {
    margin-top: 5rem !important;
  }
  .pc-mr50 {
    margin-right: 5rem !important;
  }
  .pc-mb50 {
    margin-bottom: 5rem !important;
  }
  .pc-ml50 {
    margin-left: 5rem !important;
  }
  .pc-pt50 {
    padding-top: 5rem !important;
  }
  .pc-pr50 {
    padding-right: 5rem !important;
  }
  .pc-pb50 {
    padding-bottom: 5rem !important;
  }
  .pc-pl50 {
    padding-left: 5rem !important;
  }
  .pc-mt55 {
    margin-top: 5.5rem !important;
  }
  .pc-mr55 {
    margin-right: 5.5rem !important;
  }
  .pc-mb55 {
    margin-bottom: 5.5rem !important;
  }
  .pc-ml55 {
    margin-left: 5.5rem !important;
  }
  .pc-pt55 {
    padding-top: 5.5rem !important;
  }
  .pc-pr55 {
    padding-right: 5.5rem !important;
  }
  .pc-pb55 {
    padding-bottom: 5.5rem !important;
  }
  .pc-pl55 {
    padding-left: 5.5rem !important;
  }
  .pc-mt60 {
    margin-top: 6rem !important;
  }
  .pc-mr60 {
    margin-right: 6rem !important;
  }
  .pc-mb60 {
    margin-bottom: 6rem !important;
  }
  .pc-ml60 {
    margin-left: 6rem !important;
  }
  .pc-pt60 {
    padding-top: 6rem !important;
  }
  .pc-pr60 {
    padding-right: 6rem !important;
  }
  .pc-pb60 {
    padding-bottom: 6rem !important;
  }
  .pc-pl60 {
    padding-left: 6rem !important;
  }
  .pc-mt65 {
    margin-top: 6.5rem !important;
  }
  .pc-mr65 {
    margin-right: 6.5rem !important;
  }
  .pc-mb65 {
    margin-bottom: 6.5rem !important;
  }
  .pc-ml65 {
    margin-left: 6.5rem !important;
  }
  .pc-pt65 {
    padding-top: 6.5rem !important;
  }
  .pc-pr65 {
    padding-right: 6.5rem !important;
  }
  .pc-pb65 {
    padding-bottom: 6.5rem !important;
  }
  .pc-pl65 {
    padding-left: 6.5rem !important;
  }
  .pc-mt70 {
    margin-top: 7rem !important;
  }
  .pc-mr70 {
    margin-right: 7rem !important;
  }
  .pc-mb70 {
    margin-bottom: 7rem !important;
  }
  .pc-ml70 {
    margin-left: 7rem !important;
  }
  .pc-pt70 {
    padding-top: 7rem !important;
  }
  .pc-pr70 {
    padding-right: 7rem !important;
  }
  .pc-pb70 {
    padding-bottom: 7rem !important;
  }
  .pc-pl70 {
    padding-left: 7rem !important;
  }
  .pc-mt75 {
    margin-top: 7.5rem !important;
  }
  .pc-mr75 {
    margin-right: 7.5rem !important;
  }
  .pc-mb75 {
    margin-bottom: 7.5rem !important;
  }
  .pc-ml75 {
    margin-left: 7.5rem !important;
  }
  .pc-pt75 {
    padding-top: 7.5rem !important;
  }
  .pc-pr75 {
    padding-right: 7.5rem !important;
  }
  .pc-pb75 {
    padding-bottom: 7.5rem !important;
  }
  .pc-pl75 {
    padding-left: 7.5rem !important;
  }
  .pc-mt80 {
    margin-top: 8rem !important;
  }
  .pc-mr80 {
    margin-right: 8rem !important;
  }
  .pc-mb80 {
    margin-bottom: 8rem !important;
  }
  .pc-ml80 {
    margin-left: 8rem !important;
  }
  .pc-pt80 {
    padding-top: 8rem !important;
  }
  .pc-pr80 {
    padding-right: 8rem !important;
  }
  .pc-pb80 {
    padding-bottom: 8rem !important;
  }
  .pc-pl80 {
    padding-left: 8rem !important;
  }
  .pc-mt85 {
    margin-top: 8.5rem !important;
  }
  .pc-mr85 {
    margin-right: 8.5rem !important;
  }
  .pc-mb85 {
    margin-bottom: 8.5rem !important;
  }
  .pc-ml85 {
    margin-left: 8.5rem !important;
  }
  .pc-pt85 {
    padding-top: 8.5rem !important;
  }
  .pc-pr85 {
    padding-right: 8.5rem !important;
  }
  .pc-pb85 {
    padding-bottom: 8.5rem !important;
  }
  .pc-pl85 {
    padding-left: 8.5rem !important;
  }
  .pc-mt90 {
    margin-top: 9rem !important;
  }
  .pc-mr90 {
    margin-right: 9rem !important;
  }
  .pc-mb90 {
    margin-bottom: 9rem !important;
  }
  .pc-ml90 {
    margin-left: 9rem !important;
  }
  .pc-pt90 {
    padding-top: 9rem !important;
  }
  .pc-pr90 {
    padding-right: 9rem !important;
  }
  .pc-pb90 {
    padding-bottom: 9rem !important;
  }
  .pc-pl90 {
    padding-left: 9rem !important;
  }
  .pc-mt95 {
    margin-top: 9.5rem !important;
  }
  .pc-mr95 {
    margin-right: 9.5rem !important;
  }
  .pc-mb95 {
    margin-bottom: 9.5rem !important;
  }
  .pc-ml95 {
    margin-left: 9.5rem !important;
  }
  .pc-pt95 {
    padding-top: 9.5rem !important;
  }
  .pc-pr95 {
    padding-right: 9.5rem !important;
  }
  .pc-pb95 {
    padding-bottom: 9.5rem !important;
  }
  .pc-pl95 {
    padding-left: 9.5rem !important;
  }
  .pc-mt100 {
    margin-top: 10rem !important;
  }
  .pc-mr100 {
    margin-right: 10rem !important;
  }
  .pc-mb100 {
    margin-bottom: 10rem !important;
  }
  .pc-ml100 {
    margin-left: 10rem !important;
  }
  .pc-pt100 {
    padding-top: 10rem !important;
  }
  .pc-pr100 {
    padding-right: 10rem !important;
  }
  .pc-pb100 {
    padding-bottom: 10rem !important;
  }
  .pc-pl100 {
    padding-left: 10rem !important;
  }
}

@media screen and (max-width: 768px) {
  .sp-mt0 {
    margin-top: 0rem !important;
  }
  .sp-mr0 {
    margin-right: 0rem !important;
  }
  .sp-mb0 {
    margin-bottom: 0rem !important;
  }
  .sp-ml0 {
    margin-left: 0rem !important;
  }
  .sp-pt0 {
    padding-top: 0rem !important;
  }
  .sp-pr0 {
    padding-right: 0rem !important;
  }
  .sp-pb0 {
    padding-bottom: 0rem !important;
  }
  .sp-pl0 {
    padding-left: 0rem !important;
  }
  .sp-mt5 {
    margin-top: 0.5rem !important;
  }
  .sp-mr5 {
    margin-right: 0.5rem !important;
  }
  .sp-mb5 {
    margin-bottom: 0.5rem !important;
  }
  .sp-ml5 {
    margin-left: 0.5rem !important;
  }
  .sp-pt5 {
    padding-top: 0.5rem !important;
  }
  .sp-pr5 {
    padding-right: 0.5rem !important;
  }
  .sp-pb5 {
    padding-bottom: 0.5rem !important;
  }
  .sp-pl5 {
    padding-left: 0.5rem !important;
  }
  .sp-mt10 {
    margin-top: 1rem !important;
  }
  .sp-mr10 {
    margin-right: 1rem !important;
  }
  .sp-mb10 {
    margin-bottom: 1rem !important;
  }
  .sp-ml10 {
    margin-left: 1rem !important;
  }
  .sp-pt10 {
    padding-top: 1rem !important;
  }
  .sp-pr10 {
    padding-right: 1rem !important;
  }
  .sp-pb10 {
    padding-bottom: 1rem !important;
  }
  .sp-pl10 {
    padding-left: 1rem !important;
  }
  .sp-mt15 {
    margin-top: 1.5rem !important;
  }
  .sp-mr15 {
    margin-right: 1.5rem !important;
  }
  .sp-mb15 {
    margin-bottom: 1.5rem !important;
  }
  .sp-ml15 {
    margin-left: 1.5rem !important;
  }
  .sp-pt15 {
    padding-top: 1.5rem !important;
  }
  .sp-pr15 {
    padding-right: 1.5rem !important;
  }
  .sp-pb15 {
    padding-bottom: 1.5rem !important;
  }
  .sp-pl15 {
    padding-left: 1.5rem !important;
  }
  .sp-mt20 {
    margin-top: 2rem !important;
  }
  .sp-mr20 {
    margin-right: 2rem !important;
  }
  .sp-mb20 {
    margin-bottom: 2rem !important;
  }
  .sp-ml20 {
    margin-left: 2rem !important;
  }
  .sp-pt20 {
    padding-top: 2rem !important;
  }
  .sp-pr20 {
    padding-right: 2rem !important;
  }
  .sp-pb20 {
    padding-bottom: 2rem !important;
  }
  .sp-pl20 {
    padding-left: 2rem !important;
  }
  .sp-mt25 {
    margin-top: 2.5rem !important;
  }
  .sp-mr25 {
    margin-right: 2.5rem !important;
  }
  .sp-mb25 {
    margin-bottom: 2.5rem !important;
  }
  .sp-ml25 {
    margin-left: 2.5rem !important;
  }
  .sp-pt25 {
    padding-top: 2.5rem !important;
  }
  .sp-pr25 {
    padding-right: 2.5rem !important;
  }
  .sp-pb25 {
    padding-bottom: 2.5rem !important;
  }
  .sp-pl25 {
    padding-left: 2.5rem !important;
  }
  .sp-mt30 {
    margin-top: 3rem !important;
  }
  .sp-mr30 {
    margin-right: 3rem !important;
  }
  .sp-mb30 {
    margin-bottom: 3rem !important;
  }
  .sp-ml30 {
    margin-left: 3rem !important;
  }
  .sp-pt30 {
    padding-top: 3rem !important;
  }
  .sp-pr30 {
    padding-right: 3rem !important;
  }
  .sp-pb30 {
    padding-bottom: 3rem !important;
  }
  .sp-pl30 {
    padding-left: 3rem !important;
  }
  .sp-mt35 {
    margin-top: 3.5rem !important;
  }
  .sp-mr35 {
    margin-right: 3.5rem !important;
  }
  .sp-mb35 {
    margin-bottom: 3.5rem !important;
  }
  .sp-ml35 {
    margin-left: 3.5rem !important;
  }
  .sp-pt35 {
    padding-top: 3.5rem !important;
  }
  .sp-pr35 {
    padding-right: 3.5rem !important;
  }
  .sp-pb35 {
    padding-bottom: 3.5rem !important;
  }
  .sp-pl35 {
    padding-left: 3.5rem !important;
  }
  .sp-mt40 {
    margin-top: 4rem !important;
  }
  .sp-mr40 {
    margin-right: 4rem !important;
  }
  .sp-mb40 {
    margin-bottom: 4rem !important;
  }
  .sp-ml40 {
    margin-left: 4rem !important;
  }
  .sp-pt40 {
    padding-top: 4rem !important;
  }
  .sp-pr40 {
    padding-right: 4rem !important;
  }
  .sp-pb40 {
    padding-bottom: 4rem !important;
  }
  .sp-pl40 {
    padding-left: 4rem !important;
  }
  .sp-mt45 {
    margin-top: 4.5rem !important;
  }
  .sp-mr45 {
    margin-right: 4.5rem !important;
  }
  .sp-mb45 {
    margin-bottom: 4.5rem !important;
  }
  .sp-ml45 {
    margin-left: 4.5rem !important;
  }
  .sp-pt45 {
    padding-top: 4.5rem !important;
  }
  .sp-pr45 {
    padding-right: 4.5rem !important;
  }
  .sp-pb45 {
    padding-bottom: 4.5rem !important;
  }
  .sp-pl45 {
    padding-left: 4.5rem !important;
  }
  .sp-mt50 {
    margin-top: 5rem !important;
  }
  .sp-mr50 {
    margin-right: 5rem !important;
  }
  .sp-mb50 {
    margin-bottom: 5rem !important;
  }
  .sp-ml50 {
    margin-left: 5rem !important;
  }
  .sp-pt50 {
    padding-top: 5rem !important;
  }
  .sp-pr50 {
    padding-right: 5rem !important;
  }
  .sp-pb50 {
    padding-bottom: 5rem !important;
  }
  .sp-pl50 {
    padding-left: 5rem !important;
  }
  .sp-mt55 {
    margin-top: 5.5rem !important;
  }
  .sp-mr55 {
    margin-right: 5.5rem !important;
  }
  .sp-mb55 {
    margin-bottom: 5.5rem !important;
  }
  .sp-ml55 {
    margin-left: 5.5rem !important;
  }
  .sp-pt55 {
    padding-top: 5.5rem !important;
  }
  .sp-pr55 {
    padding-right: 5.5rem !important;
  }
  .sp-pb55 {
    padding-bottom: 5.5rem !important;
  }
  .sp-pl55 {
    padding-left: 5.5rem !important;
  }
  .sp-mt60 {
    margin-top: 6rem !important;
  }
  .sp-mr60 {
    margin-right: 6rem !important;
  }
  .sp-mb60 {
    margin-bottom: 6rem !important;
  }
  .sp-ml60 {
    margin-left: 6rem !important;
  }
  .sp-pt60 {
    padding-top: 6rem !important;
  }
  .sp-pr60 {
    padding-right: 6rem !important;
  }
  .sp-pb60 {
    padding-bottom: 6rem !important;
  }
  .sp-pl60 {
    padding-left: 6rem !important;
  }
  .sp-mt65 {
    margin-top: 6.5rem !important;
  }
  .sp-mr65 {
    margin-right: 6.5rem !important;
  }
  .sp-mb65 {
    margin-bottom: 6.5rem !important;
  }
  .sp-ml65 {
    margin-left: 6.5rem !important;
  }
  .sp-pt65 {
    padding-top: 6.5rem !important;
  }
  .sp-pr65 {
    padding-right: 6.5rem !important;
  }
  .sp-pb65 {
    padding-bottom: 6.5rem !important;
  }
  .sp-pl65 {
    padding-left: 6.5rem !important;
  }
  .sp-mt70 {
    margin-top: 7rem !important;
  }
  .sp-mr70 {
    margin-right: 7rem !important;
  }
  .sp-mb70 {
    margin-bottom: 7rem !important;
  }
  .sp-ml70 {
    margin-left: 7rem !important;
  }
  .sp-pt70 {
    padding-top: 7rem !important;
  }
  .sp-pr70 {
    padding-right: 7rem !important;
  }
  .sp-pb70 {
    padding-bottom: 7rem !important;
  }
  .sp-pl70 {
    padding-left: 7rem !important;
  }
  .sp-mt75 {
    margin-top: 7.5rem !important;
  }
  .sp-mr75 {
    margin-right: 7.5rem !important;
  }
  .sp-mb75 {
    margin-bottom: 7.5rem !important;
  }
  .sp-ml75 {
    margin-left: 7.5rem !important;
  }
  .sp-pt75 {
    padding-top: 7.5rem !important;
  }
  .sp-pr75 {
    padding-right: 7.5rem !important;
  }
  .sp-pb75 {
    padding-bottom: 7.5rem !important;
  }
  .sp-pl75 {
    padding-left: 7.5rem !important;
  }
  .sp-mt80 {
    margin-top: 8rem !important;
  }
  .sp-mr80 {
    margin-right: 8rem !important;
  }
  .sp-mb80 {
    margin-bottom: 8rem !important;
  }
  .sp-ml80 {
    margin-left: 8rem !important;
  }
  .sp-pt80 {
    padding-top: 8rem !important;
  }
  .sp-pr80 {
    padding-right: 8rem !important;
  }
  .sp-pb80 {
    padding-bottom: 8rem !important;
  }
  .sp-pl80 {
    padding-left: 8rem !important;
  }
  .sp-mt85 {
    margin-top: 8.5rem !important;
  }
  .sp-mr85 {
    margin-right: 8.5rem !important;
  }
  .sp-mb85 {
    margin-bottom: 8.5rem !important;
  }
  .sp-ml85 {
    margin-left: 8.5rem !important;
  }
  .sp-pt85 {
    padding-top: 8.5rem !important;
  }
  .sp-pr85 {
    padding-right: 8.5rem !important;
  }
  .sp-pb85 {
    padding-bottom: 8.5rem !important;
  }
  .sp-pl85 {
    padding-left: 8.5rem !important;
  }
  .sp-mt90 {
    margin-top: 9rem !important;
  }
  .sp-mr90 {
    margin-right: 9rem !important;
  }
  .sp-mb90 {
    margin-bottom: 9rem !important;
  }
  .sp-ml90 {
    margin-left: 9rem !important;
  }
  .sp-pt90 {
    padding-top: 9rem !important;
  }
  .sp-pr90 {
    padding-right: 9rem !important;
  }
  .sp-pb90 {
    padding-bottom: 9rem !important;
  }
  .sp-pl90 {
    padding-left: 9rem !important;
  }
  .sp-mt95 {
    margin-top: 9.5rem !important;
  }
  .sp-mr95 {
    margin-right: 9.5rem !important;
  }
  .sp-mb95 {
    margin-bottom: 9.5rem !important;
  }
  .sp-ml95 {
    margin-left: 9.5rem !important;
  }
  .sp-pt95 {
    padding-top: 9.5rem !important;
  }
  .sp-pr95 {
    padding-right: 9.5rem !important;
  }
  .sp-pb95 {
    padding-bottom: 9.5rem !important;
  }
  .sp-pl95 {
    padding-left: 9.5rem !important;
  }
  .sp-mt100 {
    margin-top: 10rem !important;
  }
  .sp-mr100 {
    margin-right: 10rem !important;
  }
  .sp-mb100 {
    margin-bottom: 10rem !important;
  }
  .sp-ml100 {
    margin-left: 10rem !important;
  }
  .sp-pt100 {
    padding-top: 10rem !important;
  }
  .sp-pr100 {
    padding-right: 10rem !important;
  }
  .sp-pb100 {
    padding-bottom: 10rem !important;
  }
  .sp-pl100 {
    padding-left: 10rem !important;
  }
}

/*----------------------------------------------------------
    keyframes
----------------------------------------------------------*/
@-webkit-keyframes slider {
  0% {
    -webkit-transform: translateY(-25%);
            transform: translateY(-25%);
  }
  20% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  80% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  80.001% {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
  100% {
    -webkit-transform: translateY(-25%);
            transform: translateY(-25%);
  }
}
@-moz-keyframes slider {
  0% {
    -moz-transform: translateY(-25%);
         transform: translateY(-25%);
  }
  20% {
    -moz-transform: translateY(-100%);
         transform: translateY(-100%);
  }
  80% {
    -moz-transform: translateY(-100%);
         transform: translateY(-100%);
  }
  80.001% {
    -moz-transform: translateY(100%);
         transform: translateY(100%);
  }
  100% {
    -moz-transform: translateY(-25%);
         transform: translateY(-25%);
  }
}
@keyframes slider {
  0% {
    -webkit-transform: translateY(-25%);
       -moz-transform: translateY(-25%);
            transform: translateY(-25%);
  }
  20% {
    -webkit-transform: translateY(-100%);
       -moz-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  80% {
    -webkit-transform: translateY(-100%);
       -moz-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  80.001% {
    -webkit-transform: translateY(100%);
       -moz-transform: translateY(100%);
            transform: translateY(100%);
  }
  100% {
    -webkit-transform: translateY(-25%);
       -moz-transform: translateY(-25%);
            transform: translateY(-25%);
  }
}

@-webkit-keyframes forward {
  0% {
    background-position-x: 0;
  }
  40% {
    background-position-x: 2rem;
  }
  60% {
    background-position-x: 2rem;
  }
  60.1% {
    background-position-x: -2rem;
  }
  100% {
    background-position-x: 0;
  }
}

@-moz-keyframes forward {
  0% {
    background-position-x: 0;
  }
  40% {
    background-position-x: 2rem;
  }
  60% {
    background-position-x: 2rem;
  }
  60.1% {
    background-position-x: -2rem;
  }
  100% {
    background-position-x: 0;
  }
}

@keyframes forward {
  0% {
    background-position-x: 0;
  }
  40% {
    background-position-x: 2rem;
  }
  60% {
    background-position-x: 2rem;
  }
  60.1% {
    background-position-x: -2rem;
  }
  100% {
    background-position-x: 0;
  }
}

@-webkit-keyframes menu {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  50% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  50.001% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@-moz-keyframes menu {
  0% {
    -moz-transform: translateX(0);
         transform: translateX(0);
  }
  50% {
    -moz-transform: translateX(100%);
         transform: translateX(100%);
  }
  50.001% {
    -moz-transform: translateX(-100%);
         transform: translateX(-100%);
  }
  100% {
    -moz-transform: translateX(0);
         transform: translateX(0);
  }
}

@keyframes menu {
  0% {
    -webkit-transform: translateX(0);
       -moz-transform: translateX(0);
            transform: translateX(0);
  }
  50% {
    -webkit-transform: translateX(100%);
       -moz-transform: translateX(100%);
            transform: translateX(100%);
  }
  50.001% {
    -webkit-transform: translateX(-100%);
       -moz-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(0);
       -moz-transform: translateX(0);
            transform: translateX(0);
  }
}

@-webkit-keyframes closeMenu {
  0% {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
  50% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@-moz-keyframes closeMenu {
  0% {
    -moz-transform: translateY(100%);
         transform: translateY(100%);
  }
  50% {
    -moz-transform: translateY(0);
         transform: translateY(0);
  }
  100% {
    -moz-transform: translateY(0);
         transform: translateY(0);
  }
}

@keyframes closeMenu {
  0% {
    -webkit-transform: translateY(100%);
       -moz-transform: translateY(100%);
            transform: translateY(100%);
  }
  50% {
    -webkit-transform: translateY(0);
       -moz-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(0);
       -moz-transform: translateY(0);
            transform: translateY(0);
  }
}

.ttl_box_txt {
  overflow: hidden;
  display: inline-block;
}

.ttl_box_txt > span {
  position: relative;
  display: inline-block;
  -webkit-transform-style: preserve-3d;
}

.ttl_box_txt > span > span {
  display: block;
  position: relative;
  opacity: 0;
  top: 10rem;
  -webkit-transition-property: top, opacity;
  -moz-transition-property: top, opacity;
  transition-property: top, opacity;
  -webkit-transition-duration: 0.3s;
     -moz-transition-duration: 0.3s;
          transition-duration: 0.3s;
}

.ttl_box.active .ttl_box_txt > span > span {
  opacity: 1;
  top: 0;
}

.imgMarkUp {
  position: relative;
}

.imgMarkUp:before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: #fff;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform-origin: 100% 0;
     -moz-transform-origin: 100% 0;
      -ms-transform-origin: 100% 0;
          transform-origin: 100% 0;
  -webkit-transition: -webkit-transform .5s ease-out .3s;
  transition: -webkit-transform .5s ease-out .3s;
  -moz-transition: transform .5s ease-out .3s, -moz-transform .5s ease-out .3s;
  transition: transform .5s ease-out .3s;
  transition: transform .5s ease-out .3s, -webkit-transform .5s ease-out .3s, -moz-transform .5s ease-out .3s;
}

.imgMarkUp.delay_03:before {
  -webkit-transition-delay: .6s;
     -moz-transition-delay: .6s;
          transition-delay: .6s;
}

.imgMarkUp.delay_06:before {
  -webkit-transition-delay: .9s;
     -moz-transition-delay: .9s;
          transition-delay: .9s;
}

.imgMarkUp.active:before {
  -webkit-transform: scaleY(0);
     -moz-transform: scaleY(0);
      -ms-transform: scaleY(0);
          transform: scaleY(0);
}

.js-effect {
  -webkit-transition: opacity 1s ease,-webkit-transform 0.8s ease;
  transition: opacity 1s ease,-webkit-transform 0.8s ease;
  -moz-transition: transform 0.8s ease,opacity 1s ease,-moz-transform 0.8s ease;
  transition: transform 0.8s ease,opacity 1s ease;
  transition: transform 0.8s ease,opacity 1s ease,-webkit-transform 0.8s ease,-moz-transform 0.8s ease;
}

.delay_01 {
  -webkit-transition-delay: 0.1s;
     -moz-transition-delay: 0.1s;
          transition-delay: 0.1s;
}

.delay_02 {
  -webkit-transition-delay: 0.2s;
     -moz-transition-delay: 0.2s;
          transition-delay: 0.2s;
}

.delay_03 {
  -webkit-transition-delay: 0.3s;
     -moz-transition-delay: 0.3s;
          transition-delay: 0.3s;
}

.delay_04 {
  -webkit-transition-delay: 0.4s;
     -moz-transition-delay: 0.4s;
          transition-delay: 0.4s;
}

.delay_05 {
  -webkit-transition-delay: 0.5s;
     -moz-transition-delay: 0.5s;
          transition-delay: 0.5s;
}

.delay_06 {
  -webkit-transition-delay: 0.6s;
     -moz-transition-delay: 0.6s;
          transition-delay: 0.6s;
}

.delay_07 {
  -webkit-transition-delay: 0.7s;
     -moz-transition-delay: 0.7s;
          transition-delay: 0.7s;
}

.delay_08 {
  -webkit-transition-delay: 0.8s;
     -moz-transition-delay: 0.8s;
          transition-delay: 0.8s;
}

.delay_09 {
  -webkit-transition-delay: 0.9s;
     -moz-transition-delay: 0.9s;
          transition-delay: 0.9s;
}

.delay_10 {
  -webkit-transition-delay: 1s;
     -moz-transition-delay: 1s;
          transition-delay: 1s;
}

.delay_11 {
  -webkit-transition-delay: 1.1s;
     -moz-transition-delay: 1.1s;
          transition-delay: 1.1s;
}

.delay_12 {
  -webkit-transition-delay: 1.2s;
     -moz-transition-delay: 1.2s;
          transition-delay: 1.2s;
}

.delay_13 {
  -webkit-transition-delay: 1.3s;
     -moz-transition-delay: 1.3s;
          transition-delay: 1.3s;
}

.delay_14 {
  -webkit-transition-delay: 1.4s;
     -moz-transition-delay: 1.4s;
          transition-delay: 1.4s;
}

.delay_15 {
  -webkit-transition-delay: 1.5s;
     -moz-transition-delay: 1.5s;
          transition-delay: 1.5s;
}

.fadeIn {
  opacity: 0;
}

.fadeIn.active {
  opacity: 1;
}

.slideUp {
  -webkit-transform: translate3d(0, 10rem, 0);
     -moz-transform: translate3d(0, 10rem, 0);
          transform: translate3d(0, 10rem, 0);
  opacity: 0;
}

.slideUp.active {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
     -moz-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}

.slideToRight {
  -webkit-transform: translate3d(-10rem, 0, 0);
     -moz-transform: translate3d(-10rem, 0, 0);
          transform: translate3d(-10rem, 0, 0);
  opacity: 0;
}

.fadeInUp {
  opacity: 0;
  -webkit-transform: translate(0, 5rem);
     -moz-transform: translate(0, 5rem);
      -ms-transform: translate(0, 5rem);
          transform: translate(0, 5rem);
}

.fadeInUp.active {
  opacity: 1;
  -webkit-transform: translate(0, 0);
     -moz-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
}

.zoomIn {
  opacity: 0;
  -webkit-transform: scale(0.5);
     -moz-transform: scale(0.5);
      -ms-transform: scale(0.5);
          transform: scale(0.5);
}

.zoomIn.active {
  opacity: 1;
  -webkit-transform: scale(1);
     -moz-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}

/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Prevent adjustments of font size after orientation changes in IE and iOS.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 * 2. Add the correct display in IE.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  /* 1 */
  display: block;
}

/**
 * Add the correct display in IE 9-.
 */
audio,
canvas,
progress,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Add the correct display in IE 10-.
 * 1. Add the correct display in IE.
 */
template,
[hidden] {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */
}

/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */
a:active,
a:hover {
  outline-width: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000;
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none;
}

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -moz-box-sizing: content-box;
       box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}

/* Forms
   ========================================================================== */
/**
 * 1. Change font properties to `inherit` in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
select,
textarea {
  font: inherit;
  /* 1 */
  margin: 0;
  /* 2 */
}

/**
 * Restore the font weight unset by the previous rule.
 */
optgroup {
  font-weight: bold;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  -moz-box-sizing: border-box;
       box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type="checkbox"],
[type="radio"] {
  -moz-box-sizing: border-box;
       box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on OS X.
 */
[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Correct the text style of placeholders in Chrome, Edge, and Safari.
 */
::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

html {
  font-size: 62.5%;
}

@media screen and (max-width: 768px) {
  html {
    font-size: 2.66666667vw;
  }
}

body {
  font-family: "YuGothic", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", Meiryo, "MS PGothic", sans-serif;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: .08em;
  color: #707070;
  overflow-wrap: break-word;
}

@media screen and (max-width: 768px) {
  body {
    font-size: 1.4rem;
  }
}

a {
  color: inherit;
  text-decoration: none;
  -webkit-transition-duration: 0.3s;
     -moz-transition-duration: 0.3s;
          transition-duration: 0.3s;
}

a:hover {
  text-decoration: none;
}

a:focus {
  outline: none;
  text-decoration: none;
}

ul,
ol {
  margin: 0;
  padding: 0;
}

ul li,
ol li {
  list-style: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700;
  margin: 0;
}

p {
  margin: 0px 0px 30px 0px;
  padding: 0;
}

p:last-child {
  margin-bottom: 0px;
}

@media screen and (max-width: 768px) {
  p {
    margin: 0 0 4vw 0;
  }
}

figure {
  margin: 0;
  padding: 0;
  line-height: 0;
}

input[type="submit"] {
  border: none;
  -webkit-transition-duration: 0.2s;
     -moz-transition-duration: 0.2s;
          transition-duration: 0.2s;
}

table {
  border-spacing: inherit;
  border-collapse: collapse;
}

dl,
dt,
dd {
  margin: 0;
  padding: 0;
}

* {
  -moz-box-sizing: border-box;
       box-sizing: border-box;
  word-break: break-word;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

/* clearfix (micro) */
.clearfix:before,
.clearfix:after {
  content: ' ';
  display: table;
}

.clearfix:after {
  clear: both;
}

/* For IE 6/7 only */
.clearfix {
  *zoom: 1;
}

div,
p {
  /*word-break: break-all;*/
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video,
nav,
picture {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

ul,
ol,
li {
  list-style: none;
}

.page-main {
  display: block;
  position: relative;
}

.js-view {
  opacity: 0;
  -webkit-transform: translate(0, 20px);
     -moz-transform: translate(0, 20px);
      -ms-transform: translate(0, 20px);
          transform: translate(0, 20px);
  -webkit-transition: all 0.8s;
  -moz-transition: all 0.8s;
  transition: all 0.8s;
}

.js-view.fadein {
  opacity: 1;
  -webkit-transform: translate(0, 0);
     -moz-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
}

#wrapper {
  overflow: hidden;
}

@media screen and (min-width: 769px) {
  #wrapper {
    min-width: 120rem;
  }
}

.MissingWH {
  position: absolute;
  overflow: hidden;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 1;
  background: #707070;
}

.MissingWH__wrap {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 100%;
}

.MissingWH img {
  position: absolute;
  left: 0;
  top: 0;
  margin: 0;
  width: auto;
  display: none;
  height: auto;
  min-width: 100%;
  min-height: 100%;
  max-height: none;
  max-width: none;
  z-index: 1;
  opacity: 0;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  -webkit-animation: fadeInImages 3s ease forwards;
     -moz-animation: fadeInImages 3s ease forwards;
          animation: fadeInImages 3s ease forwards;
}

@media screen and (min-width: 769px) {
  .sp {
    display: none !important;
  }
  a[href^=tel] {
    pointer-events: none;
    text-decoration: none;
    opacity: 1 !important;
    cursor: default !important;
  }
}

@media screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
}

body.open {
  overflow: hidden;
}

.align-center {
  text-align: center;
}

.align-right {
  text-align: right;
}

.c-white {
  color: #fff;
}

.c-red {
  color: #FF1717;
}

.font-en {
  font-family: "Thasadith", sans-serif;
}

.fw-bold {
  font-weight: bold;
}

.inner {
  max-width: 109rem;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .inner {
    padding: 0 3rem;
  }
}

.row {
  max-width: 95.5rem;
  margin: 0 auto;
  padding: 0 2rem;
}

@media screen and (max-width: 768px) {
  .row {
    padding: 0 3rem;
  }
}

@media screen and (max-width: 768px) {
  .inner {
    max-width: 100%;
  }
}

.p-main {
  padding: 10rem 0 18.5rem;
}

.fit {
  font-family: "object-fit: cover;";
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.loading {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
  z-index: 1000;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
     -moz-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.loading:after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: #fff;
  z-index: -1;
  -webkit-transition: -webkit-transform .8s ease-out;
  transition: -webkit-transform .8s ease-out;
  -moz-transition: transform .8s ease-out, -moz-transform .8s ease-out;
  transition: transform .8s ease-out;
  transition: transform .8s ease-out, -webkit-transform .8s ease-out, -moz-transform .8s ease-out;
  -webkit-transform-origin: 100% 0;
     -moz-transform-origin: 100% 0;
      -ms-transform-origin: 100% 0;
          transform-origin: 100% 0;
}

.loading .load_img {
  display: block;
  width: 24.4rem;
  overflow: hidden;
  -webkit-transition: opacity .3s ease-out;
  -moz-transition: opacity .3s ease-out;
  transition: opacity .3s ease-out;
}

.loading .load_img img {
  display: block;
  width: 100%;
  -webkit-transition: -webkit-transform .3s ease-out;
  transition: -webkit-transform .3s ease-out;
  -moz-transition: transform .3s ease-out, -moz-transform .3s ease-out;
  transition: transform .3s ease-out;
  transition: transform .3s ease-out, -webkit-transform .3s ease-out, -moz-transform .3s ease-out;
  -webkit-transform: translateY(100%);
     -moz-transform: translateY(100%);
      -ms-transform: translateY(100%);
          transform: translateY(100%);
}

.loading.loaded .load_img img {
  -webkit-transform: translateY(0);
     -moz-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}

.loading.loadHidden {
  visibility: hidden;
  opacity: 0;
  -webkit-transition: opacity 0s ease 1s, visibility 0s ease 1s;
  -moz-transition: opacity 0s ease 1s, visibility 0s ease 1s;
  transition: opacity 0s ease 1s, visibility 0s ease 1s;
}

.loading.loadHidden .load_img img {
  -webkit-transform: translateY(-100%);
     -moz-transform: translateY(-100%);
      -ms-transform: translateY(-100%);
          transform: translateY(-100%);
}

.loading.loadHidden:after {
  -webkit-transform: scaleY(0);
     -moz-transform: scaleY(0);
      -ms-transform: scaleY(0);
          transform: scaleY(0);
}

.c-copy p {
  font-size: 1.4rem;
  line-height: 1.72;
}

.c-copy p + p {
  margin-top: 2.4rem;
}

.c-copy02 p {
  font-size: 1.6rem;
  line-height: 1.32;
}

.c-copy02 p + p {
  margin-top: 2.1rem;
}

.c-copy02 ul {
  padding: 2.1rem 0;
}

.c-pagination {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
     -moz-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.c-pagination li {
  margin: 0 .2rem;
}

.c-pagination li a {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
     -moz-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 3rem;
  height: 3rem;
  border: 1px solid #ccc;
  font-size: 1.2rem;
  -moz-border-radius: .4rem;
       border-radius: .4rem;
  color: #6A6A6A;
  -webkit-transition: background .3s ease-out, color .3s ease-out, border-color .3s ease-out;
  -moz-transition: background .3s ease-out, color .3s ease-out, border-color .3s ease-out;
  transition: background .3s ease-out, color .3s ease-out, border-color .3s ease-out;
}

.c-pagination li a.active, .c-pagination li a:hover {
  border-color: #173371;
  background: #173371;
  color: #fff;
}

.c-pagination li.c-pagination-prev {
  margin: 0 .8rem 0 0;
}

.c-pagination li.c-pagination-next {
  margin: 0 0 0 .8rem;
}

.c-pagination li.c-pagination-prev a, .c-pagination li.c-pagination-next a {
  font-size: 2.3rem;
}

.c-breadcrumb {
  border-bottom: 1px solid #707070;
}

.c-breadcrumb ul {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  padding: 0.7rem 0 0.8rem;
}

.c-breadcrumb ul li {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.2rem;
  color: #023894;
}

.c-breadcrumb ul li:not(:last-child):after {
  content: '>';
  display: block;
  margin: 0 1.5rem;
}

.c-breadcrumb ul li a {
  color: #2F2E2E;
  display: block;
  -webkit-transition: opacity .3s ease-out;
  -moz-transition: opacity .3s ease-out;
  transition: opacity .3s ease-out;
}

.c-breadcrumb ul li a:hover {
  color: #023894;
}

.c-ttl {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
     -moz-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  color: #023894;
  font-size: 1.6rem;
}

.c-ttl > span {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
}

.c-ttl__en {
  font-weight: 400;
  font-family: "Antro Vectra", sans-serif;
  font-size: 5rem;
  -webkit-transform: rotate(-7deg);
     -moz-transform: rotate(-7deg);
      -ms-transform: rotate(-7deg);
          transform: rotate(-7deg);
  letter-spacing: .04em;
}

@media screen and (max-width: 768px) {
  .c-ttl__en {
    font-size: 3.9rem;
    letter-spacing: 0;
  }
}

.c-ttl__jp {
  margin-left: -3.3rem;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .c-ttl__jp {
    font-size: 1.4rem;
  }
}

.c-header__v2 {
  letter-spacing: .1em;
  color: #023894;
  display: block;
}

.c-header__v2 .c-header__box {
  display: inline-block;
  position: relative;
}

.c-header__v2 .c-header__box:after {
  content: '';
  display: block;
  width: 100%;
  border-bottom: 1px solid #023894;
  position: absolute;
  top: 3.3rem;
  left: 0;
  -webkit-transform: scaleX(0);
     -moz-transform: scaleX(0);
      -ms-transform: scaleX(0);
          transform: scaleX(0);
  -webkit-transform-origin: 0 100%;
     -moz-transform-origin: 0 100%;
      -ms-transform-origin: 0 100%;
          transform-origin: 0 100%;
  -webkit-transition: -webkit-transform .5s ease-out .3s;
  transition: -webkit-transform .5s ease-out .3s;
  -moz-transition: transform .5s ease-out .3s, -moz-transform .5s ease-out .3s;
  transition: transform .5s ease-out .3s;
  transition: transform .5s ease-out .3s, -webkit-transform .5s ease-out .3s, -moz-transform .5s ease-out .3s;
}

.c-header__v2 .c-header__en {
  display: -webkit-inline-box;
  display: -moz-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  font-size: 1.8rem;
  font-weight: 700;
  font-family: "Thasadith", sans-serif;
  padding-bottom: 1.2rem;
  margin-bottom: .9rem;
}

.c-header__v2 .c-header__jp {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 1.6rem;
  font-weight: 500;
}

.c-header__v2.active .c-header__box:after {
  -webkit-transform: scaleX(1);
     -moz-transform: scaleX(1);
      -ms-transform: scaleX(1);
          transform: scaleX(1);
}

.section__desc {
  background: #F8F8F6;
  padding: 10rem 0 9rem;
}

.section__desc__ttl {
  font-size: 2.6rem;
  font-weight: 700;
  color: #023894;
  line-height: 1.62;
  margin-bottom: 5.8rem;
  letter-spacing: .1em;
}

@media screen and (max-width: 768px) {
  .section__desc__ttl {
    font-size: 2rem;
  }
}

@media screen and (min-width: 769px) {
  .section__desc__cont {
    padding-left: 22rem;
  }
}

.section__desc .c-copy02 p {
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .section__desc .c-copy02 p {
    font-size: 1.4rem;
  }
}

.c-boxShadow {
  -moz-box-shadow: 0 0.3rem 2rem rgba(0, 0, 0, 0.16);
       box-shadow: 0 0.3rem 2rem rgba(0, 0, 0, 0.16);
}

.c-boxShadow02 {
  -moz-box-shadow: 0 0.3rem 2rem rgba(7, 119, 119, 0.16);
       box-shadow: 0 0.3rem 2rem rgba(7, 119, 119, 0.16);
}

.mv {
  position: relative;
}

.mv:after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: url("../img/mv_bg.png") top center no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
}

.ie .mv:after {
  background-position: bottom 100% center;
}

@media screen and (max-width: 768px) {
  .mv:after {
    background: url("../img/mv_bg_sp.png") top center no-repeat;
    -moz-background-size: 100%;
         background-size: 100%;
  }
}

.mv__ttl {
  color: #023894;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
     -moz-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
     -moz-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  padding: 19rem 0 3.3rem;
  position: relative;
  z-index: 5;
}

@media screen and (max-width: 768px) {
  .mv__ttl {
    padding: 17rem 0 8.4rem;
  }
}

.mv__ttl__en {
  font-family: "Antro Vectra", sans-serif;
  font-size: 5rem;
  -webkit-transform: rotate(-7deg) translateZ(0);
     -moz-transform: rotate(-7deg) translateZ(0);
          transform: rotate(-7deg) translateZ(0);
  letter-spacing: .04em;
  font-weight: 400;
  margin-right: -6rem;
}

.mv__ttl__en > span > span {
  opacity: 1;
}

@media screen and (max-width: 768px) {
  .mv__ttl__en {
    font-size: 4.2rem;
  }
}

.mv__ttl__jp {
  display: block;
  font-size: 1.6rem;
  font-weight: 500;
  -webkit-transform: translate(0, -1rem);
     -moz-transform: translate(0, -1rem);
      -ms-transform: translate(0, -1rem);
          transform: translate(0, -1rem);
}

@media screen and (max-width: 768px) {
  .mv__ttl__jp {
    font-size: 1.4rem;
  }
}

.mv__img {
  position: relative;
  z-index: 1;
}

.mv__img img {
  width: 100%;
}

.ie .mv__img img {
  height: 39.2rem;
}

@media screen and (max-width: 768px) {
  .mv__img img {
    height: 28rem;
  }
}

.mv__desc {
  position: relative;
  z-index: 10;
}

.mv__desc__ttl {
  font-size: 2.6rem;
  font-weight: 700;
  letter-spacing: .1em;
  line-height: 1.6153;
  color: #023894;
  margin-bottom: 4rem;
}

@media screen and (min-width: 769px) {
  .mv__desc__ttl {
    padding-left: 22.5rem;
  }
}

@media screen and (min-width: 769px) {
  .mv__desc .c-copy02 {
    padding-left: 22.5rem;
  }
}

.mv__desc .c-copy02 p {
  line-height: 2;
  color: #023894;
}

.c-btn {
  position: relative;
  display: block;
  width: 16.8rem;
  -moz-border-radius: 999px;
       border-radius: 999px;
  cursor: pointer;
  border: 0;
  padding: 0;
  -webkit-transition: box-shadow .3s ease-out;
  -moz-transition: box-shadow .3s ease-out, -moz-box-shadow .3s ease-out;
  transition: box-shadow .3s ease-out;
  transition: box-shadow .3s ease-out, -moz-box-shadow .3s ease-out;
}

@media screen and (max-width: 768px) {
  .c-btn {
    margin: 0 auto;
  }
}

@media screen and (min-width: 769px) {
  .c-btn:hover {
    -moz-box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.1);
         box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.1);
  }
}

.c-btn span {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 4rem;
  font-family: "Thasadith", sans-serif;
  font-size: 1.7rem;
  font-weight: 700;
  font-style: italic;
  -moz-border-radius: 999px;
       border-radius: 999px;
  letter-spacing: .04em;
  overflow: hidden;
  padding: 0 2.3rem;
  -webkit-transition: all .5s ease-out;
  -moz-transition: all .5s ease-out;
  transition: all .5s ease-out;
}

@media screen and (max-width: 768px) {
  .c-btn span {
    padding: 0 2.2rem;
    letter-spacing: .04em;
  }
}

.c-btn span:after {
  content: '';
  display: block;
  width: 3rem;
  height: 3rem;
  background: url("../img/icon_btn.svg") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  margin-left: 1rem;
  position: absolute;
  top: 50%;
  right: 1.5rem;
  -webkit-transform: translateY(-50%);
     -moz-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
}

.c-btn__white {
  -moz-box-shadow: 0 0.3rem 2rem white;
       box-shadow: 0 0.3rem 2rem white;
}

.c-btn__white span {
  color: #023894;
  background: #fff;
}

.c-btn__default {
  background: #fff;
  -moz-box-shadow: 0 0.3rem 2rem #92e2fa;
       box-shadow: 0 0.3rem 2rem #92e2fa;
}

.c-btn__default span {
  color: #fff;
  background: #92E2FA;
}

.c-btn__default span:after {
  background: url("../img/icon_btn_default.svg") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
}

.c-btn__entry {
  -moz-box-shadow: 0 0.3rem 2rem white;
       box-shadow: 0 0.3rem 2rem white;
}

.c-btn__entry span {
  font-size: 2.2rem;
  color: #fff;
  background: #FFB307;
  width: 17.7rem;
  height: 5rem;
  padding: 0 3.3rem;
  letter-spacing: .04em;
}

.c-btn__entry span:after {
  width: 3.9rem;
  height: 3.9rem;
  background: url("../img/icon_btn_yellow.svg") no-repeat;
  -moz-background-size: 100% 100%;
       background-size: 100% 100%;
}

.c-link {
  color: #023894;
  display: inline-block;
  border-bottom: 1px solid transparent;
}

.c-link:hover {
  opacity: 0.7;
  border-color: #023894;
}

.c-list li {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
}

.c-list li:before {
  content: '・';
  display: block;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.c-box__gray {
  background: #F2F2F2;
  padding: 3.2rem 4.7rem;
}

.c-list__number {
  counter-reset: num;
}

.c-list__number li {
  counter-increment: num;
}

.c-list__number li:not(:last-child) {
  margin-bottom: 2.1rem;
}

.c-list__number li .number {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
}

.c-list__number li .number:before {
  content: counter(num) ".";
  display: block;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-right: 0.5rem;
}

.c-input {
  display: block;
  width: 100%;
  background: #EDEDED;
  -moz-border-radius: 0;
       border-radius: 0;
  border: 0;
  -moz-box-shadow: none;
       box-shadow: none;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
  outline-offset: 0;
  outline: none;
  padding: 0 2.2rem;
  height: 4.2rem;
  font-weight: 700;
}

.c-input::-webkit-input-placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-input::-moz-placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-input:-ms-input-placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-input::placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-select {
  display: block;
  width: 100%;
  background: #EDEDED;
  -moz-border-radius: 0;
       border-radius: 0;
  border: 0;
  -moz-box-shadow: none;
       box-shadow: none;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
  outline-offset: 0;
  outline: none;
  padding: 0 2.2rem;
  height: 4.2rem;
  font-weight: 700;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  color: #BDBFC4;
  width: 31.5rem;
}

@media screen and (min-width: 769px) {
  .c-select {
    width: 39.2rem;
  }
}

.c-select::-webkit-input-placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-select::-moz-placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-select:-ms-input-placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-select::placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-select::-ms-expand {
  display: none;
}

.c-textarea {
  display: block;
  width: 100%;
  background: #EDEDED;
  -moz-border-radius: 0;
       border-radius: 0;
  border: 0;
  -moz-box-shadow: none;
       box-shadow: none;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
  font-weight: 700;
  outline-offset: 0;
  outline: none;
  padding: 1.4rem 2.2rem;
  height: 22rem;
  resize: none;
}

.c-textarea::-webkit-input-placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-textarea::-moz-placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-textarea:-ms-input-placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.c-textarea::placeholder {
  color: #BDBFC4;
  opacity: 1;
}

.frm_rules {
  max-width: 42.3rem;
  margin: 5.8rem auto 5.4rem;
  padding: 1rem .6rem 1rem 1.7rem;
  -moz-box-shadow: 0.2rem 0.2rem 0.4rem rgba(179, 179, 179, 0.75);
       box-shadow: 0.2rem 0.2rem 0.4rem rgba(179, 179, 179, 0.75);
}

.frm_rules .scrollable {
  position: relative;
  margin: 0 auto;
  width: 100%;
  position: relative;
  overflow: hidden;
  height: 17.5rem;
}

.frm_rules .bx_rules {
  width: 100%;
  height: 17.5rem;
  padding: 0 3rem 0 0;
  background-color: #fff;
  overflow-y: scroll;
}

@media screen and (min-width: 769px) {
  .frm_rules .bx_rules {
    width: -webkit-calc(100% + 1.7rem);
    width: -moz-calc(100% + 1.7rem);
    width: calc(100% + 1.7rem);
  }
}

.frm_rules .scroller {
  z-index: 5;
  cursor: pointer;
  position: absolute;
  width: .5rem;
  background: #808080;
  top: 0;
  -moz-border-radius: 999px;
       border-radius: 999px;
  right: 0;
}

.frm_rules .frm_cont p, .frm_rules .frm_cont ul {
  font-size: 1.2rem;
  line-height: 1.6rem;
}

.frm_rules .frm_cont p:not(:first-child), .frm_rules .frm_cont ul:not(:first-child) {
  margin-top: 1em;
}

.frm_rules .frm_cont ul {
  width: 100%;
}

.frm_rules .frm_cont ul > li {
  position: relative;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding-left: 1em;
}

.frm_rules .frm_cont ul > li:before {
  content: '・';
  -ms-flex-negative: 0;
      flex-shrink: 0;
  position: absolute;
  top: 0;
  left: 0;
}

.custom-wpcf7c-confirmed .frm_rules {
  display: none;
}

/** header area
====================================== **/
.header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  -webkit-transition: opacity .3s ease-out, visibility .3s ease-out;
  -moz-transition: opacity .3s ease-out, visibility .3s ease-out;
  transition: opacity .3s ease-out, visibility .3s ease-out;
}

.header .inner {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
     -moz-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.header.fixed {
  opacity: 0;
  visibility: hidden;
}

.header__logo {
  position: relative;
  line-height: 0;
  z-index: 100;
  width: 24.4rem;
}

.header__logo a {
  display: block;
}

.header__logo a img {
  display: block;
  width: 100%;
}

.header__logo a:hover {
  opacity: 0.7;
}

.header__entry {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 2.2rem;
  font-family: "Thasadith", sans-serif;
  font-weight: 700;
  font-style: italic;
  color: #FFB307;
  margin-right: 3rem;
  letter-spacing: .04em;
}

.header__entry:after {
  content: '';
  display: block;
  width: 3.8rem;
  height: 3.8rem;
  background: url("../img/icon_entry.svg") no-repeat;
  -moz-background-size: 100% 100%;
       background-size: 100% 100%;
  margin-left: 0.5rem;
}

.ie .header__entry:after {
  -moz-background-size: 90% 90%;
       background-size: 90% 90%;
}

.header-globalNav {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  z-index: 100;
}

.header-hambuger {
  position: relative;
  z-index: 10001;
  cursor: pointer;
  width: 2rem;
  height: 1.5rem;
}

.header-hambuger__inner {
  position: relative;
  width: 2.5rem;
  height: 2rem;
  margin: 0 auto;
  -webkit-transition: all 0.3s linear;
  -moz-transition: all 0.3s linear;
  transition: all 0.3s linear;
}

.header-hambuger__item {
  width: 100%;
  height: .2rem;
  min-height: 2px;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -moz-border-radius: 999px;
       border-radius: 999px;
  margin: auto;
  z-index: 1;
  overflow: hidden;
}

.header-hambuger__item:after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: #FFB307;
}

.header-hambuger__item.item1 {
  bottom: auto;
  -webkit-transition: -webkit-transform .4s ease-out .2s;
  transition: -webkit-transform .4s ease-out .2s;
  -moz-transition: transform .4s ease-out .2s, -moz-transform .4s ease-out .2s;
  transition: transform .4s ease-out .2s;
  transition: transform .4s ease-out .2s, -webkit-transform .4s ease-out .2s, -moz-transform .4s ease-out .2s;
}

.header-hambuger__item.item2 {
  top: auto;
  -webkit-transition: -webkit-transform .4s ease-out .2s;
  transition: -webkit-transform .4s ease-out .2s;
  -moz-transition: transform .4s ease-out .2s, -moz-transform .4s ease-out .2s;
  transition: transform .4s ease-out .2s;
  transition: transform .4s ease-out .2s, -webkit-transform .4s ease-out .2s, -moz-transform .4s ease-out .2s;
}

.header-hambuger.open .header-hambuger__item.item1 {
  -webkit-transform: translateY(0.65rem) rotate(45deg);
     -moz-transform: translateY(0.65rem) rotate(45deg);
      -ms-transform: translateY(0.65rem) rotate(45deg);
          transform: translateY(0.65rem) rotate(45deg);
}

.header-hambuger.open .header-hambuger__item.item1:after {
  -webkit-animation: menu .8s ease-out;
     -moz-animation: menu .8s ease-out;
          animation: menu .8s ease-out;
}

.header-hambuger.open .header-hambuger__item.item2 {
  -webkit-transform: translateY(-0.65rem) rotate(-45deg);
     -moz-transform: translateY(-0.65rem) rotate(-45deg);
      -ms-transform: translateY(-0.65rem) rotate(-45deg);
          transform: translateY(-0.65rem) rotate(-45deg);
  -webkit-transition: -webkit-transform .5s ease-out .5s;
  transition: -webkit-transform .5s ease-out .5s;
  -moz-transition: transform .5s ease-out .5s, -moz-transform .5s ease-out .5s;
  transition: transform .5s ease-out .5s;
  transition: transform .5s ease-out .5s, -webkit-transform .5s ease-out .5s, -moz-transform .5s ease-out .5s;
}

.header-hambuger.open .header-hambuger__item.item2:after {
  -webkit-animation: menu .8s ease-out .3s;
     -moz-animation: menu .8s ease-out .3s;
          animation: menu .8s ease-out .3s;
}

.header .globalNav {
  position: fixed;
  top: 0;
  right: 0;
  height: 100%;
  z-index: 10;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
}

.header .globalNav:after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left bottom, left top, from(#77C6E4), to(#D8EFE3));
  background: -webkit-linear-gradient(bottom, #77C6E4, #D8EFE3);
  background: -moz- oldlinear-gradient(bottom, #77C6E4, #D8EFE3);
  background: linear-gradient(0deg, #77C6E4, #D8EFE3);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

.header .globalNav .menu__list {
  margin-bottom: 6rem;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.header .globalNav .menu__list a {
  display: inline-block;
  color: #023894;
}

.header .globalNav .menu__list a:hover {
  opacity: .38;
}

.header .globalNav .menu__list a span {
  display: block;
}

.header .globalNav .menu__list a .menu__link__en {
  font-size: 3rem;
  font-family: "Thasadith", sans-serif;
  font-weight: 700;
  font-style: italic;
  margin-bottom: 1rem;
}

.header .globalNav .menu__list a .menu__link__jp {
  font-size: 2rem;
}

.header .globalNav .c-btn {
  width: 28rem;
}

.header .globalNav .c-btn span {
  background: #FFB307;
  -moz-border-radius: 0;
       border-radius: 0;
  height: 5rem;
  color: #fff;
}

.header .globalNav .c-btn span:after {
  content: none;
}

.header .globalNav .c-btn:hover span {
  -moz-box-shadow: inset 0 0 0 3em #000;
       box-shadow: inset 0 0 0 3em #000;
}

@media screen and (max-width: 768px) {
  .header .globalNav .c-btn {
    width: 20.8rem;
  }
  .header .globalNav .c-btn span {
    font-size: 1.2rem;
  }
}

@media screen and (max-width: 768px) {
  .header .globalNav {
    width: 100%;
    -webkit-transform: translateY(-100%);
       -moz-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
            transform: translateY(-100%);
    -webkit-transition: -webkit-transform .5s ease-out .5s;
    transition: -webkit-transform .5s ease-out .5s;
    -moz-transition: transform .5s ease-out .5s, -moz-transform .5s ease-out .5s;
    transition: transform .5s ease-out .5s;
    transition: transform .5s ease-out .5s, -webkit-transform .5s ease-out .5s, -moz-transform .5s ease-out .5s;
  }
  .header .globalNav:before {
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    background: #fff;
    -webkit-transform: scaleY(1);
       -moz-transform: scaleY(1);
        -ms-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: 0 100%;
       -moz-transform-origin: 0 100%;
        -ms-transform-origin: 0 100%;
            transform-origin: 0 100%;
    -webkit-transition: -webkit-transform .5s ease-out;
    transition: -webkit-transform .5s ease-out;
    -moz-transition: transform .5s ease-out, -moz-transform .5s ease-out;
    transition: transform .5s ease-out;
    transition: transform .5s ease-out, -webkit-transform .5s ease-out, -moz-transform .5s ease-out;
  }
  .header .globalNav.open {
    -webkit-transform: translateY(0);
       -moz-transform: translateY(0);
        -ms-transform: translateY(0);
            transform: translateY(0);
    -webkit-transition: -webkit-transform 0s ease-out 0s;
    transition: -webkit-transform 0s ease-out 0s;
    -moz-transition: transform 0s ease-out 0s, -moz-transform 0s ease-out 0s;
    transition: transform 0s ease-out 0s;
    transition: transform 0s ease-out 0s, -webkit-transform 0s ease-out 0s, -moz-transform 0s ease-out 0s;
    -webkit-animation: closeMenu 1s ease-out;
       -moz-animation: closeMenu 1s ease-out;
            animation: closeMenu 1s ease-out;
  }
  .header .globalNav.open:before {
    -webkit-transform: scaleY(0);
       -moz-transform: scaleY(0);
        -ms-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: 100% 0;
       -moz-transform-origin: 100% 0;
        -ms-transform-origin: 100% 0;
            transform-origin: 100% 0;
    -webkit-transition: -webkit-transform .5s ease-out .5s;
    transition: -webkit-transform .5s ease-out .5s;
    -moz-transition: transform .5s ease-out .5s, -moz-transform .5s ease-out .5s;
    transition: transform .5s ease-out .5s;
    transition: transform .5s ease-out .5s, -webkit-transform .5s ease-out .5s, -moz-transform .5s ease-out .5s;
  }
  .header .globalNav .menu__list li {
    width: 50%;
    margin: 4rem 0 0;
  }
  .header .globalNav .menu__list li:nth-child(-n + 2) {
    margin-top: 0;
  }
  .header .globalNav .c-btn {
    margin: 0 auto;
  }
}

@media screen and (min-width: 769px) {
  .header .globalNav {
    width: 100%;
  }
  .header .globalNav .globalNav__logo {
    position: absolute;
    top: 3.2rem;
    left: 9rem;
    width: 25rem;
    opacity: 0;
    visibility: hidden;
  }
  .header .globalNav .header-menu {
    width: 100%;
    max-height: -webkit-calc(100% - 20rem);
    max-height: -moz-calc(100% - 20rem);
    max-height: calc(100% - 20rem);
    overflow: hidden;
    overflow-y: auto;
  }
  .header .globalNav .header-menu .row {
    padding: 0 8.6rem;
  }
  .header .globalNav .menu__list {
    margin-bottom: 16rem;
  }
  .header .globalNav .menu__list li {
    width: 33.33%;
    margin-top: 9rem;
  }
  .header .globalNav .menu__list li:nth-child(-n + 3) {
    margin-top: 0;
  }
  .header .globalNav .menu__list li .menu__link__en {
    font-size: 2.2rem;
    margin-bottom: 1.3rem;
  }
  .header .globalNav .menu__list li .menu__link__jp {
    font-size: 1.6rem;
    letter-spacing: .08em;
  }
  .header .globalNav .c-btn {
    width: 21rem;
  }
  .header .globalNav .c-btn span {
    padding: 0 3rem;
    font-size: 1.2rem;
  }
}

@media screen and (min-width: 769px) {
  .header {
    padding: 3.5rem 0;
    min-width: 120rem;
  }
  .header-globalNav__inner {
    position: relative;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: -webkit-calc(100% - 34rem);
    width: -moz-calc(100% - 34rem);
    width: calc(100% - 34rem);
    min-width: 110rem;
    margin: 0 auto;
  }
  .header .globalNav {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    visibility: hidden;
    -webkit-transition: visibility 0s ease-out .5s, -webkit-transform .5s ease-out;
    transition: visibility 0s ease-out .5s, -webkit-transform .5s ease-out;
    -moz-transition: visibility 0s ease-out .5s, transform .5s ease-out, -moz-transform .5s ease-out;
    transition: visibility 0s ease-out .5s, transform .5s ease-out;
    transition: visibility 0s ease-out .5s, transform .5s ease-out, -webkit-transform .5s ease-out, -moz-transform .5s ease-out;
    left: 100%;
    z-index: 99;
  }
  .header .globalNav:before {
    content: '';
    display: block;
    width: 1000%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
       -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    z-index: -2;
    opacity: 0;
    -webkit-transition: opacity .5s ease-out;
    -moz-transition: opacity .5s ease-out;
    transition: opacity .5s ease-out;
  }
  .header .globalNav.open {
    visibility: visible;
    -webkit-transition: visibility 0s ease-out, -webkit-transform .5s ease-out;
    transition: visibility 0s ease-out, -webkit-transform .5s ease-out;
    -moz-transition: visibility 0s ease-out, transform .5s ease-out, -moz-transform .5s ease-out;
    transition: visibility 0s ease-out, transform .5s ease-out;
    transition: visibility 0s ease-out, transform .5s ease-out, -webkit-transform .5s ease-out, -moz-transform .5s ease-out;
    -webkit-transform: translateX(-100%);
       -moz-transform: translateX(-100%);
        -ms-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  .header .globalNav.open:before {
    opacity: 1;
  }
  .header .globalNav__menu {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
}

@media screen and (max-width: 768px) {
  .header {
    z-index: 98;
    padding: 1.5rem 1.8rem 1.3rem;
  }
  .header .inner {
    padding: 0;
  }
  .header__logo {
    width: 18rem;
  }
  .header__logo img {
    width: 100%;
  }
  .header__entry {
    font-size: 1.8rem;
    margin-right: 1.6rem;
  }
  .header__entry:after {
    width: 3.1rem;
    height: 3.1rem;
  }
  .header-hambuger {
    width: 1.8rem;
  }
  .header .globalNav {
    padding: 10rem 0 15rem;
  }
  .header .globalNav .menu__list {
    -webkit-box-align: start;
       -moz-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    max-height: -webkit-calc(100vh - 25rem);
    max-height: -moz-calc(100vh - 25rem);
    max-height: calc(100vh - 25rem);
    overflow: hidden;
    overflow-y: auto;
  }
  .header .globalNav .menu__list li {
    margin-top: 2rem;
  }
  .header .globalNav .menu__list li a .menu__link__en {
    font-size: 2rem;
  }
  .header .globalNav .menu__list li a .menu__link__jp {
    font-size: 1.4rem;
  }
  .header .globalNav .c-btn {
    position: absolute;
    bottom: 6rem;
    right: 0;
    left: 0;
  }
  .header .globalNav .c-btn span {
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

/** footer
======================================= **/
.entry {
  background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#65D2F1));
  background: -webkit-linear-gradient(top, #fff, #65D2F1);
  background: -moz- oldlinear-gradient(top, #fff, #65D2F1);
  background: linear-gradient(180deg, #fff, #65D2F1);
  padding: 13rem 0 9.7rem;
}

@media screen and (max-width: 768px) {
  .entry {
    padding: 5.5rem 0 8rem;
  }
}

.entry__head {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
     -moz-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: #023894;
  margin-bottom: 3rem;
}

.entry__head__en {
  font-weight: 400;
  font-family: "Antro Vectra", sans-serif;
  font-size: 5rem;
  margin-right: 2rem;
}

@media screen and (max-width: 768px) {
  .entry__head__en {
    font-size: 3.9rem;
    -webkit-transform: rotate(-7deg);
       -moz-transform: rotate(-7deg);
        -ms-transform: rotate(-7deg);
            transform: rotate(-7deg);
  }
}

.entry__head__jp {
  font-size: 1.6rem;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .entry__head__jp {
    font-size: 1.4rem;
  }
}

@media screen and (min-width: 769px) {
  .entry__wrap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

@media screen and (min-width: 769px) {
  .entry__col {
    width: 50%;
  }
}

.entry__ttl {
  font-size: 2.8rem;
  line-height: 1.5;
  font-weight: normal;
  color: #023894;
  font-family: "A OTF Midashi Go MB31 Pro", sans-serif;
}

@media screen and (min-width: 769px) {
  .entry__ttl {
    padding: 0 0 0 15rem;
  }
}

@media screen and (max-width: 768px) {
  .entry__ttl {
    margin-bottom: 3.8rem;
  }
}

.entry__cont {
  font-size: 1.4rem;
  line-height: 1.71429;
  color: #023894;
  letter-spacing: .08em;
}

.entry .c-btn {
  margin: 6.2rem auto 0;
}

.footer__main {
  background: #023894;
  padding: 8.7rem 0 1.7rem;
}

@media screen and (max-width: 768px) {
  .footer__main {
    padding-bottom: 8rem;
  }
}

.footer__main__list {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.footer__main__list li {
  width: 30rem;
  margin-top: 4.5rem;
}

@media screen and (min-width: 769px) {
  .footer__main__list li:nth-child(-n + 3) {
    margin-top: 0;
  }
  .footer__main__list li:nth-child(1) {
    width: 16.3rem;
  }
  .footer__main__list li:nth-child(2) {
    width: 19rem;
  }
  .footer__main__list li:nth-child(3) {
    width: -webkit-calc(100% - 35.3rem);
    width: -moz-calc(100% - 35.3rem);
    width: calc(100% - 35.3rem);
  }
  .footer__main__list li:nth-child(4) {
    width: 16.3rem;
  }
}

@media screen and (max-width: 768px) {
  .footer__main__list li {
    width: 50%;
    margin-top: 4rem;
  }
  .footer__main__list li:nth-child(-n + 2) {
    margin-top: 0;
  }
}

.footer__main__list li a {
  display: inline-block;
  color: #fff;
  -webkit-transition: opacity .3s ease-out;
  -moz-transition: opacity .3s ease-out;
  transition: opacity .3s ease-out;
}

.footer__main__list li a:hover {
  opacity: .38;
}

.footer__main__list li a span {
  display: block;
}

.footer__main__list li a .link__en {
  font-size: 1.8rem;
  font-weight: 700;
  font-family: "Thasadith", sans-serif;
  font-style: italic;
  margin-bottom: 0.7rem;
  letter-spacing: .04em;
}

@media screen and (max-width: 768px) {
  .footer__main__list li a .link__en {
    margin-bottom: 1.3rem;
  }
}

.footer__main__list li a .link__jp {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: .1em;
}

@media screen and (max-width: 768px) {
  .footer__main__list li a .link__jp {
    font-size: 1.4rem;
  }
}

.footer__main__btn {
  margin-top: 8rem;
  border-top: 1px solid #fff;
  padding: 1.7rem 0 0;
}

@media screen and (max-width: 768px) {
  .footer__main__btn {
    margin-top: 9.2rem;
    padding-top: 8rem;
  }
}

.footer__main__btn .c-btn {
  width: 20.8rem;
  margin: 0 0 0 auto;
}

@media screen and (max-width: 768px) {
  .footer__main__btn .c-btn {
    margin: 0 auto;
  }
}

.footer__main__btn .c-btn span {
  background: #FFB307;
  color: #fff;
  -moz-border-radius: 0;
       border-radius: 0;
  font-size: 1.4rem;
  letter-spacing: 0;
  height: 5rem;
  padding: 0 1.8rem;
}

.footer__main__btn .c-btn span:after {
  content: none;
}

.footer__main__btn .c-btn:hover span {
  -moz-box-shadow: inset 0 0 0 3em #000;
       box-shadow: inset 0 0 0 3em #000;
}

.footer__bot {
  padding: 2rem 0;
}

.footer__bot .row {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (min-width: 769px) {
  .footer__bot .row {
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

@media screen and (max-width: 768px) {
  .footer__bot .row {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.footer__bot .footer__logo {
  width: 19.3rem;
}

.footer__bot .footer__logo a {
  display: block;
}

.footer__bot .footer__logo a:hover {
  opacity: 0.7;
}

.footer__bot .footer__logo img {
  display: block;
  width: 100%;
}

.footer__bot .copyright {
  font-size: 1.2rem;
}

.footer__bot .link__privacy {
  font-size: 1.2rem;
}

@media screen and (max-width: 768px) {
  .footer__bot {
    padding: 4rem 0;
  }
  .footer__bot .footer__logo {
    -webkit-box-ordinal-group: 2;
       -moz-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    width: 19.3rem;
    margin: 0 auto 2.2rem;
  }
  .footer__bot .copyright {
    width: -webkit-calc(100% + 6rem);
    width: -moz-calc(100% + 6rem);
    width: calc(100% + 6rem);
    -webkit-box-ordinal-group: 4;
       -moz-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    font-size: 1rem;
    text-align: center;
    margin: 0 -3rem;
  }
  .footer__bot .link__privacy {
    width: 100%;
    -webkit-box-ordinal-group: 3;
       -moz-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    text-align: center;
    margin-bottom: 2.7rem;
  }
}

.p-top .c-copy02 {
  color: #023894;
}

.p-top .top_bg {
  background: url("../img/top/top_bg.jpg") top center no-repeat;
  -moz-background-size: cover;
       background-size: cover;
}

.p-top .mainVisual {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}

.p-top .mainVisual:before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: #B2DFE5;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  -webkit-transform-origin: 100% 0;
     -moz-transform-origin: 100% 0;
      -ms-transform-origin: 100% 0;
          transform-origin: 100% 0;
  -webkit-transition: -webkit-transform .6s ease-out;
  transition: -webkit-transform .6s ease-out;
  -moz-transition: transform .6s ease-out, -moz-transform .6s ease-out;
  transition: transform .6s ease-out;
  transition: transform .6s ease-out, -webkit-transform .6s ease-out, -moz-transform .6s ease-out;
}

.p-top .mainVisual.active:before {
  -webkit-transform: scaleY(0);
     -moz-transform: scaleY(0);
      -ms-transform: scaleY(0);
          transform: scaleY(0);
}

.p-top .mainVisual:after {
  content: '';
  display: block;
  width: 92.96875%;
  padding-top: 23.90625%;
  background: url("../img/top/droplets.png") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  position: absolute;
  top: 22.44389%;
  left: 1.32813%;
  z-index: 2;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity .3s ease-out 1s, visibility .3s ease-out 1s;
  -moz-transition: opacity .3s ease-out 1s, visibility .3s ease-out 1s;
  transition: opacity .3s ease-out 1s, visibility .3s ease-out 1s;
}

@media screen and (max-width: 768px) {
  .p-top .mainVisual:after {
    left: 3.95rem;
    top: 3.3rem;
    width: 25.1rem;
    height: 50.9rem;
    background: url("../img/top/droplets_sp.png") no-repeat;
    -moz-background-size: 100%;
         background-size: 100%;
  }
}

.p-top .mainVisual.active:after {
  opacity: 1;
  visibility: visible;
}

@media screen and (min-width: 769px) {
  .p-top .mainVisual {
    height: 100vh;
  }
  .p-top .mainVisual__box {
    width: 43.8rem;
  }
}

@media screen and (max-width: 768px) {
  .p-top .mainVisual {
    padding-top: 6.2rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
       -moz-box-orient: vertical;
       -moz-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}

.p-top .mainVisual__cont {
  position: relative;
  z-index: 5;
}

@media screen and (min-width: 769px) {
  .p-top .mainVisual__cont {
    width: 48.828125%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
       -moz-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}

@media screen and (max-width: 768px) {
  .p-top .mainVisual__cont {
    padding: 3.5rem 7.3rem 5rem;
  }
}

.p-top .mainVisual__cont:after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: #fff;
  -webkit-transform-origin: 0 100%;
     -moz-transform-origin: 0 100%;
      -ms-transform-origin: 0 100%;
          transform-origin: 0 100%;
  -webkit-transition: -webkit-transform .5s ease-out;
  transition: -webkit-transform .5s ease-out;
  -moz-transition: transform .5s ease-out, -moz-transform .5s ease-out;
  transition: transform .5s ease-out;
  transition: transform .5s ease-out, -webkit-transform .5s ease-out, -moz-transform .5s ease-out;
}

.p-top .mainVisual__cont.active:after {
  -webkit-transform: scaleY(0);
     -moz-transform: scaleY(0);
      -ms-transform: scaleY(0);
          transform: scaleY(0);
}

.p-top .mainVisual__cont p {
  color: #023894;
  font-size: 1.9rem;
  line-height: 1.68;
}

@media screen and (max-width: 768px) {
  .p-top .mainVisual__cont p {
    font-size: 1.4rem;
  }
}

.p-top .mainVisual_pagination {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 5.2rem;
}

@media screen and (max-width: 768px) {
  .p-top .mainVisual_pagination {
    text-align: center;
    margin-top: 2.2rem;
  }
}

.p-top .mainVisual_pagination .swiper-pagination-bullet {
  display: block;
  margin: 0 0.6rem;
  line-height: 0;
  width: 5.6rem;
  height: 2px;
  background: #80BAC3;
  opacity: 0.72;
  -moz-border-radius: 999px;
       border-radius: 999px;
}

.p-top .mainVisual_pagination .swiper-pagination-bullet-active {
  background: #676767;
}

@media screen and (max-width: 768px) {
  .p-top .mainVisual_pagination .swiper-pagination-bullet {
    width: 4.5rem;
    height: 0.2rem;
    margin: 0 0.5rem;
  }
}

.p-top .mainVisual__ttl {
  margin-bottom: 2.6rem;
}

.p-top .mainVisual__ttl__after {
  margin: 0 0 -2.5rem -7.5rem;
  -webkit-transform: rotate(-7deg);
     -moz-transform: rotate(-7deg);
      -ms-transform: rotate(-7deg);
          transform: rotate(-7deg);
  font-size: 6rem;
  font-family: "Antro Vectra", sans-serif;
  font-weight: 400;
  color: #023894;
  letter-spacing: .04em;
  padding-right: 3rem;
}

@media screen and (max-width: 768px) {
  .p-top .mainVisual__ttl__after {
    font-size: 4.5rem;
    margin: 0 0 -1.7rem -4.2rem;
    letter-spacing: 0;
  }
}

.p-top .mainVisual__ttl__en {
  font-size: 4.6rem;
  font-family: "Thasadith", sans-serif;
  font-weight: 700;
  font-style: italic;
  color: #023894;
  letter-spacing: .04em;
}

@media screen and (max-width: 768px) {
  .p-top .mainVisual__ttl__en {
    font-size: 3.5rem;
  }
}

.p-top .mainVisual__img {
  position: relative;
  z-index: 1;
  -moz-box-shadow: 0 0.3rem 2rem rgba(0, 0, 0, 0.16);
       box-shadow: 0 0.3rem 2rem rgba(0, 0, 0, 0.16);
}

@media screen and (min-width: 769px) {
  .p-top .mainVisual__img {
    width: 51.171875%;
  }
}

.p-top .mainVisual__img .swiper-container {
  height: 100%;
}

.p-top .mainVisual__img .swiper-slide {
  position: relative;
  overflow: hidden;
}

.p-top .mainVisual__img .swiper-slide:before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, right top, left top, from(#00D8FF), to(transparent));
  background: -webkit-linear-gradient(right, #00D8FF, transparent);
  background: -moz- oldlinear-gradient(right, #00D8FF, transparent);
  background: linear-gradient(to left, #00D8FF, transparent);
  position: absolute;
  opacity: 0.34;
  top: 0;
  left: 0;
  z-index: 5;
}

.p-top .mainVisual__img .swiper-slide:after {
  content: '';
  display: block;
  width: 100%;
  height: 200%;
  background: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(25%, #fff), color-stop(75%, #fff), to(transparent));
  background: -webkit-linear-gradient(top, transparent 0%, #fff 25%, #fff 75%, transparent 100%);
  background: -moz- oldlinear-gradient(top, transparent 0%, #fff 25%, #fff 75%, transparent 100%);
  background: linear-gradient(to bottom, transparent 0%, #fff 25%, #fff 75%, transparent 100%);
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translateY(-25%);
     -moz-transform: translateY(-25%);
      -ms-transform: translateY(-25%);
          transform: translateY(-25%);
  z-index: 10;
}

.p-top .mainVisual__img .swiper-slide figure {
  height: 100%;
}

.p-top .mainVisual__img .swiper-slide-active:after {
  -webkit-animation: slider 5s ease-out;
     -moz-animation: slider 5s ease-out;
          animation: slider 5s ease-out;
}

.p-top .mainVisual__img img {
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 768px) {
  .p-top .mainVisual__img img {
    height: 42.9rem;
  }
}

.p-top .message {
  padding: 10.5rem 0 8.5rem;
}

@media screen and (max-width: 768px) {
  .p-top .message {
    padding: 13.5rem 0 8.5rem;
  }
}

.p-top .message .c-ttl {
  margin-bottom: 6.5rem;
}

@media screen and (min-width: 769px) {
  .p-top .message .c-ttl {
    padding-left: 3.3rem;
  }
}

.p-top .message .c-ttl__en {
  font-size: 6rem;
}

.p-top .message .c-ttl__jp {
  -webkit-transform: translateY(-0.5em);
     -moz-transform: translateY(-0.5em);
      -ms-transform: translateY(-0.5em);
          transform: translateY(-0.5em);
}

@media screen and (min-width: 769px) {
  .p-top .message__wrap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p-top .message__wrap .c-btn {
    margin-left: 50%;
    margin-top: 11rem;
  }
}

@media screen and (max-width: 768px) {
  .p-top .message__wrap .c-btn {
    margin-top: 11rem;
  }
}

.p-top .message__ttl {
  font-size: 2.6rem;
  line-height: 1.61538;
  color: #023894;
  font-weight: normal;
  font-family: "A OTF Midashi Go MB31 Pro", sans-serif;
}

@media screen and (min-width: 769px) {
  .p-top .message__ttl {
    padding: 0 0 1.5rem 5rem;
    width: 50%;
  }
}

@media screen and (max-width: 768px) {
  .p-top .message__ttl {
    margin-bottom: 4.6rem;
  }
}

@media screen and (min-width: 769px) {
  .p-top .message__cont {
    width: 50%;
  }
}

.p-top .company {
  background: url("../img/top/company_bg.png") top center no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  padding: 43.28125% 0 6rem;
  position: relative;
}

.p-top .company:after {
  content: '';
  display: block;
  width: 83.90625%;
  padding-top: 47.1875%;
  background: url("../img/top/droplets_02.png") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  position: absolute;
  top: -5rem;
  left: 8.28125%;
  z-index: 2;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity .3s ease-out .75s, visibility .3s ease-out .75s;
  -moz-transition: opacity .3s ease-out .75s, visibility .3s ease-out .75s;
  transition: opacity .3s ease-out .75s, visibility .3s ease-out .75s;
}

@media screen and (max-width: 768px) {
  .p-top .company:after {
    content: none;
  }
}

.p-top .company .row {
  position: relative;
  z-index: 5;
}

.p-top .company.active:after {
  opacity: 1;
  visibility: visible;
}

@media screen and (max-width: 768px) {
  .p-top .company {
    background: url("../img/top/company_bg_sp.jpg") top center no-repeat;
    -moz-background-size: 100%;
         background-size: 100%;
    padding: 50rem 0 5rem;
  }
}

@media screen and (min-width: 769px) {
  .p-top .company .row {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.p-top .company__img {
  position: relative;
  display: block;
  overflow: hidden;
}

.p-top .company__img img {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .p-top .company__img {
    width: 37.6rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

@media screen and (max-width: 768px) {
  .p-top .company__img {
    width: 24rem;
    margin-bottom: 5.8rem;
  }
}

.p-top .company__img:after {
  content: '';
  display: block;
  width: 124%;
  height: 100%;
  background: -webkit-gradient(linear, left top, right top, from(rgba(0, 216, 255, 0.25)), to(transparent));
  background: -webkit-linear-gradient(left, rgba(0, 216, 255, 0.25), transparent);
  background: -moz- oldlinear-gradient(left, rgba(0, 216, 255, 0.25), transparent);
  background: linear-gradient(to right, rgba(0, 216, 255, 0.25), transparent);
  position: absolute;
  top: 0;
  left: -24%;
}

.p-top .company__cont {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .p-top .company__cont {
    padding: 10rem 0 0 11.5rem;
  }
}

.p-top .company__cont .c-ttl {
  margin-left: -2rem;
  margin-bottom: 7.2rem;
}

@media screen and (max-width: 768px) {
  .p-top .company__cont .c-ttl {
    margin-bottom: 4.3rem;
  }
}

.p-top .company__cont .c-ttl__en {
  margin-right: -30px;
  letter-spacing: 0.02em;
}

.p-top .company__cont .c-ttl__jp {
  -webkit-transform: none;
     -moz-transform: none;
      -ms-transform: none;
          transform: none;
  margin-left: -1rem;
}

.p-top .company__cont .c-copy02 {
  margin-bottom: 8.3rem;
}

@media screen and (max-width: 768px) {
  .p-top .company__cont .c-copy02 {
    padding: 0 0 0 3rem;
    margin-bottom: 5.4rem;
  }
}

.p-top .job {
  padding: 15rem 0 7.5rem;
}

@media screen and (max-width: 768px) {
  .p-top .job {
    padding: 7rem 0 5rem;
  }
}

.p-top .job .inner {
  position: relative;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
}

.p-top .job .inner:after {
  content: '';
  width: 77.4rem;
  height: 77.4rem;
  background: url("../img/circle_left.png") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  position: absolute;
  top: -4rem;
  left: -20rem;
  z-index: -1;
}

@media screen and (max-width: 768px) {
  .p-top .job .inner:after {
    width: 38.7rem;
    height: 38.7rem;
    left: -5rem;
  }
}

.p-top .job .c-ttl {
  margin-bottom: 4.3rem;
}

@media screen and (min-width: 769px) {
  .p-top .job .c-ttl {
    padding-left: 5.8rem;
  }
}

.p-top .job .job__desc {
  margin-bottom: 6.6rem;
}

@media screen and (min-width: 769px) {
  .p-top .job .job__desc {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
       -moz-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding-left: 5rem;
  }
}

@media screen and (max-width: 768px) {
  .p-top .job .job__desc {
    margin-bottom: 9.2rem;
  }
}

@media screen and (min-width: 769px) {
  .p-top .job .job__desc .c-copy02 {
    width: 33.7rem;
  }
}

@media screen and (max-width: 768px) {
  .p-top .job .job__desc .c-copy02 {
    padding-left: 3rem;
    margin-bottom: 5.4rem;
  }
}

.p-top .job .job__desc .c-btn {
  margin-top: 0.9rem;
}

.p-top .job__slider .swiper-wrapper {
  -webkit-transition-timing-function: linear;
     -moz-transition-timing-function: linear;
          transition-timing-function: linear;
}

.p-top .job__slider .swiper-slide {
  width: 29.3rem;
}

.p-top .job__slider .swiper-slide img {
  width: 100%;
  height: 41.4rem;
}

@media screen and (max-width: 768px) {
  .p-top .job__slider .swiper-slide {
    width: 24.5rem;
  }
  .p-top .job__slider .swiper-slide img {
    height: 31rem;
  }
}

.p-top .benefits {
  padding: 23rem 0 10rem 0;
}

@media screen and (max-width: 768px) {
  .p-top .benefits {
    padding: 5.2rem 0 8rem;
  }
}

.p-top .benefits .inner {
  position: relative;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
}

.p-top .benefits .inner:after {
  content: '';
  width: 82rem;
  height: 82rem;
  background: url("../img/circle_right.png") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
     -moz-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  right: -24rem;
  z-index: -1;
}

@media screen and (max-width: 768px) {
  .p-top .benefits .inner:after {
    width: 51rem;
    height: 51rem;
    right: -13rem;
    top: 22rem;
  }
}

@media screen and (min-width: 769px) {
  .p-top .benefits__wrap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-left: 5.5rem;
  }
}

@media screen and (min-width: 769px) {
  .p-top .benefits__cont {
    width: 51%;
  }
}

.p-top .benefits__cont .c-ttl {
  margin-bottom: 12.6rem;
}

@media screen and (max-width: 768px) {
  .p-top .benefits__cont .c-ttl {
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-bottom: 5rem;
  }
}

.p-top .benefits__cont .c-copy02 {
  margin-bottom: 10.3rem;
}

@media screen and (max-width: 768px) {
  .p-top .benefits__cont .c-copy02 {
    margin-bottom: 6rem;
  }
}

.p-top .benefits__img {
  margin-top: 10rem;
}

@media screen and (min-width: 769px) {
  .p-top .benefits__img {
    width: 49%;
  }
}

@media screen and (max-width: 768px) {
  .p-top .benefits__img {
    margin-top: 11.6rem;
    padding-left: 3rem;
    margin-right: -3rem;
  }
}

.p-top .benefits__img__item {
  margin-top: -10rem;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
     -moz-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 25.4rem;
  height: 25.4rem;
  background: #fff;
  -moz-border-radius: 999px;
       border-radius: 999px;
  -moz-box-shadow: 0 0 1.4rem #C7EDF2;
       box-shadow: 0 0 1.4rem #C7EDF2;
}

.p-top .benefits__img__item:nth-child(even) {
  margin-right: 0;
  margin-left: auto;
}

@media screen and (max-width: 768px) {
  .p-top .benefits__img__item {
    padding: 1.5rem;
    margin-top: -6rem;
    width: 15.6rem;
    height: 15.6rem;
  }
}

.p-top .voice {
  padding: 12.3rem 0 11.5rem;
}

@media screen and (max-width: 768px) {
  .p-top .voice {
    padding: 10.8rem 0 5rem;
  }
}

.p-top .voice .c-ttl {
  margin-bottom: 3.6rem;
}

@media screen and (min-width: 769px) {
  .p-top .voice .c-ttl {
    padding-left: 4rem;
  }
}

@media screen and (max-width: 768px) {
  .p-top .voice .c-ttl {
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.p-top .voice .voice__desc {
  margin-bottom: 7.5rem;
}

@media screen and (min-width: 769px) {
  .p-top .voice .voice__desc {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    padding-left: 4rem;
  }
}

@media screen and (max-width: 768px) {
  .p-top .voice .voice__desc {
    margin-bottom: 5.2rem;
  }
}

@media screen and (min-width: 769px) {
  .p-top .voice .voice__desc .c-copy02 {
    width: 33.5rem;
  }
}

@media screen and (max-width: 768px) {
  .p-top .voice .voice__desc .c-copy02 {
    padding-left: 3rem;
    margin-bottom: 6rem;
  }
}

.p-top .voice .voice__desc .c-btn {
  margin-top: 0.5rem;
}

@media screen and (min-width: 769px) {
  .p-top .voice .voice__wrap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: start;
       -moz-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.p-top .voice .voice__item {
  position: relative;
  -moz-box-shadow: 0 0.3rem 3rem rgba(0, 0, 0, 0.16);
       box-shadow: 0 0.3rem 3rem rgba(0, 0, 0, 0.16);
  line-height: 0;
  overflow: hidden;
}

@media screen and (min-width: 769px) {
  .p-top .voice .voice__item {
    width: -webkit-calc(50% - 3.3rem);
    width: -moz-calc(50% - 3.3rem);
    width: calc(50% - 3.3rem);
  }
  .p-top .voice .voice__item:nth-child(even) {
    margin-top: 11.2rem;
  }
  .p-top .voice .voice__item:nth-child(odd) {
    margin-right: 6.6rem;
  }
}

@media screen and (max-width: 768px) {
  .p-top .voice .voice__item:nth-child(even) {
    margin-right: -7.1rem;
    margin-left: 4.7rem;
  }
  .p-top .voice .voice__item:nth-child(odd) {
    margin-left: -7.1rem;
    margin-right: 4.7rem;
  }
  .p-top .voice .voice__item:not(:first-child) {
    margin-top: 3rem;
  }
}

.p-top .voice .voice__item:after {
  content: '';
  display: block;
  width: 128%;
  height: 100%;
  position: absolute;
  top: 0;
}

.p-top .voice .voice__item img {
  width: 100%;
}

.p-top .voice .voice__item:nth-child(even):after {
  background: -webkit-gradient(linear, right top, left top, from(rgba(0, 216, 255, 0.25)), to(transparent));
  background: -webkit-linear-gradient(right, rgba(0, 216, 255, 0.25), transparent);
  background: -moz- oldlinear-gradient(right, rgba(0, 216, 255, 0.25), transparent);
  background: linear-gradient(-90deg, rgba(0, 216, 255, 0.25), transparent);
  left: 28%;
}

.p-top .voice .voice__item:nth-child(odd):after {
  background: -webkit-gradient(linear, left top, right top, from(rgba(0, 216, 255, 0.25)), to(transparent));
  background: -webkit-linear-gradient(left, rgba(0, 216, 255, 0.25), transparent);
  background: -moz- oldlinear-gradient(left, rgba(0, 216, 255, 0.25), transparent);
  background: linear-gradient(90deg, rgba(0, 216, 255, 0.25), transparent);
  right: 28%;
}

.p-message .mv__ttl {
  padding: 20rem 0 6.6rem;
}

@media screen and (max-width: 768px) {
  .p-message .mv__ttl {
    padding: 15rem 0 8.3rem;
  }
}

.p-message .mv__ttl__en {
  font-size: 6rem;
}

.p-message .mv__ttl__jp {
  -webkit-transform: translate(1.5rem, -1rem);
     -moz-transform: translate(1.5rem, -1rem);
      -ms-transform: translate(1.5rem, -1rem);
          transform: translate(1.5rem, -1rem);
}

.p-message .mv__desc__ttl {
  margin-bottom: 4.6rem;
}

@media screen and (max-width: 768px) {
  .p-message .mv__desc__ttl {
    margin-bottom: 3.7rem;
  }
}

.p-message .mv__desc .c-copy02 p {
  letter-spacing: .1em;
}

.p-message .mv__desc .c-copy02 p + p {
  margin-top: 3.2rem;
}

.p-message .message__section01 {
  padding: 11.2rem 0 5.9rem 0;
}

@media screen and (min-width: 769px) {
  .p-message .message__section01__list {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-message .message__section01__item {
    width: 50%;
  }
  .p-message .message__section01__item:nth-child(2n + 2) {
    -webkit-transform: translateY(5.5rem);
       -moz-transform: translateY(5.5rem);
        -ms-transform: translateY(5.5rem);
            transform: translateY(5.5rem);
  }
}

.p-message .message__section01__item img {
  width: 100%;
}

.p-message .message__item {
  padding: 12.5rem 0 14.5rem 0;
}

.p-message .message__item:not(:last-of-type) {
  border-bottom: 1px solid #E2E2E2;
}

@media screen and (min-width: 769px) {
  .p-message .message__item:nth-child(odd) .message__item__head .item__figure {
    margin-left: -19rem;
  }
  .p-message .message__item:nth-child(odd) .message__item__head .item__name {
    padding-left: 6.5rem;
  }
  .p-message .message__item:nth-child(odd) .message__item__head .c-copy02 {
    padding-left: 6.5rem;
  }
  .p-message .message__item:nth-child(odd) .message__item__detail .item__figure {
    margin-left: -19rem;
  }
  .p-message .message__item:nth-child(odd) .message__item__detail .item__detail {
    margin-left: -7.5rem;
  }
  .p-message .message__item:nth-child(even) .message__item__head {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
       -moz-box-orient: horizontal;
       -moz-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  .p-message .message__item:nth-child(even) .message__item__head .item__figure {
    margin-right: -19rem;
  }
  .p-message .message__item:nth-child(even) .message__item__head .item__name {
    padding-right: 5.5rem;
  }
  .p-message .message__item:nth-child(even) .message__item__head .c-copy02 {
    padding-right: 5.5rem;
  }
  .p-message .message__item:nth-child(even) .message__item__detail {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
       -moz-box-orient: horizontal;
       -moz-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  .p-message .message__item:nth-child(even) .message__item__detail .item__figure {
    margin-right: -19rem;
  }
  .p-message .message__item:nth-child(even) .message__item__detail .item__detail {
    margin-right: -7.5rem;
  }
  .p-message .message__item .item__detail {
    width: 50.6rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p-message .message__item .item__cont {
    width: 43.1rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

.p-message .message__item .item__ttl {
  font-size: 2rem;
  line-height: 2;
  letter-spacing: .1em;
  font-weight: 700;
}

.p-message .message__item__head {
  margin-bottom: 6rem;
}

@media screen and (min-width: 769px) {
  .p-message .message__item__head {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.p-message .message__item__head .item__figure {
  width: 100%;
}

.p-message .message__item__head .item__figure img {
  width: 100%;
}

.p-message .message__item__head .item__name {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: end;
     -moz-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  color: #023894;
  padding: 0 0 4.2rem;
  margin-bottom: 4.2rem;
  border-bottom: 1px solid #023894;
}

.p-message .message__item__head .item__name__top {
  width: 100%;
  font-size: 1.6rem;
  margin-bottom: 0.5rem;
}

.p-message .message__item__head .item__name__jp {
  font-size: 2.4rem;
  margin-right: 2rem;
  font-weight: 500;
  white-space: nowrap;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  letter-spacing: .1em;
}

.p-message .message__item__head .item__name__en {
  font-size: 1.6rem;
  line-height: 2;
  font-weight: 700;
  font-style: italic;
  font-family: "Thasadith", sans-serif;
  letter-spacing: .1em;
}

.p-message .message__item__head .c-copy02 {
  color: #023894;
  line-height: 1.875;
}

.p-message .message__item__head .c-copy02 p {
  line-height: 1.875;
}

.p-message .message__item__cont {
  margin-bottom: 10rem;
}

.p-message .message__item__cont .item__ttl {
  margin-bottom: 2.7rem;
}

@media screen and (min-width: 769px) {
  .p-message .message__item__detail {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.p-message .message__item__detail .item__figure {
  width: 100%;
}

.p-message .message__item__detail .item__figure img {
  width: 100%;
}

.p-message .message__item__detail .item__ttl {
  margin-bottom: 4.8rem;
}

@media screen and (max-width: 768px) {
  .p-message .mv:after {
    background: url("../img/message/mv_bg_sp.png") top center no-repeat;
    -moz-background-size: 100%;
         background-size: 100%;
  }
  .p-message .mv__desc .c-copy02 p {
    letter-spacing: .08em;
  }
  .p-message .message__section01 {
    padding: 15.3rem 0 5.9rem 0;
  }
  .p-message .message__section01__item:nth-child(even) {
    margin-right: -10rem;
    margin-left: 5rem;
  }
  .p-message .message__section01__item:nth-child(odd) {
    margin-left: -10rem;
    margin-right: 5rem;
  }
  .p-message .message__item {
    padding: 5.2rem 0 14.5rem;
  }
  .p-message .message__item__head {
    margin-bottom: 12.4rem;
  }
  .p-message .message__item__head .item__figure {
    width: -webkit-calc(100% - 2rem);
    width: -moz-calc(100% - 2rem);
    width: calc(100% - 2rem);
  }
  .p-message .message__item__head .item__figure img {
    height: 45.5rem;
  }
  .p-message .message__item__head .item__name {
    padding: 0 3rem 2.7rem;
    margin: 0 -3rem 2.7rem;
  }
  .p-message .message__item__detail .item__figure img {
    height: 37.4rem;
  }
  .p-message .message__item:nth-child(odd) .message__item__head .item__figure {
    margin: 0 0 2.8rem -3rem;
  }
  .p-message .message__item:nth-child(odd) .message__item__detail .item__figure {
    margin: 0 0 3.5rem -3rem;
  }
  .p-message .message__item:nth-child(even) .message__item__head .item__figure {
    margin: 0 -3rem 2.8rem auto;
  }
  .p-message .message__item:nth-child(even) .message__item__detail .item__figure {
    margin: 0 -3rem 3.5rem auto;
  }
}

.p-job .job__section01 {
  padding: 11.5rem 0 8rem;
}

.p-job .job__section01 .c-header__v2 {
  margin-bottom: 5.2rem;
}

@media screen and (min-width: 769px) {
  .p-job .job__section01 .job__item01 {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
       -moz-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .p-job .job__section01 .job__item01__img {
    width: -webkit-calc(50% - 15rem);
    width: -moz-calc(50% - 15rem);
    width: calc(50% - 15rem);
  }
  .p-job .job__section01 .job__item01__box {
    width: 60rem;
  }
}

@media screen and (min-width: 769px) {
  .p-job .job__section01 .job__item01__cont {
    width: 100%;
    padding: 2.2rem 0 0;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
       -moz-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}

.p-job .job__section01 .job__item01__img {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.p-job .job__section01 .job__item01__img img {
  width: 100%;
  height: 43.1rem;
}

.p-job .job__section01 .job__item01__box .c-copy02 {
  margin-bottom: 5rem;
}

.p-job .job__section01 .job__item01__box .c-copy02 p {
  line-height: 2;
  color: #023894;
}

.p-job .job__section01 .job__item01__list {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
}

.p-job .job__section01 .job__item01__list li {
  width: 25.2rem;
  position: relative;
}

@media screen and (min-width: 769px) {
  .p-job .job__section01 .job__item01__list li:nth-child(n + 1) {
    margin-right: 2rem;
  }
}

.p-job .job__section01 .job__item01__list li figure {
  display: block;
  width: 25.2rem;
  height: 25.2rem;
  -moz-border-radius: 999px;
       border-radius: 999px;
  border: 1px solid #023894;
  overflow: hidden;
}

.p-job .job__section01 .job__item01__list li .job__item01__text {
  -moz-border-radius: 999px;
       border-radius: 999px;
  background: #023894;
  color: #fff;
  width: 21rem;
  line-height: 2.8rem;
  text-align: center;
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
     -moz-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}

.p-job .job__section02 {
  background: #00C8C7;
  padding: 10.9rem 0;
}

.p-job .job__section02__item {
  padding: 8rem 8.8rem;
  margin: 0 3.3rem;
}

.p-job .job__section02__item:not(:last-child) {
  margin-bottom: 9.2rem;
}

.p-job .job__section02__item.item__01 {
  background: url("../img/job/job_item01_bg.png") center no-repeat #fff;
  -moz-background-size: 76.5rem;
       background-size: 76.5rem;
}

.p-job .job__section02__item.item__02 {
  background: url("../img/job/job_item02_bg.png") bottom right no-repeat #fff;
  -moz-background-size: 66.8rem;
       background-size: 66.8rem;
}

.p-job .job__section02__item .job__section02__ttl {
  font-size: 2rem;
  font-weight: 700;
  color: #023894;
  letter-spacing: .1em;
  margin-bottom: 8.7rem;
}

.p-job .job__section02__item .c-copy p {
  letter-spacing: .1em;
}

@media screen and (max-width: 768px) {
  .p-job .job__section02__item .c-copy p {
    letter-spacing: .08em;
  }
}

.p-job .job__section03 {
  padding: 11.3rem 0 27rem;
}

@media screen and (max-width: 768px) {
  .p-job .job__section03 {
    padding-bottom: 10rem;
  }
}

.p-job .job__section03 .row {
  position: relative;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
}

.p-job .job__section03 .row:after, .p-job .job__section03 .row:before {
  content: '';
  display: block;
  width: 81.6rem;
  height: 81.6rem;
  background: url("../img/circle_left.png") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  position: absolute;
  z-index: -1;
}

@media screen and (max-width: 768px) {
  .p-job .job__section03 .row:after, .p-job .job__section03 .row:before {
    width: 101.2rem;
    height: 101.2rem;
    background: url("../img/circle_left_sp.png") no-repeat;
    -moz-background-size: 100%;
         background-size: 100%;
  }
}

.p-job .job__section03 .row:after {
  top: 0;
  right: -20rem;
}

@media screen and (max-width: 768px) {
  .p-job .job__section03 .row:after {
    top: 6rem;
  }
}

.p-job .job__section03 .row:before {
  top: 100rem;
  left: -25rem;
}

@media screen and (max-width: 768px) {
  .p-job .job__section03 .row:before {
    display: none;
  }
}

.p-job .job__section03 .c-header__v2 {
  margin-bottom: 7.5rem;
}

.p-job .job__section03__item {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: end;
     -moz-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

.p-job .job__section03__item:not(:last-child) {
  margin-bottom: 11rem;
}

.p-job .job__section03__item .item__img {
  position: relative;
  -moz-box-shadow: 0 0.3rem 3rem rgba(7, 119, 119, 0.16);
       box-shadow: 0 0.3rem 3rem rgba(7, 119, 119, 0.16);
  overflow: hidden;
}

@media screen and (min-width: 769px) {
  .p-job .job__section03__item .item__img {
    width: 54.3rem;
  }
}

.p-job .job__section03__item .item__img:after {
  content: '';
  display: block;
  width: 125%;
  height: 100%;
  position: absolute;
  top: 0;
  left: -25%;
  background: -webkit-gradient(linear, left top, right top, from(rgba(0, 216, 255, 0.28)), to(transparent));
  background: -webkit-linear-gradient(left, rgba(0, 216, 255, 0.28), transparent);
  background: -moz- oldlinear-gradient(left, rgba(0, 216, 255, 0.28), transparent);
  background: linear-gradient(90deg, rgba(0, 216, 255, 0.28), transparent);
}

@media screen and (min-width: 769px) {
  .p-job .job__section03__item .item__right {
    width: -webkit-calc(100% - 54.3rem);
    width: -moz-calc(100% - 54.3rem);
    width: calc(100% - 54.3rem);
    padding: 0 0 0.3rem 6rem;
  }
  .p-job .job__section03__item .item__right p {
    line-height: 1.75;
  }
}

.p-job .job__section03__item .item__right p {
  color: #023894;
}

.p-job .job__section03__item .c-copy {
  margin-top: 6.3rem;
  width: 100%;
}

.p-job .job__section03__item .c-copy p {
  line-height: 1.72;
}

.p-job .job__section03__item .item__head {
  margin-bottom: 1.8rem;
  color: #023894;
}

.p-job .job__section03__item .item__head .ttl_box_txt {
  margin: -1.5rem 0;
  line-height: 2;
  padding-right: 3rem;
}

.p-job .job__section03__item .item__head__en {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  font-family: "Antro Vectra", sans-serif;
  opacity: 0.2;
  font-weight: 400;
  font-size: 5.5rem;
  letter-spacing: .04em;
  line-height: 2;
  -webkit-transform: rotate(-7deg) translateY(0.9rem);
     -moz-transform: rotate(-7deg) translateY(0.9rem);
      -ms-transform: rotate(-7deg) translateY(0.9rem);
          transform: rotate(-7deg) translateY(0.9rem);
}

.p-job .job__section03__item .item__head__en .ttl_box_txt:last-child {
  margin-bottom: 1rem;
}

.p-job .job__section03__item .item__head__jp {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 2.4rem;
  font-weight: 700;
  padding-left: 10rem;
}

@media screen and (max-width: 768px) {
  .p-job .job__section01 {
    padding-bottom: 0;
  }
  .p-job .job__section01 .job__item01 {
    position: relative;
    padding-bottom: 27.7rem;
  }
  .p-job .job__section01 .job__item01__box {
    padding: 0 3rem;
  }
  .p-job .job__section01 .job__item01__img {
    margin-left: 3rem;
  }
  .p-job .job__section01 .job__item01__img img {
    height: 26.6rem;
  }
  .p-job .job__section01 .job__item01__list {
    position: absolute;
    bottom: 6rem;
    left: 1rem;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .p-job .job__section01 .job__item01__list li {
    width: -webkit-calc(50% - 1.6rem);
    width: -moz-calc(50% - 1.6rem);
    width: calc(50% - 1.6rem);
    margin: 0 .8rem;
  }
  .p-job .job__section01 .job__item01__list li figure {
    width: 16.2rem;
    height: 16.2rem;
  }
  .p-job .job__section01 .job__item01__list li figure img {
    width: 100%;
  }
  .p-job .job__section01 .job__item01__list li .job__item01__text {
    width: 13.5rem;
    line-height: 1.8rem;
    font-size: 0.8rem;
    bottom: 1.7rem;
  }
  .p-job .job__section02 {
    padding: 5rem 0;
  }
  .p-job .job__section02 .job__section02__ttl {
    margin-bottom: 2.3rem;
  }
  .p-job .job__section02__item {
    margin: 0;
    padding: 4.4rem 2rem 6.6rem;
  }
  .p-job .job__section02__item.item__01 {
    background: url("../img/job/job_item01_bg_sp.png") left 1.5rem center no-repeat #fff;
    -moz-background-size: 30.4rem;
         background-size: 30.4rem;
  }
  .p-job .job__section02__item.item__02 {
    background: url("../img/job/job_item02_bg_sp.png") bottom right no-repeat #fff;
    -moz-background-size: 27.7rem;
         background-size: 27.7rem;
  }
  .p-job .job__section02__item:not(:last-child) {
    margin-bottom: 5rem;
  }
  .p-job .job__section03 .c-header__v2 {
    margin-bottom: 4.3rem;
  }
  .p-job .job__section03__item .item__img {
    margin-bottom: 1rem;
  }
  .p-job .job__section03__item .item__img img {
    width: 100%;
    height: 29.2rem;
  }
  .p-job .job__section03__item .item__head {
    margin-bottom: 2.8rem;
  }
  .p-job .job__section03__item .item__head__en {
    font-size: 4.2rem;
    margin-bottom: 1rem;
  }
  .p-job .job__section03__item .item__head__jp {
    padding: 0.5rem 0 0 0;
    font-size: 2rem;
  }
  .p-job .job__section03__item .c-copy02 p {
    line-height: 1.75;
  }
  .p-job .job__section03__item .c-copy {
    margin-top: 3.2rem;
  }
}

.p-company .history__line {
  position: relative;
}

.p-company .history__line:after {
  content: '';
  display: block;
  background: url("../img/company/history_line.png") repeat-y;
  -moz-background-size: 100%;
       background-size: 100%;
  width: 2px;
  position: absolute;
  top: 3.5rem;
  left: 12rem;
  bottom: 0;
}

@media screen and (max-width: 768px) {
  .p-company .history__line:after {
    left: 1.6rem;
  }
}

@media screen and (min-width: 769px) {
  .p-company .history__line__item {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p-company .history__line__item .item_year {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: 12.9rem;
  }
}

@media screen and (max-width: 768px) {
  .p-company .history__line__item {
    padding-top: 2rem;
  }
}

.p-company .history__line__item .item_year {
  position: relative;
  font-size: 2.7rem;
  font-weight: 700;
  font-style: italic;
  font-family: "Thasadith", sans-serif;
  color: #023894;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  letter-spacing: .1em;
}

@media screen and (max-width: 768px) {
  .p-company .history__line__item .item_year {
    padding: 0 0 0 4rem;
    margin-bottom: 2.2rem;
  }
}

.p-company .history__line__item .item_year:after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  width: 1.6rem;
  height: 1.6rem;
  -moz-border-radius: 50%;
       border-radius: 50%;
  background: #023894;
  -webkit-transform: translateY(-50%);
     -moz-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 0;
}

@media screen and (max-width: 768px) {
  .p-company .history__line__item .item_year:after {
    left: 0.8rem;
  }
}

.p-company .history__line__item .item_cont {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-left: 2.3rem;
  border-bottom: 1px solid #E2E2E2;
  line-height: 1.357142;
  padding: 0 4.3rem;
  width: 100%;
}

.p-company .history__line__item .item_cont p {
  font-size: 1.4rem;
  letter-spacing: .1em;
}

@media screen and (min-width: 769px) {
  .p-company .history__line__item .item_cont {
    height: 8.6rem;
  }
}

@media screen and (max-width: 768px) {
  .p-company .history__line__item .item_cont {
    margin-left: 0;
    padding: 0 0 1.7rem 4rem;
    border: 0;
  }
}

.p-company .company__history {
  padding: 11.4rem 0 12rem 0;
}

.p-company .company__history .c-header__v2 {
  margin-bottom: 3rem;
}

.p-company .company__present {
  padding: 5.5rem 0 0;
}

.p-company .company__present .c-header__v2 {
  margin-bottom: 5.5rem;
}

.p-company .company__present .present__banner {
  overflow: hidden;
}

.p-company .company__present .present__banner img {
  height: 52.7rem;
}

.p-company .company__present .present__box {
  position: relative;
  margin: -26.8rem 0 0 auto;
  background: url("../img/company/present_box_bg.png") center no-repeat;
  -moz-background-size: cover;
       background-size: cover;
}

@media screen and (min-width: 769px) {
  .p-company .company__present .present__box {
    width: -webkit-calc(50% + 20.8rem);
    width: -moz-calc(50% + 20.8rem);
    width: calc(50% + 20.8rem);
  }
}

@media screen and (min-width: 769px) {
  .p-company .company__present .present__box .present__cont {
    padding: 7.7rem 8.8rem;
    width: 77.5rem;
  }
}

.p-company .company__present .present__box .present__ttl {
  font-size: 2rem;
  font-weight: 700;
  color: #023894;
  letter-spacing: .1em;
  margin-bottom: 4rem;
}

.p-company .company__manager {
  padding: 13.5rem 0 10rem;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
}

.p-company .company__manager:after {
  content: '';
  display: block;
  width: 81.6rem;
  height: 81.6rem;
  opacity: 0.62;
  background: url("../img/circle_left.png") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  position: absolute;
  top: 10rem;
  left: -webkit-calc(50% - 11rem);
  left: -moz-calc(50% - 11rem);
  left: calc(50% - 11rem);
  z-index: -1;
}

.p-company .company__manager .c-header__v2 {
  margin-bottom: 4.8rem;
}

.p-company .company__manager .manager__list li:not(:last-child) {
  margin-bottom: 6.6rem;
}

.p-company .company__manager .manager__list .item__ttl {
  font-size: 2.4rem;
  margin-bottom: 3rem;
  color: #023894;
  letter-spacing: .1em;
}

.p-company .company__manager .manager__list .item__ttl__en {
  font-family: "Thasadith", sans-serif;
  font-weight: 700;
  margin-left: 2rem;
}

.p-company .company__manager .manager__list .item__cont p {
  font-size: 1.4rem;
  line-height: 1.71429;
  letter-spacing: .1em;
}

.p-company .company__manager .manager__list .item__cont p + p {
  margin-top: 2.4rem;
}

@media screen and (max-width: 768px) {
  .p-company .mv__ttl {
    margin-left: -3rem;
  }
  .p-company .mv__ttl__jp {
    -webkit-transform: translate(3rem, -1rem);
       -moz-transform: translate(3rem, -1rem);
        -ms-transform: translate(3rem, -1rem);
            transform: translate(3rem, -1rem);
  }
  .p-company .history__line__item .item_year {
    margin-bottom: 1.5rem;
  }
  .p-company .history__line__item .item_cont {
    padding-bottom: 0;
    min-height: 7rem;
  }
  .p-company .company__present .present__banner img {
    height: 32rem;
  }
  .p-company .company__present .present__box {
    margin: -8rem 0 0 3rem;
    padding: 4.3rem 3rem 3rem;
  }
  .p-company .company__manager .c-header__v2 {
    margin-bottom: 3.8rem;
  }
  .p-company .company__manager:after {
    top: 22rem;
    left: 50%;
    -webkit-transform: translateX(-50%) rotate(180deg);
       -moz-transform: translateX(-50%) rotate(180deg);
        -ms-transform: translateX(-50%) rotate(180deg);
            transform: translateX(-50%) rotate(180deg);
  }
  .p-company .company__manager .manager__list li:not(:last-child) {
    margin-bottom: 7.5rem;
  }
  .p-company .company__manager .manager__list .item__ttl {
    font-size: 2rem;
    margin-bottom: 2.5rem;
    padding-left: .4rem;
    letter-spacing: .12em;
  }
  .p-company .company__manager .manager__list .item__ttl span {
    display: block;
  }
  .p-company .company__manager .manager__list .item__ttl__jp {
    margin-bottom: .7rem;
  }
  .p-company .company__manager .manager__list .item__ttl__en {
    margin-left: 0;
  }
  .p-company .company__manager .manager__list .item__cont p {
    font-size: 1.6rem;
    line-height: 1.3125;
    letter-spacing: .08em;
  }
  .p-company .company__manager .manager__list .item__cont p + p {
    margin-top: 2.1rem;
  }
}

.p-benefits .mv__ttl__jp {
  -webkit-transform: translate(2rem, -1rem);
     -moz-transform: translate(2rem, -1rem);
      -ms-transform: translate(2rem, -1rem);
          transform: translate(2rem, -1rem);
}

.p-benefits .mv {
  margin-bottom: 0;
}

.p-benefits .benefits__section {
  position: relative;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
  padding: 11rem 0 9rem;
}

.p-benefits .benefits__section:nth-child(odd):before {
  left: -10rem;
  -webkit-transform: rotate(155deg);
     -moz-transform: rotate(155deg);
      -ms-transform: rotate(155deg);
          transform: rotate(155deg);
}

@media screen and (max-width: 768px) {
  .p-benefits .benefits__section:nth-child(odd):before {
    left: -25rem;
  }
}

.p-benefits .benefits__section:nth-child(even) {
  padding: 20rem 0 9rem;
}

.p-benefits .benefits__section:nth-child(even):before {
  top: 0;
  right: -10rem;
}

@media screen and (max-width: 768px) {
  .p-benefits .benefits__section:nth-child(even) {
    padding-top: 7rem;
  }
  .p-benefits .benefits__section:nth-child(even):before {
    top: 7rem;
    right: -27rem;
  }
}

.p-benefits .benefits__section.item_bg:after {
  content: '';
  display: block;
  width: -webkit-calc(50% + 24rem);
  width: -moz-calc(50% + 24rem);
  width: calc(50% + 24rem);
  height: 52.7rem;
  background: url("../img/benefits/benefits_section_bg.jpg") no-repeat;
  -moz-background-size: cover;
       background-size: cover;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: -1;
}

.p-benefits .benefits__section:before {
  content: '';
  display: block;
  width: 79.2rem;
  height: 79.2rem;
  background: url("../img/circle_left.png") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  position: absolute;
  top: 6.8rem;
  z-index: -2;
}

@media screen and (max-width: 768px) {
  .p-benefits .benefits__section:before {
    width: 85rem;
    height: 85rem;
  }
}

@media screen and (min-width: 769px) {
  .p-benefits .benefits__wrap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-benefits .benefits__item {
    width: -webkit-calc(33.33% - 5rem);
    width: -moz-calc(33.33% - 5rem);
    width: calc(33.33% - 5rem);
  }
  .p-benefits .benefits__item:nth-child(-n + 3) {
    margin-top: 0;
  }
}

.p-benefits .benefits__item {
  margin: 4.2rem 2.5rem 0;
}

.p-benefits .benefits__item__first .benefits__item__figure {
  background: transparent;
}

.p-benefits .benefits__item__figure {
  position: relative;
  padding-top: 100%;
  -moz-border-radius: 50%;
       border-radius: 50%;
  background: #fff;
}

.p-benefits .benefits__item__figure .item__center {
  position: absolute;
  top: 50%;
  left: 50%;
  margin-right: -50%;
  -webkit-transform: translate(-50%, -50%);
     -moz-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.p-benefits .benefits__item__figure .item__text {
  font-size: 2.2rem;
  letter-spacing: .1em;
  text-align: center;
  color: #023894;
  line-height: 1.357142;
}

.p-benefits .benefits__item__figure .item__text small {
  font-size: 1.4rem;
  display: inline-block;
}

.p-benefits .benefits__item__text {
  color: #023894;
  font-size: 1.6rem;
  font-weight: 500;
  text-align: center;
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .p-benefits .benefits__section {
    padding: 7.3rem 0 9rem;
  }
  .p-benefits .benefits__section.item_bg:after {
    width: -webkit-calc(100% - 3rem);
    width: -moz-calc(100% - 3rem);
    width: calc(100% - 3rem);
    padding-bottom: 11rem;
    bottom: 58rem;
    height: 62.6rem;
    background: url("../img/benefits/benefits_section_bg_sp.jpg") no-repeat;
    -moz-background-size: cover;
         background-size: cover;
  }
  .p-benefits .benefits__item {
    width: 25.4rem;
    margin-left: auto;
    margin-right: auto;
  }
  .p-benefits .benefits__item__first {
    width: auto;
    height: auto;
    margin: 0;
  }
  .p-benefits .benefits__item__first .benefits__item__figure {
    padding-top: 0;
  }
  .p-benefits .benefits__item__first .benefits__item__figure .c-header__v2 {
    position: static;
    -webkit-transform: none;
       -moz-transform: none;
        -ms-transform: none;
            transform: none;
    margin: 0;
  }
  .p-benefits .benefits__item .benefits__item__figure .item__text {
    width: 100%;
    -moz-font-feature-settings: "palt" 1;
         font-feature-settings: "palt" 1;
    padding: 5rem 3rem;
  }
  .p-benefits .benefits__item .benefits__item__figure .item__text img {
    max-width: 55%;
  }
}

.p-voice .mv__ttl__jp {
  -webkit-transform: translate(2.5rem, -1rem);
     -moz-transform: translate(2.5rem, -1rem);
      -ms-transform: translate(2.5rem, -1rem);
          transform: translate(2.5rem, -1rem);
}

.p-voice .voice__img {
  padding: 1.7rem 0 8rem 0;
}

@media screen and (min-width: 769px) {
  .p-voice .voice__img__list {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-voice .voice__img__item {
    width: 50%;
  }
  .p-voice .voice__img__item:nth-child(2n + 2) {
    -webkit-transform: translateY(5.5rem);
       -moz-transform: translateY(5.5rem);
        -ms-transform: translateY(5.5rem);
            transform: translateY(5.5rem);
  }
}

.p-voice .voice__img__item img {
  width: 100%;
}

.p-voice .voice__interview {
  padding: 17rem 0 0;
}

.p-voice .voice__interview .interview__list {
  padding: 12.6rem 0 10rem;
  position: relative;
  -webkit-perspective: 1px;
     -moz-perspective: 1px;
          perspective: 1px;
}

.p-voice .voice__interview .interview__list:after {
  content: '';
  display: block;
  width: 100%;
  height: 60rem;
  background: -webkit-gradient(linear, left bottom, left top, from(transparent), to(#65D2F1));
  background: -webkit-linear-gradient(bottom, transparent, #65D2F1);
  background: -moz- oldlinear-gradient(bottom, transparent, #65D2F1);
  background: linear-gradient(0deg, transparent, #65D2F1);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

.p-voice .voice__interview .interview__wrap {
  position: relative;
  z-index: 2;
}

@media screen and (min-width: 769px) {
  .p-voice .voice__interview .interview__wrap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 0 -5rem;
  }
}

.p-voice .voice__interview .interview__wrap:after {
  content: '';
  display: block;
  width: 34rem;
  height: 44.5rem;
  background: url("../img/voice/interview_after.png") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  position: absolute;
  top: -34rem;
  right: 7.8rem;
  z-index: -1;
}

.p-voice .voice__interview .c-header__v2 {
  margin-bottom: 4rem;
}

.p-voice .voice__interview .interview__item {
  display: block;
  -webkit-transition: opacity .3s ease-out;
  -moz-transition: opacity .3s ease-out;
  transition: opacity .3s ease-out;
}

@media screen and (min-width: 769px) {
  .p-voice .voice__interview .interview__item {
    width: -webkit-calc(50% - 10rem);
    width: -moz-calc(50% - 10rem);
    width: calc(50% - 10rem);
    margin: 12rem 5rem 0;
  }
  .p-voice .voice__interview .interview__item:nth-child(-n + 2) {
    margin-top: 0;
  }
}

.p-voice .voice__interview .interview__item:hover {
  opacity: 0.7;
}

.p-voice .voice__interview .interview__item__img {
  margin-bottom: 3.6rem;
}

.p-voice .voice__interview .interview__item__img img {
  height: 30rem;
}

.p-voice .voice__interview .interview__item__name {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: end;
     -moz-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin-bottom: 2.5rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid #12398E;
}

.p-voice .voice__interview .interview__item__name p {
  font-size: 1.6rem;
  color: #023894;
}

.p-voice .voice__interview .interview__item__name .name__top {
  width: 100%;
  margin-bottom: 0.8rem;
}

.p-voice .voice__interview .interview__item__name .name__jp {
  font-size: 2.4rem;
  margin-right: 3.5rem;
  font-weight: 700;
  letter-spacing: .1em;
}

.p-voice .voice__interview .interview__item__name .name__en {
  line-height: 1.7;
  letter-spacing: .1em;
  font-family: "Thasadith", sans-serif;
  font-weight: 700;
  font-style: italic;
}

.p-voice .voice__interview .interview__item .c-copy02 p {
  color: #023894;
  line-height: 1.875;
}

.p-voiceDetail .voice__itemFrist {
  position: relative;
  z-index: 3;
  padding: 24.4rem 0 0;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  background: url("../img/mv_bg.png") top center no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
}

.p-voiceDetail .voice__itemFrist .voice__item__cont {
  width: 100%;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
     -moz-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.p-voiceDetail .voice__itemFrist .voice__item__box {
  padding-top: 140px;
}

@media screen and (min-width: 769px) {
  .p-voiceDetail .voice__itemFrist .voice__item__box {
    width: 43rem;
  }
  .p-voiceDetail .voice__itemFrist .voice__item__box .c-copy02 {
    padding-right: 7rem;
  }
}

.p-voiceDetail .voice__itemFrist .voice__item__box .c-copy02 p {
  color: #023894;
  line-height: 1.82;
}

@media screen and (min-width: 769px) {
  .p-voiceDetail .voice__itemFrist .voice__item__figure {
    width: -webkit-calc(50% + 7.8rem);
    width: -moz-calc(50% + 7.8rem);
    width: calc(50% + 7.8rem);
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

.p-voiceDetail .voice__itemFrist .voice__item__figure img {
  width: 100%;
}

.p-voiceDetail .voice__item01 {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
     -moz-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
     -moz-box-orient: horizontal;
     -moz-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  margin-top: -6.4rem;
  position: relative;
  z-index: 5;
  padding: 0 0 7.5rem 0;
}

@media screen and (min-width: 769px) {
  .p-voiceDetail .voice__item01 .voice__item__figure {
    width: -webkit-calc(50% - 4.6rem);
    width: -moz-calc(50% - 4.6rem);
    width: calc(50% - 4.6rem);
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p-voiceDetail .voice__item01 .voice__item__box {
    width: 49.8rem;
    padding-right: 6rem;
    padding-top: 19.5rem;
  }
}

.p-voiceDetail .voice__item01 .voice__item__figure img {
  height: 59.8rem;
}

.p-voiceDetail .voice__item01 .voice__item__cont {
  width: 100%;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
     -moz-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.p-voiceDetail .voice__item01 .voice__item__box .c-copy p {
  line-height: 1.75;
}

.p-voiceDetail .voice__item01 .voice__item__ttl {
  margin-bottom: 6rem;
}

.p-voiceDetail .voice__item02 {
  position: relative;
  z-index: 5;
  padding: 7.5rem 0 5rem 0;
}

@media screen and (min-width: 769px) {
  .p-voiceDetail .voice__item02 {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
       -moz-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .p-voiceDetail .voice__item02 .voice__item__figure {
    width: -webkit-calc(50% + 4.6rem);
    width: -moz-calc(50% + 4.6rem);
    width: calc(50% + 4.6rem);
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p-voiceDetail .voice__item02 .voice__item__box {
    width: 49.8rem;
    padding-left: 6rem;
  }
}

.p-voiceDetail .voice__item02 .voice__item__figure img {
  height: 40rem;
}

.p-voiceDetail .voice__item02 .voice__item__cont {
  width: 100%;
  padding-top: 15.3rem;
}

.p-voiceDetail .voice__item02 .voice__item__box .c-copy p {
  line-height: 1.75;
}

.p-voiceDetail .voice__item02 .voice__item__ttl {
  margin-bottom: 6rem;
}

.p-voiceDetail .voice__item03 {
  padding: 5rem 0 10rem 0;
}

@media screen and (min-width: 769px) {
  .p-voiceDetail .voice__item03 .voice__item__figure {
    margin: 0 0 13rem auto;
    width: -webkit-calc(50% + 45.2rem);
    width: -moz-calc(50% + 45.2rem);
    width: calc(50% + 45.2rem);
  }
  .p-voiceDetail .voice__item03 .voice__item__cont {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p-voiceDetail .voice__item03 .voice__item__cont .voice__item__ttl {
    padding-left: 1.5rem;
    width: 50%;
  }
  .p-voiceDetail .voice__item03 .voice__item__cont .c-copy {
    padding-left: 2rem;
    width: 50%;
  }
}

.p-voiceDetail .voice__item03 .voice__item__figure img {
  height: 40rem;
}

.p-voiceDetail .voice__item03 .voice__item__cont .c-copy p {
  line-height: 1.75;
}

.p-voiceDetail .voice__item__name {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: end;
     -moz-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin-bottom: 2.5rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid #12398E;
}

.p-voiceDetail .voice__item__name p {
  color: #023894;
  font-size: 1.6rem;
}

@media screen and (max-width: 768px) {
  .p-voiceDetail .voice__item__name p {
    font-size: 1.4rem;
  }
}

.p-voiceDetail .voice__item__name .name__top {
  width: 100%;
  margin-bottom: 0.8rem;
}

.p-voiceDetail .voice__item__name .name__jp {
  font-size: 2.4rem;
  margin-right: 3.5rem;
  font-weight: 700;
  letter-spacing: .1em;
}

.p-voiceDetail .voice__item__name .name__en {
  line-height: 2;
  letter-spacing: .1em;
  font-family: "Thasadith", sans-serif;
  font-weight: 700;
  font-style: italic;
}

.p-voiceDetail .voice__history {
  background: #F8F8F6;
  position: relative;
  z-index: 2;
  padding: 0 0 13.7rem;
}

@media screen and (min-width: 769px) {
  .p-voiceDetail .voice__history {
    margin-top: -5rem;
  }
  .p-voiceDetail .voice__history .inner {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
  }
  .p-voiceDetail .voice__history__left {
    width: 60.55046%;
    padding: 6.6rem 0 12.5rem;
  }
  .p-voiceDetail .voice__history__right {
    padding-top: 224px;
    padding-left: 3.3rem;
  }
}

.p-voiceDetail .voice__history .inner:before {
  content: '';
  display: block;
  width: 1000%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 100%;
  background: #37BCB7;
}

.p-voiceDetail .voice__history__ttl {
  font-family: "Antro Vectra", sans-serif;
  font-weight: 400;
  -webkit-transform: rotate(-7deg);
     -moz-transform: rotate(-7deg);
      -ms-transform: rotate(-7deg);
          transform: rotate(-7deg);
  letter-spacing: .04em;
}

.p-voiceDetail .voice__history__left {
  background: #37BCB7;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.p-voiceDetail .voice__history__left .voice__history__ttl {
  font-size: 9rem;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 2rem;
}

.p-voiceDetail .voice__history__right {
  width: 100%;
}

.p-voiceDetail .voice__history__right .voice__history__ttl {
  font-size: 6.1rem;
  color: rgba(2, 56, 148, 0.36);
  margin-bottom: 2.8rem;
}

.p-voiceDetail .voice__history__right .c-copy02 {
  padding-left: 3rem;
}

.p-voiceDetail .voice__history__right .c-copy02 p {
  font-family: "A OTF Midashi Go MB31 Pro", sans-serif;
  font-weight: normal;
  color: #023894;
  font-size: 2.6rem;
  line-height: 1.62;
}

.p-voiceDetail .history__line {
  position: relative;
  margin: 0 17rem 0 3.5rem;
  padding-bottom: 1.5rem;
}

.p-voiceDetail .history__line:after {
  content: '';
  display: block;
  background: url("../img/voice/history_line.png") repeat-y;
  -moz-background-size: 100%;
       background-size: 100%;
  width: 2px;
  position: absolute;
  top: 1rem;
  left: 11.5rem;
  bottom: 0;
}

@media screen and (max-width: 768px) {
  .p-voiceDetail .history__line:after {
    top: 3.5rem;
    left: 1.6rem;
  }
}

@media screen and (min-width: 769px) {
  .p-voiceDetail .history__line__item {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
       -moz-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .p-voiceDetail .history__line__item .item_year {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: 12.4rem;
  }
}

@media screen and (max-width: 768px) {
  .p-voiceDetail .history__line__item {
    padding-top: 2rem;
  }
}

.p-voiceDetail .history__line__item:not(:last-child) {
  margin-bottom: 3rem;
}

.p-voiceDetail .history__line__item .item_year {
  position: relative;
  font-size: 2.7rem;
  font-weight: 700;
  line-height: 1;
  font-style: italic;
  font-family: "Thasadith", sans-serif;
  color: #fff;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  letter-spacing: .1em;
}

@media screen and (max-width: 768px) {
  .p-voiceDetail .history__line__item .item_year {
    padding: 0 0 0 4rem;
    margin-bottom: 2.2rem;
  }
}

.p-voiceDetail .history__line__item .item_year:after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  width: 1.6rem;
  height: 1.6rem;
  -moz-border-radius: 50%;
       border-radius: 50%;
  background: #fff;
  -webkit-transform: translateY(-50%);
     -moz-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 0;
}

@media screen and (max-width: 768px) {
  .p-voiceDetail .history__line__item .item_year:after {
    left: 0.8rem;
  }
}

.p-voiceDetail .history__line__item .item_cont {
  margin-left: 2.3rem;
  letter-spacing: .1em;
  line-height: 1.357142;
  padding: 0.3rem 0 1.7rem 1.5rem;
  width: 100%;
  color: #fff;
}

.p-voiceDetail .history__line__item .item_cont .text__bold {
  font-size: 1.6rem;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .p-voiceDetail .history__line__item .item_cont {
    margin-left: 0;
    padding: 0 0 1.7rem 4rem;
    border: 0;
  }
}

.p-voiceDetail .voice__item__ttl {
  font-size: 2.6rem;
  line-height: 1.62;
  color: #023894;
  font-weight: normal;
  font-family: "A OTF Midashi Go MB31 Pro", sans-serif;
  letter-spacing: .1em;
}

.p-voiceDetail .voice__btn__top {
  padding-top: 5rem;
  border-top: 1px solid #E5E5E5;
}

.p-voiceDetail .voice__btn__top .c-btn {
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .p-voice .section__desc__cont {
    margin-right: -2rem;
  }
  .p-voice .voice__img__item:nth-child(odd) {
    margin-left: -10rem;
    margin-right: 5.2rem;
  }
  .p-voice .voice__img__item:nth-child(even) {
    margin-right: -10rem;
    margin-left: 4.5rem;
  }
  .p-voice .voice__interview {
    padding-top: 5rem;
  }
  .p-voice .voice__interview .c-header__v2 {
    margin-bottom: 14.2rem;
  }
  .p-voice .voice__interview .interview__list {
    padding-top: 16.6rem;
  }
  .p-voice .voice__interview .interview__wrap:after {
    width: 26rem;
    height: 29.5rem;
    right: -1.8rem;
    top: -27rem;
  }
  .p-voice .voice__interview .interview__item:not(:last-child) {
    margin-bottom: 7rem;
  }
  .p-voice .voice__interview .interview__item__name {
    padding-bottom: 1.8rem;
    margin-bottom: 1.8rem;
  }
  .p-voice .voice__interview .interview__item__name .name__jp {
    font-size: 1.8rem;
  }
  .p-voice .voice__interview .interview__item__img {
    margin-bottom: 2.5rem;
  }
  .p-voice .voice__interview .interview__item__img img {
    height: 25.3rem;
  }
  .p-voiceDetail .voice__itemFrist {
    background: none;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
       -moz-box-orient: vertical;
       -moz-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    padding-bottom: 7rem;
    padding-top: 0;
  }
  .p-voiceDetail .voice__itemFrist .voice__item__figure img {
    height: 28rem;
  }
  .p-voiceDetail .voice__itemFrist .voice__item__box {
    padding: 4.5rem 3rem 0;
  }
  .p-voiceDetail .voice__item__name {
    padding-bottom: 1.8rem;
    margin-bottom: 1.8rem;
  }
  .p-voiceDetail .voice__item__name .name__jp {
    font-size: 1.8rem;
  }
  .p-voiceDetail .voice__item__name .name__en {
    line-height: 1.5;
  }
  .p-voiceDetail .voice__history {
    padding-bottom: 10rem;
  }
  .p-voiceDetail .voice__history__left {
    padding: 2rem 3rem 4rem 0;
    margin-right: -3rem;
  }
  .p-voiceDetail .voice__history__left .voice__history__ttl {
    font-size: 7.4rem;
    padding-left: 1.5rem;
    margin-bottom: 1rem;
  }
  .p-voiceDetail .voice__history__right {
    padding: 3rem 0 0 0;
  }
  .p-voiceDetail .voice__history__right .c-copy02 p {
    font-size: 1.6rem;
  }
  .p-voiceDetail .history__line {
    margin: 0 0 0 1.2rem;
  }
  .p-voiceDetail .voice__item01 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
       -moz-box-orient: vertical;
       -moz-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .p-voiceDetail .voice__item01 .voice__item__figure {
    margin: 0 0 4.5rem 6.5rem;
  }
  .p-voiceDetail .voice__item01 .voice__item__figure img {
    height: 35.6rem;
  }
  .p-voiceDetail .voice__item01 .voice__item__cont {
    padding: 0 3rem;
  }
  .p-voiceDetail .voice__item01 .voice__item__ttl {
    font-size: 2rem;
    margin-bottom: 4.8rem;
  }
  .p-voiceDetail .voice__item02 .voice__item__figure img {
    height: 27.2rem;
  }
  .p-voiceDetail .voice__item02 .voice__item__cont {
    padding: 4.5rem 3rem 0;
  }
  .p-voiceDetail .voice__item02 .voice__item__ttl {
    font-size: 2rem;
    margin-bottom: 4.8rem;
  }
  .p-voiceDetail .voice__item03 .voice__item__figure img {
    height: 27.2rem;
  }
  .p-voiceDetail .voice__item03 .voice__item__cont {
    padding: 4.5rem 0 0;
  }
  .p-voiceDetail .voice__item03 .voice__item__ttl {
    font-size: 2rem;
    margin-bottom: 4.8rem;
  }
}

.p-entry .mv__ttl__jp {
  -webkit-transform: translate(5rem, -1rem);
     -moz-transform: translate(5rem, -1rem);
      -ms-transform: translate(5rem, -1rem);
          transform: translate(5rem, -1rem);
}

.p-entry .section__recruit {
  padding: 11.5rem 0 5.5rem;
}

.p-entry .section__recruit .c-header__v2 {
  margin-bottom: 4.5rem;
}

.p-entry .section__recruit .recruit__img img {
  height: 46.7rem;
}

.p-entry .section__recruit .recruit__cont {
  position: relative;
  z-index: 2;
  background: #fff;
  margin-top: -2rem;
}

.p-entry .section__recruit .recruit__cont .c-copy02 p {
  line-height: 2;
}

@media screen and (min-width: 769px) {
  .p-entry .section__recruit .recruit__cont:after {
    content: '';
    display: block;
    width: 120%;
    height: 39rem;
    background: -webkit-gradient(linear, left bottom, left top, from(transparent), to(#65D2F1));
    background: -webkit-linear-gradient(bottom, transparent, #65D2F1);
    background: -moz- oldlinear-gradient(bottom, transparent, #65D2F1);
    background: linear-gradient(0deg, transparent, #65D2F1);
    position: absolute;
    top: -11.5rem;
    left: -10%;
    z-index: -1;
    -webkit-filter: blur(3.5rem);
            filter: blur(3.5rem);
  }
  .p-entry .section__recruit .recruit__cont:before {
    content: '';
    display: block;
    width: 120%;
    height: 39rem;
    background: #fff;
    position: absolute;
    top: -11.5rem;
    left: -10%;
    z-index: -1;
    -webkit-filter: blur(3.5rem);
            filter: blur(3.5rem);
  }
}

@media screen and (max-width: 768px) {
  .p-entry .section__recruit .recruit__cont:after {
    content: '';
    display: block;
    width: 120%;
    height: 39rem;
    background: url("../img/entry/recruit_cont_bg.png") repeat-x;
    -moz-background-size: auto 100%;
         background-size: auto 100%;
    position: absolute;
    top: -11.5rem;
    left: -10%;
    z-index: -1;
  }
}

.p-entry .section__recruit .recruit__cont .recruit__box {
  margin: 0 auto;
}

@media screen and (min-width: 769px) {
  .p-entry .section__recruit .recruit__cont .recruit__box {
    width: 47rem;
  }
}

.p-entry .section__recruit .recruit__cont .recruit__ttl {
  font-size: 2.6rem;
  letter-spacing: .1em;
  color: #023894;
  margin-bottom: 4.3rem;
}

.p-entry .section__recruit .recruit__cont .c-copy02 p {
  letter-spacing: .1em;
}

.p-entry .section__job {
  padding: 10rem 0;
}

.p-entry .section__job .c-header__v2 {
  margin-bottom: 5.7rem;
}

@media screen and (min-width: 769px) {
  .p-entry .section__job .job__wrap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    width: 82rem;
    margin: 0 auto 6.6rem;
  }
  .p-entry .section__job .job__item {
    width: -webkit-calc(50% - 5rem);
    width: -moz-calc(50% - 5rem);
    width: calc(50% - 5rem);
    margin: 0 2.5rem;
  }
  .p-entry .section__job .job__link {
    width: 55rem;
  }
}

.p-entry .section__job .job__item {
  position: relative;
  display: block;
}

.p-entry .section__job .job__item__figure {
  position: relative;
}

.p-entry .section__job .job__item__figure img {
  height: 21.1rem;
}

.p-entry .section__job .job__item__figure:before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  background: -webkit-gradient(linear, left top, right top, from(transparent), to(#65D2F1));
  background: -webkit-linear-gradient(left, transparent, #65D2F1);
  background: -moz- oldlinear-gradient(left, transparent, #65D2F1);
  background: linear-gradient(90deg, transparent, #65D2F1);
  opacity: 0.27;
}

.p-entry .section__job .job__item__figure:after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 4;
  -webkit-transform: scaleY(0.35);
     -moz-transform: scaleY(0.35);
      -ms-transform: scaleY(0.35);
          transform: scaleY(0.35);
  -webkit-transform-origin: 0 100%;
     -moz-transform-origin: 0 100%;
      -ms-transform-origin: 0 100%;
          transform-origin: 0 100%;
  -webkit-transition: -webkit-transform .3s ease-out;
  transition: -webkit-transform .3s ease-out;
  -moz-transition: transform .3s ease-out, -moz-transform .3s ease-out;
  transition: transform .3s ease-out;
  transition: transform .3s ease-out, -webkit-transform .3s ease-out, -moz-transform .3s ease-out;
  background: -webkit-gradient(linear, left bottom, left top, from(#0494BE), to(transparent));
  background: -webkit-linear-gradient(bottom, #0494BE, transparent);
  background: -moz- oldlinear-gradient(bottom, #0494BE, transparent);
  background: linear-gradient(0deg, #0494BE, transparent);
}

.p-entry .section__job .job__item__text {
  position: absolute;
  bottom: 1rem;
  left: 0;
  right: 0;
  z-index: 5;
  text-align: center;
  font-size: 1.6rem;
  color: #fff;
  font-weight: 700;
}

.p-entry .section__job .job__item:hover .job__item__figure:after {
  -webkit-transform: scaleY(1);
     -moz-transform: scaleY(1);
      -ms-transform: scaleY(1);
          transform: scaleY(1);
}

.p-entry .section__job .job__link {
  display: block;
  margin: 0 auto;
  -webkit-transition: all .3s ease-out;
  -moz-transition: all .3s ease-out;
  transition: all .3s ease-out;
}

.p-entry .section__job .job__link__ttl {
  border-bottom: 1px solid;
  padding-bottom: 1.5rem;
  margin-bottom: 2.3rem;
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 1.35714;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
     -moz-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.p-entry .section__job .job__link__ttl:after {
  content: '';
  display: block;
  width: 1.3rem;
  height: 1rem;
  background: url("../img/link_arrow.svg") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  -webkit-transition: background 0s ease-out .15s;
  -moz-transition: background 0s ease-out .15s;
  transition: background 0s ease-out .15s;
}

.p-entry .section__job .job__link .c-copy p {
  line-height: 1.35714;
}

.p-entry .section__job .job__link:hover {
  color: #023894;
}

.p-entry .section__job .job__link:hover .job__link__ttl:after {
  -webkit-animation: forward .5s ease-out;
     -moz-animation: forward .5s ease-out;
          animation: forward .5s ease-out;
  background: url("../img/link_arrow_hover.svg") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
}

.p-contact .mv__ttl {
  padding-left: 3rem;
}

.p-contact .mv__ttl__jp {
  padding-left: 5.5rem;
}

.p-contact .section__job {
  padding: 10rem 0;
}

.p-contact .section__job .c-header__v2 {
  margin-bottom: 5.7rem;
}

.p-contact .contact__desc__ttl {
  color: #023894;
  font-size: 1.8rem;
  font-weight: 700;
  border-bottom: 1px solid;
  padding-bottom: 2.3rem;
  margin-bottom: 6rem;
  text-align: center;
}

.p-contact .contact__desc__wrap dl {
  border-bottom: 1px solid #E2E2E2;
  padding: 2.5rem 0;
}

@media screen and (min-width: 769px) {
  .p-contact .contact__desc__wrap dl {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p-contact .contact__desc__wrap dl dt {
    width: 27.5rem;
  }
}

.p-contact .contact__desc__wrap dl:first-child {
  border-top: 1px solid #E2E2E2;
}

.p-contact .contact__desc__wrap dl dt {
  color: #023894;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-weight: 700;
  letter-spacing: .1em;
  line-height: 1.36;
}

@media screen and (min-width: 769px) {
  .p-contact .contact__desc__wrap dl dt {
    line-height: 1.75;
  }
}

.p-contact .contact__desc__wrap dl dd {
  width: 100%;
}

.p-contact .contact__desc__wrap dl p, .p-contact .contact__desc__wrap dl ul li {
  line-height: 1.36;
}

@media screen and (min-width: 769px) {
  .p-contact .contact__desc__wrap dl p, .p-contact .contact__desc__wrap dl ul li {
    line-height: 1.75;
  }
}

.p-contact .contact__desc__wrap dl p + p, .p-contact .contact__desc__wrap dl p + ul {
  margin-top: 1.9rem;
}

.p-contact .contact__desc__wrap dl ul + p, .p-contact .contact__desc__wrap dl ul + ul {
  margin-top: 1.9rem;
}

.p-contact .contact__desc__wrap dl .list__type01 > li:not(:last-child) {
  margin-bottom: 1.9rem;
}

.p-contact .contact__desc__wrap dl .list__type02 li {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
}

.p-contact .contact__desc__wrap dl .list__type02 li:before {
  content: '※';
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.p-contact .contact__desc__wrap dl .list__type03 li {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
}

.p-contact .contact__desc__wrap dl .list__type03 li:before {
  content: '・';
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.p-contact .section__contact {
  padding: 10rem 0 19.7rem;
}

.p-contact .section__contact .c-header__v2 {
  margin-bottom: 6.2rem;
}

@media screen and (min-width: 769px) {
  .p-contact .section__contact .contact__form form {
    padding: 0 5.2rem 0 6.5rem;
  }
}

.p-contact .section__contact .contact__form .contact__form__wrap:not(:last-child) {
  margin-bottom: 2.5rem;
}

@media screen and (max-width: 768px) {
  .p-contact .section__contact .contact__form .contact__form__wrap:not(:last-child) {
    margin-bottom: 1.5rem;
  }
}

.p-contact .section__contact .contact__form .contact__form__wrap dt {
  font-weight: 700;
  color: #023894;
  margin-bottom: 1rem;
}

@media screen and (max-width: 768px) {
  .p-contact .section__contact .contact__form .contact__form__wrap dt {
    margin-bottom: 1.5rem;
  }
}

.p-contact .section__contact .contact__form .contact__form__wrap dd {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
}

.p-contact .section__contact .contact__form .contact__form__wrap dd > .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

@media screen and (max-width: 768px) {
  .p-contact .section__contact .contact__form .contact__form__wrap dd {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

@media screen and (min-width: 769px) {
  .p-contact .section__contact .contact__form .contact__form__wrap dd .c-input + .c-input {
    margin-left: 1.5rem;
  }
}

@media screen and (max-width: 768px) {
  .p-contact .section__contact .contact__form .contact__form__wrap dd .c-input + .c-input {
    margin-top: 2rem;
  }
}

.p-contact .section__contact .contact__form .contact__form__wrap dd .fullname {
  width: 27.5rem;
}

@media screen and (min-width: 769px) {
  .p-contact .section__contact .contact__form .contact__form__wrap dd .fullname {
    margin-right: 1.5rem;
  }
}

.p-contact .section__contact .contact__form .contact__form__wrap dd .lastname {
  width: 27.5rem;
}

@media screen and (max-width: 768px) {
  .p-contact .section__contact .contact__form .contact__form__wrap dd .lastname {
    margin-top: 2rem;
  }
}

.p-contact .section__contact .privacy {
  padding: 1rem 0 0;
  text-align: center;
  margin-bottom: 4.3rem;
}

@media screen and (max-width: 768px) {
  .p-contact .section__contact .privacy {
    padding-top: 2.6rem;
  }
}

.p-contact .section__contact .privacy_box {
  display: inline-block;
  position: relative;
}

.p-contact .section__contact .privacy_box input {
  opacity: 0;
  visibility: hidden;
  width: 0;
  height: 0;
  margin: 0;
  position: absolute;
}

.p-contact .section__contact .privacy_box input:checked ~ label:before {
  background: url("../img/checkbox_active.jpg") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
}

.p-contact .section__contact .privacy_box label {
  display: block;
  position: relative;
  font-weight: 700;
  cursor: pointer;
  padding-left: 3rem;
  color: #023894;
}

.p-contact .section__contact .privacy_box label:before {
  width: 1.3rem;
  height: 1.3rem;
  background: url("../img/checkbox.jpg") no-repeat;
  -moz-background-size: 100%;
       background-size: 100%;
  top: 50%;
  -webkit-transform: translateY(-50%);
     -moz-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  content: '';
  visibility: visible;
  position: absolute;
}

.p-contact .section__contact .privacy_box a {
  color: #023894;
  border-bottom: 1px solid transparent;
  -webkit-transition: border-color .3s ease-out;
  -moz-transition: border-color .3s ease-out;
  transition: border-color .3s ease-out;
}

.p-contact .section__contact .privacy_box a:hover {
  border-color: #023894;
}

.p-contact .section__contact .c-btn {
  margin: 0 auto;
}

.p-contact .contact__complete {
  padding: 19.2rem 0 11rem 0;
}

@media screen and (min-width: 769px) {
  .p-contact .contact__complete .row {
    width: 84.7rem;
  }
}

.p-contact .contact__complete__ttl {
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: .08em;
  margin-bottom: 3rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .p-contact .contact__complete__ttl {
    font-size: 2rem;
  }
}

.p-contact .contact__complete .c-copy02 {
  text-align: center;
  margin-bottom: 4rem;
}

.p-contact .contact__complete .c-box__gray {
  padding: 3.2rem 4.7rem 3.4rem;
}

@media screen and (max-width: 768px) {
  .p-contact .contact__complete .c-box__gray {
    padding-left: 2.3rem;
    padding-right: 2.3rem;
  }
}

.p-contact .contact__complete .c-box__gray p, .p-contact .contact__complete .c-box__gray ul li {
  color: #585858;
  line-height: 1.5;
}

.p-contact .contact__complete .c-box__gray ul {
  padding: 3rem 0;
}

.p-contact .contact__complete .c-box__gray .text__bold {
  font-size: 2rem;
  color: #000;
}

.p-contact .contact__complete .c-box__gray .text_underLine {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(80%, transparent), color-stop(20%, #FFB307));
  background: -webkit-linear-gradient(top, transparent 80%, #FFB307 20%);
  background: -moz- oldlinear-gradient(top, transparent 80%, #FFB307 20%);
  background: linear-gradient(180deg, transparent 80%, #FFB307 20%);
}

.p-contact .contact__complete .c-box__gray .c-btn {
  line-height: 1;
  width: 22rem;
  height: 4.7rem;
  margin-top: 2.8rem;
}

.p-contact .contact__complete .c-box__gray .c-btn span {
  position: relative;
  -moz-border-radius: 0;
       border-radius: 0;
  font-size: 1.4rem;
  background: #FFB307;
  color: #fff;
}

.p-contact .contact__complete .c-box__gray .c-btn span:after {
  display: none;
}

.p-contact .contact__complete .c-box__gray .c-btn span:before {
  content: '＞';
  display: block;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
     -moz-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 1rem;
}

.p-contact .contact__complete .c-box__gray .c-btn:hover {
  -moz-box-shadow: none;
       box-shadow: none;
}

.p-contact .contact__complete .c-box__gray .c-btn:hover span {
  -moz-box-shadow: inset 0 0 0 3em #000;
       box-shadow: inset 0 0 0 3em #000;
}

.p-contact .contact__complete .contact__link {
  display: -webkit-inline-box;
  display: -moz-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  margin: 4rem 0 0 5.5rem;
}

@media screen and (max-width: 768px) {
  .p-contact .contact__complete .contact__link {
    margin-left: 0;
  }
}

.p-contact .contact__complete .contact__link:after {
  content: '＞';
  display: block;
  margin-left: 1rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-transition: -webkit-transform .3s ease-out;
  transition: -webkit-transform .3s ease-out;
  -moz-transition: transform .3s ease-out, -moz-transform .3s ease-out;
  transition: transform .3s ease-out;
  transition: transform .3s ease-out, -webkit-transform .3s ease-out, -moz-transform .3s ease-out;
}

.p-contact .contact__complete .contact__link:hover:after {
  -webkit-transform: translateX(0.5rem);
     -moz-transform: translateX(0.5rem);
      -ms-transform: translateX(0.5rem);
          transform: translateX(0.5rem);
}

@media screen and (max-width: 768px) {
  .p-entry .section__recruit .recruit__img {
    position: relative;
    z-index: 1;
  }
  .p-entry .section__recruit .recruit__img img {
    height: 28rem;
  }
  .p-entry .section__recruit .recruit__cont {
    padding-top: 3.5rem;
  }
  .p-entry .section__recruit .recruit__cont:before, .p-entry .section__recruit .recruit__cont:after {
    top: -7rem;
  }
  .p-entry .section__recruit .recruit__cont .recruit__ttl {
    font-size: 2rem;
  }
  .p-entry .section__recruit .recruit__cont .c-copy02 p {
    font-size: 1.4rem;
  }
  .p-entry .section__job .job__wrap {
    margin-bottom: 5rem;
  }
  .p-entry .section__job .job__item:not(:last-child) {
    margin-bottom: 3rem;
  }
  .p-entry .section__job .job__item__text {
    font-size: 1.4rem;
  }
  .p-entry .section__job .job__link {
    margin: 0 -3rem;
  }
  .p-entry .section__job .job__link__ttl {
    padding: 0 3rem 1.5rem;
  }
  .p-entry .section__job .job__link .c-copy {
    padding: 0 3rem;
  }
  .p-contact .contact__desc__ttl {
    font-size: 1.4rem;
  }
  .p-contact .contact__desc__wrap dl dt {
    margin-bottom: 1rem;
  }
  .p-contact .section__job {
    padding-bottom: 5rem;
  }
  .p-contact .section__contact {
    padding: 5rem 0 10rem;
  }
}

.bg_gray {
  background: #F2F3F4;
}

.text_red {
  color: #FF5A5A;
}

.text_blue {
  color: #173371;
}

.text__bold {
  font-weight: 700;
}

.breadcrumb {
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}

.breadcrumb-side {
  color: #fff;
  font-size: 1.4rem;
  line-height: 1.3572;
  background: #3C4455;
}

.breadcrumb-side__inner {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}

.breadcrumb-side__root {
  background: #173371;
  padding: 0 1.8rem;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
     -moz-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.breadcrumb-side__root.w-f-1per3 {
  width: 33.333%;
}

.breadcrumb-side__root.w-f-1per4 {
  width: 25%;
}

.breadcrumb-side__list {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
     -moz-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}

.breadcrumb-side__list li {
  width: 100%;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  text-align: center;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
     -moz-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 7.2rem;
}

.breadcrumb-side__list li a {
  padding: 0.5rem 0;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  transition: all 0.3s ease;
  display: block;
}

@media screen and (min-width: 769px) {
  .breadcrumb-side__list li a:hover {
    color: #3CC6C0;
  }
}

.breadcrumb-side__list li.is-current {
  background: #5F6674;
}

.breadcrumb-side__list li.is-current a {
  pointer-events: none;
}

@media screen and (min-width: 769px) {
  .breadcrumb-side__list li.is-current a:hover {
    color: inherit;
    pointer-events: none;
  }
}

.breadcrumb > ul {
  margin-top: 1.7rem;
}

.breadcrumb > ul li {
  display: inline-block;
  font-size: 1.3rem;
  line-height: 1.3077;
}

.breadcrumb > ul li:not(:first-child) {
  position: relative;
  padding-left: 1.5rem;
  margin-left: 1rem;
}

.breadcrumb > ul li:not(:first-child):after {
  position: absolute;
  z-index: 1;
  content: '＞';
  left: -0.5rem;
  top: 0;
}

.breadcrumb > ul li a {
  display: inline-block;
  color: inherit;
}

@media screen and (min-width: 769px) {
  .breadcrumb > ul li a {
    -webkit-transition: opacity 0.3s ease;
    -moz-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
  }
  .breadcrumb > ul li a:hover {
    opacity: 0.55;
  }
}

@media screen and (max-width: 768px) {
  .breadcrumb {
    display: none;
  }
}
