@charset "UTF-8";
/* CSS Document */
@import url("https://fonts.googleapis.com/css2?family=Heebo:wght@400;500;700;900&display=swap");
/* -------------------------------------------------
-------------------------------------------------
*01. pc common
*02. header
*03. footer
*04. 共通CSS (第2階層)
*05. 各ページ

-------------------------------------------------
------------------------------------------------- */
/* ---------------------------

01. pc common

---------------------------*/
html {
  font-size: 62.5%; }

/* 10px */
body {
  background-color: #FFF;
  color: #252525;
  font-size: 15px;
  font-size: 1.5rem;
  font-family: 'Heebo' , "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-feature-settings: "palt";
  letter-spacing: 0.1rpx;
  letter-spacing: 0.1rem;
  line-height: 30px;
  line-height: 3rem;
  overflow-x: hidden;
  position: relative;
  width: 100%; }

img {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-touch-callout: none;
  -moz-user-select: none;
  touch-callout: none;
  image-rendering: -webkit-optimize-contrast;
  user-select: none; }

.sp_none {
  display: none !important; }

.sp_noWrap {
  display: block;
  white-space: nowrap; }

.sp_left {
  text-align: left !important; }

.sp_center {
  text-align: center; }

.sp_mb0 {
  margin-bottom: 0 !important; }

.sp_white_space_nowrap {
  white-space: nowrap !important; }

.ancher_section {
  margin-top: -120px;
  padding-top: 120px; }

.container {
  margin: 0 20px; }

#wrapper {
  margin-top: 0px; }

.section_s {
  margin-bottom: 40px; }

.section {
  margin-bottom: 60px !important; }

.section_l {
  margin-bottom: 80px !important; }

.line_height_small {
  line-height: 18px;
  line-height: 1.8rem; }

.line_height_medium {
  line-height: 24px;
  line-height: 2.4rem; }

.line_height_large {
  line-height: 32px;
  line-height: 3.2rem; }

