@charset "UTF-8";
/*------------------------------------------------------------------------------
    config
------------------------------------------------------------------------------*/
/***  media ***/
/***  color ***/
/*** font ***/
.mv {
  margin-top: 106px;
}
.mv .inner {
  padding-left: 0;
  padding-right: 0;
  max-width: 1500px;
}
@media screen and (max-width: 818px) {
  .mv {
    margin-top: 60px;
  }
}
.flow {
  background: #F5F5F4;
}
.flow .inner {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 818px) {
  .flow .inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.flow .ttl_item {
  margin-top: 40px;
  display: flex;
}
@media screen and (max-width: 818px) {
  .flow .ttl_item {
    margin-top: 30px;
  }
}
.flow .ttl_item .ttl01 {
  line-height: 82px;
  width: 50%;
  text-align: center;
  border-radius: 12px 0 0 0;
  font-size: 28px;
  font-weight: bold;
  color: #ffffff;
  cursor: pointer;
}
@media screen and (max-width: 818px) {
  .flow .ttl_item .ttl01 {
    line-height: 55px;
    font-size: 18px;
  }
}
.flow .ttl_item .ttl01 span {
  font-size: 34px;
}
@media screen and (max-width: 818px) {
  .flow .ttl_item .ttl01 span {
    font-size: 22px;
  }
}
.flow .ttl_item .ttl02 {
  line-height: 82px;
  width: 50%;
  text-align: center;
  border-radius: 0 12px 0 0;
  font-size: 28px;
  font-weight: bold;
  color: #ffffff;
  cursor: pointer;
}
@media screen and (max-width: 818px) {
  .flow .ttl_item .ttl02 {
    font-size: 18px;
    line-height: 55px;
  }
}
.flow .ttl_item .ttl02 span {
  font-size: 34px;
}
@media screen and (max-width: 818px) {
  .flow .ttl_item .ttl02 span {
    font-size: 22px;
  }
}
.flow .txt_item {
  background: #ffffff;
  border: 1px solid #E2E2E2;
  padding: 40px 60px 70px 40px;
  border-radius: 0 0 12px 12px;
}
@media screen and (max-width: 818px) {
  .flow .txt_item {
    padding: 20px;
  }
}
.flow .txt_item ul {
  display: block;
}
.flow .txt_item ul li {
  padding: 30px 30px 30px 46px;
  background: #F5F5F4;
  border: 12px;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li {
    display: block;
    width: 100%;
    padding: 20px 15px;
  }
}
.flow .txt_item ul li + li {
  margin-top: 20px;
}
.flow .txt_item ul li .img {
  width: 45%;
  padding-left: 40px;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .img {
    width: 100%;
    padding-left: 0;
  }
}
.flow .txt_item ul li .img img {
  border-radius: 9px;
}
.flow .txt_item ul li .txt {
  display: flex;
  width: 55%;
  text-align: left;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .txt {
    width: 100%;
    margin-bottom: 10px;
  }
}
.flow .txt_item ul li .txt .flow_box {
  width: 100%;
}
.flow .txt_item ul li .txt .list_ttl {
  border-bottom: 1px solid #CCCCCC;
  margin-bottom: 15px;
  padding-bottom: 20px;
  font-size: 28px;
  font-weight: bold;
  width: 100%;
  line-height: 1.01;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .txt .list_ttl {
    padding-bottom: 15px;
    margin-bottom: 15px;
    font-size: 18px;
    text-align: center;
    letter-spacing: -0.02em;
  }
}
.flow .txt_item ul li .txt .list_ttl span {
  width: fit-content;
  padding-right: 20px;
  font-family: "Geist", sans-serif;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.05em;
  background: linear-gradient(90deg, #691319 0%, #C11319 67.494%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .txt .list_ttl span {
    display: block;
    font-size: 18px;
    text-align: center;
    letter-spacing: 0.05em;
    margin: auto;
    padding-right: 0;
    margin-bottom: 10px;
  }
}
.flow .txt_item ul li .txt p {
  text-align: left;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.714;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .txt p {
    line-height: 1.5;
    font-size: 14px;
  }
}
.flow .txt_item ul li .txt p span {
  display: block;
  font-size: 12px;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .txt p span {
    font-size: 10px;
  }
}
.flow .txt_item ul li .txt p .b {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.5;
  margin-top: 10px;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .txt p .b {
    font-size: 12px;
  }
}
.flow .txt_item ul li .txt p .list {
  line-height: 1.4;
  font-size: 14px;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .txt p .list {
    font-size: 12px;
  }
}
.flow .txt_item ul li .txt .btn_item {
  margin-top: 20px;
  display: flex;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .txt .btn_item {
    display: block;
  }
}
.flow .txt_item ul li .txt .btn_item .b01 {
  width: 100%;
  display: block;
  font-size: 13px;
  font-weight: bold;
  letter-spacing: 0.05em;
  text-align: center;
  color: #ffffff;
  border-radius: 5px;
  line-height: 47px;
  max-width: 205px;
  background: url(../img/top/form_btn_bg.webp) no-repeat right / contain;
  background-size: 100% 100%;
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .txt .btn_item .b01 {
    font-size: 12px;
    width: 100%;
    max-width: 100%;
  }
}
.flow .txt_item ul li .txt .btn_item .b02 {
  margin-left: 7px;
  width: 100%;
  display: block;
  font-size: 13px;
  font-weight: bold;
  letter-spacing: 0.05em;
  text-align: center;
  color: #ffffff;
  border-radius: 5px;
  line-height: 47px;
  max-width: 205px;
  background: linear-gradient(90deg, #29B637 0%, #005637 100%);
}
@media screen and (max-width: 818px) {
  .flow .txt_item ul li .txt .btn_item .b02 {
    font-size: 12px;
    margin-top: 10px;
    width: 100%;
    max-width: 100%;
    margin-left: 0;
  }
}
.flow .ttl_on {
  background: url(../img/top/flow_ttl_bg.webp) no-repeat right / contain;
  background-size: 100% 100%;
}
.flow .ttl_off {
  background: #CECECE;
}
.flow .flow_hide {
  display: none  !important;
}
.flow .flow_show {
  display: block !important;
}
.faq .inner {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 818px) {
  .faq .inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.faq .faq_item {
  position: relative;
  z-index: 10;
  max-width: 900px;
  margin: auto;
  margin-top: 50px;
}
@media screen and (max-width: 818px) {
  .faq .faq_item {
    margin-top: 30px;
  }
}
.faq .faq_item .list li + li {
  margin-top: 15px;
}
@media screen and (max-width: 818px) {
  .faq .faq_item .list li + li {
    margin-top: 10px;
  }
}
.faq .faq_item .list li .q_txt {
  position: relative;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 0.05em;
  cursor: pointer;
  line-height: 1.45;
  align-items: flex-start;
  display: flex;
  border-radius: 12px;
  background: #F5F5F4;
  padding: 23px 40px 23px 25px;
}
@media screen and (max-width: 818px) {
  .faq .faq_item .list li .q_txt {
    border-radius: 8px;
    font-size: 16px;
    padding: 15px 35px 15px 15px;
  }
}
.faq .faq_item .list li .q_txt:after {
  content: "";
  display: inline-block;
  position: absolute;
  background: url(../img/top/faq_add.webp) no-repeat center / contain;
  background-size: 100% 100%;
  width: 15px;
  height: 15px;
  right: 28px;
  top: 31px;
  transition: 0.3s;
}
@media screen and (max-width: 818px) {
  .faq .faq_item .list li .q_txt:after {
    width: 12px;
    height: 12px;
    right: 15px;
    top: 24px;
  }
}
.faq .faq_item .list li .q_txt p {
  width: calc(100% - 32px);
  text-align: left;
  padding-left: 14px;
}
@media screen and (max-width: 818px) {
  .faq .faq_item .list li .q_txt p {
    width: calc(100% - 26px);
    padding-left: 10px;
  }
}
.faq .faq_item .list li .q_txt span {
  font-size: 18px;
  text-align: left;
  font-weight: bold;
  font-family: "Geist", sans-serif;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.01;
  width: 32px;
  height: 32px;
  background: url(../img/top/faq_bg.webp) no-repeat center / contain;
  background-size: 100% 100%;
}
@media screen and (max-width: 818px) {
  .faq .faq_item .list li .q_txt span {
    width: 26px;
    height: 26px;
    font-size: 16px;
  }
}
.faq .faq_item .list li .faqactive:after {
  content: "";
  display: inline-block;
  position: absolute;
  background: url(../img/top/faq_mai.webp) no-repeat center / contain;
  background-size: 100% 100%;
  width: 15px;
  height: 15px;
  right: 28px;
  top: 31px;
  transition: 0.3s;
}
@media screen and (max-width: 818px) {
  .faq .faq_item .list li .faqactive:after {
    width: 12px;
    height: 12px;
    top: 24px;
    right: 15px;
  }
}
.faq .faq_item .list li .a_txt {
  padding: 15px 30px 15px 35px;
  position: relative;
  font-size: 16px;
  font-weight: 500;
  cursor: pointer;
  line-height: 1.625;
  align-items: center;
  display: none;
}
@media screen and (max-width: 818px) {
  .faq .faq_item .list li .a_txt {
    line-height: 1.5;
    padding: 10px 20px 10px 20px;
    font-size: 14px;
  }
}
.faq .faq_item .list li .a_txt .a_list {
  display: flex;
  align-items: flex-start;
}
.faq .faq_item .list li .a_txt:after {
  display: none;
}
.faq .faq_item .list li .a_txt a {
  text-decoration: underline;
  text-decoration-thickness: 1px;
}
.faq .faq_item .list li .a_txt p {
  width: calc(100% - 14px);
  text-align: left;
  padding-left: 21px;
}
@media screen and (max-width: 818px) {
  .faq .faq_item .list li .a_txt p {
    padding-left: 11px;
  }
}
.faq .faq_item .list li .a_txt span {
  font-size: 20px;
  text-align: left;
  font-weight: bold;
  font-family: "Geist", sans-serif;
  color: #22349A;
  width: 14px;
  width: fit-content;
  display: flex;
  line-height: 1.3;
  align-items: center;
  background: linear-gradient(318deg, #691319 0%, #C11319 67.494%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  padding-top: 3px;
}
@media screen and (max-width: 818px) {
  .faq .faq_item .list li .a_txt span {
    font-size: 16px;
  }
}
.area {
  background: #F5F5F4;
}
.area .inner {
  padding-top: 100px;
}
@media screen and (max-width: 818px) {
  .area .inner {
    padding-top: 50px;
  }
}
.area .area_item {
  max-width: 900px;
  margin: auto;
  background: #ffffff;
  border-radius: 12px;
  padding: 30px 60px;
  display: flex;
  margin-top: 50px;
}
@media screen and (max-width: 818px) {
  .area .area_item {
    margin-top: 30px;
    display: block;
    padding: 20px;
  }
}
.area .area_item .img {
  width: 50%;
  padding-right: 30px;
}
@media screen and (max-width: 818px) {
  .area .area_item .img {
    width: 100%;
    padding-right: 0;
    margin-bottom: 20px;
  }
}
.area .area_item .txt {
  padding-left: 30px;
  width: 50%;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 818px) {
  .area .area_item .txt {
    width: 100%;
    padding-left: 0;
  }
}
.area .area_item .txt .a_ttl {
  text-align: left;
  border-bottom: 1px solid #C21419;
  padding-bottom: 20px;
  margin-bottom: 20px;
  font-size: 30px;
  font-weight: bold;
}
@media screen and (max-width: 818px) {
  .area .area_item .txt .a_ttl {
    padding-bottom: 10px;
    margin-bottom: 10px;
    font-size: 20px;
    text-align: center;
  }
}
.area .area_item .txt p {
  text-align: left;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.75;
}
@media screen and (max-width: 818px) {
  .area .area_item .txt p {
    line-height: 1.6;
    font-size: 14px;
  }
}
.guide .inner {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 818px) {
  .guide .inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.guide ul {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  column-gap: 60px;
  max-width: 900px;
  margin: auto;
  margin-top: 60px;
}
@media screen and (max-width: 818px) {
  .guide ul {
    margin-top: 30px;
    display: block;
  }
}
.guide ul li {
  width: calc(50% - 30px);
}
@media screen and (max-width: 818px) {
  .guide ul li {
    width: 100%;
  }
  .guide ul li + li {
    margin-top: 30px;
  }
}
.guide ul li .ttl {
  width: 100%;
  padding-bottom: 15px;
  margin-bottom: 15px;
  position: relative;
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 0.05em;
  text-align: left;
}
@media screen and (max-width: 818px) {
  .guide ul li .ttl {
    padding-bottom: 10px;
    margin-bottom: 10px;
    font-size: 18px;
  }
}
.guide ul li .ttl:after {
  content: "";
  display: inline-block;
  position: absolute;
  background: url(../img/top/guide_line.webp) no-repeat center / contain;
  background-size: 100% 100%;
  width: 100%;
  height: 1px;
  right: 0px;
  bottom: 0;
  transition: 0.3s;
}
.guide ul li p {
  text-align: left;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.625;
}
@media screen and (max-width: 818px) {
  .guide ul li p {
    font-size: 14px;
    line-height: 1.5;
  }
}
.contact {
  background: #F5F5F4;
}
.contact .inner {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 818px) {
  .contact .inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.contact .c_item {
  padding: 60px 70px;
  background: #ffffff;
  max-width: 900px;
  margin: auto;
  border-radius: 12px;
  margin-top: 50px;
}
@media screen and (max-width: 818px) {
  .contact .c_item {
    border-radius: 8px;
    display: block;
    padding: 20px;
    margin-top: 30px;
  }
}
.contact .c_item .form input,
.contact .c_item .form textarea {
  font-size: 16px !important;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form input,
  .contact .c_item .form textarea {
    font-size: 14px !important;
  }
}
.contact .c_item .form .wpcf7-spinner {
  display: none !important;
}
.contact .c_item .form #send,
.contact .c_item .form .wpcf7-submit {
  width: 100%;
  max-width: 300px;
  background: #0A0A0A;
  line-height: 58px;
  color: #ffffff;
  font-family: "Noto Sans JP", sans-serif;
  margin: auto;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.05em;
  display: block;
  cursor: pointer;
  margin-top: 30px;
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
  border-radius: 5px;
  border: none !important;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form #send,
  .contact .c_item .form .wpcf7-submit {
    margin-top: 20px;
    line-height: 48px;
    font-size: 14px;
  }
}
.contact .c_item .form #send:hover,
.contact .c_item .form .wpcf7-submit:hover {
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
  background: #C11319;
}
.contact .c_item .form .sendok {
  background: #ffffff !important;
  border: 1px solid #C11319 !important;
  color: #C11319 !important;
  cursor: pointer !important;
}
.contact .c_item .form .sendok:hover {
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
  background: #C11319 !important;
  color: #ffffff !important;
  opacity: 1 !important;
  cursor: pointer;
}
.contact .c_item .form .check_list {
  text-align: center;
  font-size: 14px;
}
.contact .c_item .form .check_list .sub {
  font-size: 16px;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form .check_list .sub {
    font-size: 14px;
  }
}
.contact .c_item .form .check_list .sub,
.contact .c_item .form .check_list .form-acceptance {
  margin-top: 25px;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form .check_list .sub,
  .contact .c_item .form .check_list .form-acceptance {
    margin-top: 15px;
  }
}
.contact .c_item .form .check_list .sub a,
.contact .c_item .form .check_list .form-acceptance a {
  color: #208556;
  text-decoration: underline;
}
.contact .c_item .form .form-acceptance input[type=checkbox] {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  z-index: 1;
  margin: 0;
  width: 20px;
  height: 20px;
  cursor: pointer;
  opacity: 0;
}
.contact .c_item .form .wpcf7-list-item {
  margin: 0;
}
.contact .c_item .form .form-acceptance .wpcf7-list-item-label::before {
  content: "";
  position: absolute;
  top: 52%;
  left: -1.5em;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: #F5F4ED;
  cursor: pointer;
  transition: all 0.3s;
  border: 1px solid #222927;
}
.contact .c_item .form .wpcf7-list-item-label {
  position: relative;
}
.contact .c_item .form .form-acceptance .wpcf7-list-item-label::after {
  content: "";
  position: absolute;
  top: 52%;
  left: -1.7em;
  transform: translateY(-50%);
  width: 24px;
  height: 12px;
  background: url(../img/common/check_icon.webp) no-repeat center / contain;
  cursor: pointer;
  transition: all 0.3s;
  opacity: 0;
}
.contact .c_item .form input[type=checkbox]:checked + .wpcf7-list-item-label::after {
  opacity: 1;
}
.contact .c_item .form input[type=checkbox]:checked + .wpcf7-list-item-label::before {
  opacity: 1;
}
.contact .c_item .form ul {
  display: block;
}
.contact .c_item .form ul li + li {
  margin-top: 25px;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form ul li + li {
    margin-top: 15px;
  }
}
.contact .c_item .form ul li dl {
  width: 100%;
  display: flex;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form ul li dl {
    display: block;
  }
}
.contact .c_item .form ul li dl dt {
  width: 230px;
  font-size: 16px;
  font-weight: 500;
  text-align: left;
  line-height: 1.5;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form ul li dl dt {
    width: 100%;
    margin-bottom: 5px;
  }
}
.contact .c_item .form ul li dl dt .hishu {
  color: #C11319;
}
.contact .c_item .form ul li dl dt .ninyi {
  color: #0071BC;
}
.contact .c_item .form ul li dl dd {
  width: calc(100% - 230px);
}
@media screen and (max-width: 818px) {
  .contact .c_item .form ul li dl dd {
    width: 100%;
    margin-bottom: 5px;
  }
}
.contact .c_item .form ul li dl dd p {
  width: 100%;
  text-align: left;
  padding-bottom: 0;
}
.contact .c_item .form ul li dl dd input[type="button"],
.contact .c_item .form ul li dl dd input[type="submit"],
.contact .c_item .form ul li dl dd input[type="reset"] {
  -webkit-appearance: none;
}
.contact .c_item .form ul li dl dd p,
.contact .c_item .form ul li dl dd span {
  width: 100%;
  align-items: left;
  display: block !important;
  text-align: left;
}
.contact .c_item .form ul li dl dd .sub_txt {
  margin-top: 15px;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form ul li dl dd .sub_txt {
    margin-top: 10px;
  }
}
.contact .c_item .form ul li dl dd .wpcf7-radio {
  display: flex !important;
  flex-wrap: wrap;
}
.contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item {
  width: fit-content;
  margin-right: 20px;
  margin-left: 0;
  align-items: center;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item {
    margin-right: 20px;
  }
}
.contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item label {
  display: flex !important;
  align-items: center;
  text-wrap: nowrap;
  line-height: 32px;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item label {
    line-height: 24px;
    margin-right: 10px;
  }
}
.contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item div:first-of-type {
  display: flex;
  align-items: flex-start;
  margin-bottom: 5px;
}
.contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item input[type="text"]:checked {
  box-sizing: border-box;
  outline: 7px solid #CCCCCC;
  outline-offset: -7px;
}
.contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item button,
.contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item legend {
  color: white;
  background-color: #CCCCCC;
  padding: 5px 5px;
  border-radius: 0;
  border: 0;
  font-size: 14px;
}
.contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item button:hover,
.contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item button:focus {
  color: #CCCCCC;
}
.contact .c_item .form ul li dl dd .wpcf7-radio .wpcf7-list-item button:active {
  background-color: white;
  color: #CCCCCC;
  outline: 1px solid #CCCCCC;
}
.contact .c_item .form ul li dl dd input[type="text"],
.contact .c_item .form ul li dl dd input[type="tel"],
.contact .c_item .form ul li dl dd input[type="email"] {
  padding: 10px 15px;
  width: 100%;
  border: none !important;
  border-radius: 6px;
  background: #F7F7F7;
}
.contact .c_item .form ul li dl dd textarea {
  padding: 10px 15px;
  border: none !important;
  border-radius: 6px;
  background: #F7F7F7;
  height: 320px;
  max-height: 320px;
  max-width: 100%;
  width: 100%;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form ul li dl dd textarea {
    height: 200px;
    max-height: 200px;
  }
}
@media screen and (max-width: 818px) {
  .contact .c_item .form ul li dl dd select {
    font-size: 14px !important;
    border-radius: 5px;
  }
}
.contact .c_item .form ul li dl dd .wpcf7-not-valid-tip {
  color: #B42E27 !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  display: block !important;
  line-height: 160%;
  text-align: left;
}
.contact .c_item .form ul li dl dd input:focus,
.contact .c_item .form ul li dl dd textarea:focus,
.contact .c_item .form ul li dl dd select:focus {
  color: #0A0A0A !important;
}
.contact .c_item .form ul li dl dd input:valid,
.contact .c_item .form ul li dl dd textarea:valid,
.contact .c_item .form ul li dl dd select:valid {
  color: #0A0A0A !important;
}
.contact .c_item .form ul li dl dd input:invalid,
.contact .c_item .form ul li dl dd textarea:invalid,
.contact .c_item .form ul li dl dd select:invalid {
  color: #0A0A0A !important;
}
.contact .c_item .form ul li dl dd input[type="radio"] {
  appearance: none;
  border-radius: 50%;
  width: 18px;
  height: 18px;
  border: 1px solid #0A0A0A;
  transition: 0.3s all linear;
  margin-right: 5px;
  padding: 8px;
  position: relative;
  font-size: 16px;
  font-weight: 500;
}
.contact .c_item .form ul li dl dd input[type="radio"]:checked {
  box-sizing: border-box;
  outline: 7px solid #C11319;
  outline-offset: -7px;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form .check_list {
    font-size: 12px;
  }
}
.contact .c_item .form .form_check {
  font-size: 16px !important;
}
@media screen and (max-width: 818px) {
  .contact .c_item .form .form_check {
    font-size: 14px !important;
  }
}
