@charset "UTF-8";

html,
body {
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "Hiragino Sans", "ヒラギノ角ゴ ProN", apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Meiryo, sans-serif
}

body {
    font-size: 16px;
    line-height: 1.7;
    color: #1a1a1a;
    background: #fff
}

p {
    font-size: 16px;
    line-height: 1.7;
    font-weight: 400;
    color: #1a1a1a;
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "Hiragino Sans", "ヒラギノ角ゴ ProN", apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Meiryo, sans-serif
}

.font-gothic {
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "Hiragino Sans", "ヒラギノ角ゴ ProN", apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Meiryo, sans-serif
}

.font-mincho {
    font-family: "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif
}

.font-roboto {
    font-family: 'arial narrow', sans-serif
}

article.content_article {
    padding: 50px 0
}

article.content_article.none_pt {
    padding-top: 0
}

article.content_article.none_pb {
    padding-bottom: 0
}

.wrap {
    width: 960px;
    box-sizing: border-box;
    margin: 0 auto
}

.middle_wrap {
    width: 1400px;
    box-sizing: border-box;
    margin: 0 auto
}

.full_wrap {
    width: 96%;
    width: -webkit-calc(100% - 100px);
    width: calc(100% - 100px);
    box-sizing: border-box;
    margin: 0 auto
}

.wrap_w {
    background: #fff
}

.wrap_s_b {
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.5)
}

.wrap_s_w {
    box-shadow: 0 0 5px rgba(255, 255, 255, 0.8)
}

