@charset "UTF-8";
/* =====================================================
▼ COLOR
===================================================== */
/*---------------------------------------------------------------------------*/
input[type="checkbox"] { padding: 0; height: initial; width: initial; margin-bottom: 0; display: none; cursor: pointer; }

input[type="checkbox"]:checked + label:after { opacity: 1; -webkit-transform: translateY(-50%) scale(1); -moz-transform: translateY(-50%) scale(1); -ms-transform: translateY(-50%) scale(1); transform: translateY(-50%) scale(1); }

label { position: relative; cursor: pointer; padding-left: 25px; }

@media screen and (max-width: 768px) { label { padding-left: 5.625vw; } }

label:before { content: ''; -webkit-appearance: none; background-color: transparent; width: 15px; height: 15px; top: 50%; -webkit-transform: translateY(-50%); -moz-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); left: 0; display: inline-block; position: absolute; vertical-align: middle; cursor: pointer; border: 1px solid #000; }

@media screen and (max-width: 768px) { label:before { width: 3.125vw; height: 3.125vw; } }

label:after { content: ''; display: block; position: absolute; top: 50%; -webkit-transform: translateY(-50%) scale(0); -moz-transform: translateY(-50%) scale(0); -ms-transform: translateY(-50%) scale(0); transform: translateY(-50%) scale(0); left: 0; width: 16px; height: 16px; background: #000; opacity: 0; -webkit-transition: all .3s ease; -moz-transition: all .3s ease; transition: all .3s ease; }

@media screen and (max-width: 768px) { label:after { width: 3.4375vw; height: 3.4375vw; } }

.contact_error { background: #FCEFF2; color: #E50000; padding: 3rem 5rem; margin-bottom: 5rem; }

.contact_error .err_ttl { text-align: center; font-size: 1.4rem; font-weight: 400; margin-bottom: 1.5rem; }

.err_list li { color: #D8255D; font-size: 1.1rem; font-weight: bold; position: relative; padding: 0.3rem 0 0.3rem 2rem; }

.err_list li:before { position: absolute; content: ''; width: 1.2rem; height: 1.2rem; left: 0; top: 0.5rem; -moz-border-radius: 50%; border-radius: 50%; background: #E50000; }

.error_box { text-align: center; }

.error_box h3 { margin-bottom: 4rem; }

.error { color: #D8255D; font-size: 1.1rem; }

.w_error .ipt { border: 1px solid #D8255D; }

.w_error label:before { background: #D8255D; }

.contact-thanks { text-align: center; margin-bottom: 80px; }

.contact-thanks h3 { margin-bottom: 35px; }

.contact-thanks p { font-weight: bold; }

/** section-contact **/
.section-contact { padding: 0 0 10rem; }

.section-contact .contact-title { background: #0A4BBE; text-align: center; color: #fff; font-size: 2rem; font-weight: bold; padding: 1.8rem 1.5rem; margin-bottom: 2rem; }

@media screen and (max-width: 768px) { .section-contact .contact-title { font-size: 5.625vw; padding: 6.25vw 3.125vw; } }

.contact-top { text-align: center; font-size: 1.7rem; line-height: 2; margin-bottom: 4rem; }

.contact-top_lead { text-align: left; }

.contact-top_tel { font-size: 2.4rem; font-weight: bold; }

.contact-top_tel a { display: inline-block; font-size: 3.5rem; color: #0A4BBE; }

@media screen and (max-width: 768px) { .contact-top { font-size: 3.75vw; line-height: 1.6; }
  .contact-top_shedule span { display: block; } }

.contact-form_txt { font-size: 1.7rem; line-height: 2; margin-bottom: 2rem; }

@media screen and (max-width: 768px) { .contact-form_txt { font-size: 3.75vw; line-height: 1.6; } }

.contact-form .req { display: inline-block; color: #ED1C24; }

.contact-form .ipt { width: 100%; border: 1px solid #000000; outline: none; padding: 0.5rem 1rem; }

.contact-form .are { height: 21rem; }

@media screen and (max-width: 768px) { .contact-form .are { height: 37.5vw; } }

.contact-form .border-item { display: -webkit-box; display: -moz-box; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -moz-box-orient: horizontal; -moz-box-direction: normal; -ms-flex-flow: row wrap; flex-flow: row wrap; -webkit-box-align: center; -moz-box-align: center; -ms-flex-align: center; align-items: center; font-size: 1.7rem; line-height: 2; background: #DEEAFF; }

@media screen and (max-width: 768px) { .contact-form .border-item { font-size: 3.75vw; line-height: 1.6; background: none; } }

.contact-form .border-item dt { width: -webkit-calc(250/950 * 100%); width: -moz-calc(250/950 * 100%); width: calc(250/950 * 100%); padding: 1.3rem 2rem; font-weight: bold; color: #0A4BBE; }

@media screen and (max-width: 768px) { .contact-form .border-item dt { width: 100%; padding: 3.125vw; background: #DEEAFF; border-bottom: 1px solid #0A4BBE; } }

.contact-form .border-item dd { width: -webkit-calc(700/950 * 100%); width: -moz-calc(700/950 * 100%); width: calc(700/950 * 100%); background: #fff; padding: 1rem 2.5rem; border-left: 1px solid #0A4BBE; }

@media screen and (min-width: 769px) { .contact-form .border-item dd ul { display: -webkit-box; display: -moz-box; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -moz-box-orient: horizontal; -moz-box-direction: normal; -ms-flex-flow: row wrap; flex-flow: row wrap; -webkit-box-pack: justify; -moz-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
  .contact-form .border-item dd ul li { width: 48%; } }

@media screen and (max-width: 768px) { .contact-form .border-item dd { width: 100%; padding: 3.125vw; border-left: none; } }

.contact-form .btn { width: 30rem; height: 8.5rem; font-size: 1.9rem; font-weight: bold; background: #fff; color: #0A4BBE; border: 4px solid #0A4BBE; margin: 3rem auto 0; }

.contact-form .btn:hover { background: #0A4BBE; color: #fff; }

@media screen and (max-width: 768px) { .contact-form .btn { width: 75vw; height: 18.75vw; font-size: 4.6875vw; margin: 6.25vw auto 0; } }

.contact-form .box-center { margin: 3rem 0 4rem; font-size: 1.7rem; text-align: center; }

@media screen and (max-width: 768px) { .contact-form .box-center { font-size: 3.75vw; line-height: 1.6; text-align: left; margin: 6.25vw 0 9.375vw; } }

.contact-form .box-center a { display: inline-block; color: #0A4BBE; text-decoration: underline; }

.contact-form .frm-chk { margin: 1rem 0 2rem; }

@media screen and (max-width: 768px) { .contact-form .frm-chk { margin: 3.125vw 0; } }

.privacy-box { border: 1px solid #0A4BBE; padding: 2rem 4rem; font-size: 1.7rem; line-height: 2; letter-spacing: -1px; }

.privacy-box h3 { font-size: 1.7rem; color: #0A4BBE; }

.privacy-box h3:not(:first-child) { margin-top: 2rem; }

@media screen and (max-width: 768px) { .privacy-box { padding: 3.125vw; font-size: 3.75vw; line-height: 1.6; }
  .privacy-box h3 { font-size: 3.75vw; line-height: 1.6; } }
