@charset "UTF-8";

* {
  margin: 0;
  padding: 0;
}

.hidden {
  display: none;
}

.center {
  text-align: center;
}

body {
  position: relative;
  font-size: 16px;
  font-family: "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro W3",
    "Hiragino Kaku Gothic Pro", "sans-serif";
  line-height: 1.8;
  color: #333;
  background: #fff;
}

.noto_serif {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

.kv_area li img {
  width: 100%;
  height: 455px;
}

a {
  color: #bc000e;
  text-decoration: none;
}
a:hover {
  opacity: 0.5;
}

ul {
  list-style: none;
}

.inner {
  width: 1080px;
  margin: 0 auto;
}

/*ヘッダー
=======================================================*/
header {
  position: relative;
  padding: 14px 0 6px;
  background: #fff;
  z-index: 2;
}

header .inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

header h1 {
  line-height: 1;
}

header .cv {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

header .tel {
  margin: 15px 23px 0 0;
  padding: 0px 0 0 40px;
  background: url(../img/tel_phone.png) 0 5px no-repeat;
  background-size: 36px auto;
  text-align: center;
}

header .cv .tel .num {
  line-height: 1;
  font-size: 32px;
  color: #111;
  margin-top: 3px;
}

.consalt {
  margin-bottom: 0;
  font-size: 11px;
  text-align: center;
}

header .cv .tel .time {
  font-size: 13px;
  color: #666;
}

header .cv .btn_cv {
  font-size: 14px;
}

header .cv .btn_cv a {
  padding: 9px 20px 9px 14px;
  background-position: right 10px top 50%;
  background-size: 10px auto;
}

/*ついてくるCV
=======================================================*/
.fix_cv {
  position: fixed;
  right: -1px;
  top: calc(49% - 40px);
  width: 80px;
  height: 160px;
  z-index: 3;
}

.fix_cv .col {
  position: absolute;
  right: 1px;
  width: 92px;
  height: 86px;
  overflow: hidden;
  transition: 0.4s;
  z-index: 2;
}
.fix_cv .col.tel {
  top: -6px;
  background: #b0000d;
}
.fix_cv .col.mail {
  top: 80px;
  background: #04a004;
}
.fix_cv .col.line {
  top: 166px;
  background: #04a004;
}
/*展開時*/
.fix_cv.is_tel .col.tel,
.fix_cv.is_mail .col.mail,
.fix_cv.is_line .col.line {
  width: 326px;
  border-radius: 6px 0 0 6px;
  box-shadow: 0 0 20px 5px rgba(0, 0, 0, 0.2);
}
.fix_cv.is_line .col.line {
  width: 200px;
  height: 150px;
}

.fix_cv .col .ico {
  position: absolute;
  width: 90px;
  height: 100%;
  padding: 52px 0 0 2px;
  box-sizing: border-box;
  line-height: 1;
  color: #fff;
  transition: transform 0.6s;
  text-align: center;
}
.fix_cv .col.tel .ico {
  background: url(../img/tel.png) 50% 14px no-repeat;
  background-size: 23px auto;
}
.fix_cv .col.mail .ico {
  background: url(../img/mail.png) 50% 16px no-repeat;
  background-size: 44px auto;
}
.fix_cv .col.line .ico {
  background: url(../img/line.png) 50% 8px no-repeat;
  background-size: 59px auto;
}

/*メインビジュアル
=======================================================*/
.kv_area {
  position: relative;
  overflow: hidden;
}

.kv_area .txt_inner {
  position: absolute;
  top: 55px;
  left: calc(50% - 540px);
  width: 1080px;
  margin: 0 auto;
  z-index: 2;
  text-align: center;
}

.kv_area .txt_inner .lead {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 0 86px;
}

.kv_area .txt_inner .lead .ls {
  width: 498px;
  margin: 0 14px 0 0;
}

.kv_area .txt_inner .lead .ll {
  width: 446px;
}

.kv_area .txt_inner .col2 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.kv_area .txt_inner .col2 .left {
  width: 545px;
}

.kv_area .txt_inner .col2 .catch {
  width: 587px;
  margin: 0 0 0 -20px;
  opacity: 0;
  animation: kv_circle 0.8s ease-out 1.6s forwards;
}

.kv_area .txt_inner .col2 .cv {
  position: relative;
  width: 403px;
  padding: 45px 40px 64px;
  box-sizing: border-box;
  background: url(../img/bg_kv_cv.jpg) 0 0 no-repeat #f0f1f1;
  background-size: cover;
  opacity: 0;
  animation: kv_circle 0.8s ease-out 2s forwards;
}

.kv_area .txt_inner .col2 .cv .btn_cv {
  position: absolute;
  bottom: -30px;
  left: calc(50% - 167px);
}

.kv_area .txt_inner .col2 .cv .btn_cv a {
  padding: 18px 60px 20px;
  background-position: right 10px top 50%;
  background-size: 10px auto;
}

/*お知らせ
=======================================================*/
.news_area {
  padding: 55px 0;
}

.news_area h2 {
  position: relative;
  margin: 0 0 20px;
  padding: 0 0 14px;
  font-size: 24px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #111;
  border-bottom: 1px solid #b5b5b5;
}
.news_area h2::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 90px;
  height: 1px;
  background: #b0000d;
}

.news_area ul {
  height: 160px;
  overflow-y: scroll;
}

.news_area li {
  position: relative;
  display: flex;
  padding: 16px 0 16px 3px;
  border-bottom: 1px dotted #ccc;
}
.news_area li:last-child {
  border-bottom: none;
}

.news_area li .date {
  margin: 0 16px 0 0;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #696969;
}

.news_area li.new::before,
.news_area li.fix::before {
  content: "NEW";
  display: block;
  position: absolute;
  left: 0;
  top: calc(50% - 11px);
  padding: 0 5px 2px;
  line-height: 22px;
  font-size: 15px;
  font-family: "Noto Serif JP", serif;
  color: #fff;
  background: #000;
}

.news_area li.fix::before {
  content: "固定記事";
}

/*お悩み
=======================================================*/
.trouble_area {
  padding: 86px 0 10px;
  background: url(../img/back.png) 50% 50% no-repeat;
  background-size: cover;
  overflow: hidden;
}

.trouble_area h2 {
  position: relative;
  width: 1080px;
  margin: 0 auto;
  line-height: 1;
  font-size: 36px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #fff;
  text-align: center;
}

.trouble_area .comment {
  position: relative;
  width: 968px;
  height: 474px;
  margin: 0 auto;
  background: url(../img/coment.png) 0 0 no-repeat;
}

.trouble_area .comment p {
  position: absolute;
  font-size: 21px;
  font-family: "Noto Serif JP", serif;
  color: #111;
  line-height: 1.4;
  font-weight: bold;
}

.trouble_area .comment p:nth-child(1) {
  top: 70px;
  left: 97px;
}
.trouble_area .comment p:nth-child(2) {
  top: 82px;
  left: 595px;
}
.trouble_area .comment p:nth-child(3) {
  top: 176px;
  left: 81px;
}
.trouble_area .comment p:nth-child(4) {
  top: 212px;
  left: 655px;
}
.trouble_area .comment p:nth-child(5) {
  top: 317px;
  left: 79px;
}
.trouble_area .comment p:nth-child(6) {
  top: 350px;
  left: 586px;
}

/*ファクタリングとは
=======================================================*/
.about_area {
  position: relative;
  padding: 28px 0 42px;
  background: url(../img/back3.png) 50% 0 no-repeat #264a9f;
}

.about_area h2 {
  margin: 0 0 20px;
  font-size: 38px;
  font-weight: 500;
  color: #fff;
  text-align: center;
  font-family: "Noto Serif JP", serif;
}

.about_area .box {
  text-align: center;
  width: 920px;
  margin: 0 auto;
  padding: 24px 50px;
  box-sizing: border-box;
  background: #001a70;
}

.about_area .box h3 {
  margin: 0 20px 0 0;
  padding: 9px 50px 9px 0;
  line-height: 1.4;
  font-size: 28px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #fff;
  background: url(../img/ico_about_arw.png) 100% 50% no-repeat;
  text-align: center;
  border-bottom: 1px solid #ffffff;
}

.about_area .box .tit {
  font-size: 22px;
  margin-bottom: 0;
  margin-top: 14px;
}

.about_area .box p {
  color: #fff;
}

/*仕組み
=======================================================*/
.structure_area {
  padding: 90px 0 0px;
  background: url(../img/bg_structure_txt.png) calc(50% + 569px) 90px no-repeat;
}

.structure_area .img01 {
  margin: 26px auto 6%;
  width: 806px;
}

.structure_area .col2 {
  display: flex;
  justify-content: center;
}

.structure_area .col2 .txt {
  width: 463px;
  margin: 0 38px 0 0;
}

.structure_area .col2 h3 {
  position: relative;
  margin: 0 0 20px;
  padding: 0 0 0 32px;
  font-size: 24px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #111;
}
.structure_area .col2 h3::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 16px;
  height: 2px;
  background: #bc000f;
}