.lp_bg_dot {
    background: #f1f1f1;
    background-image: radial-gradient(#e3e3e3 6%, transparent 12%), radial-gradient(#e3e3e3 6%, transparent 12%);
    background-position: 0 0, 11px 11px;
    background-size: 22px 22px
}

.lp_bg_line {
    background: #000;
    background-image: linear-gradient(-90deg, rgba(255, 255, 255, 0.3) 0, transparent 1%, transparent 100%);
    background-size: 100px
}

.common_h2 {
    margin-bottom: 50px
}

.common_h2 .sub {
    font-family: "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
    text-align: center;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 1px;
    font-style: italic;
    color: #ccc;
    margin-bottom: 5px
}

.common_h2 h2 {
    font-family: 'ヒラギノ角ゴ ProN W6', 'HiraKakuProN-W6', 'HiraKakuProN-W6', sans-serif;
    text-align: center;
    font-size: 32px;
    line-height: 1.6;
    font-weight: 900;
    padding-bottom: 30px;
    position: relative
}

.common_h2 h2::before {
    content: "";
    display: block;
    width: 150px;
    height: 1px;
    background: #000;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto
}

.common_h2 h2 span {
    color: #0c43ac;
    font-size: 130%
}

.common_h2.c2 h2 {
    color: #fff
}

.common_h2.c2 h2::before {
    background: #fff
}

.common_h2.c2 h2 span {
    color: #fcee21
}

.common_h2_2 {
    margin-bottom: 50px;
    position: relative
}

.common_h2_2 h2 {
    font-family: 'ヒラギノ角ゴ ProN W6', 'HiraKakuProN-W6', 'HiraKakuProN-W6', sans-serif;
    text-align: center;
    font-size: 32px;
    line-height: 1.6;
    font-weight: 900
}

.common_h2_2 h2 span {
    color: #0c43ac;
    line-height: 1.3;
    font-size: 200%
}

.common_h2_2::before,
.common_h2_2::after {
    content: "";
    display: block;
    width: 80px;
    height: 80px;
    background-size: cover;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit- transform: translateY(-50%)
}

.common_h2_2::before {
    background-image: url(../images/c/point_1.png);
    left: 160px
}

.common_h2_2::after {
    background-image: url(../images/c/point_2.png);
    right: 180px
}

h3.common_h3 {
    font-size: 24px;
    line-height: 1.5;
    color: #1a1a1a;
    font-weight: 600
}

p.p_c {
    text-align: center
}

small {
    font-size: 80%
}

strong {
    font-weight: 900;
    font-family: 'ヒラギノ角ゴ ProN W6', 'HiraKakuProN-W6', 'HiraKakuProN-W6', sans-serif
}

.fsb {
    font-size: 130%
}

.fsb_l {
    font-size: 160%
}

.tc1 {
    color: #980000
}

.tc2 {
    color: #0065ad
}

.tc3 {
    color: #ce9b2f
}

.tc4 {
    color: #6e3a87
}

.tc5 {
    color: #e1003a
}

.tm1 {
    background: linear-gradient(transparent 40%, #efcaca 0)
}

.tm2 {
    background: linear-gradient(transparent 40%, #d3e9ef 0)
}

.tm3 {
    background: linear-gradient(transparent 40%, #ffeab0 0)
}

.tm4 {
    background: linear-gradient(transparent 40%, #fd0 0)
}

.tul1 {
    border-bottom: 3px double #980000;
    display: inline-block;
    line-height: 1.3
}

.tul2 {
    border-bottom: 3px double #0065ad;
    display: inline-block;
    line-height: 1.3
}

.tul3 {
    border-bottom: 3px double #ce9b2f;
    display: inline-block;
    line-height: 1.3
}

.tul4 {
    border-bottom: 3px double #6e3a87;
    display: inline-block;
    line-height: 1.3
}

.tul5 {
    border-bottom: 3px double #000;
    display: inline-block;
    line-height: 1.3
}

.tw1 {
    text-decoration: underline wavy #efcaca
}

.tw2 {
    text-decoration: underline wavy #d3e9ef
}

.tw3 {
    text-decoration: underline wavy #ffeab0
}

.tw4 {
    text-decoration: underline wavy #ddd
}

.td1 {
    border-bottom: dotted 2px #980000
}

.td2 {
    border-bottom: dotted 2px #0065ad
}

.td3 {
    border-bottom: dotted 2px #ce9b2f
}

.td4 {
    border-bottom: dotted 2px #999
}

.tbg1 {
    background: #980000;
    color: #fff;
    display: inline
}

.tbg2 {
    background: #0065ad;
    color: #fff;
    display: inline
}

.tbg3 {
    background: #ce9b2f;
    color: #fff;
    display: inline
}

.tbg4 {
    background: #6e3a87;
    color: #fff;
    display: inline
}

.tbg5 {
    background: #333;
    color: #fff;
    display: inline
}

.te1 {
    color: #980000;
    background: linear-gradient(transparent 40%, #ffeab0 0)
}

.te2 {
    color: #0065ad;
    background: linear-gradient(transparent 40%, #ffeab0 0)
}

.te3 {
    color: #ce9b2f;
    background: linear-gradient(transparent 40%, #ddeaf4 0)
}

.te4 {
    color: #e1003a;
    background: linear-gradient(transparent 40%, #fd0 0)
}

.brSp {
    display: none
}

.lp_m {
    margin: 50px 0
}

.lp_m_auto {
    margin: 50px auto
}

.lp_p {
    padding: 0 50px
}

.lp_mt {
    margin-top: 50px
}

.lp_pt {
    padding-top: 50px
}

.lp_mb {
    margin-bottom: 50px
}

.lp_pb {
    padding-bottom: 50px
}

.lp_img img {
    display: block
}

.lp_img.be_border img {
    box-sizing: border-box;
    border: solid 1px #e0e0e0
}

img.fr {
    display: block;
    float: right;
    max-width: 300px;
    margin-left: 15px;
    margin-bottom: 15px
}

figure figcaption {
    text-align: right;
    font-size: 11px;
    line-height: 2;
    color: #666
}

.lp2c {
    display: flex;
    justify-content: space-between
}

.lp2c > div {
    width: 48%
}

.lp2c.lp2c_r {
    flex-flow: row-reverse
}

.mov {
    width: 100%;
    height: auto;
    position: relative
}

.mov::before {
    content: "";
    display: block;
    padding-top: 56.2%
}

.mov iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.inner_content .ic_container {
    width: 91%;
    width: -webkit-calc(100% - 100px);
    width: calc(100% - 100px);
    margin: 0 auto 50px;
    background: #f1f1f1;
    box-sizing: border-box;
    position: relative
}

.inner_content .ic_container:last-child {
    margin: 0 auto
}

.inner_content .ic_container > .ic_first_wrap {
    padding: 30px
}

.inner_content .ic_container .ic_title img {
    display: block;
    width: 100%
}

.inner_content.be_bg {
    background: #f1f1f1;
    padding: 50px 0
}

.inner_content.be_bg .ic_container {
    background: #fff;
    position: relative
}

.inner_content.be_line .ic_container::before {
    content: "";
    display: block;
    width: 2px;
    height: 50px;
    position: absolute;
    bottom: -50px;
    left: 0;
    right: 0;
    margin: 0 auto;
    background: #ddd
}

.inner_content.be_line .ic_container:last-child::before {
    content: none
}

.inner_content.be_flow .ic_container::before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 20px 25px 0 25px;
    border-color: #ddd transparent transparent transparent;
    position: absolute;
    bottom: -34px;
    left: 0;
    right: 0;
    margin: 0 auto
}

.inner_content.be_flow .ic_container:last-child::before {
    content: none
}

.inner_content.be_border .ic_container {
    border: solid 2px #000
}

.tag_list.be_bg ul {
    background: #f1f1f1;
    padding: 30px
}

.tag_list ul li {
    font-size: 18px;
    line-height: 1.5;
    color: #333;
    font-weight: bold;
    background: #fff;
    padding: 20px 15px;
    border-left: solid 15px #13434f;
    margin-bottom: 10px;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.2)
}

.tag_list ul li:last-child {
    margin-bottom: 0
}

.faq_list ul li {
    padding: 30px;
    background: #fff;
    margin-bottom: 20px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
    border-radius: 7px
}

.faq_list ul li:last-child {
    margin-bottom: 0
}

.faq_list dl dt,
.faq_list dl dd {
    display: flex;
    justify-content: space-between
}

.faq_list dl dt {
    margin-bottom: 15px;
    border-bottom: solid 1px #ddd;
    padding-bottom: 15px
}

.faq_list dl dt .txt {
    font-size: 22px;
    font-weight: bold
}

.faq_list dl i {
    width: 35px;
    height: 35px;
    line-height: 35px;
    font-size: 20px;
    color: #fff;
    font-weight: bold;
    text-align: center;
    border-radius: 50%
}

.faq_list dl i.q::before {
    content: "Q"
}

.faq_list dl i.a::before {
    content: "A"
}

.faq_list dl i.q {
    background: #ff6e1d
}

.faq_list dl i.a {
    background: #0065ad
}

.faq_list dl .txt {
    width: 92%;
    width: -webkit-calc(100% - 50px);
    width: calc(100% - 50px);
    font-size: 16px
}

.faq_list dl dd .txt {
    padding-top: 5px
}

header.hero_area {
    position: relative;
    background-image: url(../images/hero/hero_bg.jpg);
    background-size: cover;
    background-position: center;
    padding-top: 30px
}

header.hero_area .wrap {
    position: relative
}

header.hero_area .hp1 {
    width: 90%;
    filter: drop-shadow(0 0 10px rgba(0, 0, 0, 0.3));
    margin: 0 auto 30px
}

header.hero_area .hero_title {
    margin: 0 auto 70px
}

header.hero_area .hero_title .hp2 {
    width: 50%;
    margin: 0 auto 15px
}

header.hero_area .hp2c {
    display: flex;
    justify-content: space-between
}

header.hero_area .hp2c .lc {
    width: 43%
}

header.hero_area .hp2c .rc {
    width: 55%
}

header.hero_area .hp2c .rc .hp_btn {
    margin: 15px auto 20px
}

header.hero_area .hp5.hp5-sp {
    display: none
}

header.hero_area .hp-vin {
    padding-bottom: 30px
}

header.hero_area .hp1,
header.hero_area .hp2,
header.hero_area .hp3,
header.hero_area .hp4,
header.hero_area .hp5,
header.hero_area .hp6,
header.hero_area .hp_btn,
header.hero_area .hp-vin {
    opacity: 0;
    position: relative;
    top: 30px
}

#before_after .ba_sec1 {
    text-align: center;
    padding: 30px 0;
    position: relative;
    background: -moz-linear-gradient(0 50% 0, rgba(0, 113, 188, 1) .14%, rgba(102, 45, 145, 1) 99.81%);
    background: -webkit-linear-gradient(0, rgba(0, 113, 188, 1) .14%, rgba(102, 45, 145, 1) 99.81%);
    background: -webkit-gradient(linear, 0 50%, 100% 50%, color-stop(0.0014, rgba(0, 113, 188, 1)), color-stop(0.9981, rgba(102, 45, 145, 1)));
    background: -o-linear-gradient(0, rgba(0, 113, 188, 1) .14%, rgba(102, 45, 145, 1) 99.81%);
    background: -ms-linear-gradient(0, rgba(0, 113, 188, 1) .14%, rgba(102, 45, 145, 1) 99.81%);
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr='#0071BC', endColorstr='#662D91' ,GradientType=0)";
    background: linear-gradient(90deg, rgba(0, 113, 188, 1) .14%, rgba(102, 45, 145, 1) 99.81%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#0071BC', endColorstr='#662D91', GradientType=1)
}

#before_after .ba_sec1 h2 {
    text-align: center;
    font-size: 32px;
    font-weight: 900;
    line-height: 1.5;
    background: #fff;
    color: #0c43ac;
    display: inline-block;
    padding: 15px 30px 5px;
    border-radius: 50px;
    margin-bottom: 15px;
    box-shadow: 10px 10px 10px rgba(0, 0, 0, 0.2)
}

#before_after .ba_sec1 h2 span {
    font-size: 24px
}

#before_after .ba_sec1 p {
    text-align: center;
    font-size: 26px;
    font-weight: bold;
    color: #fff
}

#before_after .ba_sec2 {
    padding: 30px 0 40px;
    position: relative
}

#before_after .ba_sec2::before {
    content: "";
    display: block;
    width: 100px;
    height: 100px;
    background-image: url(../images/c/ba_1.png);
    background-size: cover;
    position: absolute;
    top: -33px;
    left: 0;
    right: 0;
    margin: auto
}

#before_after .ba_sec2 .ba_list {
    display: flex;
    justify-content: space-between
}

