@charset "UTF-8";
@import url('https://fonts.googleapis.com/css?family=Work+Sans:500');

/*================================================
 *  一般・共通設定
 ================================================*/

body {
  font-size: 16px;
  font-family: 'Yu Gothic Medium', '游ゴシック Medium', YuGothic, '游ゴシック体', 'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  color: #4d4d4d;
}

p {
  font-size: 16px;
}

a {
  color: #4d4d4d;
  text-decoration: none;
}

a:hover {
  opacity: 0.7;
}

.linearAnime_one,
.linearAnime a {
  transition-property: all;
  -moz-transition: 0.1s linear;
  -webkit-transition: 0.1s linear;
  -o-transition: 0.1s linear;
  -ms-ttransition: 0.1s linear;
  transition: 0.1s linear;
}

img {
  vertical-align: bottom;
}

/*色*/
.color_red {
  color: #e53828;
}

/* position */
.relative {
  position: relative;
}
.absolute {
  position: absolute;
}
/* sp/pcの切替 */
.sp {
  display: none;
}
.pc {
  display: block;
}
/*文字揃え*/
.ta-l {
  text-align: justify;
  text-justify: inter-ideograph;
}
.ta-r {
  text-align: right;
}
.ta-c {
  text-align: center !important;
}
.pcspText {
  /*PC：中央揃え・SP左揃え用*/
  text-align: center;
}
/*文字太さ*/
.fontNormal {
  font-weight: normal !important;
}
.fontBold {
  font-weight: bold !important;
}

/*文字種類*/
.font_mincho {
  font-family: '游明朝', YuMincho, 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', serif;
}

/*================================================
 *  ヘッダー
 ================================================*/
header {
  background-color: #fff;
  width: 100%;
  padding: 50px 0;
  position: relative;
  margin-bottom: 10px;
}
header:after {
  position: absolute;
  background: url(../images/header_line.jpg) top center repeat;
  content: '';
  bottom: -10px;
  left: 0;
  width: 100%;
  height: 10px;
}
header .header_wrap {
  max-width: 1100px;
  width: 100%;
  display: table;
  table-layout: fixed;
  margin: 0 auto;
}
header .header_wrap > div {
  display: table-cell;
  vertical-align: middle;
}
header .header_wrap > div.logo_maru {
  padding-left: 30px;
}
header .header_wrap > div.logo {
  width: 265px;
}
header .ex-icon {
  display: block;
  width: 50px;
  position: absolute;
  right: 30px;
  top: 30px;
}
header .ex-icon img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 799px) {
  header .ex-icon {
    display: none;
  }
}

/*******グローバルナビ*******/
header .header_wrap nav {
  float: right;
  padding-right: 40px;
}
header .header_wrap nav ul {
  display: table;
  table-layout: fixed;
}
header .header_wrap nav ul li {
  display: table-cell;
  height: 115px;
  text-align: center;
  vertical-align: middle;
  padding: 0 20px;
}
header .header_wrap nav ul li a {
  letter-spacing: 2px;
  display: block;
  -webkit-writing-mode: tb-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: tb-rl;
  /* IE独自仕様 */
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -o-writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  font-size: 12px;
  padding: 0 14px;
  height: 115px;
}
header .header_wrap nav ul li a:hover,
header .header_wrap nav ul li a.active {
  background: url(../images/menu_bg.png) top center no-repeat;
  opacity: 1;
}

.hamburger {
  display: none;
}

/*================================================
 *  ページタイトル
 ================================================*/
#page_title {
  padding: 0 0 60px;
  text-align: center;
}
#page_title span {
  background: url('../images/pagetitle_bg.png') center center no-repeat;
  display: block;
  margin: 0 auto;
  padding: 14px 0 12px;
  width: 150px;
  text-align: center;
}

/*================================================
 *  コンテンツ
 ================================================*/
.wrap {
  width: 740px;
  margin: 0 auto;
}
#contents {
  padding: 100px 0 80px;
  box-sizing: border-box;
  position: relative;
}

/*見出し*/
h1 {
  position: absolute;
  top: 50px;
  left: 50%;
  margin-left: -490px;
  font-size: 10px;
  color: #979797;
  letter-spacing: 2px;
  -webkit-writing-mode: tb-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: tb-rl;
  /* IE独自仕様 */
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -o-writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
}

/*******箇条書きリスト*******/
.kome_list li,
.disc_list li,
.indent_list li {
  list-style-position: inside;
  padding-left: 1em;
  text-indent: -1em;
}
/*※箇条書き*/
.kome_list li:before {
  display: inline;
  content: '\203b';
}
/*・箇条書き*/
.disc_list li:before {
  display: inline;
  content: '\30fb';
}

/*******ボタン*******/
.btn {
  text-align: center;
}
.btn a,
.btn div a,
.btn input {
  border: none;
  background-color: #979797;
  color: #fff !important;
  display: inline-block;
  padding: 1em 0 0.9em;
  width: 200px;
  font-size: 13px;
  font-weight: bold;
  text-align: center;
  cursor: pointer;
  text-decoration: none !important;
}
.btn .gray {
  /*修正ボタン*/
  margin: 0 20px 0 0;
  background-color: #c8c8c8;
}
.btn div a,
.btn input[type='submit'] {
  /*トップに戻る+同意*/
  margin: 0;
}
.btn input:hover,
.btn a:hover {
  opacity: 0.7 !important;
}