/*cv
=======================================================*/
.cv_button a {
  display: block;
  padding: 16px 39px 17px 28px;
  color: #fff;
  background-position: right 20px top 50%;
  background-size: 15px auto;
  transition: opacity 0.2s;
  background: url(../img/point_button.png) no-repeat #04a004;
  background-position: right 20px top 50%;
  text-align: center;
}
.cv_button02 a {
  display: block;
  padding: 7px 3px 5px 48px;
  color: #fff;
  background-position: right 20px top 50%;
  background-size: 15px auto;
  transition: opacity 0.2s;
  background: url(../img/point_button.png) no-repeat #04a004;
  background-position: right 20px top 50%;
}

.cv_right strong {
  font-weight: bold;
  color: #528d52;
  font-size: 25px;
}
.text-area span {
  color: #bd000e;
}
.cv_right {
  margin-left: 5%;
  font-size: 18px;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
}
.contact_weight span {
  font-weight: bold;
  font-family: メイリオ;
  color: #528d52;
  font-size: 34px;
}
.cv_area {
  padding: 80px 0 70px;
  background: url(../img/back2.png) 50% 50% no-repeat;
  background-size: cover;
}

.cv_area h2 {
  margin: 0 0 20px;
  font-size: 36px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #fff;
  text-align: center;
}