#before_after .ba_sec2 .ba_list > div {
    width: 47%;
    box-sizing: border-box
}

#before_after .ba_sec2 .ba_list h3 {
    text-align: center;
    font-size: 36px;
    font-weight: 900;
    letter-spacing: 1px;
    margin-bottom: 10px
}

#before_after .ba_sec2 .ba_list .ba_b h3 {
    color: #11376b
}

#before_after .ba_sec2 .ba_list .ba_a h3 {
    color: #ff6e1d
}

#before_after .ba_sec2 .ba_content {
    background: #fff;
    padding: 30px;
    box-shadow: 7px 7px 0 #ccc
}

#before_after .ba_sec2 .ba_content ul li {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px
}

#before_after .ba_sec2 .ba_content ul li:last-child {
    margin-bottom: 0
}

#before_after .ba_sec2 .ba_content ul li i {
    width: 25px
}

#before_after .ba_sec2 .ba_content ul li i img {
    display: block
}

#before_after .ba_sec2 .ba_content ul li .txt {
    width: 90%;
    width: -webkit-calc(100% - 35px);
    width: calc(100% - 35px);
    font-size: 16px;
    font-weight: bold;
    color: #333
}

#about {
    position: relative
}

#about .wrap {
    position: relative
}

#about p {
    font-weight: bold
}

