@charset "UTF-8";

/* CSS Document */

/**
BUTTON
**/

.btn_set {
  margin-top: 4rem;
}

.btn_subset {
  margin-top: 1rem;
}

/* 角丸ボタン 背景：赤 文字：白 */
.btn_action {
  display: block;
  width: 210px;
  margin: 0 auto;
  padding: 1rem;
  background-color: #ed1c24;
  text-decoration: none;
  text-align: center;
  font-weight: bold;
  font-size: 1.14rem;
  color: #fff;
  border-radius: 2px;
}

.btn_action:hover {
  text-decoration: none;
  opacity: 0.7;
}

/* 角丸ボタン 文字・ボーダー：黒 */
.btn_sub_action {
  display: block;
  width: 50%;
  margin: 0 auto;
  padding: 0.4rem 0;
  background-color: #fff;
  text-decoration: none;
  text-align: center;
  font-weight: bold;
  font-size: 1rem;
  color: #2c2c2c;
  border-radius: 2px;
  border: 1px solid #000;
}

.btn_sub_action:hover {
  text-decoration: none;
  background-color: #2c2c2c;
  color: #fff;
}

/* 四角いボタン 背景：白 文字：黒 */
.btn_detail {
  display: block;
  width: 280px;
  margin: 0 auto;
  background-color: #fff;
  border: 1px solid #2c2c2c;
  border-radius: 2px;
  line-height: 3.2rem;
  color: #2c2c2c;
  text-align: center;
  font-size: 1.3rem;
}

.btn_detail:hover {
  text-decoration: none;
  opacity: 0.7;
}

/* 四角いボタン  文字・ボーダー：黒 */
.btn_square {
  display: block;
  width: 280px;
  margin: 0 auto;
  background-color: #fff;
  line-height: 3.2rem;
  border: 1px solid #000;
  border-radius: 2px;
  color: #2c2c2c;
  text-align: center;
  font-size: 1.3rem;
}

.btn_square:hover {
  text-decoration: none;
  background-color: #2c2c2c;
  color: #fff;
}

.btn_square i {
  margin: 0 5px;
}

/* 四角いボタン  文字・ボーダー：黒 */
.btn_sub_square {
  display: block;
  width: 50%;
  margin: 0 auto;
  padding: 0.4rem 0;
  background-color: #fff;
  border: 1px solid #000;
  text-decoration: none;
  text-align: center;
  font-weight: bold;
  font-size: 1rem;
  color: #2c2c2c;
  border-radius: 2px;
}

.btn_sub_square:hover {
  text-decoration: none;
  background-color: #2c2c2c;
  color: #fff;
}

/* 角丸ボタン 文字・ボーダー：白 */
.btn_cercle {
  display: block;
  width: 210px;
  margin: 0 auto;
  background-color: #fff;
  line-height: 3.2rem;
  border: 1px solid #fff;
  color: #fff;
  text-align: center;
  border-radius: 2rem;
  font-size: 1.1rem;
}

.btn_cercle:hover {
  text-decoration: none;
  background-color: #fff;
  color: #2c2c2c;
}

/*
リンク・ボタン
PC: > 付きリンク
SP: 青枠のボタン
*/

/* スマホ 幅が 0px - 599px */
@media screen and (max-width: 599px) {
  .btn_sp-blue-btn_pc-text-angle {
    background-color: #fff;
    border: 1px solid #0067af;
    display: block;
    width: 100%;
    padding: 0.5rem 0;
    text-align: center;
    content: '';
  }

  .btn_sp-blue-btn_pc-text-angle:hover {
    text-decoration: none;
    background-color: #0067af;
    color: #fff;
  }
}

/* PC 幅が 600px 以上 */
@media screen and (min-width: 600px) {
  .btn_sp-blue-btn_pc-text-angle::before {
    content: '\f105';
    font-family: FontAwesome, sans-serif;
    margin-right: 0.4rem;
  }
}