.cv_area .lead {
  margin: 0 0 35px;
  font-size: 18px;
  color: #fff;
  text-align: center;
}

.cv_area .box {
  width: 863px;
  margin: 0 auto;
}

.cv_area .box .tit {
  padding: 5px 0;
  font-size: 24px;
  color: #fff;
  background: #192331;
  text-align: center;
}

.text-box {
  background-color: #07237f;
  margin-top: -16px;
  font-variant: JIS04;
}

.suport {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 1080px;
  margin: 0 auto;
  padding: 30px 0 30px;
}

.cont-bx {
  color: #fff;
  font-size: 15px;
}

.inner-text {
  color: #fff;
  font-size: 19px;
}

.contact_weight {
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  font-size: 24px;
  text-align: center;
  margin-bottom: 0;
}
.text-area {
  display: flex;
  justify-content: space-around;
}
.cv_area .box .contact {
  justify-content: space-between;
  align-items: center;
  padding: 31px 60px 42px;
  background: url(../img/bg_cv_contact.png) 0 0 no-repeat #dddddd;
}

.cv_area .box .contact .tel {
  font-size: 42px;
  background: url(../img/ico_tel.png) 0 50% no-repeat;
  background-size: 61px auto;
}

.cv_num {
  line-height: 1;
  font-size: 40px;
  margin-top: 3px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #000;
  margin-left: 13%;
}
.cv_num::after {
  content: "";
  background: url(../img/tel_phone.png) 0 5px no-repeat;
  position: absolute;
  left: calc(50% - 398px);
  width: 213px;
  height: 50px;
}

.local-menu {
  width: 47%;
  height: 340px;
  padding: 4%;
  background-color: #dddddd;
  height: 230px;
}
.point-box0 {
  display: flex;
  margin: 50px auto 73px;
  justify-content: space-between;
}
p.local-font {
  margin-left: 5%;
  font-size: 18px;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
}
p.local-font02 {
  font-size: 16px;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  margin-top: 4%;
}
.tel_none .cv_area .box .contact {
  justify-content: center;
}

.about_area::after {
  content: "";
  position: absolute;
  left: calc(50% - 136px);
  bottom: -70px;
  width: 213px;
  height: 50px;
  background-size: contain;
  background: url(../img/point.png) 40px 0 no-repeat;
}

/*フロー
=======================================================*/
.flow02::after,
.flow03::after {
  content: "";
  position: absolute;
  left: -54px;
  top: calc(50% - 13px);
  width: 16px;
  height: 27px;
  background: url(../img/yajirushi.png) 50% 50% no-repeat;
  background-size: contain;
}

.flow_area {
  padding: 80px 0 120px;
  background: url(../img/yajirushit.png) 40px 0 no-repeat;
  background-size: 266px auto;
  overflow: hidden;
}

.flow_area h2 {
  margin: 0 0 50px;
  line-height: 1;
  font-size: 36px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #111;
  text-align: center;
}

.flow_area h2 .red {
  color: #001a70;
}

.flow_area h2 em {
  font-size: 54px;
  font-style: normal;
}

.flow_area .flow_inner {
  position: relative;
}

.flow_area ul {
  display: flex;
  justify-content: space-between;
}

.flow_area li {
  position: relative;
  padding: 30px 0 0;
  background: #ffffff;
  box-shadow: 0 0 10px 2px rgb(0 0 0 / 20%);
}

.flow_area li + li::before {
  content: "";
  position: absolute;
  left: -54px;
  top: calc(50% - 13px);
  width: 16px;
  height: 27px;
  background: url(../img/ico_flow_arw.png) 50% 50% no-repeat;
  background-size: contain;
}

.flow_area li .num {
  position: absolute;
  top: -13px;
  left: 130px;
  width: 62px;
  height: 57px;
  overflow-y: hidden;
}

.flow_area li .tit {
  margin: 0 0 30px;
  font-size: 20px;
  text-align: center;
}

