@charset "UTF-8";
/* -------------------------------------------------------------------------*/
/* MIXIN / ARGUMENT / COMMON CLASS
/* -------------------------------------------------------------------------*/
@import url("https://fonts.googleapis.com/css?family=Maven+Pro:600&display=swap");
.default_ftz {
  font-size: 18px;
  font-size: 1.125rem;
}

@media only screen and (max-width: 640px) {
  .default_ftz {
    font-size: 16px;
    font-size: 1rem;
  }
}

.text_out {
  overflow: hidden;
  text-indent: 100%;
  white-space: nowrap;
}

.tbl_scroll {
  overflow-x: auto;
}

.tbl_scroll table {
  min-width: 600px;
}

.def_cntSize {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto;
  padding-right: 20px;
  padding-left: 20px;
}

@media only screen and (max-width: 980px) {
  .def_cntSize {
    padding-right: 15px;
    padding-left: 15px;
  }
}

@media only screen and (max-width: 640px) {
  .def_cntSize {
    padding-right: 10px;
    padding-left: 10px;
  }
}

/* -------------------------------------------------------------------------*/
/* -------------------------------------------------------------------------*/
/* FONT
/* -------------------------------------------------------------------------*/
.lang_ja {
  font-family: 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
}

.mincho {
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "ＭＳ 明朝", serif;
}

/* -------------------------------------------------------------------------*/
/* -------------------------------------------------------------------------*/
/* PAGES
/* -------------------------------------------------------------------------*/
@media only screen and (max-width: 1200px) {
  .pg_kv_page::after {
    width: 54.16667%;
    padding-top: 20.83333%;
  }
}

/* -------------------------------------------------------------------------*/
/* -------------------------------------------------------------------------*/
/* CONTACT
/* -------------------------------------------------------------------------*/
/* -------------------------------------------------------------------------*/
/* CONTACT TOP
/* -------------------------------------------------------------------------*/
.contact_block {
  font-size: 0;
}

.contact_block .telBox, .contact_block .box span.tel {
  font-size: 12px;
  font-size: 0.75rem;
  display: inline-block;
  vertical-align: middle;
  line-height: 1;
  padding: 4px 7px;
  background-color: #4fb1ee;
  color: #fff;
  border-radius: 2px;
  margin-right: 5px;
}

.contact_block .box {
  font-size: 16px;
  font-size: 1rem;
  display: inline-block;
  vertical-align: top;
  width: 49%;
  margin: 8px 0;
  padding: 20px;
  border: 2px solid #d2e0e9;
}

.contact_block .box:nth-child(odd) {
  margin-right: 1%;
}

.contact_block .box:nth-child(even) {
  margin-left: 1%;
}

.contact_block .box .title {
  font-size: 18px;
  font-size: 1.125rem;
  margin: 0 0 20px;
  padding-bottom: 10px;
  color: #004ea2;
  border-bottom: 2px solid;
  line-height: 1.5;
}

.contact_block .box table {
  width: 100%;
  margin-bottom: 20px;
}

.contact_block .box table td {
  padding: 10px 3px;
}

.contact_block .box table tr:nth-child(odd) td {
  background-color: #f2f8fc;
  border: 1px solid #def2ff;
  border-right: none;
  border-left: none;
}

.contact_block .box table .name {
  font-size: 14px;
  font-size: 0.875rem;
  margin: 0 0 2px;
}

.contact_block .box .tel_name {
  margin-bottom: -10px;
}

.contact_block .box .tel_n {
  font-size: 20px;
  font-size: 1.25rem;
  font-family: 'Maven Pro', sans-serif;
  color: #323232;
}

.contact_block .box div.tel {
  white-space: nowrap;
}

.contact_block .bnr {
  font-size: 0;
}

.contact_block .bnr a {
  display: inline-block;
  margin: 2px 0;
}

.contact_block .bnr a:first-child {
  margin-right: 4px;
}

.contact_block .bnr img {
  width: auto;
  height: auto;
  max-width: 100%;
}

@media only screen and (max-width: 980px) {
  .contact_block .box {
    padding: 15px;
  }
  .contact_block .box table, .contact_block .box tbody, .contact_block .box tr, .contact_block .box th, .contact_block .box td {
    display: block;
  }
  .contact_block .box tr {
    padding: 2px 0;
  }
  .contact_block .box td {
    padding: 5px 10px !important;
    border: none !important;
  }
}

@media only screen and (max-width: 640px) {
  .contact_block .box {
    display: block;
    width: 100%;
    margin: 10px 0 !important;
    padding: 10px;
  }
}

.cnt_tel {
  font-size: 18px;
  font-size: 1.125rem;
  margin-top: 2rem;
  text-align: center;
}

.cnt_tel p {
  display: inline-block;
}

.cnt_tel a {
  display: block;
  text-decoration: underline;
}