#about .about_1 {
    width: 75%;
    margin: auto
}

.about_bg {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0
}

.area {
    width: 100%;
    height: 100%
}

.circles {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden
}

.circles li {
    position: absolute;
    display: block;
    list-style: none;
    width: 20px;
    height: 20px;
    background: #dde8fd;
    animation: animate 25s linear infinite;
    bottom: -150px
}

.circles li:nth-child(1) {
    left: 25%;
    width: 80px;
    height: 80px;
    animation-delay: 0
}

.circles li:nth-child(2) {
    left: 10%;
    width: 20px;
    height: 20px;
    animation-delay: 2s;
    animation-duration: 12s
}

.circles li:nth-child(3) {
    left: 70%;
    width: 20px;
    height: 20px;
    animation-delay: 4s
}

.circles li:nth-child(4) {
    left: 40%;
    width: 60px;
    height: 60px;
    animation-delay: 0;
    animation-duration: 18s
}

.circles li:nth-child(5) {
    left: 65%;
    width: 20px;
    height: 20px;
    animation-delay: 0
}

.circles li:nth-child(6) {
    left: 75%;
    width: 110px;
    height: 110px;
    animation-delay: 3s
}

.circles li:nth-child(7) {
    left: 35%;
    width: 150px;
    height: 150px;
    animation-delay: 7s
}

.circles li:nth-child(8) {
    left: 50%;
    width: 25px;
    height: 25px;
    animation-delay: 15s;
    animation-duration: 45s
}

.circles li:nth-child(9) {
    left: 20%;
    width: 15px;
    height: 15px;
    animation-delay: 2s;
    animation-duration: 35s
}

.circles li:nth-child(10) {
    left: 85%;
    width: 150px;
    height: 150px;
    animation-delay: 0;
    animation-duration: 11s
}

@keyframes animate {
    0 {
        transform: translateY(0) rotate(0);
        opacity: 1;
        border-radius: 0
    }

    100% {
        transform: translateY(-1000px) rotate(720deg);
        opacity: 0;
        border-radius: 50%
    }
}

#merit {
    background: #0c43ac
}

#merit .common_h2 {
    margin-bottom: 10px;
}

#merit .common_h2 .lp_img {
    width: 80%;
    margin: auto;
}

#merit .merit_list ul {
    display: flex;
    justify-content: space-between
}

#merit .merit_list ul li {
    width: 31%;
    position: relative;
    filter: drop-shadow(3px 3px 5px rgba(0, 0, 0, 0.5))
}

#merit .merit_list ul li::before {
    content: "";
    display: block;
    width: 100%;
    height: 70%;
    position: absolute;
    bottom: 0;
    left: 0;
    background: #fff
}

#merit .merit_list dl {
    position: relative
}

#merit .merit_list dl dt img {
    display: block
}

#merit .merit_list dl dd {
    padding: 20px;
    font-size: 14px
}

#voice {
    background-image: url(../images/ac/voice_bg.jpg);
    background-size: cover;
    background-attachment: fixed;
    position: relative
}

#voice::before {
    content: "";
    display: block;
    width: 100%;
    height: 200px;
    position: absolute;
    top: 0;
    left: 0;
    background: -moz-linear-gradient(50% 100% 90deg, rgba(0, 0, 0, 0) .05%, rgba(0, 0, 0, 0.6) 100%);
    background: -webkit-linear-gradient(90deg, rgba(0, 0, 0, 0) .05%, rgba(0, 0, 0, 0.6) 100%);
    background: -webkit-gradient(linear, 50% 100%, 50% 0, color-stop(0.0005, rgba(0, 0, 0, 0)), color-stop(1, rgba(0, 0, 0, 0.6)));
    background: -o-linear-gradient(90deg, rgba(0, 0, 0, 0) .05%, rgba(0, 0, 0, 0.6) 100%);
    background: -ms-linear-gradient(90deg, rgba(0, 0, 0, 0) .05%, rgba(0, 0, 0, 0.6) 100%);
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr='#000000', endColorstr='#000000' ,GradientType=0)";
    background: linear-gradient(0, rgba(0, 0, 0, 0) .05%, rgba(0, 0, 0, 0.6) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#000000', endColorstr='#000000', GradientType=0)
}