.border_gray {
  border: 1px solid #DDD; }

.bg_beige {
  background: url("../images/common/bg_baige.png") repeat;
  background-size: 66px; }

.bg_gray {
  background-color: #eee; }

.bg_white {
  background-color: #FFF; }

.text_white {
  color: #FFF; }

.text_red {
  color: #a70000; }

.text_blue {
  color: #3b5998; }

.font-weight-medium {
  font-weight: 600; }

.text_ss {
  font-size: 11px;
  font-size: 1.1rem; }

.d_block {
  display: block; }

.d-flex {
  display: flex; }

.sp_d-flex {
  display: flex; }

.align-items-center {
  align-items: center; }

.justify-content-between {
  justify-content: space-between; }

.sp_justify-content-between {
  justify-content: space-between; }

.sp_flex-wrap-reverse {
  flex-wrap: wrap-reverse; }

.align-self-center {
  align-self: center; }

.flex-wrap {
  flex-wrap: wrap; }

.sp_flex-wrap {
  flex-wrap: wrap; }

.flex-wrap {
  flex-wrap: wrap; }

.sp_float_left {
  float: left; }

.sp_float_right {
  float: right; }

.ankerlink {
  padding-top: 30px;
  margin-top: -30px; }

p {
  margin-bottom: 1.5em; }

.gothic {
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif; }

.mincho, .qa_dl dt:before, .qa_dl dd:before {
  font-family: 'Playfair Display', "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }

.text_small {
  font-size: 11px !important;
  font-size: 1.1rem !important;
  line-height: 14px !important;
  line-height: 1.4rem !important; }

.text_medium {
  font-size: 16px !important;
  font-size: 1.6rem !important; }

.text_large {
  font-size: 18px;
  font-size: 1.8rem; }

.sp_text_small {
  font-size: 13px;
  font-size: 1.3rem;
  line-height: 22px;
  line-height: 2.1rem; }

h1, h2, h3, h4, h5 {
  color: #000;
  font-weight: normal; }

hr {
  border-top: 1px solid #DDD;
  border-right: none;
  border-bottom: none;
  border-left: none;
  margin: 15px 0; }

.list_circle {
  list-style: none;
  margin-bottom: 2em; }
  .list_circle li {
    padding-left: 10px;
    position: relative; }
    .list_circle li:before {
      background-color: #000;
      border-radius: 20px;
      content: "";
      display: block;
      width: 3px;
      height: 3px;
      position: absolute;
      left: 0;
      top: 0.8em; }

.img_w_100 {
  width: 100%;
  height: auto; }

.link_border {
  text-decoration: underline !important; }

/* button */
input[type="submit"].btn_submit {
  background-color: #252525;
  border: none;
  border-radius: 5px;
  color: #FFF !important;
  display: block;
  font-size: 18px;
  letter-spacing: 0.2rem;
  margin: 0 auto;
  outline: none;
  padding: 22px 0;
  position: relative;
  text-align: center;
  width: 280px; }

.btn_back {
  background-color: #252525;
  border: none;
  border-radius: 5px;
  color: #FFF !important;
  display: block;
  font-size: 18px;
  letter-spacing: 0.2rem;
  margin: 0 auto;
  outline: none;
  padding: 22px 0;
  position: relative;
  text-align: center;
  width: 280px; }
  .btn_back:before {
    background: url(../images/common/icon_arrow_white_02.png);
    background-size: 8px;
    content: "";
    display: block;
    position: absolute;
    top: 40%;
    left: 15px;
    width: 8px;
    height: 15px;
    transform: rotate(180deg); }

.size_btn_m {
  text-align: center;
  width: 280px; }

.btn_pink {
  background-color: #d71c47;
  color: #FFF !important;
  text-decoration: none !important;
  padding: 5px 8px; }

/* list */
.list-style-disc {
  margin-left: 3em; }
  .list-style-disc li {
    list-style: disc; }

.list_center {
  text-align: center; }
  .list_center li {
    display: inline-block;
    margin: 0 13px; }

/* link */
a {
  cursor: pointer; }

a:link, a:visited {
  cursor: pointer;
  color: #252525;
  text-decoration: none;
  outline: none;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s; }

a:hover, a:active {
  color: #252525;
  cursor: pointer;
  outline: none;
  opacity: 0.5;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s; }

/* セレクトボックス */
.select-wrap {
  position: relative;
  margin: 0 auto 30px;
  max-width: 280px; }

.select-wrap {
  position: relative;
  margin: 0 0 30px;
  max-width: 280px; }
  .select-wrap:before {
    border-right: 2px solid #333;
    border-top: 2px solid #333;
    content: "";
    display: block;
    height: 5px;
    right: 15px;
    position: absolute;
    top: 16px;
    transform: rotate(135deg);
    width: 5px;
    z-index: 1; }
  .select-wrap select {
    outline: none;
    -moz-appearance: none;
    text-indent: 0.01px;
    text-overflow: '';
    background: none transparent;
    vertical-align: middle;
    font-size: inherit;
    color: inherit;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    height: 40px;
    padding: 8px 12px;
    border: 1px solid #d6d6d6;
    color: #828c9a;
    width: 100%;
    border-radius: 3px; }
    .select-wrap select option {
      background-color: #fff;
      color: #333; }
      .select-wrap select option::-ms-expand {
        display: none; }
      .select-wrap select option:-moz-focusring {
        color: transparent;
        text-shadow: 0 0 0 #828c9a; }

.select-wrap.select-primary:before {
  color: #fff; }
  .select-wrap.select-primary:before > select {
    background: #0084B4;
    color: #fff;
    border-color: #0084B4; }
  .select-wrap.select-primary:before :-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #fff; }

.select-wrap.select-inverse:before {
  color: #fff; }
.select-wrap.select-inverse > select {
  color: #fff;
  border-color: #fff; }

/*  -------------------

layout 

-------------------*/
.layout01_ph {
  width: 400px; }

.layout01_text {
  width: 560px; }

.layout02_ph {
  width: 560px; }

.layout02_text {
  width: 400px; }

.order_1 {
  order: 1; }

/* セレクトボックス */
.select-wrap {
  position: relative;
  margin: 0 auto 30px;
  max-width: 280px; }

.select-wrap {
  position: relative;
  margin: 0 0 30px;
  max-width: 280px; }
  .select-wrap:before {
    border-right: 2px solid #333;
    border-top: 2px solid #333;
    content: "";
    display: block;
    height: 5px;
    right: 15px;
    position: absolute;
    top: 16px;
    transform: rotate(135deg);
    width: 5px;
    z-index: 1; }
  .select-wrap select {
    outline: none;
    -moz-appearance: none;
    text-indent: 0.01px;
    text-overflow: '';
    background: none transparent;
    vertical-align: middle;
    font-size: inherit;
    color: inherit;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    height: 40px;
    padding: 8px 12px;
    border: 1px solid #d6d6d6;
    color: #828c9a;
    width: 100%;
    border-radius: 3px; }
    .select-wrap select option {
      background-color: #fff;
      color: #333; }
      .select-wrap select option::-ms-expand {
        display: none; }
      .select-wrap select option:-moz-focusring {
        color: transparent;
        text-shadow: 0 0 0 #828c9a; }

.select-wrap.select-primary:before {
  color: #fff; }
  .select-wrap.select-primary:before > select {
    background: #0084B4;
    color: #fff;
    border-color: #0084B4; }
  .select-wrap.select-primary:before :-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #fff; }

.select-wrap.select-inverse:before {
  color: #fff; }
.select-wrap.select-inverse > select {
  color: #fff;
  border-color: #fff; }


/* ----------------------------------------------

*04. 共通CSS (第2階層)

----------------------------------------------*/
.tit_container {
  background-size: cover;
  background-position: center;
  height: 220px;
  margin: 0 auto;
  width: 100%;
  position: relative; }

.tit_area {
  align-items: center;
  background-color: #FFF;
  box-shadow: 0 9px 21px rgba(0, 0, 0, 0.1);
  display: flex;
  margin: 0 auto;
  width: 90%;
  height: 138px;
  padding: 0 20px;
  position: absolute;
  top: 170px;
  left: 0;
  right: 0; }
  .tit_area:before {
    background-color: #d71c47;
    content: "";
    display: block;
    width: 80px;
    height: 4px;
    position: absolute;
    top: 10px;
    left: 10px; }

.tit_area_text {
  color: #252525;
  font-weight: bold;
  font-size: 28px; }

.contents_container {
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 30px;
  line-height: 3rem;
  max-width: 1100px;
  margin: 0 auto;
  padding-top: 100px;
  width: 90%; }
  .contents_container p {
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 30px;
    line-height: 3rem; }
    .contents_container p a {
      text-decoration: underline; }

.contents_inner {
  border-bottom: 1px solid #EEE;
  padding: 50px 0; }
  .contents_inner h2 {
    font-size: 22px;
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 20px;
    line-height: 2rem;
    margin-bottom: 25px; }
    .contents_inner h2 span {
      color: #d71c47;
      font-size: 12px;
      font-size: 1.2rem; }
  .contents_inner table {
    border: 1px solid #DDD;
    border-collapse: collapse;
    width: 100%; }
    .contents_inner table th {
      background-color: #252525;
      border: 1px solid #DDD;
      border-collapse: collapse;
      color: #FFF;
      line-height: 24px;
      line-height: 2.4rem;
      padding: 8px 10px;
      text-align: left; }
    .contents_inner table td {
      border: 1px solid #DDD;
      border-collapse: collapse;
      line-height: 24px;
      line-height: 2.4rem;
      padding: 8px 10px; }
  .contents_inner .scroll_table {
    overflow-x: auto;
    white-space: nowrap;
    border: solid 1px #ddd; }
    .contents_inner .scroll_table table {
      margin: -1px;
      border: none; }
  .contents_inner .block_table table {
    border: 1px solid #DDD; }
    .contents_inner .block_table table th {
      border-top: none;
      border-right: none;
      border-bottom: 1px solid #DDD;
      border-left: none;
      display: block; }
    .contents_inner .block_table table td {
      border-top: none;
      border-right: none;
      border-bottom: 1px solid #DDD;
      border-left: none;
      display: block; }

/* ----------------------------------------------

*05. 各ページ

----------------------------------------------*/





/*  --------------------------------------

self check 

--------------------------------------*/

.check_container {
  width: 100%;
  margin: 0 auto 40px; }

.check_intro_text_01 {
  color: 000;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: bold;
  margin-bottom: 5px;
  text-align: center; }

.check_img_type {
  line-height: 0;
  margin: 0 auto 15px;
  max-width: 336px;
  width: 100%; }

.check_intro_text_02 {
  border-top: 1px solid #DDD;
  padding-top: 20px;
  padding-bottom: 38px; }
  .check_intro_text_02 p {
    margin-bottom: 0; }

.check_q_tit {
  background-color: #f8f6f6;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 24px;
  line-height: 2.4rem;
  margin-bottom: 30px;
  padding: 8px 9px 8px 63px;
  position: relative; }
  .check_q_tit span {
    color: #d71c47;
    display: block;
    font-size: 22px;
    font-size: 2.2rem;
    padding-right: 17px;
    position: absolute;
    top: 8px;
    left: 8px; }

.check_ul {
  width: 90%;
  margin: 0 auto 25px; }
  .check_ul > li {
    display: flex;
    margin-bottom: 15px; }
    .check_ul > li .radio_input {
      display: none; }
    .check_ul > li .radio_input + label {
      line-height: 0;
      position: relative;
      width: 100%; }
    .check_ul > li .check_ul_checked {
      border: 3px solid #DDD; }
    .check_ul > li .radio_input + label::before {
      background-color: #f8f6f6;
      border: 1px solid #c1c7ca;
      content: "";
      display: block;
      position: absolute;
      top: -8px;
      left: -8px;
      width: 22px;
      height: 22px;
      border-radius: 50%; }
    .check_ul > li .radio_input:checked + label .check_ul_checked {
      border: 3px solid #c62b56; }
    .check_ul > li .radio_input:checked + label::after {
      content: "";
      display: block;
      position: absolute;
      top: -2px;
      left: -2px;
      width: 10px;
      height: 10px;
      background: #d01137;
      border-radius: 50%; }
    .check_ul > li img {
      line-height: 0;
      width: 100%; }
  .check_ul .check_ul_text {
    border: 3px solid #DDD;
    font-weight: bold;
    line-height: 30px;
    width: 100%;
    padding: 13px 10px; }
    .check_ul .check_ul_text li {
      font-size: 14px;
      font-size: 1.4rem;
      line-height: 20px;
      line-height: 2rem;
      float: left; }
      .check_ul .check_ul_text li:after {
        content: "、"; }
      .check_ul .check_ul_text li:last-child:after {
        content: ""; }
    .check_ul .check_ul_text::after {
      content: "";
      display: block;
      clear: both; }
  .check_ul .check_text {
    border: 3px solid #DDD;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 20px;
    line-height: 2rem;
    width: 100%;
    padding: 13px 10px; }

.check_ul_li_s {
  width: 47%; }

.check_ul_li_l {
  width: 100%; }

input[type="submit"].btn_check {
  background-color: #c62b56;
  border: none;
  border-radius: 0;
  color: #FFF !important;
  display: block;
  font-size: 18px;
  letter-spacing: 0.2rem;
  margin: 0 auto;
  outline: none;
  padding: 18px 0;
  position: relative;
  text-align: center;
  width: 90%; }