/*================================================
 *  フッター
 ================================================*/
footer {
  background-color: #fff;
  text-align: center;
  position: relative;
  padding: 65px 0 15px;
  width: 100%;
  left: 0;
  bottom: 0;
}
footer .pagetop {
  top: 0;
  right: 50%;
  margin-right: -410px;
  cursor: pointer;
}
footer .copy {
  margin-top: 20px;
}
footer .copy small {
  font-size: 10px;
}

/*================================================
 *  タブレット/スマートフォン向けデザイン
 ================================================*/
/* スクロールバーを考慮して20px大きいサイズで切り替え */
@media screen and (max-width: 799px) {
  body {
    font-size: 4vw;
  }
  p {
    font-size: 4vw;
  }

  img {
    max-width: 100%;
  }
  /*文字揃え*/
  .pcspText {
    /*PC：中央揃え・SP左揃え用*/
    text-align: justify;
    text-justify: inter-ideograph;
  }
  /* sp/pcの切替 */
  .sp {
    display: block;
  }
  .pc {
    display: none;
  }

  /*================================================
 *  ヘッダー
 ================================================*/
  header {
    position: fixed;
    top: 0;
    left: 0;
    padding: 4vw 3vw;
    z-index: 10000;
    margin-bottom: 0;
  }
  header:after {
    content: none;
  }
  header .header_wrap {
    max-width: inherit;
  }
  header .header_wrap > div.logo_maru {
    padding-left: 0;
  }
  header .header_wrap > div.logo_maru img {
    height: 8vw;
  }
  header .header_wrap > div.navi {
    display: none;
  }
  header .header_wrap > div.logo {
    width: 50vw;
  }
  header .header_wrap > div.logo img {
    height: 6vw;
  }

  .hamburger {
    display: block;
    left: auto;
    right: 0;
    width: 16vw;
    height: 16vw;
    padding: 3vw 4vw;
    z-index: 10000;
  }
  .hamburger__icon {
    margin-top: 4.5vw;
    margin-bottom: 0;
  }
  .hamburger__icon,
  .hamburger__icon:before,
  .hamburger__icon:after {
    background-color: #ccc;
    width: 8vw;
    height: 1vw;
  }
  .hamburger.active .hamburger__icon:before,
  .hamburger.active .hamburger__icon:after {
    background-color: #ccc;
  }
  .hamburger__icon:before {
    top: -2.5vw;
  }
  .hamburger__icon:after {
    top: 2.5vw;
  }
  .hamburger.active .hamburger__icon:before {
    transform: translateY(2.5vw) rotate(45deg);
  }
  .hamburger.active .hamburger__icon:after {
    transform: translateY(-2.5vw) rotate(-45deg);
  }

  /*================================================
 *  ナビゲーション
 ================================================*/
  .fat-nav {
    background: rgba(255, 255, 255, 1);
  }
  .fat-nav ul {
    vertical-align: top;
    padding-top: 20vw;
  }
  .fat-nav ul li {
    text-align: left;
    padding: 0;
  }
  .fat-nav ul li a {
    padding: 5vw 0;
    display: block;
  }
  .fat-nav ul li img {
    height: 5vw;
  }
  .fat-nav ul li.ex-icon {
    width: 50px;
    margin-left: auto;
    margin-right: 20px;
  }
  .fat-nav ul li.ex-icon img {
    width: 100%;
    height: auto;
  }
  .fat-nav ul li.ex-icon a {
    padding: 0;
  }

  /*================================================
 *  ページタイトル
 ================================================*/
  #page_title {
    padding: 0 0 8vw;
  }
  #page_title span {
    background: url('../images/pagetitle_bg.png') center center no-repeat;
    background-size: auto 14vw;
    padding: 5vw 0;
    width: 50vw;
  }

  /*================================================
 *  コンテンツ
 ================================================*/
  .wrap {
    width: 90%;
  }
  #contents {
    padding: 26vw 0 0; /*header16vw分含む*/
  }

  /*******ボタン*******/
  .btn a,
  .btn div a,
  .btn input {
    display: block;
    width: 70%;
    font-size: 5vw;
    padding: 0.8em 0;
  }
  .btn .gray {
    /*修正ボタン*/
    margin: 0 auto 5vw;
  }
  .btn div a,
  .btn input[type='submit'] {
    margin: 0 auto;
  }

  /*================================================
 *  フッター
 ================================================*/
  footer {
    padding: 30vw 0 8vw;
  }
  footer .pagetop {
    top: 5vw;
    right: 5vw;
    margin-right: 0;
  }
  footer .pagetop img {
    height: 25vw;
  }
  footer .logo img {
    width: 30vw;
  }
  footer .copy {
    margin-top: 5vw;
  }
  footer .copy small {
    font-size: 2.8vw;
  }
}