#voice .wrap {
    position: relative
}

#voice .voice_lead {
    width: 30%;
    margin: 0 auto 50px
}

#voice .uv_box {
    display: flex !important;
    position: relative
}

#voice .uv_box::before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 30px 30px 0;
    border-color: transparent #00a761 transparent transparent;
    position: absolute;
    top: 0;
    right: 0
}

#voice .uv_box.v2 {
    flex-flow: row-reverse
}

#voice .uv_box.v2::before {
    border-width: 30px 30px 0 0;
    border-color: #00a761 transparent transparent transparent;
    top: 0;
    right: inherit;
    left: 0;
}

#voice .uv_box .avatar {
    width: 150px;
    box-sizing: border-box
}

#voice .uv_box .txt {
    width: 80%;
    width: -webkit-calc(100% - 150px);
    width: calc(100% - 150px);
    box-sizing: border-box;
    background: #fff;
    padding: 30px
}

#voice .uv_box .txt h3 {
    font-family: 'ヒラギノ角ゴ ProN W6', 'HiraKakuProN-W6', 'HiraKakuProN-W6', sans-serif;
    font-size: 25px;
    font-weight: bold;
    line-height: 1.5;
    padding-bottom: 29px;
    margin-bottom: 30px;
    border-bottom: dotted 1px #ccc
}

#voice .uv_box .txt h3 span {
    color: #ff6e1d
}

#voice .uv_box .txt p {
    font-size: 15px;
    line-height: 1.5
}

#voice .slick-dots li {
    margin: 0;
}

#voice .slick-dots li button:before {
    opacity: .5;
    color: #fff;
}

#voice .slick-dots li.slick-active button:before {
    opacity: 1;
    color: #00a761;
}

#flow {
    background: #f1f1f1
}

#flow img.flow {
    width: 75%;
    margin: auto
}

#why {
    position: relative;
    background: -moz-linear-gradient(0 50% 0, rgba(0, 113, 188, 1) .14%, rgba(102, 45, 145, 1) 99.81%);
    background: -webkit-linear-gradient(0, rgba(0, 113, 188, 1) .14%, rgba(102, 45, 145, 1) 99.81%);
    background: -webkit-gradient(linear, 0 50%, 100% 50%, color-stop(0.0014, rgba(0, 113, 188, 1)), color-stop(0.9981, rgba(102, 45, 145, 1)));
    background: -o-linear-gradient(0, rgba(0, 113, 188, 1) .14%, rgba(102, 45, 145, 1) 99.81%);
    background: -ms-linear-gradient(0, rgba(0, 113, 188, 1) .14%, rgba(102, 45, 145, 1) 99.81%);
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr='#0071BC', endColorstr='#662D91' ,GradientType=0)";
    background: linear-gradient(90deg, rgba(0, 113, 188, 1) .14%, rgba(102, 45, 145, 1) 99.81%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#0071BC', endColorstr='#662D91', GradientType=1)
}

#why::before {
    content: "";
    display: block;
    width: 100%;
    height: 300px;
    background-image: url(../images/c/why_bg.png);
    background-position: bottom center;
    position: absolute;
    top: 0;
    left: 0;
    right: 0
}

#why .wrap {
    position: relative
}

.reason_list ul li {
    position: relative;
    margin-bottom: 100px
}

.reason_list ul li:last-child {
    margin-bottom: 60px
}

.reason_list ul li .txt {
    width: 60%;
    box-sizing: border-box;
    background: #fff;
    padding: 30px;
    position: absolute;
    bottom: -50px;
    z-index: 2;
    border-radius: 15px;
    box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.1)
}

.reason_list ul li .txt h3 {
    font-family: 'ヒラギノ角ゴ ProN W6', 'HiraKakuProN-W6', 'HiraKakuProN-W6', sans-serif;
    font-weight: 900;
    font-size: 26px;
    line-height: 1.4;
    color: #0c43ac;
    margin-bottom: 20px
}

.reason_list ul li .txt h3 small {
    font-size: 100%;
    letter-spacing: -0.05em
}

.reason_list ul li .img {
    width: 60%;
    height: auto;
    position: relative;
    margin-left: auto;
    z-index: 1
}

.reason_list ul li .img::before {
    content: "";
    display: block;
    padding-top: 60%
}

.reason_list ul li .img img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 15px
}

.reason_list ul li:nth-child(even) .txt {
    right: 0
}