.btn_contactForm a {
  display: inline-block;
  padding: 10px 30px;
  background-color: #f9fcff;
  line-height: 1;
  border-radius: 5px;
  border: 1px solid #d0e0ea;
  transition: background 0.2s ease, border 0.2s ease;
  box-shadow: 2px 2px 0 rgba(0, 0, 0, 0.05);
}

.btn_contactForm a::before {
  content: '';
  display: inline-block;
  vertical-align: middle;
  margin-right: 5px;
  margin-top: -5px;
  width: 47px;
  height: 37px;
  background: url(../img/cnt_mail.png) 0 0 no-repeat;
}

.btn_contactForm a:hover {
  background-color: #e1f4ff;
  border-color: #b1d8ef;
  text-decoration: none;
  box-shadow: none;
}

/* ----- CONTACT FORM ----- */
.cntct_form > table {
  width: 100%;
  border-collapse: collapse;
}

.cntct_form > table th, .cntct_form > table td {
  padding: 5px 10px;
  border: 1px solid #ebebeb;
}

.cntct_form > table th {
  text-align: left;
  font-weight: normal;
  background-color: #f9fdff;
  border: 1px solid #d7e5ef;
  width: 25%;
  white-space: nowrap;
}

.cntct_form > table tr.alert th {
  background-color: #ffe4e4;
  border-color: #f7cece;
}

.cntct_form > table tr.alert td {
  background-color: #ffefef;
  border-color: #f7dddd;
}

.cntct_form > table tr.alert input[type="text"], .cntct_form > table tr.alert input[type="tel"], .cntct_form > table tr.alert input[type="email"], .cntct_form > table tr.alert textarea, .cntct_form > table tr.alert select {
  border: 1px solid #dda8a8;
}

.cntct_form > table tr.alert input[type="text"]:focus, .cntct_form > table tr.alert input[type="tel"]:focus, .cntct_form > table tr.alert input[type="email"]:focus, .cntct_form > table tr.alert textarea:focus, .cntct_form > table tr.alert select:focus {
  border-color: #e36767;
  box-shadow: 0 0 5px rgba(255, 193, 193, 0.6);
}

.cntct_form > table .input-error {
  font-size: 14px;
  font-size: 0.875rem;
  margin: 0;
  color: #c92727;
}

.cntct_form > table .input-error::before {
  content: '';
  display: inline-block;
  margin-right: 5px;
  margin-left: 2px;
  vertical-align: middle;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 4px 0 4px;
  border-color: #c92727 transparent transparent transparent;
}

.cntct_form .required {
  font-size: 12px;
  font-size: 0.75rem;
  display: inline-block;
  vertical-align: middle;
  margin-left: 5px;
  background-color: #ff6b6b;
  line-height: 1;
  padding: 4px 8px;
  border-radius: 3px;
  color: #fff;
}

.cntct_form input[type="text"], .cntct_form input[type="tel"], .cntct_form input[type="email"], .cntct_form textarea {
  width: 100%;
  border: 1px solid #c5c5c5;
  padding: 5px;
  border-radius: 5px;
  transition: all 0.2s ease;
}

.cntct_form input[type="text"]:focus, .cntct_form input[type="tel"]:focus, .cntct_form input[type="email"]:focus, .cntct_form textarea:focus {
  background-color: #fffef4;
  outline: none;
  border-color: #61abc1;
  box-shadow: 0 0 5px #aad8ff;
}

.cntct_form select {
  border: 1px solid #c5c5c5;
  padding: 5px;
  border-radius: 5px;
  transition: all 0.2s ease;
}

.cntct_form select:focus {
  background-color: #fffef4;
  outline: none;
  border-color: #61abc1;
  box-shadow: 0 0 5px #aad8ff;
}

.cntct_form textarea {
  height: 200px;
}

.cntct_form .cntct_formBtn {
  margin-top: 30px;
  text-align: center;
}

.cntct_form .cntct_formBtn input {
  padding: 10px 20px;
  margin: 5px 10px;
}

.cntct_form .cntct_formBtn input[type="submit"] {
  width: 100%;
  max-width: 260px;
  border: 2px solid #4294d9;
  color: #08295f;
  background-color: #edfbff;
  transition: all 0.2s ease;
}

.cntct_form .cntct_formBtn input[type="submit"]:hover {
  outline: none;
  background-color: #dbf7ff;
  box-shadow: 0 0 5px #8dc9fb;
}

.cntct_form .cntct_formBtn input[type="reset"] {
  color: #999999;
  border: 1px solid #dedede;
}

.cntct_form .cntct_recaptcha {
  margin-top: 20px;
  padding: 10px;
  background: #f8f8f8;
  text-align: center;
  line-height: 0;
}

.cntct_form .cntct_recaptcha .recaptcha-wrap {
  display: inline-block;
}

.cntct_form .input_zip input {
  width: 150px;
}

.cntct_form .input_tel input {
  width: 200px;
}

@media only screen and (max-width: 980px) {
  .cntct_form > table th, .cntct_form > table td {
    padding: 5px;
  }
}