/* 申し込むボタン */
.btn_entry {
  width: 100%;
  height: 100%;
  display: block;
  background-color: #f03;
  color: #fff;
  border-radius: 2rem;
  position: relative;
  text-align: center;
  line-height: 2.5;
  font-size: 1.1rem;
}

.btn_entry::after {
  content: '\f105';
  font-family: FontAwesome, sans-serif;
  color: #fff;
  line-height: 1;
  position: absolute;
  right: 1rem;
  top: 50%;
  margin-top: -0.5rem;
}

.btn_entry:hover {
  opacity: 0.7;
  text-decoration: none;
}

.btn_entry-download {
  width: 100%;
  height: 100%;
  display: block;
  background-color: #f03;
  color: #fff;
  border-radius: 2rem;
  position: relative;
  text-align: center;
  line-height: 2.5;
  font-size: 1.1rem;
}

.btn_entry-download::after {
  content: '\f019';
  font-family: FontAwesome, sans-serif;
  margin-left: 0.2rem;
}

.btn_entry-download:hover {
  opacity: 0.7;
  text-decoration: none;
}

/* --------------
HEAD
----------------- */
.head3_default {
  font-size: 1.6rem;
  font-weight: bold;
  margin: 0 1rem 2rem;
}

.head3_align-center {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  margin: 0 0 3rem;
}

.head3_border-left {
  border-left: 1rem solid #f5d000;
  font-size: 1.6rem;
  font-weight: bold;
  padding: 0 0 0 1rem;
  margin: 0 1rem 2rem;
}

.head4_default {
  font-size: 1.2rem;
  font-weight: bold;
  margin: 0 1rem 1rem;
}

.head4_align-center {
  font-size: 1.2rem;
  font-weight: bold;
  text-align: center;
  margin: 0 1rem 1rem;
}

/* PC 幅が 600px 以上 */
@media screen and (min-width: 600px) {
  .head3_default {
    margin: 0 0 2rem;
  }

  .head3_border-left {
    margin: 0 0 2rem;
  }

  .head4_default {
    margin: 0 0 1rem;
  }
}

/* --------------
見出し
----------------- */
.section-head {
  margin-bottom: 4rem;
  padding: 1rem;
  background-color: #373737;
  font-weight: bold;
  font-size: 1.43rem;
  color: #fff;
  -webkit-border-radius: 4px;
  border-radius: 4px;
}

.section-subhead {
  margin-bottom: 1rem;
  border-left: 6px solid #ed1c24;
  padding-left: 1rem;
  line-height: 1.3;
  font-weight: bold;
  font-size: 1.43rem;
}

/* --------------
TEXT
----------------- */
.text-larger {
  font-size: 130%;
}

.text-smaller {
  font-size: 70%;
}

.text-default-color {
  color: #2c2c2c;
}

.text-yellow {
  color: #f5d000;
}

.text-blue {
  color: #0067af;
}

.text-gray {
  color: #c4c4c4;
}

.text-emphasis_red {
  color: #f03;
}

.text-align-center {
  text-align: center;
}

.text-align-right {
  text-align: right;
}

/* --------------
リンクマーク
----------------- */

.text-link_mark-left_angle-right::before {
  content: '\f105';
  font-family: FontAwesome, sans-serif;
  margin-right: 0.4rem;
}

.text-link_mark-right_angle-right::after {
  content: '\f105';
  font-family: FontAwesome, sans-serif;
  margin: 0 0.2rem;
}

.text-link_mark-right_external-link::after {
  content: '\f08e';
  font-family: FontAwesome, sans-serif;
  margin: 0 0.2rem;
}

.text-link_mark-left_pdf::before {
  content: '\f1c1'; /* PDFアイコン */
  font-family: FontAwesome, sans-serif;
  margin: 0 0.2rem;
}

.btn_sp-blue-btn_pc-text-angle.text-link_mark-right_external-link::after,
.text-link_mark-left_angle-right.text-link_mark-right_external-link::after {
  /* 他のマーク等と組み合わせて使うときは左右マージンを少し広げる */
  margin: 0 0.5rem;
}