.reason_list ul li:nth-child(even) .img {
    margin-left: inherit
}

#point {
    position: relative
}

#point .wrap {
    position: relative
}

.point_list ul li {
    display: flex;
    justify-content: space-between;
    background: #fff;
    align-items: center;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.15);
    margin-bottom: 30px;
    border-radius: 15px;
    overflow: hidden
}

.point_list ul li:last-child {
    margin-bottom: 0
}

.point_list ul li .img {
    width: 300px;
    box-sizing: border-box
}

.point_list ul li .txt {
    width: 75%;
    width: -webkit-calc(100% - 320px);
    width: calc(100% - 320px);
    display: flex;
    justify-content: space-between;
    align-items: center
}

.point_list ul li .txt i {
    width: 25px
}

.point_list ul li .txt h3 {
    width: 90%;
    width: -webkit-calc(100% - 30px);
    width: calc(100% - 30px);
    font-size: 28px;
    font-weight: bold;
    color: #11376b
}

.point_list ul li:nth-child(odd) {
    flex-flow: row-reverse
}

.point_list ul li:nth-child(odd) .txt {
    box-sizing: border-box;
    padding-left: 30px
}

#job {
    background-image: url(../images/c/point_bg.png);
    background-size: cover;
    background-position: center
}

#job .job_lead {
    width: 85%;
    margin: auto;
}

.content_wrap {
    background: #fff;
    padding: 30px
}

.content_wrap .content_box {
    display: flex;
    justify-content: space-between
}

.content_wrap .info {
    margin-bottom: 30px
}

.content_box .voice {
    width: 72%;
    box-sizing: border-box
}

.content_box .voice section {
    margin-bottom: 15px
}

.content_box .voice section:last-child {
    margin-bottom: 0
}

.content_box .voice h3 {
    background: #dde8fd;
    font-size: 16px;
    font-weight: bold;
    padding: 5px 10px;
    color: #11376b;
    margin-bottom: 10px
}

.content_box .voice p {
    font-size: 15px;
    line-height: 1.5
}

.content_box .time {
    width: 24%
}

#faq h2 {
    text-align: center;
    font-size: 70px;
    font-weight: bold;
    margin-bottom: 50px
}

#faq h2 .sub {
    font-size: 14px;
    line-height: 14px;
    display: block
}

.cta {
    z-index: 10
}

#fixed_btn {
    position: fixed;
    bottom: 10px;
    right: 10px;
    width: 180px;
    z-index: 9
}

#fixed_btn img {
    display: block
}

footer {
    background: #000;
    padding: 50px 0;
    text-align: center;
    position: relative;
    z-index: 10
}

footer .foot_inner {
    width: 98%;
    width: -webkit-calc(100% - 50px);
    width: calc(100% - 50px);
    margin: 0 auto
}

footer p.copy {
    color: #eee;
    font-size: 10px;
    font-weight: 300;
    line-height: 2.5
}

footer p.copy a.tokushoho {
    font-size: 14px;
    text-decoration: none;
    color: #eee;
    transition: all .5s;
    -webkit-transition: all .5s;
    -moz-transition: all .5s
}

footer p.copy a.tokushoho:hover {
    opacity: .7
}

@media screen and (-webkit-min-device-pixel-ratio:0) {}

@media all and (-ms-high-contrast:none) {}

@media only screen and (max-width:1400px) {

    .full_wrap,
    .middle_wrap {
        width: 92%
    }
}

@media only screen and (max-width:960px) {
    .wrap {
        width: 92%
    }
}