.flow_area .catch {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  right: -52px;
  bottom: -51px;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  line-height: 1.4;
  font-size: 24px;
  color: #fff;
  background: linear-gradient(135deg, #001a70 50%, #133288 50%);
  box-shadow: 0 0 20px 5px rgb(0 0 0 / 20%);
  text-align: center;
}
.img_area {
  margin-bottom: 0;
}
/*メリット
=======================================================*/
.merit_area {
  padding: 90px 0 100px;
  background: url(../img/back04.png) no-repeat;
  background-size: cover;
}

.merit_area h2 {
  margin: 0 0 40px;
  font-size: 36px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  text-align: center;
  color: #fff;
}
.merit_bx {
  display: flex;
  text-align: center;
}

.merit_cont {
  width: 34%;
}

.merit_undercont {
  background-color: #fff;
  width: 70%;
  height: 260px;
  margin: 0 auto;
}

.merit_undercont h4 {
  font-family: "Noto Serif JP", serif;
  font-size: 22px;
  line-height: 1.2;
  padding-top: 18px;
  padding-left: 6%;
  text-align: left;
  color: #001868;
}

.merit_undercont p {
  font-size: 14px;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  line-height: 1.5;
  padding: 14px;
  text-align: left;
}

/*他社比較
=======================================================*/
.comparison_area {
  padding: 65px 0 28px;
  background: url(../img/bg_comparison_txt.png) 100% 0 no-repeat;
}

.graph_content {
  text-align: center;
  margin-bottom: 7%;
}

.comparison_area {
  margin: 0 0 0;
  font-size: 36px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #111;
  text-align: center;
}

/*選ばれる理由
=======================================================*/
.reason_area {
  padding: 90px 0 0;
  background: url(../img/bg_reason_txt.png) 0 100px no-repeat,
    url(../img/bg_reason.jpg) 50% 50% no-repeat;
  background-size: 379px auto, cover;
}

.reason_area .reason_inner {
  position: relative;
  height: 1180px;
  background: url(../img/bg_reason_5.png) 50% 70px no-repeat;
}

.reason_area .reason_inner .tit_area {
  position: absolute;
  top: 470px;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
}

.reason_area .reason_inner .tit_area .lead {
  line-height: 1;
  font-size: 32px;
  color: #161b22;
}

.reason_area .reason_inner .tit_area h2 {
  line-height: 1;
  font-size: 48px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #161b22;
}

.reason_area .reason_inner .tit_area h2 .red {
  color: #c61d2a;
}

.reason_area .reason_inner .tit_area h2 em {
  font-size: 68px;
  font-style: normal;
}

.reason_area .reason_inner li {
  position: absolute;
  top: 0;
  left: calc(50% - 140px);
  width: 280px;
}

.reason_area .reason_inner li .num {
  position: absolute;
  top: -16px;
  left: 87px;
  z-index: 2;
}

.reason_area .reason_inner li .tit {
  line-height: 1.4;
  font-size: 24px;
  color: #fff;
}

.reason_area .reason_inner li:nth-child(2) {
  top: 238px;
  left: calc(100% - 280px);
}

/*よくあるご質問
=======================================================*/
.faq_area {
  margin: 63px auto;
}
.faq_area h2 {
  margin: 0 0 35px;
  font-size: 36px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #111;
  text-align: center;
}
.cp_qa {
  width: 66%;
  margin: 0 auto;
}
.cp_qa *,
.cp_qa *:after,
.cp_qa *:before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.cp_qa .cp_actab {
  position: relative;
  overflow: hidden;
  width: 100%;
  margin: 0 0 1em 0;
  color: #fff;
}
.cp_qa .cp_actab input {
  position: absolute;
  opacity: 0;
}
/* 質問 */
.cp_qa .cp_actab label {
  font-size: 1em;
  line-height: 1.6em;
  position: relative;
  display: block;
  margin: 0 0 0 0;
  padding: 0.8em 2.5em 0.8em 3.5em;
  cursor: pointer;
  text-indent: 0.5em;
  border-radius: 0em;
  background: #001a70;
}
.cp_qa .cp_actab label::before {
  font-family: serif;
  font-size: 1.6em;
  margin-left: -1.8em;
  padding-right: 0.5em;
  content: "Q";
}
.cp_qa .cp_actab label:hover {
  transition: all 0.3s;
  color: #6890eb;
}
/* --質問の＋アイコン */
.cp_qa .cp_actab label::after {
  font-size: 1.7em;
  font-weight: bold;
  line-height: 2.2em;
  position: absolute;
  top: 0;
  right: 0;
  content: "＋";
  display: inline-block;
  width: 2em;
  height: 2em;
  -webkit-transition: transform 0.4s;
  transition: transform 0.4s;
}
/* 答え */
.cp_qa .cp_actab .cp_actab-content {
  position: relative;
  overflow: hidden;
  max-height: 0;
  padding: 0 0 0 2.5em;
  -webkit-transition: max-height 0.2s;
  transition: max-height 0.2s;
  border-radius: 0 0 0.5em 0.5em;
  background: #fff;
  color: #000;
}
.cp_qa .cp_actab .cp_actab-content::before {
  font-family: serif;
  font-size: 1.5em;
  position: absolute;
  margin: 0.4em 0 0 -1em;
  padding: 0;
  content: "A";
}
.cp_qa .cp_actab .cp_actab-content p {
  margin: 1em 1em 1em 0;
}
/* 質問を開いた時の仕様 */
/* --答えの高さ */
.cp_qa .cp_actab input:checked ~ .cp_actab-content {
  max-height: 40em;
  border: 2px solid rgb(157 157 157 / 50%);
}
/* 質問をクリックした時のアイコンの動き */
.cp_qa .cp_actab input:checked ~ label {
  color: #fff;
}
/* 質問をクリックした時の+の動き */
.cp_qa .cp_actab input[type="checkbox"]:checked + label::after {
  -webkit-transform: rotateZ(45deg);
  transform: rotateZ(45deg);
  -webkit-transform-origin: 50% 50%;
  transform-origin: 50% 50%;
}

/*お問い合わせフォーム
=======================================================*/
.form_area {
  padding: 70px 0;
  background: url(../img/form_back.png) 50% 50% no-repeat;
  background-size: cover;
  font-family: "Noto Serif JP", serif;
}

.form_area h2 {
  margin: 0 0 5px;
  font-size: 36px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #fff;
  text-align: center;
}

.form_area .lead {
  margin: 0 0 30px;
  font-size: 18px;
  color: #fff;
  text-align: center;
}

.form_area table {
  width: 920px;
  margin: 0 auto;
}

.form_area th {
  position: relative;
  width: 240px;
  padding: 12px 68px 0 0;
  box-sizing: border-box;
  font-size: 18px;
  font-weight: normal;
  color: #fff;
  vertical-align: top;
  text-align: left;
}

.form_area th span {
  position: absolute;
  right: 20px;
  top: 18px;
  line-height: 23px;
  padding: 0 6px;
  font-size: 16px;
  background: #ff3747;
}

.form_area td {
  padding: 10px 0;
  color: #fff;
}

.form_area td input[type="number"],
.form_area td input[type="text"],
.form_area td input[type="email"],
.form_area td textarea {
  width: 100% !important;
  padding: 12px 10px;
  box-sizing: border-box;
}
.form_area td input[type="number"] {
  padding: 5px 10px;
}
.form_area td select {
  padding: 12px 10px;
  box-sizing: border-box;
}
.form_area td input[type="tel"] {
  padding: 12px 10px;
  box-sizing: border-box;
}

.form_area button[type="submit"],
.form_area input[type="submit"] {
  position: relative;
  padding: 24px 67px 24px 50px;
  border-radius: 8px;
  font-size: 24px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #fff;
  background: url(../img/ico_arw.png) no-repeat #04a004;
  background-position: right 20px top 50%;
  background-size: 9px auto;
  border: none;
}
/*職人エラーメッセージ*/
.form_area .err_block {
  width: 920px;
  margin: 0 auto;
}

.form_area .err_block .err_tit {
  color: #fff;
  text-align: center;
}

.form_area #errorMessage {
  padding: 0 0 0 240px;
}