.layout_global-navi .fa-chevron-down,
.layout_global-navi .fa-external-link {
  margin-left: 0.4rem;
  color: #00d9d9;
}

/* --------------
リストマーク
----------------- */

.list-mark_default {
  list-style: disc outside;
  margin: 0 0 0 1.4rem;
  line-height: 2;
}

.list-mark_notes {
  /* 米印付きのリスト */
  list-style: none inside;
  text-indent: -0.8rem;
  margin: 0.5rem 0 1rem 0.8rem;
  line-height: 1.6;
  font-size: 0.9rem;
  color: #767676;
}

.list-mark_notes-number {
  /* 米印付きのリスト */
  list-style: none inside;
  text-indent: -1.8rem;
  margin: 0 0 1rem 1.8rem;
  line-height: 1.6;
  font-size: 0.9rem;
  color: #767676;
}

/* PC 幅が 600px 以上 */
@media screen and (min-width: 600px) {
  .list-mark_notes {
    /* 米印付きのリスト */
    text-indent: -1.2rem;
    margin: 0.5rem 0 1rem 1.4rem;
  }
}

/* --------------
取り消し線
----------------- */

.del-red {
  color: #f03;
}

/* unit */

.unit {
  font-size: 80%;
}

/* -------------
TABLE
--------------- */

/* 情報量の多いTABLE用のスクロール枠 */

/* スマホ 幅が 0px - 599px */
@media screen and (max-width: 599px) {
  .table-scroll_wrapper {
    overflow-x: auto;
    width: 100%;
  }
}

/* th が左側にあるTABLE */

.table_th-left {
  width: 100%;
  margin: 0 0 2rem;
}

.table_th-left_row {
  border-bottom: 1px solid #dcdcdc;
}

.table_th-left_row:first-child {
  border-top: 1px solid #dcdcdc;
}

.table_th-left_head {
  padding: 1rem 0.5rem;
  background-color: #f4f4f4;
  vertical-align: top;
}

.table_th-left_data {
  padding: 1rem 0.5rem 1rem 1rem;
}

/* PC 幅が 600px 以上 */
@media screen and (min-width: 600px) {
  .table_th-left_head {
    padding: 1rem 2rem;
    white-space: nowrap;
  }

  .table_th-left_data {
    padding: 1rem 2rem 1rem 3rem;
  }
}

/* th が上側にあるTABLE */

.table_th-top {
  width: 100%;
  margin: 0 0 2rem;
}

.table_th-top_head {
  background-color: #f4f4f4;
  border: 1px solid #dcdcdc;
  padding: 0.5rem;
  text-align: center;
}

.table_th-top_data {
  border: 1px solid #dcdcdc;
  padding: 0.5rem;
  text-align: center;
}

/* PC 幅が 600px 以上 */
@media screen and (min-width: 600px) {
  .table_th-top_head {
    padding: 1rem 2rem;
  }

  .table_th-top_data {
    padding: 1rem 2rem;
  }
}

/* -------------
TABLE
証明書価格一覧表
--------------- */

/*
 パートナーバナー
*/

.footer-banner {
  text-align: center;
}

.footer-banner img:hover {
  opacity: 0.5;
}

/*
 PRバナー
*/

.pr-banner {
  text-align: center;
  margin: 40px auto;
}

.pr-banner img:hover {
  opacity: 0.5;
}

.pr-banner.pr-plan {
    margin: 40px auto 0px;
}

.banner_item + .banner_item {
  margin-top: 20px;
}

/* スマホ 幅が 0px - 599px */
@media screen and (max-width: 599px) {
  .banner_pr {
    display: none;
  }

  .banner_pr_sp {
    margin: 0 auto;
    display: block;
  }
  .pr-banner {
    margin: 0px auto;
  }
}

/* PC 幅が 600px 以上 */
@media screen and (min-width: 600px) {
  .banner_pr {
    display: block;
  }

  .banner_pr_sp {
    display: none;
  }
}