@media only screen and (max-width:644px) {
    body {
        font-size: 15px;
        line-height: 1.6
    }

    p {
        font-size: 15px;
        line-height: 1.6
    }

    article.content_article {
        padding: 30px 0
    }

    .lp_bg_dot {
        background-position: 0 0, 9px 9px;
        background-size: 18px 18px
    }

    .lp_bg_line {
        background-image: background-size:80px
    }

    .common_h2 {
        margin-bottom: 30px
    }

    .common_h2 .sub {
        font-size: 10px;
        letter-spacing: 0
    }

    .common_h2 h2 {
        font-size: 6.5vw;
        line-height: 1.5;
        padding-bottom: 30px
    }

    .common_h2 h2::before {
        width: 50px
    }

    .common_h2 h2 span {
        font-size: 120%
    }

    .common_h2_2 {
        margin-bottom: 30px
    }

    .common_h2_2 h2 {
        font-size: 6.5vw
    }

    .common_h2_2 h2 span {
        font-size: 180%
    }

    .common_h2_2::before,
    .common_h2_2::after {
        width: 40px;
        height: 40px;
        top: -2px;
        transform: none;
        -webkit- transform: none
    }

    .common_h2_2::before {
        left: 0
    }

    .common_h2_2::after {
        right: 0
    }

    .brRes {
        display: none
    }

    .brSp {
        display: block
    }

    span.brSp {
        display: inline
    }

    .lp_m {
        margin: 30px 0
    }

    .lp_m_auto {
        margin: 30px auto
    }

    .lp_p {
        padding: 0 16px
    }

    .lp_mt {
        margin-top: 30px
    }

    .lp_pt {
        padding-top: 30px
    }

    .lp_mb {
        margin-bottom: 30px
    }

    .lp_pb {
        padding-bottom: 30px
    }

    img.fr {
        max-width: 120px;
        margin-left: 10px;
        margin-bottom: 10px
    }

    figure figcaption {
        text-align: left;
        font-size: 10px;
        line-height: 1.5;
        margin-top: 5px
    }

    .lp2c {
        display: block
    }

    .lp2c > div {
        width: 100%
    }

    .lp2c > div:last-child {
        margin-top: 30px
    }

    .inner_content .ic_container {
        width: 96%;
        width: -webkit-calc(100% - 32px);
        width: calc(100% - 32px);
        margin: 0 auto 30px
    }

    .inner_content .ic_container > .ic_first_wrap {
        padding: 20px 15px
    }

    .inner_content.be_bg {
        padding: 20px 0
    }

    .inner_content.be_line .ic_container::before {
        height: 30px;
        bottom: -30px
    }

    .inner_content.be_flow .ic_container::before {
        border-width: 16px 20px 0 20px;
        bottom: -23px
    }

    .inner_content.be_border .ic_container {
        border-width: 1px
    }

    .tag_list.be_bg ul {
        padding: 15px
    }

    .tag_list ul li {
        font-size: 16px;
        padding: 15px 10px;
        border-left-width: 10px
    }

    .faq_list ul li {
        padding: 20px 15px
    }

    .faq_list dl dt .txt {
        font-size: 18px
    }

    .faq_list dl i {
        width: 30px;
        height: 30px;
        line-height: 30px;
        font-size: 16px
    }

    .faq_list dl .txt {
        width: -webkit-calc(100% - 40px);
        width: calc(100% - 40px);
        font-size: 14px
    }

    header.hero_area {
        background-image: url(../images/hero/hero_bg.jpg);
        padding-top: 20px
    }

    header.hero_area .hp1 {
        width: 88%;
        filter: drop-shadow(0 0 8px rgba(0, 0, 0, 0.15));
        margin: 0 auto 20px
    }

    header.hero_area .hero_title {
        margin: 0 auto 30px
    }

    header.hero_area .hero_title .hp2 {
        width: 50%
    }

    header.hero_area .hp2c {
        align-items: flex-end;
        align-items: center;
        margin-bottom: 10px;
    }

    header.hero_area .hp2c .lc {
        width: 41%;
        position: relative;
        right: 2%;
    }

    header.hero_area .hp2c .rc {
        width: 59%;
        padding-bottom: 10px
    }

    header.hero_area .hp2c .rc .hp_btn {
        margin: 10px auto 0;
        padding-bottom: 10px
    }

    header.hero_area .hp2c .rc .hp5 {
        display: none
    }

    header.hero_area .hp5.hp5-sp {
        display: block;
        margin: 0 calc(50% - 50vw);
        width: 100vw;
        box-sizing: border-box;
        padding: 10px 0;
        background: #f2f2f2;
    }

    header.hero_area .hp5.hp5-sp img {
        width: 92%;
        margin: auto
    }

    header.hero_area .hp-vin {
        padding-bottom: 15px
    }

    #before_after .ba_sec1 {
        text-align: center;
        padding: 30px 0
    }

    #before_after .ba_sec1 h2 {
        font-size: 6.2vw;
        padding: 12px 20px 5px;
        margin-bottom: 15px
    }

    #before_after .ba_sec1 h2 span {
        font-size: 85%
    }

    #before_after .ba_sec1 p {
        font-size: 20px
    }

    #before_after .ba_sec2 {
        padding: 30px 0
    }

    #before_after .ba_sec2::before {
        width: 60px;
        height: 60px;
        top: -20px
    }

    #before_after .ba_sec2 .ba_list > div {
        width: 48%
    }

    #before_after .ba_sec2 .ba_list h3 {
        font-size: 26px;
        letter-spacing: 0;
        margin-bottom: 5px
    }

    #before_after .ba_sec2 .ba_content {
        padding: 15px;
        box-shadow: 5px 5px 0 #ccc
    }

    #before_after .ba_sec2 .ba_content ul li i {
        width: 18px
    }

    #before_after .ba_sec2 .ba_content ul li .txt {
        width: -webkit-calc(100% - 22px);
        width: calc(100% - 22px);
        font-size: 15px;
        line-height: 1.5
    }

    #about .about_1 {
        width: 90%
    }

    #merit .common_h2 {
        margin-bottom: 10px;
    }

    #merit .common_h2 .lp_img {
        width: 100%;
    }

    #merit .merit_list ul {
        display: block
    }

    #merit .merit_list ul li {
        width: 90%;
        margin: auto;
        margin-bottom: 30px
    }

    #merit .merit_list ul li:last-child {
        margin-bottom: 0
    }

    #merit .merit_list dl dd {
        padding: 20px;
        font-size: 14px
    }

    #voice {
        background: #09141c;
        background-image: url(../images/ac/voice_bg_sp.jpg);
        background-size: contain;
        background-position: top;
        background-attachment: fixed;
        background-repeat: no-repeat;
        overflow: hidden;
    }

    #voice::before {
        height: 150px
    }

    #voice .voice_lead {
        width: 200px;
        margin: 0 auto 30px
    }

    #voice .uv_box {
        display: block !important;
    }

    #voice .uv_box::before {
        content: none;
    }

    #voice .uv_box .avatar {
        width: 100%;
    }

    #voice .uv_box .txt {
        width: -webkit-calc(100%);
        width: calc(100%);
        padding: 20px 15px
    }

    #voice .uv_box .txt h3 {
        font-size: 17px;
        line-height: 1.4;
        padding-bottom: 19px;
        margin-bottom: 20px
    }

    #voice .uv_box .txt p {
        font-size: 14px
    }

    #voice .slick-prev,
    #voice .slick-next {
        top: 5.5%;
        -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
        transform: translate(0, 0);
    }

    #voice .slick-prev {
        left: -9px;
        z-index: 2;
    }

    #voice .slick-next {
        right: -9px;
        z-index: 2;
    }

    #flow img.flow {
        width: 100%
    }

    #why::before {
        height: 300px;
        background-image: url(../images/c/why_bg.png)
    }

    .reason_list ul li {
        margin-bottom: 30px;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }

    .reason_list ul li:last-child {
        margin-bottom: 0
    }

    .reason_list ul li .txt {
        width: 100%;
        padding: 20px;
        position: relative;
        box-shadow: none;
        border-top-right-radius: 0;
        border-top-left-radius: 0;
        bottom: 0;
        -webkit-box-ordinal-group: 2;
        -ms-flex-order: 2;
        -webkit-order: 2;
        order: 2
    }

    .reason_list ul li .txt h3 {
        font-size: 5vw;
        margin-bottom: 15px
    }

    .reason_list ul li .img {
        width: 100%;
        -webkit-box-ordinal-group: 1;
        -ms-flex-order: 1;
        -webkit-order: 1;
        order: 1
    }

    .reason_list ul li .img img {
        border-bottom-right-radius: 0;
        border-bottom-left-radius: 0
    }

    .point_list ul li {
        box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
        margin-bottom: 20px;
        border-radius: 5px
    }

    .point_list ul li .img {
        width: 40%
    }

    .point_list ul li .txt {
        width: 55%;
        width: -webkit-calc(100% - 40%);
        width: calc(100% - 40%);
        box-sizing: border-box;
        padding-left: 10px
    }

    .point_list ul li .txt i {
        width: 16px
    }

    .point_list ul li .txt h3 {
        width: -webkit-calc(100% - 20px);
        width: calc(100% - 20px);
        font-size: 16px;
        line-height: 1.3
    }

    .point_list ul li:nth-child(odd) .txt {
        padding-left: 10px
    }

    #job {
        background-image: url(../images/c/point_bg_sp.png)
    }

    #job .job_lead {
        width: 95%;
    }

    .content_wrap {
        padding: 20px
    }

    .content_wrap .content_box {
        display: block
    }

    .content_wrap .info {
        margin-bottom: 15px
    }

    .content_box .voice {
        width: 100%
    }

    .content_box .time {
        width: 60%;
        margin: 15px auto 0
    }

    #faq h2 {
        font-size: 50px;
        margin-bottom: 30px
    }

    #fixed_btn {
        bottom: 5px;
        right: 5px;
        width: 100px
    }

    footer .foot_inner {
        width: 95%;
        width: -webkit-calc(95%);
        width: calc(95%)
    }
}

/*211014追記*/


/* PC/SP表示切り替え*/

.pc {
    display: block !important;
}

.sp {
    display: none !important;
}


@media only screen and (max-width: 960px) {
    .pc {
        display: none !important;
    }

    .sp {
        display: block !important;
    }

    .hero_attention {
        font-size: 1px;
    }
}

.step {
    background: #0c43ac;
    background: #edecfa
}

.step .common_h2 h2 {
    padding-bottom: 0;
}

.step .common_h2 h2::before {
    content: none;
}

/*220205追記*/

.att {
    text-align: center;
    margin: 0 auto;
    margin-top: 20px;
    margin-bottom: 20px;
    font-size: 14px;
    font-weight: 700;
}

.att_wh {
    color: #fff;
}

.att_sm {
    font-size: 10px;
}

@media only screen and (max-width: 960px) {
    .att {
        font-size: 10px;
    }

    .att_sm {
        font-size: 6px;
    }
}