.form_area #errorMessage p {
  font-weight: bold;
  color: #fff;
}

.form_area td .error {
  background: #ffb2b2;
}
/*確認画面*/
.form_area.confirm {
  background: none;
}

.form_area.confirm .lead {
  display: none;
}

.form_area.confirm p,
.form_area.confirm h2,
.form_area.confirm .err_block .err_tit,
.form_area.confirm #errorMessage p,
.form_area.confirm th,
.form_area.confirm td {
  color: #333;
}

.form_area.confirm th span {
  color: #fff;
}

.form_area.confirm table {
  border-spacing: 0;
  border-top: 1px solid #333;
  border-left: 1px solid #333;
}

.form_area.confirm th,
.form_area.confirm td {
  padding-left: 15px;
  border-right: 1px solid #333;
  border-bottom: 1px solid #333;
}
/*完了画面*/
.form_area .comp_tit {
  margin: 0 0 50px;
  font-size: 20px;
  text-align: center;
}

.form_area .comp_back {
  margin: 50px 0 0;
  text-align: center;
}

.form_area .comp_back a {
  text-decoration: underline;
}
.form_area .comp_back a:hover {
  text-decoration: none;
}

/*会社概要
=======================================================*/
.conpany_cont {
  justify-content: space-between;
  display: flex;
  width: 87%;
  margin: 54px auto;
}
.conpany_right {
  width: 58%;
}
dd .company_area {
  padding: 85px 0 120px;
}

.company_area h2 {
  margin: 35px 0 35px;
  font-size: 36px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #111;
  text-align: center;
}

.company_area table {
  width: 100%;
  border-collapse: collapse;
  font-size: 15px;
  border-top: 1px solid #dbdbdb; /* [15. 表組み設定]　枠線色 */
  border-left: 1px solid #dbdbdb; /* [15. 表組み設定]　枠線色 */
}

.company_area table th {
  font-weight: bold;
  padding: 10px;
  line-height: 1.5;
  text-align: left;
  color: #333; /* [15. 表組み設定]　th文字色 */
  border-right: 1px solid #dbdbdb; /* [15. 表組み設定]　枠線色 */
  border-bottom: 1px solid #dbdbdb; /* [15. 表組み設定]　枠線色 */
  background: #f2f2f2; /* [15. 表組み設定]　th背景色 */
}

.company_area table td {
  padding: 10px;
  text-align: left;
  line-height: 1.5;
  border-right: 1px solid #dbdbdb; /* [15. 表組み設定]　枠線色 */
  border-bottom: 1px solid #dbdbdb; /* [15. 表組み設定]　枠線色 */
}

/*フッター
=======================================================*/
footer .info_area {
  padding: 39px 0;
  background: #f2f2f2;
}