@media only screen and (max-width: 640px) {
  .cntct_form table, .cntct_form tbody, .cntct_form tr, .cntct_form th, .cntct_form td {
    display: block;
    width: 100% !important;
  }
  .cntct_form > table tr {
    margin: 15px 0;
  }
  .cntct_form > table th {
    border: none;
    border-bottom: 1px solid #004ea2;
  }
  .cntct_form > table th br {
    display: none;
  }
  .cntct_form > table td {
    padding: 10px 5px;
    border: none;
    background-color: #f7f7f7;
  }
  .cntct_form .cntct_formBtn input[type="reset"] {
    margin-top: 15px;
    background-color: #f7f7f7;
    padding: 5px 10px;
  }
}

.cntct_alertBox {
  padding: 15px 20px;
  margin-bottom: 20px;
  background-color: #fff4f4;
}

.cntct_alertBox p {
  margin: 5px 0;
}

.cntct_alertBox .alert {
  font-weight: bold;
  color: #e03636;
}

.cntct_thankBox {
  padding: 15px 20px;
  margin-bottom: 20px;
  background-color: #eefbff;
  border: 2px solid #d4f2fb;
}

.cntct_thankBox .alert {
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: bold;
  color: #3066b1;
}

/* -------------------------------------------------------------------------*/
/* -------------------------------------------------------------------------*/
/* FAQ
/* -------------------------------------------------------------------------*/
.faq_area .pageblockWide {
  margin: 70px 0;
}

.faq_area h4 {
  padding-bottom: 10px;
  margin-top: 50px;
  color: #004ea2;
  border-bottom: 1px dotted #acacac;
}

.faq_area h5 {
  font-size: 16px;
  font-size: 1rem;
  margin-bottom: 10px;
  color: #004ea2;
  border-bottom: 1px dotted;
}

.faq_area .qanda {
  margin-bottom: 30px;
  padding: 15px;
  background-color: #f7f7f7;
  border: 1px solid #dedede;
}

.faq_area .qanda img {
  width: auto;
  height: auto;
  max-width: 100%;
}

.faq_area .qanda table {
  border-collapse: collapse;
  font-size: 14px;
  font-size: 0.875rem;
}

.faq_area .qanda th, .faq_area .qanda td {
  padding: 5px;
  border: 1px solid #cbcbcb;
}

.faq_area .qanda th {
  background-color: #e0e0e0;
}

.faq_area .qanda td {
  background-color: #fff;
}

.faq_area .question, .faq_area .answer {
  position: relative;
  padding: 1px 0 0 50px;
}

.faq_area .question > p:first-child, .faq_area .answer > p:first-child {
  margin-top: 0;
}

.faq_area .question::before, .faq_area .answer::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  padding: 5px 10px;
  line-height: 1;
  font-weight: bold;
  color: #fff;
  border-radius: 5px;
}

.faq_area .question::before {
  content: 'Q';
  background-color: #ff0000;
}

.faq_area .answer::before {
  content: 'A';
  background-color: #0075ea;
}

.faq_area .smallred {
  font-size: 13px;
  font-size: 0.8125rem;
  color: #f00000;
}

.faq_area .complement {
  font-size: 13px;
  font-size: 0.8125rem;
  color: #00831e;
  position: relative;
  padding-left: 20px;
}

.faq_area .complement::before {
  content: '!';
  display: block;
  position: absolute;
  width: 16px;
  height: 15px;
  text-align: center;
  padding-top: 1px;
  top: 3px;
  left: 0;
  line-height: 1;
  color: #fff;
  font-weight: bold;
  font-size: 14px;
  background-color: #006517;
  border-radius: 50%;
}

@media only screen and (max-width: 640px) {
  .faq_area .qanda {
    margin-bottom: 20px;
    padding: 10px;
  }
  .faq_area .question, .faq_area .answer {
    padding: 1px 0 0 28px;
  }
  .faq_area .question::before, .faq_area .answer::before {
    top: -1px;
    left: -5px;
    padding: 5px 7px;
    border-radius: 3px;
  }
}

.faq_c_box {
  margin-bottom: 30px;
  padding: 15px;
  background-color: #f7f7f7;
  border: 1px solid #dedede;
}

.faq_c_box h4 {
  font-size: 18px;
  font-size: 1.125rem;
  margin-top: 0;
  border: none;
  background-color: #cfebff;
  padding: 15px 10px 12px;
}

.faq_c_box h5 {
  margin: 35px 20px 15px;
  padding-bottom: 10px;
}

.faq_c_box p {
  margin: 15px 20px;
}

@media only screen and (max-width: 640px) {
  .faq_c_box {
    padding: 5px 5px 10px;
  }
  .faq_c_box h5 {
    margin: 25px 10px 10px;
    padding-bottom: 10px;
  }
  .faq_c_box p {
    margin: 10px 10px;
  }
}

/* -------------------------------------------------------------------------*/