footer .foot_in {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

footer .foot_in .address {
  line-height: 1.4;
}

footer .copy {
  padding: 13px 0;
  text-align: center;
}

/*CVボタン
=======================================================*/
.btn_cv {
  position: relative;
  border-radius: 8px;
  line-height: 1;
  font-size: 24px;
  font-family: "Noto Serif JP", serif;
  overflow: hidden;
}

.btn_cv a {
  display: block;
  padding: 16px 67px 17px 50px;
  border-radius: 8px;
  color: #fff;
  background: url(../img/point_button.png) no-repeat #04a004;
  background-position: right 20px top 50%;
  background-size: 15px auto;
  transition: opacity 0.2s;
}
.btn_cv a:hover {
  text-decoration: none;
  opacity: 0.8;
}

@keyframes btn_cv {
  0% {
    transform: rotate(-45deg) translateY(0);
  }
  6% {
    transform: rotate(-45deg) translateY(60%);
  }
  20% {
    transform: rotate(-45deg) translateY(200%);
  }
  100% {
    transform: rotate(-45deg) translateY(200%);
  }
}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

.pc_none {
  display: none;
}

.overimg {
  transition: opacity 0.2s;
}
.overimg:hover {
  opacity: 0.7;
}
.ipadonly {
  display: none;
}

/*==========================================================================
  タブレット
==========================================================================*/
@media (max-width: 1024px) and (min-width: 1023px) {
  .cv_button02 a {
    padding: 7px 3px 5px 85px;
  }
  .cv_num::after {
    left: calc(50% - 442px);
  }
}
@media (max-width: 1022px) and (min-width: 768px) {
  .trouble_area .comment {
    width: 768px;
    height: 382px;
    background: url(../img/coment_02.png) 0 0 no-repeat;
  }
  .trouble_area .comment p {
    font-size: 18px;
  }
  .trouble_area .comment p:nth-child(1) {
    top: 61px;
    left: 81px;
  }
  .trouble_area .comment p:nth-child(2) {
    top: 71px;
    left: 507px;
  }
  .trouble_area .comment p:nth-child(3) {
    top: 150px;
    left: 72px;
  }
  .trouble_area .comment p:nth-child(5) {
    top: 270px;
    left: 65px;
  }
  .trouble_area .comment p:nth-child(4) {
    top: 181px;
    left: 553px;
  }
  .trouble_area .comment p:nth-child(6) {
    top: 297px;
    left: 499px;
  }
  .trouble_area {
    padding: 45px 0 10px;
  }

  .cv_num::after {
    left: calc(50% - 337px);
  }
}

@media screen and (max-width: 1024px) {
  .ipadonly {
    display: block;
  }
  /*ヘッダー
=======================================================*/
  header h1 {
    width: 35%;
    margin-left: 2%;
    margin-top: 1%;
  }
  header .inner {
    width: 100%;
  }
  .inner {
    width: 100%;
  }
  header .cv {
    margin-right: 2%;
  }
  .btn_cv {
    width: 100%;
    margin: 6px auto 1%;
  }
  /*メインビジュアル
=======================================================*/
  .suport {
    display: block;
    margin: 0 auto;
    width: 90%;
    text-align: center;
  }
  .news_area {
    width: 95%;
    margin: 0 auto;
    padding: 25px 0;
    font-size: 15px;
  }
  /*お悩み
=======================================================*/
  .trouble_area h2 {
    width: 100%;
  }
  /*ファクタリングとは
=======================================================*/
  .about_area .box {
    width: 90%;
  }
  .structure_area .img01 {
    width: 726px;
    margin: 0 auto 4%;
  }
  /*cv
=======================================================*/
  .cv_area .box {
    width: 93%;
    margin: 0 auto;
  }
  .cv_right {
    margin-left: 3%;
  }
  .cv_area .box .contact {
    padding: 20px 28px 38px;
  }
  .cv_button a {
    padding: 11px 33px 10px 21px;
  }
  .local-menu {
    height: 246px;
    padding: 6% 7% 6%;
  }
  .cv_area {
    padding: 80px 0 1px;
  }
  p.local-font {
    text-align: center;
  }
  /*フロー
=======================================================*/
  .flow_area .flow_inner {
    width: 90%;
    margin: 0 auto;
    justify-content: space-between;
  }
  .flow_area li {
    width: 30%;
  }
  .flow_area li .num {
    left: 42%;
  }
  .flow_area .catch {
    right: -29px;
    bottom: -87px;
    width: 121px;
    height: 121px;
    font-size: 19px;
  }
  .flow02::after,
  .flow03::after {
    content: "";
    position: absolute;
    left: -22px;
    top: calc(50% - 13px);
    width: 16px;
    height: 27px;
    background: url(../img/yajirushi.png) 50% 50% no-repeat;
    background-size: contain;
  }
  /*メリット
=======================================================*/
  .merit_bx {
    width: 93%;
    margin: 0 auto;
    justify-content: space-between;
  }
  .merit_cont {
    width: 31%;
  }
  .merit_area {
    padding: 48px 0 70px;
  }
  .merit_undercont {
    width: 100%;
    height: 273px;
    margin: 0 auto;
  }
  /*よくある質問
=======================================================*/
  .cp_qa {
    width: 92%;
  }
  /*フォーム
=======================================================*/
  .form_area table {
    width: 94%;
    margin: 0 auto;
  }
  .form_area {
    padding: 47px 0;
  }
  /*会社概要
=======================================================*/
  .conpany_cont {
    width: 93%;
    margin: 38px auto;
  }
  .conpany_right {
    width: 74%;
    margin-left: 4%;
  }
  .company_area table th {
    font-size: 14px;
  }
  .company_area table td {
    font-size: 14px;
  }
  /*フッター
=======================================================*/
  footer .foot_in {
    width: 90%;
  }
}

@media only screen and (max-width: 750px) {
  .ipadonly {
    display: none;
  }
  /*ヘッダー
=======================================================*/
  header h1 {
    width: 80%;
  }
  header .cv {
    display: none;
  }

  header {
    width: 82%;
    padding: 18px 26px 0px 19px;
  }

  .suport {
    display: block;
    width: 90%;
    text-align: center;
  }
  .inner-text {
    font-size: 16px;
  }

  .cont-bx {
    font-size: 17px;
  }

  .btn_cv {
    font-size: 19px;
  }

  .txt_inner img {
    width: 92%;
  }
  /*メインビジュアル
=======================================================*/
  .kv_area li img {
    width: 100%;
    height: auto;
  }
  .kv_area .txt_inner {
    width: 100%;
    left: 0;
    top: 30px;
  }

  /*お知らせ
=======================================================*/
  .news_area {
    margin: 0 auto;
    width: 92%;
    padding: 28px 0;
  }
  .sp_none {
    display: none;
  }
  .pc_none {
    display: block;
  }
  .news_area li {
    display: block;
  }
  p.txt {
    font-size: 15px;
  }
  /*お悩み
=======================================================*/
  .trouble_area h2 {
    width: 100%;
  }
  .trouble_area .comment {
    width: 95%;
    background: url(../img/sp/coment.png) 0 0 no-repeat;
    position: relative;
    padding: 0 0 145.9%;
    margin: 0 auto;
    background-size: 100% auto;
    top: 35px;
    margin-bottom: -14%;
  }
  .trouble_area h2 {
    font-size: 29px;
    width: 93%;
    margin: 0 auto;
  }
  .trouble_area {
    padding: 50px 0 10px;
    background: url(../img/sp/back.png) 50% 50% no-repeat;
    background-size: cover;
    overflow: hidden;
  }
  .trouble_area .comment p {
    font-size: 4.6vw;
  }
  .trouble_area .comment p:nth-child(1) {
    top: 2%;
    left: 13%;
  }
  .trouble_area .comment p:nth-child(2) {
    top: 15.5%;
    left: 15%;
  }
  .trouble_area .comment p:nth-child(3) {
    top: 29.4%;
    left: 8%;
  }
  .trouble_area .comment p:nth-child(4) {
    top: 43%;
    left: 21%;
  }
  .trouble_area .comment p:nth-child(5) {
    top: 57.5%;
    left: 6%;
  }
  .trouble_area .comment p:nth-child(6) {
    top: 71%;
    left: 29%;
  }
  /*ファクタリングとは
=======================================================*/
  .about_area .box {
    width: 100%;
  }
  .structure_area .img01 {
    width: 100%;
  }
  .about_area h2 {
    font-size: 30px;
    line-height: 1.3;
  }
  .about_area .box {
    width: 90%;
    padding: 6px 11px;
  }
  .about_area .box h3 {
    padding: 6px 0 6px;
    margin: 5px;
    font-size: 24px;
  }
  /*仕組み
=======================================================*/
  .structure_area {
    padding: 52px 0 0px;
  }
  /*cv
=======================================================*/
  .cv_button02 a {
    padding: 7px 3px 5px 61px;
  }
  .cv_num {
    text-align: center;
  }
  .cv_area .box {
    width: 100%;
  }
  .inner {
    width: 100%;
  }
  .cv_area {
    padding: 30px 0 6px;
  }
  .cv_area h2 {
    font-size: 26px;
    line-height: 1.5;
    width: 95%;
    margin: 0 auto;
  }
  .cv_area .lead {
    width: 95%;
    margin: 18px auto 24px;
  }
  .cv_area .box .contact {
    padding: 20px 15px 13px;
  }
  .contact_weight {
    font-size: 22px;
    line-height: 1.4;
  }
  .cv_right strong {
    font-size: 20px;
  }
  .cv_right p {
    line-height: 1.7;
    margin: 19px auto 19px;
  }
  p.pc_none {
    text-align: center;
  }
  .point-box0 {
    display: block;
    margin: 50px 0 0;
  }
  .local-menu {
    width: 100%;
    margin: 0 auto 14%;
    height: auto;
  }
  .cv_num::after {
    left: calc(51% - 42%);
  }
  /*フロー
=======================================================*/
  .flow02::after,
  .flow03::after {
    content: "";
    position: absolute;
    left: 47%;
    top: -57px;
    width: 16px;
    height: 27px;
    margin: 0 0 0 -8px;
    background: url(../img/sp/yajirushi.png) 50% 50% no-repeat;
    background-size: contain;
  }
  .flow_area {
    padding: 32px 0 0px;
  }
  .flow_area h2 {
    font-size: 28px;
  }
  .flow_area h2 em {
    font-size: 42px;
  }
  .flow_area ul {
    display: block;
  }
  .flow_area li .num {
    top: -9px;
    left: 44%;
  }
  .flow_area li .tit {
    font-size: 18px;
    margin: 0 0 9px;
  }
  .flow_area li {
    padding: 20px 0 0;
    margin: 0 0 80px;
    width: 100%;
  }
  .flow_area .catch {
    right: -2%;
    bottom: -6%;
    width: 113px;
    height: 113px;
    font-size: 18px;
  }
  /*メリット
=======================================================*/
  .merit_area h2 {
    font-size: 30px;
    line-height: 1.3;
  }
  .merit_area {
    padding: 40px 0 40px;
  }
  .merit_cont {
    width: 87%;
    margin: 0 auto;
    margin-bottom: 13%;
  }
  .merit_undercont {
    width: 100%;
    height: 202px;
  }
  /*他社との比較
=======================================================*/
  .graph_content {
    margin-bottom: 13%;
  }
  .comparison_area {
    padding: 28px 0 28px;
  }
  h2.comparison_area {
    font-size: 30px;
  }
  /*よくあるご質問
=======================================================*/
  .cp_qa {
    width: 90%;
  }
  .faq_area h2 {
    font-size: 30px;
    margin: 0 0 5%;
  }
  .faq_area {
    margin: 32px auto 45px;
  }
  .cp_qa .cp_actab label::before {
    font-size: 1em;
  }
  .cp_qa .cp_actab label::after {
    right: -11px;
  }
  .cp_qa .cp_actab label {
    padding: 0.8em 2.5em 0.8em 2.5em;
  }
  /*会社概要
=======================================================*/
  .conpany_cont {
    display: block;
    margin: 0 auto;
  }
  .company_area h2 {
    font-size: 30px;
    margin: 21px 0 5%;
  }
  .conpany_right {
    width: 100%;
    margin-top: 8%;
    margin-bottom: 14%;
    margin-left: 0;
  }
  footer .foot_in {
    display: block;
    text-align: center;
  }
  footer .info_area {
    padding: 31px 0 14px;
  }
  .company_1 img {
    width: 100%;
  }
  /*フォーム
=======================================================*/
  .form_area h2 {
    font-size: 30px;
    margin: 0;
  }
  .form_area {
    padding: 36px 0;
  }
  .form_area .lead {
    line-height: 1.4;
    width: 90%;
    margin: 0 auto;
  }
  .form_area button[type="submit"],
  .form_area input[type="submit"] {
    padding: 9px 67px 9px 57px;
    font-size: 20px;
  }
  .form_area table {
    width: 90%;
  }
  .form_area th {
    display: block;
    width: 100%;
    padding: 12px 20px 0 0;
    box-sizing: border-box;
    font-size: 15px;
    font-weight: normal;
    color: #fff;
    vertical-align: top;
    text-align: left;
  }
  .form_area td {
    display: block;
    padding: 10px 0;
    color: #fff;
  }
  .form_area th span {
    display: inline-block;
    line-height: 23px;
    padding: 0 6px;
    margin: 0 0 0 20px;
    font-size: 13px;
    background: #ff3747;
    top: 12px;
    right: auto;
  }
  .form_area td select {
    font-size: 15px;
  }
  .form_area td input[type="text"],
  .form_area td input[type="email"],
  .form_area td textarea {
    padding: 5px 12px;
  }
  .form_area td input[type="tel"] {
    padding: 5px 9px;
  }
  /*ついてくるcv
=======================================================*/
  .fix_cv {
    position: fixed;
    left: 0;
    bottom: 0;
    top: auto;
    width: 100%;
    height: 50px;
    z-index: 3;
    letter-spacing: -0.4em;
  }
  .tel_none .fix_cv {
    height: 50px;
  }

  .fix_cv .sp_col {
    width: 100%;
    font-size: 13px;
    font-weight: 500;
    background: #b0000d;
  }
  .fix_cv .sp_col.tel {
    width: 100%;
    letter-spacing: normal;
    margin-bottom: 0;
  }
  .fix_cv .sp_col.mail {
    display: inline-block;
    background: #04a004;
    letter-spacing: normal;
  }
  .fix_cv .sp_col.line {
    display: inline-block;
    background: #04a004;
    letter-spacing: normal;
  }
  .fix_cv .sp_col a {
    display: block;
    color: #fff;
    text-align: center;
  }

  .fix_cv .sp_col span {
    display: inline-block;
    line-height: 50px;
    padding: 0 0 0 25px;
    background: url(../img/tel.png) 0 50% no-repeat;
    background-size: 16px auto;
    text-align: center;
  }
  .fix_cv .sp_col.mail span {
    padding-left: 30px;
    background: url(../img/mail.png) 0 50% no-repeat;
    background-size: 20px auto;
  }
  .fix_cv .sp_col.line span {
    padding-left: 35px;
    background: url(../img/line.png) 0 50% no-repeat;
    background-size: 32px auto;
  }
  /*フッター
=======================================================*/
  footer .foot_in .address {
    padding-bottom: 7%;
  }
  footer {
    margin-bottom: 100px;
  }
}
